/* kagai.me — shared tokens + components for all page mocks */
:root {
  --ink-100: #FBF8F1; --ink-95: #F4EEE0; --ink-85: #E5DCC7;
  --ink-70: #C4B89D; --ink-55: #8C8369; --ink-40: #5A5440;
  --ink-25: #2E2A1F; --ink-15: #1A1810; --ink-10: #0E0D08;
  --rule: rgba(26,24,16,0.12); --rule-strong: rgba(26,24,16,0.22);
  --amber: #B8862B; --amber-soft: #E8C770; --amber-ink: #5C4310;
  --pos: #3F6B4A; --neg: #9A4423;
  --f-display: 'Newsreader','Source Serif Pro',Georgia,serif;
  --f-body: 'Inter Tight',ui-sans-serif,system-ui,-apple-system,sans-serif;
  --f-mono: 'JetBrains Mono',ui-monospace,'SF Mono',Menlo,monospace;
  --t-caption:11px; --t-small:13px; --t-body:16px; --t-body-l:19px;
  --t-subhead:22px; --t-h3:28px; --t-h2:40px; --t-h1:56px; --t-display:88px;
  --s-1:4px; --s-2:8px; --s-3:12px; --s-4:16px; --s-5:24px;
  --s-6:32px; --s-7:48px; --s-8:64px; --s-9:96px; --s-10:128px;
  --r-1:2px; --r-2:4px; --r-3:8px; --r-4:12px;
  --ease-out: cubic-bezier(0.2,0,0,1); --d-fast:150ms; --d-base:200ms;
  --gutter: 32px;
}
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font:400 16px/1.65 var(--f-body);color:var(--ink-15);background:var(--ink-100);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
.page{max-width:1440px;margin-inline:auto}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:default;border:0;background:none}

.display{font:500 88px/0.98 var(--f-display);letter-spacing:-0.025em;color:var(--ink-10)}
.h1{font:500 56px/1.05 var(--f-display);letter-spacing:-0.022em;color:var(--ink-10)}
.h2{font:500 40px/1.12 var(--f-display);letter-spacing:-0.018em;color:var(--ink-10)}
.h3{font:500 28px/1.25 var(--f-display);letter-spacing:-0.012em;color:var(--ink-10)}
.subhead{font:500 22px/1.35 var(--f-body);letter-spacing:-0.005em;color:var(--ink-15)}
.body-l{font:400 19px/1.55 var(--f-body);color:var(--ink-25)}
.body{font:400 16px/1.65 var(--f-body);color:var(--ink-25)}
.small{font:400 13px/1.55 var(--f-body);color:var(--ink-40)}
.caption{font:500 11px/1.4 var(--f-mono);letter-spacing:0.08em;text-transform:uppercase;color:var(--ink-40)}
.mono{font:400 13px/1.55 var(--f-mono);color:var(--ink-25)}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:var(--s-2);font:500 14px/1 var(--f-body);letter-spacing:-0.005em;padding:14px 22px;border-radius:var(--r-2);border:0.5px solid transparent;white-space:nowrap;transition:background var(--d-base) var(--ease-out),color var(--d-base) var(--ease-out),border-color var(--d-base) var(--ease-out)}
.btn-primary{background:var(--ink-10);color:var(--ink-100)}
.btn-primary:hover{background:var(--amber);color:var(--amber-ink)}
.btn-secondary{background:transparent;color:var(--ink-15);border-color:var(--rule-strong)}
.btn-secondary:hover{border-color:var(--ink-15)}
.btn-ghost{background:transparent;color:var(--ink-25);padding:14px 0}
.btn-ghost:hover{color:var(--ink-10)}
.btn-link{display:inline-flex;align-items:baseline;gap:var(--s-2);font:500 14px/1 var(--f-body);color:var(--ink-15);border-bottom:1px solid var(--amber);padding-bottom:2px;white-space:nowrap;transition:color var(--d-fast) var(--ease-out)}
.btn-link:hover{color:var(--amber-ink)}
.btn-link .arrow{transition:transform var(--d-base) var(--ease-out)}
.btn-link:hover .arrow{transform:translateX(3px)}

/* Chips */
.chip{display:inline-flex;align-items:center;gap:var(--s-2);font:500 11px/1 var(--f-mono);letter-spacing:0.08em;text-transform:uppercase;color:var(--ink-40);padding:6px 10px;border:0.5px solid var(--rule-strong);border-radius:var(--r-1);transition:color var(--d-fast) var(--ease-out),border-color var(--d-fast) var(--ease-out)}
.chip:hover{color:var(--ink-15);border-color:var(--ink-15)}
.chip.is-active{color:var(--ink-10);border-color:var(--ink-10);background:var(--ink-95)}
.chip-strategy{color:var(--ink-15);border-color:var(--ink-15)}
.chip-technical{color:var(--amber-ink);border-color:var(--amber)}
.chip-industry{color:var(--pos);border-color:var(--pos)}

/* Site nav */
.snav{display:flex;align-items:center;justify-content:space-between;padding:var(--s-5) var(--s-6);border-bottom:0.5px solid var(--rule)}
.snav .mark{font:600 31px/1 var(--f-display);color:var(--ink-10);letter-spacing:-0.02em}
.snav .mark::after{content:'.';color:var(--amber)}
.snav-links{display:flex;gap:var(--s-6);list-style:none;padding:0;margin:0}
.snav-links a{font:500 14px/1 var(--f-body);color:var(--ink-25);transition:color var(--d-fast) var(--ease-out)}
.snav-links a:hover,.snav-links a.is-active{color:var(--ink-10)}
.snav-links a.is-active{border-bottom:1px solid var(--amber);padding-bottom:2px}
.snav-cta{display:flex;gap:var(--s-3);align-items:center}

/* Section head */
.section{padding-block:var(--s-9);padding-inline:max(var(--s-6),calc(50vw - 720px + var(--s-6)));margin-inline:calc(50% - 50vw);border-top:1px solid var(--rule)}
.section-head{display:grid;grid-template-columns:200px 1fr;gap:var(--s-7);margin-bottom:var(--s-7)}
.section-head .marker{font:500 11px/1.5 var(--f-mono);color:var(--ink-55);text-transform:uppercase;letter-spacing:0.12em}
.section-head .marker em{color:var(--amber);font-style:normal}
.section-head h2{margin:0;max-width:24ch}

/* Stat tile */
.stat-tile{display:flex;flex-direction:column;gap:var(--s-3);padding:var(--s-6) 0;border-top:1px solid var(--ink-15)}
.stat-tile .stat-label{font:500 11px/1 var(--f-mono);letter-spacing:0.1em;text-transform:uppercase;color:var(--ink-40)}
.stat-tile .stat-num{font:500 64px/0.95 var(--f-display);letter-spacing:-0.025em;color:var(--ink-10)}
.stat-tile .stat-num .arrow{color:var(--ink-55);padding:0 var(--s-2);font-weight:400}
.stat-tile .stat-num .pos{color:var(--pos)}
.stat-tile .stat-num .neg{color:var(--neg)}
.stat-tile .stat-num .accent{color:var(--amber)}
.stat-tile .stat-context{font:400 14px/1.45 var(--f-body);color:var(--ink-40);max-width:32ch}
.stat-tile .stat-attr{font:500 11px/1 var(--f-mono);letter-spacing:0.06em;color:var(--ink-55);margin-top:var(--s-2)}

/* Pillar */
.pillar{display:flex;flex-direction:column;gap:var(--s-3);padding:var(--s-6) var(--s-5) var(--s-6) var(--s-5);border-left:1px solid var(--rule-strong)}
.pillar .num{font:500 11px/1 var(--f-mono);letter-spacing:0.1em;color:var(--amber-ink)}
.pillar .name{font:500 22px/1.2 var(--f-display);color:var(--ink-10);letter-spacing:-0.01em}
.pillar .desc{font:400 14px/1.55 var(--f-body);color:var(--ink-25)}

