/* ===========================================================================
   Spectral Consulting — CV page styles ("Dusk")
   Extends colors_and_type.css (tokens) + styles.css (base kit). CV-only rules.
   =========================================================================== */

/* ---------------------------------------------------------- a11y utils ---- */
.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}
.skip-link{position:fixed;top:-60px;left:16px;z-index:200;background:var(--ink-700);
  color:var(--cream);border:1px solid var(--glass-border);padding:10px 16px;border-radius:var(--r-md);
  font-size:14px;transition:top var(--dur) var(--ease-out)}
.skip-link:focus{top:16px;outline:none;box-shadow:0 0 0 3px var(--accent-quiet)}

/* Anchored sections clear the fixed nav */
section[id], header[id]{scroll-margin-top:118px}

/* Nav CTA: near-black text for stronger contrast on the amber gradient */
.nav-links .btn-primary{color:#0a0503}

/* Consistent, visible focus ring for keyboard users across the page */
a:focus-visible, button:focus-visible, input:focus-visible{
  outline:none;border-radius:var(--r-sm);
  box-shadow:0 0 0 2px var(--ink-900), 0 0 0 4px var(--ember)}

/* --------------------------------------------------------------- motion --- */
@keyframes reveal-up{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
.js .reveal{opacity:0}
.reveal.is-in{animation:reveal-up .7s var(--ease-out) var(--reveal-delay,0ms) both}
.js .cv-hero .load{opacity:0}
.cv-hero .load{animation:reveal-up .66s var(--ease-out) calc(var(--i,0) * 78ms + 140ms) both}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;
    transition-duration:.001ms !important;scroll-behavior:auto !important}
  .js .reveal,.js .cv-hero .load{opacity:1 !important;transform:none !important}
}

/* --- the signal mark: a ping that broadcasts, never a loop ---------------- */
/* Inlined in cv-app.jsx (SignalMark). On mount the nav lockup runs a one-shot
   broadcast — core ignites, rings emanate outward in sequence, one ring is
   transmitted past the edge and fades. Every lockup re-emits a single ping on
   hover/focus. transform + opacity only; reduced-motion gets the static mark. */
.sig-mark{overflow:visible;transition:filter var(--dur) var(--ease-out)}
.sig-ring,.sig-emit,.sig-core{transform-box:fill-box;transform-origin:center}
.sig-ring--1{opacity:1}
.sig-ring--2{opacity:.6}
.sig-ring--3{opacity:.34}
.sig-core{opacity:1}
.sig-emit{opacity:0}

/* one-shot broadcast on mount — staggered emanation, then a transmitted ring */
.sig-mark--lit .sig-core   {animation:sig-core-in .55s var(--ease-out) .06s both}
.sig-mark--lit .sig-ring--1{animation:sig-ring-in .60s var(--ease-out) .18s both}
.sig-mark--lit .sig-ring--2{animation:sig-ring-in .62s var(--ease-out) .30s both}
.sig-mark--lit .sig-ring--3{animation:sig-ring-in .64s var(--ease-out) .42s both}
.sig-mark--lit .sig-emit   {animation:sig-ping 1.05s var(--ease-out) .56s}

/* hover / keyboard focus re-emits one ping and warms the glow */
.ds-logo:hover .sig-mark,.ds-logo:focus-visible .sig-mark{filter:drop-shadow(0 0 7px rgba(255,179,71,.5))}
.ds-logo:hover .sig-emit,.ds-logo:focus-visible .sig-emit{animation:sig-ping .66s var(--ease-out)}
.ds-logo:hover .sig-core,.ds-logo:focus-visible .sig-core{animation:sig-core-pulse .66s var(--ease-out)}

@keyframes sig-core-in{from{opacity:0;transform:scale(.2)}}
@keyframes sig-ring-in{from{opacity:0;transform:scale(.4)}}
@keyframes sig-ping{from{opacity:.5;transform:scale(.4)}to{opacity:0;transform:scale(1.75)}}
@keyframes sig-core-pulse{0%{transform:scale(1)}38%{transform:scale(1.26)}100%{transform:scale(1)}}

@media (prefers-reduced-motion: reduce){
  .sig-mark,.sig-mark *{animation:none !important}
  .sig-emit{opacity:0 !important}
}

/* Keep the booking CTA reachable on mobile (base kit hides .nav-links < 900px) */
@media (max-width:900px){
  .nav-inner{height:84px}
  .nav .ds-logo{--logo-mark:46px !important}
  .nav-links{display:flex;gap:0}
  .nav-links a:not(.btn){display:none}
  .nav-links .btn{display:inline-flex}
}

/* Fluid section headings for this page */
.section-head h2{font-size:clamp(1.9rem,1.1rem + 2.6vw,2.5rem);text-wrap:balance}
.cv-h2{font-family:var(--font-display);font-weight:700;font-size:clamp(1.9rem,1.1rem + 2.6vw,2.5rem);
  line-height:1.08;letter-spacing:-0.025em;color:var(--cream);margin:18px 0 0;text-wrap:balance}

/* =====================================================================
   HERO — name-led, the portrait reads as the brand "ping" mark
   ===================================================================== */
