/* ============================================================
   WhyHire — Phase 0
   Design language: professional LinkedIn/Indeed (blue, warm
   off-white, clean cards) elevated with Bricolage + Hanken.
   ============================================================ */

:root{
  --brand:#0a66c2; --brand-strong:#004182; --brand-ink:#063a73;
  --brand-soft:#e8f0fa; --brand-soft-2:#dbe9f8;
  --ink:#1d2226; --ink-2:#41525f; --ink-3:#6b7b8a;
  --bg:#f4f1ea; --bg-2:#efebe1;
  --surface:#ffffff; --surface-2:#fbfaf6;
  --line:#e4e0d6; --line-2:#d8d3c6;
  --like:#1a8f5a; --like-soft:#e4f4ec; --like-ink:#0f5f3b;
  --pass:#d6455d; --pass-soft:#fbe7eb; --pass-ink:#a32238;
  --amber:#b45309;
  --shadow-sm:0 1px 2px rgba(20,30,45,.06), 0 1px 1px rgba(20,30,45,.04);
  --shadow:0 6px 20px rgba(20,30,45,.09), 0 2px 6px rgba(20,30,45,.05);
  --shadow-lg:0 22px 50px rgba(15,30,55,.16), 0 8px 20px rgba(15,30,55,.08);
  --r-xs:8px; --r-sm:10px; --r:14px; --r-lg:18px; --r-xl:24px; --pill:999px;
  --font-display:'Bricolage Grotesque', ui-sans-serif, system-ui, sans-serif;
  --font-body:'Hanken Grotesk', ui-sans-serif, system-ui, sans-serif;
  --maxw:1160px;
  --nav-h:66px;
}

html[data-theme="dark"]{
  --brand:#5aa2ec; --brand-strong:#8cc0f5; --brand-ink:#bcd9f8;
  --brand-soft:#152c44; --brand-soft-2:#1b3a59;
  --ink:#e7edf3; --ink-2:#aebcc8; --ink-3:#7e8f9d;
  --bg:#0e1318; --bg-2:#0a0e12;
  --surface:#161d25; --surface-2:#1b232c;
  --line:#28323d; --line-2:#34414e;
  --like:#3fbd82; --like-soft:#11271d; --like-ink:#7ed9ac;
  --pass:#f06a80; --pass-soft:#2a151a; --pass-ink:#f7a3b1;
  --amber:#e0922f;
  --shadow-sm:0 1px 2px rgba(0,0,0,.4);
  --shadow:0 8px 24px rgba(0,0,0,.5), 0 2px 6px rgba(0,0,0,.35);
  --shadow-lg:0 26px 60px rgba(0,0,0,.62), 0 10px 22px rgba(0,0,0,.45);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth; -webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:var(--font-body); font-size:17px; line-height:1.6;
  font-weight:400; letter-spacing:-0.005em;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  transition:background .35s ease, color .35s ease;
}
.wrap{width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:clamp(18px,4vw,40px)}
h1,h2,h3{font-family:var(--font-display); font-weight:700; line-height:1.06; letter-spacing:-0.025em; color:var(--ink); margin:0}
h1 em,h2 em{font-style:normal; color:var(--brand)}
p{margin:0}
a{color:inherit; text-decoration:none}
img,svg{display:block}
kbd{font-family:var(--font-body); font-size:.78em; background:var(--surface); border:1px solid var(--line-2); border-bottom-width:2px; border-radius:6px; padding:1px 6px; color:var(--ink-2)}

.skip{position:absolute; left:-999px; top:8px; z-index:200; background:var(--brand); color:#fff; padding:10px 16px; border-radius:var(--r-sm)}
.skip:focus{left:12px}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5em;
  font-family:var(--font-body); font-weight:600; font-size:.97rem; letter-spacing:-0.01em;
  padding:11px 20px; border-radius:var(--pill); border:1.5px solid transparent;
  cursor:pointer; transition:transform .14s ease, background .2s ease, box-shadow .2s ease, border-color .2s ease, color .2s ease;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px) scale(.99)}