/* Pull quote */
.pullquote{padding:var(--s-7) 0;border-top:1px solid var(--ink-15);border-bottom:1px solid var(--rule);max-width:64ch}
.pullquote .stars{display:flex;gap:2px;margin-bottom:var(--s-4)}
.pullquote .stars span{width:10px;height:10px;background:var(--amber);display:block;clip-path:polygon(50% 0%,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%)}
.pullquote-text{font:400 30px/1.3 var(--f-display);color:var(--ink-10);letter-spacing:-0.015em;margin:0 0 var(--s-5) 0}
.pullquote-text::before{content:'\201C';color:var(--amber);margin-left:-0.45em}
.pullquote-text::after{content:'\201D';color:var(--amber)}
.pullquote-attr{display:flex;gap:var(--s-3);align-items:baseline}
.pullquote-attr .name{font:500 13px/1 var(--f-body);color:var(--ink-15)}
.pullquote-attr .role{font:400 13px/1 var(--f-body);color:var(--ink-55)}
.pullquote-draft{font:500 9px/1 var(--f-mono);color:var(--ink-55);letter-spacing:0.08em;text-transform:uppercase;padding:4px 6px;border:0.5px solid var(--rule-strong)}

/* Review card (shared by reviews.html + home 3-up) */
.review-card{padding:var(--s-5);background:var(--ink-100);border:0.5px solid var(--rule);border-radius:var(--r-3);display:flex;flex-direction:column;gap:var(--s-4);height:100%}
.review-card .stars{display:flex;gap:2px}
.review-card .stars span{width:14px;height:14px;background:var(--ink-70);clip-path:polygon(50% 0%,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%);display:block}
.review-card .stars span.on{background:var(--amber)}
.review-card .stars span.partial{background:linear-gradient(to right,var(--amber) var(--fill),var(--ink-70) var(--fill))}
.review-card .body{margin:0;font:400 15px/1.55 var(--f-body);color:var(--ink-25);flex:1}
.review-card .brand{font:500 13px/1.4 var(--f-body);color:var(--ink-10);margin-top:auto;padding-top:var(--s-3);border-top:0.5px solid var(--rule)}
.review-card .brand .store{color:var(--ink-40);font-weight:400}
.review-card.is-hidden{display:none}
.home-reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-5);margin-top:var(--s-6)}
@media (max-width: 1024px){.home-reviews-grid{grid-template-columns:1fr;gap:var(--s-4)}}

/* CTA block */
.ctablock{padding:var(--s-9) var(--s-7);background:var(--ink-10);color:var(--ink-100);border-radius:var(--r-3);display:grid;grid-template-columns:1.2fr 1fr;gap:var(--s-7);align-items:end}
.ctablock .label{font:500 11px/1.5 var(--f-mono);color:var(--amber-soft);letter-spacing:0.12em;text-transform:uppercase;margin-bottom:var(--s-4)}
.ctablock h3{margin:0;color:var(--ink-100);font:500 40px/1.12 var(--f-display);letter-spacing:-0.018em}
.ctablock .sub{color:rgba(251,248,241,0.6);font:400 16px/1.55 var(--f-body);margin-top:var(--s-4);max-width:42ch}
.ctablock .btn-primary{background:var(--amber);color:var(--amber-ink)}
.ctablock .btn-primary:hover{background:var(--amber-soft)}
.ctablock .actions{display:flex;gap:var(--s-3);align-items:center;justify-content:flex-end;flex-wrap:wrap}
.ctablock .btn-ghost{color:rgba(251,248,241,0.7)}
.ctablock .btn-ghost:hover{color:var(--ink-100)}

/* Footer */
.footer{padding-block:var(--s-9) var(--s-6);padding-inline:max(var(--s-6),calc(50vw - 720px + var(--s-6)));margin-inline:calc(50% - 50vw);background:var(--ink-10);color:var(--ink-100)}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:var(--s-7)}
.footer .mark{font:600 32px/1 var(--f-display);color:var(--ink-100);letter-spacing:-0.02em}
.footer .mark::after{content:'.';color:var(--amber)}
.footer .bio{font:400 14px/1.6 var(--f-body);color:rgba(251,248,241,0.55);margin-top:var(--s-4);max-width:36ch}
.footer .reviews-widget{margin-top:var(--s-5);display:flex;gap:var(--s-3);align-items:center}
.footer .reviews-widget .stars{display:flex;gap:1px}
.footer .reviews-widget .stars span{width:10px;height:10px;background:var(--amber);display:block;clip-path:polygon(50% 0%,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%)}
.footer .reviews-widget .label{font:500 11px/1 var(--f-mono);color:rgba(251,248,241,0.55);letter-spacing:0.06em;text-transform:uppercase}
.footer h5{margin:0 0 var(--s-3) 0;font:500 11px/1 var(--f-mono);letter-spacing:0.12em;text-transform:uppercase;color:rgba(251,248,241,0.4)}
.footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--s-3)}
.footer ul a{font:400 14px/1 var(--f-body);color:rgba(251,248,241,0.85);transition:color var(--d-fast) var(--ease-out)}
.footer ul a:hover{color:var(--amber-soft)}
.footer-bottom{display:flex;justify-content:space-between;padding-top:var(--s-5)}
.footer-bottom .small{color:rgba(251,248,241,0.4)}

/* Home-specific */
.hero{padding:var(--s-10) var(--s-6) var(--s-9);position:relative}
.hero-eyebrow{display:inline-flex;gap:var(--s-3);align-items:center;font:500 11px/1 var(--f-mono);letter-spacing:0.12em;text-transform:uppercase;color:var(--ink-40);margin-bottom:var(--s-5)}
.hero-eyebrow::before{content:'';width:24px;height:1px;background:var(--amber)}
.hero h1{margin:0;max-width:22ch;font:500 88px/0.98 var(--f-display);letter-spacing:-0.025em;color:var(--ink-10)}
.hero h1 .underline{background-image:linear-gradient(var(--amber),var(--amber));background-size:100% 2px;background-position:0 95%;background-repeat:no-repeat;padding-bottom:2px}
.hero-sub{margin-top:var(--s-5);max-width:56ch;font:400 19px/1.55 var(--f-body);color:var(--ink-25)}
.hero-actions{margin-top:var(--s-6);display:flex;gap:var(--s-4);align-items:center}
.hero-meta{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s-5);margin-top:var(--s-9);padding-top:var(--s-5);border-top:1px solid var(--rule)}
.hero-meta .item .label{font:500 11px/1 var(--f-mono);color:var(--ink-55);letter-spacing:0.1em;text-transform:uppercase;margin-bottom:var(--s-2)}
.hero-meta .item .val{font:500 18px/1.2 var(--f-display);color:var(--ink-10);letter-spacing:-0.005em}
.results-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-6) var(--s-7)}
.pillars-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.pillars-grid .pillar:first-child{padding-left:0;border-left:none}
.cs-grid{display:grid;grid-template-columns:1fr;gap:0}
.cstile{display:grid;grid-template-columns:1fr;gap:var(--s-4);padding:var(--s-7) 0;border-top:1px solid var(--ink-15)}
.cstile-num{font:500 80px/0.95 var(--f-display);letter-spacing:-0.025em;color:var(--ink-10)}
.cstile-num .arrow{color:var(--ink-55);padding:0 var(--s-3);font-weight:400}
.cstile-num .pos{color:var(--pos)}
.cstile-num .accent{color:var(--amber)}
.cstile-num .neg{color:var(--neg)}
.cstile-headline{font:500 22px/1.3 var(--f-display);color:var(--ink-10);letter-spacing:-0.008em;max-width:38ch}
.cstile-meta{display:flex;gap:var(--s-4);align-items:center}
.cstile-meta .brand{font:500 13px/1 var(--f-body);color:var(--ink-15)}
.insights-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-6)}
.acard{display:flex;flex-direction:column;gap:var(--s-3);padding:var(--s-5) 0;border-top:0.5px solid var(--rule)}
.acard:hover .acard-title{color:var(--amber-ink)}
.acard-thumb{height:220px;background:repeating-linear-gradient(135deg,var(--ink-95) 0 8px,var(--ink-85) 8px 9px);border-radius:var(--r-2);display:flex;align-items:flex-end;padding:var(--s-3)}
.acard-thumb .placeholder-label{font:500 10px/1.2 var(--f-mono);color:var(--ink-55);text-transform:uppercase;letter-spacing:0.08em}
.acard-meta{display:flex;gap:var(--s-3);align-items:center}
.acard-title{font:500 24px/1.2 var(--f-display);color:var(--ink-10);letter-spacing:-0.012em;transition:color var(--d-base) var(--ease-out)}
.acard-dek{font:400 15px/1.55 var(--f-body);color:var(--ink-40)}
.acard-byline{font:500 11px/1 var(--f-mono);color:var(--ink-55);letter-spacing:0.06em}

