/* ============================================================
   MEVY · marketing site — main.css
   Hand-written. No framework, no reset library.
   Visual canon: docs/design/mevy_canonical.html
   Discipline: hero visuals flow on the page (no card);
               structured info groups ARE cards.
   Warnings/errors use amber only — the danger hue is forbidden.
   ============================================================ */

/* ============== RESET ============== */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }
body { min-height: 100vh; }
/* Horizontal-overflow guard. MUST be `clip`, not `hidden`: `overflow-x: hidden`
   computes `overflow-y` to `auto`, turning <html>/<body> into a scroll container,
   which silently breaks every `position: sticky` (the signature river never pins
   → ~1.2 empty screens of track). `clip` guards the same overflow WITHOUT making a
   scroll container, so sticky pins to the viewport. (`hidden` kept as the pre-clip
   fallback; any browser new enough for color-mix() also supports clip.) */
html, body { max-width: 100%; overflow-x: hidden; overflow-x: clip; }
img, svg { display: block; max-width: 100%; }
button { font: inherit; color: inherit; background: none; border: none; cursor: pointer; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }
:focus-visible { outline: 2px solid var(--sage); outline-offset: 3px; border-radius: 4px; }
::selection { background: color-mix(in srgb, var(--sage) 28%, transparent); }

/* ============================================================
   TOKENS — light is the base; dark is applied via system
   preference OR the manual [data-theme] override.
   ============================================================ */
:root {
  /* surfaces */
  --bg: #FAF5E8;
  --bg-2: #F3EAD3;
  --ink: #1E2A24;
  --ink-dim: rgba(30, 42, 36, .68);
  --ink-faint: rgba(30, 42, 36, .66);   /* AA 4.7:1 — eyebrows / placeholder / ai-disclaimer are small text */
  --ink-ghost: rgba(30, 42, 36, .32);

  /* accent */
  --sage: #3D7A63;
  --sage-glow: #5FA784;
  --sage-deep: #2B5847;
  --orb-hi: #6FB394;

  /* warm / amber (warnings are amber; the danger hue is forbidden) */
  --warm: #C4933A;
  --warn: #B87B2E;
  --warn-ink: #825016;   /* deep amber for warning TEXT — clears AA 4.5:1 on the warm bg */
  --sun: #E8A740;

  /* person colours (each family member keeps their hue) */
  --p-self: #3D7A63;
  --p-mom: #C9923A;
  --p-dad: #B97A82;
  --p-sibling: #8E7AAA;
  --p-child: #5C8FB0;
  --on-person: #FFFFFF;   /* initials on a person-coloured avatar (same both themes) */

  /* lines & cards */
  --hairline: rgba(30, 42, 36, .08);
  --hairline-strong: rgba(30, 42, 36, .12);
  --card-bg: rgba(255, 255, 255, .72);
  --card-border: rgba(30, 42, 36, .09);
  --card-radius: 24px;
  --shadow-card: 0 18px 40px -28px rgba(30, 42, 36, .28);
  --shadow-phone: 0 50px 110px -30px rgba(61, 122, 99, .28), 0 0 0 1px rgba(30, 42, 36, .06);

  /* glass nav */
  --nav-bg: rgba(250, 245, 232, .72);

  /* orb (light = warm sun, per canon) */
  --orb-core-hi: #FFF5D9;
  --orb-core-mid: #F2C965;
  --orb-core-lo: #C4933A;
  --orb-glow: rgba(242, 201, 101, .50);
  --orb-ring: rgba(196, 147, 58, .32);

  /* phone */
  --phone-frame-a: #E8E2D2;
  --phone-frame-b: #D4CCBB;
  --phone-screen: #FAF5E8;

  /* ambient */
  --amb-1: rgba(216, 187, 110, .30);
  --amb-2: rgba(141, 215, 179, .20);
  --stars-opacity: 0;

  /* motion */
  --ease-std: cubic-bezier(.22, .6, .2, 1);
  --ease-page: cubic-bezier(.32, .72, 0, 1);
  --dur-reveal: 640ms;

  /* layout */
  --page-edge: clamp(20px, 5vw, 72px);
  --maxw: 1180px;
  --maxw-narrow: 760px;

  color-scheme: light;
}

/* dark token block (kept identical in both selectors below) */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) {
    --bg: #0E1512;
    --bg-2: #0A100E;
    --ink: #EFE9DC;
    --ink-dim: rgba(239, 233, 220, .64);
    --ink-faint: rgba(239, 233, 220, .54);
    --ink-ghost: rgba(239, 233, 220, .30);

    --sage: #8DD7B3;
    --sage-glow: #C4F0D6;
    --sage-deep: #3D7A63;
    --orb-hi: #C4F0D6;

    --warm: #F2B97E;
    --warn: #E5A555;
    --warn-ink: #E5A555;
    --sun: #FFE08A;

    --p-self: #8DD7B3;
    --p-mom: #D89440;
    --p-dad: #D98C97;
    --p-sibling: #B8A4E8;
    --p-child: #7FA8C9;

    --hairline: rgba(246, 242, 233, .08);
    --hairline-strong: rgba(246, 242, 233, .12);
    --card-bg: rgba(246, 242, 233, .05);
    --card-border: rgba(246, 242, 233, .10);
    --shadow-card: 0 24px 50px -30px rgba(0, 0, 0, .7);
    --shadow-phone: 0 60px 140px -30px rgba(0, 0, 0, .9), 0 0 0 1px rgba(255, 255, 255, .05);

    --nav-bg: rgba(14, 21, 18, .68);

    --orb-core-hi: #C4F0D6;
    --orb-core-mid: #8DD7B3;
    --orb-core-lo: #3D7A63;
    --orb-glow: rgba(141, 215, 179, .50);
    --orb-ring: rgba(141, 215, 179, .28);

    --phone-frame-a: #15161A;
    --phone-frame-b: #0B0C0E;
    --phone-screen: #0E1512;

    --amb-1: rgba(141, 215, 179, .20);
    --amb-2: rgba(216, 148, 64, .12);
    --stars-opacity: .5;

    color-scheme: dark;
  }
}
:root[data-theme="dark"] {
  --bg: #0E1512;
  --bg-2: #0A100E;
  --ink: #EFE9DC;
  --ink-dim: rgba(239, 233, 220, .64);
  --ink-faint: rgba(239, 233, 220, .48);
  --ink-ghost: rgba(239, 233, 220, .30);

  --sage: #8DD7B3;
  --sage-glow: #C4F0D6;
  --sage-deep: #3D7A63;
  --orb-hi: #C4F0D6;

  --warm: #F2B97E;
  --warn: #E5A555;
  --warn-ink: #E5A555;
  --sun: #FFE08A;

  --p-self: #8DD7B3;
  --p-mom: #D89440;
  --p-dad: #D98C97;
  --p-sibling: #B8A4E8;
  --p-child: #7FA8C9;

  --hairline: rgba(246, 242, 233, .08);
  --hairline-strong: rgba(246, 242, 233, .12);
  --card-bg: rgba(246, 242, 233, .05);
  --card-border: rgba(246, 242, 233, .10);
  --shadow-card: 0 24px 50px -30px rgba(0, 0, 0, .7);
  --shadow-phone: 0 60px 140px -30px rgba(0, 0, 0, .9), 0 0 0 1px rgba(255, 255, 255, .05);

  --nav-bg: rgba(14, 21, 18, .68);

  --orb-core-hi: #C4F0D6;
  --orb-core-mid: #8DD7B3;
  --orb-core-lo: #3D7A63;
  --orb-glow: rgba(141, 215, 179, .50);
  --orb-ring: rgba(141, 215, 179, .28);

  --phone-frame-a: #15161A;
  --phone-frame-b: #0B0C0E;
  --phone-screen: #0E1512;

  --amb-1: rgba(141, 215, 179, .20);
  --amb-2: rgba(216, 148, 64, .12);
  --stars-opacity: .5;

  color-scheme: dark;
}

/* ============== BASE ============== */
body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  /* base wash only — the aurora radials moved to .ambient-aurora (a fixed layer
     that slow-drifts), so the cream is alive instead of dead-flat. */
  background: linear-gradient(180deg, var(--bg) 0%, var(--bg-2) 100%);
  color: var(--ink);
  line-height: 1.5;
  overflow-x: hidden;
  overflow-x: clip;   /* see reset note line 15: `clip` not `hidden`, or it kills the sticky river. This body rule wins over the grouped reset, so it must match. */
  transition: background-color .5s var(--ease-std), color .5s var(--ease-std);
}

.skip-link {
  position: absolute; top: -100px; left: 16px; z-index: 999;
  background: var(--sage); color: var(--bg);
  padding: 10px 18px; border-radius: 100px;
  font-family: 'JetBrains Mono', monospace; font-size: 12px; letter-spacing: .08em;
  transition: top .2s var(--ease-std);
}
.skip-link:focus { top: 16px; }

.visually-hidden {
  position: absolute; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0;
}

/* ============== AMBIENT FIELD ============== */
.ambient { position: fixed; inset: 0; z-index: -1; pointer-events: none; overflow: clip; }
/* slow autonomous aurora — "the morning is awake whether or not you are."
   Timer-driven (never scroll/cursor). inset:-15% so the drift never bares an
   edge. Same --amb/--sage tokens → identical net brightness light & dark. */
