/* ============================================================
   tektari.css — single shared stylesheet for tektari.com
   Brand: brand/tektari-brand-guidelines.md (graphite ground,
   safety-orange accent ~10%, blueprint-blue, concrete-white;
   Space Grotesk / Inter / IBM Plex Mono; drafting motif).
   Positioning per docs/superpowers/specs/2026-07-02-verification-layer-adoption.md
   ============================================================ */

/* ---- self-hosted fonts (latin) ---- */
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:500 700;font-display:swap;src:url(/fonts/space-grotesk-var.woff2) format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:400 500;font-display:swap;src:url(/fonts/inter-var.woff2) format('woff2')}
@font-face{font-family:'IBM Plex Mono';font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/ibm-plex-mono-400.woff2) format('woff2')}
@font-face{font-family:'IBM Plex Mono';font-style:normal;font-weight:500;font-display:swap;src:url(/fonts/ibm-plex-mono-500.woff2) format('woff2')}

/* ---- tokens ---- */
:root{
  /* colour — text colours pass WCAG AA on ink, panel, and panel-2 */
  --ink:#15191E; --panel:#1E2329; --panel-2:#232931; --paper:#F1EEE7;
  --prose:#D7D3C9;          /* body text        11.8:1 on ink */
  --prose-dim:#C9C5BB;      /* ledes, quiet body 10.2:1       */
  --concrete:#9499A1;       /* mono labels        6.2:1       */
  --concrete-dim:#8E939C;   /* smallest legible   5.7:1 (4.75 on panel-2) */
  --dim-deco:#6B7079;       /* decoration only — never text   */
  --line:rgba(241,238,231,.10); --line-strong:rgba(241,238,231,.18);
  --orange:#FF5A1F; --orange-ink:#1A0E07; --orange-soft:#FFD9C8;
  --blue:#16384F; --blue-line:rgba(123,178,219,.28);

  /* type scale — 8 tokens + 3 fluid display sizes */
  --fs-xs:12px;             /* mono micro: hints, tags, legal   */
  --fs-sm:13.5px;           /* mono labels, by-lines            */
  --fs-nav:14px;            /* nav, footer links                */
  --fs-base:15.5px;         /* buttons, list items, small prose */
  --fs-md:17px;             /* body                             */
  --fs-lg:19px;             /* h3, offer names                  */
  --fs-xl:23px;             /* wordmark                         */
  --fs-num:30px;            /* stat numerals                    */
  --fs-h1:clamp(40px,6.4vw,76px);
  --fs-h1-sub:clamp(34px,5.6vw,60px);
  --fs-h2:clamp(28px,4vw,44px);
  --fs-lede:clamp(17px,2vw,21px);

  /* spacing — 4/8 scale */
  --s1:4px; --s2:8px; --s3:12px; --s4:16px; --s5:24px; --s6:32px; --s7:48px; --s8:64px;

  --display:'Space Grotesk',-apple-system,'Segoe UI',Roboto,sans-serif;
  --body:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --mono:'IBM Plex Mono',ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  --maxw:1180px; --r-sm:7px; --r-md:12px;
}

/* ---- base ---- */
*{box-sizing:border-box;margin:0;padding:0}
@media(prefers-reduced-motion:no-preference){html{scroll-behavior:smooth}}
body{
  background:var(--ink);color:var(--paper);font-family:var(--body);
  font-size:var(--fs-md);line-height:1.65;-webkit-font-smoothing:antialiased;
  background-image:
    linear-gradient(var(--line) 1px,transparent 1px),
    linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:44px 44px;background-position:-1px -1px;
}
::selection{background:var(--orange);color:var(--ink)}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--s5)}
h1,h2,h3{font-family:var(--display);font-weight:700;letter-spacing:-.02em;line-height:1.06;text-wrap:balance}
h1{font-size:var(--fs-h1)}
h2{font-size:var(--fs-h2)}
h3{font-size:var(--fs-lg);letter-spacing:-.01em;line-height:1.2}
p{color:var(--prose);text-wrap:pretty}
.lede{font-size:var(--fs-lede);color:var(--prose-dim);max-width:60ch}
.mono{font-family:var(--mono);font-size:var(--fs-xs);letter-spacing:.06em;color:var(--concrete);text-transform:lowercase}
.mono a{color:var(--paper);border-bottom:1px solid var(--orange);padding-bottom:2px}
.eyebrow{font-family:var(--mono);font-size:var(--fs-xs);letter-spacing:.14em;color:var(--orange);text-transform:uppercase}
.callout{font-size:var(--fs-base);color:var(--prose-dim);max-width:70ch;border-left:2px solid var(--orange);padding-left:var(--s4)}

