/* landing.css — Autopilot Deals · "Midnight Editorial"
   Dark midnight base + warm ink + sky-blue accent (swatchable). Literata
   headlines, Hanken Grotesk body, Dancing Script handwritten accents.
   Paper noise, soft radii, single dark theme. */

:root{
  --bg:#0F141C; --bg-2:#131B27; --bg-deep:#080B11;
  --surface:#172031; --surface-2:#1F2A3D;
  --hairline:rgba(244,239,231,.13); --hairline-2:rgba(244,239,231,.07);
  --ink:#F5EFE4; --ink-mid:#B7AC98; --ink-low:#7B8597; --ink-faint:#46505F;
  --accent:#6CB8F2; --accent-deep:#9ED0F6; --accent-soft:rgba(108,184,242,.16); --accent-line:rgba(108,184,242,.4); --on-accent:#0A1019;
  --good:#5FCF8F; --bad:#E8786B;
  --r-lg:22px; --r-md:16px; --r-sm:12px;
  --serif:'Literata', Georgia, serif;
  --ui:'Hanken Grotesk', ui-sans-serif, system-ui, sans-serif;
  --hand:'Dancing Script', ui-rounded, cursive;
  --maxw:1240px;
}
*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{ margin:0; background:var(--bg); color:var(--ink); font-family:var(--ui); font-weight:400;
  -webkit-font-smoothing:antialiased; line-height:1.6; overflow-x:hidden; }