.cv-hero{position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:center;
  padding:128px 0 72px;overflow:hidden}
.cv-hero__bg{position:absolute;inset:0;pointer-events:none}
.cv-hero__glow{position:absolute;top:-160px;right:-120px;width:820px;height:820px;border-radius:50%;
  background:radial-gradient(circle,rgba(253,140,89,.30) 0%,rgba(253,97,86,.10) 40%,rgba(16,11,9,0) 70%)}
/* concentric rings centered behind the portrait — the signal broadcasting outward */
.cv-ring{position:absolute;border-radius:50%;border:1px solid rgba(253,160,110,.16);
  top:46%;right:14%;transform:translate(50%,-50%)}
.cv-ring.r1{width:440px;height:440px}
.cv-ring.r2{width:680px;height:680px;border-color:rgba(253,140,89,.10)}
.cv-ring.r3{width:940px;height:940px;border-color:rgba(253,140,89,.055)}

/* Hero entrance — the signal ignites, then broadcasts (one-shot, on load).
   The glow blooms first, then the rings emanate outward in sequence — the logo
   mark's broadcast at hero scale. transform/opacity only; .js-gated so non-JS
   and reduced-motion users get the lit hero with no motion. */
.js .cv-hero__glow{opacity:0}
.cv-hero__glow{transform-origin:62% 38%;animation:hero-glow-in 1.3s var(--ease-out) 60ms both}
.js .cv-hero .cv-ring{opacity:0}
.cv-hero .cv-ring{animation:hero-ring-in 1.05s var(--ease-out) both}
.cv-hero .cv-ring.r1{animation-delay:180ms}
.cv-hero .cv-ring.r2{animation-delay:340ms}
.cv-hero .cv-ring.r3{animation-delay:500ms}
@keyframes hero-glow-in{from{opacity:0;transform:scale(.72)}to{opacity:1;transform:scale(1)}}
@keyframes hero-ring-in{
  from{opacity:0;transform:translate(50%,-50%) scale(.5)}
  to{opacity:1;transform:translate(50%,-50%) scale(1)}}

/* Stat panel — the proof figures cascade in line by line after the panel lands */
.js .cv-hero .cv-heroledger__row{opacity:0}
.cv-hero .cv-heroledger__row{animation:reveal-up .58s var(--ease-out) calc(640ms + var(--i,0) * 75ms) both}

@media (prefers-reduced-motion: reduce){
  /* show the lit hero immediately; keep ring positioning (no transform reset) */
  .js .cv-hero__glow,.js .cv-hero .cv-ring{opacity:1 !important;animation:none !important}
  .js .cv-hero .cv-heroledger__row{opacity:1 !important;transform:none !important;animation:none !important}
}

.cv-hero__grid{position:relative;display:grid;grid-template-columns:0.92fr 1.08fr;gap:44px;align-items:center}

.cv-hero__copy{max-width:580px}
.cv-hero__name{font-family:var(--font-display);font-weight:800;
  font-size:clamp(2.6rem,1.4rem + 4.4vw,4.5rem);line-height:1.0;letter-spacing:-0.035em;
  color:var(--cream);margin:22px 0 0}
.cv-hero__tagline{font-family:var(--font-display);font-weight:700;
  font-size:clamp(1.3rem,.9rem + 1.5vw,1.95rem);line-height:1.2;letter-spacing:-0.02em;
  color:var(--cream);margin:18px 0 0;max-width:18ch;text-wrap:balance}
.cv-hero__sub{font-family:var(--font-sans);font-size:clamp(1rem,.95rem + .3vw,1.15rem);
  line-height:1.62;color:var(--cream-dim);max-width:50ch;margin:22px 0 0}
.cv-hero__sub strong{color:var(--cream);font-weight:600}
.cv-hero__meta{display:flex;flex-direction:column;align-items:flex-start;gap:11px;margin-top:24px}
.cv-hero__cred{font-family:var(--font-mono);font-size:12.5px;letter-spacing:.02em;color:var(--taupe)}

/* availability chip */
.status-chip{display:inline-flex;align-items:center;gap:10px;padding:9px 16px 9px 13px;
  border-radius:var(--r-pill);background:var(--glass-fill-strong);border:1px solid var(--glass-border);
  font-size:13.5px;font-weight:500;color:var(--cream-dim);letter-spacing:.005em}
.status-dot{width:8px;height:8px;border-radius:50%;background:var(--amber);flex:none;
  box-shadow:0 0 0 4px rgba(252,177,104,.16), 0 0 10px 1px rgba(252,177,104,.6)}

/* portrait + floating track panel */
.cv-hero__figure{position:relative}
.cv-portrait{position:relative;z-index:1;width:min(122%,620px);margin-left:auto;margin-right:-64px;margin-top:-34px}
.cv-portrait::before{content:"";position:absolute;left:50%;top:46%;width:115%;height:115%;
  transform:translate(-50%,-50%);border-radius:50%;z-index:-1;
  background:radial-gradient(closest-side,rgba(253,140,89,.26),rgba(16,11,9,0) 72%)}