.ambient-aurora {
  position: absolute; inset: -15%; z-index: 0; pointer-events: none; will-change: transform, opacity;
  background:
    radial-gradient(ellipse 60% 50% at 22% 12%, var(--amb-1) 0%, transparent 60%),
    radial-gradient(ellipse 55% 48% at 82% 28%, var(--amb-2) 0%, transparent 62%),
    radial-gradient(ellipse 50% 46% at 68% 80%, color-mix(in srgb, var(--sage) 12%, transparent) 0%, transparent 64%);
  animation: auroraDrift 56s ease-in-out infinite;
}
@keyframes auroraDrift {
  0%, 100% { transform: translate3d(-1.4%, -1%, 0) scale(1.02); opacity: .62; }
  50%      { transform: translate3d(1.6%, 1.4%, 0) scale(1.06); opacity: .78; }
}
.ambient-stars {
  position: absolute; inset: 0; opacity: var(--stars-opacity);
  transition: opacity .6s var(--ease-std);
  background-image:
    radial-gradient(1px 1px at 12% 18%, rgba(255,255,255,.9) 50%, transparent),
    radial-gradient(1px 1px at 28% 42%, rgba(255,255,255,.65) 50%, transparent),
    radial-gradient(1.4px 1.4px at 48% 22%, rgba(255,255,255,.8) 50%, transparent),
    radial-gradient(1px 1px at 67% 58%, rgba(255,255,255,.6) 50%, transparent),
    radial-gradient(1px 1px at 82% 30%, rgba(255,255,255,.75) 50%, transparent),
    radial-gradient(1.2px 1.2px at 91% 72%, rgba(255,255,255,.7) 50%, transparent),
    radial-gradient(1px 1px at 38% 82%, rgba(255,255,255,.55) 50%, transparent);
  background-size: 100% 100%;
  animation: twinkle 6s ease-in-out infinite;
}
@keyframes twinkle { 0%, 100% { opacity: var(--stars-opacity); } 50% { opacity: calc(var(--stars-opacity) * .55); } }

/* ============================================================
   TYPOGRAPHY UTILITIES
   ============================================================ */
.display {
  font-family: 'Fraunces', Georgia, 'Times New Roman', serif;   /* metric-closer fallback narrows the font-swap reflow */
  font-weight: 300;
  letter-spacing: -.032em;
  line-height: 1.0;
  color: var(--ink);
  text-wrap: pretty;           /* 'balance' can fail to wrap long TR lines at narrow widths */
  overflow-wrap: break-word;   /* last-resort: never let a long word (e.g. TR) overflow */
}
.display em { font-style: italic; font-weight: 300; color: var(--sage); }

.display-hero {
  font-size: clamp(44px, 7vw, 84px);
  font-variation-settings: "opsz" 110;
  letter-spacing: -.036em;
}
.hero-title-break { display: none; }
.display-section {
  font-size: clamp(28px, 4.2vw, 48px);
  font-variation-settings: "opsz" 64;
  letter-spacing: -.03em;
  line-height: 1.04;
}

.eyebrow {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: .20em; text-transform: uppercase;
  font-weight: 500; color: var(--ink-faint);
  display: inline-flex; align-items: center; gap: 10px;
}
.eyebrow-dot::before {
  content: ''; width: 7px; height: 7px; border-radius: 50%;
  background: var(--sage); box-shadow: 0 0 10px var(--sage);
  animation: breath 3s ease-in-out infinite;
}
@keyframes breath { 0%, 100% { transform: scale(1); opacity: .85; } 50% { transform: scale(1.32); opacity: 1; } }

.lede {
  font-size: clamp(15px, 1.4vw, 18px);
  line-height: 1.6; color: var(--ink-dim);
  max-width: 34ch;
}

.chapter-num {
  font-family: 'Fraunces', serif; font-style: italic; font-weight: 300;
  font-size: clamp(40px, 5vw, 58px);
  font-variation-settings: "opsz" 96;
  color: var(--sage); line-height: 1; letter-spacing: -.03em;
}

/* ============== SECTION SHELL ============== */
section { position: relative; }
.section-head { padding: 0 var(--page-edge); max-width: var(--maxw); margin: 0 auto 48px; }
.section-head .eyebrow { margin-bottom: 16px; }
.psection-divider { padding-top: clamp(72px, 11vh, 140px); }
.psection-divider::before {
  content: ''; position: absolute; top: 0;
  left: var(--page-edge); right: var(--page-edge); height: 1px;
  background: var(--hairline); max-width: var(--maxw); margin: 0 auto;
}

/* scroll reveal (only hidden when JS is active)
   NOTE: the shown-rule must out-specify the hidden-rule. `html.js .reveal`
   is (0,2,1); a bare `.reveal.is-visible` is only (0,2,0) and silently loses,
   leaving every section stuck at opacity:0. Keep the `html.js` prefix on BOTH. */
html.js .reveal { opacity: 0; transform: translateY(var(--reveal-travel, 26px)); }
.reveal { transition: opacity var(--dur-reveal) var(--ease-std), transform var(--dur-reveal) var(--ease-std); transition-delay: var(--reveal-delay, 0ms); }
html.js .reveal.is-visible { opacity: 1; transform: none; }
/* role-tiered entrance depth — heading groups rise a touch further than cards,
   cards "land" (scale-settle) while editorial text just "rises": two materials,
   two physics, no spring (ease-std). .985 is felt, not seen. */
html.js .section-head.reveal { --reveal-travel: 32px; }
html.js .feature-card.reveal,
html.js .tier.reveal,
html.js .how-step.reveal { transform: translateY(var(--reveal-travel, 26px)) scale(.985); }
html.js .feature-card.reveal.is-visible,
html.js .tier.reveal.is-visible,
html.js .how-step.reveal.is-visible { transform: none; }
/* reveal-line: the privacy manifesto cascades line-by-line (one section only) */
html.js .reveal-line { opacity: 0; transform: translateY(18px); transition: opacity var(--dur-reveal) var(--ease-std), transform var(--dur-reveal) var(--ease-std); transition-delay: var(--reveal-delay, 0ms); display: block; }
html.js .reveal-line.is-visible { opacity: 1; transform: none; }

/* ============================================================
   NAV
   ============================================================ */
.nav { position: fixed; top: 0; left: 0; right: 0; z-index: 100; transition: background .4s var(--ease-std), border-color .4s var(--ease-std); border-bottom: 1px solid transparent; }
.nav.scrolled {
  background: var(--nav-bg);
  backdrop-filter: blur(20px) saturate(1.3); -webkit-backdrop-filter: blur(20px) saturate(1.3);
  border-bottom: 1px solid var(--hairline);
}
/* a quiet reading-progress hairline — information, not a loader. Only after
   scroll begins (clean top edge). scaleX is composite-cheap; JS writes --scroll-p. */
.nav-progress {
  position: absolute; left: 0; bottom: -1px; width: 100%; height: 2px;
  transform: scaleX(var(--scroll-p, 0)); transform-origin: left;
  background: linear-gradient(90deg, var(--sage), var(--warm));
  opacity: 0; transition: opacity .4s var(--ease-std); pointer-events: none;
}
.nav.scrolled .nav-progress { opacity: .9; }
.nav-inner {
  max-width: var(--maxw); margin: 0 auto;
  padding: 16px var(--page-edge);
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
}
.wordmark { display: inline-flex; align-items: center; gap: 9px; }
.wordmark-orb { width: 22px; height: 22px; filter: drop-shadow(0 0 8px color-mix(in srgb, var(--sage) 45%, transparent)); }
.wordmark-text { font-family: 'Fraunces', serif; font-weight: 500; font-size: 22px; letter-spacing: -.01em; color: var(--ink); }

.nav-meta { display: flex; align-items: center; gap: clamp(12px, 2vw, 22px); }
.lang-toggle { display: inline-flex; align-items: center; gap: 6px; font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: .08em; }
.lang-btn { color: var(--ink-faint); padding: 4px 2px; transition: color .25s var(--ease-std); }
.lang-btn[aria-pressed="true"] { color: var(--sage); }
.lang-btn:hover { color: var(--ink); }
.lang-sep { color: var(--ink-ghost); }

.theme-toggle { width: 34px; height: 34px; border-radius: 50%; display: grid; place-items: center; color: var(--ink-dim); border: 1px solid var(--hairline); transition: color .25s var(--ease-std), border-color .25s var(--ease-std), transform .4s var(--ease-std); }
.theme-toggle:hover { color: var(--sage); border-color: var(--sage); }
.theme-toggle svg { width: 17px; height: 17px; }
.theme-toggle .icon-moon { display: none; }
:root[data-theme="dark"] .theme-toggle .icon-sun,
.theme-toggle .icon-sun { animation: breath 4.5s ease-in-out infinite; }
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) .theme-toggle .icon-sun { display: none; }
  :root:not([data-theme="light"]) .theme-toggle .icon-moon { display: block; }
}
:root[data-theme="dark"] .theme-toggle .icon-sun { display: none; }
:root[data-theme="dark"] .theme-toggle .icon-moon { display: block; }
:root[data-theme="light"] .theme-toggle .icon-sun { display: block; }
:root[data-theme="light"] .theme-toggle .icon-moon { display: none; }

/* ============== CTA PILL ============== */
.cta-pill {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  font-family: 'Inter', sans-serif; font-size: 13px; font-weight: 500; letter-spacing: .01em;
  padding: 11px 22px; border-radius: 100px;
  border: 1px solid var(--sage);
  color: var(--sage);
  background: color-mix(in srgb, var(--sage) 8%, transparent);
  transition: background .3s var(--ease-std), box-shadow .3s var(--ease-std), transform .3s var(--ease-std);
  white-space: nowrap;
}
.cta-pill:hover { background: color-mix(in srgb, var(--sage) 16%, transparent); box-shadow: 0 0 28px color-mix(in srgb, var(--sage) 24%, transparent); }
.cta-pill:active { transform: scale(.97); }
.cta-solid {
  background: var(--sage); color: var(--bg); border-color: var(--sage);
  font-weight: 600;
}
.cta-solid:hover { background: var(--sage); box-shadow: 0 0 34px color-mix(in srgb, var(--sage) 42%, transparent); filter: brightness(1.04); }