.btn-primary{background:var(--brand); color:#fff; box-shadow:0 2px 10px rgba(10,102,194,.28)}
.btn-primary:hover{background:var(--brand-strong); box-shadow:0 6px 18px rgba(10,102,194,.34)}
html[data-theme="dark"] .btn-primary{color:#06203c}
.btn-ghost{background:transparent; color:var(--brand); border-color:var(--line-2)}
.btn-ghost:hover{border-color:var(--brand); background:var(--brand-soft)}
.btn-lg{padding:14px 26px; font-size:1.03rem}
.btn-block{width:100%}

/* ---------- Nav ---------- */
.nav{position:sticky; top:0; z-index:100; background:color-mix(in srgb, var(--bg) 86%, transparent); backdrop-filter:saturate(1.4) blur(12px); border-bottom:1px solid transparent; transition:border-color .3s ease, background .3s ease}
.nav.scrolled{border-bottom-color:var(--line); background:color-mix(in srgb, var(--bg) 94%, transparent)}
.nav-inner{height:var(--nav-h); display:flex; align-items:center; gap:24px}
.brand{display:inline-flex; align-items:center; gap:9px; color:var(--brand)}
.brand-mark{display:inline-flex; color:var(--brand)}
.brand-word{font-family:var(--font-display); font-weight:800; font-size:1.28rem; letter-spacing:-0.03em; color:var(--ink)}
.brand-word span{color:var(--brand)}
.nav-links{display:flex; gap:26px; margin-left:8px}
.nav-links a{font-size:.95rem; font-weight:500; color:var(--ink-2); transition:color .18s ease}
.nav-links a:hover{color:var(--brand)}
.nav-actions{margin-left:auto; display:flex; align-items:center; gap:12px}
.mode-toggle{display:inline-flex; align-items:center; justify-content:center; width:40px; height:40px; border-radius:var(--pill); border:1.5px solid var(--line-2); background:var(--surface); color:var(--ink-2); cursor:pointer; transition:transform .2s ease, color .2s ease, border-color .2s ease}
.mode-toggle:hover{color:var(--brand); border-color:var(--brand)}
.mode-toggle:active{transform:scale(.92) rotate(-12deg)}
.mode-toggle .i-moon{display:none}
html[data-theme="dark"] .mode-toggle .i-sun{display:none}
html[data-theme="dark"] .mode-toggle .i-moon{display:block}

/* ---------- Hero ---------- */
.hero{padding:clamp(40px,6vw,76px) 0 clamp(30px,4vw,52px); position:relative; overflow:hidden}
.hero::before{content:""; position:absolute; inset:0; background:
  radial-gradient(60% 70% at 88% 0%, color-mix(in srgb, var(--brand) 12%, transparent), transparent 70%),
  radial-gradient(40% 50% at 0% 100%, color-mix(in srgb, var(--brand) 7%, transparent), transparent 70%);
  pointer-events:none}
.hero-grid{display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(24px,4vw,56px); align-items:center; position:relative}
.eyebrow{display:inline-flex; align-items:center; gap:9px; font-size:.84rem; font-weight:600; letter-spacing:.01em; color:var(--brand-ink); background:var(--brand-soft); border:1px solid var(--brand-soft-2); padding:7px 14px; border-radius:var(--pill); margin-bottom:22px}
html[data-theme="dark"] .eyebrow{color:var(--brand-strong)}
.eyebrow .dot{width:7px; height:7px; border-radius:50%; background:var(--like); box-shadow:0 0 0 4px color-mix(in srgb, var(--like) 22%, transparent)}
h1{font-size:clamp(2.5rem,5.4vw,4.05rem); font-weight:800; margin-bottom:20px}
.lede{font-size:clamp(1.08rem,1.7vw,1.26rem); color:var(--ink-2); max-width:33ch; margin-bottom:30px}
.hero-cta{display:flex; gap:14px; flex-wrap:wrap; margin-bottom:22px}
.hero-foot{font-size:.92rem; color:var(--ink-3)}
.hero-foot strong{color:var(--ink-2)}

/* phone teaser */
.hero-art{display:flex; justify-content:center; perspective:1400px}
.phone{position:relative; width:min(320px,82vw); aspect-ratio:9/17; background:var(--surface); border:1px solid var(--line); border-radius:38px; box-shadow:var(--shadow-lg); padding:16px; transform:rotateY(-13deg) rotateX(4deg) rotate(1.5deg); transition:transform .5s cubic-bezier(.2,.8,.2,1)}
.hero-art:hover .phone{transform:rotateY(-6deg) rotateX(2deg)}
.phone-notch{position:absolute; top:13px; left:50%; transform:translateX(-50%); width:96px; height:7px; border-radius:99px; background:var(--line-2)}
.teaser-card{position:absolute; left:18px; right:18px; top:34px; bottom:96px; background:var(--surface-2); border:1px solid var(--line); border-radius:var(--r-lg); box-shadow:var(--shadow)}
.teaser-back1{transform:rotate(-4deg) scale(.95); opacity:.6; filter:saturate(.9)}
.teaser-back2{transform:rotate(5deg) scale(.9); opacity:.34}
.teaser-front{padding:18px; display:flex; flex-direction:column; overflow:hidden}
.tc-top{display:flex; align-items:center; gap:10px; margin-bottom:14px}
.logo-chip{flex:none; width:42px; height:42px; border-radius:11px; background:var(--c,#0a66c2); color:#fff; display:grid; place-items:center; font-family:var(--font-display); font-weight:700; font-size:1.15rem; box-shadow:var(--shadow-sm)}
.tc-co{display:flex; flex-direction:column; line-height:1.25; min-width:0}
.tc-co b{font-size:.98rem; color:var(--ink)}
.tc-co span{font-size:.8rem; color:var(--ink-3)}
.match-badge{margin-left:auto; flex:none; font-size:.82rem; font-weight:700; color:var(--like-ink); background:var(--like-soft); padding:5px 10px; border-radius:var(--pill)}
.teaser-front h3{font-size:1.42rem; margin:2px 0 8px}
.tc-sal{font-weight:700; color:var(--ink-2); margin-bottom:14px}
.chips{display:flex; flex-wrap:wrap; gap:8px}
.chips span{font-size:.8rem; font-weight:500; color:var(--ink-2); background:var(--brand-soft); border:1px solid var(--brand-soft-2); padding:5px 11px; border-radius:var(--pill)}
html[data-theme="dark"] .chips span{color:var(--brand-strong)}
.tc-foot{margin-top:auto; padding-top:14px}
.tag{font-size:.76rem; font-weight:600; color:var(--amber); background:color-mix(in srgb, var(--amber) 12%, transparent); padding:5px 10px; border-radius:var(--pill)}
.stamp{position:absolute; top:24px; font-family:var(--font-display); font-weight:800; font-size:1.5rem; letter-spacing:.06em; padding:6px 14px; border-radius:10px; border:3px solid; opacity:0}
.stamp-like{right:20px; color:var(--like); border-color:var(--like); transform:rotate(14deg)}
.hero-art:hover .stamp-like{opacity:1; transition:opacity .3s ease}
.teaser-controls{position:absolute; left:0; right:0; bottom:26px; display:flex; justify-content:center; gap:26px}
.mini-btn{width:54px; height:54px; border-radius:50%; display:grid; place-items:center; font-size:1.3rem; background:var(--surface); border:1px solid var(--line); box-shadow:var(--shadow)}
.mini-pass{color:var(--pass)}
.mini-like{color:var(--like)}

/* ---------- Stat band ---------- */
.stats{padding:6px 0 8px}
.stat-row{display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:18px; background:var(--surface); border:1px solid var(--line); border-radius:var(--r-xl); padding:clamp(20px,3vw,34px) clamp(18px,3vw,30px); box-shadow:var(--shadow-sm)}
.stat{text-align:center; padding:6px 8px; border-right:1px solid var(--line); min-width:0}
.stat:last-child{border-right:none}
.stat b{display:block; font-family:var(--font-display); font-weight:800; font-size:clamp(1.9rem,3.4vw,2.7rem); color:var(--brand); letter-spacing:-0.03em; line-height:1}
.stat span{display:block; margin-top:8px; font-size:.88rem; color:var(--ink-3); line-height:1.4}

/* ---------- Sections ---------- */
.section{padding:clamp(54px,8vw,104px) 0}
.section-alt{background:var(--bg-2)}
.sec-head{max-width:680px; margin:0 auto clamp(36px,5vw,58px); text-align:center}
.kicker{display:inline-block; font-size:.8rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--brand); margin-bottom:14px}
.sec-head h2,.split-copy h2,.wl-copy h2{font-size:clamp(1.9rem,3.6vw,2.85rem); font-weight:800}
.sec-sub{margin-top:16px; font-size:clamp(1.02rem,1.5vw,1.18rem); color:var(--ink-2)}

.two-col{display:grid; grid-template-columns:1fr 1fr; gap:clamp(20px,3vw,34px); align-items:center}

/* problem cards */
.problem-card{background:var(--surface); border:1px solid var(--line); border-radius:var(--r-xl); padding:clamp(24px,3vw,38px); box-shadow:var(--shadow-sm); transition:transform .25s ease, box-shadow .25s ease}
.problem-card:hover{transform:translateY(-4px); box-shadow:var(--shadow)}
.pc-badge{display:inline-block; font-size:.8rem; font-weight:700; padding:6px 13px; border-radius:var(--pill); margin-bottom:18px}
.pc-grad{color:var(--brand-ink); background:var(--brand-soft)}
html[data-theme="dark"] .pc-grad{color:var(--brand-strong)}
.pc-emp{color:var(--like-ink); background:var(--like-soft)}
.problem-card h3{font-size:1.42rem; margin-bottom:18px; line-height:1.18}
.ticks{list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:13px}
.ticks li{position:relative; padding-left:30px; color:var(--ink-2); font-size:1.01rem}
.ticks li::before{content:""; position:absolute; left:0; top:3px; width:19px; height:19px; border-radius:50%; background:var(--brand-soft); background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230a66c2' stroke-width='3.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12.5 10 17.5 19.5 7'/%3E%3C/svg%3E"); background-size:13px; background-repeat:no-repeat; background-position:center}

/* steps */
.steps{list-style:none; margin:0; padding:0; display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(16px,2vw,24px); counter-reset:s}
.step{background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); padding:26px 24px; box-shadow:var(--shadow-sm); position:relative; transition:transform .25s ease, box-shadow .25s ease}
.step:hover{transform:translateY(-5px); box-shadow:var(--shadow)}
.step-ic{display:inline-flex; align-items:center; justify-content:center; width:50px; height:50px; border-radius:14px; background:var(--brand-soft); color:var(--brand); margin-bottom:18px}
.step h3{font-size:1.06rem; color:var(--brand); margin-bottom:9px; font-weight:700; letter-spacing:.01em}
.step p{font-size:.97rem; color:var(--ink-2)}

/* ---------- Demo ---------- */
.demo-section{position:relative}
.demo-wrap{display:grid; grid-template-columns:minmax(0,1fr) 360px; gap:clamp(28px,4vw,56px); align-items:center; max-width:980px; margin-inline:auto}
.demo-device{justify-self:center; width:min(400px,94vw); background:var(--surface); border:1px solid var(--line); border-radius:var(--r-xl); box-shadow:var(--shadow-lg); padding:14px}
.demo-screen{background:var(--surface-2); border:1px solid var(--line); border-radius:var(--r-lg); padding:16px; min-height:560px; display:flex; flex-direction:column}
.demo-topbar{display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; padding:0 2px}
.persona{display:inline-flex; align-items:center; gap:8px; font-size:.86rem; font-weight:600; color:var(--ink-2)}
.persona-dot{width:8px; height:8px; border-radius:50%; background:var(--brand); box-shadow:0 0 0 4px color-mix(in srgb,var(--brand) 20%,transparent); transition:background .3s ease, box-shadow .3s ease}
.persona.recruiter .persona-dot{background:var(--amber); box-shadow:0 0 0 4px color-mix(in srgb,var(--amber) 22%,transparent)}
.demo-progress{font-size:.8rem; font-weight:600; color:var(--ink-3); background:var(--bg); border:1px solid var(--line); padding:3px 10px; border-radius:var(--pill)}
.stage{flex:1; display:flex; flex-direction:column}
.stage[hidden]{display:none}

/* swipe deck */
.deck{position:relative; flex:1; min-height:380px; touch-action:pan-y}
.job-card{position:absolute; inset:0; background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); box-shadow:var(--shadow); padding:20px; display:flex; flex-direction:column; cursor:grab; user-select:none; will-change:transform; transform-origin:center 120%}
.job-card.dragging{cursor:grabbing; transition:none}
.job-card.leaving{transition:transform .42s cubic-bezier(.4,.1,.3,1), opacity .42s ease}
.job-card h3{font-size:1.5rem; margin:4px 0 9px; line-height:1.12}
.jc-meta{display:flex; flex-wrap:wrap; gap:6px 12px; font-size:.88rem; color:var(--ink-3); margin-bottom:12px}
.jc-meta span{display:inline-flex; align-items:center; gap:5px}
.jc-sal{font-weight:700; color:var(--ink-2); font-size:1.02rem; margin-bottom:13px}
.jc-blurb{font-size:.94rem; color:var(--ink-2); margin-bottom:14px; line-height:1.5}
.jc-foot{margin-top:auto; display:flex; align-items:center; justify-content:space-between; padding-top:12px; border-top:1px solid var(--line)}
.jc-posted{font-size:.78rem; color:var(--ink-3)}
.job-card .stamp{position:absolute; top:24px}
.job-card .stamp-like{right:22px; color:var(--like); border-color:var(--like); transform:rotate(13deg)}
.job-card .stamp-pass{left:22px; color:var(--pass); border-color:var(--pass); transform:rotate(-13deg)}

.swipe-controls{display:flex; align-items:center; justify-content:center; gap:18px; padding:18px 0 6px}
.sc-btn{display:grid; place-items:center; border-radius:50%; border:1.5px solid var(--line-2); background:var(--surface); cursor:pointer; transition:transform .15s ease, box-shadow .2s ease, border-color .2s ease, background .2s ease, color .2s ease; box-shadow:var(--shadow-sm)}
.sc-btn:hover{transform:translateY(-3px) scale(1.06); box-shadow:var(--shadow)}
.sc-btn:active{transform:scale(.94)}
.sc-pass{width:62px; height:62px; color:var(--pass)}
.sc-pass:hover{border-color:var(--pass); background:var(--pass-soft)}
.sc-like{width:62px; height:62px; color:var(--like)}
.sc-like:hover{border-color:var(--like); background:var(--like-soft)}
.sc-rewind{width:46px; height:46px; color:var(--ink-3)}
.sc-rewind:hover{border-color:var(--brand); color:var(--brand)}
.swipe-hint{text-align:center; font-size:.82rem; color:var(--ink-3); margin-top:8px}
.swipe-hint kbd{margin:0 1px}

/* score card stage */
.stage-score, .stage-result, .stage-end{gap:0; animation:fadeUp .4s ease both}
.score-top{display:flex; align-items:center; gap:12px; background:var(--surface); border:1px solid var(--line); border-radius:var(--r) var(--r) 0 0; padding:16px}
.recruiter-banner{font-size:.82rem; color:var(--amber); font-weight:600; background:color-mix(in srgb,var(--amber) 11%,transparent); border:1px solid color-mix(in srgb,var(--amber) 24%,transparent); border-radius:var(--r-sm); padding:9px 12px; margin-bottom:12px; line-height:1.4}
.avatar{flex:none; width:54px; height:54px; border-radius:50%; display:grid; place-items:center; font-family:var(--font-display); font-weight:700; font-size:1.25rem; color:#fff; background:linear-gradient(135deg,var(--brand),var(--brand-strong)); box-shadow:0 0 0 3px var(--surface), 0 0 0 4.5px var(--brand-soft-2)}
.score-id{min-width:0; line-height:1.3}
.score-id b{font-size:1.12rem; color:var(--ink)}
.score-id span{display:block; font-size:.85rem; color:var(--ink-3)}
.fit{margin-left:auto; flex:none; text-align:center}
.fit b{font-family:var(--font-display); font-weight:800; font-size:1.7rem; color:var(--like); line-height:1; display:block}
.fit span{font-size:.66rem; text-transform:uppercase; letter-spacing:.08em; color:var(--ink-3)}
.score-body{background:var(--surface); border:1px solid var(--line); border-top:none; border-radius:0 0 var(--r) var(--r); padding:16px; box-shadow:var(--shadow-sm)}
.score-stats{display:grid; grid-template-columns:repeat(4,1fr); gap:8px; margin-bottom:14px}
.score-stats div{text-align:center; background:var(--bg); border:1px solid var(--line); border-radius:var(--r-xs); padding:9px 4px}
.score-stats b{display:block; font-family:var(--font-display); font-weight:700; font-size:1.04rem; color:var(--ink)}
.score-stats span{font-size:.7rem; color:var(--ink-3)}
.score-section-label{font-size:.74rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-3); margin:4px 0 9px}
.chips.match span.hit{background:var(--like-soft); border-color:color-mix(in srgb,var(--like) 30%,transparent); color:var(--like-ink)}
.signals{display:flex; flex-direction:column; gap:8px; margin-top:14px}
.signal{display:flex; align-items:center; gap:9px; font-size:.86rem; color:var(--ink-2)}
.signal svg{flex:none; color:var(--brand)}
.actions-label{text-align:center; font-size:.82rem; color:var(--ink-3); margin:16px 0 10px}
.actions{display:grid; grid-template-columns:1fr 1fr; gap:10px}
.act{display:flex; align-items:center; gap:10px; text-align:left; padding:13px 14px; border-radius:var(--r-sm); border:1.5px solid var(--line-2); background:var(--surface); color:var(--ink); font-family:var(--font-body); font-weight:600; font-size:.92rem; cursor:pointer; transition:transform .14s ease, border-color .2s ease, background .2s ease, box-shadow .2s ease}
.act:hover{transform:translateY(-2px); box-shadow:var(--shadow); border-color:var(--brand)}
.act:active{transform:translateY(0) scale(.99)}
.act svg{flex:none}
.act-primary{background:var(--brand); color:#fff; border-color:var(--brand)}
html[data-theme="dark"] .act-primary{color:#06203c}
.act-primary:hover{background:var(--brand-strong)}
.act-mut{color:var(--ink-3)}
.act-mut:hover{border-color:var(--pass); color:var(--pass); background:var(--pass-soft)}

/* result stage */
.result-card{margin:auto 0; text-align:center; background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); padding:30px 24px; box-shadow:var(--shadow)}
.result-ic{width:74px; height:74px; border-radius:50%; display:grid; place-items:center; margin:0 auto 18px; background:var(--like-soft); color:var(--like)}
.result-ic.decline{background:var(--pass-soft); color:var(--pass)}
.result-card h3{font-size:1.5rem; margin-bottom:10px}
.result-card p{color:var(--ink-2); margin-bottom:6px}
.result-note{font-size:.9rem; color:var(--ink-3); background:var(--bg); border:1px solid var(--line); border-radius:var(--r-sm); padding:12px 14px; margin:18px 0 22px; line-height:1.5}
.result-note b{color:var(--brand)}

/* end stage */
.stage-end{justify-content:center; text-align:center; padding:20px}
.end-emoji{font-size:3rem; margin-bottom:8px}
.stage-end h3{font-size:1.7rem; margin-bottom:12px}
.stage-end p{color:var(--ink-2); margin-bottom:24px; max-width:34ch; margin-inline:auto}
.end-cta{display:flex; flex-direction:column; gap:10px}

/* demo aside */
.demo-aside h3{font-size:1.32rem; margin-bottom:12px}
.demo-aside>p{color:var(--ink-2); margin-bottom:20px}
.aside-list{list-style:none; margin:0 0 24px; padding:0; display:flex; flex-direction:column; gap:14px}
.aside-list li{padding-left:18px; position:relative; color:var(--ink-2); font-size:.97rem; line-height:1.5}
.aside-list li::before{content:""; position:absolute; left:0; top:9px; width:7px; height:7px; border-radius:2px; background:var(--brand)}
.aside-list b{color:var(--ink)}

/* ---------- Split sections ---------- */
.split-copy h2{margin-bottom:16px}
.split-copy>p{color:var(--ink-2); font-size:1.08rem; margin-bottom:20px}
.split-copy .ticks{margin-bottom:26px}
.split-visual{display:flex; justify-content:center}
.mini-scorecard{width:min(360px,100%); background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); padding:20px; box-shadow:var(--shadow)}
.ms-head{display:flex; align-items:center; gap:12px; margin-bottom:16px}
.ms-head>div{line-height:1.3; min-width:0}
.ms-head b{font-size:1.04rem}
.ms-head span{font-size:.82rem; color:var(--ink-3)}
.ms-fit{margin-left:auto; font-family:var(--font-display); font-weight:800; font-size:1.6rem; color:var(--like)}
.ms-stats{display:flex; gap:8px; margin-bottom:14px}
.ms-stats span{flex:1; text-align:center; background:var(--bg); border:1px solid var(--line); border-radius:var(--r-xs); padding:8px 4px; font-size:.74rem; color:var(--ink-3)}
.ms-stats b{display:block; font-family:var(--font-display); color:var(--ink); font-size:1rem}
.ms-actions{display:grid; grid-template-columns:repeat(4,1fr); gap:6px; margin-top:14px}
.ms-actions i{font-style:normal; text-align:center; font-size:.74rem; font-weight:600; padding:8px 2px; border-radius:var(--r-xs); background:var(--brand-soft); color:var(--brand-ink)}
html[data-theme="dark"] .ms-actions i{color:var(--brand-strong)}
.ms-actions i.mut{background:var(--bg); color:var(--ink-3)}

.cohort-card{width:min(360px,100%); background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); padding:24px; box-shadow:var(--shadow)}
.cc-row{display:flex; justify-content:space-between; align-items:baseline; margin-bottom:8px}
.cc-row span{font-size:.9rem; color:var(--ink-2)}
.cc-row b{font-family:var(--font-display); font-weight:800; font-size:1.3rem; color:var(--ink)}
.cc-bar{height:8px; border-radius:99px; background:var(--bg-2); border:1px solid var(--line); overflow:hidden; margin-bottom:20px}
.cc-bar i{display:block; height:100%; background:linear-gradient(90deg,var(--brand),var(--brand-strong)); border-radius:99px}
.cohort-card .cc-row:last-of-type{margin-bottom:8px}
.cohort-card .cc-bar:last-child{margin-bottom:0}

/* ---------- Waitlist ---------- */
.waitlist-section{padding-bottom:clamp(64px,9vw,120px)}
.waitlist-card{display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,4vw,54px); align-items:center; background:var(--surface); border:1px solid var(--line); border-radius:var(--r-xl); padding:clamp(28px,4vw,52px); box-shadow:var(--shadow); position:relative; overflow:hidden}
.waitlist-card::before{content:""; position:absolute; inset:0; background:radial-gradient(50% 80% at 100% 0%, color-mix(in srgb,var(--brand) 10%,transparent), transparent 70%); pointer-events:none}
.wl-copy{position:relative}
.wl-copy>p{color:var(--ink-2); margin:14px 0; font-size:1.06rem}
.wl-count{display:inline-flex; align-items:center; gap:8px; font-size:.9rem; color:var(--ink-3); font-weight:500}
.wl-count #joinCount{font-family:var(--font-display); font-weight:800; color:var(--brand); font-size:1.05rem}
.wl-form{position:relative; display:flex; flex-direction:column; gap:14px}
.role-toggle{display:flex; gap:4px; background:var(--bg); border:1px solid var(--line); border-radius:var(--pill); padding:4px}
.role-opt{flex:1; padding:10px 8px; border:none; background:transparent; border-radius:var(--pill); font-family:var(--font-body); font-weight:600; font-size:.9rem; color:var(--ink-2); cursor:pointer; transition:background .2s ease, color .2s ease, box-shadow .2s ease}
.role-opt.is-active{background:var(--surface); color:var(--brand); box-shadow:var(--shadow-sm)}
.field{display:flex; flex-direction:column; gap:6px}
.field label{font-size:.85rem; font-weight:600; color:var(--ink-2)}
.field input{font-family:var(--font-body); font-size:1rem; color:var(--ink); background:var(--surface-2); border:1.5px solid var(--line-2); border-radius:var(--r-sm); padding:12px 14px; transition:border-color .2s ease, box-shadow .2s ease}
.field input::placeholder{color:var(--ink-3)}
.field input:focus{outline:none; border-color:var(--brand); box-shadow:0 0 0 3px color-mix(in srgb,var(--brand) 18%,transparent)}
.field input.invalid{border-color:var(--pass); box-shadow:0 0 0 3px var(--pass-soft)}
.wl-fine{font-size:.8rem; color:var(--ink-3); text-align:center}
.wl-success{position:absolute; inset:0; background:var(--surface); display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; gap:8px; border-radius:var(--r); animation:fadeUp .4s ease both}
.wl-success[hidden]{display:none}
.ok-ic{width:64px; height:64px; border-radius:50%; display:grid; place-items:center; background:var(--like-soft); color:var(--like); margin-bottom:6px}
.wl-success h3{font-size:1.5rem}
.wl-success p{color:var(--ink-2); max-width:32ch; margin-bottom:10px}