.cv-portrait img{width:100%;height:auto;display:block;
  -webkit-mask-image:linear-gradient(to bottom,#000 76%,transparent 99%);
  mask-image:linear-gradient(to bottom,#000 76%,transparent 99%);
  filter:saturate(.96) contrast(1.02) brightness(.99) drop-shadow(0 30px 55px rgba(0,0,0,.6))}
.cv-heroledger{position:absolute;left:-20px;bottom:-26px;z-index:3;width:min(350px,98%);padding:20px 22px;
  background:linear-gradient(158deg,rgba(28,22,18,.52),rgba(16,11,9,.68))}
.cv-heroledger .panel-h{margin:0 0 12px}
.cv-heroledger__list{list-style:none;margin:0;padding:0}
.cv-heroledger__list li{display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:center;
  padding:9px 0;border-top:1px solid var(--glass-border-soft)}
.cv-heroledger__list li:first-child{border-top:0;padding-top:0}
.cv-heroledger__list .num{font-family:var(--font-display);font-weight:800;font-size:20px;line-height:1;
  letter-spacing:-0.02em;font-variant-numeric:tabular-nums;white-space:nowrap}
.cv-heroledger__list li:first-child .num{font-size:25px}
.cv-heroledger__list .lbl{font-size:11.5px;line-height:1.32;color:var(--taupe)}

/* =====================================================================
   PROFILE — editorial split, "not an agency"
   ===================================================================== */
.cv-profile{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}
.cv-profile__head{max-width:26rem}
.cv-profile__body{display:flex;flex-direction:column;gap:18px}
.cv-profile__body p{font-size:var(--t-body-lg);line-height:1.66;color:var(--cream-dim);
  max-width:60ch;margin:0;text-wrap:pretty}

/* =====================================================================
   LOGO WALL — uniform warm-mono marks, warm to full presence on hover
   ===================================================================== */
.cv-logos-sec{padding:40px 0 12px}
.cv-logos__label{margin:0}
.cv-marquee{position:relative;margin-top:26px;overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.cv-marquee__track{display:flex;align-items:center;gap:72px;width:max-content;
  animation:cv-marquee 46s linear infinite;will-change:transform}
.cv-marquee:hover .cv-marquee__track{animation-play-state:paused}
.cv-marquee .cv-logo{flex:none;height:44px;display:flex;align-items:center;justify-content:center;padding:0}
.cv-marquee .cv-logo img{max-height:40px;max-width:170px;width:auto;height:auto;object-fit:contain;
  filter:brightness(0) invert(1);opacity:.5;transition:opacity var(--dur) var(--ease-out)}
.cv-marquee .cv-logo:hover img{opacity:.95}
@keyframes cv-marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion: reduce){
  .cv-marquee{-webkit-mask-image:none;mask-image:none}
  .cv-marquee__track{animation:none;flex-wrap:wrap;justify-content:center;width:auto;gap:34px 52px;padding:0 24px}
  .cv-marquee .is-dupe{display:none}
}

/* =====================================================================
   PROOF — the editorial ledger (the page's centerpiece)
   ===================================================================== */
.cv-proof__grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.cv-proof__lead{max-width:34rem}
.cv-proof__ctx{margin-top:22px;font-size:var(--t-body-lg);line-height:1.62;color:var(--cream-dim);
  max-width:46ch;text-wrap:pretty}
.cv-proof__figure{position:relative}
.cv-proof__facts{list-style:none;margin:30px 0 0;padding:0;display:flex;flex-direction:column;gap:13px}
.cv-proof__facts li{position:relative;padding-left:30px;font-family:var(--font-mono);font-size:13px;
  letter-spacing:.01em;color:var(--cream-dim)}
.cv-proof__facts li::before{content:"";position:absolute;left:0;top:8px;width:18px;height:2px;
  border-radius:2px;background:var(--grad-dusk-h)}
.cv-anchor{display:block;margin-top:0}
.cv-anchor__fig{display:block;font-family:var(--font-display);font-weight:800;
  font-size:clamp(3.4rem,1.6rem + 6.4vw,6.5rem);line-height:.92;letter-spacing:-0.04em;
  font-variant-numeric:tabular-nums}
.cv-anchor__label{display:block;margin-top:16px;max-width:30ch;font-size:var(--t-body);
  line-height:1.5;color:var(--cream-dim)}
.cv-proof__note{margin-top:30px;max-width:36ch;font-family:var(--font-mono);font-size:12px;
  line-height:1.6;letter-spacing:.01em;color:var(--taupe)}

.cv-ledger{list-style:none;margin:0;padding:0}
.cv-ledger__row{display:grid;grid-template-columns:minmax(0,auto) 1fr;gap:28px;align-items:baseline;
  padding:22px 0;border-top:1px solid var(--glass-border-soft)}
.cv-ledger__row:first-child{border-top:0;padding-top:4px}
.cv-ledger__fig{font-family:var(--font-display);font-weight:800;letter-spacing:-0.03em;
  font-variant-numeric:tabular-nums;white-space:nowrap}
.cv-ledger__row.size-lg .cv-ledger__fig{font-size:clamp(2.3rem,1.4rem + 2.4vw,3rem)}
.cv-ledger__row.size-md .cv-ledger__fig{font-size:clamp(1.7rem,1.2rem + 1.4vw,2.1rem)}
.cv-ledger__label{font-size:var(--t-body);line-height:1.45;color:var(--taupe);
  max-width:42ch;align-self:center}

/* =====================================================================
   TRACK RECORD — single narrative on a phase rail (no fabricated dates)
   ===================================================================== */
.cv-track__head{max-width:32rem;margin-bottom:48px}
.cv-phases{list-style:none;margin:0 0 0 4px;padding:0;max-width:68ch;position:relative}
.cv-phases::before{content:"";position:absolute;left:5px;top:8px;bottom:8px;width:1px;
  background:linear-gradient(to bottom,var(--glass-border),var(--glass-border-soft) 80%,transparent)}
.cv-phase{position:relative;padding:0 0 32px 38px}
.cv-phase:last-child{padding-bottom:0}
.cv-phase__node{position:absolute;left:0;top:5px;width:11px;height:11px;border-radius:50%;
  background:var(--grad-dusk);box-shadow:0 0 0 4px var(--ink-850), 0 0 12px rgba(253,140,89,.5)}
.cv-phase__tag{display:block;font-family:var(--font-mono);font-size:12px;font-weight:600;
  letter-spacing:.12em;text-transform:uppercase;color:var(--amber);margin-bottom:8px}
.cv-phase__text{margin:0;font-size:var(--t-body-lg);line-height:1.6;color:var(--cream-dim);text-wrap:pretty}
.cv-track__creds{margin:44px 0 0 4px;padding-top:26px;border-top:1px solid var(--glass-border-soft);
  font-family:var(--font-mono);font-size:12.5px;line-height:1.9;letter-spacing:.02em;color:var(--taupe)}

/* =====================================================================
   CAPABILITIES — asymmetric bento (Creative Strategy is the feature)
   ===================================================================== */
.cv-bento{display:grid;grid-template-columns:repeat(12,1fr);gap:20px}
.cv-cap{position:relative;border-radius:var(--r-lg);background:var(--glass-fill);
  border:1px solid var(--glass-border-soft);padding:30px 30px 32px;overflow:hidden;
  transition:border-color var(--dur) var(--ease-out),background var(--dur) var(--ease-out),
    transform var(--dur) var(--ease-out)}
.cv-cap:hover{border-color:var(--glass-border);background:var(--glass-fill-strong);transform:translateY(-2px)}
.cv-cap .idx{position:absolute;top:24px;right:26px;font-family:var(--font-mono);font-size:12px;color:var(--taupe-dim)}
.cv-cap .ic{width:42px;height:42px;border-radius:11px;background:var(--accent-quiet);
  display:flex;align-items:center;justify-content:center;margin-bottom:20px;color:var(--amber)}
.cv-cap h3{font-family:var(--font-display);font-size:21px;font-weight:700;letter-spacing:-0.02em;margin:0 0 10px}
.cv-cap p{font-size:15px;line-height:1.6;color:var(--taupe);margin:0;max-width:46ch}
/* placement */
.cv-bento > :nth-child(1){grid-column:1 / 8;grid-row:1 / 3}
.cv-bento > :nth-child(2){grid-column:8 / 13;grid-row:1}
.cv-bento > :nth-child(3){grid-column:8 / 13;grid-row:2}
.cv-bento > :nth-child(4){grid-column:1 / 13;grid-row:3}
/* feature card extras */
.cv-cap.is-feature{padding:34px 34px 34px}
.cv-cap.is-feature::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(70% 90% at 88% 8%,rgba(253,140,89,.12),rgba(16,11,9,0) 60%)}
.cv-cap.is-feature h3{font-size:25px;margin-top:2px}
.cv-cap.is-feature p{font-size:16px;max-width:42ch}
.cv-cap__points{list-style:none;margin:22px 0 0;padding:0;display:flex;flex-direction:column;gap:12px}
.cv-cap__points li{position:relative;padding-left:30px;font-size:14.5px;line-height:1.5;color:var(--cream-dim)}
.cv-cap__points li::before{content:"";position:absolute;left:0;top:9px;width:18px;height:2px;
  border-radius:2px;background:var(--grad-dusk-h)}

/* tech stack strip */
.cv-stack{display:flex;flex-wrap:wrap;align-items:center;gap:12px;margin-top:34px;
  padding-top:30px;border-top:1px solid var(--glass-border-soft)}
.cv-stack__label{font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.2em;
  text-transform:uppercase;color:var(--taupe);margin-right:6px}
.cv-stack__tags{list-style:none;display:flex;flex-wrap:wrap;gap:10px;margin:0;padding:0}
.cv-stack__tags li{font-family:var(--font-mono);font-size:12.5px;letter-spacing:.02em;color:var(--taupe);
  padding:7px 14px;border-radius:var(--r-pill);border:1px solid var(--glass-border-soft);
  background:var(--glass-fill)}

/* =====================================================================
   SYSTEM — the deck pipeline + the loop
   ===================================================================== */
.cv-pipeline{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.cv-pipeline__step{position:relative;border-radius:var(--r-lg);background:var(--glass-fill);
  border:1px solid var(--glass-border-soft);padding:26px 24px 28px;
  transition:border-color var(--dur) var(--ease-out),background var(--dur) var(--ease-out),transform var(--dur) var(--ease-out)}
.cv-pipeline__step:hover{border-color:var(--glass-border);background:var(--glass-fill-strong);transform:translateY(-2px)}
.cv-pipeline__n{font-family:var(--font-mono);font-size:13px;font-weight:600;letter-spacing:.08em;color:var(--taupe-dim)}
.cv-pipeline__name{font-family:var(--font-display);font-size:21px;font-weight:700;letter-spacing:-0.02em;margin:14px 0 8px}
.cv-pipeline__tag{display:block;font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:.07em;
  text-transform:uppercase;color:var(--amber);margin-bottom:13px}
.cv-pipeline__d{font-size:13.5px;line-height:1.55;color:var(--taupe);margin:0}
.cv-pipeline__step::after{content:"›";position:absolute;top:34px;right:-11px;
  font-family:var(--font-mono);font-size:16px;color:var(--coral);z-index:2}
.cv-pipeline__step:last-child::after{display:none}

.cv-loop{margin-top:22px;border-radius:var(--r-lg);border:1px solid var(--glass-border-soft);
  background:var(--glass-fill);padding:30px 34px;display:grid;grid-template-columns:.85fr 1.15fr;gap:44px;align-items:center}
.cv-loop__label{font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.2em;
  text-transform:uppercase;color:var(--amber)}
.cv-loop__lead{font-family:var(--font-display);font-size:21px;font-weight:700;line-height:1.3;
  letter-spacing:-0.015em;color:var(--cream);margin:12px 0 0;max-width:24ch;text-wrap:balance}
.cv-loop__rules{list-style:none;margin:0;padding:0}
.cv-loop__rules li{display:flex;gap:16px;align-items:baseline;font-size:14px;line-height:1.45;
  color:var(--taupe);padding:13px 0;border-top:1px solid var(--glass-border-soft)}
.cv-loop__rules li:first-child{border-top:0;padding-top:0}
.cv-loop__rules li:last-child{padding-bottom:0}
.cv-loop__sig{flex:none;width:128px;font-family:var(--font-mono);font-size:12.5px;font-weight:600;
  letter-spacing:.02em;color:var(--amber)}

/* =====================================================================
   COVERAGE MATRIX — Segment × Awareness (deck slide 5)
   ===================================================================== */
.cv-matrix__grid{display:grid;grid-template-columns:minmax(150px,1fr) repeat(5,1fr);gap:10px}
.cv-matrix__col{font-family:var(--font-mono);font-size:10.5px;font-weight:500;letter-spacing:.05em;
  text-transform:uppercase;color:var(--taupe);text-align:center;padding:0 4px 10px;align-self:end;line-height:1.3}
.cv-matrix__rowhead{display:flex;align-items:center;padding-right:14px;font-family:var(--font-display);
  font-size:15px;font-weight:600;letter-spacing:-0.01em;color:var(--cream-dim)}
.cv-matrix__cell{position:relative;min-height:66px;border-radius:var(--r-sm);
  border:1px solid var(--glass-border-soft);background:var(--glass-fill)}
.cv-matrix__cell::after{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:8px;height:8px;border-radius:50%;border:1px solid var(--taupe-dim)}
.cv-matrix__cell.is-covered{border-color:transparent;
  background:linear-gradient(135deg,rgba(252,177,104,.20),rgba(253,97,86,.14));
  box-shadow:inset 0 0 0 1px rgba(253,140,89,.4)}
.cv-matrix__cell.is-covered::after{width:11px;height:11px;border:0;background:var(--grad-dusk)}
.cv-matrix__legend{display:flex;gap:26px;margin-top:20px}
.cv-matrix__key{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-mono);font-size:12px;
  letter-spacing:.02em;color:var(--taupe)}
.cv-matrix__key::before{content:"";width:11px;height:11px;border-radius:50%;border:1px solid var(--taupe-dim)}
.cv-matrix__key.is-covered::before{background:var(--grad-dusk);border-color:transparent}

/* =====================================================================
   PAGE MOTION — the connective dash, the coverage sweep
   (count-up figures are driven by the CountUp component in cv-app.jsx)
   ===================================================================== */
/* The eyebrow dash draws itself in as each section reveals — one consistent
   signature threading the whole scroll, not scattered one-offs. */
.eyebrow .dash{transform-origin:left center}
.js .reveal:not(.is-in) .eyebrow .dash{transform:scaleX(0)}
.reveal.is-in .eyebrow .dash{animation:dash-draw .55s var(--ease-out) .12s both}
.cv-hero .eyebrow.load .dash{animation:dash-draw .55s var(--ease-out) 320ms both}
@keyframes dash-draw{from{transform:scaleX(0)}to{transform:scaleX(1)}}

/* Coverage matrix builds in a diagonal sweep; covered cells' dots land a beat
   later — coverage being painted onto the market, not guessed at. */
.js .cv-matrix:not(.is-in) .cv-matrix__cell{opacity:0}
.cv-matrix.is-in .cv-matrix__cell{animation:cell-in .5s var(--ease-out) calc(var(--cell,0) * 60ms) both}
.cv-matrix.is-in .cv-matrix__cell.is-covered::after{animation:dot-in .5s var(--ease-out) calc(120ms + var(--cell,0) * 60ms) both}
@keyframes cell-in{from{opacity:0;transform:scale(.72)}to{opacity:1;transform:scale(1)}}
@keyframes dot-in{from{opacity:0;transform:translate(-50%,-50%) scale(0)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}

/* count-up figures hold a steady width while ticking */
.cv-ref__fig{font-variant-numeric:tabular-nums}

@media (prefers-reduced-motion: reduce){
  .reveal .eyebrow .dash,.cv-hero .eyebrow.load .dash{animation:none !important;transform:none !important}
  .cv-matrix .cv-matrix__cell{opacity:1 !important;animation:none !important}
  .cv-matrix .cv-matrix__cell.is-covered::after{animation:none !important;transform:translate(-50%,-50%) !important}
}
.cv-matrix__note{margin-top:30px;max-width:62ch;font-family:var(--font-mono);font-size:13px;
  line-height:1.6;color:var(--taupe)}

/* =====================================================================
   C.A.S.H. — Concept · Angle · Style · Hook (deck slide 6)
   ===================================================================== */
.cv-cash__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(196px,1fr));gap:20px}
.cv-cash__card{border-radius:var(--r-lg);border:1px solid var(--glass-border-soft);background:var(--glass-fill);
  padding:26px 26px 30px;transition:border-color var(--dur) var(--ease-out),background var(--dur) var(--ease-out),transform var(--dur) var(--ease-out)}