/* ============================================================
   HERO
   ============================================================ */
.hero {
  min-height: min(100svh, 920px);
  padding: clamp(112px, 14vh, 170px) var(--page-edge) clamp(58px, 8vh, 96px);
  max-width: var(--maxw);
  margin: 0 auto;
  display: flex;
  align-items: center;
}
.hero-grid {
  width: 100%;
  display: grid; grid-template-columns: minmax(0, .95fr) minmax(360px, 1.05fr); gap: clamp(36px, 7vw, 96px);
  align-items: center;
}
.hero-copy { max-width: 610px; }
.hero-copy .eyebrow { margin-bottom: 22px; }
.display-hero { margin-bottom: 24px; }
.hero-copy .lede { margin-bottom: 16px; }
.hero-whisper {
  font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: .18em; text-transform: uppercase;
  color: var(--ink-faint); margin-bottom: 20px;
  display: inline-flex; align-items: center; gap: 9px;
}
.hero-whisper::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: var(--sage); box-shadow: 0 0 8px var(--sage); animation: breath 3.4s ease-in-out infinite; }

.hero-proof {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  max-width: 560px;
  margin: 0 0 28px;
}
.hero-proof li {
  min-height: 74px;
  padding: 13px 14px 12px;
  border-radius: 18px;
  border: 1px solid color-mix(in srgb, var(--sage) 18%, var(--card-border));
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--card-bg) 84%, var(--sage) 6%), color-mix(in srgb, var(--card-bg) 74%, transparent));
  box-shadow: 0 18px 44px -34px color-mix(in srgb, var(--sage) 44%, transparent);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 8px;
}
.proof-kicker {
  font-family: 'JetBrains Mono', monospace;
  font-size: 8.5px;
  letter-spacing: .16em;
  color: var(--sage);
}
.hero-proof li span:last-child {
  font-size: 13px;
  line-height: 1.35;
  color: var(--ink-dim);
}

.hero-cta { display: flex; flex-direction: column; gap: 16px; }
/* mode flip: [hidden] must beat the class display:flex (UA [hidden] loses the specificity tie) */
.hero-cta[hidden], .cta-action[hidden] { display: none; }

/* waitlist form */
.waitlist-form { width: 100%; max-width: 500px; }
.field { display: flex; gap: 10px; align-items: stretch; }
.email-input {
  flex: 1; min-width: 0;
  font-family: 'Inter', sans-serif; font-size: 15px; color: var(--ink);
  padding: 14px 18px; border-radius: 100px;
  background: color-mix(in srgb, var(--card-bg) 88%, var(--ink) 3%);
  border: 1px solid color-mix(in srgb, var(--sage) 16%, var(--card-border));
  box-shadow: inset 0 1px 0 color-mix(in srgb, white 7%, transparent);
  transition: border-color .3s var(--ease-std), box-shadow .3s var(--ease-std), background .3s var(--ease-std);
}
.email-input::placeholder { color: var(--ink-faint); }
.email-input:focus-visible { outline: none; border-color: var(--sage); box-shadow: 0 0 0 3px color-mix(in srgb, var(--sage) 20%, transparent); }
.email-input.invalid { border-color: var(--warn); box-shadow: 0 0 0 3px color-mix(in srgb, var(--warn) 18%, transparent); }
.hp-field { position: absolute; left: -9999px; width: 1px; height: 1px; opacity: 0; pointer-events: none; }
.field .cta-pill { flex-shrink: 0; }

.form-feedback {
  font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: .04em;
  min-height: 18px; margin-top: 12px; padding-left: 18px;
  color: var(--ink-dim);
}
.form-feedback.error { color: var(--warn-ink); }
.form-feedback.success { color: var(--sage); }
.form-feedback.success em { font-family: 'Fraunces', serif; font-style: italic; }
.form-feedback.is-breathing { animation: feedbackBreath 3.4s ease-in-out infinite; }
@keyframes feedbackBreath { 0%, 100% { opacity: .82; } 50% { opacity: 1; } }

.form-microcopy {
  font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: .06em;
  color: var(--ink-dim); margin-top: 12px; padding-left: 18px;
}
.copy-email {
  font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: .04em;
  color: var(--sage); margin-top: 4px; padding: 6px 0 0 18px;
  border-bottom: 1px solid transparent; align-self: flex-start;
  transition: border-color .25s var(--ease-std);
}
.copy-email:hover { border-bottom-color: var(--sage); }
.soon-eyebrow { margin-top: 2px; }

/* store badges */
.store-row { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.store-badge {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 10px 18px; border-radius: 14px; border: 1px solid var(--hairline-strong);
}
.store-eyebrow { font-family: 'JetBrains Mono', monospace; font-size: 9px; letter-spacing: .18em; text-transform: uppercase; color: var(--ink-faint); display: block; }
.store-badge.live { border-color: var(--card-border); background: var(--card-bg); transition: box-shadow .3s var(--ease-std), transform .3s var(--ease-std); }
.store-badge.live:hover { box-shadow: var(--shadow-card); transform: translateY(-2px); }
.apple-mark { width: 24px; height: 24px; color: var(--ink); }
.store-badge-text { display: flex; flex-direction: column; line-height: 1.1; }
.store-name { font-family: 'Inter', sans-serif; font-size: 17px; font-weight: 600; color: var(--ink); letter-spacing: -.01em; }
.qr { width: 72px; height: 72px; }
.qr-svg { width: 100%; height: 100%; color: var(--ink); }
.qr-bg { fill: var(--card-bg); stroke: var(--card-border); stroke-width: 1; }
.qr-hole { fill: var(--card-bg); }

/* ============== PHONE MOCKUP ============== */
.hero-visual { display: flex; justify-content: center; perspective: 1400px; position: relative; }
.hero-visual-shell {
  width: min(430px, 88vw);
  min-height: 670px;
  position: relative;
  display: grid;
  place-items: center;
  isolation: isolate;
}
.hero-visual-shell::before {
  content: '';
  position: absolute;
  inset: 7% -12% 12%;
  z-index: -2;
  border-radius: 44% 56% 52% 48%;
  background:
    radial-gradient(ellipse at 50% 38%, color-mix(in srgb, var(--sage) 28%, transparent), transparent 56%),
    radial-gradient(ellipse at 70% 76%, color-mix(in srgb, var(--warm) 16%, transparent), transparent 62%);
  filter: blur(18px);
  opacity: .9;
}
.hero-visual-shell::after {
  content: '';
  position: absolute;
  left: 16%;
  right: 14%;
  bottom: 2%;
  height: 44px;
  z-index: -1;
  border-radius: 999px;
  background: radial-gradient(ellipse at center, rgba(0, 0, 0, .42), transparent 68%);
  opacity: .55;
}
.visual-chip {
  position: absolute;
  z-index: 4;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 13px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--sage) 28%, var(--card-border));
  background: color-mix(in srgb, var(--bg) 62%, transparent);
  color: var(--ink);
  box-shadow: 0 18px 40px -28px rgba(0, 0, 0, .55);
  backdrop-filter: blur(18px) saturate(1.2);
  -webkit-backdrop-filter: blur(18px) saturate(1.2);
  font-family: 'JetBrains Mono', monospace;
  font-size: 9.5px;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.visual-chip-top { top: 14%; right: -2%; }
