/* ============================================================
   ADVISORY MONKS CONSULTING — "QUIET AUTHORITY"
   Design system v3 · single stylesheet for all pages
   Editorial serif (Fraunces) · Inter · Spline Sans Mono
   Neutral paper · navy blue-charcoal bands · steel-blue accent
   ============================================================ */

/* ---- Fonts (self-hosted, variable, latin) ------------------ */
@font-face{font-family:'Fraunces';src:url('/fonts/Fraunces-Var.woff2') format('woff2');font-weight:300 700;font-style:normal;font-display:swap}
@font-face{font-family:'Fraunces';src:url('/fonts/Fraunces-Italic-Var.woff2') format('woff2');font-weight:300 700;font-style:italic;font-display:swap}
@font-face{font-family:'Inter';src:url('/fonts/Inter-Var.woff2') format('woff2');font-weight:400 700;font-style:normal;font-display:swap}
@font-face{font-family:'Spline Sans Mono';src:url('/fonts/SplineSansMono-Var.woff2') format('woff2');font-weight:400 500;font-style:normal;font-display:swap}

/* ---- Tokens ------------------------------------------------- */
:root{
  /* canvas — clean neutral off-white (no warm/brown, no blue tinge) */
  --paper:#FAFAFA;
  --paper-dim:#F1F1F2;
  --paper-deep:#E7E7E9;
  /* ink (dark bands) — brand navy #061C33 (same blue as the CTA) */
  --band:#061C33;
  --band-2:#0B2A4A;
  /* text — neutral grays */
  --text:#1A1B1E;
  --mid:#585A5F;
  --faint:#8B8D92;
  /* lines */
  --line:#E6E6E8;
  --line-strong:#CFCFD2;
  /* brand blue — deep navy (Pantone-spec #061C33), matches the logo + footer */
  --accent:#061C33;
  --accent-deep:#123A63;
  --accent-tint:#EDF2F7;
  /* on dark (navy band) */
  --d-text:#EEF0F3;
  --d-mid:#9BA6B4;
  --d-faint:#6A7480;
  --d-line:rgba(238,240,243,.13);
  --d-accent:#B6D2EA;
  /* type */
  /* display + body now share one clean grotesque (Inter); serif retired */
  --serif:'Inter',system-ui,-apple-system,'Segoe UI',sans-serif;
  --sans:'Inter',system-ui,-apple-system,'Segoe UI',sans-serif;
  --mono:'Spline Sans Mono',ui-monospace,'SF Mono',monospace;
  /* legacy aliases (old inline styles on a few pages) */
  --text-line:#E6E6E8; --text-line-strong:#CFCFD2;
  --text-strong:#1A1B1E; --text-mid:#585A5F; --text-faint:#8B8D92;
  --paper-deeper:#E7E7E9; --ivory:#FAFAFA;
  --blue:#061C33; --blue-deep:#123A63; --blue-soft:#6E8DB0;
  --gold:#061C33; --gold-tint:#EDF2F7; --blue-tint:#EDF2F7;
  /* misc */
  --ease:cubic-bezier(.22,.61,.36,1);
  --rad:3px;
  --rad-lg:5px;
  --wrap:1200px;
  --gut:clamp(20px,4vw,48px);
}

/* ---- Reset / base ------------------------------------------- */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
html:focus-within{scroll-behavior:smooth}
body{
  background:var(--paper);color:var(--text);
  font-family:var(--sans);font-size:16px;line-height:1.65;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  font-feature-settings:"liga","kern";
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;background:none;border:0;color:inherit}
ul,ol{list-style:none}
::selection{background:var(--accent);color:#fff}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:2px}
.wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:var(--gut)}
.skip{position:absolute;left:-9999px;top:0;background:var(--text);color:var(--paper);padding:10px 18px;z-index:200}
.skip:focus{left:12px;top:12px}

/* ---- Type utilities ------------------------------------------ */
.eyebrow,.section-num,.pv-eyebrow,.hero-eyebrow,.ins-eyebrow,.scenario-label,.sp-eyebrow{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--sans);font-size:11px;font-weight:600;
  letter-spacing:.28em;text-transform:uppercase;color:var(--accent);
}
.serif-display{font-family:var(--serif);font-weight:360;letter-spacing:-.02em;line-height:1.05}
em.tilt,.serif-display em,h1 em,h2 em{font-style:italic;font-weight:400;color:var(--accent)}

/* ============================================================
   NAV RAIL
   ============================================================ */