.cv-cash__card:hover{border-color:var(--glass-border);background:var(--glass-fill-strong);transform:translateY(-2px)}
.cv-cash__letter{display:block;font-family:var(--font-display);font-weight:800;font-size:62px;line-height:.85;
  letter-spacing:-0.04em;margin-bottom:20px}
.cv-cash__name{font-family:var(--font-display);font-size:20px;font-weight:700;letter-spacing:-0.02em;
  margin:0 0 8px;display:flex;flex-direction:column;gap:4px}
.cv-cash__role{font-family:var(--font-mono);font-size:11.5px;font-weight:500;letter-spacing:.03em;color:var(--amber)}
.cv-cash__d{font-size:14px;line-height:1.55;color:var(--taupe);margin:0}

/* =====================================================================
   TOOLKIT — ABCDE · 12 angles · style library (deck slide 7)
   ===================================================================== */
.cv-toolkit__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(252px,1fr));gap:20px;align-items:start}
.cv-tk{border-radius:var(--r-lg);border:1px solid var(--glass-border-soft);background:var(--glass-fill);padding:28px 28px 30px}
.cv-tk__tag{font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.16em;
  text-transform:uppercase;color:var(--taupe-dim)}
.cv-tk__title{font-family:var(--font-display);font-size:23px;font-weight:700;letter-spacing:-0.02em;margin:10px 0 20px}
.cv-tk__abcde{margin:0;padding:0}
.cv-tk__pair{display:grid;grid-template-columns:6.4rem 1fr;gap:10px;align-items:baseline;
  padding:10px 0;border-top:1px solid var(--glass-border-soft)}