.visual-chip-bottom { left: -3%; bottom: 19%; }
.visual-chip-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--sage);
  box-shadow: 0 0 12px var(--sage);
}
.visual-chip-dot.warm {
  background: var(--warm);
  box-shadow: 0 0 12px var(--warm);
}
.phone {
  width: min(360px, 78vw); aspect-ratio: 310 / 660;
  border-radius: 46px; padding: 9px; position: relative; flex-shrink: 0;
  background: linear-gradient(180deg, var(--phone-frame-a), var(--phone-frame-b));
  box-shadow: var(--shadow-phone);
  will-change: transform;
  transition: box-shadow .5s var(--ease-std);
}
.phone-screen { width: 100%; height: 100%; border-radius: 38px; overflow: hidden; position: relative; isolation: isolate; background: var(--phone-screen); color: var(--ink); }
.phone-bg { position: absolute; inset: 0; z-index: 0; background:
  radial-gradient(ellipse at 30% 14%, var(--amb-2) 0%, transparent 55%),
  radial-gradient(ellipse at 80% 86%, var(--amb-1) 0%, transparent 55%);
}
.phone-island { position: absolute; top: 9px; left: 50%; transform: translateX(-50%); width: 92px; height: 26px; background: #000; border-radius: 100px; z-index: 30; }
.phone-status { position: absolute; top: 0; left: 0; right: 0; height: 44px; padding: 14px 24px 0; display: flex; justify-content: space-between; align-items: center; z-index: 20; font-size: 12px; font-weight: 600; font-variant-numeric: tabular-nums; }
.phone-status-r { display: inline-flex; gap: 5px; align-items: center; }
.phone-status svg { width: 14px; height: 10px; }
.phone-homebar { position: absolute; bottom: 7px; left: 50%; transform: translateX(-50%); width: 104px; height: 4px; border-radius: 10px; background: currentColor; opacity: .5; z-index: 20; }
.phone-sample { position: absolute; top: 16px; right: 16px; z-index: 25; font-family: 'JetBrains Mono', monospace; font-size: 7.5px; letter-spacing: .16em; color: var(--ink-faint); padding: 3px 7px; border-radius: 100px; border: 1px solid var(--hairline-strong); background: color-mix(in srgb, var(--bg) 60%, transparent); }
.phone-scroll { position: absolute; inset: 0; z-index: 2; padding: 52px 0 24px; overflow: hidden; }

.phone-head { padding: 10px 22px 16px; }
.phone-eyebrow { font-size: 8.5px; letter-spacing: .14em; margin-bottom: 12px; }
.phone-eyebrow.eyebrow-dot::before { width: 6px; height: 6px; }
.phone-greet { font-family: 'Fraunces', serif; font-weight: 300; font-size: 30px; line-height: .98; letter-spacing: -.03em; font-variation-settings: "opsz" 72; color: var(--ink); }
.phone-greet em { font-style: italic; color: var(--sage); }
.phone-sub { font-size: 11.5px; line-height: 1.5; margin-top: 10px; color: var(--ink-dim); max-width: 230px; }
.phone-sub b { font-weight: 500; color: var(--ink); }

.phone-card { margin: 4px 18px 16px; }
.orb-wrap {
  padding: 18px; border-radius: 20px; position: relative; overflow: hidden;
  background: var(--card-bg); border: 1px solid var(--card-border);
}
.orb-wrap::before { content: ''; position: absolute; inset: 0; pointer-events: none; background: radial-gradient(circle at 82% 16%, var(--amb-1) 0%, transparent 55%); }
.orb-top { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; position: relative; z-index: 1; }
.orb-top-l { flex: 1; min-width: 0; }
.orb-l { font-family: 'JetBrains Mono', monospace; font-size: 8.5px; letter-spacing: .14em; text-transform: uppercase; font-weight: 500; color: var(--ink-faint); margin-bottom: 8px; display: inline-flex; align-items: center; gap: 7px; }
.orb-pill { padding: 2px 7px; border-radius: 100px; font-size: 8.5px; background: color-mix(in srgb, var(--sage) 14%, transparent); color: var(--sage); border: 1px solid color-mix(in srgb, var(--sage) 28%, transparent); font-variant-numeric: tabular-nums; }
.orb-text { font-family: 'Fraunces', serif; font-weight: 300; font-size: 18px; line-height: 1.2; letter-spacing: -.02em; font-variation-settings: "opsz" 32; color: var(--ink); }
.orb-text em { font-style: italic; color: var(--sage); }

/* the orb itself */
.orb { width: 54px; height: 54px; position: relative; flex-shrink: 0; }
.orb-core {
  position: absolute; inset: 18%; border-radius: 50%;
  background: radial-gradient(circle at 35% 32%, var(--orb-core-hi) 0%, var(--orb-core-mid) 55%, var(--orb-core-lo) 100%);
  box-shadow: 0 0 22px var(--orb-glow), inset 0 -3px 8px rgba(0,0,0,.25), inset 0 3px 8px rgba(255,255,255,.4);
  animation: orbBreath 4.5s ease-in-out infinite;
}
.orb-ring { position: absolute; inset: 0; border-radius: 50%; border: 1px solid var(--orb-ring); animation: orbRing 4.5s ease-in-out infinite; }
.orb-ring.r2 { inset: 10%; border-color: color-mix(in srgb, var(--orb-glow) 60%, transparent); animation-delay: -.5s; }
@keyframes orbBreath { 0%, 100% { transform: scale(1); } 50% { transform: scale(1.06); } }
@keyframes orbRing { 0%, 100% { transform: scale(1); opacity: .6; } 50% { transform: scale(1.14); opacity: .22; } }

.orb-next { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 12px; margin-top: 14px; padding: 10px 12px; border-radius: 12px; background: color-mix(in srgb, var(--ink) 3%, transparent); border: 1px solid var(--card-border); position: relative; z-index: 1; }
.orb-next-time { font-family: 'Fraunces', serif; font-size: 17px; font-weight: 500; letter-spacing: -.02em; font-variant-numeric: tabular-nums; line-height: 1; color: var(--sage); }
.orb-next-in { display: block; font-family: 'JetBrains Mono', monospace; font-size: 8px; letter-spacing: .08em; text-transform: uppercase; margin-top: 3px; color: var(--ink-faint); }
.orb-next-name { font-size: 12px; font-weight: 500; color: var(--ink); }
.orb-next-meta { font-family: 'JetBrains Mono', monospace; font-size: 9px; letter-spacing: .04em; margin-top: 3px; color: var(--ink-dim); display: inline-flex; align-items: center; gap: 6px; }
.orb-next-arrow { width: 26px; height: 26px; border-radius: 50%; display: grid; place-items: center; background: color-mix(in srgb, var(--sage) 12%, transparent); border: 1px solid color-mix(in srgb, var(--sage) 22%, transparent); color: var(--sage); }
.orb-next-arrow svg { width: 11px; height: 11px; }

.person-dot { width: 5px; height: 5px; border-radius: 50%; display: inline-block; }
.person-dot.self { background: var(--p-self); }
.person-dot.mom { background: var(--p-mom); }
.person-dot.dad { background: var(--p-dad); }
.person-dot.sibling { background: var(--p-sibling); }
.person-dot.child { background: var(--p-child); }

/* phone med rows — flow, hairlines between */
.phone-meds { padding: 0 22px; }
.phone-med { display: grid; grid-template-columns: 3px 1fr auto; gap: 12px; align-items: center; padding: 11px 0; position: relative; }
.phone-med + .phone-med::before { content: ''; position: absolute; top: 0; left: 15px; right: 0; height: 1px; background: var(--hairline); }
.med-bar { align-self: stretch; width: 3px; border-radius: 2px; opacity: .85; }
.med-bar.self { background: var(--p-self); }
.med-bar.mom { background: var(--p-mom); }
.med-bar.dad { background: var(--p-dad); }
.med-mid { min-width: 0; }
.med-name { font-family: 'Fraunces', serif; font-size: 15px; font-weight: 400; letter-spacing: -.015em; font-variation-settings: "opsz" 22; color: var(--ink); }
.med-meta { font-family: 'JetBrains Mono', monospace; font-size: 8px; letter-spacing: .08em; margin-top: 3px; color: var(--ink-faint); }
.med-time { font-family: 'JetBrains Mono', monospace; font-size: 12px; font-weight: 500; font-variant-numeric: tabular-nums; color: var(--sage); }
.med-time.taken { color: color-mix(in srgb, var(--sage) 45%, transparent); }

/* ============================================================
   RIVER — signature section
   ============================================================ */
.river { position: relative; }
.river-track { position: relative; }
html.js .river-track { height: 220vh; }                        /* desktop scrub budget — was 320vh: ~3 pinned screens read as "stuck/dead". 220vh keeps ~1.2 screens of crisp scrub (JS builds the river; no-JS keeps it from reserving an empty void) */
.river-sticky { position: sticky; top: 0; height: 100vh; display: flex; align-items: center; overflow: hidden; }
.river-sample { position: absolute; top: clamp(20px, 4vh, 48px); right: var(--page-edge); z-index: 3; font-family: 'JetBrains Mono', monospace; font-size: 9px; letter-spacing: .16em; color: var(--ink-faint); }
.river-layout {
  width: 100%; max-width: var(--maxw); margin: 0 auto;
  padding: 0 var(--page-edge);
  display: grid; grid-template-columns: minmax(260px, 380px) 1fr; gap: clamp(24px, 4vw, 64px);
  align-items: center;
}
.river-copy { max-width: 380px; }
.river-copy .eyebrow { margin-bottom: 18px; }
.river-copy .display-section { margin-bottom: 26px; }
.river-prose {
  position: relative; padding-left: 16px;
  font-family: 'Fraunces', serif; font-weight: 300; font-style: italic;
  font-size: clamp(15px, 1.5vw, 18px); line-height: 1.5; letter-spacing: -.01em;
  font-variation-settings: "opsz" 24; color: var(--ink-dim);
  max-width: 36ch; margin-top: 14px;
  transition: color .55s var(--ease-std);
}
.river-prose:first-of-type { margin-top: 0; }
/* the river narrates: as the day scrubs past, each prose line lights in turn.
   Emphasis is ADDED to the active line (brighter ink + sage marker); inactive
   lines stay at today's --ink-dim, never dimmed below current contrast. */
.river-prose::before {
  content: ''; position: absolute; left: 0; top: .18em; bottom: .18em; width: 2px;
  border-radius: 2px; background: var(--sage);
  box-shadow: 0 0 10px color-mix(in srgb, var(--sage) 50%, transparent);
  opacity: 0; transform: scaleY(.2); transform-origin: top;
  transition: opacity .5s var(--ease-std), transform .5s var(--ease-std);
}
.river-prose.is-lit { color: var(--ink); }
.river-prose.is-lit::before { opacity: 1; transform: scaleY(1); }

.river-stage { position: relative; height: min(72vh, 600px); }
.river-svg { width: 100%; height: 100%; display: block; overflow: visible; }
.river-progress { position: absolute; left: 0; right: 0; bottom: -2px; height: 2px; background: var(--hairline); border-radius: 2px; overflow: hidden; }
.river-progress-fill { display: block; height: 100%; width: 100%; transform: scaleX(0); transform-origin: left; will-change: transform; background: linear-gradient(90deg, var(--sage), var(--warm)); border-radius: 2px; box-shadow: 0 0 12px var(--sage); }

/* river svg pieces (styled here, positioned/added by JS) */
.river-tick { font-family: 'JetBrains Mono', monospace; font-size: 9px; letter-spacing: .1em; fill: var(--ink-ghost); font-weight: 500; }
.river-stream { fill: none; stroke-width: 14; stroke-linecap: round; opacity: .9; }
.river-stream-bg { fill: none; stroke-width: 14; stroke-linecap: round; opacity: .28; }

.now-line { stroke: var(--sage); stroke-width: 1; stroke-dasharray: 3 3; opacity: .55; }
.now-pill { fill: var(--sage); }
.now-pill-text { font-family: 'JetBrains Mono', monospace; font-size: 8px; font-weight: 700; letter-spacing: .12em; fill: var(--bg); }

.river-node { cursor: default; }
.river-node .node-glow { opacity: 0; transition: opacity .6s var(--ease-std); }
.river-node .node-core { transition: transform .22s var(--ease-std); transform-box: fill-box; transform-origin: center; }
.river-node .node-fill { opacity: .35; transition: opacity .6s var(--ease-std); }
.river-node.is-taken .node-glow { opacity: 1; }
.river-node.is-taken .node-fill { opacity: 1; }
.river-node .node-time { font-family: 'JetBrains Mono', monospace; font-size: 9px; font-variant-numeric: tabular-nums; fill: var(--ink-dim); font-weight: 500; }
.river-node .node-hit { fill: transparent; cursor: pointer; }
/* node lift on hover/focus */
.river-node .node-lift { transition: transform .24s var(--ease-std); transform-box: view-box; }
.river-node:hover .node-lift,
.river-node:focus-visible .node-lift { transform: translateY(-6px); }
.river-node:focus-visible { outline: none; }
.river-node:focus-visible .node-core { transform: scale(1.18); }
.river-node:hover .node-core { transform: scale(1.12); }

/* node hover label chip */
.node-chip { opacity: 0; transition: opacity .2s var(--ease-std); pointer-events: none; }
.river-node:hover .node-chip,
.river-node:focus-visible .node-chip,
.river-node.chip-open .node-chip { opacity: 1; }
.node-chip rect { fill: var(--card-bg); stroke: var(--card-border); stroke-width: 1; }
.node-chip text { font-family: 'JetBrains Mono', monospace; font-size: 8px; letter-spacing: .08em; fill: var(--ink); }

/* the breathing hot node */
.river-node.is-hot .node-pulse { animation: hotPulse 3.2s ease-in-out infinite; transform-box: fill-box; transform-origin: center; }
@keyframes hotPulse { 0%, 100% { transform: scale(1); opacity: .5; } 50% { transform: scale(1.35); opacity: .15; } }

/* ============================================================
   HOW IT WORKS
   ============================================================ */
.how-steps {
  max-width: var(--maxw); margin: 0 auto; padding: 0 var(--page-edge) clamp(40px, 7vh, 90px);
  display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(28px, 4vw, 56px);
}
.how-step { display: flex; flex-direction: column; gap: 16px; }
.how-step .chapter-num { margin-bottom: 4px; }
.how-step-title { font-family: 'Fraunces', serif; font-weight: 300; font-size: clamp(20px, 2.2vw, 26px); letter-spacing: -.02em; font-variation-settings: "opsz" 36; color: var(--ink); }
.how-step-body { font-size: 14.5px; line-height: 1.6; color: var(--ink-dim); max-width: 32ch; }
.how-visual { height: 130px; border-radius: 18px; border: 1px solid var(--hairline); background: color-mix(in srgb, var(--ink) 2.5%, transparent); display: grid; place-items: center; overflow: hidden; position: relative; }

/* 01 scan */
.scan-svg { width: 100%; height: 100%; }
.scan-box { fill: none; stroke: var(--hairline-strong); stroke-width: 1.5; }
.scan-line-art { stroke: var(--ink-ghost); stroke-width: 2.5; stroke-linecap: round; }
.scan-line-art.short { opacity: .6; }
.scan-corners path { fill: none; stroke: var(--sage); stroke-width: 2; stroke-linecap: round; }
.scanline { stroke: var(--sage); stroke-width: 2; stroke-linecap: round; filter: drop-shadow(0 0 6px var(--sage)); opacity: 0; }
.how-step.is-visible .scanline { animation: scanSweep 2.6s var(--ease-std) infinite; }
@keyframes scanSweep { 0% { transform: translateY(-26px); opacity: 0; } 15% { opacity: 1; } 85% { opacity: 1; } 100% { transform: translateY(38px); opacity: 0; } }

/* 02 ai typed */
.how-visual-ai { padding: 22px; }
.ai-typed { font-family: 'Fraunces', serif; font-style: italic; font-weight: 300; font-size: 16px; line-height: 1.45; color: var(--ink-dim); font-variation-settings: "opsz" 24; text-align: center; }
.ai-typed .tw-word { opacity: 0; }
.ai-typed .tw-word.lit { opacity: 1; transition: opacity .42s var(--ease-std); }

/* 03 flow */
.mini-river { width: 100%; height: 100%; }
.mini-stream { fill: none; stroke: var(--sage); stroke-width: 2; opacity: .35; stroke-linecap: round; }
.mini-stream.s2 { stroke: var(--warm); opacity: .28; }
.mini-node { animation: orbBreath 4s ease-in-out infinite; }
.mini-node.self { fill: var(--p-self); }
.mini-node.dad { fill: var(--p-dad); }
.mini-node.mom { fill: var(--p-mom); }
.mini-node.child { fill: var(--p-child); }

/* ============================================================
   FEATURES TRIPTYCH
   ============================================================ */
.triptych { max-width: var(--maxw); margin: 0 auto; padding: 0 var(--page-edge) clamp(40px, 7vh, 90px); display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(20px, 2.4vw, 32px); }
.feature-card {
  background: var(--card-bg); border: 1px solid var(--card-border); border-radius: var(--card-radius);
  padding: 28px 26px 30px; display: flex; flex-direction: column; gap: 18px;
  box-shadow: var(--shadow-card);
  transition: transform .32s var(--ease-std), box-shadow .32s var(--ease-std), border-color .32s var(--ease-std);
}
.feature-card:hover { transform: translateY(-4px); box-shadow: 0 30px 60px -34px color-mix(in srgb, var(--sage) 40%, var(--shadow-card)); border-color: color-mix(in srgb, var(--sage) 24%, var(--card-border)); }
.feature-title { font-family: 'Fraunces', serif; font-weight: 300; font-size: clamp(20px, 2.1vw, 24px); letter-spacing: -.02em; font-variation-settings: "opsz" 34; color: var(--ink); margin-top: auto; }
.feature-title em { font-style: italic; color: var(--sage); }
.feature-body { font-size: 14px; line-height: 1.6; color: var(--ink-dim); }

/* avatar cluster */
.avatar-cluster { display: flex; height: 64px; align-items: center; }
.avatar { width: 42px; height: 42px; border-radius: 50%; display: grid; place-items: center; font-family: 'Fraunces', serif; font-style: italic; font-weight: 500; font-size: 16px; margin-left: -10px; border: 2px solid var(--bg); }
.avatar:first-child { margin-left: 0; }
.avatar.self { background: var(--p-self); color: var(--on-person); }
.avatar.mom { background: var(--p-mom); color: #3B2806; }
.avatar.dad { background: var(--p-dad); color: var(--on-person); }
.avatar.child { background: var(--p-child); color: var(--on-person); }

/* ai snippet */
.ai-snippet { background: color-mix(in srgb, var(--sage) 6%, transparent); border: 1px solid color-mix(in srgb, var(--sage) 16%, transparent); border-radius: 14px; padding: 16px 18px; }
.ai-snippet-text { font-family: 'Fraunces', serif; font-weight: 300; font-size: 14.5px; line-height: 1.45; color: var(--ink); font-variation-settings: "opsz" 22; }
.ai-snippet-text em { font-style: italic; color: var(--sage); }
.ai-disclaimer { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: .04em; color: var(--ink-faint); margin-top: 12px; }

/* notification mock */
.notif-mock { display: grid; grid-template-columns: auto 1fr auto; gap: 12px; align-items: center; background: var(--card-bg); border: 1px solid var(--card-border); border-radius: 16px; padding: 14px 16px; box-shadow: var(--shadow-card); }
.notif-dot { width: 9px; height: 9px; border-radius: 50%; background: var(--sage); box-shadow: 0 0 10px var(--sage); animation: breath 3.6s ease-in-out infinite; }
.notif-title { font-family: 'JetBrains Mono', monospace; font-size: 9px; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-faint); }
.notif-body { font-family: 'Fraunces', serif; font-style: italic; font-size: 14px; color: var(--ink); margin-top: 3px; font-variation-settings: "opsz" 20; }
.notif-time { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--ink-faint); align-self: flex-start; }