.rail{
  position:fixed;inset:0 0 auto;z-index:90;height:72px;
  display:flex;align-items:center;justify-content:space-between;
  padding-inline:var(--gut);
  background:color-mix(in srgb,var(--paper) 86%,transparent);
  -webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
  transition:background .3s,border-color .3s;
}
.rail-l a{display:flex;align-items:baseline;gap:12px}
.brandmark{font-family:var(--serif);font-weight:560;font-size:21px;letter-spacing:-.012em;color:var(--text);white-space:nowrap}
.brandmark .sl{font-style:italic;color:var(--accent);font-weight:420}
.brandsub{font-family:var(--mono);font-size:9px;font-weight:500;letter-spacing:.4em;text-transform:uppercase;color:var(--faint)}
.rail-c{display:flex;align-items:center;gap:clamp(16px,2.4vw,34px)}
.rail-c a{
  position:relative;font-size:13.5px;font-weight:500;color:var(--mid);
  padding:6px 0;letter-spacing:.01em;transition:color .22s;
}
.rail-c a::after{
  content:"";position:absolute;left:0;right:100%;bottom:0;height:1.5px;
  background:var(--accent);transition:right .32s var(--ease);
}
.rail-c a:hover,.rail-c a.active{color:var(--text)}
.rail-c a:hover::after,.rail-c a.active::after{right:0}
.rail-r{display:flex;align-items:center;gap:14px}
.rail-r .wa{color:var(--mid);transition:color .2s}
.rail-r .wa:hover{color:#1FA855}
.rail-r .wa svg{width:21px;height:21px;fill:currentColor}
.rail-r .cta,a.nav-cta{
  font-size:13px;font-weight:600;letter-spacing:.01em;
  background:var(--text);color:var(--paper);
  padding:11px 20px;border-radius:var(--rad);border:1px solid var(--text);
  transition:background .22s,color .22s;white-space:nowrap;
}
.rail-r .cta:hover{background:var(--accent);border-color:var(--accent);color:#fff}

/* mobile drawer (checkbox pattern preserved) */
.nav-toggle-cb{display:none}
.nav-toggle{display:none;width:40px;height:40px;place-items:center;color:var(--text);cursor:pointer}
.nav-toggle svg{width:22px;height:22px}
@media(max-width:960px){
  .rail{height:62px}
  .rail-c{
    position:fixed;inset:62px 0 auto;flex-direction:column;align-items:stretch;gap:0;
    background:var(--paper);border-bottom:1px solid var(--line);
    padding:8px 0 14px;display:none;box-shadow:0 30px 60px -30px rgba(23,29,38,.25);
  }
  .rail-c a{padding:13px var(--gut);font-size:15px;border-top:1px solid var(--line)}
  .rail-c a::after{display:none}
  .nav-toggle{display:grid}
  .nav-toggle-cb:checked ~ .rail-c{display:flex}
  .rail-r .cta{display:none}
  .brandsub{display:none}
}

/* ============================================================
   FOOTER
   ============================================================ */
.footer,.foot{background:var(--band);color:var(--d-mid)}
.footer-inner{max-width:var(--wrap);margin-inline:auto;padding:clamp(28px,3.5vw,44px) var(--gut) 28px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:48px;padding-bottom:52px;border-bottom:1px solid var(--d-line)}
@media(max-width:960px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.footer-grid{grid-template-columns:1fr}}
.footer-brand-mark{font-family:var(--serif);font-weight:500;font-size:22px;letter-spacing:-.01em;color:var(--d-text);margin-bottom:14px}
.footer-brand-desc{font-size:13.5px;line-height:1.7;color:var(--d-mid);max-width:34ch}
.footer-col h4{
  font-family:var(--sans);font-size:10.5px;font-weight:600;letter-spacing:.26em;
  text-transform:uppercase;color:var(--d-accent);margin-bottom:18px;
}
.footer-col ul{display:grid;gap:9px}
.footer-col a{font-size:13.5px;color:var(--d-mid);transition:color .2s}
.footer-col a:hover{color:var(--d-text)}
.footer-col li{font-size:13.5px;color:var(--d-mid)}
.footer-legal{display:flex;flex-wrap:wrap;gap:8px 14px;align-items:center;padding:26px 0 0;font-size:12px;color:var(--d-faint)}
.footer-legal a{color:var(--d-mid)}
.footer-legal a:hover{color:var(--d-text)}
.legal-sep{color:var(--d-faint)}
.footer-bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:8px 20px;margin-top:18px;font-size:12px;color:var(--d-faint)}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn,.btn-primary,.btn-ghost,.cta-btn-primary,.cta-btn-secondary,.team-link,.consent-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:11px;
  font-family:var(--sans);font-size:14px;font-weight:600;letter-spacing:.01em;
  padding:15px 28px;border-radius:var(--rad);
  transition:background .22s,color .22s,border-color .22s,transform .18s;
}
.btn-primary,.cta-btn-primary{background:var(--text);color:var(--paper);border:1px solid var(--text)}
.btn-primary:hover,.cta-btn-primary:hover{background:var(--accent);border-color:var(--accent);color:#fff;transform:translateY(-1px)}
.btn-primary .arr{transition:transform .22s var(--ease)}
.btn-primary:hover .arr{transform:translateX(4px)}
.btn-ghost,.cta-btn-secondary{background:transparent;color:var(--text);border:1px solid var(--line-strong)}
.btn-ghost:hover,.cta-btn-secondary:hover{border-color:var(--text)}
/* on dark bands */
.cta-section .cta-btn-primary{background:var(--paper);color:var(--text);border-color:var(--paper)}
.cta-section .cta-btn-primary:hover{background:transparent;color:var(--d-text);border-color:var(--d-mid)}
.cta-section .cta-btn-secondary{color:var(--d-text);border-color:var(--d-line)}
.cta-section .cta-btn-secondary:hover{border-color:var(--d-text)}

/* ============================================================
   HOME — HERO (dark editorial band)
   ============================================================ */
.hero-home{
  position:relative;background:linear-gradient(168deg,var(--band) 0%,var(--band-2) 100%);
  color:var(--d-text);padding:calc(72px + clamp(32px,4.5vw,60px)) 0 0;overflow:hidden;
}
.hero-home::before{ /* faint radial light, top-right */
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(1000px 520px at 82% -8%,rgba(147,178,208,.13),transparent 64%);
}
.hero-home::after{ /* engraved rule texture, bottom */
  content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--d-line);
}
.hero-home .wrap{position:relative}
.hero-kick{display:flex;align-items:center;gap:18px;margin-bottom:clamp(18px,2.5vw,28px)}
.hero-kick .k{font-size:10.5px;font-weight:600;letter-spacing:.3em;text-transform:uppercase;color:var(--d-accent);white-space:nowrap}
.hero-kick .ln{flex:1;height:1px;background:var(--d-line)}
@media(max-width:700px){
  .hero-kick .k:last-child{display:none}
  .hero-kick .k{font-size:9px;letter-spacing:.22em;white-space:normal;line-height:1.7}
}
.hero-home h1{
  font-family:var(--serif);font-weight:340;
  font-size:clamp(40px,5.4vw,76px);line-height:1.06;letter-spacing:-.02em;
  max-width:21ch;text-wrap:balance;color:var(--d-text);
}
.hero-home h1 em{font-style:italic;font-weight:380;color:var(--d-accent)}
.hero-cols{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(40px,6vw,90px);align-items:end;margin-top:clamp(18px,2.5vw,28px);padding-bottom:clamp(24px,3vw,38px)}
@media(max-width:960px){.hero-cols{grid-template-columns:1fr}}
.hero-deck{font-size:clamp(15.5px,1.25vw,17.5px);line-height:1.75;color:var(--d-mid);max-width:56ch}
.hero-deck strong{color:var(--d-text);font-weight:600}
.hero-ctas{display:flex;align-items:center;flex-wrap:wrap;gap:14px;margin-top:30px}
.hero-ctas .meta{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--d-faint)}
.hero-home .btn-primary{background:var(--paper);color:var(--text);border-color:var(--paper)}
.hero-home .btn-primary:hover{background:transparent;color:var(--d-text);border-color:var(--d-mid)}
.hero-home .btn-ghost{color:var(--d-text);border-color:var(--d-line)}
.hero-home .btn-ghost:hover{border-color:var(--d-text)}

/* engagement brief card (right column) */
.brief-card{
  position:relative;border:1px solid var(--d-line);border-radius:var(--rad-lg);
  background:rgba(240,241,238,.035);padding:24px 26px 10px;
  -webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);
}
.brief-card::before{content:"";position:absolute;inset:0 auto auto 0;width:46px;height:2px;background:var(--d-accent)}
.brief-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.brief-head .t{font-size:10px;font-weight:600;letter-spacing:.26em;text-transform:uppercase;color:var(--d-mid)}
.brief-count{font-family:var(--mono);font-size:11px;color:var(--d-accent)}
.brief-row{display:flex;justify-content:space-between;gap:18px;padding:11px 0;border-top:1px solid var(--d-line)}
.brief-row .k{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--d-faint);padding-top:2px;white-space:nowrap}
.brief-row .v{font-size:13px;line-height:1.55;color:var(--d-text);text-align:right;max-width:34ch}
.brief-row .v.em{color:var(--d-accent);font-family:var(--mono);font-size:12px}
.brief-foot{display:flex;justify-content:space-between;align-items:center;padding:12px 0 14px;border-top:1px solid var(--d-line)}
.brief-nav{display:flex;gap:8px}
.brief-nav button{
  width:30px;height:30px;border:1px solid var(--d-line);border-radius:50%;
  display:grid;place-items:center;color:var(--d-mid);transition:.2s;
}
.brief-nav button:hover{border-color:var(--d-accent);color:var(--d-text)}
.brief-nav svg{width:14px;height:14px}
.brief-tagline{font-family:var(--mono);font-size:10.5px;color:var(--d-faint);letter-spacing:.04em}
.brief-card .fade{transition:opacity .3s ease}
.brief-card .fade.out{opacity:0}