/* ─── Voice block: "A note about money" (caring) ──────────────────────── */
.note-money{padding-block:var(--s-9);padding-inline:max(var(--s-6),calc(50vw - 720px + var(--s-6)));margin-inline:calc(50% - 50vw);background:var(--ink-100);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);display:grid;grid-template-columns:200px 1fr;gap:var(--s-7)}
.note-money .marker{font:500 11px/1.5 var(--f-mono);color:var(--ink-55);text-transform:uppercase;letter-spacing:0.12em}
.note-money h2{margin:0 0 var(--s-5);font:500 40px/1.15 var(--f-display);letter-spacing:-0.018em;color:var(--ink-10);max-width:22ch}
.note-money .body p{margin:0 0 var(--s-4);font:400 19px/1.65 var(--f-display);color:var(--ink-15);max-width:60ch}
.note-money .body p:last-of-type{margin-bottom:0}
.note-money .body p .lift{background:linear-gradient(transparent 60%,var(--amber-soft) 60%)}
.note-money .signoff{margin-top:var(--s-6);padding-top:var(--s-4);border-top:0.5px solid var(--rule);display:flex;gap:var(--s-4);align-items:center;font:500 13px/1 var(--f-body);color:var(--ink-55)}
.note-money .signoff .pen{font:400 13px/1 var(--f-mono);color:var(--amber-ink)}

/* ─── Voice block: "30-day promise" (honest) ───────────────────────────── */
.promise-block{padding-block:var(--s-9);padding-inline:max(var(--s-6),calc(50vw - 720px + var(--s-6)));margin-inline:calc(50% - 50vw);background:var(--ink-95);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.promise-head{display:grid;grid-template-columns:200px 1fr;gap:var(--s-7);margin-bottom:var(--s-6)}
.promise-head .marker{font:500 11px/1.5 var(--f-mono);color:var(--ink-55);text-transform:uppercase;letter-spacing:0.12em}
.promise-head .marker em{color:var(--amber-ink);font-style:normal}
.promise-head h2{margin:0;font:500 40px/1.12 var(--f-display);letter-spacing:-0.018em;color:var(--ink-10);max-width:22ch}
.promise-head .lede{margin:var(--s-3) 0 0;font:400 16px/1.55 var(--f-body);color:var(--ink-40);max-width:56ch}
.promise-grid{display:grid;grid-template-columns:200px 1fr;gap:0 var(--s-7)}
.promise-grid .spacer{}
.promise-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--rule-strong);border:0.5px solid var(--rule-strong)}
.promise-card{padding:var(--s-6) var(--s-5);background:var(--ink-100);display:flex;flex-direction:column;gap:var(--s-3)}
.promise-card .num{font:500 56px/0.95 var(--f-display);color:var(--ink-10);letter-spacing:-0.025em}
.promise-card .num small{font:500 11px/1 var(--f-mono);color:var(--ink-55);letter-spacing:0.12em;text-transform:uppercase;padding-left:10px;vertical-align:middle}
.promise-card h4{margin:0;font:500 22px/1.25 var(--f-display);color:var(--ink-10);letter-spacing:-0.008em}
.promise-card p{margin:0;font:400 14px/1.55 var(--f-body);color:var(--ink-40);max-width:38ch}
.promise-card .signed{margin-top:auto;padding-top:var(--s-3);border-top:0.5px dashed var(--rule-strong);font:500 11px/1 var(--f-mono);color:var(--amber-ink);letter-spacing:0.06em}

/* ─── Footer: memberships strip ──────────────────────────────────────── */
.memberships{padding:var(--s-5) 0;border-top:0.5px solid rgba(251,248,241,0.12);border-bottom:0.5px solid rgba(251,248,241,0.12);margin:var(--s-6) 0;display:flex;align-items:center;justify-content:space-between;gap:var(--s-5);flex-wrap:wrap}
.memberships .label{font:500 10px/1 var(--f-mono);letter-spacing:0.12em;text-transform:uppercase;color:rgba(251,248,241,0.4)}
.memberships .marks{display:flex;gap:var(--s-5);align-items:center;flex-wrap:wrap}
.member-mark{display:inline-flex;align-items:center;gap:var(--s-3);padding:8px 14px;border:0.5px solid rgba(251,248,241,0.18);border-radius:var(--r-2);transition:border-color var(--d-base) var(--ease-out),background var(--d-base) var(--ease-out)}
.member-mark:hover{border-color:var(--amber-soft);background:rgba(184,134,43,0.08)}
.member-mark .badge{width:10px;height:10px;background:var(--amber);border-radius:50%;flex-shrink:0}
.member-mark .text{display:flex;flex-direction:column;gap:2px}
.member-mark .name{font:500 13px/1 var(--f-body);color:var(--ink-100);letter-spacing:-0.005em}
.member-mark .role{font:400 10px/1 var(--f-mono);color:rgba(251,248,241,0.55);letter-spacing:0.08em;text-transform:uppercase}

/* Page */
.page{background:var(--ink-100)}
.placeholder{background:repeating-linear-gradient(135deg,var(--ink-95) 0 8px,var(--ink-85) 8px 9px);display:flex;align-items:flex-end;padding:var(--s-3);border-radius:var(--r-2)}
.placeholder .placeholder-label{font:500 10px/1.2 var(--f-mono);color:var(--ink-55);text-transform:uppercase;letter-spacing:0.08em}

/* ─── RESPONSIVE ──────────────────────────────────────────────────────────
   1024px: tablet — collapse 4-up grids to 2-up, drop 200px side rails
   640px:  mobile — single column, stacked nav, smaller display type
   ───────────────────────────────────────────────────────────────────────── */

@media (max-width: 1024px){
  /* Hero — softer display type, 2-up meta */
  .hero{padding:var(--s-9) var(--s-5) var(--s-8)}
  .hero h1{font-size:64px;letter-spacing:-0.022em}
  .hero-meta{grid-template-columns:repeat(2,1fr);gap:var(--s-5) var(--s-6)}
  /* Section heads stack the rail above the heading */
  .section{padding:var(--s-8) var(--s-5)}
  .section-head{grid-template-columns:1fr;gap:var(--s-3)}
  /* Pillars 4-up → 2-up */
  .pillars-grid{grid-template-columns:repeat(2,1fr)}
  .pillars-grid .pillar:nth-child(3){padding-left:0;border-left:none}
  /* Results 3-up → 2-up */
  .results-grid{grid-template-columns:repeat(2,1fr);gap:var(--s-6)}
  /* Insights 3-up → 2-up */
  .insights-grid{grid-template-columns:repeat(2,1fr)}
  /* Footer 4-col → 2-col */
  .footer-top{grid-template-columns:1fr 1fr;gap:var(--s-6)}
  .footer-top > div:first-child{grid-column:1 / -1}
  /* CTA block stacks */
  .ctablock{grid-template-columns:1fr;gap:var(--s-6);padding:var(--s-7) var(--s-5)}
  .ctablock h3{font-size:32px}
  /* Voice blocks */
  .note-money,.promise-head{grid-template-columns:1fr;gap:var(--s-3)}
  .promise-grid{grid-template-columns:1fr}
  .promise-grid .spacer{display:none}
}