/* paper noise */
body::before{ content:''; position:fixed; inset:0; pointer-events:none; z-index:9999; opacity:.06; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.6' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }
a{ color:inherit; text-decoration:none; }
a:focus-visible, button:focus-visible, input:focus-visible{ outline:2px solid var(--accent-deep); outline-offset:3px; }
a:focus:not(:focus-visible), button:focus:not(:focus-visible){ outline:none; }
.wrap{ width:90vw; max-width:var(--maxw); margin:0 auto; }
.serif{ font-family:var(--serif); font-weight:400; }
.eyebrow{ font-family:var(--ui); font-size:11px; font-weight:500; letter-spacing:.26em; text-transform:uppercase; color:var(--ink-mid); }

/* ── nav ─────────────────────────────────────────────────── */
.nav{ position:sticky; top:0; z-index:50; backdrop-filter:blur(10px);
  background:color-mix(in srgb, var(--bg) 82%, transparent); border-bottom:1px solid var(--hairline-2); }
.nav-in{ display:flex; align-items:center; gap:24px; height:80px; }
.brand{ display:flex; align-items:center; gap:11px; font-family:'Schibsted Grotesk', var(--ui); font-weight:600; font-size:21px; letter-spacing:-.01em; }
.brand .orb{ width:16px; height:16px; border-radius:50%; background:var(--accent);
  box-shadow:0 0 0 4px color-mix(in srgb, var(--accent) 30%, transparent), 0 0 16px var(--accent-soft); animation:breathe 3.4s ease-in-out infinite; }
.brand em{ font-style:normal; color:var(--accent-deep); }
@keyframes breathe{ 0%,100%{ transform:scale(.9); } 50%{ transform:scale(1.08); } }
.nav-links{ display:flex; gap:28px; margin-left:auto; font-size:11px; font-weight:500; letter-spacing:.2em;
  text-transform:uppercase; color:var(--ink-mid); }
.nav-links a{ white-space:nowrap; transition:color .2s; }
.nav-links a:hover{ color:var(--ink); }
.beta{ font-size:10px; font-weight:500; letter-spacing:.24em; text-transform:uppercase; color:var(--ink-mid);
  border:1px solid var(--hairline); border-radius:999px; padding:6px 13px; white-space:nowrap; }
.btn{ font-family:var(--ui); font-size:13px; font-weight:500; letter-spacing:.04em; cursor:pointer; border-radius:var(--r-sm);
  padding:13px 26px; border:1px solid var(--accent); background:var(--accent); color:var(--on-accent);
  transition:background .4s ease, color .4s ease, transform .4s cubic-bezier(.16,1,.3,1), box-shadow .4s ease; white-space:nowrap; }
.btn:hover{ background:var(--accent-deep); border-color:var(--accent-deep); color:var(--on-accent); transform:translateY(-1px); box-shadow:0 10px 28px var(--accent-soft); }
.btn.ghost{ background:transparent; color:var(--ink); border-color:var(--hairline); }
.btn.ghost:hover{ background:transparent; border-color:var(--accent-line); color:var(--ink); box-shadow:none; }
.theme-toggle{ width:40px; height:40px; border-radius:0; border:1px solid var(--hairline); background:transparent;
  color:var(--ink-mid); cursor:pointer; display:flex; align-items:center; justify-content:center; flex:none; transition:.25s; }
.theme-toggle:hover{ border-color:var(--ink); color:var(--ink); }
.theme-toggle .sun{ display:none; } .theme-toggle .moon{ display:block; }
:root[data-theme="dark"] .theme-toggle .sun{ display:block; } :root[data-theme="dark"] .theme-toggle .moon{ display:none; }

/* ── hero ────────────────────────────────────────────────── */
.hero{ position:relative; padding:96px 0 96px; }
.hero-grid{ display:grid; grid-template-columns:0.78fr 1.32fr; gap:44px; align-items:center; }
.hero h1{ font-family:var(--serif); font-weight:500; font-size:clamp(42px,6.2vw,84px); line-height:.98;
  letter-spacing:-.01em; margin:22px 0 0; text-wrap:balance; }
.hero p.lede{ font-size:19px; color:var(--ink-mid); max-width:560px; margin:30px 0 0; font-weight:300; }
.hero-cta{ display:flex; gap:14px; margin-top:36px; flex-wrap:wrap; align-items:center; }
.hero-note{ margin-top:26px; font-family:var(--hand); font-size:30px; line-height:1; color:var(--accent-deep);
  display:flex; align-items:center; gap:10px; }
.hero-note::before{ content:'↳'; font-family:var(--ui); font-size:18px; color:var(--accent-deep); }

/* hero visual — soft organic card */
.hero-visual{ border:1px solid var(--hairline); border-radius:var(--r-lg); background:var(--surface);
  padding:40px 34px 34px; display:flex; flex-direction:column; align-items:center; gap:22px;
  box-shadow:0 30px 70px rgba(32,42,45,.10); }
.hv-head{ align-self:flex-start; display:flex; align-items:center; gap:9px; font-size:10px; font-weight:500;
  letter-spacing:.26em; text-transform:uppercase; color:var(--ink-mid); }
.hv-dot{ width:7px; height:7px; border-radius:50%; background:var(--accent-deep);
  box-shadow:0 0 0 4px color-mix(in srgb, var(--accent) 35%, transparent); animation:breathe 2.6s ease-in-out infinite; }
.hv-orb{ width:128px; height:128px; display:flex; align-items:center; justify-content:center; margin-top:8px;
  position:relative; isolation:isolate; }
/* aura: shader-style pulsing energy field (layered, no HTML change) */
.hv-orb::before, .hv-orb::after{ content:''; position:absolute; border-radius:50%; pointer-events:none; }
.hv-orb::before{ inset:-12%; background:radial-gradient(circle at 50% 50%,
    color-mix(in srgb, var(--accent) 70%, transparent) 0%, transparent 66%);
  filter:blur(11px); animation:auraPulse 4.2s ease-in-out infinite; z-index:0; }
.hv-orb::after{ inset:2%; background:radial-gradient(circle at 36% 34%, var(--accent-deep) 0%, transparent 60%);
  filter:blur(13px); opacity:.85; animation:auraSwirl 7.5s linear infinite; z-index:0; }
.hv-orb .core{ position:relative; width:78%; height:78%; border-radius:50%; z-index:1;
  background:
    radial-gradient(circle at 38% 32%, #FFFFFF 0%, color-mix(in srgb, var(--accent) 88%, #fff) 30%, var(--accent) 58%, var(--accent-deep) 100%);
  box-shadow:0 0 38px color-mix(in srgb, var(--accent) 55%, transparent), 0 14px 40px rgba(32,42,45,.18);
  animation:breathe 3.6s ease-in-out infinite; overflow:hidden; }
.hv-orb .core::before{ content:''; position:absolute; inset:-34%; border-radius:50%;
  background:conic-gradient(from 0deg, transparent 0%, color-mix(in srgb, #fff 70%, var(--accent)) 22%, transparent 50%, color-mix(in srgb, var(--accent-deep) 80%, transparent) 74%, transparent 100%);
  filter:blur(7px); opacity:.7; animation:auraSpin 5.5s linear infinite; }
.hv-orb .core::after{ content:''; position:absolute; inset:16%; border-radius:50%;
  background:radial-gradient(circle at 40% 34%, rgba(255,255,255,.95) 0%, transparent 58%);
  animation:auraHot 2.8s ease-in-out infinite; }
@keyframes auraPulse{ 0%,100%{ transform:scale(.92); opacity:.85; } 50%{ transform:scale(1.12); opacity:1; } }
@keyframes auraSwirl{ 0%{ transform:rotate(0) translate(2%,0) scale(1); } 50%{ transform:rotate(180deg) translate(-2%,2%) scale(1.08); } 100%{ transform:rotate(360deg) translate(2%,0) scale(1); } }
@keyframes auraSpin{ to{ transform:rotate(360deg); } }
@keyframes auraHot{ 0%,100%{ transform:scale(.86); opacity:.7; } 50%{ transform:scale(1.05); opacity:1; } }
.hv-wave{ display:flex; align-items:center; gap:5px; height:30px; }
.hv-wave span{ width:4px; border-radius:3px; background:var(--accent-deep); transform-origin:center; animation:eq .9s ease-in-out infinite; }
.hv-wave span:nth-child(odd){ height:45%; } .hv-wave span:nth-child(even){ height:80%; } .hv-wave span:nth-child(3n){ height:30%; }
.hv-wave span:nth-child(1){ animation-delay:0s; } .hv-wave span:nth-child(2){ animation-delay:.1s; }
.hv-wave span:nth-child(3){ animation-delay:.2s; } .hv-wave span:nth-child(4){ animation-delay:.3s; }
.hv-wave span:nth-child(5){ animation-delay:.4s; } .hv-wave span:nth-child(6){ animation-delay:.5s; }
.hv-wave span:nth-child(7){ animation-delay:.6s; } .hv-wave span:nth-child(8){ animation-delay:.7s; }
.hv-wave span:nth-child(9){ animation-delay:.8s; }
@keyframes eq{ 0%,100%{ transform:scaleY(.4); } 50%{ transform:scaleY(1); } }
.hv-line{ font-family:var(--serif); font-style:italic; font-size:25px; line-height:1.28; text-align:center;
  color:var(--ink); text-wrap:balance; max-width:340px; }

/* hero headline streaming + hand-drawn sage underline */
.hero h1 em{ font-style:italic; }
.hero h1 .g{ position:relative; font-style:italic; white-space:nowrap; }
.hero h1 .g::after{ content:''; position:absolute; left:-.02em; right:-.02em; bottom:-.12em; height:.34em;
  background:var(--accent-deep);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 300 24' preserveAspectRatio='none'%3E%3Cpath d='M3 14 C40 4 62 22 96 13 S150 2 184 13 232 23 264 12 295 8 296 8' fill='none' stroke='%23fff' stroke-width='3.4' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat center/100% 100%;
          mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 300 24' preserveAspectRatio='none'%3E%3Cpath d='M3 14 C40 4 62 22 96 13 S150 2 184 13 232 23 264 12 295 8 296 8' fill='none' stroke='%23fff' stroke-width='3.4' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat center/100% 100%;
  clip-path:inset(0 calc((1 - var(--up,0)) * 100%) 0 0); transition:clip-path .14s linear; }
.hero h1 .w{ white-space:nowrap; }
.hero h1 .c{ opacity:0; position:relative; }
.hero h1 .c.on{ opacity:1; }
.hero h1 .c.cur::after{ content:''; position:absolute; right:-.05em; top:.18em; width:.05em; height:.68em;
  background:var(--ink); animation:cblink 1s steps(1) infinite; }
@keyframes cblink{ 50%{ opacity:0; } }

/* accent tweaker */
.tweaker{ position:fixed; right:20px; bottom:20px; z-index:200; display:flex; flex-direction:column; align-items:flex-end; gap:10px; }
.tw-toggle{ display:flex; align-items:center; gap:9px; font-family:var(--ui); font-size:11px; font-weight:500; letter-spacing:.18em;
  text-transform:uppercase; color:var(--ink); background:color-mix(in srgb, var(--surface) 80%, transparent); border:1px solid var(--hairline); border-radius:999px;
  padding:10px 16px; cursor:pointer; box-shadow:0 10px 28px rgba(0,0,0,.4); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px); }
.tw-dot{ width:12px; height:12px; border-radius:50%; background:var(--accent); border:1px solid var(--hairline); }
.tw-panel{ display:none; gap:10px; background:color-mix(in srgb, var(--surface) 84%, transparent); border:1px solid var(--hairline); border-radius:var(--r-sm); padding:14px;
  box-shadow:0 18px 44px rgba(0,0,0,.5); backdrop-filter:blur(18px); -webkit-backdrop-filter:blur(18px); }
.tw-panel.open{ display:flex; }
.tw-sw{ width:30px; height:30px; border-radius:8px; cursor:pointer; border:2px solid transparent; padding:0; transition:transform .2s; }
.tw-sw:hover{ transform:scale(1.14); }
.tw-sw.sel{ border-color:var(--ink); }

/* ── sections ────────────────────────────────────────────── */
section{ padding:120px 0; }
.section-head{ max-width:700px; margin-bottom:56px; }
.section-head h2{ font-family:var(--serif); font-weight:400; font-size:clamp(34px,4.6vw,60px); line-height:1.0;
  letter-spacing:-.01em; margin:16px 0 0; text-wrap:balance; }
.section-head p{ font-size:18px; color:var(--ink-mid); margin:20px 0 0; font-weight:300; }
.alt{ background:var(--bg-2); }
.problem h2{ font-family:var(--serif); font-weight:400; font-size:clamp(30px,4vw,48px); line-height:1.14;
  letter-spacing:-.01em; text-wrap:balance; max-width:1000px; }
.problem h2 .dim{ color:var(--ink-low); }

/* how it works — horizontal steps (left to right) */
.hsteps{ list-style:none; margin:0; padding:0; display:grid; grid-template-columns:repeat(4,1fr); }
.hstep{ position:relative; padding:6px 28px 0 0; display:flex; flex-direction:column; align-items:flex-start; }
.hstep + .hstep{ padding-left:28px; border-left:1px solid var(--hairline); }
.hs-num{ font-family:var(--ui); font-size:11px; font-weight:500; letter-spacing:.24em; text-transform:uppercase; color:var(--ink-low); }
.hs-illo{ width:56px; height:56px; color:var(--accent-deep); margin:16px 0 20px; }
.hs-illo svg{ width:100%; height:100%; overflow:visible; }
.hstep h3{ font-family:var(--serif); font-weight:400; font-size:22px; line-height:1.12; margin:0; }
.hstep p{ font-size:14px; color:var(--ink-mid); margin:12px 0 0; font-weight:300; }
@media (min-width:881px){ .hstep h3{ min-height:2.3em; } }

/* hand-drawn looping animations */
.hd-dot{ animation:hd-dot 1.5s ease-in-out infinite; }
.hd-dot.d2{ animation-delay:.2s; } .hd-dot.d3{ animation-delay:.4s; }
@keyframes hd-dot{ 0%,100%{ opacity:.22; } 50%{ opacity:1; } }
.hd-wave{ transform-origin:42px 24px; animation:hd-wave 2.4s ease-in-out infinite; }
.hd-wave.w2{ animation-delay:.3s; }
@keyframes hd-wave{ 0%,100%{ opacity:0; } 40%{ opacity:.9; } }

.hd-card{ stroke-dasharray:34; stroke-dashoffset:34; animation:hd-draw 3.4s ease-in-out infinite; }
.hd-card.c2{ animation-delay:.25s; } .hd-card.c3{ animation-delay:.5s; } .hd-card.c4{ animation-delay:.75s; }
@keyframes hd-draw{ 0%{ stroke-dashoffset:34; } 30%,80%{ stroke-dashoffset:0; } 100%{ stroke-dashoffset:0; } }
.hd-sweep{ animation:hd-sweep 3.4s cubic-bezier(.5,0,.3,1) infinite; }
@keyframes hd-sweep{ 0%{ transform:translateY(0); opacity:0; } 12%{ opacity:.18; } 75%{ transform:translateY(27px); opacity:.18; } 90%,100%{ opacity:0; transform:translateY(27px); } }

.hd-shield{ stroke-dasharray:120; stroke-dashoffset:120; animation:hd-shielddraw 4s ease-in-out infinite; }
@keyframes hd-shielddraw{ 0%{ stroke-dashoffset:120; } 35%,100%{ stroke-dashoffset:0; } }
.hd-check{ stroke-dasharray:30; stroke-dashoffset:30; animation:hd-checkdraw 4s ease-in-out infinite; }
@keyframes hd-checkdraw{ 0%,38%{ stroke-dashoffset:30; } 56%,100%{ stroke-dashoffset:0; } }
.hd-spark{ transform-origin:44px 15px; animation:hd-spark 4s ease-in-out infinite; }
@keyframes hd-spark{ 0%,60%{ opacity:0; transform:scale(.4); } 72%{ opacity:1; transform:scale(1.1); } 86%,100%{ opacity:0; transform:scale(.7); } }

.hd-msg{ transform-origin:38px 25px; animation:hd-msgfloat 3.6s ease-in-out infinite; }
.hd-msgcheck{ stroke-dasharray:12; stroke-dashoffset:12; animation:hd-msgcheck 3.6s ease-in-out infinite; }
@keyframes hd-msgfloat{ 0%,18%{ transform:translate(0,0); opacity:1; } 60%{ transform:translate(2px,-3px); opacity:1; } 82%{ transform:translate(7px,-12px); opacity:0; } 100%{ transform:translate(0,0); opacity:1; } }
@keyframes hd-msgcheck{ 0%,30%{ stroke-dashoffset:12; } 48%,72%{ stroke-dashoffset:0; } 86%,100%{ stroke-dashoffset:12; } }

/* cards (philosophy-style invert on hover) */
.cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.card{ border:1px solid var(--hairline); border-radius:var(--r-md); padding:32px; background:var(--surface);
  transition:background .5s ease, color .5s ease, border-color .5s ease, transform .5s cubic-bezier(.16,1,.3,1); }
.card:hover{ background:var(--accent); border-color:var(--accent); color:var(--on-accent); transform:translateY(-4px); }
.card .ic{ color:var(--accent-deep); margin-bottom:16px; transition:color .5s; }
.card:hover .ic{ color:var(--on-accent); }
.card h3{ font-family:var(--serif); font-weight:500; font-size:24px; margin:0 0 8px; }
.card p{ font-size:15px; color:var(--ink-mid); margin:0; font-weight:300; transition:color .5s; }
.card:hover p{ color:rgba(10,16,25,.78); }

/* ── built around your brand ─────────────────────────────── */
.brand-grid{ display:grid; grid-template-columns:1fr; max-width:640px; margin:0 auto; gap:56px; align-items:center; text-align:center; }
.brand-copy h2{ font-family:var(--serif); font-weight:400; font-size:clamp(30px,4vw,46px); line-height:1.02; letter-spacing:-.015em; margin:14px 0 0; text-wrap:balance; }
.brand-copy > p{ font-size:17px; color:var(--ink-mid); margin:18px auto 0; font-weight:300; max-width:52ch; }
.brand-copy > p.brand-try{ margin-top:18px; font-size:14px; color:var(--accent-deep); display:flex; align-items:flex-start; gap:9px; }
.brand-try::before{ content:'→'; }
.brand-tiles{ display:flex; flex-direction:column; gap:14px; }
.btile{ display:flex; align-items:center; gap:16px; padding:18px 20px; border:1px solid var(--hairline); background:var(--surface);
  transition:border-color .3s, transform .3s cubic-bezier(.16,1,.3,1); }
.btile:hover{ border-color:var(--accent-line); transform:translateX(4px); }
.bt-logo{ width:44px; height:44px; flex:none; display:flex; align-items:center; justify-content:center; font-size:14px; font-weight:600;
  letter-spacing:.04em; color:#fff; background:var(--c); }
.bt-meta{ display:flex; flex-direction:column; flex:1; min-width:0; }
.bt-name{ font-family:var(--serif); font-size:21px; }
.bt-sub{ font-size:13.5px; color:var(--ink-mid); font-weight:300; }
.bt-orb{ width:26px; height:26px; flex:none; border-radius:50%; background:radial-gradient(circle at 38% 32%, #fff, var(--c) 62%, #00000022); box-shadow:0 0 16px color-mix(in srgb, var(--c) 50%, transparent); }

/* ── experience mock — charcoal device block on cream ────── */
.mock{ position:relative; border-radius:var(--r-md); overflow:hidden; background:#131B27; color:#F5EFE4;
  box-shadow:0 40px 90px rgba(0,0,0,.5); border:1px solid rgba(244,239,231,.1); }
.mock-bar{ display:flex; align-items:center; gap:8px; padding:14px 18px; border-bottom:1px solid rgba(247,245,235,.08); }
.mock-bar .md{ width:11px; height:11px; border-radius:50%; background:rgba(247,245,235,.18); }
.mock-url{ margin-left:14px; font-size:12px; letter-spacing:.12em; text-transform:uppercase; color:rgba(247,245,235,.4); }
.mock-body{ display:grid; grid-template-columns:1fr 1fr; min-height:444px; }
.mock-spine{ position:relative; overflow:hidden; padding:32px 28px; display:flex; flex-direction:column; gap:15px;
  border-right:1px solid rgba(247,245,235,.08); background:radial-gradient(80% 60% at 18% 8%, rgba(108,184,242,.15), transparent 62%); }
.mock-spine > *{ position:relative; z-index:1; }
.mock-spine::before{ content:''; position:absolute; z-index:0; width:220px; height:220px; border-radius:50%; top:-50px; left:-40px;
  background:radial-gradient(circle, rgba(108,184,242,.16), transparent 70%); animation:drift 9s ease-in-out infinite; }
@keyframes drift{ 0%,100%{ transform:translate(0,0); } 50%{ transform:translate(48px,34px); } }
.mock-frankie{ display:flex; align-items:center; gap:9px; font-size:10px; letter-spacing:.26em; text-transform:uppercase; color:rgba(247,245,235,.45); }
.mock-brand{ display:flex; align-items:center; gap:10px; padding-bottom:14px; margin-bottom:4px; border-bottom:1px solid rgba(247,245,235,.08); }
.mb-logo{ width:30px; height:30px; flex:none; display:flex; align-items:center; justify-content:center; font-size:11px; font-weight:600; letter-spacing:.04em; color:#0A1019; background:var(--accent); }
.mb-name{ font-size:14px; color:#F5EFE4; letter-spacing:.02em; }.mock-frankie .hv-dot{ background:var(--accent); box-shadow:0 0 0 4px rgba(108,184,242,.2); }
.mock-spine .hv-orb{ width:80px; height:80px; margin:2px 0; }
.mock-spine .hv-orb .core{ box-shadow:0 0 30px color-mix(in srgb, var(--accent) 50%, transparent), 0 8px 26px rgba(0,0,0,.4); }
.mock-line{ font-family:var(--serif); font-style:italic; font-size:23px; line-height:1.26; min-height:3.4em; color:#F7F5EB; }
.mock-line .dim{ color:rgba(247,245,235,.32); }
.mock-line.streaming::after, #mkYou.streaming::after{ content:''; display:inline-block; width:2px; height:.9em;
  background:var(--accent); margin-left:3px; transform:translateY(2px); animation:cblink 1s steps(1) infinite; }
.mock-you{ min-height:2.6em; transition:opacity .45s ease; font-family:var(--serif); font-style:italic; font-size:15px; color:rgba(247,245,235,.6); }
.mock-you .lbl{ font-style:normal; font-family:var(--ui); font-size:10px; letter-spacing:.22em; text-transform:uppercase; color:rgba(247,245,235,.4); display:block; margin-bottom:5px; }
.mock-canvas{ padding:26px; display:flex; flex-direction:column; gap:9px; justify-content:center; }
.mock-eyebrow{ font-size:10px; letter-spacing:.24em; text-transform:uppercase; color:rgba(247,245,235,.4); margin-bottom:4px; }
.mock-item{ display:flex; align-items:center; gap:12px; padding:12px 13px; border:1px solid rgba(247,245,235,.1); border-radius:10px; background:rgba(247,245,235,.04);
  transition:opacity .55s ease, transform .55s ease, filter .55s ease; }
.mock-item.pre, .mock-total.pre{ opacity:0; transform:translateY(14px); filter:blur(7px); }
.mock-item.dim{ opacity:.5; }
.mi-ic{ width:32px; height:32px; flex:none; border-radius:9px; border:1px solid rgba(247,245,235,.12); display:flex; align-items:center; justify-content:center; color:var(--accent); }
.mi-txt{ flex:1; min-width:0; } .mi-name{ font-size:15px; } .mi-sub{ font-size:12.5px; color:rgba(247,245,235,.5); font-weight:300; }
.mi-tag{ font-size:9.5px; letter-spacing:.12em; text-transform:uppercase; padding:5px 9px; border-radius:999px; white-space:nowrap; }
.mi-tag.rec{ color:#0A1019; background:var(--accent); }
.mi-tag.skip{ color:rgba(247,245,235,.5); border:1px solid rgba(247,245,235,.16); }
.mock-total{ display:flex; align-items:center; justify-content:space-between; margin-top:5px; padding-top:14px;
  border-top:1px solid rgba(247,245,235,.1); transition:opacity .55s ease, transform .55s ease, filter .55s ease; }
.mock-total span{ font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:rgba(247,245,235,.55); }
.mock-total b{ font-family:var(--serif); font-style:italic; font-weight:400; font-size:26px; }
.mock-total small{ font-family:var(--ui); font-size:12px; color:rgba(247,245,235,.45); }

/* closing — sage card */
.honesty{ border-radius:var(--r-lg); padding:48px 52px; background:var(--accent);
  display:flex; gap:24px; align-items:flex-start; color:var(--on-accent); }
.honesty .ic{ color:var(--on-accent); flex:none; margin-top:4px; }
.honesty h3{ font-family:var(--serif); font-weight:400; font-style:italic; font-size:32px; margin:0 0 10px; }
.honesty p{ font-size:17px; color:rgba(10,16,25,.82); margin:0; max-width:780px; font-weight:300; }

/* cta */
.cta{ text-align:center; }
.cta h2{ font-family:var(--serif); font-weight:400; font-style:italic; font-size:clamp(40px,6vw,84px); line-height:1.0;
  letter-spacing:-.01em; margin:0 0 18px; text-wrap:balance; }
.cta p{ font-size:18px; color:var(--ink-mid); margin:0 auto 32px; max-width:560px; font-weight:300; }
/* creative "Frankie" highlight in the CTA */
.frankie-hl{ position:relative; display:inline-block; color:var(--accent-deep); font-style:italic; padding:0 .06em; }
.frankie-hl::before{ content:''; position:absolute; inset:-.1em -.2em; background:var(--accent-soft); transform:skewX(-9deg) rotate(-1.2deg); z-index:-1; }
.signup{ display:flex; gap:10px; max-width:520px; margin:0 auto; border:1px solid var(--hairline); border-radius:var(--r-md);
  background:var(--surface); padding:8px 8px 8px 10px; }
.signup input{ flex:1; font-family:var(--ui); font-size:15px; padding:12px 16px; border:0; background:transparent; color:var(--ink); }
.signup input::placeholder{ color:var(--ink-low); }
.signup input:focus{ outline:none; }
.cta-fine{ margin-top:18px; font-size:10px; font-weight:500; letter-spacing:.2em; text-transform:uppercase; color:var(--ink-low); }

footer{ background:var(--bg-2); padding:54px 0; margin-top:0; }
.foot-in{ display:flex; align-items:center; gap:18px; flex-wrap:wrap; color:var(--ink-low); font-size:10px;
  font-weight:500; letter-spacing:.2em; text-transform:uppercase; }
.foot-in .sp{ flex:1; }

/* reveal */
.reveal{ opacity:0; transform:translateY(20px); transition:opacity .8s ease-out, transform .8s ease-out; }
.reveal.in{ opacity:1; transform:none; }

/* ── Frankie aura (hero + experience), ported from the app ─── */
.hv-aura{ width:158px; height:158px; display:flex; align-items:center; justify-content:center; margin-top:4px; }
.hero-visual{ min-height:360px; }
.hero-visual .hv-head .hv-dot{ transition:background .35s, box-shadow .35s; }
.hero-visual[data-state="speaking"] .hv-dot{ background:var(--accent); box-shadow:0 0 0 4px var(--accent-soft); }
.hero-visual[data-state="listening"] .hv-dot{ background:#8FB0B6; box-shadow:0 0 0 4px rgba(143,176,182,.2); }
.hv-line{ min-height:3.2em; }

/* experience mock — closer to the real app spine */
.mock-aura{ width:92px; height:92px; display:flex; align-items:center; justify-content:center; margin:2px 0 2px; }
.mock-frankie{ align-self:flex-start; display:inline-flex; align-items:center; gap:8px; font-size:10px; letter-spacing:.2em;
  text-transform:uppercase; color:var(--ink-mid); background:rgba(6,9,14,.5); border:1px solid var(--hairline);
  border-radius:999px; padding:5px 12px; }
.mock-ptt{ display:flex; align-items:center; gap:11px; margin-top:auto; padding:9px 12px;
  border:1px solid var(--hairline); border-radius:14px; background:rgba(247,245,235,.04); }
.mptt-ic{ width:34px; height:34px; flex:none; display:flex; align-items:center; justify-content:center;
  border-radius:11px; background:var(--accent-soft); color:var(--accent-deep); }
.mptt-hint{ font-size:13px; color:rgba(245,239,228,.72); display:flex; align-items:center; gap:8px; font-style:normal; font-family:var(--ui); }
.mptt-hint kbd{ font-family:var(--ui); font-size:9.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-mid);
  border:1px solid var(--hairline); border-radius:6px; padding:2px 7px; }

/* how-it-works: illustration sits at the top now (step labels removed) */
.hs-illo{ margin-top:2px; }

/* footer wordmark matches the nav brand */
.foot-brand{ text-transform:none; letter-spacing:-.01em; font-size:21px; color:var(--ink); }

/* compact hero variant of the experience mock — 2-col browser window, tighter */
.mock.compact .mock-body{ min-height:0; }
.mock.compact .mock-spine{ padding:20px 20px; gap:10px; }
.mock.compact .mock-aura{ width:72px; height:72px; }
.mock.compact .mock-line{ font-size:15px; line-height:1.34; min-height:4.4em; }
.mock.compact .mock-you{ font-size:12.5px; min-height:2em; }
.mock.compact .mock-canvas{ padding:18px 20px; gap:7px; justify-content:flex-start; }
.mock.compact .mock-eyebrow{ font-size:9px; }
.mock.compact .mock-item{ padding:9px 10px; gap:10px; }
.mock.compact .mi-ic{ width:28px; height:28px; }
.mock.compact .mi-name{ font-size:13px; }
.mock.compact .mi-sub{ font-size:11px; }
.mock.compact .mock-total b{ font-size:21px; }
.mock.compact .mock-ptt{ padding:8px 10px; margin-top:6px; }
.mock.compact .mptt-ic{ width:28px; height:28px; }
.mock.compact .mptt-hint{ font-size:11.5px; }
@media (max-width:700px){
  .mock.compact .mock-body{ grid-template-columns:1fr; }
  .mock.compact .mock-spine{ border-right:0; border-bottom:1px solid rgba(247,245,235,.08); }
}
/* below this width the hero stacks, so the demo gets full width (stays 2-col) */
@media (max-width:1040px){
  .hero-grid{ grid-template-columns:1fr; gap:40px; }
}
/* hide the nav links before the nav can no longer fit the CTA (fits only ≥~1050px) */
@media (max-width:1060px){
  .nav-links{ display:none; }
}

@media (max-width:880px){
  .hero-grid{ grid-template-columns:1fr; gap:36px; }
  section{ padding:88px 0; }
  .hsteps{ grid-template-columns:1fr 1fr; gap:0; }
  .hstep + .hstep{ border-left:0; padding-left:0; }
  .hstep{ padding:26px 20px 4px 0; }
  .hstep::before, .hstep + .hstep::before{ display:none; }
  .cards{ grid-template-columns:1fr; }
  .brand-grid{ grid-template-columns:1fr; gap:36px; }
  .mock-body{ grid-template-columns:1fr; }
  .mock-spine{ border-right:0; border-bottom:1px solid rgba(247,245,235,.08); }
  .nav-links{ display:none; }
  .honesty{ flex-direction:column; padding:36px; }
}

/* phones — hide the beta tag, shrink + allow the nav to wrap so the CTA never clips */
@media (max-width:620px){
  .nav-in{ flex-wrap:wrap; height:auto; min-height:64px; padding:12px 0; gap:10px 12px; }
  .beta{ display:none; }
  .brand{ font-size:18px; }
  .nav .btn{ padding:11px 18px; font-size:12.5px; }
}