/* ledger strip (light, under hero) */
.ledger{border-bottom:1px solid var(--line);background:var(--paper)}
.ledger-in{display:grid;grid-template-columns:repeat(5,1fr)}
@media(max-width:960px){.ledger-in{grid-template-columns:repeat(2,1fr)}.ledger-cell:nth-child(5){display:none}}
.ledger-cell{padding:26px 28px 28px;border-right:1px solid var(--line)}
.ledger-cell:first-child{padding-left:0}
.ledger-cell:last-child{border-right:0}
@media(max-width:960px){.ledger-cell{padding:20px 18px}.ledger-cell:first-child{padding-left:18px}}
.ledger-k{font-size:10px;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--faint);margin-bottom:8px}
.ledger-v{font-family:var(--serif);font-weight:440;font-size:clamp(22px,2vw,28px);letter-spacing:-.01em;color:var(--text);font-variant-numeric:lining-nums}
.ledger-v .u{font-style:italic;font-size:.62em;color:var(--accent);margin-left:1px}
.ledger-s{font-size:12px;color:var(--mid);margin-top:3px}

/* ============================================================
   HOME — SECTIONS
   ============================================================ */
.section{padding-block:clamp(32px,4vw,54px)}
.section.tint{background:var(--paper-dim);border-block:1px solid var(--line)}
.s-head{display:grid;grid-template-columns:1.2fr .8fr;gap:40px;align-items:end;margin-bottom:clamp(18px,2.5vw,28px)}
@media(max-width:820px){.s-head{grid-template-columns:1fr;gap:16px}}
.s-head .eyebrow::before{content:"";width:34px;height:1px;background:var(--accent)}
.s-display,.section-title{
  font-family:var(--serif);font-weight:360;
  font-size:clamp(30px,3.4vw,48px);line-height:1.08;letter-spacing:-.018em;
  margin-top:16px;text-wrap:balance;color:var(--text);
}
.s-deck{font-size:15px;line-height:1.7;color:var(--mid);max-width:38ch;justify-self:end;padding-bottom:6px}
@media(max-width:820px){.s-deck{justify-self:start}}

/* starting points (#who) */
.sp-grid{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--text)}
@media(max-width:960px){.sp-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.sp-grid{grid-template-columns:1fr}}
.sp-card{
  position:relative;padding:30px 26px 70px;border-bottom:1px solid var(--line);
  border-right:1px solid var(--line);background:transparent;transition:background .25s;
}
.sp-card:last-child{border-right:0}
@media(max-width:960px){.sp-card:nth-child(2n){border-right:0}}
@media(max-width:560px){.sp-card{border-right:0}}
.sp-card:hover{background:var(--accent-tint)}
.sp-eyebrow{font-size:10px;letter-spacing:.22em;color:var(--accent)}
.sp-title{font-family:var(--serif);font-weight:480;font-size:21.5px;line-height:1.25;letter-spacing:-.012em;margin:14px 0 10px;color:var(--text)}
.sp-desc{font-size:13.5px;line-height:1.65;color:var(--mid)}
.sp-go{
  position:absolute;left:26px;bottom:24px;display:inline-flex;align-items:center;gap:8px;
  font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);transition:.25s;
}
.sp-card:hover .sp-go{color:var(--accent);gap:12px}

/* practice index (#practices) */
.aud-group{margin-bottom:clamp(17px,2.5vw,26px)}
.aud-group:last-child{margin-bottom:0}
.aud-head{display:flex;align-items:baseline;gap:18px;margin-bottom:6px}
.aud-title{font-size:11px;font-weight:600;letter-spacing:.26em;text-transform:uppercase;color:var(--accent);white-space:nowrap}
.aud-desc{font-size:13px;color:var(--faint);display:none}
.aud-ln{flex:1;height:1px;background:var(--line);transform:translateY(-3px)}
.index{border-top:1px solid var(--text)}
.aud-group .index{border-top:none}
.index-row{
  position:relative;display:grid;grid-template-columns:74px 290px 1fr auto;gap:28px;align-items:baseline;
  padding:21px 0;border-bottom:1px solid var(--line);
}
@media(max-width:960px){.index-row{grid-template-columns:54px 1fr auto}.idx-desc{display:none}}
@media(max-width:560px){.index-row{grid-template-columns:44px 1fr}.idx-for{display:none}}
.index-row::before{
  content:"";position:absolute;left:0;bottom:-1px;width:0;height:1.5px;
  background:var(--accent);transition:width .42s var(--ease);
}
.index-row:hover::before{width:100%}
.idx-num{font-family:var(--mono);font-size:11.5px;color:var(--faint);letter-spacing:.06em}
.idx-name{font-family:var(--serif);font-weight:470;font-size:clamp(19px,1.85vw,23px);letter-spacing:-.012em;color:var(--text);transition:color .25s,transform .3s var(--ease)}
.index-row:hover .idx-name{color:var(--accent);transform:translateX(5px)}
.idx-desc{font-size:13.5px;line-height:1.6;color:var(--mid)}
.idx-for{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);white-space:nowrap;transition:color .25s}
.index-row:hover .idx-for{color:var(--text)}

/* principles (#trust) */
.principles{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,3.5vw,44px)}
@media(max-width:820px){.principles{grid-template-columns:1fr}}
.principle{padding-top:24px;border-top:2px solid var(--text)}
.principle .p-k{font-family:var(--mono);font-size:11.5px;letter-spacing:.14em;color:var(--accent)}
.principle h3{font-family:var(--serif);font-weight:480;font-size:21px;letter-spacing:-.012em;margin:14px 0 9px;color:var(--text)}
.principle p{font-size:14px;line-height:1.7;color:var(--mid)}

/* outcomes */
.outcomes{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:820px){.outcomes{grid-template-columns:1fr}}
.outcome{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--rad-lg);
  padding:30px 28px;display:flex;flex-direction:column;transition:transform .28s var(--ease),box-shadow .28s,border-color .28s;
}
.outcome:hover{transform:translateY(-4px);box-shadow:0 26px 50px -30px rgba(23,29,38,.3);border-color:var(--line-strong)}
.o-metric{font-family:var(--serif);font-weight:460;font-size:clamp(32px,3vw,42px);letter-spacing:-.02em;color:var(--text);font-variant-numeric:lining-nums}
.outcome p{font-size:14px;line-height:1.7;color:var(--mid);margin:14px 0 18px}
.o-tag{margin-top:auto;font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent)}
.cred-strip{display:flex;flex-wrap:wrap;gap:9px 12px;margin-top:34px;padding-top:26px;border-top:1px solid var(--line)}
.cred-strip span{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.05em;text-transform:uppercase;
  color:var(--mid);border:1px solid var(--line);border-radius:999px;padding:7px 14px;background:var(--paper);
}