.cv-tk__pair:first-child{border-top:0;padding-top:0}
.cv-tk__pair dt{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--cream)}
.cv-tk__pair dd{margin:0;font-size:13px;line-height:1.4;color:var(--taupe)}
.cv-tk__angles{list-style:none;margin:0;padding:0}
.cv-tk__angles li{font-size:14px;line-height:1.4;color:var(--cream-dim);padding:8px 0;
  border-top:1px solid var(--glass-border-soft)}
.cv-tk__angles li:first-child{border-top:0;padding-top:0}
.cv-tk__fmt{font-family:var(--font-mono);font-size:11.5px;font-weight:600;letter-spacing:.08em;
  text-transform:uppercase;color:var(--amber);margin:20px 0 12px}
.cv-tk__fmt:first-of-type{margin-top:0}
.cv-tk__fmt span{color:var(--taupe-dim);font-weight:500;text-transform:none;letter-spacing:.02em}
.cv-tk__chips{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:8px}
.cv-tk__chips li{font-family:var(--font-mono);font-size:12px;letter-spacing:.01em;color:var(--taupe);
  padding:6px 12px;border-radius:var(--r-pill);border:1px solid var(--glass-border-soft);background:var(--glass-fill)}

/* =====================================================================
   APPROACH — the POV moment, its own art direction
   ===================================================================== */