/* ---------- Footer ---------- */
.footer{background:var(--surface); border-top:1px solid var(--line); padding:clamp(40px,5vw,60px) 0 28px}
.footer-inner{display:flex; justify-content:space-between; gap:30px; flex-wrap:wrap; padding-bottom:28px; border-bottom:1px solid var(--line)}
.footer-brand p{color:var(--ink-3); margin-top:12px; font-size:.95rem; max-width:30ch}
.footer-links{display:flex; gap:22px; flex-wrap:wrap; align-content:flex-start}
.footer-links a{font-size:.93rem; color:var(--ink-2); transition:color .18s ease}
.footer-links a:hover{color:var(--brand)}
.footer-base{display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap; padding-top:22px; font-size:.85rem; color:var(--ink-3)}
.footer-tag{color:var(--brand)}
.foot-credit{text-align:center; font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3); padding-top:22px; margin-top:24px; border-top:1px solid var(--line)}
.foot-credit a{color:var(--ink-2); font-weight:600}
.foot-credit a:hover{color:var(--brand)}

/* ---------- Generated device shots ---------- */
.shot{display:block; height:auto; max-width:100%; border-radius:var(--r-xl); border:1px solid var(--line); box-shadow:var(--shadow-lg)}
.hero-shot{width:min(420px,86%); animation:float 6.5s ease-in-out infinite}
.aside-shot{width:min(248px,66%); margin:0 auto 22px; border-radius:var(--r-lg)}
.shot-wide{width:min(560px,100%)}
.shot-portrait{width:min(360px,90%)}
@keyframes float{0%,100%{transform:translateY(0)} 50%{transform:translateY(-12px)}}
@media (prefers-reduced-motion:reduce){.hero-shot{animation:none}}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0; transform:translateY(22px); transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1; transform:none}
@keyframes fadeUp{from{opacity:0; transform:translateY(14px)} to{opacity:1; transform:none}}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1 !important; transform:none !important; transition:none}
  .job-card,.phone,.btn,.sc-btn,.act{transition:none !important}
  *{animation:none !important}
}