/* dark band — quote + stats (homepage) */
.band-dark{background:linear-gradient(160deg,var(--band),var(--band-2));color:var(--d-text);position:relative;overflow:hidden}
.band-dark::before{content:"";position:absolute;inset:0;background:radial-gradient(820px 380px at 88% -10%,rgba(147,178,208,.12),transparent 62%);pointer-events:none}
.band-dark .wrap{position:relative}
.band-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(40px,7vw,100px);align-items:center}
@media(max-width:880px){.band-grid{grid-template-columns:1fr}}
.band-q{font-family:var(--serif);font-weight:330;font-style:italic;font-size:clamp(24px,2.5vw,34px);line-height:1.34;letter-spacing:-.012em}
.band-q em{color:var(--d-accent)}
.band-attr{margin-top:24px;font-size:10.5px;font-weight:600;letter-spacing:.26em;text-transform:uppercase;color:var(--d-faint)}
.stat-list{border-top:1px solid var(--d-line)}
.stat{display:flex;align-items:baseline;justify-content:space-between;gap:20px;padding:19px 0;border-bottom:1px solid var(--d-line)}
.stat-k{font-size:13.5px;color:var(--d-mid)}
.stat-v{font-family:var(--serif);font-weight:420;font-size:clamp(26px,2.4vw,32px);color:var(--d-text);font-variant-numeric:lining-nums;white-space:nowrap}
.stat-v .u{font-style:italic;font-size:.6em;color:var(--d-accent)}

/* voices / testimonials */
.tgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:980px){.tgrid{grid-template-columns:1fr 1fr}}
@media(max-width:640px){.tgrid{grid-template-columns:1fr}}
.tcard{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--rad-lg);
  padding:26px 26px 22px;display:flex;flex-direction:column;
  transition:transform .28s var(--ease),box-shadow .28s;
}
.tcard:hover{transform:translateY(-3px);box-shadow:0 24px 44px -30px rgba(23,29,38,.28)}
.tcard blockquote{font-family:var(--serif);font-weight:380;font-size:16px;line-height:1.55;letter-spacing:-.005em;color:var(--text)}
.tcard figcaption{margin-top:auto;padding-top:16px}
.tcard .t-name{display:block;font-weight:600;font-size:13.5px;color:var(--text)}
.tcard .t-role{display:block;font-size:12px;color:var(--faint);margin-top:3px;line-height:1.5}
.t-more{
  display:inline-flex;align-items:center;gap:8px;margin-top:26px;
  font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);
  border-bottom:1px solid var(--line-strong);padding-bottom:3px;transition:.2s;
}
.t-more:hover{border-color:var(--accent);gap:12px}

/* process */
.proc{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--text)}
@media(max-width:960px){.proc{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.proc{grid-template-columns:1fr}}
.p-step{padding:28px 26px 34px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);position:relative}
.p-step:last-child{border-right:0}
@media(max-width:960px){.p-step:nth-child(2n){border-right:0}}
@media(max-width:560px){.p-step{border-right:0}}
.p-num{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent)}
.p-title{font-family:var(--serif);font-weight:480;font-size:20px;letter-spacing:-.01em;margin:16px 0 9px;color:var(--text)}
.p-desc{font-size:13.5px;line-height:1.68;color:var(--mid)}

/* pricing */
.pbar{display:flex;align-items:center;gap:0;margin-bottom:34px;border:1px solid var(--line-strong);border-radius:var(--rad);overflow:hidden;width:max-content}
.pbar-btn{
  font-size:12.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  padding:11px 22px;color:var(--mid);background:var(--paper);transition:.2s;
}
.pbar-btn + .pbar-btn{border-left:1px solid var(--line-strong)}
.pbar-btn.active{background:var(--text);color:var(--paper)}
.pbar-meta{margin-left:18px;font-size:12.5px;color:var(--faint)}
@media(max-width:640px){.pbar{width:100%}.pbar-btn{flex:1;text-align:center}}
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;align-items:stretch}
@media(max-width:960px){.price-grid{grid-template-columns:1fr}}
.price-card{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--rad-lg);
  padding:30px 28px;display:flex;flex-direction:column;position:relative;
  transition:transform .28s var(--ease),box-shadow .28s,border-color .28s;
}
.price-card:hover{transform:translateY(-4px);box-shadow:0 28px 54px -32px rgba(23,29,38,.32)}
.price-card[hidden]{display:none}
.price-badge{
  position:absolute;top:-11px;left:26px;font-family:var(--mono);font-size:10px;
  letter-spacing:.16em;text-transform:uppercase;background:var(--accent);color:#fff;
  padding:4px 12px;border-radius:999px;
}
.price-name{font-family:var(--serif);font-weight:500;font-size:21px;letter-spacing:-.01em;color:var(--text)}
.price-amt{font-family:var(--serif);font-weight:420;font-size:clamp(30px,2.8vw,38px);letter-spacing:-.018em;margin:14px 0 6px;color:var(--text);font-variant-numeric:lining-nums}
.price-amt .per{font-size:14px;font-style:italic;color:var(--faint);font-weight:380;letter-spacing:0}
.price-desc{font-size:13.5px;line-height:1.65;color:var(--mid);padding-bottom:18px;border-bottom:1px solid var(--line)}
.price-feat{display:grid;gap:0;margin:6px 0 24px}
.price-feat li{
  position:relative;font-size:13.5px;line-height:1.55;color:var(--mid);
  padding:9px 0 9px 24px;border-bottom:1px solid var(--line);
}
.price-feat li:last-child{border-bottom:0}
.price-feat li::before{content:"";position:absolute;left:4px;top:16px;width:6px;height:6px;background:var(--accent);transform:rotate(45deg)}
.price-foot{margin-top:auto;font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);margin-bottom:16px}
.price-card .btn-ghost{width:100%}
.price-card.featured{background:linear-gradient(165deg,var(--band),var(--band-2));border-color:var(--band);color:var(--d-text)}
.price-card.featured .price-name,.price-card.featured .price-amt{color:var(--d-text)}
.price-card.featured .price-amt .per{color:var(--d-faint)}
.price-card.featured .price-desc{color:var(--d-mid);border-color:var(--d-line)}
.price-card.featured .price-feat li{color:var(--d-mid);border-color:var(--d-line)}
.price-card.featured .price-feat li::before{background:var(--d-accent)}
.price-card.featured .price-foot{color:var(--d-faint)}
.price-card.featured .btn-ghost{color:var(--d-text);border-color:var(--d-line)}
.price-card.featured .btn-ghost:hover{border-color:var(--d-text)}
.price-custom{
  margin-top:22px;border:1px solid var(--line);border-radius:var(--rad-lg);
  padding:30px 30px;display:grid;grid-template-columns:1fr auto;gap:26px;align-items:center;background:var(--paper);
}
@media(max-width:820px){.price-custom{grid-template-columns:1fr}}
.price-custom-h{font-family:var(--serif);font-weight:460;font-size:21px;letter-spacing:-.01em;color:var(--text);margin-bottom:8px}
.price-custom p{font-size:13.5px;line-height:1.7;color:var(--mid);max-width:78ch}