.cv-approach{position:relative;overflow:hidden;padding:128px 0;text-align:left}
.cv-approach__glow{position:absolute;left:18%;top:50%;transform:translate(-50%,-50%);
  width:1000px;height:680px;pointer-events:none;
  background:radial-gradient(closest-side,rgba(253,120,80,.18),rgba(16,11,9,0))}
.cv-approach .wrap{position:relative}
.cv-approach__quote{font-family:var(--font-display);font-weight:800;
  font-size:clamp(2rem,1.1rem + 3.6vw,3.4rem);line-height:1.08;letter-spacing:-0.03em;
  color:var(--cream);margin:0;max-width:20ch;text-wrap:balance;border:0;quotes:none}
.cv-approach__body{margin:28px 0 0;max-width:62ch;font-size:var(--t-body-lg);line-height:1.66;
  color:var(--cream-dim);text-wrap:pretty}
.cv-approach__cite{margin:22px 0 0;font-family:var(--font-mono);font-size:13px;letter-spacing:.03em;color:var(--taupe)}
.cv-approach__cite em{color:var(--cream-dim);font-style:italic}
.cv-approach__cta{margin-top:38px}
.article-link{display:grid;grid-template-columns:1fr auto;grid-template-areas:"kick arr" "title arr";
  column-gap:30px;row-gap:7px;align-items:center;max-width:620px;padding:24px 30px;
  border-radius:var(--r-lg);border:1px solid var(--glass-border);background:var(--glass-fill-strong);
  text-decoration:none;box-shadow:var(--sh-card);
  transition:border-color var(--dur) var(--ease-out),background var(--dur) var(--ease-out),
    transform var(--dur) var(--ease-out),box-shadow var(--dur) var(--ease-out)}