/* ============================================================
   PRIVACY MANIFESTO
   ============================================================ */
.privacy { padding: clamp(90px, 16vh, 200px) var(--page-edge); position: relative; overflow: hidden; }
.privacy::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse 700px 500px at 50% 45%, color-mix(in srgb, var(--sage) 9%, transparent) 0%, transparent 70%); pointer-events: none; }
.privacy-inner { max-width: 880px; margin: 0 auto; text-align: center; position: relative; }
.privacy-eyebrow { margin-bottom: 30px; justify-content: center; }
.privacy-statement { font-family: 'Fraunces', serif; font-weight: 300; font-size: clamp(28px, 4vw, 48px); line-height: 1.22; letter-spacing: -.024em; font-variation-settings: "opsz" 72; color: var(--ink); text-wrap: balance; }
.privacy-statement span { display: inline; }
.privacy-statement em { font-style: italic; color: var(--sage); }
.privacy-sub { font-size: clamp(14px, 1.4vw, 16.5px); line-height: 1.6; color: var(--ink-dim); max-width: 50ch; margin: 30px auto 0; }

/* ============================================================
   PRICING
   ============================================================ */
.billing-toggle { display: inline-flex; gap: 4px; margin-top: 24px; padding: 4px; border-radius: 100px; background: color-mix(in srgb, var(--ink) 4%, transparent); border: 1px solid var(--hairline); }
.billing-btn { font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: .1em; text-transform: uppercase; padding: 8px 18px; border-radius: 100px; color: var(--ink-faint); transition: background .3s var(--ease-std), color .3s var(--ease-std); }
.billing-btn.is-active { background: var(--sage); color: var(--bg); }