/* about */
.about-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(40px,6vw,80px)}
@media(max-width:880px){.about-grid{grid-template-columns:1fr}}
.about-body p{font-size:15px;line-height:1.8;color:var(--mid);margin-bottom:1.2em;max-width:62ch}
.about-body p:first-child{
  font-family:var(--serif);font-weight:400;font-size:clamp(17px,1.6vw,20px);
  line-height:1.6;color:var(--text);
}
.about-body p strong{color:var(--text);font-weight:600}
.about-stats{display:grid;grid-template-columns:1fr 1fr;align-content:start;border-top:1px solid var(--text)}
.about-stat{padding:20px 18px 22px;border-bottom:1px solid var(--line)}
.about-stat:nth-child(odd){border-right:1px solid var(--line)}
.about-stat-val{font-family:var(--serif);font-weight:440;font-size:clamp(24px,2.2vw,30px);letter-spacing:-.015em;color:var(--text);font-variant-numeric:lining-nums}
.about-stat-key{font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--faint);margin-top:6px}

/* FAQ */
.faq{border-top:1px solid var(--text);max-width:860px}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{
  position:relative;width:100%;text-align:left;
  font-family:var(--serif);font-weight:470;font-size:clamp(17px,1.6vw,20px);
  letter-spacing:-.008em;color:var(--text);
  padding:22px 54px 22px 0;cursor:pointer;transition:color .2s;
}
.faq-q:hover{color:var(--accent)}
.faq-q::after{
  content:"";position:absolute;right:6px;top:50%;width:12px;height:12px;
  border-right:1.5px solid var(--faint);border-bottom:1.5px solid var(--faint);
  transform:translateY(-70%) rotate(45deg);transition:transform .3s var(--ease);
}
.faq-item.open .faq-q::after{transform:translateY(-30%) rotate(-135deg)}
.faq-a{
  font-size:14.5px;line-height:1.75;color:var(--mid);max-width:70ch;
  max-height:0;overflow:hidden;transition:max-height .45s var(--ease),padding .3s;
}
.faq-item.open .faq-a{max-height:420px;padding-bottom:26px}
/* no-JS fallback: keep answers visible until JS marks the list */
.faq:not(.faq-js) .faq-a{max-height:none;padding-bottom:26px}

/* contact */
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(40px,6vw,80px)}
@media(max-width:880px){.contact-grid{grid-template-columns:1fr}}
.contact-side{display:grid;gap:0;align-content:start;border-top:1px solid var(--text)}
.contact-item{padding:20px 0;border-bottom:1px solid var(--line)}
.contact-item .k{font-size:10.5px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:7px}
.contact-item .v{font-family:var(--serif);font-weight:440;font-size:18px;color:var(--text);letter-spacing:-.005em}
.contact-item .v a:hover{color:var(--accent)}
.contact-item .s{font-size:12.5px;color:var(--faint);margin-top:4px;line-height:1.6}
.contact-form{display:grid;gap:16px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:560px){.form-row{grid-template-columns:1fr}}
.field label{display:block;font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--mid);margin-bottom:8px}
.field input,.field select,.field textarea{
  width:100%;font-family:var(--sans);font-size:14.5px;color:var(--text);
  background:var(--paper);border:1px solid var(--line-strong);border-radius:var(--rad);
  padding:13px 14px;transition:border-color .2s,box-shadow .2s;
}
.field textarea{min-height:120px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-tint)}
.field ::placeholder{color:var(--faint)}
.form-status{display:none;font-size:13.5px;padding:13px 16px;border-radius:var(--rad);background:#FBF0EC;color:#8A4630;border:1px solid #EBD4C9}
.form-status.show{display:block}
.form-status.ok{background:#EDF4EE;color:#2F6440;border-color:#D2E4D6}
.form-foot{font-size:12px;color:var(--faint);line-height:1.6}

/* CTA band (shared) */
.cta-section{
  position:relative;background:linear-gradient(160deg,var(--band),var(--band-2));
  color:var(--d-text);padding-block:clamp(36px,4.5vw,58px);text-align:center;overflow:hidden;
}
.cta-section::before{content:"";position:absolute;inset:0;background:radial-gradient(900px 420px at 50% 120%,rgba(147,178,208,.14),transparent 62%);pointer-events:none}
.cta-section>*{position:relative}
.cta-section .section-num{
  display:inline-flex;font-size:10.5px;font-weight:600;letter-spacing:.3em;
  text-transform:uppercase;color:var(--d-accent);
}
.cta-section h2{
  font-family:var(--serif);font-weight:340;font-size:clamp(32px,4.2vw,58px);
  line-height:1.08;letter-spacing:-.02em;color:var(--d-text);
  max-width:22ch;margin:22px auto 16px;text-wrap:balance;padding-inline:var(--gut);
}
.cta-section h2 em{font-style:italic;color:var(--d-accent)}
.cta-section p{font-size:15px;line-height:1.7;color:var(--d-mid);max-width:54ch;margin:0 auto 34px;padding-inline:var(--gut)}
.cta-row{display:flex;justify-content:center;flex-wrap:wrap;gap:14px}

/* ============================================================
   INTERIOR PAGES (practices / page-view / articles)
   ============================================================ */
main{display:block}
.crumb{display:flex;flex-wrap:wrap;gap:9px;align-items:center;font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--faint)}
.crumb a:hover{color:var(--accent)}
.crumb .sep{color:var(--line-strong)}
.crumb .current{color:var(--mid)}

/* practice hero — light editorial */
.hero{padding:calc(72px + clamp(20px,3vw,36px)) 0 clamp(20px,2.5vw,30px)}
.hero,.section,.cta-section,.pn-nav{display:block}
.hero-num{
  font-family:var(--mono);font-size:12px;letter-spacing:.1em;color:var(--faint);
  margin:34px 0 10px;
}
.hero-eyebrow{margin-bottom:18px}
.hero h1{
  font-family:var(--serif);font-weight:340;font-size:clamp(36px,4.6vw,64px);
  line-height:1.06;letter-spacing:-.02em;color:var(--text);max-width:20ch;text-wrap:balance;
}
.hero-lede{
  font-size:clamp(15.5px,1.3vw,17.5px);line-height:1.75;color:var(--mid);
  max-width:64ch;margin-top:22px;
}
.hero .wrap::after{content:"";display:block;margin-top:clamp(36px,5vw,54px);height:1px;background:var(--line)}

/* numbered sections */
.section .section-num{margin-bottom:14px}
.section-rule{height:1px;background:var(--line);margin:18px 0 30px;position:relative}
.section-rule::before{content:"";position:absolute;left:0;top:0;width:64px;height:1.5px;background:var(--accent)}
#what>p{max-width:680px;font-size:15.5px;line-height:1.8;color:var(--mid);margin-bottom:1.1em}
#what>p:first-of-type{font-family:var(--serif);font-weight:400;font-size:clamp(18px,1.8vw,21px);line-height:1.6;color:var(--text);margin-bottom:24px}
#what h3{font-family:var(--serif);font-weight:480;font-size:19px;color:var(--text);letter-spacing:-.01em;margin:28px 0 4px;max-width:720px}
.what-list{max-width:720px;margin:8px 0 18px}
.what-list li{
  position:relative;padding:12px 0 12px 26px;border-top:1px solid var(--line);
  font-size:14.5px;line-height:1.65;color:var(--mid);
}
.what-list li:last-child{border-bottom:1px solid var(--line)}
.what-list li::before{content:"";position:absolute;left:3px;top:20px;width:6px;height:6px;background:var(--accent);transform:rotate(45deg)}
.what-list li strong{color:var(--text);font-weight:600}
.what-note{font-size:13px;color:var(--faint);max-width:720px;margin-top:14px;line-height:1.7}
.what-note strong{color:var(--mid)}

/* who cards (interior) */
.who-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:760px){.who-grid{grid-template-columns:1fr}}
.who-card{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--rad-lg);
  padding:26px 26px;transition:transform .26s var(--ease),box-shadow .26s,border-color .26s;
}
.who-card:hover{transform:translateY(-3px);box-shadow:0 22px 44px -30px rgba(23,29,38,.28)}
.who-card-title{font-family:var(--serif);font-weight:480;font-size:18.5px;letter-spacing:-.008em;color:var(--text);margin-bottom:9px}
.who-card-desc{font-size:13.5px;line-height:1.7;color:var(--mid)}