/* ---- focus (designed, not disabled) ---- */
:focus-visible{outline:2px solid var(--orange);outline-offset:2px;border-radius:2px}
.btn:focus-visible{outline-offset:3px}
.skip{position:absolute;left:-9999px;top:0;z-index:100;background:var(--orange);color:var(--orange-ink);
  font-family:var(--mono);font-size:var(--fs-sm);padding:var(--s3) var(--s4);border-radius:0 0 var(--r-sm) 0}
.skip:focus{left:0}

/* ---- header / nav ---- */
header{position:sticky;top:0;z-index:50;background:rgba(21,25,30,.82);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:68px;gap:var(--s4)}
.brand{display:flex;align-items:center;gap:var(--s3)}
.brand .wm{font-family:var(--display);font-weight:700;font-size:var(--fs-xl);letter-spacing:-.04em;color:var(--paper)}
.brand .dot{color:var(--orange)}
.navlinks{display:flex;gap:var(--s6);align-items:center}
.navlinks a{font-size:var(--fs-nav);color:var(--concrete);transition:color .2s}
.navlinks a:hover{color:var(--paper)}
.nav-cta{display:flex;align-items:center;gap:var(--s3)}

/* mobile disclosure nav — visible below 880px only */
.mnav{display:none;position:relative}
.mnav summary{list-style:none;cursor:pointer;font-family:var(--mono);font-size:var(--fs-xs);letter-spacing:.1em;
  text-transform:uppercase;color:var(--paper);border:1px solid var(--line-strong);border-radius:var(--r-sm);padding:9px 14px;user-select:none}
.mnav summary::-webkit-details-marker{display:none}
.mnav[open] summary{border-color:var(--orange);color:var(--orange)}
.mnav-panel{position:fixed;left:0;right:0;top:68px;background:var(--panel);border-bottom:1px solid var(--line-strong);
  display:flex;flex-direction:column;z-index:60}
.mnav-panel a{font-family:var(--mono);font-size:var(--fs-sm);letter-spacing:.04em;color:var(--paper);
  padding:var(--s4) var(--s5);border-bottom:1px solid var(--line)}
.mnav-panel a:last-child{border-bottom:0}
.mnav-panel a:hover{background:var(--panel-2);color:var(--orange)}

/* ---- buttons ---- */
.btn{font-family:var(--body);font-weight:500;font-size:var(--fs-base);border-radius:var(--r-sm);padding:11px 18px;
  border:1px solid transparent;cursor:pointer;display:inline-flex;align-items:center;gap:var(--s2);
  transition:transform .15s ease,background .2s,border-color .2s;white-space:nowrap}