.article-link:hover{border-color:var(--amber);background:var(--glass-fill);transform:translateY(-2px);box-shadow:var(--sh-glow)}
.article-link__kick{grid-area:kick;font-family:var(--font-mono);font-size:11px;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;color:var(--amber)}
.article-link__title{grid-area:title;font-family:var(--font-display);font-weight:700;letter-spacing:-0.02em;
  font-size:clamp(1.2rem,.95rem + .8vw,1.55rem);line-height:1.15;color:var(--cream)}
.article-link__arr{grid-area:arr;align-self:center;font-size:26px;color:var(--coral);
  transition:transform var(--dur) var(--ease-out)}
.article-link:hover .article-link__arr{transform:translateX(5px)}

/* =====================================================================
   REFERENCES — on-the-record testimonials (featured + compact)
   ===================================================================== */
.cv-refs__grid{display:grid;grid-template-columns:1.62fr 1fr;gap:20px;align-items:stretch}
.cv-ref{position:relative;margin:0;border-radius:var(--r-lg);background:var(--glass-fill);
  border:1px solid var(--glass-border-soft);padding:34px 34px 30px;overflow:hidden;
  display:flex;flex-direction:column;
  transition:border-color var(--dur) var(--ease-out),background var(--dur) var(--ease-out),
    transform var(--dur) var(--ease-out)}
.cv-ref:hover{border-color:var(--glass-border);background:var(--glass-fill-strong);transform:translateY(-2px)}
.cv-ref__mark{display:block;align-self:flex-start;font-family:var(--font-display);font-weight:800;
  font-size:52px;line-height:1;
  background:var(--grad-dusk-h);-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;opacity:.55;margin-bottom:-6px}
.cv-ref__quote{margin:0;border:0;padding:0;font-family:var(--font-sans);font-weight:400;
  font-size:16px;line-height:1.62;color:var(--cream-dim)}
/* featured card — soft gradient wash + brighter, longer-form quote */
.cv-ref.is-feature::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(70% 90% at 90% 6%,rgba(253,140,89,.10),rgba(16,11,9,0) 60%)}
.cv-ref.is-feature .cv-ref__quote{font-size:16.5px;color:var(--cream);max-width:62ch}
/* compact card — short, punchy quote in display type, vertically centered */
.cv-ref:not(.is-feature) .cv-ref__quote{margin:auto 0;font-family:var(--font-display);
  font-weight:700;font-size:23px;line-height:1.34;letter-spacing:-0.015em;color:var(--cream)}
/* pulled metrics (featured) */
.cv-ref__stats{list-style:none;display:flex;flex-wrap:wrap;gap:12px;margin:26px 0 0;padding:0}
.cv-ref__stat{flex:1 1 120px;border-radius:var(--r-md);background:var(--glass-fill);
  border:1px solid var(--glass-border-soft);padding:15px 16px;display:flex;flex-direction:column;gap:6px}
.cv-ref__fig{font-family:var(--font-display);font-weight:800;font-size:26px;line-height:1;letter-spacing:-0.02em}
.cv-ref__statlbl{font-size:11.5px;line-height:1.35;color:var(--taupe)}
/* attribution footer */
.cv-ref__who{display:flex;align-items:center;gap:14px;margin-top:26px;padding-top:20px;
  border-top:1px solid var(--glass-border-soft)}
.cv-ref__avatar{width:54px;height:54px;border-radius:50%;object-fit:cover;flex:none;
  box-shadow:0 0 0 1px var(--glass-border),0 0 0 4px rgba(247,236,226,.03)}