/* work grid (interior) */
.work-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;border-top:1px solid var(--text)}
@media(max-width:760px){.work-grid{grid-template-columns:1fr}}
.work-item{padding:26px 26px 30px;border-bottom:1px solid var(--line);border-right:1px solid var(--line)}
.work-item:nth-child(2n){border-right:0}
@media(max-width:760px){.work-item{border-right:0;padding-inline:0}}
.work-item-num{font-family:var(--mono);font-size:11px;letter-spacing:.14em;color:var(--accent)}
.work-item-title{font-family:var(--serif);font-weight:480;font-size:19px;letter-spacing:-.01em;color:var(--text);margin:13px 0 8px}
.work-item-desc{font-size:13.5px;line-height:1.7;color:var(--mid)}

/* scenarios */
.scenarios{display:grid;gap:16px}
.scenario{
  border:1px solid var(--line);border-left:2px solid var(--accent);border-radius:0 var(--rad-lg) var(--rad-lg) 0;
  padding:26px 30px;background:var(--paper);
}
.scenario-label{font-size:10px;letter-spacing:.22em}
.scenario-title{font-family:var(--serif);font-weight:490;font-size:20px;letter-spacing:-.01em;color:var(--text);margin:10px 0 10px}
.scenario-body{font-size:14px;line-height:1.75;color:var(--mid);max-width:90ch}

/* practice quote */
.prac-quote-sec{background:var(--paper-dim);border-block:1px solid var(--line)}
.prac-quote{max-width:760px;margin:0 auto;text-align:center;padding-inline:var(--gut)}
.prac-quote blockquote{
  font-family:var(--serif);font-weight:340;font-style:italic;
  font-size:clamp(19px,2.1vw,25px);line-height:1.5;letter-spacing:-.01em;color:var(--text);margin-bottom:22px;
}
.prac-quote figcaption{display:inline-flex;flex-direction:column;gap:4px;padding-top:14px;border-top:1.5px solid var(--accent)}
.prac-quote .pq-name{font-weight:600;font-size:13.5px;color:var(--text)}
.prac-quote .pq-role{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint)}

/* prev/next practice nav */
.pn-nav{border-top:1px solid var(--line)}
.pn-wrap{display:grid;grid-template-columns:1fr 1fr}
.pn-link{padding:30px 28px 36px;transition:background .22s}
.pn-link:first-child{padding-left:0}
.pn-link:hover{background:var(--accent-tint)}
.pn-link.pn-next{text-align:right;border-left:1px solid var(--line);padding-right:0}
.pn-link-label{font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);margin-bottom:8px}
.pn-link-title{font-family:var(--serif);font-weight:470;font-size:clamp(17px,1.7vw,21px);letter-spacing:-.01em;color:var(--text)}
.pn-link:hover .pn-link-title{color:var(--accent)}
@media(max-width:640px){.pn-wrap{grid-template-columns:1fr}.pn-link{padding-inline:0}.pn-link.pn-next{border-left:0;border-top:1px solid var(--line);text-align:left}}

/* ---- page-view (team / insights hub / legal / articles) ----- */
.page-view{
  max-width:var(--wrap);margin-inline:auto;
  padding:calc(72px + clamp(20px,3vw,36px)) var(--gut) clamp(28px,3.5vw,46px);
}
.page-view h1{
  font-family:var(--serif);font-weight:340;font-size:clamp(34px,4.4vw,58px);
  line-height:1.07;letter-spacing:-.02em;color:var(--text);margin:14px 0 0;max-width:22ch;text-wrap:balance;
}
.pv-lead{
  font-size:clamp(15.5px,1.3vw,17.5px);line-height:1.75;color:var(--mid);
  max-width:62ch;margin:22px 0 clamp(28px,4vw,40px);
}
.page-view>p,.page-view>ul,.page-view>ol{max-width:680px;font-size:15px;line-height:1.8;color:var(--mid);margin-bottom:1.15em}
.page-view>h2{
  font-family:var(--serif);font-weight:440;font-size:clamp(22px,2.3vw,28px);
  letter-spacing:-.014em;color:var(--text);margin:clamp(30px,4vw,40px) 0 12px;max-width:680px;
}
.page-view>h3{font-family:var(--serif);font-weight:480;font-size:19px;color:var(--text);margin:26px 0 8px;max-width:680px}
.page-view>ul li,.page-view>ol li{position:relative;padding:6px 0 6px 24px}
.page-view>ul li::before{content:"";position:absolute;left:3px;top:14px;width:6px;height:6px;background:var(--accent);transform:rotate(45deg)}
.page-view>ol{counter-reset:pvol}
.page-view>ol li{counter-increment:pvol}
.page-view>ol li::before{content:counter(pvol,decimal-leading-zero);position:absolute;left:0;top:7px;font-family:var(--mono);font-size:11.5px;color:var(--accent)}
.page-view a:not(.btn):not(.ins-card):not(.team-link):not(.pn-link){color:var(--accent);border-bottom:1px solid var(--line-strong);transition:border-color .2s}
.page-view a:not(.btn):not(.ins-card):not(.team-link):not(.pn-link):hover{border-color:var(--accent)}
.page-view blockquote{
  font-family:var(--serif);font-style:italic;font-size:18px;line-height:1.6;color:var(--text);
  border-left:2px solid var(--accent);padding:6px 0 6px 24px;margin:24px 0;max-width:640px;
}
.pv-meta{
  display:flex;flex-wrap:wrap;gap:8px 22px;margin:0 0 30px;padding:14px 0;
  border-block:1px solid var(--line);font-family:var(--mono);font-size:11.5px;color:var(--faint);
}
.pv-meta strong,.pv-meta b{color:var(--mid);font-weight:500}
a.pv-back{
  display:inline-flex;align-items:center;gap:9px;margin-bottom:26px;
  font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--mid)!important;
  border:1px solid var(--line-strong)!important;border-radius:var(--rad);padding:9px 16px;transition:.2s;
}
a.pv-back:hover{border-color:var(--accent)!important;color:var(--accent)!important}
.pv-actions{display:flex;flex-wrap:wrap;gap:12px;margin:30px 0}