.btn-pri{background:var(--orange);color:var(--orange-ink)}
.btn-pri:hover{transform:translateY(-1px);background:#ff6b35}
.btn-ghost{border-color:var(--line-strong);color:var(--paper)}
.btn-ghost:hover{border-color:var(--concrete);background:rgba(241,238,231,.04)}
.nav .btn{padding:9px 16px}
.seclink{display:inline-flex;align-items:center;gap:var(--s2);font-size:var(--fs-base);color:var(--paper);
  border-bottom:1px solid var(--orange);padding-bottom:3px}

/* ---- sheet markers (drawing title blocks) ---- */
.sheet{display:flex;align-items:baseline;gap:var(--s4);border-top:1px solid var(--line-strong);padding-top:var(--s4);margin-bottom:var(--s7)}
.sheet .id{font-family:var(--mono);font-size:var(--fs-xs);color:var(--orange);letter-spacing:.08em}
.sheet .nm{font-family:var(--mono);font-size:var(--fs-xs);font-weight:400;color:var(--concrete);letter-spacing:.1em;text-transform:uppercase}
h2.nm{line-height:1.65}

/* ---- sections ---- */
main section{padding:clamp(54px,8vw,92px) 0}
.band{background:var(--panel);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.band .tight{padding:var(--s7) 0}

/* ---- hero ---- */
.hero{padding:clamp(56px,9vw,108px) 0 60px;position:relative}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:var(--s8);align-items:center}
.hero h1{margin:var(--s4) 0 var(--s5)}
.hero h1 .pt{color:var(--orange)}
.hero .btn-pri{margin-top:var(--s6)}

/* ---- email capture ---- */
.capture{margin-top:var(--s6);max-width:480px}
.capture form{display:flex;gap:var(--s2);background:var(--panel);border:1px solid var(--line-strong);border-radius:10px;padding:7px;transition:border-color .2s}
.capture form:focus-within{border-color:var(--orange)}
.capture input{flex:1;min-width:0;background:transparent;border:0;color:var(--paper);font-family:var(--body);font-size:var(--fs-base);padding:10px 12px;outline:none}
.capture input::placeholder{color:var(--concrete-dim)}
.capture input[aria-invalid="true"]{box-shadow:inset 0 -2px 0 var(--orange)}
.capture .hint{font-family:var(--mono);font-size:var(--fs-xs);color:var(--concrete-dim);margin-top:var(--s3);letter-spacing:.03em}
.capture .ok{display:none;margin-top:var(--s3);font-family:var(--mono);font-size:var(--fs-sm);color:var(--orange)}
.capture .err{display:none;margin-top:var(--s3);font-family:var(--mono);font-size:var(--fs-xs);color:var(--orange)}
.capture .err.show{display:block}
.magnet{font-family:var(--mono);font-size:var(--fs-xs);color:var(--concrete);margin-top:var(--s2);letter-spacing:.02em}
.magnet b{color:var(--paper);font-weight:500}

/* ---- hero drawing vignette ---- */
.draw{position:relative;border:1px solid var(--line-strong);border-radius:var(--r-md);background:
  linear-gradient(var(--blue-line) 1px,transparent 1px),
  linear-gradient(90deg,var(--blue-line) 1px,transparent 1px),var(--panel);
  background-size:24px 24px,24px 24px,100%;padding:var(--s5);overflow:hidden}
.reg{position:absolute;width:13px;height:13px;border:1px solid var(--dim-deco)}
.reg.tl{top:9px;left:9px;border-right:0;border-bottom:0}
.reg.br{bottom:9px;right:9px;border-left:0;border-top:0}
.draw .tag{font-family:var(--mono);font-size:var(--fs-xs);color:var(--concrete);letter-spacing:.08em}
.draw-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--s4)}
.draw-lines{display:flex;flex-direction:column;gap:var(--s2)}
.draw-lines.faded{opacity:.7}
.draw-lines i{display:block;height:9px;background:var(--line-strong);border-radius:3px}
.w62{width:62%}.w74{width:74%}.w88{width:88%}.w90{width:90%}.w96{width:96%}
.draw-flag{margin:var(--s4) 0;border-left:2px solid var(--orange);background:rgba(255,90,31,.08);border-radius:0 8px 8px 0;padding:var(--s3) var(--s4)}
.draw-flag .k{font-family:var(--mono);font-size:var(--fs-xs);color:var(--orange);letter-spacing:.06em;margin-bottom:var(--s1)}
.draw-flag .v{font-size:var(--fs-nav);color:var(--paper);line-height:1.45}
.draw-foot{display:flex;justify-content:space-between;align-items:center;margin-top:var(--s4);border-top:1px solid var(--line);padding-top:var(--s3)}
.draw-foot .ok{font-family:var(--mono);font-size:var(--fs-xs);color:#7FD6A0}

/* ---- trust band / stats ---- */
.trust{display:flex;align-items:center;justify-content:space-between;gap:var(--s7);flex-wrap:wrap}
.trust .trust-h{font-family:var(--display);font-weight:500;font-size:clamp(18px,2.2vw,24px);color:var(--paper);max-width:30ch;line-height:1.25;letter-spacing:-.01em;text-wrap:balance}
.trust .sub{font-family:var(--body);font-weight:400;font-size:var(--fs-base);color:var(--prose-dim);max-width:56ch;margin-top:var(--s3);line-height:1.6}
.stats{display:flex;gap:var(--s4);flex-wrap:wrap}
.stat{border:1px solid var(--line-strong);border-radius:9px;padding:var(--s4) var(--s5);min-width:150px;max-width:230px}
.stat .n{font-family:var(--display);font-weight:700;font-size:var(--fs-num);color:var(--paper)}
a.stat .n{color:var(--orange)} /* orange marks the one actionable stat, not the row (70/20/10) */
.stat .l{font-family:var(--mono);font-size:var(--fs-xs);color:var(--concrete);letter-spacing:.03em;margin-top:var(--s1);line-height:1.6}
.stat .src{display:block;font-family:var(--mono);font-size:var(--fs-xs);color:var(--concrete-dim);margin-top:var(--s2)}
a.stat{transition:border-color .2s}
a.stat:hover{border-color:var(--orange)}

/* ---- two-col compare ---- */
.cols{display:grid;grid-template-columns:1fr 1fr;gap:var(--s4);margin-top:var(--s4)}
.col{border:1px solid var(--line-strong);border-radius:var(--r-md);padding:var(--s5);position:relative}
.col.us{border-color:rgba(255,90,31,.4)}
.col h3{margin-bottom:var(--s4)}
.col .kx{font-family:var(--mono);font-size:var(--fs-xs);letter-spacing:.1em;text-transform:uppercase;color:var(--concrete);margin-bottom:var(--s4)}
.col.us .kx{color:var(--orange)}
.col ul{list-style:none;display:flex;flex-direction:column;gap:var(--s3)}
.col li{display:flex;gap:var(--s3);font-size:var(--fs-base);color:var(--prose);line-height:1.45}
.col li .m{font-family:var(--mono);color:var(--concrete-dim);flex:0 0 auto}
.col.us li .m{color:var(--orange)}
.col .body-sm{font-size:var(--fs-base);color:var(--prose);margin-top:var(--s2)}
.col .seclink{margin-top:var(--s5)}

/* ---- persona / discipline cards ---- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s4)}
.cards.four{grid-template-columns:repeat(2,1fr)}
.card{border:1px solid var(--line-strong);border-radius:var(--r-md);padding:var(--s5);background:var(--panel);transition:transform .18s ease,border-color .2s}
.card:hover{transform:translateY(-3px);border-color:var(--concrete-dim)}
.card .k{font-family:var(--mono);font-size:var(--fs-xs);color:var(--orange);letter-spacing:.1em;text-transform:uppercase}
.card h3{margin:var(--s3) 0 var(--s2)}
.card p{font-size:var(--fs-base);color:var(--prose)}
.card .who{font-family:var(--mono);font-size:var(--fs-xs);color:var(--concrete);margin-top:var(--s4);line-height:1.7}

/* ---- offer ladder (semantic list) ---- */
.ladder{list-style:none;display:flex;flex-direction:column;border:1px solid var(--line-strong);border-radius:var(--r-md);overflow:hidden}
.rung{display:grid;grid-template-columns:54px 1fr auto;gap:var(--s5);align-items:center;padding:var(--s5);border-bottom:1px solid var(--line)}
.rung:last-child{border-bottom:0}
.rung:hover{background:var(--panel-2)}
.rung .ix{font-family:var(--mono);font-size:var(--fs-sm);color:var(--concrete-dim)}
.rung h3{font-family:var(--display);font-weight:500;font-size:var(--fs-lg);color:var(--paper);letter-spacing:-.01em}
.rung .ds{font-size:var(--fs-nav);color:var(--concrete);margin-top:2px}
.rung .pr{font-family:var(--mono);font-size:var(--fs-nav);color:var(--orange);text-align:right;white-space:nowrap}
.rung.flag{background:linear-gradient(90deg,rgba(255,90,31,.08),transparent)}
.rung.flag h3::after{content:'flagship';font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink);background:var(--orange);padding:2px 7px;border-radius:4px;margin-left:var(--s3);vertical-align:middle}
.ladder-label{margin-bottom:var(--s3)}
.ladder-note{margin:var(--s4) 0 var(--s6)}