.tiers { max-width: var(--maxw); margin: 0 auto; padding: 0 var(--page-edge); display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(16px, 2vw, 24px); align-items: stretch; }
.tier { background: var(--card-bg); border: 1px solid var(--card-border); border-radius: var(--card-radius); padding: 30px 28px; display: flex; flex-direction: column; gap: 8px; position: relative; box-shadow: var(--shadow-card); transition: transform .32s var(--ease-std), box-shadow .32s var(--ease-std); }
.tier:hover { transform: translateY(-3px); }
.tier-family { border-color: color-mix(in srgb, var(--sage) 38%, transparent); box-shadow: 0 0 0 1px color-mix(in srgb, var(--sage) 22%, transparent), var(--shadow-card); }
.tier-badge { position: absolute; top: 20px; right: 24px; font-family: 'JetBrains Mono', monospace; font-size: 9px; letter-spacing: .14em; padding: 4px 10px; border-radius: 100px; background: color-mix(in srgb, var(--sage) 14%, transparent); color: var(--sage); border: 1px solid color-mix(in srgb, var(--sage) 30%, transparent); }
.tier-name { font-family: 'Fraunces', serif; font-style: italic; font-weight: 400; font-size: 22px; color: var(--ink); font-variation-settings: "opsz" 30; }
.tier-price { font-family: 'Fraunces', serif; font-weight: 300; line-height: 1; margin-top: 8px; color: var(--ink); display: flex; align-items: baseline; gap: 2px; }
.tier-amount { font-size: clamp(38px, 4.6vw, 52px); letter-spacing: -.03em; font-variation-settings: "opsz" 80; font-variant-numeric: tabular-nums; }
.tier-per { font-family: 'JetBrains Mono', monospace; font-size: 13px; color: var(--ink-dim); letter-spacing: .04em; }
.tier-price-alt { font-family: 'JetBrains Mono', monospace; font-size: 10.5px; letter-spacing: .06em; color: var(--ink-dim); min-height: 14px; }
.tier-tagline { font-size: 13.5px; color: var(--ink-dim); margin-top: 6px; margin-bottom: 6px; }
.tier-features { display: flex; flex-direction: column; gap: 10px; margin-top: 12px; padding-top: 16px; border-top: 1px solid var(--hairline); }
.tier-features li { font-size: 13.5px; color: var(--ink-dim); display: flex; align-items: flex-start; gap: 9px; }
.tier-features li::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: var(--sage); margin-top: 6px; flex-shrink: 0; }
.pricing-foot { font-family: 'JetBrains Mono', monospace; font-size: 10.5px; letter-spacing: .04em; color: var(--ink-dim); text-align: center; margin-top: 28px; padding: 0 var(--page-edge); }

/* ============================================================
   FAQ
   ============================================================ */
.faq-list { max-width: var(--maxw-narrow); margin: 0 auto; padding: 0 var(--page-edge); }
.faq-item { border-bottom: 1px solid var(--hairline); }
.faq-item:first-child { border-top: 1px solid var(--hairline); }
.faq-item summary { list-style: none; cursor: pointer; padding: 24px 4px; display: flex; align-items: center; justify-content: space-between; gap: 20px; }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-q { font-family: 'Fraunces', serif; font-weight: 400; font-size: clamp(17px, 1.9vw, 21px); letter-spacing: -.015em; font-variation-settings: "opsz" 28; color: var(--ink); }
.faq-chevron { width: 12px; height: 12px; flex-shrink: 0; border-right: 1.6px solid var(--ink-faint); border-bottom: 1.6px solid var(--ink-faint); transform: rotate(45deg); transition: transform .2s var(--ease-std); margin-top: -4px; }
.faq-item[open] .faq-chevron { transform: rotate(-135deg); margin-top: 4px; }
.faq-a { overflow: hidden; }
.faq-a p { font-size: 14.5px; line-height: 1.65; color: var(--ink-dim); padding: 0 4px 26px; max-width: 62ch; }

/* ============================================================
   FINAL CTA
   ============================================================ */
.cta { padding: clamp(90px, 15vh, 180px) var(--page-edge); text-align: center; }
.cta-inner { max-width: 620px; margin: 0 auto; display: flex; flex-direction: column; align-items: center; gap: 8px; }
.orb-large { width: 120px; height: 120px; margin-bottom: 18px; }
.cta-title { margin-bottom: 6px; }
.cta-sub { font-size: clamp(14px, 1.4vw, 16.5px); line-height: 1.6; color: var(--ink-dim); max-width: 40ch; margin-bottom: 30px; }
.cta-action { width: 100%; display: flex; justify-content: center; }
.cta-form { max-width: 460px; margin: 0 auto; }
.cta-form .form-feedback,
.cta-form .form-microcopy { text-align: center; padding-left: 0; }
.cta-form .copy-email { align-self: center; padding-left: 0; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer { border-top: 1px solid var(--hairline); padding: clamp(40px, 7vh, 72px) var(--page-edge); }
.footer-inner { max-width: var(--maxw); margin: 0 auto; display: grid; grid-template-columns: 1fr auto; gap: 32px 48px; align-items: center; }
.footer-brand { display: flex; flex-direction: column; gap: 12px; }
.footer-whisper { font-family: 'Fraunces', serif; font-size: 15px; color: var(--ink-dim); }
.footer-whisper em { font-style: italic; }   /* full-sentence voice line — italic only, not an accent-colour span */
.footer-links { display: flex; flex-wrap: wrap; gap: 8px 22px; grid-column: 1 / -1; order: 3; }
.footer-links a { font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: .06em; color: var(--ink-faint); transition: color .25s var(--ease-std); }
.footer-links a:hover { color: var(--sage); }
.footer-meta { display: flex; align-items: center; gap: 18px; justify-content: flex-end; flex-wrap: wrap; }
.footer-copy { font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: .06em; color: var(--ink-faint); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 920px) {
  .hero {
    display: block;
    min-height: 0;
    padding-top: clamp(118px, 15vh, 150px);
  }
  .hero-grid { display: flex; flex-direction: column; align-items: stretch; gap: 52px; }   /* stretch (not inherited center) so .hero-copy fills width and the heading wraps */
  .hero-copy { max-width: none; order: 1; min-width: 0; }
  .hero-visual { order: 2; min-width: 0; }
  .hero-visual-shell { width: min(420px, 92vw); min-height: 650px; margin: 0 auto; }
  .how-steps { grid-template-columns: 1fr; gap: 40px; }
  .triptych { grid-template-columns: 1fr; }
  .tiers { grid-template-columns: 1fr; max-width: 460px; }
  .river-layout { grid-template-columns: 1fr; gap: 28px; }
}

@media (max-width: 720px) {
  :root { --page-edge: clamp(18px, 5vw, 28px); }
  .nav { overflow: hidden; }
  .nav-inner { width: 100%; min-width: 0; padding-top: 14px; padding-bottom: 12px; }
  .nav-meta { gap: 10px; min-width: 0; }
  .wordmark { min-width: 0; flex-shrink: 0; }
  .lang-toggle { flex-shrink: 0; margin-left: auto; }
  .nav-cta { display: none; }
  .lang-toggle { gap: 3px; font-size: 10px; }
  .lang-btn { padding: 9px 6px; }            /* >=24px touch target (WCAG 2.5.8) */
  .theme-toggle { width: 40px; height: 40px; }
  .hero { width: auto; max-width: 100%; overflow: hidden; padding-top: 118px; padding-bottom: 48px; }
  .hero-grid,
  .hero-copy,
  .hero-cta,
  .waitlist-form,
  .field { width: auto; max-width: 100%; min-width: 0; }
  .hero-title-break { display: block; }
  .display-hero {
    font-size: clamp(42px, 11vw, 56px);
    line-height: 1.02;
    letter-spacing: -.028em;
    max-width: 13.25ch;
  }
  .hero-copy .lede {
    max-width: 31ch;
    font-size: 16px;
  }
  .hero-whisper {
    margin-bottom: 18px;
    letter-spacing: .14em;
  }
  .hero-proof {
    grid-template-columns: 1fr;
    width: 100%;
    max-width: 430px;
    gap: 8px;
    margin-bottom: 24px;
  }
  .hero-proof li {
    width: 100%;
    min-width: 0;
    min-height: 0;
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
    padding: 12px 14px;
  }
  .hero-proof li span:last-child { font-size: 13.5px; }
  .field { flex-direction: column; }
  .field .cta-pill {
    width: 100%;
    min-width: 0;
    padding: 13px;
    white-space: normal;
    text-align: center;
  }
  .waitlist-form { max-width: 100%; }
  .email-input { width: 100%; }
  .form-microcopy,
  .form-feedback { overflow-wrap: anywhere; }
  .hero-visual {
    width: 100%;
    overflow: hidden;
    margin-inline: calc(var(--page-edge) * -1);
    padding-inline: var(--page-edge);
  }
  .hero-visual-shell {
    width: min(370px, 94vw);
    min-height: 630px;
  }
  .visual-chip {
    display: none;
  }
  .phone { width: min(330px, 84vw); }
  .footer-inner { grid-template-columns: 1fr; }
  .footer-meta { justify-content: flex-start; }

  /* vertical river on phones: compact vertical SVG + autoplay loop,
     NO scroll hijack (sticky is desktop-only). Time flows top→bottom. */
  .river-track { height: auto; }
  .river-sticky { position: static; height: auto; display: block; padding: clamp(56px, 9vh, 90px) 0; overflow: visible; }
  .river-layout { display: block; }
  .river-copy { max-width: none; margin-bottom: 28px; }
  .river-stage { height: min(68vh, 540px); }
  .river-sample { right: var(--page-edge); top: clamp(40px, 8vh, 64px); }
  .river-progress { display: none; }       /* autoplay needs no scrub indicator */
}

@media (max-width: 420px) {
  .wordmark-text { font-size: 21px; }
  .theme-toggle { display: none; }
  .display-hero { font-size: clamp(39px, 10.6vw, 48px); }   /* floor lowered so long TR words wrap cleanly */
  .hero-copy .eyebrow { margin-bottom: 18px; }
  .hero-proof li { align-items: flex-start; flex-direction: column; gap: 5px; }
  .hero-visual-shell { min-height: 590px; }
  .phone { width: min(318px, 86vw); }
  .store-row { gap: 12px; }
}

/* ============================================================
   REDUCED MOTION — animations off, everything visible
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .001ms !important;
    scroll-behavior: auto !important;
  }
  html.js .reveal, html.js .reveal-line { opacity: 1 !important; transform: none !important; }
  .river-track { height: auto !important; }
  .river-sticky { position: static !important; height: auto !important; padding: 80px 0; overflow: visible; }
  .ambient-stars, .ambient-aurora { animation: none !important; }
  .scanline { opacity: 1 !important; }
  .ai-typed .tw-word { opacity: 1 !important; }
}

/* ============================================================
   PRINT / PDF — a calm light document, not a dark ink-flood
   (a pricing/FAQ page is a natural thing to save or share as PDF)
   ============================================================ */
@media print {
  :root, :root[data-theme="dark"] { color-scheme: light; }
  html, body { background: #fff !important; color: #1E2A24 !important; }
  * { box-shadow: none !important; text-shadow: none !important; background-image: none !important; }
  .ambient, .nav, .skip-link, .theme-toggle, .lang-toggle, .billing-toggle,
  .hero-visual, .qr, .orb, .orb-large, .river-stage, .river-progress { display: none !important; }
  main { padding-top: 0 !important; }
  .reveal, .reveal-line { opacity: 1 !important; transform: none !important; }
  .river-track { height: auto !important; }
  .river-sticky { position: static !important; height: auto !important; overflow: visible; padding: 24px 0; }
  section { break-inside: avoid; page-break-inside: avoid; }
  a { color: #1E2A24 !important; text-decoration: underline; }
}

/* ============================================================
   V2 ART DIRECTION — product operating system, live canvas river
   ============================================================ */
.hero-v2 {
  max-width: 1320px;
  min-height: min(100svh, 980px);
  padding-top: clamp(104px, 13vh, 156px);
}
.hero-v2 .hero-grid {
  grid-template-columns: minmax(340px, .88fr) minmax(520px, 1.12fr);
  gap: clamp(42px, 6vw, 110px);
}
.hero-v2 .hero-copy { max-width: 660px; }
.hero-v2 .display-hero {
  font-size: clamp(48px, 7.4vw, 96px);
  line-height: .89;
  max-width: 10.8ch;
}
.hero-v2 .display-hero em { display: inline; }
.hero-v2 .lede {
  max-width: 610px;
  font-size: clamp(17px, 1.45vw, 21px);
}
.hero-v2 .hero-proof {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  max-width: 640px;
}
.hero-v2 .hero-proof li {
  min-height: 88px;
  border-radius: 20px;
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--card-bg) 84%, var(--sage) 9%), color-mix(in srgb, var(--bg) 72%, transparent)),
    radial-gradient(circle at 18% 14%, color-mix(in srgb, var(--sage) 15%, transparent), transparent 44%);
}