/* tables (articles) */
.map-table,.page-view table{width:100%;border-collapse:collapse;margin:20px 0;font-size:13.5px}
.map-table th,.page-view table th{
  text-align:left;font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--faint);border-bottom:2px solid var(--text);padding:10px 12px;
}
.map-table td,.page-view table td{padding:12px;border-bottom:1px solid var(--line);vertical-align:top;color:var(--mid);line-height:1.6}
.map-table td.f{font-family:var(--mono);color:var(--accent);white-space:nowrap;font-size:12px}
.map-table tr:hover td{background:var(--paper-dim)}

/* insights cards */
.ins-list{display:grid;gap:16px;margin-top:8px}
@media(min-width:768px){.ins-list{grid-template-columns:1fr 1fr}}
.page-view a.ins-card{
  display:block;padding:26px 28px;border:1px solid var(--line);border-radius:var(--rad-lg);
  background:var(--paper);transition:transform .26s var(--ease),box-shadow .26s,border-color .26s;
}
.page-view a.ins-card:hover{transform:translateY(-3px);box-shadow:0 24px 46px -30px rgba(23,29,38,.3)}
.ins-card-meta{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:14px}
.ins-card-tag{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent)}
.ins-card-date{font-family:var(--mono);font-size:10.5px;color:var(--faint)}
.ins-card-h{font-family:var(--serif);font-weight:470;font-size:20px;line-height:1.3;letter-spacing:-.012em;color:var(--text);margin-bottom:9px}
.ins-card-deck{font-size:13.5px;line-height:1.65;color:var(--mid);margin-bottom:16px}
.ins-card-cta{font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);transition:color .2s}
.ins-card:hover .ins-card-cta{color:var(--accent)}
.ins-related{margin:38px 0 8px;padding-top:24px;border-top:1px solid var(--line);max-width:680px}
.ins-related-k{font-size:10.5px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--accent)}
.ins-related-links{display:flex;flex-wrap:wrap;gap:10px 22px;margin-top:14px}
.ins-related-links a{font-family:var(--serif);font-size:16.5px;color:var(--text)!important;border-bottom:1px solid var(--line-strong)!important;padding-bottom:2px}
.ins-related-links a:hover{color:var(--accent)!important;border-color:var(--accent)!important}

/* team */
.team-grid{display:grid;gap:18px;margin-top:6px}
.team-card{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--rad-lg);
  display:flex;flex-direction:column;transition:border-color .25s;
}
.team-card:hover{border-color:var(--line-strong)}
.team-body{padding:30px 32px 30px;display:flex;flex-direction:column;gap:12px}
.team-meta{font-size:10.5px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--accent)}
.team-name{font-family:var(--serif);font-weight:440;font-size:clamp(24px,2.4vw,30px);letter-spacing:-.015em;color:var(--text)}
.team-bio{font-size:14.5px;line-height:1.75;color:var(--mid);max-width:75ch}
.team-bio strong{color:var(--text);font-weight:600}
.team-focus{margin-top:6px}
.team-focus-key{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);margin-bottom:10px}
.team-focus-list{display:flex;flex-wrap:wrap;gap:8px}
.team-focus-list li{
  font-family:var(--mono);font-size:11px;letter-spacing:.03em;color:var(--mid);
  border:1px solid var(--line);border-radius:999px;padding:6px 13px;
}
.team-link{align-self:flex-start;margin-top:8px;font-size:12px!important;letter-spacing:.08em;text-transform:uppercase;color:var(--accent)!important;border:1px solid var(--line-strong)!important;padding:10px 18px!important}
.team-link:hover{border-color:var(--accent)!important;background:var(--accent-tint)}
.team-foot{margin-top:34px;padding-top:24px;border-top:1px solid var(--line);font-size:13.5px;color:var(--mid);max-width:70ch;line-height:1.7}

/* calculator (tools) */
.calc{border:1px solid var(--line);border-radius:var(--rad-lg);padding:30px;background:var(--paper-dim);margin:26px 0;max-width:760px}
.calc .field{margin-bottom:16px}
.calc-out,.calc-result{
  background:var(--band);color:var(--d-text);border-radius:var(--rad);
  padding:22px 24px;margin-top:18px;font-variant-numeric:lining-nums;
}
.calc-out .big,.calc-result .big{font-family:var(--serif);font-size:30px;font-weight:440}
.calc button,.calc .btn{background:var(--text);color:var(--paper);border-radius:var(--rad);padding:13px 24px;font-weight:600;font-size:14px}
.calc button:hover{background:var(--accent)}

/* ============================================================
   WHATSAPP FAB · CONSENT · MISC
   ============================================================ */
.wa-fab{
  position:fixed;right:18px;bottom:18px;z-index:80;width:52px;height:52px;border-radius:50%;
  background:#1FA855;display:grid;place-items:center;
  box-shadow:0 12px 28px -8px rgba(31,168,85,.5);transition:transform .2s;
}
.wa-fab:hover{transform:scale(1.07)}
.wa-fab svg{width:27px;height:27px;fill:#fff}
@media print{.wa-fab,.rail,.consent{display:none}}

.consent{
  position:fixed;right:18px;bottom:18px;left:auto;z-index:95;max-width:420px;
  background:var(--paper);border:1px solid var(--line-strong);border-radius:var(--rad-lg);
  box-shadow:0 30px 70px -24px rgba(23,29,38,.4);
}
.consent[hidden]{display:none}
@media(max-width:560px){.consent{left:12px;right:12px;bottom:12px;max-width:none}}
.consent-inner{padding:22px 24px 20px}
.consent-h{font-family:var(--serif);font-weight:500;font-size:17px;letter-spacing:-.008em;color:var(--text);margin-bottom:8px}
.consent-d{font-size:12.5px;line-height:1.65;color:var(--mid)}
.consent-d a{color:var(--accent);border-bottom:1px solid var(--line-strong)}
.consent-actions{display:flex;gap:10px;margin-top:16px}
.consent-btn{flex:1;padding:11px 14px;font-size:13px}
.consent-btn-primary{background:var(--text);color:var(--paper);border:1px solid var(--text)}
.consent-btn-primary:hover{background:var(--accent);border-color:var(--accent)}
.consent-btn-secondary{border:1px solid var(--line-strong);color:var(--mid)}
.consent-btn-secondary:hover{border-color:var(--text);color:var(--text)}

/* ============================================================
   MOTION — respectful, interaction + entrance
   ============================================================ */
html.js .reveal{opacity:0;transform:translateY(22px)}
html.js .reveal.in{opacity:1;transform:none;transition:opacity .75s ease,transform .75s var(--ease)}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  html.js .reveal{opacity:1;transform:none}
  *,*::before,*::after{animation-duration:.001s!important;transition-duration:.001s!important}
}
/* hero entrance (home) */
@media(prefers-reduced-motion:no-preference){
  .hero-home .hero-kick{animation:amc-fade .7s ease both}
  .hero-home h1{animation:amc-rise .8s var(--ease) .08s both}
  .hero-home .hero-deck,.hero-home .hero-ctas{animation:amc-rise .8s var(--ease) .18s both}
  .hero-home .brief-card{animation:amc-rise .9s var(--ease) .3s both}
  .hero h1,.page-view h1{animation:amc-rise .7s var(--ease) both}
  .hero-lede,.pv-lead{animation:amc-rise .7s var(--ease) .1s both}
}
@keyframes amc-fade{from{opacity:0}to{opacity:1}}
@keyframes amc-rise{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}