/* ---- course cards ---- */
.courses{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s4)}
.course{border:1px solid var(--line-strong);border-radius:var(--r-md);padding:var(--s5);display:flex;flex-direction:column;gap:var(--s2);min-height:200px;transition:transform .18s,border-color .2s}
.course:hover{transform:translateY(-3px);border-color:var(--orange)}
.course .lvl{font-family:var(--mono);font-size:var(--fs-xs);color:var(--concrete);letter-spacing:.06em;text-transform:uppercase}
.course h3{font-size:18px;font-family:var(--display);font-weight:500;line-height:1.15}
.course .pr{font-family:var(--mono);font-size:var(--fs-nav);color:var(--orange);margin-top:auto}

/* ---- founder ---- */
.founder{display:grid;grid-template-columns:.5fr 1fr;gap:var(--s7);align-items:center}
.portrait{aspect-ratio:1/1;border:1px solid var(--line-strong);border-radius:14px;background:
  radial-gradient(circle at 50% 40%,rgba(255,90,31,.10),transparent 60%),var(--panel-2);
  display:flex;align-items:center;justify-content:center}
.founder blockquote{font-family:var(--display);font-weight:500;font-size:clamp(20px,2.6vw,28px);line-height:1.3;letter-spacing:-.01em;color:var(--paper);text-wrap:balance}
.founder .by{font-family:var(--mono);font-size:var(--fs-sm);color:var(--concrete);margin-top:var(--s4);line-height:1.7}