.hero-experience {
  position: relative;
  min-height: min(78vh, 720px);
  display: grid;
  place-items: center;
  isolation: isolate;
  perspective: 1600px;
}
.hero-map {
  position: absolute;
  inset: -7% -10%;
  width: 120%;
  height: 114%;
  z-index: -2;
  opacity: .94;
  filter: saturate(1.04);
}
.hero-experience::before {
  content: '';
  position: absolute;
  inset: 4% 2% 6%;
  z-index: -3;
  border-radius: 42% 58% 48% 52%;
  background:
    radial-gradient(circle at 48% 38%, color-mix(in srgb, var(--sage) 28%, transparent), transparent 50%),
    radial-gradient(circle at 78% 70%, color-mix(in srgb, var(--warm) 22%, transparent), transparent 58%),
    radial-gradient(circle at 16% 74%, color-mix(in srgb, var(--p-child) 16%, transparent), transparent 46%);
  filter: blur(22px);
  opacity: .95;
}
.hero-experience::after {
  content: '';
  position: absolute;
  left: 18%;
  right: 12%;
  bottom: 6%;
  height: 44px;
  z-index: -2;
  border-radius: 999px;
  background: radial-gradient(ellipse at center, rgba(0, 0, 0, .42), transparent 72%);
  opacity: .48;
}
.experience-shell {
  width: min(540px, 88vw);
  min-height: 610px;
  padding: 24px;
  border-radius: 38px;
  position: relative;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--sage) 18%, var(--card-border));
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--card-bg) 92%, var(--sage) 4%), color-mix(in srgb, var(--bg) 76%, transparent)),
    radial-gradient(circle at 76% 14%, color-mix(in srgb, var(--warm) 18%, transparent), transparent 42%);
  box-shadow:
    0 56px 110px -62px color-mix(in srgb, var(--sage) 55%, rgba(0,0,0,.42)),
    inset 0 1px 0 color-mix(in srgb, white 30%, transparent);
  backdrop-filter: blur(22px) saturate(1.22);
  -webkit-backdrop-filter: blur(22px) saturate(1.22);
  transform: rotateX(4deg) rotateY(-7deg);
  transition: transform .55s var(--ease-std), box-shadow .55s var(--ease-std);
}
.experience-shell::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(110deg, transparent 0 26%, rgba(255,255,255,.18) 36%, transparent 48%),
    radial-gradient(circle at 18% 0%, color-mix(in srgb, var(--sage) 14%, transparent), transparent 38%);
  opacity: .7;
}
.experience-top,
.experience-main,
.dayline,
.care-feed,
.ai-brief {
  position: relative;
  z-index: 1;
}
.experience-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 44px;
}
.experience-top .phone-sample {
  position: static;
  inset: auto;
  flex-shrink: 0;
}
.experience-time {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: .12em;
  color: var(--ink-faint);
}
.experience-status {
  font-family: 'JetBrains Mono', monospace;
  font-size: 9px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--sage);
  padding: 7px 10px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--sage) 22%, transparent);
  background: color-mix(in srgb, var(--sage) 9%, transparent);
}
.experience-main { margin-bottom: 32px; }
.experience-main .phone-greet {
  font-size: clamp(36px, 4.5vw, 56px);
  max-width: 9ch;
}
.experience-main .phone-sub {
  font-size: 14px;
  max-width: 34ch;
}
.dayline {
  display: grid;
  grid-template-columns: auto repeat(4, 1fr) auto;
  align-items: center;
  gap: 12px;
  margin: 22px 0 24px;
  color: var(--ink-faint);
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: .12em;
}
.dayline::before {
  content: '';
  position: absolute;
  left: 34px;
  right: 34px;
  top: 50%;
  height: 1px;
  background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--sage) 50%, transparent), transparent);
}
.dayline i {
  position: relative;
  z-index: 1;
  justify-self: center;
  width: 11px;
  height: 11px;
  border-radius: 50%;
  background: color-mix(in srgb, var(--ink) 12%, transparent);
  border: 1px solid var(--hairline-strong);
}
.dayline i.is-done { background: var(--sage); box-shadow: 0 0 18px color-mix(in srgb, var(--sage) 55%, transparent); }
.dayline i.is-hot {
  background: var(--warm);
  box-shadow: 0 0 18px color-mix(in srgb, var(--warm) 55%, transparent);
  animation: hotPulseDom 3.4s ease-in-out infinite;
}
@keyframes hotPulseDom { 0%,100% { transform: scale(1); } 50% { transform: scale(1.18); } }