/* ============================================================
   v4 — INTER DISPLAY + CONSISTENT BLUE + BRAND LOGO
   Retire the serif/italic editorial treatment; tune Inter as a
   display face (heavier weights, tighter tracking) and carry the
   steel-blue accent across primary actions and emphasis.
   ============================================================ */

/* --- Display weights tuned for Inter (heavier than the old serif) --- */
.serif-display{font-weight:660;letter-spacing:-.028em}
.s-display,.section-title{font-weight:660;letter-spacing:-.028em;line-height:1.05}
.hero-home h1{font-weight:680;letter-spacing:-.032em;line-height:1.03}
.band-q{font-weight:480;font-style:normal;letter-spacing:-.018em}
.idx-name{font-weight:600}
.sp-title{font-weight:600;letter-spacing:-.016em}
.principle h3{font-weight:600}
.o-metric{font-weight:680;letter-spacing:-.03em}
.stat-v{font-weight:660}
.ledger-v{font-weight:660}
.tcard blockquote{font-weight:460;letter-spacing:-.005em}
.about-stat-val,.price-name,.price-amt,.pv-title,.hero h1,.page-view h1{font-weight:660;letter-spacing:-.024em}

/* Emphasis = upright brand blue, never italic (kills the AI-serif tell) */
em.tilt,.serif-display em,h1 em,h2 em,.s-display em,.band-q em{font-style:normal;font-weight:inherit;color:var(--accent)}
.hero-home h1 em{font-style:normal;font-weight:inherit;color:var(--d-accent)}

/* --- Brand logo (header + footer) --- */
.rail-l a{align-items:center}
.brand-logo{height:40px;width:auto;display:block}
@media(max-width:960px){.brand-logo{height:34px}}
.footer-logo{height:48px;width:auto;display:block;margin-bottom:16px}

/* --- Blue carried through the primary actions --- */
.btn-primary,.cta-btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}
.btn-primary:hover,.cta-btn-primary:hover{background:var(--accent-deep);border-color:var(--accent-deep);color:#fff}
.rail-r .cta,a.nav-cta{background:var(--accent);border-color:var(--accent);color:#fff}
.rail-r .cta:hover,a.nav-cta:hover{background:var(--accent-deep);border-color:var(--accent-deep);color:#fff}
/* On the navy bands the brand-blue button would vanish — use white there */
.hero-home .btn-primary{background:#fff;border-color:#fff;color:var(--band)}
.hero-home .btn-primary:hover{background:var(--d-accent);border-color:var(--d-accent);color:var(--band)}
.cta-section .cta-btn-primary{background:#fff;border-color:#fff;color:var(--band)}
.cta-section .cta-btn-primary:hover{background:var(--d-accent);border-color:var(--d-accent);color:var(--band)}

/* ============================================================
   v8 — DEEPER BLUE TUNING · TIGHTER CARD GAPS · JUSTIFIED PROSE
   ============================================================ */

/* Reduce inter-card spacing ~40% (grids of cards) */
.outcomes{gap:11px}
.tgrid{gap:11px}
.price-grid{gap:11px}
.principles{gap:clamp(14px,2.1vw,26px)}
.who-grid{gap:10px}
.scenarios{gap:10px}

/* Justify long-form prose paragraphs (not short UI/card labels) */
.hero-deck,.hero-lede,.pv-lead,.about-body p,.faq-a,.price-custom p,.page-view p{
  text-align:justify;-webkit-hyphens:auto;hyphens:auto;
}

/* Inline logo SVG: lock intrinsic width so it always lays out fully */
.brand-logo{width:131px;height:40px}
@media(max-width:960px){.brand-logo{width:111px;height:34px}}
.footer-logo{width:157px;height:48px}

/* Primary nav links — bold */
.rail-c a{font-weight:700}

/* Mobile: tables scroll within their box instead of widening the page */
@media(max-width:700px){
  main table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}
  .map-table td.f{white-space:normal}
}

/* ============================================================
   FOUNDER MATH CALLOUT  (startup-legal · founders-tax-desk · valuation)
   Previously had no rules — the arrow SVG blew up to viewport width.
   ============================================================ */
.fm-callout{padding:clamp(32px,4vw,54px) var(--gut)}
.fm-callout-inner{
  max-width:var(--wrap);margin-inline:auto;
  display:grid;grid-template-columns:1.6fr auto;gap:clamp(24px,4vw,48px);align-items:center;
  background:var(--accent-tint);border:1px solid var(--line-strong);border-radius:var(--rad-lg);
  padding:clamp(26px,3vw,40px);
}
@media(max-width:760px){.fm-callout-inner{grid-template-columns:1fr;padding:24px;gap:20px}}
.fm-callout-eyebrow{font-size:11px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:10px}
.fm-callout-title{font-weight:660;font-size:clamp(19px,2.2vw,26px);letter-spacing:-.02em;line-height:1.15;color:var(--text);margin-bottom:10px}
.fm-callout-desc{font-size:14px;line-height:1.7;color:var(--mid);max-width:64ch;text-align:justify;-webkit-hyphens:auto;hyphens:auto}
.fm-callout-meta{margin-top:12px;font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--faint)}
.fm-callout-cta{
  display:inline-flex;align-items:center;gap:10px;white-space:nowrap;align-self:center;
  background:var(--accent);color:#fff;border:1px solid var(--accent);
  font-weight:600;font-size:14px;padding:14px 24px;border-radius:var(--rad);
  transition:background .22s,border-color .22s,transform .18s;
}
.fm-callout-cta:hover{background:var(--accent-deep);border-color:var(--accent-deep);transform:translateY(-1px)}
.fm-callout-cta svg{width:18px;height:18px;flex:none;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* Founder Math — coming-soon state */
.fm-soon-badge{
  display:inline-block;margin-left:8px;font-family:var(--mono);font-size:9.5px;font-weight:500;
  letter-spacing:.12em;text-transform:uppercase;color:var(--accent);
  background:#fff;border:1px solid var(--line-strong);border-radius:999px;padding:3px 9px;vertical-align:middle;
}
.fm-callout-cta.fm-soon{background:transparent;color:var(--mid);border-color:var(--line-strong);cursor:default;pointer-events:none}
.fm-callout-cta.fm-soon:hover{background:transparent;border-color:var(--line-strong);transform:none}