/* ---- final CTA ---- */
.final{text-align:center}
.final h2{max-width:18ch;margin:0 auto var(--s3)}
.final .lede{margin:0 auto}
.final .btn-pri{margin-top:var(--s5)}
.final .capture{margin:var(--s5) auto 0}
.final .hint{text-align:center}

/* ---- charter / commitments ---- */
.charter-hero{padding:clamp(56px,8vw,96px) 0 var(--s5)}
.charter-hero h1{margin:var(--s4) 0 var(--s5);font-size:var(--fs-h1-sub)}
.charter-hero h1 .pt{color:var(--orange)}
.commit{border:1px solid var(--line-strong);border-radius:var(--r-md);overflow:hidden}
.commit .row{display:grid;grid-template-columns:54px 1fr;gap:var(--s5);padding:var(--s5);border-bottom:1px solid var(--line)}
.commit .row:last-child{border-bottom:0}
.commit .row:hover{background:var(--panel-2)}
.commit .ix{font-family:var(--mono);font-size:var(--fs-sm);color:var(--orange)}
.commit h3{margin-bottom:var(--s2);font-weight:500;font-family:var(--display);font-size:var(--fs-lg)}
.commit p{font-size:var(--fs-base);color:var(--prose);line-height:1.55}
.plain p{font-size:16px;color:var(--prose);max-width:70ch;margin-bottom:var(--s4)}
.plain b{color:var(--paper);font-weight:500}
.plain ul{list-style:none;display:flex;flex-direction:column;gap:var(--s3);max-width:70ch}
.plain li{display:flex;gap:var(--s3);font-size:var(--fs-base);color:var(--prose);line-height:1.55}
.plain li .m{font-family:var(--mono);color:var(--concrete-dim);flex:0 0 auto}
.vnote{font-family:var(--mono);font-size:var(--fs-xs);color:var(--concrete-dim);letter-spacing:.04em;line-height:1.8}
.vnote a{border-bottom:1px solid var(--line-strong)}