@media (max-width: 640px){
  /* Site nav: hide inline links, keep mark + CTA */
  .snav{padding:var(--s-4) var(--s-5)}
  /* Pull-quote attribution: stack name + role vertically */
  .pullquote-attr{flex-direction:column;gap:var(--s-1);align-items:flex-start}
  .snav-links{display:none}
  .snav .mark{font-size:26px}
  .snav-cta .btn{padding:8px 14px;font-size:12px}
  /* Hero — phone-scale display */
  .hero{padding:var(--s-7) var(--s-5) var(--s-7)}
  .hero h1{font-size:42px;line-height:1.02;max-width:100%;letter-spacing:-0.02em}
  .hero-eyebrow{font-size:10px;margin-bottom:var(--s-4)}
  .hero-sub{font-size:16px;margin-top:var(--s-4);max-width:100%}
  .hero-actions{margin-top:var(--s-5);flex-direction:column;align-items:flex-start;gap:var(--s-3)}
  .hero-actions .btn{width:100%;justify-content:center}
  .hero-meta{grid-template-columns:1fr 1fr;gap:var(--s-4);margin-top:var(--s-7);padding-top:var(--s-4)}
  .hero-meta .item .label{font-size:10px}
  .hero-meta .item .val{font-size:15px}
  /* Sections */
  .section{padding:var(--s-7) var(--s-5)}
  .section-head h2{font-size:28px;line-height:1.18}
  /* Stat tiles single column */
  .results-grid{grid-template-columns:1fr;gap:var(--s-5)}
  .stat-tile .stat-num{font-size:56px}
  /* Pillars single column with stacked dividers (no left borders) */
  .pillars-grid{grid-template-columns:1fr;gap:0}
  .pillar{padding:var(--s-5) 0 !important;border-left:none !important;border-top:0.5px solid var(--rule)}
  .pillar:first-child{border-top:none;padding-top:0 !important}
  .pillar .num{font-size:36px}
  .pillar .name{font-size:18px}
  /* Case study tiles */
  .cstile{padding:var(--s-6) 0}
  .cstile-num{font-size:48px}
  .cstile-headline{font-size:20px;line-height:1.3}
  .cstile-meta{flex-wrap:wrap;gap:var(--s-3)}
  /* Pull quote */
  .pullquote{padding:var(--s-6) 0}
  .pullquote-text{font-size:24px;line-height:1.3}
  /* Insights single column */
  .insights-grid{grid-template-columns:1fr;gap:var(--s-4)}
  .acard-title{font-size:20px}
  /* CTA block */
  .ctablock{padding:var(--s-6) var(--s-5);border-radius:var(--r-2)}
  .ctablock h3{font-size:26px;line-height:1.2}
  .ctablock .actions{flex-direction:column;align-items:stretch;gap:var(--s-3)}
  .ctablock .actions .btn{width:100%;justify-content:center}
  /* Footer single column */
  .footer{padding:var(--s-7) var(--s-5) var(--s-5)}
  .footer-top{grid-template-columns:1fr;gap:var(--s-6)}
  .footer-top > div:first-child{grid-column:auto}
  .footer .mark{font-size:24px}
  .memberships{flex-direction:column;align-items:flex-start;gap:var(--s-4);padding:var(--s-4) 0}
  .memberships .marks{flex-direction:column;align-items:stretch;gap:var(--s-3);width:100%}
  .member-mark{justify-content:flex-start}
  .footer-bottom{flex-direction:column;gap:var(--s-2);align-items:flex-start;padding-top:var(--s-4)}
  /* Voice blocks (Solutions/Case Study) */
  .note-money,.promise-block{padding:var(--s-7) var(--s-5)}
  .note-money h2,.promise-head h2{font-size:26px;line-height:1.18}
  .promise-cards{grid-template-columns:1fr}
  .promise-card{padding:var(--s-5)}
  .promise-card .num{font-size:40px}
}

/* Mobile menu trigger — only visible at ≤640px */
.mobile-menu{display:none;background:none;border:0;padding:8px;cursor:pointer;flex-direction:column;gap:4px;align-items:flex-end}
.mobile-menu span{display:block;width:22px;height:1.5px;background:var(--ink-10);transition:transform var(--d-fast) var(--ease-out)}
.mobile-menu span:last-child{width:14px}
@media (max-width: 640px){
  .mobile-menu{display:flex}
  .snav.is-open .snav-links{display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:var(--ink-100);border-top:0.5px solid var(--rule);border-bottom:0.5px solid var(--rule);padding:var(--s-4) var(--s-5);gap:var(--s-4);z-index:50}
  .snav.is-open .snav-links a{font-size:16px;padding:var(--s-2) 0}
  .snav{position:relative}
  .snav.is-open .mobile-menu span:nth-child(1){transform:translateY(5.5px) rotate(45deg)}
  .snav.is-open .mobile-menu span:nth-child(2){opacity:0}
  .snav.is-open .mobile-menu span:nth-child(3){width:22px;transform:translateY(-5.5px) rotate(-45deg)}
}

/* ─────────────────────────────────────────────────────────────────
   ABOUT PAGE
   ───────────────────────────────────────────────────────────────── */
.about-hero{padding:var(--s-10) var(--s-6) var(--s-8);max-width:920px}
.about-hero .eyebrow{display:inline-flex;gap:var(--s-3);align-items:center;font:500 11px/1 var(--f-mono);letter-spacing:0.12em;text-transform:uppercase;color:var(--ink-40);margin-bottom:var(--s-5)}
.about-hero .eyebrow::before{content:'';width:24px;height:1px;background:var(--amber)}
.about-hero h1{margin:0;font:500 72px/1.05 var(--f-display);letter-spacing:-0.022em;color:var(--ink-10);max-width:18ch}
.about-hero h1 .accent{background-image:linear-gradient(var(--amber),var(--amber));background-size:100% 2px;background-position:0 95%;background-repeat:no-repeat;padding-bottom:2px}
.about-hero .lede{margin-top:var(--s-6);max-width:60ch;font:400 19px/1.55 var(--f-body);color:var(--ink-25)}

.values-band{padding-block:var(--s-9);padding-inline:max(var(--s-6),calc(50vw - 720px + var(--s-6)));margin-inline:calc(50% - 50vw);background:var(--ink-95);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-7)}
.value-card{display:flex;flex-direction:column;gap:var(--s-4)}
.value-card .num{font:500 56px/0.95 var(--f-display);color:var(--ink-10);letter-spacing:-0.022em}
.value-card .num em{color:var(--amber);font-style:normal}
.value-card h3{margin:0;font:500 24px/1.25 var(--f-display);color:var(--ink-10);letter-spacing:-0.012em}
.value-card p{margin:0;font:400 15px/1.6 var(--f-body);color:var(--ink-25);max-width:38ch}
.value-card .ref{margin-top:var(--s-3);font:500 11px/1 var(--f-mono);color:var(--ink-40);letter-spacing:0.04em;border-top:0.5px solid var(--rule);padding-top:var(--s-3)}