.care-feed {
  display: grid;
  gap: 10px;
}
.care-row {
  display: grid;
  grid-template-columns: 54px 10px 1fr;
  align-items: center;
  gap: 12px;
  padding: 13px 14px;
  border-radius: 18px;
  border: 1px solid var(--hairline);
  background: color-mix(in srgb, var(--ink) 2.2%, transparent);
}
.care-row.is-next {
  border-color: color-mix(in srgb, var(--sage) 30%, var(--hairline));
  background: color-mix(in srgb, var(--sage) 9%, transparent);
}
.care-time {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  color: var(--sage);
  font-variant-numeric: tabular-nums;
}
.care-person {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  box-shadow: 0 0 12px currentColor;
}
.care-person.self { color: var(--p-self); background: var(--p-self); }
.care-person.mom { color: var(--p-mom); background: var(--p-mom); }
.care-person.dad { color: var(--p-dad); background: var(--p-dad); }
.care-title {
  font-family: 'Fraunces', serif;
  font-size: 18px;
  line-height: 1.1;
  color: var(--ink);
}
.care-meta {
  font-family: 'JetBrains Mono', monospace;
  font-size: 9px;
  letter-spacing: .08em;
  color: var(--ink-faint);
  margin-top: 4px;
}
.ai-brief {
  margin-top: 18px;
  padding: 16px 17px;
  border-radius: 20px;
  background: color-mix(in srgb, var(--bg) 52%, transparent);
  border: 1px solid color-mix(in srgb, var(--sage) 16%, var(--hairline));
}
.ai-brief-text {
  font-family: 'Fraunces', serif;
  font-style: italic;
  font-weight: 300;
  font-size: 17px;
  line-height: 1.35;
  color: var(--ink);
}
.orbit-card {
  position: absolute;
  z-index: 3;
  display: inline-flex;
  align-items: center;
  gap: 9px;
  padding: 10px 13px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--sage) 28%, var(--card-border));
  background: color-mix(in srgb, var(--bg) 64%, transparent);
  box-shadow: 0 24px 48px -34px rgba(0,0,0,.55);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  font-family: 'JetBrains Mono', monospace;
  font-size: 9.5px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ink);
}
.orbit-card-a { top: 12%; right: 1%; animation: floatQuiet 5.4s ease-in-out infinite; }
.orbit-card-b { left: 0; bottom: 24%; animation: floatQuiet 6.1s ease-in-out infinite reverse; }
.orbit-card-c { right: 6%; bottom: 9%; animation: floatQuiet 5.8s ease-in-out infinite; }
.visual-chip-dot.child { background: var(--p-child); box-shadow: 0 0 12px var(--p-child); }
@keyframes floatQuiet { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-10px); } }

.river-v2 {
  margin-top: clamp(20px, 4vh, 60px);
  overflow: clip;
}
.river-v2::before {
  content: '';
  position: absolute;
  inset: 7% 0 auto;
  height: 86vh;
  pointer-events: none;
  background:
    radial-gradient(ellipse at 58% 48%, color-mix(in srgb, var(--sage) 18%, transparent), transparent 62%),
    radial-gradient(ellipse at 82% 18%, color-mix(in srgb, var(--warm) 15%, transparent), transparent 54%);
  opacity: .84;
}
.river-v2 .river-layout {
  max-width: 1320px;
  grid-template-columns: minmax(300px, 390px) minmax(0, 1fr);
  gap: clamp(34px, 5vw, 84px);
}
.river-v2 .river-stage {
  height: min(78vh, 720px);
  min-height: 560px;
}
.river-canvas-stage {
  border-radius: 36px;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--sage) 18%, var(--hairline));
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--bg) 74%, transparent), color-mix(in srgb, var(--card-bg) 72%, transparent)),
    radial-gradient(circle at 66% 44%, color-mix(in srgb, var(--sage) 16%, transparent), transparent 46%);
  box-shadow: 0 52px 110px -72px color-mix(in srgb, var(--sage) 55%, rgba(0,0,0,.55));
}
.river-canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
}
.river-panel {
  position: absolute;
  right: clamp(18px, 3vw, 34px);
  top: clamp(56px, 7vh, 84px);
  width: min(310px, 42%);
  padding: 18px 18px 17px;
  border-radius: 24px;
  border: 1px solid color-mix(in srgb, var(--sage) 20%, var(--card-border));
  background: color-mix(in srgb, var(--bg) 66%, transparent);
  backdrop-filter: blur(20px) saturate(1.18);
  -webkit-backdrop-filter: blur(20px) saturate(1.18);
  box-shadow: 0 24px 60px -42px rgba(0,0,0,.55);
}
.river-panel-kicker {
  font-family: 'JetBrains Mono', monospace;
  font-size: 9px;
  letter-spacing: .16em;
  color: var(--sage);
  margin-bottom: 10px;
}
.river-panel-title {
  font-family: 'Fraunces', serif;
  font-weight: 300;
  font-size: clamp(25px, 2.8vw, 36px);
  line-height: 1;
  letter-spacing: -.025em;
  color: var(--ink);
}
.river-panel-meta {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: .08em;
  color: var(--ink-faint);
  margin-top: 8px;
}
.river-panel-note {
  font-size: 13px;
  line-height: 1.55;
  color: var(--ink-dim);
  margin-top: 14px;
}
/* dose text breathes in on change instead of hard-cutting during the scrub */
.river-panel-title.swapping, .river-panel-meta.swapping { transition: opacity .16s var(--ease-std); }
.river-dock {
  position: absolute;
  left: clamp(18px, 3vw, 34px);
  bottom: clamp(18px, 3vw, 34px);
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.river-dock li {
  min-width: 96px;
  padding: 12px 13px;
  border-radius: 18px;
  border: 1px solid var(--hairline);
  background: color-mix(in srgb, var(--bg) 56%, transparent);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}
.river-dock span {
  display: block;
  font-family: 'JetBrains Mono', monospace;
  font-size: 8.5px;
  letter-spacing: .13em;
  text-transform: uppercase;
  color: var(--ink-faint);
}
.river-dock b {
  display: block;
  font-family: 'Fraunces', serif;
  font-size: 30px;
  font-weight: 300;
  line-height: 1;
  margin-top: 7px;
  color: var(--ink);
}
.river-v2 .river-progress {
  left: clamp(18px, 3vw, 34px);
  right: clamp(18px, 3vw, 34px);
  bottom: 12px;
  background: color-mix(in srgb, var(--ink) 11%, transparent);
}

@media (max-width: 1040px) {
  .hero-v2 .hero-grid {
    grid-template-columns: 1fr;
    max-width: 760px;
    margin: 0 auto;
  }
  .hero-v2 .hero-copy { order: 1; }
  .hero-experience { order: 2; }
  .hero-v2 .display-hero { max-width: 12ch; }
  .hero-experience { min-height: 680px; }
  .experience-shell { transform: none; }
  .river-v2 .river-layout { grid-template-columns: 1fr; }
  .river-v2 .river-copy { max-width: 640px; }
}

@media (max-width: 720px) {
  .nav-inner { gap: 12px; }
  .nav .lang-toggle,
  .nav .theme-toggle { display: none; }
  .nav .nav-cta { display: none; }
  .hero-v2 {
    display: block;
    padding-top: 112px;
    padding-bottom: 42px;
  }
  .hero-v2 .hero-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    width: 100%;
    max-width: 100%;
  }
  .hero-v2 .hero-copy,
  .hero-v2 .hero-cta {
    width: 100%;
    max-width: 100%;
    min-width: 0;
  }
  .hero-v2 .waitlist-form,
  .hero-v2 .field {
    width: min(100%, 342px);
    max-width: min(100%, 342px);
    min-width: 0;
  }
  .hero-v2 .lede,
  .hero-v2 .hero-whisper,
  .hero-v2 .hero-proof {
    width: min(100%, 342px);
    max-width: min(100%, 342px);
    overflow-wrap: anywhere;
  }
  .hero-v2 .field {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
  }
  .hero-v2 .display-hero {
    font-size: clamp(42px, 12vw, 58px);
    width: min(100%, 342px);
    max-width: min(100%, 342px);
  }
  .hero-v2 .hero-proof {
    grid-template-columns: 1fr;
  }
  .hero-v2 .hero-proof li {
    min-height: 68px;
  }
  .hero-experience {
    min-height: 590px;
    overflow: hidden;
  }
  .hero-map {
    inset: -3% -18%;
    width: 136%;
    height: 108%;
  }
  .experience-shell {
    width: min(420px, 92vw);
    min-height: 520px;
    padding: 20px;
    border-radius: 30px;
  }
  .experience-main .phone-greet { font-size: clamp(34px, 10vw, 44px); }
  .orbit-card {
    position: static;
    justify-self: center;
    margin-top: 10px;
  }
  .orbit-card-b,
  .orbit-card-c { display: none; }
  .dayline { gap: 8px; }
  .care-row {
    grid-template-columns: 48px 9px 1fr;
    padding: 11px 12px;
  }
  .ai-brief { padding: 14px; }
  .river-v2 .river-sticky {
    padding-top: 72px;
    padding-bottom: 76px;
  }
  .river-v2 .river-stage {
    height: 650px;
    min-height: 650px;
    border-radius: 28px;
  }
  .river-panel {
    left: 16px;
    right: 16px;
    top: 16px;
    width: auto;
  }
  .river-dock {
    left: 16px;
    right: 16px;
    bottom: 18px;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
  }
  .river-dock li {
    min-width: 0;
    padding: 10px;
  }
  .river-dock b { font-size: 24px; }
}

@media (max-width: 420px) {
  .nav .nav-cta { display: none; }
  .hero-v2 .display-hero { font-size: clamp(38px, 11.4vw, 48px); }
  .experience-shell { width: min(380px, 94vw); }
  .experience-status { display: none; }
  .care-feed { gap: 8px; }
  .river-v2 .river-stage {
    height: 610px;
    min-height: 610px;
  }
  .river-panel-note { display: none; }
}

@media (prefers-reduced-motion: reduce) {
  .orbit-card,
  .dayline i.is-hot { animation: none; }
}

@media print {
  .hero-map,
  .river-canvas,
  .orbit-card,
  .river-panel,
  .river-dock { display: none !important; }
}