/* ---- long-form document pages (legal, methodology) ---- */
.doc{padding-top:var(--s6)}
.doc>*{max-width:72ch} /* measure-limit children so the doc shares the hero's left rail */
.doc-hero{padding:clamp(48px,7vw,80px) var(--s5) var(--s4)} /* keep .wrap's side padding — shorthand would zero it */
.doc-hero h1{font-size:var(--fs-h1-sub);margin:var(--s4) 0 var(--s4)}
.doc-hero h1 .pt{color:var(--orange)}
.doc h2{font-size:clamp(22px,3vw,30px);margin:var(--s8) 0 var(--s4);border-top:1px solid var(--line-strong);padding-top:var(--s5)}
.doc h3{font-size:var(--fs-lg);margin:var(--s6) 0 var(--s3);color:var(--paper)}
.doc p{font-size:16px;color:var(--prose);margin-bottom:var(--s4);line-height:1.7}
.doc ul,.doc ol{margin:0 0 var(--s4) 0;padding-left:var(--s5);color:var(--prose)}
.doc li{font-size:16px;margin-bottom:var(--s2);line-height:1.6}
.doc li::marker{color:var(--concrete-dim)}
.doc a{color:var(--paper);border-bottom:1px solid var(--orange);padding-bottom:1px}
.doc b,.doc strong{color:var(--paper);font-weight:500}
.doc table{width:100%;border-collapse:collapse;margin:var(--s4) 0;font-size:var(--fs-base)}
.doc th{font-family:var(--mono);font-size:var(--fs-xs);letter-spacing:.06em;text-transform:uppercase;color:var(--concrete);
  font-weight:400;text-align:left;border-bottom:1px solid var(--line-strong);padding:var(--s2) var(--s3)}
.doc td{border-bottom:1px solid var(--line);padding:var(--s3);color:var(--prose);vertical-align:top}
.doc .tablewrap{overflow-x:auto}
.doc hr{border:0;border-top:1px solid var(--line);margin:var(--s6) 0}
.doc .updated,.doc-hero .updated{font-family:var(--mono);font-size:var(--fs-xs);color:var(--concrete-dim);letter-spacing:.04em;max-width:72ch}
.note{border:1px solid var(--line-strong);border-left:2px solid var(--orange);border-radius:0 var(--r-sm) var(--r-sm) 0;
  background:var(--panel);padding:var(--s4) var(--s5);margin:var(--s4) 0;font-size:var(--fs-base);color:var(--prose-dim)}
.note .k{font-family:var(--mono);font-size:var(--fs-xs);letter-spacing:.1em;text-transform:uppercase;color:var(--orange);display:block;margin-bottom:var(--s1)}

/* ---- bands table (scoreboard) ---- */
.bands{list-style:none;display:flex;flex-direction:column;border:1px solid var(--line-strong);border-radius:var(--r-md);overflow:hidden}
.bands li{display:grid;grid-template-columns:86px 1fr;gap:var(--s5);padding:var(--s5);border-bottom:1px solid var(--line)}
.bands li:last-child{border-bottom:0}
.bands .rge{font-family:var(--mono);font-size:var(--fs-sm);color:var(--orange);white-space:nowrap}
.bands h3{font-family:var(--display);font-weight:500;font-size:var(--fs-lg);color:var(--paper)}
.bands p{font-size:var(--fs-base);color:var(--prose);margin-top:var(--s1);line-height:1.55}