.bio-section{padding:var(--s-9) var(--s-6)}
.bio-grid{display:grid;grid-template-columns:200px 1fr;gap:var(--s-7);max-width:1100px}
.bio-grid h2{margin:0 0 var(--s-5);font:500 40px/1.12 var(--f-display);letter-spacing:-0.018em;color:var(--ink-10);max-width:22ch}
.bio-prose p{margin:0 0 var(--s-5);font:400 17px/1.65 var(--f-body);color:var(--ink-25);max-width:60ch}
.bio-prose p:last-child{margin-bottom:0}
.bio-prose strong{color:var(--ink-15);font-weight:500}

.timeline{padding-block:var(--s-9);padding-inline:max(var(--s-6),calc(50vw - 720px + var(--s-6)));margin-inline:calc(50% - 50vw);background:var(--ink-100);border-top:1px solid var(--rule)}
.timeline-grid{display:grid;grid-template-columns:200px 1fr;gap:var(--s-7);max-width:1100px}
.timeline-grid h2{margin:0;font:500 40px/1.12 var(--f-display);letter-spacing:-0.018em;color:var(--ink-10);max-width:22ch}
.timeline-list{display:flex;flex-direction:column}
.timeline-item{display:grid;grid-template-columns:120px 1fr;gap:var(--s-6);padding:var(--s-5) 0;border-top:0.5px solid var(--rule)}
.timeline-item:first-child{border-top:none;padding-top:0}
.timeline-item .year{font:500 14px/1 var(--f-mono);color:var(--ink-55);letter-spacing:0.04em;padding-top:6px}
.timeline-item .role{font:500 18px/1.3 var(--f-display);color:var(--ink-10);letter-spacing:-0.005em}
.timeline-item .role .org{color:var(--amber-ink)}
.timeline-item .desc{margin-top:var(--s-2);font:400 14px/1.55 var(--f-body);color:var(--ink-40);max-width:60ch}

.notgood-band{padding-block:var(--s-9);padding-inline:max(var(--s-6),calc(50vw - 720px + var(--s-6)));margin-inline:calc(50% - 50vw);background:var(--ink-95);color:var(--ink-15);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.notgood-grid{display:grid;grid-template-columns:200px 1fr;gap:var(--s-7);max-width:1100px}
.notgood-grid .marker{font:500 11px/1.5 var(--f-mono);color:var(--ink-55);text-transform:uppercase;letter-spacing:0.12em}
.notgood-grid .marker em{color:var(--amber-ink);font-style:normal}
.notgood-grid h2{margin:0;font:500 40px/1.12 var(--f-display);letter-spacing:-0.018em;color:var(--ink-10);max-width:22ch}
.notgood-grid .lede{margin:var(--s-3) 0 var(--s-6);font:400 17px/1.55 var(--f-body);color:var(--ink-25);max-width:56ch}
.notgood-list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:0}
.notgood-list li{padding:var(--s-5) 0;border-top:0.5px solid var(--rule)}
.notgood-list li:first-child{border-top:none;padding-top:0}
.notgood-list h4{margin:0 0 var(--s-2);font:500 20px/1.3 var(--f-display);color:var(--ink-10);letter-spacing:-0.005em}
.notgood-list p{margin:0;font:400 15px/1.55 var(--f-body);color:var(--ink-25);max-width:64ch}
.notgood-list .ref{margin-top:var(--s-3);font:500 11px/1 var(--f-mono);color:var(--amber-ink);letter-spacing:0.06em}

/* ─────────────────────────────────────────────────────────────────
   CONTACT PAGE
   ───────────────────────────────────────────────────────────────── */
.contact-hero{padding:var(--s-10) var(--s-6) var(--s-7);max-width:920px}
.contact-hero h1{margin:0;font:500 72px/1.05 var(--f-display);letter-spacing:-0.022em;color:var(--ink-10);max-width:18ch}
.contact-hero h1 .accent{background-image:linear-gradient(var(--amber),var(--amber));background-size:100% 2px;background-position:0 95%;background-repeat:no-repeat;padding-bottom:2px}
.contact-hero .lede{margin-top:var(--s-5);max-width:56ch;font:400 19px/1.55 var(--f-body);color:var(--ink-25)}

.contact-grid{padding:var(--s-7) var(--s-6) var(--s-9);display:grid;grid-template-columns:1.4fr 1fr;gap:var(--s-9);max-width:1240px}
.contact-form{display:flex;flex-direction:column;gap:var(--s-5)}
.contact-form h2{margin:0 0 var(--s-3);font:500 28px/1.25 var(--f-display);color:var(--ink-10);letter-spacing:-0.012em}
.contact-form .field{display:flex;flex-direction:column;gap:var(--s-2)}
.contact-form label{font:500 11px/1 var(--f-mono);color:var(--ink-55);letter-spacing:0.08em;text-transform:uppercase}
.contact-form input,.contact-form textarea,.contact-form select{font:400 16px/1.5 var(--f-body);color:var(--ink-10);background:transparent;border:0;border-bottom:1px solid var(--rule-strong);padding:10px 0;outline:none;width:100%;font-family:inherit}
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{border-bottom-color:var(--amber)}
.contact-form textarea{resize:vertical;min-height:90px}
.contact-form .row{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-5)}
.contact-form .submit-row{display:flex;justify-content:space-between;align-items:center;margin-top:var(--s-4);padding-top:var(--s-5);border-top:0.5px solid var(--rule)}
.contact-form .privacy{font:400 12px/1.5 var(--f-body);color:var(--ink-55);max-width:36ch}

