[hidden]{display:none !important;}
/* ============================================================
   Signature Cleans — Design System
   Navy + olive-lime, bold geometric sans (Plus Jakarta Sans)
   ============================================================ */

/* Self-hosted Plus Jakarta Sans (variable, latin) — was Google Fonts @import.
   Self-hosting removes the render-blocking external request → better CWV/LCP. */
@font-face {
  font-family: 'Plus Jakarta Sans';
  font-style: normal;
  font-weight: 200 800;
  font-display: swap;
  src: url('../fonts/plus-jakarta-sans-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Plus Jakarta Sans';
  font-style: italic;
  font-weight: 200 800;
  font-display: swap;
  src: url('../fonts/plus-jakarta-sans-latin-italic.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

:root {
  /* Brand */
  --navy:        #16265c;
  --navy-700:    #1c3270;
  --navy-600:    #24407f;
  --navy-deep:   #0d1840;
  --green:       #a8cf45;
  --green-600:   #9bc23a;
  --green-700:   #8aae2f;

  /* Neutrals (cool, low chroma) */
  --ink:         #16265c;   /* headings */
  --body:        #4a5670;   /* paragraph text */
  --muted:       #74809a;   /* captions */
  --line:        #e4e9f2;
  --line-strong: #d3dbe9;
  --bg:          #ffffff;
  --bg-soft:     #f1f5fc;   /* light blue-grey sections */
  --bg-soft-2:   #eaf0fa;
  --card:        #ffffff;

  /* Accents */
  --gold:        #f6a91b;

  /* Type */
  --font: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  /* Radius + shadow */
  --r-sm: 10px;
  --r:    16px;
  --r-lg: 22px;
  --r-xl: 28px;
  --r-pill: 999px;
  --shadow-sm: 0 2px 8px rgba(22,38,92,.06);
  --shadow:    0 10px 30px rgba(22,38,92,.08);
  --shadow-lg: 0 30px 70px rgba(13,24,64,.16);

  /* Layout */
  --maxw: 1200px;
  --gut: 24px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 96px; -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: var(--font);
  color: var(--body);
  background: var(--bg);
  font-size: 17px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; }
::selection { background: var(--green); color: var(--navy); }

h1, h2, h3, h4 {
  color: var(--ink);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.05;
  margin: 0;
  text-wrap: balance;
}
p { margin: 0; text-wrap: pretty; }

/* ---------- Layout helpers ---------- */
.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 var(--gut); }
.section { padding: 96px 0; }
.section-soft { background: linear-gradient(180deg, var(--bg-soft) 0%, var(--bg-soft-2) 100%); }
.grid { display: grid; gap: 28px; }

/* Eyebrow label with leading line */
.eyebrow {
  display: inline-flex; align-items: center; gap: 12px;
  font-size: 13px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase;
  color: var(--navy-600);
}
.eyebrow::before { content: ""; width: 28px; height: 2px; background: var(--green); border-radius: 2px; }
.eyebrow.on-dark { color: var(--green); }
.eyebrow.on-dark::before { background: var(--green); }

/* Section heading block */
.head-xl { font-size: clamp(34px, 4.4vw, 52px); }
.head-lg { font-size: clamp(28px, 3.4vw, 42px); }
.lead { font-size: 18px; color: var(--body); max-width: 46ch; }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  font-weight: 700; font-size: 16px;
  padding: 15px 26px; border-radius: var(--r-pill);
  border: 1.5px solid transparent; transition: .2s ease;
  white-space: nowrap;
}
.btn .arr { transition: transform .2s ease; }
.btn:hover .arr { transform: translateX(4px); }
.btn-green { background: var(--green); color: var(--navy); }
.btn-green:hover { background: var(--green-600); box-shadow: 0 10px 24px rgba(168,207,69,.35); }
.btn-navy { background: var(--navy); color: #fff; }
.btn-navy:hover { background: var(--navy-700); box-shadow: 0 10px 24px rgba(22,38,92,.28); }
.btn-ghost { background: #fff; color: var(--navy); border-color: var(--line-strong); }
.btn-ghost:hover { border-color: var(--navy); }
.btn-lg { padding: 18px 32px; font-size: 17px; }
.btn-block { width: 100%; justify-content: center; }

/* link arrow */
.link-arrow { display: inline-flex; align-items: center; gap: 8px; font-weight: 700; color: var(--navy-600); }
.link-arrow .arr { transition: transform .2s ease; }
.link-arrow:hover .arr { transform: translateX(4px); }

/* ---------- Placeholder imagery ---------- */
.ph {
  position: relative; overflow: hidden; border-radius: var(--r);
  background:
    repeating-linear-gradient(135deg, #dfe6f1 0 2px, transparent 2px 14px),
    linear-gradient(135deg, #eef2fa, #e3eaf6);
  display: grid; place-items: center;
}
.ph::after {
  content: attr(data-label);
  font-family: ui-monospace, 'SF Mono', Menlo, monospace;
  font-size: 12px; letter-spacing: .04em; color: #8f9bb3;
  background: rgba(255,255,255,.7); padding: 6px 12px; border-radius: 6px;
}
.ph.dark {
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,.05) 0 2px, transparent 2px 14px),
    linear-gradient(135deg, var(--navy-700), var(--navy-deep));
}
.ph.dark::after { color: #c9d3ea; background: rgba(13,24,64,.45); }

/* ---------- Pills / chips ---------- */
.chip {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 9px 16px; border-radius: var(--r-pill);
  background: #fff; border: 1px solid var(--line); font-weight: 600; font-size: 14.5px; color: var(--ink);
  transition: .18s ease;
}
.chip .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--green); }
.chip.on-dark { background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.16); color: #eaf0fb; }
.chip.area:hover { border-color: var(--navy); transform: translateY(-2px); box-shadow: var(--shadow-sm); }

/* stars */
.stars { display: inline-flex; gap: 2px; color: var(--gold); }

/* Scroll-reveal: kept visually neutral so content is NEVER hidden behind an
   animation (some embedded preview engines freeze CSS animation timelines).
   Real browsers still get the gentle transition below. */
.fade-up { opacity: 1; transform: none; transition: opacity .5s ease, transform .5s ease; }
.fade-up.in { opacity: 1; transform: none; }

@media (prefers-reduced-motion: reduce) {
  * { scroll-behavior: auto !important; }
  .fade-up { opacity: 1; transform: none; transition: none; }
}