/* ---- footer ---- */
footer{border-top:1px solid var(--line);padding:var(--s8) 0 var(--s7);margin-top:var(--s6)}
.fcols{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:var(--s6)}
.fh{font-family:var(--mono);font-size:var(--fs-xs);letter-spacing:.1em;text-transform:uppercase;color:var(--concrete);margin-bottom:var(--s4)}
footer nav a{display:block;font-size:var(--fs-nav);color:var(--prose);margin-bottom:var(--s2)}
footer nav a:hover{color:var(--paper)}
.verify{font-size:var(--fs-sm);color:var(--concrete);max-width:38ch;line-height:1.6;margin-top:var(--s4)}
.legal{display:flex;justify-content:space-between;gap:var(--s5);flex-wrap:wrap;border-top:1px solid var(--line);margin-top:var(--s7);padding-top:var(--s5);font-family:var(--mono);font-size:var(--fs-xs);color:var(--concrete-dim);letter-spacing:.03em}
.legal a:hover{color:var(--paper)}

/* ---- centred utility pages (thank-you, 404) ---- */
.centerpage{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--s5);text-align:center}
.centerpage .card-c{max-width:560px}
.centerpage h1{font-size:clamp(34px,6vw,54px);margin:var(--s4) 0 var(--s4);line-height:1.05}
.centerpage p{color:var(--prose-dim);font-size:var(--fs-md);line-height:1.7;margin:0 auto var(--s4);max-width:46ch}
.centerpage .btn{margin-top:var(--s4);font-size:16px;padding:13px 22px;border-radius:8px}
.centerpage .back{display:inline-block;margin-top:var(--s5);color:var(--concrete);font-size:var(--fs-nav);border-bottom:1px solid var(--line);padding-bottom:2px}
.centerpage .back:hover{color:var(--paper)}
.centerpage .mark{margin-bottom:var(--s5)}
.centerpage .quiet{font-size:var(--fs-nav);color:var(--concrete)}

/* ---- reveal motion (progressive enhancement) ---- */
.rv{transition:opacity .6s ease,transform .6s ease}
.js .rv{opacity:0;transform:translateY(16px)}
.rv.in{opacity:1;transform:none}

/* ---- responsive ---- */
@media(max-width:880px){
  .navlinks{display:none}
  .mnav{display:block}
  .hero-grid{grid-template-columns:1fr;gap:var(--s6)}
  .cards,.courses{grid-template-columns:1fr 1fr}
  .cards.four{grid-template-columns:1fr}
  .cols,.founder{grid-template-columns:1fr}
  .fcols{grid-template-columns:1fr 1fr}
  .rung{grid-template-columns:34px 1fr;row-gap:var(--s2)}
  .rung .pr{grid-column:2;text-align:left}
  .commit .row{grid-template-columns:34px 1fr}
}
@media(max-width:560px){
  body{background-size:34px 34px}
  .nav .btn{display:none} /* brand + menu only — the hero CTA is one scroll away */
  .cards,.courses,.fcols{grid-template-columns:1fr}
  .capture form{flex-direction:column}
  .capture input{font-size:16px} /* prevents iOS focus-zoom */
  .btn-pri{justify-content:center}
  .bands li{grid-template-columns:1fr;row-gap:var(--s1)}
}

/* ---- reduced motion: kill every transform/transition ---- */
@media(prefers-reduced-motion:reduce){
  .rv,.js .rv{transition:none!important;opacity:1!important;transform:none!important}
  .btn,.card,.course,.btn-pri:hover,.card:hover,.course:hover,a.stat{transition:none!important;transform:none!important}
}

/* ---- print: plain reading, no chrome ---- */
@media print{
  body{background:#fff;color:#111}
  header,footer,.skip,.mnav,.capture,.btn{display:none!important}
  .doc a{border:0;color:#111}
}