/* ---------- Responsive ---------- */
@media (max-width:960px){
  .hero-grid{grid-template-columns:1fr; gap:8px}
  .hero-art{order:-1; margin-bottom:18px}
  .lede{max-width:none}
  .demo-wrap{grid-template-columns:1fr; gap:30px}
  .demo-aside{max-width:460px; margin-inline:auto; text-align:center}
  .aside-list li{text-align:left}
  .demo-aside .btn{width:100%}
  .two-col{grid-template-columns:1fr}
  .two-col.reverse .split-copy{order:-1}
  .waitlist-card{grid-template-columns:1fr; gap:26px}
  .steps{grid-template-columns:1fr 1fr}
  .stat-row{grid-template-columns:repeat(2,minmax(0,1fr)); gap:6px 18px}
  .stat:nth-child(2){border-right:none}
  .stat:nth-child(-n+2){border-bottom:1px solid var(--line)}
}
@media (max-width:680px){
  body{font-size:16px}
  .nav-links{display:none}
  .stat b{font-size:clamp(1.7rem,7vw,2.2rem)}
  .stat{padding:14px 10px}
  .actions{grid-template-columns:1fr}
  .footer-inner{flex-direction:column; gap:24px}
}
@media (max-width:420px){
  .steps{grid-template-columns:1fr}
  .nav-cta{display:none}
}
