/* Self-hosted fonts (CSP-safe — replaces Google Fonts CDN). Newsreader is the
   primary serif (Source Serif 4 was only a fallback); Geist + Geist Mono for UI. */
@font-face{font-family:'Newsreader';font-style:normal;font-weight:400;font-display:swap;src:url('/fonts/nr-400.woff2') format('woff2')}
@font-face{font-family:'Newsreader';font-style:italic;font-weight:400;font-display:swap;src:url('/fonts/nr-400i.woff2') format('woff2')}
@font-face{font-family:'Newsreader';font-style:normal;font-weight:500;font-display:swap;src:url('/fonts/nr-500.woff2') format('woff2')}
@font-face{font-family:'Newsreader';font-style:normal;font-weight:600;font-display:swap;src:url('/fonts/nr-600.woff2') format('woff2')}
@font-face{font-family:'Geist';font-style:normal;font-weight:400;font-display:swap;src:url('/fonts/gs-400.woff2') format('woff2')}
@font-face{font-family:'Geist';font-style:normal;font-weight:500;font-display:swap;src:url('/fonts/gs-500.woff2') format('woff2')}
@font-face{font-family:'Geist';font-style:normal;font-weight:600;font-display:swap;src:url('/fonts/gs-600.woff2') format('woff2')}
@font-face{font-family:'Geist Mono';font-style:normal;font-weight:400;font-display:swap;src:url('/fonts/gm-400.woff2') format('woff2')}
@font-face{font-family:'Geist Mono';font-style:normal;font-weight:500;font-display:swap;src:url('/fonts/gm-500.woff2') format('woff2')}
:root{
  --cream:#FCF6F2;
  --white:#FFFFFF;
  --ink:#212121;
  --muted:#4A4A4A;
  --hairline:#EAE2DB;
  --aubergine:#482353;
  --green:#2C6E48;
  --paper:#FFFDFC;
  --max:1480px;
  --gutter:clamp(22px,4.8vw,84px);
  --colgap:24px;
}
*{box-sizing:border-box}
html{background:var(--cream);color:var(--ink);scroll-behavior:smooth}
body{margin:0;background:var(--cream);color:var(--ink);font-family:Geist,Arial,sans-serif;font-weight:400;-webkit-font-smoothing:antialiased;text-rendering:geometricPrecision}
a{color:inherit;text-decoration:none}
::selection{background:var(--hairline);color:var(--ink)}
.page{min-height:100vh;overflow:hidden}
.top-rule{position:fixed;z-index:30;top:0;left:0;right:0;height:1px;background:var(--aubergine)}
.nav{position:fixed;z-index:25;top:1px;left:0;right:0;padding:18px var(--gutter);display:grid;grid-template-columns:repeat(12,1fr);gap:var(--colgap);pointer-events:none;mix-blend-mode:multiply}
.brand{grid-column:1/5;font-family:"Geist Mono",monospace;font-size:11px;letter-spacing:.13em;text-transform:uppercase;color:var(--muted)}
.nav-links{grid-column:9/13;justify-self:end;display:flex;gap:10px;pointer-events:auto}
.btn{height:44px;padding:0 19px;border:1px solid var(--ink);display:inline-flex;align-items:center;justify-content:center;font-size:13px;letter-spacing:.01em;background:transparent;color:var(--ink);border-radius:2px;line-height:1}
.btn.dark{background:var(--ink);color:var(--cream)}
.hero{position:relative;max-width:var(--max);margin:0 auto;padding:158px var(--gutter) 118px;display:grid;grid-template-columns:repeat(12,1fr);gap:var(--colgap)}
.hero:after{content:"";grid-column:2/12;grid-row:4;display:block;height:1px;background:var(--hairline);margin-top:84px}
.eyebrow{grid-column:2/5;font-family:"Geist Mono",monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--aubergine);border-top:1px solid var(--aubergine);padding-top:14px}
.hero h1{grid-column:2/12;margin:31px 0 0;font-family:Newsreader,"Source Serif 4",serif;font-size:clamp(72px,11.7vw,180px);font-weight:500;letter-spacing:-.073em;line-height:.79}
.catch{grid-column:7/12;margin:18px 0 0;font-family:Newsreader,"Source Serif 4",serif;font-size:clamp(31px,4.25vw,66px);font-weight:500;letter-spacing:-.052em;line-height:.9}
.hero-actions{grid-column:7/12;display:flex;gap:10px;margin-top:30px}
.thesis{grid-column:2/6;margin:86px 0 0;border-left:1px solid var(--hairline);padding-left:18px;color:var(--muted);font-size:14px;line-height:1.55;max-width:360px}
.dossier-code{grid-column:10/12;margin-top:92px;align-self:end;font-family:"Geist Mono",monospace;font-size:10px;line-height:1.7;letter-spacing:.09em;text-transform:uppercase;color:var(--muted)}
.journey{max-width:var(--max);margin:0 auto;position:relative;padding:0 var(--gutter) 172px}
.spine{position:absolute;top:0;bottom:0;left:calc(var(--gutter) + 11px);width:1px;background:var(--hairline)}
.stage{position:relative;display:grid;grid-template-columns:repeat(12,1fr);gap:var(--colgap);padding:80px 0 82px}
.stage.compact{padding-top:54px}
.stage:before{content:"";position:absolute;left:7px;top:88px;width:8px;height:8px;background:var(--cream);border:1px solid var(--aubergine);border-radius:1px}
.stage.compact:before{top:62px}
.flow-svg{position:absolute;left:0;top:0;pointer-events:none;z-index:1;overflow:visible}
.stage-kicker{grid-column:2/4;font-family:"Geist Mono",monospace;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);padding-top:3px}
.stage h2{grid-column:4/7;margin:0;font-family:Newsreader,"Source Serif 4",serif;font-size:clamp(37px,4.25vw,68px);font-weight:500;letter-spacing:-.05em;line-height:.88}
.stage-note{grid-column:9/12;margin:2px 0 0;color:var(--muted);font-size:13px;line-height:1.48;max-width:280px}
.stage-rule{grid-column:4/12;height:1px;background:var(--hairline);margin-top:26px}
.link-wrap{grid-column:4/13;position:relative;margin-top:40px}
.cards{display:grid;grid-template-columns:repeat(12,1fr);gap:12px;position:relative;z-index:2}
.card{background:var(--paper);border:1px solid var(--hairline);border-radius:3px;min-height:292px;padding:12px;display:flex;flex-direction:column;justify-content:space-between;transition:transform .8s cubic-bezier(.2,.8,.2,1),border-color .8s cubic-bezier(.2,.8,.2,1)}
.card:hover{transform:translateY(-5px);border-color:#d8cdc5}
.portrait{height:158px;border:1px solid var(--hairline);background:var(--cream);overflow:hidden;display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.portrait svg{width:100%;height:100%;display:block;transition:transform .9s cubic-bezier(.2,.8,.2,1)}
.card:hover .portrait svg{transform:translateY(-4px)}
.meta{min-height:80px}
.name{font-family:Newsreader,"Source Serif 4",serif;font-size:27px;line-height:.95;font-weight:500;letter-spacing:-.035em}
.role{margin-top:8px;font-family:"Geist Mono",monospace;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.skill{margin-top:15px;font-size:13px;line-height:1.35;color:var(--ink)}
.learn{display:inline-flex;align-items:center;gap:9px;margin-top:16px;border-top:1px solid var(--hairline);padding-top:12px;padding-bottom:10px;font-family:"Geist Mono",monospace;font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.learn:after{content:"";display:inline-block;width:22px;height:1px;background:var(--aubergine)}
.team-svg{position:absolute;inset:0;z-index:1;pointer-events:none;overflow:visible}
.team-svg path,.team-svg line,.team-svg polyline,.team-svg circle{fill:none;stroke:var(--hairline);stroke-width:1;shape-rendering:geometricPrecision}
.team-svg .node{fill:var(--cream);stroke:var(--aubergine)}
.team-svg .vote-line,.vote-rail{stroke:var(--green)}
.team-svg .green-node{fill:var(--cream);stroke:var(--green)}
.solo .card{grid-column:1/4}
.parallel .card{grid-column:span 2}
.skeptics .card{grid-column:span 2}
.open-cards .card{grid-column:span 4}
.harden .card{grid-column:1/4}
.review-agents .card{grid-column:span 3;min-height:292px}
.vote{grid-column:4/9;margin-top:18px;border-top:1px solid var(--green);padding-top:15px;color:var(--green);font-family:"Geist Mono",monospace;font-size:12px;letter-spacing:.05em}
.gate-cards .card{grid-column:span 4}
.audit-strip{grid-column:4/12;margin-top:52px;display:grid;grid-template-columns:repeat(4,1fr);border-left:1px solid var(--hairline);border-top:1px solid var(--hairline);background:var(--white)}
.review-wrap{grid-column:4/13;margin-top:52px}
.audit{min-height:146px;border-right:1px solid var(--hairline);border-bottom:1px solid var(--hairline);padding:18px;display:flex;flex-direction:column;justify-content:space-between}
.audit-name{font-family:Newsreader,"Source Serif 4",serif;font-size:31px;line-height:.98;font-weight:500;letter-spacing:-.04em}
.audit-role{font-family:"Geist Mono",monospace;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.audit .learn{margin-top:12px}
/* end-of-workflow: the finished memo + view demo */
.finish-cards .card.finish{grid-column:1/8;min-height:0;padding:0;background:transparent;border:0}
.finish-cards .card.finish:hover{transform:none;border-color:transparent}
.mm{background:var(--white);border:1px solid var(--hairline);border-radius:4px;padding:28px 32px}
.mm-eyebrow{font-family:"Geist Mono",monospace;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--aubergine)}
.mm-title{font-family:Newsreader,"Source Serif 4",serif;font-weight:600;font-size:26px;line-height:1.1;letter-spacing:-.02em;margin-top:10px}
.mm-body p{font-family:Newsreader,"Source Serif 4",serif;font-size:15px;line-height:1.55;color:#2a2a2a;margin-top:14px}
.mm-src{font-family:"Geist Mono",monospace;font-size:10px;letter-spacing:.05em;color:#8a8175;margin-top:13px;line-height:1.6}
.mm-rule{height:1px;background:var(--hairline);margin:16px 0}
.mm-meta{display:flex;flex-wrap:wrap;gap:10px 20px;align-items:center;font-family:"Geist Mono",monospace;font-size:11px;letter-spacing:.04em}
.mm-risk{color:#9a5b2b}
.mm-ok{color:var(--green)}
.view-demo{margin-top:22px}
.view-demo .arr{transition:transform .2s;display:inline-block;margin-left:.4em}
.view-demo:hover .arr{transform:translateX(3px)}

.subscriptions{max-width:var(--max);margin:0 auto;padding:0 var(--gutter) 118px;display:grid;grid-template-columns:repeat(12,1fr);gap:var(--colgap)}
.subs-kicker{grid-column:2/4;font-family:"Geist Mono",monospace;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--aubergine);border-top:1px solid var(--aubergine);padding-top:14px}
.subscriptions h2{grid-column:4/9;margin:0;font-family:Newsreader,"Source Serif 4",serif;font-size:clamp(42px,5.4vw,86px);font-weight:500;letter-spacing:-.055em;line-height:.88}
.subs-note{grid-column:9/12;margin:4px 0 0;color:var(--muted);font-size:13px;line-height:1.48;max-width:290px}
.offer-ledger{grid-column:4/12;margin-top:54px;border-top:1px solid var(--hairline)}
.subs-activate{grid-column:4/12;margin:22px 0 0;font-family:"Geist Mono",monospace;font-size:11px;letter-spacing:.04em;color:var(--muted)}
.subs-activate a{color:var(--aubergine);border-bottom:1px solid var(--hairline);padding-bottom:1px}
.offer{display:grid;grid-template-columns:repeat(8,1fr);gap:var(--colgap);border-bottom:1px solid var(--hairline);padding:25px 0 27px}
.offer-name{grid-column:1/3;font-family:Newsreader,"Source Serif 4",serif;font-size:32px;line-height:.98;font-weight:500;letter-spacing:-.04em}
.offer-line{grid-column:3/6;color:var(--ink);font-size:14px;line-height:1.45}
.offer-code{grid-column:6/8;font-family:"Geist Mono",monospace;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);align-self:center}
.offer-action{grid-column:8/9;justify-self:end;align-self:center;font-family:"Geist Mono",monospace;font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);border-top:1px solid var(--hairline);padding-top:10px}
.offer-action:after{content:"";display:block;width:24px;height:1px;background:var(--aubergine);margin-top:9px}

.close{max-width:var(--max);margin:0 auto;padding:0 var(--gutter) 132px;display:grid;grid-template-columns:repeat(12,1fr);gap:var(--colgap)}
.close p{grid-column:4/11;margin:0;border-top:1px solid var(--aubergine);padding-top:28px;font-family:Newsreader,"Source Serif 4",serif;font-size:clamp(28px,3.1vw,46px);line-height:1.02;letter-spacing:-.04em}
/* Reveal-on-scroll is progressive enhancement: content is visible by default and
   only hidden once JS adds .js-anim to <html>. No JS / blocked CSP / failed anim
   => everything stays visible. */
.settle{opacity:1;transform:none;transition:transform 1s cubic-bezier(.2,.8,.2,1),opacity 1s cubic-bezier(.2,.8,.2,1)}
.js-anim .settle{opacity:0;transform:translateY(18px)}
.js-anim .settle.in{opacity:1;transform:none}
.js-anim .hero .settle{opacity:0;transform:translateY(18px);animation:heroSettle 1.05s cubic-bezier(.2,.8,.2,1) forwards}
.hero .settle:nth-child(1){animation-delay:.01s}.hero .settle:nth-child(2){animation-delay:.04s}.hero .settle:nth-child(3){animation-delay:.1s}.hero .settle:nth-child(4){animation-delay:.16s}.hero .settle:nth-child(5){animation-delay:.22s}.hero .settle:nth-child(6){animation-delay:.28s}
@keyframes heroSettle{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}.js-anim .settle,.js-anim .hero .settle{opacity:1;transform:none;animation:none}.settle.in{transition:none}.card,.portrait svg{transition:none}}
@media(max-width:1220px){.parallel .card{grid-column:span 4}.skeptics .card{grid-column:span 3}}
@media(max-width:980px){
  .nav{display:none}
  .hero,.stage,.close{grid-template-columns:repeat(6,1fr)}
  .hero{padding-top:74px}
  .eyebrow{grid-column:1/4}
  .hero h1,.catch,.hero-actions,.thesis,.dossier-code,.close p{grid-column:1/7}
  .hero:after{grid-column:1/7}
  .stage-kicker{grid-column:1/3}
  .stage h2{grid-column:2/7}
  .stage-note,.stage-rule,.link-wrap,.gate-wrap,.audit-strip,.subs-kicker,.subscriptions h2,.subs-note,.offer-ledger,.subs-activate{grid-column:2/7}
  .cards{grid-template-columns:repeat(6,1fr)}
  .solo .card,.parallel .card,.skeptics .card,.gate-cards .card,.harden .card,.review-agents .card{grid-column:span 6}
  .team-svg{display:none}
  .prow{grid-template-columns:1fr;gap:8px}
  .prow .vbar{display:none}
  .audit-strip{grid-template-columns:1fr}.subscriptions{grid-template-columns:repeat(6,1fr)}.offer{grid-template-columns:1fr;gap:8px}.offer-name,.offer-line,.offer-code,.offer-action{grid-column:auto;justify-self:start}
  .spine{left:var(--gutter)}
}