.cv-ref__id{display:flex;flex-direction:column;gap:3px;min-width:0}
.cv-ref__name{font-family:var(--font-display);font-weight:700;font-size:16px;letter-spacing:-0.01em;color:var(--cream)}
.cv-ref__role{font-family:var(--font-mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--taupe)}

/* =====================================================================
   CONTACT — closing CTA (reuses base .cta / .access)
   ===================================================================== */
.cv-contact .cv-contact__eyebrow{justify-content:center;margin-bottom:20px}
.cv-contact h2{font-size:clamp(2rem,1.2rem + 3vw,3.25rem)}
.cv-contact form{display:contents}
.cv-contact .access input::placeholder{color:var(--taupe)}

/* =====================================================================
   FOOTER
   ===================================================================== */
.cv-footer{border-top:1px solid var(--glass-border-soft);padding:56px 0 52px;margin-top:40px}
.cv-footer__grid{display:flex;justify-content:space-between;align-items:flex-start;gap:40px;flex-wrap:wrap}
.cv-footer__legal{font-size:13px;color:var(--taupe);margin:22px 0 0;max-width:34ch}
.cv-footer__contact{display:flex;flex-direction:column}
.cv-footer__contact .eyebrow{margin-bottom:6px}
.cv-footer__contact a{color:var(--cream-dim);font-size:15px;margin-top:10px;
  transition:color var(--dur) var(--ease-out)}
.cv-footer__contact a:hover{color:var(--amber)}

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media (max-width:1040px){
  .cv-hero__grid{gap:40px}
  .cv-proof__grid{grid-template-columns:.9fr 1.1fr;gap:44px}
}
@media (max-width:900px){
  /* Lead with identity + claim + CTA; the portrait and the stat ledger
     follow as proof. A face is not proof, and the name has to land first
     on a page built to convince a skeptical founder in under a minute. */
  .cv-hero{min-height:auto;padding-top:140px;padding-bottom:80px}
  .cv-hero__grid{grid-template-columns:1fr;gap:34px}
  .cv-hero__copy{max-width:none;order:0}
  .cv-hero__figure{order:1;min-height:0;margin:0}
  .cv-portrait{width:min(100%,330px);margin:0 auto}
  .cv-heroledger{position:static;width:100%;max-width:400px;margin:20px auto 0;left:auto;bottom:auto}
  .cv-ring{top:30%;right:50%}
  .cv-hero__tagline{max-width:none}

  .cv-profile{grid-template-columns:1fr;gap:20px}
  .cv-profile__head{max-width:none}

  .cv-logos{grid-template-columns:repeat(3,1fr);gap:20px}

  .cv-proof__grid{grid-template-columns:1fr;gap:36px}
  .cv-proof__lead{position:static}
  .cv-anchor{margin-top:26px}

  .cv-bento{grid-template-columns:1fr}
  .cv-bento > :nth-child(n){grid-column:auto;grid-row:auto}

  .cv-refs__grid{grid-template-columns:1fr;gap:16px}
  .cv-ref{padding:28px 26px 26px}
  .cv-ref:not(.is-feature) .cv-ref__quote{margin:0 0 4px;font-size:21px}

  .cv-approach{padding:88px 0}
  .cv-approach__glow{left:50%}

  .cv-pipeline{grid-template-columns:repeat(2,1fr)}
  .cv-pipeline__step::after{display:none}
  .cv-loop{grid-template-columns:1fr;gap:24px}
  .cv-matrix__col{font-size:9.5px}
  .cv-matrix__cell{min-height:48px}
  /* match anchor offset to the shorter mobile nav (84px) */
  section[id], header[id]{scroll-margin-top:96px}
}
@media (max-width:560px){
  .nav-inner{height:72px}
  section[id], header[id]{scroll-margin-top:84px}
  /* Keep the wordmark (SPECTRAL + CONSULTING) on phones. A smaller mark, the
     hairline divider dropped (the brand's stacked lockup omits it too), and a
     compact CTA let the lockup and button share the row cleanly down to 360px. */
  .nav .ds-logo{--logo-mark:28px !important}
  .nav .ds-logo__rule{display:none}
  .nav-links .btn{padding:8px 14px;font-size:13px}
  .eyebrow{white-space:normal}
  .cv-hero{padding-top:120px}
  .cv-logos{grid-template-columns:repeat(2,1fr)}
  .cv-ledger__row{grid-template-columns:1fr;gap:6px;padding:18px 0}
  .cv-ledger__label{align-self:start}
  .cv-stack{gap:10px}
  .cv-pipeline{grid-template-columns:1fr}
  .cv-loop__rules li{flex-direction:column;gap:3px}
  .cv-loop__sig{width:auto}
  .cv-matrix__grid{grid-template-columns:minmax(66px,.85fr) repeat(5,1fr);gap:4px}
  .cv-matrix__rowhead{font-size:12px;padding-right:7px}
  .cv-matrix__col{font-size:8px;padding-bottom:7px}
  .cv-matrix__cell{min-height:38px}
  .cv-cash__letter{font-size:54px}
  .cv-footer__grid{flex-direction:column;gap:28px}
}