/* Form states */
.contact-form .field.is-error input,
.contact-form .field.is-error textarea,
.contact-form .field.is-error select{border-bottom-color:#c8482b}
.contact-form .field.is-error label{color:#c8482b}
.contact-form .field .err{font:500 12px/1.4 var(--f-body);color:#c8482b;display:flex;gap:6px;align-items:flex-start;margin-top:4px}
.contact-form .field .err::before{content:"!";display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%;background:#c8482b;color:var(--ink-100);font:600 10px/1 var(--f-body);flex:0 0 14px;margin-top:2px}
.contact-form .field .hint{font:400 12px/1.4 var(--f-body);color:var(--ink-55);margin-top:4px}

.form-banner{padding:var(--s-4) var(--s-5);border-radius:2px;display:flex;gap:var(--s-3);align-items:flex-start;margin-bottom:var(--s-4);font:400 14px/1.5 var(--f-body)}
.form-banner.is-error{background:rgba(200,72,43,0.08);border-left:3px solid #c8482b;color:var(--ink-15)}
.form-banner.is-error strong{color:#c8482b;font-weight:600}
.form-banner .icon{flex:0 0 18px;display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:#c8482b;color:var(--ink-100);font:600 11px/1 var(--f-body);margin-top:1px}

.btn.is-loading{position:relative;color:transparent;pointer-events:none}
.btn.is-loading::after{content:"";position:absolute;inset:0;margin:auto;width:14px;height:14px;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:btnspin 0.7s linear infinite;color:var(--ink-100)}
@keyframes btnspin{to{transform:rotate(360deg)}}

.form-success{padding:var(--s-7) var(--s-6);background:var(--ink-95);border:1px solid var(--rule);border-radius:2px;display:grid;grid-template-columns:48px 1fr;gap:var(--s-4);align-items:start}
.form-success .check{width:48px;height:48px;border-radius:50%;background:var(--amber);display:inline-flex;align-items:center;justify-content:center;color:var(--ink-10);font:500 22px/1 var(--f-display)}
.form-success h3{margin:0 0 var(--s-2);font:500 24px/1.2 var(--f-display);color:var(--ink-10);letter-spacing:-0.012em}
.form-success p{margin:0 0 var(--s-3);font:400 15px/1.55 var(--f-body);color:var(--ink-25);max-width:52ch}
.form-success .next{margin-top:var(--s-4);padding-top:var(--s-4);border-top:0.5px solid var(--rule);font:500 11px/1.5 var(--f-mono);color:var(--ink-55);letter-spacing:0.08em;text-transform:uppercase}
.form-success .next em{display:block;font:400 14px/1.55 var(--f-body);color:var(--ink-15);font-style:normal;letter-spacing:0;text-transform:none;margin-top:var(--s-2)}

/* Empty state — Case Studies filter zero results */
.empty-state{padding:var(--s-9) var(--s-6);display:grid;grid-template-columns:200px 1fr;gap:var(--s-7);border-top:0.5px solid var(--rule);max-width:1240px}
.empty-state .marker{font:500 11px/1.5 var(--f-mono);color:var(--ink-55);text-transform:uppercase;letter-spacing:0.12em}
.empty-state .body{max-width:60ch}
.empty-state .body h3{margin:0 0 var(--s-3);font:500 32px/1.15 var(--f-display);color:var(--ink-10);letter-spacing:-0.014em}
.empty-state .body p{margin:0 0 var(--s-4);font:400 17px/1.55 var(--f-body);color:var(--ink-25)}
.empty-state .filter-recap{padding:var(--s-3) var(--s-4);background:var(--ink-95);border-left:2px solid var(--amber);margin:var(--s-4) 0;display:flex;gap:var(--s-3);align-items:baseline;flex-wrap:wrap;font:400 14px/1.5 var(--f-body);color:var(--ink-25)}
.empty-state .filter-recap strong{color:var(--ink-10);font-weight:500}
.empty-state .filter-recap .pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:var(--ink-100);border:0.5px solid var(--rule-strong);font:500 12px/1 var(--f-mono);color:var(--ink-15);letter-spacing:0.04em}
.empty-state .filter-recap .pill span.x{color:var(--ink-55);font-size:14px;line-height:1}
.empty-state .actions{display:flex;gap:var(--s-3);flex-wrap:wrap;margin-top:var(--s-4)}
.empty-state .suggest{margin-top:var(--s-6);padding-top:var(--s-5);border-top:0.5px solid var(--rule)}
.empty-state .suggest h4{margin:0 0 var(--s-3);font:500 11px/1 var(--f-mono);color:var(--ink-55);letter-spacing:0.12em;text-transform:uppercase}
.empty-state .suggest-list{display:flex;flex-direction:column;gap:var(--s-2)}
.empty-state .suggest-list a{display:flex;justify-content:space-between;align-items:baseline;gap:var(--s-3);padding:var(--s-3) 0;border-bottom:0.5px solid var(--rule);font:500 16px/1.3 var(--f-display);color:var(--ink-15);letter-spacing:-0.005em;transition:color var(--d-fast) var(--ease-out)}
.empty-state .suggest-list a:hover{color:var(--ink-10)}
.empty-state .suggest-list a small{font:400 12px/1 var(--f-mono);color:var(--ink-55);letter-spacing:0.06em;text-transform:uppercase;flex-shrink:0}

@media (max-width: 1024px){
  .empty-state{grid-template-columns:1fr;gap:var(--s-3);padding:var(--s-7) var(--s-5)}
  .empty-state .body h3{font-size:24px}
}

.contact-side{display:flex;flex-direction:column;gap:var(--s-7);padding-left:var(--s-7);border-left:0.5px solid var(--rule)}
.contact-card{display:flex;flex-direction:column;gap:var(--s-3)}
.contact-card .marker{font:500 11px/1 var(--f-mono);color:var(--ink-55);letter-spacing:0.12em;text-transform:uppercase}
.contact-card h3{margin:0;font:500 22px/1.3 var(--f-display);color:var(--ink-10);letter-spacing:-0.005em}
.contact-card p{margin:0;font:400 14px/1.6 var(--f-body);color:var(--ink-25);max-width:36ch}
.contact-card a.contact-link{display:inline-flex;align-items:center;gap:var(--s-2);font:500 14px/1 var(--f-body);color:var(--ink-15);border-bottom:1px solid var(--amber);padding-bottom:2px;align-self:flex-start;transition:color var(--d-fast) var(--ease-out)}
.contact-card a.contact-link:hover{color:var(--amber-ink)}
.calendar-mock{margin-top:var(--s-3);background:var(--ink-95);padding:var(--s-4);border-radius:var(--r-2);display:flex;flex-direction:column;gap:var(--s-3)}
.calendar-mock .cm-head{display:flex;justify-content:space-between;align-items:center;font:500 12px/1 var(--f-mono);color:var(--ink-25);letter-spacing:0.04em}
.calendar-mock .cm-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.calendar-mock .cm-cell{aspect-ratio:1;border:0.5px solid transparent;border-radius:var(--r-1);display:flex;align-items:center;justify-content:center;font:400 11px/1 var(--f-mono);color:var(--ink-40)}
.calendar-mock .cm-cell.is-day{background:var(--ink-100);border-color:var(--rule);color:var(--ink-15)}
.calendar-mock .cm-cell.is-available{background:var(--ink-100);border-color:var(--amber);color:var(--ink-10)}
.calendar-mock .cm-cell.is-selected{background:var(--ink-10);color:var(--amber-soft);border-color:var(--ink-10)}
.calendar-mock .cm-foot{font:400 11px/1.4 var(--f-mono);color:var(--ink-55);padding-top:var(--s-2);border-top:0.5px solid var(--rule)}

/* ─────────────────────────────────────────────────────────────────
   CASE STUDIES INDEX
   ───────────────────────────────────────────────────────────────── */
.csindex-hero{padding:var(--s-10) var(--s-6) var(--s-7);max-width:1100px}
.csindex-hero h1{margin:0;font:500 72px/1.05 var(--f-display);letter-spacing:-0.022em;color:var(--ink-10);max-width:18ch}
.csindex-hero .lede{margin-top:var(--s-5);max-width:56ch;font:400 19px/1.55 var(--f-body);color:var(--ink-25)}
.csindex-filters{padding-block:var(--s-5);padding-inline:max(var(--s-6),calc(50vw - 720px + var(--s-6)));margin-inline:calc(50% - 50vw);border-top:0.5px solid var(--rule);border-bottom:0.5px solid var(--rule);background:var(--ink-95);display:flex;flex-wrap:wrap;gap:var(--s-3);align-items:center}
.csindex-filters .label{font:500 11px/1 var(--f-mono);color:var(--ink-55);letter-spacing:0.12em;text-transform:uppercase;margin-right:var(--s-3)}
.csindex-list{padding:0 var(--s-6) var(--s-9)}
.csindex-tile{display:grid;grid-template-columns:280px 1fr 200px;gap:var(--s-6);padding:var(--s-7) 0;border-top:1px solid var(--ink-15);align-items:start;transition:padding-left var(--d-base) var(--ease-out)}
.csindex-tile:hover{padding-left:var(--s-3)}
.csindex-tile:last-child{border-bottom:1px solid var(--ink-15)}
.csindex-tile .num{font:500 64px/0.95 var(--f-display);letter-spacing:-0.025em;color:var(--ink-10)}
.csindex-tile .num .accent{color:var(--amber)}
.csindex-tile .num .pos{color:var(--pos)}
.csindex-tile .num .neg{color:var(--neg)}
.csindex-tile .num .arrow{color:var(--ink-55);padding:0 6px;font-weight:400}
.csindex-tile .num small{display:block;font:500 11px/1.5 var(--f-mono);color:var(--ink-55);letter-spacing:0.04em;margin-top:var(--s-3);text-transform:uppercase}
.csindex-tile .body h3{margin:0 0 var(--s-3);font:500 24px/1.3 var(--f-display);color:var(--ink-10);letter-spacing:-0.008em;max-width:42ch}
.csindex-tile .body .meta{display:flex;gap:var(--s-3);align-items:center;margin-bottom:var(--s-3);flex-wrap:wrap}
.csindex-tile .body .meta .brand{font:500 13px/1 var(--f-body);color:var(--ink-15)}
.csindex-tile .body p{margin:0;font:400 15px/1.6 var(--f-body);color:var(--ink-25);max-width:52ch}
.csindex-tile .read{display:flex;flex-direction:column;justify-content:flex-start;align-items:flex-end;gap:var(--s-2);font:500 13px/1 var(--f-body);color:var(--ink-15);padding-top:var(--s-3)}
.csindex-tile .read .arrow{color:var(--amber);font-size:18px}
.csindex-tile .read small{font:500 11px/1.4 var(--f-mono);color:var(--ink-55);letter-spacing:0.04em;text-transform:uppercase}

/* ─────────────────────────────────────────────────────────────────
   INSIGHTS INDEX
   ───────────────────────────────────────────────────────────────── */
.insights-hero{padding:var(--s-10) var(--s-6) var(--s-7);max-width:1100px}
.insights-hero h1{margin:0;font:500 72px/1.05 var(--f-display);letter-spacing:-0.022em;color:var(--ink-10);max-width:18ch}
.insights-hero .lede{margin-top:var(--s-5);max-width:56ch;font:400 19px/1.55 var(--f-body);color:var(--ink-25)}
.insights-feature{padding-block:var(--s-7);padding-inline:max(var(--s-6),calc(50vw - 720px + var(--s-6)));margin-inline:calc(50% - 50vw);border-top:1px solid var(--ink-15);border-bottom:1px solid var(--rule)}
.insights-feature-grid{display:block;max-width:760px}
.insights-feature .thumb{aspect-ratio:4/3;background:var(--ink-95);background-image:repeating-linear-gradient(135deg,var(--ink-95) 0 8px,var(--ink-85) 8px 9px);border-radius:var(--r-2);display:flex;align-items:flex-end;padding:var(--s-4)}
.insights-feature .thumb-label{font:500 10px/1.2 var(--f-mono);color:var(--ink-55);text-transform:uppercase;letter-spacing:0.08em}
.insights-feature .body{display:flex;flex-direction:column;gap:var(--s-4);justify-content:center}
.insights-feature .meta{display:flex;gap:var(--s-3);align-items:center}
.insights-feature h2{margin:0;font:500 40px/1.15 var(--f-display);color:var(--ink-10);letter-spacing:-0.018em;max-width:18ch}
.insights-feature .dek{margin:0;font:400 17px/1.55 var(--f-body);color:var(--ink-25);max-width:48ch}
.insights-feature .byline{font:500 11px/1 var(--f-mono);color:var(--ink-40);letter-spacing:0.08em;text-transform:uppercase}

.insights-list{padding:var(--s-7) var(--s-6) var(--s-9)}
.insights-list-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--s-6) var(--s-7)}
.acard-more{display:inline-flex;align-items:baseline;gap:var(--s-2);font:500 13px/1 var(--f-body);color:var(--ink-15);border-bottom:1px solid var(--amber);padding-bottom:2px;align-self:flex-start;margin-top:var(--s-2);transition:color var(--d-fast) var(--ease-out)}
.acard:hover .acard-more{color:var(--amber-ink)}

/* ─────────────────────────────────────────────────────────────────
   ARTICLE TEMPLATE
   ───────────────────────────────────────────────────────────────── */
.article-hero{padding:var(--s-10) var(--s-6) var(--s-7);max-width:780px;margin:0 auto}
.article-hero .meta{display:flex;gap:var(--s-3);align-items:center;margin-bottom:var(--s-5)}
.article-hero .meta .chip{margin:0}
.article-hero h1{margin:0;font:500 56px/1.08 var(--f-display);letter-spacing:-0.022em;color:var(--ink-10)}
.article-hero .dek{margin-top:var(--s-5);font:400 19px/1.55 var(--f-body);color:var(--ink-25)}
.article-hero .byline{display:flex;justify-content:space-between;align-items:center;margin-top:var(--s-7);padding-top:var(--s-5);border-top:0.5px solid var(--rule);font:500 12px/1 var(--f-mono);color:var(--ink-40);letter-spacing:0.08em;text-transform:uppercase}
.article-hero .byline strong{color:var(--ink-15);font-weight:500}

.article-body{padding:var(--s-7) var(--s-6) var(--s-9);max-width:680px;margin:0 auto}
.article-body p{margin:0 0 var(--s-5);font:400 18px/1.7 var(--f-body);color:var(--ink-25);font-family:var(--f-display);font-weight:400}
.article-body p:first-of-type::first-letter{font-size:64px;line-height:0.9;float:left;padding:8px 12px 0 0;color:var(--ink-10);font-weight:500}
.article-body h2{margin:var(--s-7) 0 var(--s-4);font:500 32px/1.2 var(--f-display);color:var(--ink-10);letter-spacing:-0.012em}
.article-body h3{margin:var(--s-6) 0 var(--s-3);font:500 22px/1.3 var(--f-display);color:var(--ink-10);letter-spacing:-0.008em}
.article-body blockquote{margin:var(--s-6) 0;padding:0 var(--s-6);border-left:2px solid var(--amber);font:500 26px/1.4 var(--f-display);color:var(--ink-10);letter-spacing:-0.008em;font-style:italic}
.article-body code{font:500 14px/1 var(--f-mono);background:var(--ink-95);padding:2px 6px;border-radius:var(--r-1);color:var(--ink-15)}
.article-body pre{background:var(--ink-10);color:var(--ink-100);padding:var(--s-5);border-radius:var(--r-2);overflow-x:auto;margin:var(--s-5) 0}
.article-body pre code{background:transparent;color:var(--amber-soft);padding:0;font-size:13px;line-height:1.6}
.article-body figure{margin:var(--s-6) 0}
.article-body figure img,.article-body .figplaceholder{width:100%;background:var(--ink-95);background-image:repeating-linear-gradient(135deg,var(--ink-95) 0 8px,var(--ink-85) 8px 9px);aspect-ratio:16/9;border-radius:var(--r-2);display:flex;align-items:flex-end;padding:var(--s-4)}
.article-body figure figcaption{margin-top:var(--s-3);font:400 13px/1.55 var(--f-mono);color:var(--ink-55);letter-spacing:0.02em}
.article-body ul{margin:var(--s-4) 0;padding-left:0;list-style:none}
.article-body ul li{position:relative;padding:var(--s-2) 0 var(--s-2) var(--s-5);font:400 17px/1.65 var(--f-body);color:var(--ink-25);font-family:var(--f-display)}
.article-body ul li::before{content:'';position:absolute;left:0;top:18px;width:12px;height:1px;background:var(--amber)}
.article-body a{color:var(--ink-15);border-bottom:1px solid var(--amber);transition:color var(--d-fast) var(--ease-out)}
.article-body a:hover{color:var(--amber-ink)}

.article-footer{padding-block:var(--s-7);padding-inline:max(var(--s-6),calc(50vw - 720px + var(--s-6)));margin-inline:calc(50% - 50vw);background:var(--ink-95);border-top:1px solid var(--rule)}
.article-footer-grid{max-width:680px;margin:0 auto;display:flex;flex-direction:column;gap:var(--s-6)}
.article-share{display:flex;justify-content:space-between;align-items:center}
.article-share .label{font:500 11px/1 var(--f-mono);color:var(--ink-55);letter-spacing:0.12em;text-transform:uppercase}
.article-share .links{display:flex;gap:var(--s-3)}
.article-share .links a{font:500 13px/1 var(--f-body);color:var(--ink-15);border-bottom:1px solid var(--amber);padding-bottom:2px;transition:color var(--d-fast) var(--ease-out)}
.article-share .links a:hover{color:var(--amber-ink)}
.article-related{margin-top:var(--s-7);padding-top:var(--s-7);border-top:0.5px solid var(--rule)}
.article-related h4{margin:0 0 var(--s-5);font:500 14px/1 var(--f-mono);color:var(--ink-25);letter-spacing:0.06em;text-transform:uppercase}
.article-related-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-6)}
.article-related-tile{display:flex;flex-direction:column;gap:var(--s-2);padding:var(--s-5);background:var(--ink-100);border-radius:var(--r-2);transition:transform var(--d-base) var(--ease-out)}
.article-related-tile:hover{transform:translateY(-2px)}
.article-related-tile h5{margin:0;font:500 18px/1.3 var(--f-display);color:var(--ink-10);letter-spacing:-0.005em}
.article-related-tile .cap{font:500 11px/1 var(--f-mono);color:var(--ink-55);letter-spacing:0.04em;margin-top:var(--s-2)}

/* ─────────────────────────────────────────────────────────────────
   404
   ───────────────────────────────────────────────────────────────── */
.fourohfour{min-height:80vh;display:grid;place-items:center;padding:var(--s-9) var(--s-6)}
.fourohfour-card{display:flex;flex-direction:column;align-items:flex-start;gap:var(--s-5);max-width:600px}
.fourohfour-num{font:500 240px/0.9 var(--f-display);color:var(--ink-10);letter-spacing:-0.04em;margin-left:-12px}
.fourohfour-num .dot{color:var(--amber)}
.fourohfour h1{margin:0;font:500 40px/1.12 var(--f-display);color:var(--ink-10);letter-spacing:-0.018em;max-width:18ch}
.fourohfour p{margin:0;font:400 17px/1.6 var(--f-body);color:var(--ink-25);max-width:52ch}
.fourohfour .actions{display:flex;gap:var(--s-4);align-items:center;margin-top:var(--s-3)}
.fourohfour .suggestions{margin-top:var(--s-6);padding-top:var(--s-5);border-top:0.5px solid var(--rule);width:100%;display:flex;flex-direction:column;gap:var(--s-3)}
.fourohfour .suggestions .label{font:500 11px/1 var(--f-mono);color:var(--ink-55);letter-spacing:0.12em;text-transform:uppercase}
.fourohfour .suggestions ul{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:var(--s-2)}
.fourohfour .suggestions li a{display:flex;justify-content:space-between;align-items:center;padding:var(--s-3) 0;border-bottom:0.5px solid var(--rule);font:500 15px/1 var(--f-body);color:var(--ink-15);transition:color var(--d-fast) var(--ease-out)}
.fourohfour .suggestions li a .arrow{color:var(--amber)}
.fourohfour .suggestions li a:hover{color:var(--amber-ink)}

/* ─────────────────────────────────────────────────────────────────
   RESPONSIVE — new pages
   ───────────────────────────────────────────────────────────────── */
@media (max-width: 1024px){
  .about-hero{padding:var(--s-9) var(--s-5) var(--s-7)}
  .about-hero h1{font-size:56px}
  .values-band{padding:var(--s-8) var(--s-5)}
  .values-grid{grid-template-columns:1fr;gap:var(--s-5)}
  .bio-section,.timeline,.notgood-band{padding:var(--s-8) var(--s-5)}
  .bio-grid,.timeline-grid,.notgood-grid{grid-template-columns:1fr;gap:var(--s-3)}
  .contact-hero{padding:var(--s-9) var(--s-5) var(--s-6)}
  .contact-grid{grid-template-columns:1fr;gap:var(--s-7);padding:var(--s-6) var(--s-5) var(--s-8)}
  .contact-side{padding-left:0;border-left:0;border-top:0.5px solid var(--rule);padding-top:var(--s-6)}
  .csindex-hero,.insights-hero{padding:var(--s-9) var(--s-5) var(--s-6)}
  .csindex-tile{grid-template-columns:200px 1fr;gap:var(--s-5);padding:var(--s-6) 0}
  .csindex-tile .read{grid-column:1 / -1;flex-direction:row;justify-content:flex-start;align-items:center;padding-top:0}
  .insights-feature-grid{grid-template-columns:1fr;gap:var(--s-5)}
  .insights-list-grid{grid-template-columns:1fr;gap:0}
  .article-hero{padding:var(--s-9) var(--s-5) var(--s-6)}
  .article-hero h1{font-size:42px}
  .article-related-grid{grid-template-columns:1fr}
}

@media (max-width: 640px){
  .about-hero h1,.contact-hero h1,.csindex-hero h1,.insights-hero h1{font-size:38px;line-height:1.05}
  .about-hero .lede,.contact-hero .lede,.csindex-hero .lede,.insights-hero .lede{font-size:16px;margin-top:var(--s-4)}
  .value-card .num{font-size:42px}
  .value-card h3{font-size:20px}
  .bio-grid h2,.timeline-grid h2,.notgood-grid h2{font-size:28px}
  .timeline-item{grid-template-columns:1fr;gap:var(--s-2);padding:var(--s-4) 0}
  .timeline-item .year{padding-top:0}
  .contact-form .row{grid-template-columns:1fr;gap:var(--s-4)}
  .contact-form .submit-row{flex-direction:column;align-items:stretch;gap:var(--s-4)}
  .contact-form .submit-row .btn{width:100%;justify-content:center}
  .csindex-filters{padding:var(--s-4) var(--s-5);overflow-x:auto;flex-wrap:nowrap}
  .csindex-tile{grid-template-columns:1fr;gap:var(--s-3);padding:var(--s-5) 0}
  .csindex-tile .num{font-size:48px}
  .csindex-tile .body h3{font-size:20px}
  .insights-feature h2{font-size:30px}
  .article-hero h1{font-size:32px}
  .article-body{padding:var(--s-6) var(--s-5) var(--s-7)}
  .article-body p{font-size:17px}
  .article-body h2{font-size:26px;margin-top:var(--s-6)}
  .article-body blockquote{padding:0 var(--s-4);font-size:20px}
  .fourohfour-num{font-size:140px}
  .fourohfour h1{font-size:28px}
  .fourohfour .actions{flex-direction:column;align-items:stretch;width:100%}
  .fourohfour .actions .btn{width:100%;justify-content:center}
}

/* ─────────────────────────────────────────────────────────────────
   ACCESSIBILITY — added May 2026
   ───────────────────────────────────────────────────────────────── */

/* Skip-to-content link — visible on keyboard focus only */
.skip-link{
  position:absolute;
  top:-40px;
  left:8px;
  background:var(--ink-10);
  color:var(--ink-100);
  padding:10px 16px;
  border-radius:var(--r-2);
  font:500 13px/1 var(--f-body);
  z-index:1000;
  text-decoration:none;
  transition:top 0.15s ease;
}
.skip-link:focus,
.skip-link:focus-visible{
  top:8px;
  outline:2px solid var(--amber);
  outline-offset:2px;
}

/* Visible focus ring for keyboard users — never strip without replacement */
:focus{outline:none}
:focus-visible{
  outline:2px solid var(--amber);
  outline-offset:2px;
  border-radius:var(--r-1);
}
.btn:focus-visible,
.btn-link:focus-visible,
a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible{
  outline:2px solid var(--amber);
  outline-offset:3px;
}

/* Visually-hidden utility — for screen-reader-only text */
.sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

/* Reduced motion — respect user preference */
@media (prefers-reduced-motion: reduce){
  *,
  *::before,
  *::after{
    animation-duration:0.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:0.01ms !important;
    scroll-behavior:auto !important;
  }
}
