/* ============================================================
   DENTIVA — Design System
   Brand tokens reverse-engineered from product UI screenshots.
   Navy / Teal / Gold. Fraunces (display) + Inter (body).
   ============================================================ */

:root {
  /* Core palette */
  --navy:        #0A1929;
  --navy-2:      #0F2440;
  --navy-3:      #163055;
  --navy-700:    #1E3A5F;
  --navy-line:   rgba(255,255,255,.08);

  --teal:        #00897B;
  --teal-600:    #00766A;
  --teal-light:  #4DB6AC;
  --teal-bright: #26C6B5;
  --teal-bg:     #E0F2F1;

  --gold:        #C9A961;
  --gold-light:  #E3C988;
  --gold-bg:     #FAF0D7;

  --cream:       #F7F5F1;
  --paper:       #FFFFFF;
  --ink:         #0C1B2A;
  --ink-2:       #2C3E50;
  --muted:       #5A6B7B;
  --muted-2:     #8A98A6;
  --hairline:    #E7E9EC;

  /* Semantic */
  --green:       #10B981;
  --green-bg:    #DCFCE7;
  --red:         #EF4444;
  --red-bg:      #FEE2E2;
  --amber:       #F59E0B;
  --amber-bg:    #FEF3C7;
  --blue:        #3B82F6;
  --blue-bg:     #DBEAFE;

  /* Typography */
  --font-display: 'Fraunces', ui-serif, Georgia, serif;
  --font-body: 'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --font-mono: 'JetBrains Mono', ui-monospace, 'SF Mono', monospace;

  /* Radius / shadow */
  --r-sm: 8px;
  --r-md: 12px;
  --r-lg: 18px;
  --r-xl: 26px;
  --r-pill: 999px;

  --sh-sm: 0 1px 2px rgba(10,25,41,.06), 0 1px 3px rgba(10,25,41,.10);
  --sh-md: 0 4px 12px rgba(10,25,41,.08), 0 2px 4px rgba(10,25,41,.06);
  --sh-lg: 0 18px 50px rgba(10,25,41,.16), 0 6px 16px rgba(10,25,41,.08);
  --sh-xl: 0 40px 100px rgba(10,25,41,.28), 0 12px 32px rgba(10,25,41,.14);
  --sh-glow: 0 0 0 1px rgba(0,137,123,.18), 0 24px 70px rgba(0,137,123,.22);

  --maxw: 1200px;
  --ease: cubic-bezier(.22,.61,.36,1);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: var(--font-body);
  color: var(--ink);
  background: var(--cream);
  line-height: 1.55;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
::selection { background: rgba(0,137,123,.22); }

/* ---------- Layout helpers ---------- */
.container { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 24px; }
.section { padding: 96px 0; position: relative; }
.section--tight { padding: 64px 0; }
.center { text-align: center; }
.stack-sm > * + * { margin-top: 10px; }
.grid { display: grid; gap: 24px; }
.row { display: flex; gap: 16px; align-items: center; }
.wrap { flex-wrap: wrap; }

/* ---------- Type ---------- */
h1,h2,h3,h4 { font-family: var(--font-display); font-weight: 600; line-height: 1.08; letter-spacing: -.02em; margin: 0; color: var(--ink); }
.display { font-size: clamp(40px, 6.2vw, 76px); font-weight: 600; line-height: 1.02; letter-spacing: -.03em; }
h2.h-sec { font-size: clamp(30px, 4vw, 46px); }
h3 { font-size: clamp(20px, 2.4vw, 26px); }
.lede { font-size: clamp(17px, 1.5vw, 20px); color: var(--muted); line-height: 1.6; }
.eyebrow {
  font-family: var(--font-mono);
  font-size: 12px; font-weight: 600; letter-spacing: .18em; text-transform: uppercase;
  color: var(--teal-600);
}
.eyebrow--gold { color: var(--gold); }
.eyebrow--light { color: var(--teal-light); }
.text-muted { color: var(--muted); }
.balance { text-wrap: balance; }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-body); font-weight: 600; font-size: 15px;
  padding: 13px 22px; border-radius: var(--r-pill); border: 1px solid transparent;
  cursor: pointer; transition: transform .18s var(--ease), box-shadow .18s var(--ease), background .18s var(--ease);
  white-space: nowrap;
}
.btn:active { transform: translateY(1px); }
.btn--gold { background: linear-gradient(180deg, var(--gold-light), var(--gold)); color: #3A2E12; box-shadow: 0 8px 24px rgba(201,169,97,.35); }
.btn--gold:hover { transform: translateY(-2px); box-shadow: 0 14px 34px rgba(201,169,97,.45); }
.btn--teal { background: linear-gradient(180deg, var(--teal-light), var(--teal)); color: #fff; box-shadow: 0 8px 24px rgba(0,137,123,.32); }
.btn--teal:hover { transform: translateY(-2px); box-shadow: 0 14px 34px rgba(0,137,123,.42); }
.btn--ghost { background: rgba(255,255,255,.06); color: #fff; border-color: rgba(255,255,255,.22); }
.btn--ghost:hover { background: rgba(255,255,255,.12); }
.btn--outline { background: transparent; color: var(--ink); border-color: var(--hairline); }
.btn--outline:hover { border-color: var(--teal); color: var(--teal-600); }
.btn--lg { padding: 16px 28px; font-size: 16px; }
.btn--sm { padding: 9px 16px; font-size: 13px; }

/* ---------- Badges / pills ---------- */
.pill {
  display: inline-flex; align-items: center; gap: 6px; white-space: nowrap;
  font-size: 12px; font-weight: 600; letter-spacing: .02em;
  padding: 5px 11px; border-radius: var(--r-pill);
  background: var(--teal-bg); color: var(--teal-600);
}
.pill--gold { background: var(--gold-bg); color: #8A6D1F; }
.pill--soon {
  background: linear-gradient(180deg, var(--gold-bg), #F3E4BB);
  color: #7A5E18; border: 1px solid rgba(201,169,97,.4);
}
.pill--live { background: var(--red-bg); color: #B91C1C; }
.pill--green { background: var(--green-bg); color: #047857; }
.pill--ghost { background: rgba(255,255,255,.08); color: #cfe8e4; border: 1px solid rgba(255,255,255,.14); }
.dot { width: 7px; height: 7px; border-radius: 50%; background: currentColor; }
.dot--pulse { position: relative; }
.dot--pulse::after {
  content: ''; position: absolute; inset: -4px; border-radius: 50%;
  background: currentColor; opacity: .35; animation: pulse 1.8s var(--ease) infinite;
}
@keyframes pulse { 0%{transform:scale(.7);opacity:.6} 70%{transform:scale(2.2);opacity:0} 100%{opacity:0} }

.flag {
  display: inline-grid; place-items: center;
  width: 22px; height: 16px; border-radius: 3px;
  font-family: var(--font-mono); font-size: 9px; font-weight: 700; letter-spacing: .04em;
  color: #fff; background: var(--navy-3);
}
.flag--ru { background: #2563EB; }
.flag--es { background: #DC2626; }
.flag--en { background: #475569; }

/* ---------- Surface cards ---------- */
.card {
  background: var(--paper); border: 1px solid var(--hairline);
  border-radius: var(--r-lg); padding: 28px; box-shadow: var(--sh-sm);
  transition: transform .25s var(--ease), box-shadow .25s var(--ease), border-color .25s var(--ease);
}
.card--hover:hover { transform: translateY(-4px); box-shadow: var(--sh-lg); border-color: rgba(0,137,123,.25); }
.card__icon {
  width: 46px; height: 46px; border-radius: 12px; display: grid; place-items: center;
  background: var(--teal-bg); color: var(--teal-600); margin-bottom: 16px;
}
.card__icon svg { width: 24px; height: 24px; }

/* ============================================================
   NAVBAR
   ============================================================ */
.nav {
  position: sticky; top: 0; z-index: 60;
  background: rgba(247,245,241,.82); backdrop-filter: saturate(180%) blur(14px);
  border-bottom: 1px solid var(--hairline);
}
.nav__inner { display: flex; align-items: center; justify-content: space-between; height: 70px; }
.brand { display: flex; align-items: center; gap: 10px; font-family: var(--font-display); font-weight: 600; font-size: 22px; letter-spacing: -.02em; }
.brand__mark {
  width: 34px; height: 34px; border-radius: 9px; display: grid; place-items: center; color: #fff; font-family: var(--font-display);
  background: linear-gradient(150deg, var(--teal-light), var(--teal-600)); box-shadow: 0 4px 12px rgba(0,137,123,.35);
}
.brand__dot { color: var(--teal); }
.nav__links { display: flex; align-items: center; gap: 28px; }
.nav__links a { font-size: 14.5px; font-weight: 500; color: var(--ink-2); transition: color .15s; }
.nav__links a:hover { color: var(--teal-600); }
.nav__cta { display: flex; align-items: center; gap: 12px; }
.nav__burger { display: none; background: none; border: 0; cursor: pointer; padding: 8px; }
.nav__burger span { display: block; width: 22px; height: 2px; background: var(--ink); margin: 4px 0; border-radius: 2px; transition: .25s; }

/* ============================================================
   HERO
   ============================================================ */
.hero { position: relative; overflow: hidden; background: var(--navy); color: #fff; padding: 84px 0 0; }
.hero::before {
  content: ''; position: absolute; inset: 0;
  background:
    radial-gradient(900px 500px at 78% -8%, rgba(0,137,123,.35), transparent 60%),
    radial-gradient(700px 420px at 8% 12%, rgba(38,198,181,.16), transparent 55%),
    linear-gradient(180deg, var(--navy), var(--navy-2));
}
.hero::after {
  content: ''; position: absolute; inset: 0; opacity: .35;
  background-image: linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 46px 46px; mask-image: radial-gradient(70% 60% at 50% 0%, #000, transparent 75%);
}
.hero__inner { position: relative; z-index: 2; text-align: center; padding-bottom: 70px; }
.hero__grid { display: grid; grid-template-columns: 1fr; gap: 52px; align-items: center; }
.hero__intro { max-width: 880px; margin: 0 auto; }
.hero h1 { color: #fff; }
.hero .lede { color: #B7C7D6; max-width: 620px; margin-left: auto; margin-right: auto; }
.hero__badges { display: flex; gap: 10px; flex-wrap: wrap; margin: 26px 0; justify-content: center; }
.hero__cta { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 30px; justify-content: center; }
.hero__trust { margin-top: 30px; display: flex; gap: 22px; flex-wrap: wrap; color: #8FA6BB; font-size: 13px; justify-content: center; }
.hero__trust b { color: #fff; }
/* Full-width dashboard showcase below the intro — never clipped */
.hero__art { position: relative; width: 100%; max-width: 1120px; margin: 0 auto; min-width: 0; text-align: left; }
.hero__art .appframe { width: 100%; }
.hero__floats { position: absolute; inset: 0; pointer-events: none; }
.floatcard {
  position: absolute; background: rgba(255,255,255,.96); color: var(--ink);
  border-radius: 14px; padding: 12px 14px; box-shadow: var(--sh-lg); font-size: 13px;
  animation: floaty 6s ease-in-out infinite;
}
@keyframes floaty { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-10px)} }

/* ============================================================
   PRODUCT UI — 1:1 dashboard recreation
   ============================================================ */
.appframe {
  background: var(--navy); border-radius: var(--r-xl); overflow: hidden;
  box-shadow: var(--sh-xl); border: 1px solid rgba(255,255,255,.06);
}
.appframe__bar {
  display: flex; align-items: center; gap: 8px; padding: 12px 16px;
  background: rgba(255,255,255,.03); border-bottom: 1px solid var(--navy-line);
}
.appframe__bar i { width: 11px; height: 11px; border-radius: 50%; background: #2a3f57; display: inline-block; }
.appframe__bar i:nth-child(1){background:#ff5f57} .appframe__bar i:nth-child(2){background:#febc2e} .appframe__bar i:nth-child(3){background:#28c840}
.appframe__url { margin-left: 12px; font-family: var(--font-mono); font-size: 11px; color: #6c829a; }

.app {
  display: grid; grid-template-columns: 220px 1fr;
  background: var(--navy); color: #E7EEF5; min-height: 560px;
}

/* Sidebar */
.side { background: var(--navy); border-right: 1px solid var(--navy-line); padding: 18px 14px; display: flex; flex-direction: column; }
.side__brand { display: flex; align-items: center; gap: 9px; font-family: var(--font-display); font-size: 19px; font-weight: 600; padding: 4px 8px 18px; }
.side__brand .brand__mark { width: 28px; height: 28px; font-size: 15px; border-radius: 8px; }
.side__group { margin-top: 14px; }
.side__label { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: .16em; text-transform: uppercase; color: #5b7088; padding: 0 8px 8px; }
.side__item {
  display: flex; align-items: center; gap: 10px; padding: 9px 10px; border-radius: 9px;
  font-size: 13.5px; font-weight: 500; color: #aebfd0; cursor: pointer; transition: .15s; position: relative;
}
.side__item svg { width: 17px; height: 17px; opacity: .85; }
.side__item:hover { background: rgba(255,255,255,.04); color: #fff; }
.side__item.is-active { background: linear-gradient(90deg, rgba(0,137,123,.28), rgba(0,137,123,.08)); color: #fff; }
.side__item.is-active::before { content:''; position:absolute; left:-14px; top:8px; bottom:8px; width:3px; border-radius:0 3px 3px 0; background: var(--teal-light); }
.side__badge { margin-left: auto; font-size: 10.5px; font-weight: 700; padding: 1px 7px; border-radius: 999px; background: var(--teal); color: #fff; }
.side__badge--gold { background: var(--gold); color: #3A2E12; }
.side__practice {
  margin-top: auto; padding: 12px; border-radius: 12px; background: rgba(255,255,255,.04); border: 1px solid var(--navy-line);
}
.side__practice b { font-size: 13px; color: #fff; display: block; }
.side__practice span { font-size: 11px; color: #7c91a8; }
.side__langs { display: flex; gap: 5px; margin-top: 8px; }

/* Main */
.appmain { padding: 22px 26px; overflow: hidden; background: var(--navy); }
.appmain__top { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; }
.crumb { font-family: var(--font-mono); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: #5b7088; }
.appmain h2 { color: #fff; font-size: 27px; margin-top: 4px; }
.app-right { display: flex; align-items: center; gap: 10px; }
.avatar { width: 34px; height: 34px; border-radius: 50%; display: grid; place-items: center; font-weight: 700; font-size: 12px; color: #fff; background: linear-gradient(150deg,#3a5a82,#1e3a5f); }

.statgrid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin-top: 20px; }
.stat {
  background: rgba(255,255,255,.035); border: 1px solid var(--navy-line); border-radius: 14px; padding: 15px 16px;
}
.stat__label { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: .12em; text-transform: uppercase; color: #6c829a; }
.stat__value { font-family: var(--font-display); font-size: 30px; font-weight: 600; color: #fff; margin: 6px 0 4px; }
.stat__sub { font-size: 11px; color: #8fa6bb; }
.stat__sub b { color: var(--teal-light); }
.stat--hero { background: linear-gradient(160deg, var(--navy-3), var(--navy-2)); border-color: rgba(0,137,123,.3); box-shadow: inset 0 0 0 1px rgba(0,137,123,.12); }
.stat--hero .stat__value { color: var(--teal-light); }

.panels { display: grid; grid-template-columns: 1.55fr 1fr; gap: 14px; margin-top: 16px; }
.panel { background: rgba(255,255,255,.035); border: 1px solid var(--navy-line); border-radius: 14px; padding: 16px; }
.panel__head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.panel__title { display: flex; align-items: center; gap: 8px; font-size: 13px; font-weight: 600; color: #cfe0f0; }
.panel__link { font-size: 11px; color: var(--teal-light); }

/* Calls list inside app */
.callrow { display: flex; align-items: center; gap: 11px; padding: 9px 4px; border-top: 1px solid rgba(255,255,255,.05); }
.callrow:first-of-type { border-top: 0; }
.callrow__name { font-size: 13px; font-weight: 600; color: #eaf1f8; }
.callrow__meta { font-size: 11px; color: #7c91a8; }
.callrow__right { margin-left: auto; text-align: right; }
.tag { font-size: 9.5px; font-weight: 700; letter-spacing: .03em; padding: 2px 7px; border-radius: 5px; text-transform: uppercase; }
.tag--new { background: rgba(77,182,172,.18); color: var(--teal-light); }
.tag--react { background: rgba(201,169,97,.18); color: var(--gold-light); }
.tag--emerg { background: rgba(239,68,68,.18); color: #fca5a5; }

/* Live call panel */
.live { background: linear-gradient(165deg, #0d2a2c, #0b2138); border-color: rgba(0,137,123,.3); }
.live__num { font-family: var(--font-mono); font-size: 18px; color: #fff; margin: 4px 0; }
.live__detect { font-size: 11px; color: #8fa6bb; }
.wave { display: flex; align-items: flex-end; gap: 3px; height: 38px; margin: 14px 0; }
.wave i { flex: 1; background: linear-gradient(180deg, var(--teal-light), var(--teal)); border-radius: 2px; animation: wave 1.1s ease-in-out infinite; }
@keyframes wave { 0%,100%{height:18%} 50%{height:100%} }
.bubble { font-size: 11.5px; line-height: 1.45; padding: 8px 11px; border-radius: 12px; margin-bottom: 7px; max-width: 92%; }
.bubble--in { background: rgba(255,255,255,.07); color: #d8e4f0; }
.bubble--ai { background: rgba(0,137,123,.22); color: #d5f3ee; margin-left: auto; }
.bubble small { display:block; font-size: 9px; color: #7c91a8; margin-bottom: 2px; letter-spacing: .04em; }
.live__actions { display: flex; gap: 8px; margin-top: 12px; }
.live__actions .btn { flex: 1; justify-content: center; }

/* X-ray viewer */
.xray { background:#0b1620; border:1px solid var(--navy-line); border-radius:14px; padding:16px; }
.xray__view { position: relative; background: radial-gradient(circle at 50% 40%, #1c2733, #0a121b); border-radius: 10px; aspect-ratio: 16/9; overflow:hidden; }
.teeth { position:absolute; inset: 22% 12% 30%; display:flex; gap:6px; align-items:flex-end; }
.tooth { flex:1; background: linear-gradient(180deg,#cfd6dc,#9aa6b0); border-radius: 6px 6px 3px 3px; box-shadow: inset 0 -6px 10px rgba(0,0,0,.25); }
.xbox { position:absolute; border:2px solid; border-radius:4px; font-family:var(--font-mono); font-size:9px; font-weight:700; padding:1px 4px; }
.xbox--caries { border-color:#ff5a5a; color:#ff8a8a; }
.xbox--bone { border-color:#f5a623; color:#ffc874; }
.xbox span { position:absolute; top:-16px; left:-2px; white-space:nowrap; }
.xray__meta { font-family:var(--font-mono); font-size:10px; color:#6c829a; margin-top:8px; display:flex; justify-content:space-between; }
.finding { display:flex; gap:10px; padding:11px 0; border-top:1px solid rgba(255,255,255,.06); }
.finding:first-child { border-top:0; }
.finding__ic { width:22px;height:22px;border-radius:6px;display:grid;place-items:center;flex:none;font-size:12px;font-weight:700; }
.finding__ic--red{background:rgba(239,68,68,.2);color:#fca5a5} .finding__ic--amber{background:rgba(245,158,11,.2);color:#fcd34d} .finding__ic--green{background:rgba(16,185,129,.2);color:#6ee7b7}
.finding b { font-size:12.5px;color:#eaf1f8 } .finding p { margin:2px 0 0; font-size:11px; color:#8fa6bb }
.finding .conf { font-family:var(--font-mono); font-size:10px; color:var(--teal-light); }

/* ============================================================
   FEATURE / CONTENT SECTIONS
   ============================================================ */
.features-grid { grid-template-columns: repeat(3, 1fr); }
.feat__soon { float: right; }
.split { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }
.split--rev .split__media { order: -1; }
.checklist { list-style: none; padding: 0; margin: 18px 0 0; }
.checklist li { display: flex; gap: 10px; padding: 7px 0; font-size: 15px; color: var(--ink-2); }
.checklist svg { flex: none; width: 20px; height: 20px; color: var(--teal); margin-top: 1px; }

.stats-band { background: var(--navy); color:#fff; }
.stats-grid { grid-template-columns: repeat(4, 1fr); }
.stats-band .num { font-family: var(--font-display); font-size: clamp(36px,5vw,56px); color: var(--teal-light); font-weight:600; }
.stats-band .cap { color:#8fa6bb; font-size:14px; margin-top:4px; }

.steps { grid-template-columns: repeat(3,1fr); counter-reset: s; }
.step__n { font-family: var(--font-display); font-size: 40px; color: var(--teal-light); opacity:.5; }

/* Calculator */
.calc { background: linear-gradient(165deg, var(--navy-2), var(--navy)); color:#fff; border-radius: var(--r-xl); padding: 40px; box-shadow: var(--sh-xl); }
.calc__grid { display:grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items:center; }
.calc label { display:flex; justify-content:space-between; font-size:13px; color:#b7c7d6; margin: 18px 0 8px; }
.calc label b { color:#fff; font-family:var(--font-mono); }
input[type=range]{ -webkit-appearance:none; appearance:none; width:100%; height:6px; border-radius:99px; background: rgba(255,255,255,.14); outline:none; }
input[type=range]::-webkit-slider-thumb{ -webkit-appearance:none; width:22px;height:22px;border-radius:50%; background:linear-gradient(180deg,var(--teal-light),var(--teal)); cursor:pointer; box-shadow:0 4px 12px rgba(0,137,123,.5); }
.calc__out { text-align:center; }
.calc__big { font-family:var(--font-display); font-size: clamp(48px,7vw,72px); color: var(--teal-light); font-weight:600; line-height:1; }
.calc__row { display:flex; justify-content:space-around; margin-top:24px; padding-top:24px; border-top:1px solid var(--navy-line); }

/* Pricing */
.price-grid { grid-template-columns: repeat(3,1fr); align-items: stretch; }
.price { display:flex; flex-direction:column; }
.price--feature { background: var(--navy); color:#fff; border-color: transparent; box-shadow: var(--sh-lg); position:relative; }
.price--feature .price__amt { color:#fff; }
.price__amt { font-family:var(--font-display); font-size:46px; font-weight:600; }
.price__amt span { font-size:15px; color:var(--muted); font-family:var(--font-body); }
.price--feature .price__amt span { color:#8fa6bb; }
.price ul { list-style:none; padding:0; margin: 18px 0; flex:1; }
.price li { display:flex; gap:9px; padding:7px 0; font-size:14px; border-top:1px solid var(--hairline); }
.price--feature li { border-color: rgba(255,255,255,.08); color:#cfe0f0; }
.price li svg { flex:none; width:18px;height:18px; color:var(--teal); }
.price--feature li svg { color: var(--teal-light); }
.price__ribbon { position:absolute; top:-12px; left:50%; transform:translateX(-50%); }
.toggle { display:inline-flex; background:#fff; border:1px solid var(--hairline); border-radius:99px; padding:4px; gap:4px; }
.toggle button { border:0; background:none; padding:8px 18px; border-radius:99px; font-weight:600; font-size:14px; color:var(--muted); cursor:pointer; }
.toggle button.is-on { background: var(--ink); color:#fff; }

/* FAQ */
.faq__item { border-bottom:1px solid var(--hairline); }
.faq__q { display:flex; justify-content:space-between; align-items:center; gap:16px; padding:22px 0; cursor:pointer; font-family:var(--font-display); font-size:19px; font-weight:600; }
.faq__q .ic { flex:none; width:26px;height:26px;border-radius:50%; border:1px solid var(--hairline); display:grid;place-items:center; transition:.25s; }
.faq__item.is-open .ic { transform: rotate(45deg); background:var(--teal); color:#fff; border-color:var(--teal); }
.faq__a { max-height:0; overflow:hidden; transition:max-height .3s var(--ease); color:var(--muted); }
.faq__a p { padding: 0 0 22px; margin:0; max-width: 760px; }
.faq__item.is-open .faq__a { max-height: 320px; }

/* Logos / trust strip */
.trustbar { border-top:1px solid var(--hairline); border-bottom:1px solid var(--hairline); background:#fff; }
.trustbar__inner { display:flex; align-items:center; justify-content:center; gap:42px; flex-wrap:wrap; padding:26px 0; opacity:.7; }
.trustbar b { font-family:var(--font-display); font-size:18px; color:var(--muted); }

/* CTA */
.cta { background: var(--navy); color:#fff; border-radius: var(--r-xl); padding: 64px; text-align:center; position:relative; overflow:hidden; }
.cta::before { content:''; position:absolute; inset:0; background: radial-gradient(700px 360px at 50% -20%, rgba(0,137,123,.4), transparent 60%); }
.cta > * { position:relative; }
.cta h2 { color:#fff; }

/* Footer */
.footer { background: var(--navy); color:#8fa6bb; padding: 64px 0 32px; }
.footer__grid { display:grid; grid-template-columns: 1.6fr repeat(3,1fr); gap:32px; }
.footer h4 { color:#fff; font-family:var(--font-body); font-size:13px; letter-spacing:.06em; text-transform:uppercase; margin-bottom:14px; }
.footer a { display:block; padding:5px 0; font-size:14px; color:#8fa6bb; transition:.15s; }
.footer a:hover { color:#fff; }
.footer__bottom { margin-top:40px; padding-top:24px; border-top:1px solid var(--navy-line); display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px; font-size:13px; }

/* Reveal on scroll */
.reveal { opacity:0; transform: translateY(24px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.is-in { opacity:1; transform:none; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
  .hero__grid, .split, .calc__grid { grid-template-columns: 1fr; }
  .features-grid, .steps { grid-template-columns: repeat(2,1fr); }
  .price-grid { grid-template-columns: 1fr; max-width: 460px; margin: 0 auto; }
  .footer__grid { grid-template-columns: 1fr 1fr; }
  .app { grid-template-columns: 1fr; }
  .side { display:none; }
}
@media (max-width: 720px) {
  .section { padding: 64px 0; }
  .nav__links { display:none; }
  .nav__burger { display:block; }
  .nav__cta .btn--outline { display:none; }
  .nav.is-open .nav__links {
    display:flex; position:absolute; top:70px; left:0; right:0; flex-direction:column;
    background:#fff; padding:18px 24px; gap:14px; border-bottom:1px solid var(--hairline); box-shadow:var(--sh-md);
  }
  .features-grid, .steps, .statgrid, .panels { grid-template-columns: 1fr; }
  .stats-grid { grid-template-columns: repeat(2, 1fr); gap: 28px 14px; }
  .cta { padding: 40px 24px; }
  .calc { padding: 28px; }
}

/* ============================================================
   Demo modal + Formspree form (Order #4 — appended, additive)
   ============================================================ */
.modal { position:fixed; inset:0; z-index:1000; display:flex; align-items:center; justify-content:center; }
.modal__overlay { position:absolute; inset:0; background:rgba(10,25,41,.7); backdrop-filter:blur(4px); }
.modal__box { position:relative; background:#fff; border-radius:16px; padding:40px; max-width:480px; width:90%; max-height:90vh; overflow-y:auto; z-index:1; box-shadow:var(--sh-xl); }
.modal__close { position:absolute; top:16px; right:16px; background:none; border:none; font-size:20px; cursor:pointer; color:var(--muted); }
.modal__box h2 { font-family:var(--font-display); font-size:1.6rem; margin-bottom:8px; }
.modal__box .field { margin-bottom:16px; }
.modal__box label { display:block; font-size:.875rem; font-weight:600; margin-bottom:6px; color:var(--ink); }
.modal__box input, .modal__box select { width:100%; padding:10px 14px; border:1.5px solid #E2E8F0; border-radius:8px; font-size:1rem; font-family:var(--font-body); }
.modal__box input:focus, .modal__box select:focus { outline:none; border-color:var(--teal); }
.btn--block { width:100%; justify-content:center; margin-top:8px; }
.formnote { font-size:.8rem; color:var(--muted); text-align:center; margin-top:10px; }

/* ============================================================
   Wave-1 subpage building blocks — ADDITIVE ONLY (do not edit above).
   Uses locked brand tokens only. Added for /pricing /demo /product/* /security /privacy /terms.
   ============================================================ */
.page-hero{background:var(--navy);color:#fff;padding:118px 0 72px;text-align:center}
.page-hero .eyebrow{color:var(--gold-light)}
.page-hero h1{color:#fff;font-family:var(--font-display);font-size:clamp(2.1rem,5vw,3.3rem);line-height:1.06;margin:14px auto 18px;max-width:800px}
.page-hero p{color:#cbd5e1;max-width:640px;margin:0 auto 28px;font-size:1.12rem;line-height:1.6}
.page-hero .btn{margin:0 6px}
.prose{max-width:760px;margin:0 auto}
.prose h2{font-family:var(--font-display);font-size:1.5rem;color:var(--navy);margin:34px 0 10px}
.prose h3{font-family:var(--font-display);color:var(--navy);margin:22px 0 6px}
.prose p,.prose li{color:var(--muted);line-height:1.7}
.prose ul{padding-left:20px;margin:8px 0}
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:44px;align-items:stretch}
@media(max-width:880px){.pricing-grid{grid-template-columns:1fr}}
.plan{background:#fff;border:1.5px solid #E2E8F0;border-radius:18px;padding:32px 28px;display:flex;flex-direction:column}
.plan--featured{border-color:var(--teal);box-shadow:0 22px 54px -22px rgba(0,137,123,.4);position:relative}
.plan__badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--gold);color:var(--navy);font-size:.72rem;font-weight:700;padding:5px 14px;border-radius:100px;letter-spacing:.03em;white-space:nowrap}
.plan__name{font-family:var(--font-display);font-size:1.25rem;color:var(--navy)}
.plan__price{font-size:2rem;font-weight:700;color:var(--navy);font-family:var(--font-display);margin-top:6px}
.plan__price small{font-size:.95rem;font-weight:500;color:var(--muted)}
.plan__sub{color:var(--muted);font-size:.9rem;margin-bottom:6px}
.plan ul{list-style:none;padding:0;margin:14px 0 22px;display:flex;flex-direction:column;gap:9px}
.plan li{color:var(--ink);font-size:.95rem;padding-left:22px;position:relative}
.plan li::before{content:"✓";position:absolute;left:0;color:var(--teal);font-weight:700}
.plan .btn{margin-top:auto;width:100%;justify-content:center}
.founding{margin-top:40px;background:rgba(201,169,97,.1);border:1px solid rgba(201,169,97,.4);border-radius:16px;padding:30px;text-align:center}
.founding h3{font-family:var(--font-display);color:var(--navy);margin-bottom:6px}
.founding p{color:var(--muted);margin-bottom:16px}
.compare{width:100%;border-collapse:collapse;margin-top:34px;font-size:.95rem;background:#fff;border-radius:14px;overflow:hidden;box-shadow:0 10px 30px -18px rgba(10,25,41,.25)}
.compare th,.compare td{padding:13px 16px;text-align:left;border-bottom:1px solid #E2E8F0}
.compare thead th{background:var(--navy);color:#fff;font-weight:600}
.compare .hl{background:rgba(201,169,97,.08);font-weight:600;color:var(--teal-600)}
.compare thead th.hl{background:var(--teal);color:#fff}
.demo-split{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:start}
@media(max-width:880px){.demo-split{grid-template-columns:1fr}}
.demo-benefits{list-style:none;padding:0;display:flex;flex-direction:column;gap:14px;margin-top:10px}
.demo-benefits li{padding-left:30px;position:relative;color:var(--ink);font-size:1.05rem}
.demo-benefits li::before{content:"✓";position:absolute;left:0;color:var(--teal);font-weight:700;font-size:1.1rem}
.inline-form{background:#fff;border:1.5px solid #E2E8F0;border-radius:16px;padding:30px}
.inline-form .field{margin-bottom:16px}
.inline-form label{display:block;font-size:.875rem;font-weight:600;margin-bottom:6px;color:var(--ink)}
.inline-form input,.inline-form select{width:100%;padding:11px 14px;border:1.5px solid #E2E8F0;border-radius:8px;font-size:1rem;font-family:var(--font-body)}
.inline-form input:focus,.inline-form select:focus{outline:none;border-color:var(--teal)}
.roi-box{max-width:560px;margin:28px auto 0;background:var(--navy);color:#fff;border-radius:16px;padding:28px;text-align:center}
.roi-box .big{font-family:var(--font-display);font-size:2.2rem;color:var(--gold-light);margin:4px 0}
