/* CHL Draft → NHL Draft translation page. Self-contained: lab base layer + page styles.
   Ported from the lab prototype (lab/chl-translation.html + lab/lab.css) into production. */
/* ============================================================
   LAB design system v2 — "broadcast desk meets scouting lab"
   Editorial sports-analytics, cinematic motion. Self-contained.
   ============================================================ */
:root{
  --ink:#0a1424; --ink-2:#1b2c47; --muted:#5a6b86; --muted-2:#8a9bbd;
  --rink:#ffffff; --line:#dce6f5; --line-2:#c4d3ea;
  --blue:#1d5fff; --blue-2:#3b82f6; --blue-dark:#1145c9; --blue-deep:#0b2a7a; --blue-glow:#69a0ff;
  --cyan:#13c2d8; --gold:#f0a808; --gold-deep:#b87500;
  --red:#f0314e; --red-deep:#c81537; --green:#0bb07a; --green-deep:#077a55; --purple:#7c5cff;
  --surface:#ffffff; --surface-2:#f4f8ff; --surface-3:#eaf1fd; --page:#eef3fb;
  --glass:rgba(255,255,255,.66);
  --shadow-sm:0 8px 22px -14px rgba(11,28,60,.4);
  --shadow:0 26px 60px -34px rgba(11,28,60,.5);
  --shadow-lg:0 50px 110px -40px rgba(11,28,60,.55);
  --shadow-blue:0 24px 60px -26px rgba(29,95,255,.55);
  --radius:14px; --radius-lg:22px; --radius-xl:30px;
  --serif:"Newsreader",Georgia,serif; --body:"Instrument Sans",system-ui,sans-serif; --mono:"JetBrains Mono",ui-monospace,monospace;
  --ease:cubic-bezier(.22,1,.36,1); --ease-spring:cubic-bezier(.34,1.56,.64,1);
}
[data-theme="dark"]{
  --ink:#eef4ff; --ink-2:#c2d2ec; --muted:#8ba0c4; --muted-2:#5f7398;
  --rink:#101e38; --line:rgba(150,180,230,.14); --line-2:rgba(150,180,230,.24);
  --blue:#5b8cff; --blue-2:#3b82f6; --blue-dark:#3b6fe0; --blue-glow:#7fb0ff;
  --surface:#0f1d36; --surface-2:#14233f; --surface-3:#18294a; --page:#070e1d;
  --glass:rgba(15,29,54,.6);
  --shadow-sm:0 10px 26px -16px rgba(0,0,0,.7);
  --shadow:0 30px 64px -30px rgba(0,0,0,.78);
  --shadow-lg:0 60px 120px -40px rgba(0,0,0,.85);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--page);color:var(--ink);font-family:var(--body);-webkit-font-smoothing:antialiased;overflow-x:hidden;transition:background .4s,color .4s}
body::before{/* atmospheric mesh */content:"";position:fixed;inset:0;z-index:-2;background:
  radial-gradient(60% 50% at 12% 0%,rgba(29,95,255,.12),transparent 70%),
  radial-gradient(50% 45% at 100% 8%,rgba(19,194,216,.10),transparent 70%),
  radial-gradient(55% 50% at 80% 100%,rgba(124,92,255,.08),transparent 70%);pointer-events:none}
body::after{/* fine grain */content:"";position:fixed;inset:0;z-index:-1;opacity:.4;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.5'/%3E%3C/svg%3E");mix-blend-mode:soft-light}
[data-theme="dark"] body::after{opacity:.5;mix-blend-mode:overlay}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{margin:0;letter-spacing:-.02em}
.wrap{max-width:1240px;margin:0 auto;padding:0 1.5rem}
.mono{font-family:var(--mono)} .muted{color:var(--muted)} .serif{font-family:var(--serif)}

/* ===== motion utilities ===== */
/* reveals are driven by a CSS load animation (always plays — no JS/observer
   dependency), staggered via --i. Robust in any render context. */
.reveal{opacity:0;animation:revIn .72s var(--ease) both;animation-delay:calc(var(--i,0)*70ms)}
@keyframes revIn{from{opacity:0;transform:translateY(22px);filter:blur(3px)}to{opacity:1;transform:none;filter:none}}
.reveal.in{opacity:1}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1!important;transform:none!important;filter:none!important;animation:none}
  *,*::before,*::after{animation-duration:.001s!important;animation-iteration-count:1!important;transition-duration:.001s!important;scroll-behavior:auto!important}}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
@keyframes shimmer{100%{background-position:200% 0}}
@keyframes pulse-dot{0%,100%{opacity:1}50%{opacity:.35}}
@keyframes sweepIn{from{transform:translateX(28px) scale(.97);opacity:0}to{transform:none;opacity:1}}

/* ===== top ribbon + nav ===== */
.lab-flag{background:linear-gradient(90deg,var(--gold),#ffd66e,var(--gold));background-size:200% 100%;animation:shimmer 6s linear infinite;color:#231700;font:800 .68rem/1 var(--mono);letter-spacing:.08em;text-align:center;padding:.45rem;text-transform:uppercase}
nav.lab-nav{position:sticky;top:0;z-index:50;backdrop-filter:blur(18px) saturate(1.4);background:color-mix(in srgb,var(--page) 78%,transparent);border-bottom:1px solid var(--line)}
.lab-row{display:flex;align-items:center;gap:.8rem;height:62px}
.brand{display:flex;align-items:center;gap:.5rem;font-weight:800;font-size:1.05rem}
.brand b{color:var(--blue)}
.brand .lab-pill{font:800 .58rem var(--mono);background:linear-gradient(135deg,var(--blue),var(--blue-deep));color:#fff;padding:.18rem .42rem;border-radius:6px;letter-spacing:.1em;box-shadow:var(--shadow-blue)}
.lab-links{display:flex;align-items:center;gap:.12rem;margin-left:.7rem;flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;min-width:0;scroll-behavior:smooth;
  -webkit-mask-image:linear-gradient(90deg,transparent 0,#000 14px,#000 calc(100% - 26px),transparent 100%);mask-image:linear-gradient(90deg,transparent 0,#000 14px,#000 calc(100% - 26px),transparent 100%)}
.lab-links::-webkit-scrollbar{display:none}
.lab-links a{scroll-margin-inline:24px}
.lab-links a{position:relative;padding:.4rem .62rem;border-radius:999px;font-weight:600;font-size:.82rem;color:var(--ink-2);white-space:nowrap;transition:.2s var(--ease)}
.lab-links a:hover{color:var(--blue)}
.lab-links a.active{color:#fff;background:linear-gradient(135deg,var(--blue),var(--blue-dark));box-shadow:var(--shadow-blue)}
.nav-right{margin-left:auto;display:flex;gap:.5rem;align-items:center}
.iconbtn{width:36px;height:36px;border:1px solid var(--line);background:var(--surface);color:var(--ink-2);cursor:pointer;display:grid;place-items:center;border-radius:10px;font-size:1.02rem;transition:.2s var(--ease)}
.iconbtn:hover{color:var(--blue);border-color:var(--blue);transform:translateY(-1px)}

/* ===== hero / page head ===== */
.hero{position:relative;padding:3rem 0 1.6rem;overflow:hidden}
.hero .eyebrow{display:inline-flex;align-items:center;gap:.5rem;font:800 .72rem var(--mono);letter-spacing:.16em;text-transform:uppercase;color:var(--blue)}
.hero .eyebrow::before{content:"";width:26px;height:2px;background:linear-gradient(90deg,var(--blue),transparent)}
.hero h1{font-family:var(--serif);font-weight:600;font-size:clamp(2.1rem,5.4vw,3.9rem);line-height:1.0;margin:.6rem 0 .5rem;letter-spacing:-.025em}
.hero h1 em{font-style:italic;color:var(--blue);position:relative}
.hero h1 .stroke{-webkit-text-stroke:1.4px var(--ink);color:transparent}
[data-theme="dark"] .hero h1 .stroke{-webkit-text-stroke-color:var(--ink)}
.hero p.lead{color:var(--muted);max-width:64ch;font-size:1.05rem;line-height:1.6;margin:.2rem 0 0}
.hero p.lead b{color:var(--ink-2)}

/* live stat ticker */
.ticker{display:flex;flex-wrap:wrap;gap:.5rem 2rem;margin-top:1.3rem;align-items:baseline}
.ticker .stat{display:flex;flex-direction:column}
.ticker .stat b{font:800 1.7rem var(--mono);line-height:1;letter-spacing:-.02em}
.ticker .stat span{font:600 .68rem var(--mono);color:var(--muted);text-transform:uppercase;letter-spacing:.1em;margin-top:.25rem}
.live-dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 0 4px color-mix(in srgb,var(--green) 22%,transparent);animation:pulse-dot 2s infinite;margin-right:.45rem;vertical-align:middle}
.live-dot.amber{background:var(--gold);box-shadow:0 0 0 4px color-mix(in srgb,var(--gold) 22%,transparent)}
.real-note{display:inline-flex;align-items:center;gap:.5rem;margin-top:1.1rem;font:600 .78rem var(--body);color:var(--muted);background:var(--surface);border:1px solid var(--line);padding:.4rem .7rem;border-radius:999px;box-shadow:var(--shadow-sm)}

/* ===== controls ===== */
.controls{display:flex;flex-wrap:wrap;gap:.6rem;align-items:center;margin:1.4rem 0}
.seg{position:relative;display:inline-flex;background:var(--surface-2);border:1px solid var(--line);border-radius:999px;padding:4px;box-shadow:inset 0 1px 3px rgba(11,28,60,.05)}
.seg button{position:relative;z-index:1;border:0;background:transparent;color:var(--ink-2);font:700 .82rem var(--body);padding:.46rem .95rem;border-radius:999px;cursor:pointer;transition:color .25s;white-space:nowrap}
.seg button.active{color:#fff}
.seg .glider{position:absolute;top:4px;bottom:4px;border-radius:999px;background:linear-gradient(135deg,var(--blue),var(--blue-dark));box-shadow:var(--shadow-blue);transition:left .35s var(--ease-spring),width .35s var(--ease-spring);z-index:0}
.field{display:inline-flex;align-items:center;gap:.45rem;font:600 .8rem var(--body);color:var(--muted)}
.field select,.field input{font:600 .82rem var(--body);color:var(--ink);background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:.42rem .6rem;transition:.2s}
.field input:focus,.field select:focus{outline:0;border-color:var(--blue);box-shadow:0 0 0 4px color-mix(in srgb,var(--blue) 14%,transparent)}
.lens-desc{font-size:.86rem;color:var(--muted);min-height:1.2rem;margin:-.4rem 0 1.1rem;transition:.3s}
.lens-desc b{color:var(--ink-2)}

/* ===== board ===== */
.board{display:flex;flex-direction:column;gap:.55rem}
.brow{position:relative;display:grid;grid-template-columns:58px 48px 1fr auto;gap:.85rem;align-items:center;padding:.7rem .9rem;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);cursor:pointer;transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s;will-change:transform}
.brow:hover{border-color:color-mix(in srgb,var(--blue) 50%,var(--line));box-shadow:var(--shadow);transform:translateY(-2px)}
.brow::before{content:"";position:absolute;left:0;top:10%;bottom:10%;width:3px;border-radius:3px;background:linear-gradient(var(--accent-a,var(--blue)),var(--accent-b,var(--blue-deep)));opacity:.85}
.medallion{display:flex;flex-direction:column;align-items:center;justify-content:center}
.medallion .rk{font:800 1.4rem var(--mono);line-height:1;letter-spacing:-.03em}
.medallion .delta{font:800 .64rem var(--mono);margin-top:.2rem;display:flex;align-items:center;gap:.1rem}
.up{color:var(--green)} .down{color:var(--red)} .flat{color:var(--muted-2)}
.av{position:relative;width:46px;height:46px;border-radius:13px;overflow:hidden;background:linear-gradient(140deg,var(--blue),var(--blue-deep));display:grid;place-items:center;color:#fff;font:800 .82rem var(--mono);box-shadow:var(--shadow-sm)}
.av img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 16%}
.pinfo{min-width:0}
.pinfo .nm{font-weight:800;font-size:1.02rem;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pinfo .sub{color:var(--muted);font-size:.78rem;margin:.08rem 0 .35rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pinfo .chips{display:flex;flex-wrap:wrap;gap:.3rem}
.bscore{display:flex;align-items:center;gap:.9rem}
/* stacked mini-breakdown bar */
.stack{width:118px;height:34px;display:flex;border-radius:8px;overflow:hidden;border:1px solid var(--line);background:var(--surface-2)}
.stack i{height:100%;transition:width .6s var(--ease),flex-basis .6s var(--ease)}
.stack i.s-consensus{background:var(--blue)} .stack i.s-production{background:var(--green)} .stack i.s-scoringUpside{background:var(--gold)}
.stack i.s-trajectory{background:var(--cyan)} .stack i.s-leagueDifficulty{background:var(--purple)} .stack i.s-size{background:var(--muted-2)}
.bignum{text-align:right;min-width:64px}
.bignum .v{font:800 1.6rem var(--mono);line-height:1;letter-spacing:-.03em}
.bignum .l{font:700 .6rem var(--mono);color:var(--muted-2);text-transform:uppercase;letter-spacing:.1em;margin-top:.2rem}

/* chips */
.chip{display:inline-flex;align-items:center;gap:.25rem;font:700 .64rem var(--mono);padding:.2rem .45rem;border-radius:7px;letter-spacing:.02em;white-space:nowrap;line-height:1}
.chip.pos{background:color-mix(in srgb,var(--blue) 12%,transparent);color:var(--blue-dark)}
.chip.conf-high{background:color-mix(in srgb,var(--green) 16%,transparent);color:var(--green-deep)}
.chip.conf-medium{background:color-mix(in srgb,var(--gold) 18%,transparent);color:var(--gold-deep)}
.chip.conf-low,.chip.conf-volatile{background:color-mix(in srgb,var(--red) 14%,transparent);color:var(--red-deep)}
.chip.risk{background:color-mix(in srgb,var(--red) 12%,transparent);color:var(--red-deep)}
.chip.po-spiked{background:color-mix(in srgb,var(--green) 18%,transparent);color:var(--green-deep)}
.chip.po-held{background:color-mix(in srgb,var(--blue) 12%,transparent);color:var(--blue-dark)}
.chip.po-fell{background:color-mix(in srgb,var(--red) 14%,transparent);color:var(--red-deep)}

/* movers bar */
.movers{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.2rem}
.mvcard{padding:1rem 1.15rem;border-radius:var(--radius-lg);background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow-sm)}
.mvcard h4{font:800 .72rem var(--mono);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.7rem;display:flex;align-items:center;gap:.4rem}
.mvrow{display:flex;align-items:center;gap:.5rem;padding:.32rem 0;font-size:.86rem;cursor:pointer}
.mvrow:hover .mvn{color:var(--blue)}
.mvrow .mvn{font-weight:700;flex:1;transition:.15s}
.mvrow .mvd{font:800 .76rem var(--mono)}

/* ===== scout cards (holographic, 3d flip) ===== */
.cardgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(186px,1fr));gap:1rem}
.flip3d{perspective:1200px;aspect-ratio:3/4.1;cursor:pointer}
.flip3d .inner{position:relative;width:100%;height:100%;transition:transform .7s var(--ease-spring);transform-style:preserve-3d}
.flip3d.flipped .inner{transform:rotateY(180deg)}
.flip3d .face,.flip3d .back{position:absolute;inset:0;backface-visibility:hidden;border-radius:18px;overflow:hidden;border:1px solid rgba(255,255,255,.18);box-shadow:var(--shadow)}
.flip3d .face{display:grid;place-items:center;color:#fff}
.gwash{position:absolute;inset:0}
.gwash::after{content:"";position:absolute;inset:0;background:
  repeating-linear-gradient(115deg,rgba(255,255,255,.0) 0 8px,rgba(255,255,255,.06) 8px 16px);mix-blend-mode:overlay}
.holo .gwash::before{content:"";position:absolute;inset:-40%;background:conic-gradient(from 0deg,#ff5e8a,#ffd166,#5eead4,#60a5fa,#c084fc,#ff5e8a);filter:blur(22px);opacity:.5;mix-blend-mode:color-dodge;animation:spin 7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.gtop{position:absolute;top:.7rem;left:.8rem;right:.8rem;display:flex;justify-content:space-between;font:800 .66rem var(--mono);z-index:3;text-shadow:0 1px 8px rgba(0,0,0,.4)}
.gletter{position:relative;z-index:3;font-family:var(--serif);font-weight:600;font-size:4.6rem;line-height:1;text-shadow:0 6px 30px rgba(0,0,0,.45)}
.gsub{position:absolute;bottom:3.1rem;left:.8rem;right:.8rem;z-index:3;font:800 .9rem var(--mono);text-align:center;opacity:.92}
.gname{position:absolute;bottom:.7rem;left:.8rem;right:.8rem;z-index:3;font-weight:800;font-size:.94rem;text-shadow:0 1px 8px rgba(0,0,0,.55)}
.gname small{display:block;font-weight:600;font-size:.68rem;opacity:.82;margin-top:.1rem}
.flip3d .back{transform:rotateY(180deg);background:var(--surface);color:var(--ink);padding:.9rem;display:flex;flex-direction:column}
.back h5{font:800 .68rem var(--mono);text-transform:uppercase;letter-spacing:.06em;color:var(--blue);margin-bottom:.6rem}

/* contribution bars */
.bars{display:flex;flex-direction:column;gap:.55rem}
.bar-row{display:grid;grid-template-columns:96px 1fr 40px;align-items:center;gap:.6rem;font-size:.76rem}
.bar-row .bl{color:var(--muted);font-weight:600;text-transform:capitalize}
.bar-track{height:10px;border-radius:999px;background:var(--surface-3);overflow:hidden}
.bar-fill{height:100%;border-radius:999px;width:0;transition:width 1s var(--ease)}
.bar-row .bv{font:800 .76rem var(--mono);text-align:right}

/* ===== dials / funnel ===== */
.dials{display:flex;gap:1rem;flex-wrap:wrap;align-items:center}
.dial{display:flex;flex-direction:column;align-items:center;gap:.3rem;width:104px}
.dial svg{width:96px;height:96px}
.dring-bg{fill:none;stroke:var(--surface-3);stroke-width:8}
.dring{fill:none;stroke-width:8;stroke-linecap:round;transform:rotate(-90deg);transform-origin:center;transition:stroke-dashoffset 1.1s var(--ease)}
.dial .dctr{margin-top:-62px;text-align:center;pointer-events:none}
.dial .dval{font:800 1.35rem var(--mono);letter-spacing:-.03em}
.dial .dval small{font-size:.58em;opacity:.6}
.dial .dlab{margin-top:34px;text-align:center}
.dial .dlab b{font:800 .76rem var(--body);text-transform:uppercase;letter-spacing:.05em}
.dial .dlab span{display:block;font:600 .64rem var(--body);color:var(--muted-2)}
.nhle-num{display:flex;flex-direction:column;justify-content:center;padding-left:1rem;border-left:1px solid var(--line)}
.nhle-num b{font:800 2.4rem var(--mono);line-height:1;letter-spacing:-.04em;background:linear-gradient(135deg,var(--blue),var(--cyan));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.nhle-num span{font:700 .64rem var(--mono);color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-top:.25rem}

/* sparkline — self-draws on insert (no observer needed) */
.spark path.l{fill:none;stroke:var(--blue);stroke-width:2.4;stroke-linejoin:round;stroke-linecap:round;stroke-dasharray:var(--len,300);stroke-dashoffset:var(--len,300);animation:draw 1.1s var(--ease) .15s both}
@keyframes draw{to{stroke-dashoffset:0}}
.spark circle{fill:var(--blue);opacity:0;animation:fadeIn .4s .95s both}
.spark .area{fill:url(#sparkgrad);opacity:0;animation:fadeArea .7s .3s both}
@keyframes fadeIn{to{opacity:1}}@keyframes fadeArea{to{opacity:.18}}

/* ===== comps spectrum / poles ===== */
.spectrum{position:relative;height:54px;border-radius:12px;margin:.4rem 0 1.4rem;background:linear-gradient(90deg,var(--red) 0%,var(--gold) 50%,var(--green) 100%);box-shadow:inset 0 0 0 1px rgba(255,255,255,.2)}
.spectrum .seg-lab{position:absolute;top:-1.3rem;font:700 .62rem var(--mono);text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}
.spectrum .pin{position:absolute;top:50%;transform:translate(-50%,-50%);width:20px;height:20px;border-radius:50%;background:#fff;border:3px solid var(--ink);box-shadow:0 4px 12px rgba(0,0,0,.3);transition:left 1s var(--ease)}
.spectrum .ptick{position:absolute;top:0;bottom:0;width:2px;background:rgba(255,255,255,.6)}
.gauge{display:flex;align-items:center;gap:1rem}
.gauge svg{width:104px;height:104px;flex:0 0 auto}
.gauge .gv{font:800 1.7rem var(--mono);fill:var(--ink)}
.poles{display:grid;grid-template-columns:repeat(auto-fit,minmax(168px,1fr));gap:.7rem}
.pole{position:relative;border:1px solid var(--line);border-radius:var(--radius);padding:.9rem;background:var(--surface-2);overflow:hidden;transition:transform .25s var(--ease)}
.pole:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.pole .ptag{font:800 .6rem var(--mono);text-transform:uppercase;letter-spacing:.06em;padding:.22rem .5rem;border-radius:7px;display:inline-block;margin-bottom:.55rem}
.pole.star{background:linear-gradient(160deg,color-mix(in srgb,var(--green) 14%,var(--surface)),var(--surface-2))}
.pole.star .ptag{background:var(--green);color:#fff}
.pole.role .ptag{background:color-mix(in srgb,var(--blue) 16%,transparent);color:var(--blue-dark)}
.pole.miss .ptag{background:color-mix(in srgb,var(--red) 14%,transparent);color:var(--red-deep)}
.pole .pn{font-weight:800;font-size:1.04rem;letter-spacing:-.01em}
.pole .pmeta2{font-size:.74rem;color:var(--muted);margin-top:.15rem}
.pole .career{margin-top:.6rem;font:800 .92rem var(--mono)}
.pole .career small{display:block;font:600 .62rem var(--body);color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-top:.12rem}
.careerbar{height:5px;border-radius:999px;background:var(--surface-3);margin-top:.5rem;overflow:hidden}
.careerbar i{display:block;height:100%;border-radius:999px;width:0;transition:width 1.1s var(--ease)}

/* ===== redraft wall ===== */
.rd-hero-band{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.4rem}
.rd-spot{position:relative;border-radius:var(--radius-lg);padding:1.1rem 1.2rem;color:#fff;overflow:hidden;box-shadow:var(--shadow)}
.rd-spot.steal{background:linear-gradient(140deg,var(--green),var(--green-deep))}
.rd-spot.bust{background:linear-gradient(140deg,var(--red),var(--red-deep))}
.rd-spot .lbl{font:800 .66rem var(--mono);text-transform:uppercase;letter-spacing:.1em;opacity:.85}
.rd-spot .big{font-family:var(--serif);font-weight:600;font-size:1.7rem;margin:.3rem 0 .1rem;line-height:1}
.rd-spot .mv{font:800 .9rem var(--mono);display:inline-flex;align-items:center;gap:.3rem;margin-top:.5rem;background:rgba(255,255,255,.2);padding:.2rem .55rem;border-radius:999px}
.wall{display:flex;flex-direction:column;gap:.4rem}
.wrow{display:grid;grid-template-columns:54px 26px 1fr auto auto;gap:.7rem;align-items:center;padding:.55rem .8rem;background:var(--surface);border:1px solid var(--line);border-radius:11px;transition:transform .3s var(--ease),box-shadow .3s}
.wrow:hover{transform:translateX(3px);box-shadow:var(--shadow-sm)}
.wrow .wn{font:800 1.15rem var(--mono);color:var(--ink)}
.wrow .teamdot{width:10px;height:10px;border-radius:3px;background:var(--blue)}
.wrow .pname{font-weight:700}
.wrow .pname small{display:block;color:var(--muted);font-weight:500;font-size:.72rem}
.wrow .career2{font:700 .8rem var(--mono);color:var(--ink-2);text-align:right}
.delta-pill{font:800 .72rem var(--mono);padding:.2rem .5rem;border-radius:999px;display:inline-flex;align-items:center;gap:.2rem;min-width:54px;justify-content:center}
.delta-pill.steal{background:color-mix(in srgb,var(--green) 18%,transparent);color:var(--green-deep)}
.delta-pill.bust{background:color-mix(in srgb,var(--red) 16%,transparent);color:var(--red-deep)}
.delta-pill.even{background:var(--surface-3);color:var(--muted)}

/* ===== drawer ===== */
.scrim{position:fixed;inset:0;background:rgba(6,12,26,.55);backdrop-filter:blur(4px);opacity:0;pointer-events:none;transition:.3s;z-index:60}
.scrim.open{opacity:1;pointer-events:auto}
.drawer{position:fixed;top:0;right:0;height:100%;width:min(600px,96vw);background:var(--page);border-left:1px solid var(--line);box-shadow:var(--shadow-lg);transform:translateX(100%);transition:transform .42s var(--ease);z-index:61;overflow-y:auto}
.drawer.open{transform:none}
.drawer-hero{position:relative;padding:1.5rem 1.4rem 1.2rem;color:#fff;overflow:hidden}
.drawer-hero .dh-wash{position:absolute;inset:0;z-index:0}
.drawer-hero>*{position:relative;z-index:1}
.drawer-hero .dx{position:absolute;top:1rem;right:1rem;z-index:2;width:34px;height:34px;border:0;border-radius:9px;background:rgba(255,255,255,.18);color:#fff;cursor:pointer;font-size:1rem;backdrop-filter:blur(6px)}
.dh-name{font-family:var(--serif);font-weight:600;font-size:1.8rem;line-height:1.05}
.dh-sub{opacity:.85;font-size:.82rem;margin-top:.2rem}
.dh-nums{display:flex;gap:1.4rem;margin-top:1.1rem}
.dh-nums .n b{font:800 1.9rem var(--mono);line-height:1}
.dh-nums .n span{font:700 .6rem var(--mono);opacity:.8;text-transform:uppercase;letter-spacing:.08em;display:block;margin-top:.2rem}
.drawer-body{padding:1.2rem 1.4rem 3rem}
.dtabs{display:flex;gap:.2rem;background:var(--surface-2);border:1px solid var(--line);border-radius:12px;padding:4px;margin-bottom:1rem}
.dtabs button{flex:1;border:0;background:transparent;color:var(--muted);font:700 .8rem var(--body);padding:.5rem;cursor:pointer;border-radius:9px;transition:.2s}
.dtabs button.active{background:var(--surface);color:var(--blue);box-shadow:var(--shadow-sm)}
.dsection{margin-top:1.3rem}
.dsection h4{font:800 .72rem var(--mono);text-transform:uppercase;letter-spacing:.08em;color:var(--blue);margin-bottom:.7rem;display:flex;align-items:center;gap:.5rem}
.dsection h4::after{content:"";flex:1;height:1px;background:var(--line)}
.why{font-size:.88rem;line-height:1.65;color:var(--ink-2)}
.tiny{font-size:.72rem;color:var(--muted)}

/* hub */
.hub-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:1.1rem;margin:1.8rem 0 2rem}
.hub-card{position:relative;display:block;padding:1.5rem;border-radius:var(--radius-xl);background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow-sm);overflow:hidden;transition:transform .3s var(--ease),box-shadow .3s}
.hub-card::before{content:"";position:absolute;inset:0;background:radial-gradient(120% 80% at 100% 0,color-mix(in srgb,var(--hc,var(--blue)) 14%,transparent),transparent 60%);opacity:0;transition:.3s}
.hub-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:color-mix(in srgb,var(--hc,var(--blue)) 40%,var(--line))}
.hub-card:hover::before{opacity:1}
.hub-card .num{font:800 .76rem var(--mono);color:var(--hc,var(--blue));letter-spacing:.08em}
.hub-card h3{font-family:var(--serif);font-weight:600;font-size:1.45rem;margin:.5rem 0 .55rem;letter-spacing:-.02em}
.hub-card p{color:var(--muted);font-size:.9rem;line-height:1.6;margin:0}
.hub-card .tag{display:inline-flex;align-items:center;gap:.35rem;margin-top:1rem;font:700 .66rem var(--mono);padding:.24rem .55rem;border-radius:999px;background:color-mix(in srgb,var(--green) 14%,transparent);color:var(--green-deep)}
.hub-card .tag.derived{background:color-mix(in srgb,var(--gold) 16%,transparent);color:var(--gold-deep)}
.hub-card .arrow{position:absolute;right:1.3rem;bottom:1.4rem;font-size:1.3rem;color:var(--hc,var(--blue));opacity:0;transform:translateX(-6px);transition:.3s}
.hub-card:hover .arrow{opacity:1;transform:none}

/* drawer depth: bio chips, disagreement plot, production table, mini comps */
.chip.ghost{background:var(--surface-3);color:var(--muted);border:1px solid var(--line)}
.biochips{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.9rem}
.biochips span{font:700 .64rem var(--mono);background:rgba(255,255,255,.18);color:#fff;padding:.2rem .5rem;border-radius:7px;backdrop-filter:blur(4px)}
.biochips span.style{background:rgba(255,255,255,.28)}
.srcplot{position:relative;height:34px;margin-top:.4rem}
.srcline{position:absolute;left:0;right:0;top:50%;height:3px;border-radius:3px;background:linear-gradient(90deg,var(--green),var(--gold),var(--red))}
.srcdot{position:absolute;top:50%;width:11px;height:11px;border-radius:50%;background:var(--blue);border:2px solid var(--surface);transform:translate(-50%,-50%);box-shadow:0 2px 5px rgba(0,0,0,.25);transition:left .8s var(--ease)}
.srcend{position:absolute;top:-2px;font:800 .62rem var(--mono);color:var(--muted)}.srcend.l{left:0}.srcend.r{right:0}
.prodtable{width:100%;border-collapse:collapse;font-size:.8rem}
.prodtable th{text-align:left;font:700 .62rem var(--mono);text-transform:uppercase;letter-spacing:.04em;color:var(--muted);padding:.35rem .5rem;border-bottom:1px solid var(--line-2)}
.prodtable td{padding:.4rem .5rem;border-bottom:1px solid var(--line)}
.prodtable tbody tr:hover td{background:var(--surface-2)}
.compmini{display:flex;justify-content:space-between;align-items:center;gap:.6rem;padding:.5rem .2rem;border-bottom:1px solid var(--line);flex-wrap:wrap}
.compmini .cm-l{display:flex;align-items:center;gap:.4rem}
.compmini .cm-r{display:flex;align-items:center;gap:.6rem;margin-left:auto}
.cm-out{font:800 .6rem var(--mono);text-transform:uppercase;letter-spacing:.04em;padding:.14rem .4rem;border-radius:6px}
.cm-out.o-impact{background:color-mix(in srgb,var(--green) 18%,transparent);color:var(--green-deep)}
.cm-out.o-nhler{background:color-mix(in srgb,var(--blue) 16%,transparent);color:var(--blue-dark)}
.cm-out.o-miss{background:color-mix(in srgb,var(--red) 14%,transparent);color:var(--red-deep)}
.odot{display:inline-block;width:9px;height:9px;border-radius:50%}.o-impact{background:var(--green)}.o-nhler{background:var(--blue)}.o-miss{background:var(--red)}
.dsection h4{justify-content:flex-start}
.pctitem{padding:.5rem 0;border-bottom:1px solid var(--line)}
.pcthead{display:flex;justify-content:space-between;align-items:baseline;font-weight:700;font-size:.82rem}
.pcthead b{font-family:var(--mono);color:var(--blue)}
.pctgauge{height:14px;border-radius:999px;background:var(--surface-3);overflow:hidden;margin:.3rem 0}
.pctfill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--blue),var(--cyan));width:0;transition:width 1s var(--ease)}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}
.foot{color:var(--muted-2);font-size:.82rem;line-height:1.7;border-top:1px solid var(--line);padding:1.8rem 0 3rem;margin-top:2.2rem}
.skel{display:grid;place-items:center;padding:3rem;color:var(--muted);font-size:.9rem;gap:1rem}
.skel .spinner{width:34px;height:34px;border-radius:50%;border:3px solid var(--surface-3);border-top-color:var(--blue);animation:spin .8s linear infinite}
@media(max-width:760px){.movers,.rd-hero-band{grid-template-columns:1fr}.brow{grid-template-columns:48px 42px 1fr auto}.stack{display:none}.wrow{grid-template-columns:46px 1fr auto}.wrow .career2,.wrow .teamdot{display:none}}

/* ============================================================
   VISUAL LANGUAGE v4 — Webby-grade identity (additive overrides)
   ============================================================ */
:root{
  --grotesk:"Space Grotesk",var(--body);
  --blue:#2E6BFF; --blue-glow:#69A0FF; --blue-dark:#1745c9;
  --cyan:#19D3E6; --gold:#F5B100; --red:#F0314E; --green:#0BB07A;
  --dur-fast:.4s; --dur-base:.7s; --dur-slow:1.1s;
}
[data-theme="dark"]{
  --page:#060B16; --surface:#0D1626; --surface-2:#122036; --surface-3:#18294a;
  --line:rgba(150,180,230,.12); --line-2:rgba(150,180,230,.22);
  --muted:#93A8CC; --glass:rgba(13,22,38,.62);
}
/* three-voice rule: numbers are tabular mono */
.mono,[data-count],.bignum .v,.dval,.fv,.dval small,.career2,.wn,.tr-v,.tr-rk,.rk,.head b,.d-hero b,.pm-v{font-variant-numeric:tabular-nums}
/* grotesk chrome */
.eyebrow,.lab-links a,.seg button,.lens .l,.bignum .l,.nhlel,.dlab b,.dn-l,.obandtitle,.pm-lab,.cstat span,.head span,.d-sec h5,.dcl{font-family:var(--grotesk)}
/* focus ring (a11y) */
:focus-visible{outline:2px solid var(--blue);outline-offset:2px;box-shadow:0 0 0 5px color-mix(in srgb,var(--blue) 28%,transparent);border-radius:6px}
/* glass surface */
.glass{background:var(--glass);backdrop-filter:blur(20px) saturate(1.3);-webkit-backdrop-filter:blur(20px) saturate(1.3);border:1px solid var(--line);box-shadow:inset 0 1px 0 rgba(255,255,255,.06),0 26px 60px -34px rgba(0,3,10,.7)}
/* THE SWEEP scanline */
.scanline{position:absolute;left:0;right:0;top:0;height:140px;pointer-events:none;z-index:3;background:linear-gradient(180deg,transparent,color-mix(in srgb,var(--blue) 16%,transparent) 60%,color-mix(in srgb,var(--blue-glow) 32%,transparent),transparent);opacity:0;mix-blend-mode:screen}
/* dynamic-insight chips */
.insightbar{display:flex;flex-wrap:wrap;gap:.55rem;margin:.9rem 0 .2rem}
.insight-chip{display:inline-flex;align-items:center;gap:.5rem;cursor:pointer;border-radius:999px;padding:.4rem .8rem .4rem .7rem;font-family:var(--serif);font-size:.86rem;line-height:1.15;color:var(--ink);border:1px solid var(--line);background:var(--glass);backdrop-filter:blur(14px);transition:transform .2s var(--ease),border-color .2s,box-shadow .2s;text-align:left}
.insight-chip:hover{transform:translateY(-2px);border-color:color-mix(in srgb,var(--blue) 55%,var(--line));box-shadow:var(--shadow-sm)}
.insight-chip .iv{font:800 1rem var(--mono);font-variant-numeric:tabular-nums}
.insight-chip .idot{width:8px;height:8px;border-radius:50%;flex:0 0 auto;background:var(--blue)}
.insight-chip.surge .idot{background:var(--cyan)} .insight-chip.surge .iv{color:var(--cyan)}
.insight-chip.volatile .idot{background:var(--gold)} .insight-chip.volatile .iv{color:var(--gold-deep)}
.insight-chip.outcome .idot{background:var(--green)} .insight-chip.outcome .iv{color:var(--green-deep)}
.insight-chip .idot{box-shadow:0 0 8px currentColor}
.jump-flash{animation:jumpflash 1.2s var(--ease)}
@keyframes jumpflash{0%,100%{box-shadow:var(--shadow-sm)}30%{box-shadow:0 0 0 3px color-mix(in srgb,var(--blue) 60%,transparent)}}
.insight-sub{font-family:var(--serif);font-size:clamp(1rem,2vw,1.32rem);color:var(--muted);max-width:64ch;line-height:1.5;margin:.3rem 0 0}
.insight-sub b{color:var(--ink)}
/* altitude rail (scroll progress + jumps) */
.altrail{position:fixed;left:18px;top:50%;transform:translateY(-50%);z-index:45;display:flex;flex-direction:column;gap:.7rem;align-items:center}
.altrail .at{width:9px;height:9px;border-radius:50%;border:1.5px solid var(--line-2);background:transparent;cursor:pointer;padding:0;transition:.2s}
.altrail .at.on{background:var(--blue);border-color:var(--blue);box-shadow:0 0 0 4px color-mix(in srgb,var(--blue) 22%,transparent)}
@media(max-width:900px){.altrail{display:none}}
/* reduced-motion: kill the new loops too */
@media(prefers-reduced-motion:reduce){.scanline{display:none}}

/* ============================================================================
   ===== LAB v5 CARD SYSTEM =====
   Ports the LIVE /ranks premium card techniques into reusable, framework-free
   classes so every lab page can match (or beat) /ranks. Studied from
   ranks.css .rk-* (vintage cardboard) + .red-* (editorial poster) systems.

   FIVE LOAD-BEARING IDEAS (the premium "feel"):
     1) ONE accent. Set --acc ONCE on a card root (style="--acc:#1d4ed8") and
        every accent surface reads var(--acc). Never hardcode the accent twice.
     2) Three-voice type. serif (--serif) for names/big numbers, mono (--mono)
        for EVERY stat/figure, grotesk (--grotesk) for tracked uppercase labels.
        Stats in a body font is the #1 tell of a cheap card.
     3) Tight, world-tinted, negative-spread shadow (0 16px 34px -22px ...),
        never a soft grey blur. The accent only touches thin structural edges.
     4) Editorial grade NAMES, not numbers ("Franchise" not "Tier 1"). The
        .gradecard ramp encodes the live accentFor() rank->colour+name map.
     5) Designed imageless state (tinted mat + crest/flag wash + monogram), and
        real photos FADE IN over it. Most cards have no photo.

   STATIC-FIRST: every class renders complete & correct with NO animation;
   sheen/shimmer/tilt are progressive enhancement gated behind (hover:hover) +
   prefers-reduced-motion. Bars/counts are filled by LAB.finalize() as failsafe.
   Dark-capable via the existing [data-theme="dark"] token swaps — no new palette.
   ============================================================================ */

/* ---- card root tokens (per-card; --acc is the ONLY thing a call-site sets) ---- */
.cardx,.gradecard{
  /* default accent + a derived shadow tint; override --acc inline per card.
     --acc-ink is a near-black wash of the accent used for shadow/mat worlds. */
  --acc:var(--blue);
  --acc-ink:color-mix(in srgb,var(--acc) 30%,#070d1a);
  --card-r:var(--radius);
}

/* ---- .cardx : the premium card SHELL (layered gradient + sheen + shadow stack)
   A neutral, accent-themed surface for any content. Use as a section card, a
   stat panel, or the wrapper for .gradecard internals. ---- */
.cardx{
  position:relative;
  background:
    linear-gradient(180deg,color-mix(in srgb,var(--acc) 6%,transparent),transparent 30%),
    var(--surface);
  border:1px solid var(--line);
  border-radius:var(--card-r);
  /* tight negative-spread lift, tinted to the accent's world (never grey blur) */
  box-shadow:0 16px 34px -22px color-mix(in srgb,var(--acc-ink) 70%,transparent),var(--shadow-sm);
  overflow:hidden;
  isolation:isolate;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s;
}
.cardx::before{ /* top accent hairline — the only large-ish accent touch, kept thin */
  content:"";position:absolute;left:0;right:0;top:0;height:2px;z-index:2;
  background:linear-gradient(90deg,var(--acc),color-mix(in srgb,var(--acc) 30%,transparent));
  opacity:.9;
}
.cardx::after{ /* static diagonal sheen — a faint band, NOT animated by default */
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;border-radius:inherit;
  background:linear-gradient(115deg,transparent 40%,rgba(255,255,255,.06) 48%,transparent 56%);
}
.cardx>*{position:relative;z-index:2}
.cardx.is-hot{box-shadow:0 22px 48px -24px color-mix(in srgb,var(--acc-ink) 80%,transparent),var(--shadow)}
@media(prefers-reduced-motion:no-preference) and (hover:hover){
  .cardx.lift:hover{transform:translateY(-3px);border-color:color-mix(in srgb,var(--acc) 40%,var(--line));
    box-shadow:0 26px 56px -26px color-mix(in srgb,var(--acc-ink) 82%,transparent),var(--shadow)}
}
.cardx-pad{padding:1.1rem 1.2rem}
.cardx-hd{display:flex;align-items:baseline;justify-content:space-between;gap:.6rem;margin-bottom:.7rem}
.cardx-hd h4{font:800 .72rem var(--grotesk);text-transform:uppercase;letter-spacing:.08em;color:var(--ink-2)}
.cardx-hd .k{font:800 .62rem var(--mono);color:var(--acc);letter-spacing:.06em}

/* ============================================================================
   .gradecard — grade-coloured HERO trading card (a la the live /ranks cards).
   One --acc theme, an editorial tier NAME, serif hero numeral, mono stats, and a
   designed imageless mat. Apply a .g-* ramp class to set both --acc and tier.
   The ramp mirrors ranks.css accentFor(): rank -> colour + human tier name.

     <article class="gradecard g-aplus">
       <div class="gc-mat" style="--nat:#c8102e"> ...crest/flag/monogram... </div>
       ...front content...
     </article>

   .gradecard is purely the FRONT skin; pair with .flipcard (below) for 2-sided.
   ============================================================================ */
.gradecard{
  position:relative;display:flex;flex-direction:column;
  background:#0b1020;color:#fff;
  border:1px solid color-mix(in srgb,var(--acc) 35%,#1a2236);
  border-radius:var(--card-r);overflow:hidden;isolation:isolate;
  box-shadow:0 16px 34px -22px color-mix(in srgb,var(--acc-ink) 75%,transparent);
}
/* GRADE RAMP — accent colour + editorial tier name (via ::after on .gc-tier).
   Colours lifted from the live accentFor() map; names are house-editorial. */
.gradecard.g-aplus{--acc:#7c2d12}             /* burnt sienna — "Franchise"      */
.gradecard.g-a    {--acc:#1d4ed8}             /* blue-chip                       */
.gradecard.g-aminus{--acc:#2563eb}            /* top of the 1st                  */
.gradecard.g-b    {--acc:#0e7490}             /* teal — first round              */
.gradecard.g-bminus{--acc:#0891b2}            /* late first                      */
.gradecard.g-c    {--acc:#475569}             /* slate — second round            */
.gradecard.g-d    {--acc:#64748b}             /* day two / depth                 */
.gradecard.g-elite{--acc:var(--gold)}         /* special highlight ramp          */
/* tier-name auto-fill: put an empty <span class="gc-tier"></span> and the ramp
   supplies the editorial word. Override with text content to customise. */
.gradecard.g-aplus .gc-tier:empty::after{content:"Franchise"}
.gradecard.g-a .gc-tier:empty::after{content:"Blue-chip"}
.gradecard.g-aminus .gc-tier:empty::after{content:"Top of the 1st"}
.gradecard.g-b .gc-tier:empty::after{content:"First round"}
.gradecard.g-bminus .gc-tier:empty::after{content:"Late first"}
.gradecard.g-c .gc-tier:empty::after{content:"Second round"}
.gradecard.g-d .gc-tier:empty::after{content:"Day two"}
.gradecard.g-elite .gc-tier:empty::after{content:"Steal of the round"}

/* --- gradecard photo / imageless mat (designed fallback, never a bare letter) --- */
.gc-mat{
  position:relative;aspect-ratio:4/3;overflow:hidden;z-index:0;
  border-bottom:2px solid var(--acc);
  background:linear-gradient(162deg,color-mix(in srgb,var(--nat,var(--acc)) 70%,#0b1020) 0%,#0b1020 84%);
}
.gc-wash{ /* faded, rotated full-bleed flag/crest wash behind the focal */
  position:absolute;right:-14%;top:50%;width:128%;height:128%;object-fit:cover;
  transform:translateY(-50%) rotate(-7deg);opacity:.13;filter:saturate(1.25);pointer-events:none;
}
.gc-logo{ /* club crest as focal */
  position:absolute;left:50%;top:46%;transform:translate(-50%,-50%);
  width:58%;max-width:128px;max-height:50%;object-fit:contain;
  filter:drop-shadow(0 6px 16px rgba(0,0,0,.55));z-index:2;
}
.gc-flagfocal{ /* national flag as emblem when no crest */
  position:absolute;left:50%;top:44%;transform:translate(-50%,-50%);
  width:54%;max-width:116px;aspect-ratio:3/2;object-fit:cover;border-radius:7px;
  box-shadow:0 5px 16px rgba(0,0,0,.45),0 0 0 2px rgba(255,255,255,.7);z-index:2;
}
.gc-ini{ /* serif monogram fallback — last in the priority order */
  position:absolute;left:0;right:0;top:44%;transform:translateY(-50%);text-align:center;z-index:2;
  font:700 3.2rem/1 var(--serif);color:rgba(255,255,255,.9);text-shadow:0 3px 14px rgba(0,0,0,.4);
}
.gc-badge{ /* crisp corner flag badge with double ring */
  position:absolute;top:.6rem;right:.6rem;width:27px;height:18px;border-radius:3px;object-fit:cover;z-index:3;
  box-shadow:0 0 0 1.5px rgba(255,255,255,.85),0 2px 7px rgba(0,0,0,.45);
}
.gc-photo{ /* real photo — ONE crop rule; fades in over the mat */
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center top;
  opacity:0;transition:opacity 240ms ease;z-index:1;
}
.gc-photo.is-loaded{opacity:1}
@media(prefers-reduced-motion:reduce){.gc-photo{transition:none}}

/* --- gradecard text / scrim --- */
.gc-grad{ /* poster legibility scrim so white text reads over any photo */
  position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(180deg,rgba(8,12,26,.05) 0%,transparent 24%,rgba(8,12,26,.5) 58%,rgba(8,12,26,.96) 100%);
}
.gc-num{ /* hero rank/pick numeral over the photo — italic serif signature */
  position:absolute;right:.45rem;bottom:.3rem;z-index:3;
  font:800 italic 1.55rem/1 var(--serif);color:#fff;text-shadow:0 2px 9px rgba(0,0,0,.65);
}
.gc-kick{ /* accent kicker pill (top corner) */
  position:absolute;top:.7rem;left:.7rem;z-index:3;
  font:800 .56rem var(--mono);letter-spacing:.1em;text-transform:uppercase;color:#fff;
  background:var(--acc);padding:.2rem .5rem;border-radius:4px;
}
.gc-body{position:relative;z-index:3;padding:.9rem;display:flex;flex-direction:column;gap:.34rem}
.gc-tier{ /* editorial tier name pill (reads premium; never numeric) */
  align-self:flex-start;font:600 .56rem var(--grotesk);letter-spacing:.08em;text-transform:uppercase;
  color:#eaf1ff;background:color-mix(in srgb,var(--acc) 55%,transparent);
  padding:.16rem .46rem;border-radius:999px;
}
.gc-name{ /* serif name — clamps to 2 lines so the grid stays even */
  font:800 1.42rem/1.0 var(--serif);letter-spacing:-.02em;color:#fff;margin:.06rem 0;
  display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.gc-cover{ /* editorial italic cover line with accent rule */
  font:italic .9rem/1.25 var(--serif);color:#eaf1ff;
  border-left:3px solid var(--acc);padding-left:.55rem;margin:.1rem 0;
}
.gc-meta{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap;
  font:700 .58rem var(--mono);letter-spacing:.03em;color:rgba(255,255,255,.82)}
.gc-meta .gc-flag{width:16px;height:11px;border-radius:2px;object-fit:cover;flex:0 0 auto}

/* watchlist FOIL — reserved for MEANINGFUL states only (signal, not decoration).
   Static gold-white band; animates once on hover where motion is allowed. */
.gradecard.is-watched::after,.cardx.is-watched::after{
  content:"";position:absolute;inset:0;z-index:4;pointer-events:none;border-radius:inherit;
  background:linear-gradient(115deg,transparent 38%,rgba(255,255,255,.16) 47%,rgba(255,215,130,.2) 50%,rgba(255,255,255,.12) 53%,transparent 62%);
  background-size:240% 100%;background-position:82% 0;
}
@media(prefers-reduced-motion:no-preference) and (hover:hover){
  .gradecard.is-watched:hover::after,.cardx.is-watched:hover::after{animation:gcFoil .9s ease}
}
@keyframes gcFoil{from{background-position:120% 0}to{background-position:0% 0}}

/* ELITE shimmer — a moving specular streak gated to special items only */
.is-shimmer{position:relative;overflow:hidden}
.is-shimmer::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(120deg,transparent 0%,rgba(255,255,255,0) 30%,rgba(255,255,255,.5) 50%,rgba(255,255,255,0) 70%,transparent 100%);
  transform:translateX(-100%);
}
@media(prefers-reduced-motion:no-preference){
  .is-shimmer::before{animation:gcShimmer 2.6s ease-in-out infinite}
}
@keyframes gcShimmer{0%{transform:translateX(-100%)}60%,100%{transform:translateX(100%)}}

/* ============================================================================
   .flipcard — reusable 3D flip scaffold (front .fc-front / back .fc-back).
   Mirrors the live .rk-card flip: perspective on root, preserve-3d inner,
   backface-hidden faces, back pre-rotated. CRITICAL: pointer-events:none on the
   rotated-away face or its buttons silently die in Chromium (backface-visibility
   hides pixels only, not hit-testing). Reduced-motion -> 120ms opacity crossfade.

     <div class="flipcard"><div class="fc-inner">
       <div class="fc-front"> <article class="gradecard g-a">...</article> </div>
       <div class="fc-back">  ...ledger / why panel... </div>
     </div></div>
   Toggle .is-flipped on .flipcard (JS) to flip.
   ============================================================================ */
.flipcard{perspective:1500px;cursor:pointer}
.fc-inner{position:relative;width:100%;height:100%;transform-style:preserve-3d;
  transition:transform .62s cubic-bezier(.4,.08,.18,1)}
.flipcard.is-flipped .fc-inner{transform:rotateY(180deg)}
.fc-front,.fc-back{position:absolute;inset:0;-webkit-backface-visibility:hidden;backface-visibility:hidden;
  border-radius:var(--card-r);overflow:hidden}
.fc-back{transform:rotateY(180deg);background:var(--surface);color:var(--ink);
  display:flex;flex-direction:column;
  box-shadow:0 16px 34px -22px color-mix(in srgb,var(--acc-ink,#070d1a) 70%,transparent)}
/* hit-test guard — inactive face cannot steal clicks */
.flipcard:not(.is-flipped) .fc-back{pointer-events:none}
.flipcard.is-flipped .fc-front{pointer-events:none}
/* resting tilt — editorial only, gated; never fights the flip transform */
@media(prefers-reduced-motion:no-preference) and (hover:hover){
  .flipcard.tilt:not(.is-flipped):hover .fc-inner{
    transform:perspective(1000px) rotateX(1.4deg) rotateY(-2.4deg) translateY(-2px)}
}
/* reduced-motion: replace 3D rotation with a 120ms crossfade of stacked faces.
   Opacity-only is motion-safe, so it intentionally out-specifies the global clamp. */
@media(prefers-reduced-motion:reduce){
  .fc-inner{transition:none!important;transform:none!important}
  .fc-front,.fc-back{transform:none!important;-webkit-backface-visibility:visible;backface-visibility:visible}
  .fc-front{opacity:1;visibility:visible;transition:opacity 120ms ease,visibility 0s 0s!important}
  .fc-back{opacity:0;visibility:hidden;transition:opacity 120ms ease,visibility 0s 120ms!important}
  .flipcard.is-flipped .fc-front{opacity:0;visibility:hidden;transition:opacity 120ms ease,visibility 0s 120ms!important}
  .flipcard.is-flipped .fc-back{opacity:1;visibility:visible;transition:opacity 120ms ease,visibility 0s 0s!important}
}
/* persistent flip affordance pill; fills with --acc on card hover */
.fc-hint{position:absolute;z-index:4;bottom:.6rem;right:.6rem;
  font:800 .56rem var(--mono);letter-spacing:.06em;text-transform:uppercase;color:#fff;
  background:rgba(8,12,26,.55);border:1px solid rgba(255,255,255,.4);
  padding:.22rem .55rem;border-radius:999px;transition:background .14s,border-color .14s}
.flipcard:hover .fc-hint{background:var(--acc);border-color:var(--acc)}
.fc-hint.pulse{animation:fcHint .6s ease-in-out 2}
@keyframes fcHint{0%,100%{transform:scale(1)}50%{transform:scale(1.06)}}
@media(prefers-reduced-motion:reduce){.fc-hint.pulse{animation:none}}

/* ============================================================================
   .statline / .statrow — label + tabular-mono number + mini-bar. The honest
   stat primitive: every NUMBER is mono (tabular), labels are grotesk. The bar
   width comes from data-w (filled by LAB.finalize() / animateBars failsafe), so
   it is correct even with no animation. Accent fill reads var(--acc).

     <div class="statline">
       <span class="sl-lab">Production</span>
       <span class="sl-track"><i data-w="72%"></i></span>
       <span class="sl-val">72</span>
     </div>
   .statrow is the compact inline variant (label : value, no bar).
   ============================================================================ */
.statline{display:grid;grid-template-columns:minmax(72px,auto) 1fr minmax(34px,auto);
  align-items:center;gap:.6rem;padding:.18rem 0}
.sl-lab{font:600 .68rem var(--grotesk);text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}
.sl-track{height:8px;border-radius:999px;background:var(--surface-3);overflow:hidden}
.sl-track i{display:block;height:100%;width:0;border-radius:999px;
  background:linear-gradient(90deg,var(--acc),color-mix(in srgb,var(--acc) 55%,#fff));
  transition:width 1s var(--ease)}
.sl-val{font:800 .76rem var(--mono);font-variant-numeric:tabular-nums;text-align:right;color:var(--ink)}
.sl-val small{font-weight:600;color:var(--muted-2)}
/* compact key:value row (no bar) */
.statrow{display:flex;align-items:baseline;justify-content:space-between;gap:.6rem;
  padding:.3rem 0;border-bottom:1px solid var(--line)}
.statrow:last-child{border-bottom:0}
.statrow .sr-lab{font:600 .72rem var(--body);color:var(--muted)}
.statrow .sr-val{font:800 .82rem var(--mono);font-variant-numeric:tabular-nums;color:var(--ink)}

/* ============================================================================
   .whybtn + .whypop — the hover/expand "why" panel showing the engine's
   component value x weight contribution bars. Use for transparent provenance:
   every house number should be openable into "where it comes from".
   CSS-only open via :hover/:focus-within (so it works with rAF frozen); JS may
   add .is-open for click-toggle. Null-guard at the call site (some players lack
   forecast/components — render nothing rather than an empty pop).

     <span class="whywrap">
       <button class="whybtn" aria-expanded="false">why?</button>
       <div class="whypop" role="tooltip">
         <div class="wp-row"><span class="wp-l">Consensus</span>
           <span class="wp-bar"><i data-w="64%"></i></span>
           <span class="wp-v">0.64 x 0.30 = .19</span></div>
         ...more component rows...
       </div>
     </span>
   ============================================================================ */
.whywrap{position:relative;display:inline-flex}
.whybtn{font:800 .56rem var(--mono);letter-spacing:.06em;text-transform:uppercase;
  color:var(--acc);background:color-mix(in srgb,var(--acc) 12%,transparent);
  border:1px solid color-mix(in srgb,var(--acc) 26%,transparent);
  padding:.14rem .42rem;border-radius:999px;cursor:pointer;transition:.16s var(--ease)}
.whybtn:hover{background:color-mix(in srgb,var(--acc) 20%,transparent)}
.whypop{
  position:absolute;z-index:30;top:calc(100% + .45rem);left:0;min-width:236px;max-width:300px;
  background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:.7rem .75rem;
  box-shadow:var(--shadow);opacity:0;visibility:hidden;transform:translateY(-4px);
  transition:opacity .18s var(--ease),transform .18s var(--ease),visibility 0s .18s}
.whywrap:hover .whypop,.whywrap:focus-within .whypop,.whypop.is-open{
  opacity:1;visibility:visible;transform:none;transition:opacity .18s var(--ease),transform .18s var(--ease),visibility 0s 0s}
.whypop::before{content:"";position:absolute;top:-5px;left:14px;width:9px;height:9px;
  background:var(--surface);border-left:1px solid var(--line);border-top:1px solid var(--line);transform:rotate(45deg)}
.whypop h6{margin:0 0 .5rem;font:800 .6rem var(--grotesk);text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}
.wp-row{display:grid;grid-template-columns:78px 1fr auto;align-items:center;gap:.5rem;padding:.2rem 0}
.wp-l{font:600 .66rem var(--body);color:var(--ink-2);text-transform:capitalize}
.wp-bar{height:7px;border-radius:999px;background:var(--surface-3);overflow:hidden}
.wp-bar i{display:block;height:100%;width:0;border-radius:999px;background:var(--acc);transition:width .9s var(--ease)}
.wp-v{font:800 .62rem var(--mono);font-variant-numeric:tabular-nums;color:var(--ink);white-space:nowrap}
.wp-foot{margin:.5rem 0 0;font:600 .58rem var(--mono);color:var(--muted-2);line-height:1.4}
.wp-foot b{color:var(--acc)}

/* ============================================================================
   .chip variants (v5) — small mono pills, accent-aware. Extend the base .chip
   defined above. .chip.acc themes to the card's --acc; tier/grade chips encode
   the editorial-name voice; .chip.steal/.chip.bust/.chip.reach for redraft.
   ============================================================================ */
.chip.acc{background:color-mix(in srgb,var(--acc) 14%,transparent);color:var(--acc)}
.chip.acc-solid{background:var(--acc);color:#fff}
.chip.outline{background:transparent;border:1px solid color-mix(in srgb,var(--acc) 40%,var(--line));color:var(--ink-2)}
.chip.grade{font-weight:800;letter-spacing:.04em;background:color-mix(in srgb,var(--acc) 16%,transparent);color:var(--acc)}
.chip.steal{background:color-mix(in srgb,var(--green) 18%,transparent);color:var(--green-deep)}
.chip.bust{background:color-mix(in srgb,var(--red) 16%,transparent);color:var(--red-deep)}
.chip.reach{background:color-mix(in srgb,var(--gold) 18%,transparent);color:var(--gold-deep)}
.chip.live{background:color-mix(in srgb,var(--green) 16%,transparent);color:var(--green-deep)}
.chip.live::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--green);
  box-shadow:0 0 0 3px color-mix(in srgb,var(--green) 22%,transparent)}
@media(prefers-reduced-motion:no-preference){.chip.live::before{animation:pulse-dot 2s infinite}}
.chip.dot::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--acc)}

/* ============================================================================
   .scanline (defined above) + .grain — texture utilities. .scanline already
   exists; .grain adds a fixed-cost fractal-noise overlay scoped to a container
   (the body grain is global; this is for a single panel/card). Use sparingly.
   ============================================================================ */
.grain{position:relative}
.grain::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;opacity:.35;
  border-radius:inherit;mix-blend-mode:soft-light;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='gn'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23gn)' opacity='.5'/%3E%3C/svg%3E")}
[data-theme="dark"] .grain::after{mix-blend-mode:overlay;opacity:.4}
/* scoped scanline that draws statically (visible without rAF). Add .draw to
   reveal it as a resting decorative band; animate only when motion allowed. */
.scanline.draw{opacity:.5}
@media(prefers-reduced-motion:no-preference){
  .scanline.sweep-once{opacity:1;animation:scanSweep 1.1s var(--ease) both}
}
@keyframes scanSweep{from{transform:translateY(-140px)}to{transform:translateY(360px);opacity:0}}

/* ============================================================================
   .splitbars — tug-of-war: two opposing forces sharing one 100% track, meeting
   at a centre seam. For "consensus vs production", "floor vs ceiling", "took X
   vs best available". Widths come from data-w (finalize-safe).

     <div class="splitbars" style="--a:var(--blue);--b:var(--red)">
       <span class="sb-l"><i data-w="58%"></i></span>
       <span class="sb-seam"></span>
       <span class="sb-r"><i data-w="42%"></i></span>
     </div>
     <div class="sb-legend"><span>Floor 58</span><span>Ceiling 42</span></div>
   ============================================================================ */
.splitbars{--a:var(--blue);--b:var(--red);
  display:flex;align-items:stretch;height:16px;border-radius:999px;overflow:hidden;
  background:var(--surface-3);border:1px solid var(--line)}
.splitbars .sb-l,.splitbars .sb-r{position:relative;flex:1;overflow:hidden}
.splitbars .sb-l{display:flex;justify-content:flex-end}
.splitbars .sb-l i,.splitbars .sb-r i{display:block;height:100%;width:0;transition:width 1s var(--ease)}
.splitbars .sb-l i{background:linear-gradient(90deg,color-mix(in srgb,var(--a) 55%,#fff),var(--a))}
.splitbars .sb-r i{background:linear-gradient(90deg,var(--b),color-mix(in srgb,var(--b) 55%,#fff))}
.splitbars .sb-seam{width:2px;background:var(--surface);z-index:1}
.sb-legend{display:flex;justify-content:space-between;margin-top:.32rem;
  font:700 .62rem var(--mono);font-variant-numeric:tabular-nums;color:var(--muted)}
.sb-legend span:first-child{color:color-mix(in srgb,var(--blue) 70%,var(--ink))}
.sb-legend span:last-child{color:color-mix(in srgb,var(--red) 70%,var(--ink))}

/* ============================================================================
   .tickrail — a horizontal scale/axis with labelled ticks and an accent marker
   pin, for "where this value sits on the league distribution". Pin position via
   style="--p:64%" (or left inline); ticks are plain children. Static-safe (no
   animation needed to be correct).

     <div class="tickrail" style="--p:64%">
       <span class="tr-fill"></span>
       <span class="tr-pin"><b>0.64</b></span>
       <span class="tr-tk" style="left:0%">0</span>
       <span class="tr-tk" style="left:50%">.5</span>
       <span class="tr-tk" style="left:100%">1.0</span>
     </div>
   ============================================================================ */
.tickrail{position:relative;height:10px;margin:1.5rem 0 1.7rem;border-radius:999px;
  background:linear-gradient(90deg,var(--surface-3),color-mix(in srgb,var(--acc) 22%,var(--surface-3)));
  border:1px solid var(--line)}
.tr-fill{position:absolute;left:0;top:0;bottom:0;width:var(--p,0%);border-radius:999px;
  background:linear-gradient(90deg,color-mix(in srgb,var(--acc) 30%,transparent),var(--acc));
  transition:width 1s var(--ease)}
.tr-pin{position:absolute;top:50%;left:var(--p,0%);transform:translate(-50%,-50%);z-index:2;
  width:14px;height:14px;border-radius:50%;background:#fff;border:3px solid var(--acc);
  box-shadow:0 3px 10px rgba(0,0,0,.3);transition:left 1s var(--ease)}
.tr-pin b{position:absolute;bottom:calc(100% + .35rem);left:50%;transform:translateX(-50%);
  font:800 .64rem var(--mono);font-variant-numeric:tabular-nums;color:var(--ink);white-space:nowrap}
.tr-tk{position:absolute;top:calc(100% + .35rem);transform:translateX(-50%);
  font:700 .58rem var(--mono);color:var(--muted)}
.tr-tk:first-of-type{transform:none}            /* clamp ends inside the rail */
.tr-tk:last-of-type{transform:translateX(-100%)}

/* ---- shared grid for the new card systems ---- */
.gradegrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(232px,1fr));gap:1.15rem;margin-top:1rem}
.gradegrid .flipcard{height:442px}
.gradegrid .gradecard{height:100%}
@media(max-width:520px){
  .gradegrid{grid-template-columns:repeat(auto-fill,minmax(158px,1fr));gap:.7rem}
  .gradegrid .flipcard{height:384px}
  .gc-name{font-size:1.18rem}
}

/* DARK MAT — the imageless gradecard mat + back already use dark literals; in
   dark theme give the card a mat ring so it reads as mounted, not glaring. */
[data-theme="dark"] .gradecard,[data-theme="dark"] .fc-back{
  border:1px solid color-mix(in srgb,var(--acc) 40%,#222b40);
}
/* ===== END LAB v5 CARD SYSTEM ===== */

/* ============================ page-specific styles ============================ */
  /* ============================================================
     THE TRANSLATION: CHL Draft -> NHL Draft, all 20 rounds.
     The build reproduces the independently hand-charted 2024 OHL
     first-round anchor (8/21 NHL-drafted, 6 of the top 8, best NHL
     slot Caleb Malhotra #3 to VAN), then extends the same accounting
     to all three CHL leagues, every round, 2000-2024. Honest throughout:
     NHL-draft rates settle for CHL classes <=2022; career "played NHL"
     rates need mature classes <=2017. Recent years are translation
     studies, not finished career studies, and are labelled as such.
     ============================================================ */
  .wrap{max-width:1240px}
  .hero h1 em{font-style:italic;color:var(--blue)}
  .real-note code{font:700 .82em var(--mono);color:var(--blue);background:var(--surface-3);padding:.05rem .3rem;border-radius:5px}
  .data-stamp{display:flex;align-items:center;flex-wrap:wrap;width:max-content;max-width:100%;gap:.35rem;margin-top:.6rem;font:700 .62rem var(--mono);color:var(--muted);background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:.32rem .6rem;box-shadow:var(--shadow-sm)}
  .data-stamp b{color:var(--ink-2)}

  /* per-league colour identity — three distinct token-based accents, used everywhere */
  .lg-OHL{--lg:var(--blue);--lgd:var(--blue-dark)}
  .lg-WHL{--lg:var(--red);--lgd:var(--red-deep)}
  .lg-QMJHL{--lg:var(--purple);--lgd:#5b3fd6}
  .lgchip{display:inline-flex;align-items:center;gap:.3rem;font:800 .58rem var(--grotesk);letter-spacing:.04em;text-transform:uppercase;
    color:var(--lgd);background:color-mix(in srgb,var(--lg) 13%,transparent);border:1px solid color-mix(in srgb,var(--lg) 30%,transparent);
    padding:.18rem .45rem;border-radius:999px;white-space:nowrap}

  /* ---- OVERVIEW STRIP (whole-dataset summary) ---- */
  .proof{position:relative;overflow:hidden;margin-top:1.2rem;border-radius:var(--radius-lg);
    background:radial-gradient(120% 150% at 100% 0,color-mix(in srgb,var(--green) 12%,transparent),transparent 55%),linear-gradient(180deg,var(--surface-2),var(--surface));
    border:1px solid color-mix(in srgb,var(--green) 24%,var(--line));box-shadow:var(--shadow-sm)}
  .proof::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,var(--green),color-mix(in srgb,var(--green) 35%,transparent))}
  .proof-in{padding:1.05rem 1.3rem 1.1rem 1.45rem}
  .proof-k{font:800 .58rem var(--mono);text-transform:uppercase;letter-spacing:.13em;color:var(--green-deep);display:flex;align-items:center;gap:.45rem;margin-bottom:.5rem}
  .proof-k::after{content:"";flex:1;height:1px;background:linear-gradient(90deg,color-mix(in srgb,var(--green) 45%,transparent),transparent)}
  .proof-say{font-family:var(--serif);font-weight:500;font-size:1.24rem;line-height:1.42;color:var(--ink);letter-spacing:-.01em}
  .proof-say b{font-weight:700} .proof-say .num{font-family:var(--mono);font-weight:800;font-variant-numeric:tabular-nums;color:var(--green-deep)}
  .proof-chk{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.85rem}
  .pck{display:inline-flex;align-items:center;gap:.35rem;font:700 .68rem var(--mono);color:var(--ink-2);background:var(--surface);
    border:1px solid var(--line);border-radius:999px;padding:.3rem .6rem}
  .pck .tick{color:var(--green-deep);font-weight:800}

  /* ---- shared section shell ---- */
  .sec{margin-top:1.5rem;border-radius:var(--radius-xl);background:linear-gradient(180deg,var(--surface-2),var(--surface));border:1px solid var(--line);box-shadow:var(--shadow);overflow:hidden}
  .sec-head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:.5rem 1rem;padding:1.1rem 1.35rem .4rem}
  .sec-head h2{font-family:var(--serif);font-weight:600;font-size:clamp(1.35rem,3.4vw,1.7rem);line-height:1.05;letter-spacing:-.01em}
  .sec-head .sub{font:600 .68rem var(--mono);color:var(--muted);margin-top:.3rem;max-width:64ch;line-height:1.5}
  .sec-head .sub b{color:var(--blue)}
  .sec-num{font:800 .56rem var(--grotesk);text-transform:uppercase;letter-spacing:.13em;color:var(--muted);align-self:flex-start;margin-top:.2rem}

  /* ---- CLASS TRANSLATOR ---- */
  .tr-controls{display:flex;flex-wrap:wrap;gap:.9rem 1.4rem;align-items:flex-end;padding:.4rem 1.35rem 1rem;position:sticky;top:104px;z-index:8;
    background:linear-gradient(180deg,var(--surface-2) 70%,transparent);backdrop-filter:blur(3px)}
  @media (max-width:720px){ .tr-controls{ top:96px; } }
  .tr-ctl{display:flex;flex-direction:column;gap:.4rem}
  .tr-ctl>label{font:800 .56rem var(--grotesk);text-transform:uppercase;letter-spacing:.07em;color:var(--muted)}
  /* league segmented control — paints to the active league colour */
  #lgSeg{flex-wrap:wrap}
  #lgSeg button[data-lg].on{color:#fff}
  #lgSeg .glider{background:linear-gradient(135deg,var(--lg,var(--blue)),var(--lgd,var(--blue-dark)))}
  .pickrange{display:flex;align-items:center;gap:.4rem}
  .picknum{width:54px;font:800 .95rem var(--mono);text-align:center;color:var(--ink);background:var(--surface);border:1px solid var(--line-2);border-radius:9px;padding:.4rem .3rem;-moz-appearance:textfield}
  .picknum::-webkit-outer-spin-button,.picknum::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
  .picknum:focus{outline:0;border-color:var(--lg,var(--blue));box-shadow:0 0 0 3px color-mix(in srgb,var(--lg,var(--blue)) 16%,transparent)}
  .pkdash{color:var(--muted);font-weight:700}
  .yrline{display:flex;align-items:center;gap:.55rem}
  .yr-nav{width:34px;height:34px;border:1px solid var(--line);background:var(--surface);border-radius:9px;cursor:pointer;font:800 1rem var(--mono);color:var(--ink-2);transition:.15s}
  .yr-nav:hover:not(:disabled){border-color:var(--lg,var(--blue));color:var(--lg,var(--blue))}
  .yr-nav:disabled{opacity:.35;cursor:not-allowed}
  .yrsel{font:800 1.5rem var(--mono);color:var(--ink);background:var(--surface);border:1px solid var(--line-2);border-radius:11px;padding:.3rem .55rem;cursor:pointer}
  .yrsel:focus{outline:0;border-color:var(--lg,var(--blue));box-shadow:0 0 0 4px color-mix(in srgb,var(--lg,var(--blue)) 16%,transparent)}
  /* normal-text selects for the translator's Outcome / Position lenses (the year selects are huge) */
  .trsel{font:700 .9rem var(--body);color:var(--ink);background:var(--surface);border:1px solid var(--line-2);border-radius:11px;padding:.52rem .6rem;cursor:pointer;min-width:8rem}
  .trsel:focus{outline:0;border-color:var(--lg,var(--blue));box-shadow:0 0 0 4px color-mix(in srgb,var(--lg,var(--blue)) 16%,transparent)}
  .cl-filterflag{margin:.1rem .45rem .7rem;font:700 .72rem var(--body);color:var(--lgd,var(--blue-dark))}
  .cl-filterflag b{color:var(--ink)}
  .depth-seg button.on{color:#fff}
  .depth-seg .glider{background:linear-gradient(135deg,var(--lg,var(--blue)),var(--lgd,var(--blue-dark)))}
  /* round preset + range share a row with the number inputs */
  .ctl-row{display:flex;align-items:center;gap:.55rem;flex-wrap:wrap}
  .round-seg button.on{color:#fff}
  .round-seg .glider{background:linear-gradient(135deg,var(--lg,var(--blue)),var(--lgd,var(--blue-dark)))}
  .tr-ctl label .unit{font-weight:600;color:var(--muted);text-transform:none;letter-spacing:0}
  .yr-dash{font-weight:700;color:var(--muted)}
  #yFrom,#yTo{font-size:1.12rem;padding:.32rem .42rem}
  /* the translator is the page centerpiece — a touch more presence */
  .tool-hero{border-color:color-mix(in srgb,var(--blue) 22%,var(--line));box-shadow:0 14px 44px -24px color-mix(in srgb,var(--blue) 52%,transparent),var(--shadow)}

  /* class scoreboard + share card */
  .tr-top{display:grid;grid-template-columns:1fr 320px;gap:1rem;padding:0 1.35rem 1rem;align-items:start}
  @media(max-width:880px){.tr-top{grid-template-columns:1fr}}
  .scoreboard{display:grid;grid-template-columns:repeat(4,1fr);gap:.6rem}
  @media(max-width:520px){.scoreboard{grid-template-columns:repeat(2,1fr)}}
  .sb{position:relative;padding:.8rem .85rem;border-radius:14px;background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow-sm);overflow:hidden}
  .sb::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--lg,var(--blue))}
  .sb b{font:800 2rem var(--mono);font-variant-numeric:tabular-nums;line-height:1;letter-spacing:-.03em;color:var(--ink)}
  .sb b small{font-size:.5em;color:var(--muted);font-weight:700}
  .sb span{display:block;font:700 .54rem var(--grotesk);text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-top:.35rem}
  .sb.best b{font-size:1.18rem;line-height:1.15}
  .sb.best .bn{color:var(--lgd,var(--blue-dark))}

  /* share card */
  .sharecard{position:relative;border-radius:16px;overflow:hidden;border:1px solid color-mix(in srgb,var(--lg,var(--blue)) 30%,var(--line));
    background:linear-gradient(150deg,color-mix(in srgb,var(--lg,var(--blue)) 12%,var(--surface)),var(--surface-2));box-shadow:var(--shadow-sm);display:flex;flex-direction:column}
  .sc-in{padding:.95rem 1rem;flex:1}
  .sc-eyebrow{font:800 .54rem var(--grotesk);text-transform:uppercase;letter-spacing:.1em;color:var(--lgd,var(--blue-dark))}
  .sc-h{font-family:var(--serif);font-weight:600;font-size:1.16rem;line-height:1.15;margin:.25rem 0 .5rem;color:var(--ink)}
  .sc-line{font:600 .76rem var(--body);color:var(--ink-2);line-height:1.5}
  .sc-line b{color:var(--ink);font-weight:800}
  .sc-foot{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.6rem 1rem;border-top:1px solid color-mix(in srgb,var(--lg,var(--blue)) 22%,var(--line));background:color-mix(in srgb,var(--lg,var(--blue)) 6%,transparent)}
  .sc-foot .mark{font:700 .56rem var(--mono);color:var(--muted)}
  .copybtn{font:800 .64rem var(--grotesk);text-transform:uppercase;letter-spacing:.03em;padding:.4rem .7rem;border-radius:9px;border:1px solid var(--lg,var(--blue));
    background:var(--lg,var(--blue));color:#fff;cursor:pointer;transition:.15s;white-space:nowrap}
  .copybtn:hover{filter:brightness(1.06);transform:translateY(-1px)}
  .copybtn.ok{background:var(--green);border-color:var(--green)}
  .copybtn.ghost{background:var(--surface);color:var(--lgd,var(--blue-dark));border-color:color-mix(in srgb,var(--lg,var(--blue)) 35%,var(--line))}
  .sc-actions{display:flex;gap:.4rem;align-items:center;flex-wrap:wrap;justify-content:flex-end}
  .read-rule{margin:0 1.35rem 1rem;padding:.58rem .75rem;border-radius:11px;border:1px solid color-mix(in srgb,var(--blue) 20%,var(--line));background:color-mix(in srgb,var(--blue) 6%,var(--surface));font:650 .75rem/1.45 var(--body);color:var(--ink-2)}
  .read-rule b{color:var(--blue-dark)}

  /* class roster rows */
  .classlist{padding:.2rem .9rem 1.2rem}
  .partial-flag{margin:.2rem .45rem 1rem;padding:.55rem .8rem;border-radius:11px;font:600 .74rem var(--body);line-height:1.45;color:var(--gold-deep);
    background:color-mix(in srgb,var(--gold) 9%,var(--surface));border:1px dashed color-mix(in srgb,var(--gold) 38%,var(--line))}
  .partial-flag b{font-weight:800}
  .crow{display:grid;grid-template-columns:34px 44px 1fr auto;gap:.6rem;align-items:center;padding:.5rem .45rem;border-radius:12px;border:1px solid transparent;cursor:pointer;transition:.14s}
  .crow:hover{background:var(--surface);border-color:var(--line);box-shadow:var(--shadow-sm)}
  .crow:focus-visible{outline:2px solid var(--lg,var(--blue));outline-offset:2px}
  .crow+.crow{margin-top:.1rem}
  .crow .cpk{font:800 1rem var(--mono);color:var(--lgd,var(--blue-dark));text-align:center;font-variant-numeric:tabular-nums}
  .crow .cpk small{display:block;font:700 .48rem var(--grotesk);color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-top:.1rem}
  .cav{position:relative;width:44px;height:44px;border-radius:11px;overflow:hidden;background:linear-gradient(140deg,var(--lg,var(--blue)),var(--lgd,var(--blue-dark)));
    display:grid;place-items:center;color:#fff;font:800 .8rem var(--mono);flex:0 0 auto}
  .cav img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 12%}
  .cav.und{background:var(--surface-3);color:var(--muted)}
  .cmid{min-width:0}
  .cnm{font-weight:700;font-size:.95rem;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:.4rem}
  .cmeta{font:600 .66rem var(--mono);color:var(--muted);margin-top:.15rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .cout{display:flex;align-items:center;gap:.55rem;justify-self:end}
  .clogo{width:30px;height:30px;object-fit:contain;flex:0 0 auto;filter:drop-shadow(0 1px 2px rgba(11,28,60,.18))}
  .cout-txt{text-align:right}
  .cout-txt .ov{font:800 .9rem var(--mono);color:var(--ink);font-variant-numeric:tabular-nums;line-height:1}
  .cout-txt .lag{font:700 .58rem var(--mono);color:var(--muted);margin-top:.15rem;white-space:nowrap}
  .cout.no{font:700 .64rem var(--grotesk);text-transform:uppercase;letter-spacing:.04em;color:var(--muted);
    background:var(--surface-3);border-radius:8px;padding:.3rem .55rem}
  .pos-pill{font:700 .54rem var(--mono);color:var(--muted);background:var(--surface-3);border-radius:5px;padding:.06rem .3rem}
  /* per-row year / round chips when the cohort spans more than one year or round */
  .metachip{font:700 .56rem var(--mono);color:var(--muted);background:var(--surface-3);border:1px solid var(--line);border-radius:5px;padding:.04rem .3rem;flex:0 0 auto}
  .metachip.rd{color:var(--lgd,var(--blue-dark));border-color:color-mix(in srgb,var(--lg,var(--blue)) 30%,var(--line))}
  .cl-more{display:flex;flex-direction:column;align-items:center;gap:.3rem;padding:.8rem .4rem .3rem}
  .cmut{color:var(--muted);font-weight:600}

  /* ===== mobile: the top caveat pill and the cohort rows must not clip ===== */
  @media(max-width:560px){
    /* caveat: stop being an overflowing inline pill — wrap as a normal rounded block */
    .real-note{display:block;width:100%;border-radius:12px;line-height:1.45;padding:.55rem .7rem;font-size:.74rem}
    .real-note .live-dot{margin-right:.45rem}
    /* cohort rows: stack into a card — pick · avatar · name on row 1, CHL team + NHL result on row 2 */
    .crow{
      grid-template-columns:32px 40px minmax(0,1fr) auto;
      grid-template-areas:
        "pk av nm   nm"
        "pk av meta out";
      column-gap:.5rem;row-gap:.18rem;align-items:center;padding:.55rem .4rem;
    }
    .crow .cpk{grid-area:pk}
    .crow .cav{grid-area:av;width:40px;height:40px}
    .crow .cmid{display:contents}          /* let .cnm and .cmeta land in the row grid directly */
    .crow .cnm{grid-area:nm;white-space:normal;line-height:1.18;align-self:center}
    .crow .cmeta{grid-area:meta;white-space:normal;overflow:visible;line-height:1.35}
    .crow .cout{grid-area:out;justify-self:end;align-self:center}
    .crow .cout.no{grid-area:out}
  }
  .conf-dot{width:7px;height:7px;border-radius:50%;flex:0 0 auto}
  .conf-exact{background:var(--green)} .conf-alias{background:var(--gold)} .conf-variant{background:var(--cyan)} .conf-fallback{background:var(--red)}

  /* ---- WHAT TRANSLATES (insight) ---- */
  .read{position:relative;overflow:hidden;margin:0 0 1.1rem;border-radius:var(--radius-lg);
    background:radial-gradient(120% 140% at 100% 0,color-mix(in srgb,var(--blue) 12%,transparent),transparent 55%),linear-gradient(180deg,var(--surface-2),var(--surface));
    border:1px solid color-mix(in srgb,var(--blue) 22%,var(--line));box-shadow:var(--shadow-sm)}
  .read::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,var(--blue),color-mix(in srgb,var(--blue) 35%,transparent))}
  .read-in{padding:1rem 1.3rem 1.05rem 1.45rem}
  .read-k{font:800 .56rem var(--mono);text-transform:uppercase;letter-spacing:.13em;color:var(--blue);margin-bottom:.45rem}
  .read p{font-family:var(--serif);font-weight:500;font-size:1.18rem;line-height:1.42;color:var(--ink);margin:0}
  .read p b{font-weight:700} .read .num{font-family:var(--mono);font-weight:800;font-variant-numeric:tabular-nums;color:var(--blue-dark)}

  .ins-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem;padding:0 1.35rem 1.3rem}
  @media(max-width:900px){.ins-grid{grid-template-columns:1fr}}
  .ins-card{border-radius:var(--radius-lg);border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow-sm);padding:1rem 1.1rem}
  .ins-card.wide{grid-column:1/-1}
  .ins-card h3{font:800 .62rem var(--grotesk);text-transform:uppercase;letter-spacing:.07em;color:var(--ink-2);margin-bottom:.2rem}
  .ins-card .ic-sub{font:600 .66rem var(--mono);color:var(--muted);margin-bottom:.9rem;line-height:1.4}

  /* league bars */
  .lgbars{display:flex;flex-direction:column;gap:.85rem}
  .lgb{display:grid;grid-template-columns:64px 1fr;gap:.7rem;align-items:center}
  .lgb .lgb-l{display:flex;flex-direction:column;gap:.2rem}
  .lgb .lgb-n{font:800 .8rem var(--grotesk);color:var(--lgd)}
  .lgb .lgb-c{font:600 .54rem var(--mono);color:var(--muted)}
  .twobar{display:flex;flex-direction:column;gap:.3rem}
  .tb-row{display:flex;align-items:center;gap:.5rem}
  .tb-tag{font:700 .52rem var(--grotesk);text-transform:uppercase;letter-spacing:.04em;color:var(--muted);width:62px;flex:0 0 auto}
  .tb-track{flex:1;height:15px;border-radius:7px;background:var(--surface-3);overflow:hidden;position:relative}
  .tb-fill{height:100%;width:0;border-radius:7px;transition:width 1s var(--ease)}
  .tb-fill.draft{background:linear-gradient(90deg,var(--lg),var(--lgd))}
  .tb-fill.play{background:linear-gradient(90deg,color-mix(in srgb,var(--lg) 55%,var(--surface)),var(--lg))}
  .tb-val{font:800 .72rem var(--mono);color:var(--ink-2);width:42px;text-align:right;flex:0 0 auto;font-variant-numeric:tabular-nums}

  /* band gradient */
  .bands{display:flex;flex-direction:column;gap:.7rem}
  .band{display:grid;grid-template-columns:54px 1fr;gap:.7rem;align-items:center}
  .band .bd-l{font:800 .74rem var(--mono);color:var(--ink-2);text-align:right}
  .band .bd-l small{display:block;font:600 .5rem var(--grotesk);color:var(--muted);text-transform:uppercase;letter-spacing:.03em}
  .bd-track{position:relative;height:26px;border-radius:8px;background:var(--surface-3);overflow:hidden}
  .bd-draft{position:absolute;inset:0;width:0;border-radius:8px;transition:width 1s var(--ease);background:color-mix(in srgb,var(--blue) 26%,transparent)}
  .bd-play{position:absolute;left:0;top:0;bottom:0;width:0;border-radius:8px;transition:width 1s var(--ease);background:linear-gradient(90deg,var(--blue),var(--blue-dark));display:flex;align-items:center}
  .bd-play b{font:800 .66rem var(--mono);color:#fff;padding-left:.5rem;text-shadow:0 1px 3px rgba(0,0,0,.35)}
  .bd-dpct{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);font:700 .6rem var(--mono);color:var(--muted)}
  .bandleg{display:flex;gap:1rem;flex-wrap:wrap;margin-top:.7rem;font:700 .58rem var(--mono);color:var(--muted)}
  .bandleg i{display:inline-block;width:14px;height:9px;border-radius:3px;vertical-align:middle;margin-right:.3rem}

  /* lag distribution */
  .lagwrap{display:flex;align-items:flex-end;gap:.6rem;height:130px;padding-top:.4rem}
  .lagcol{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:.35rem;height:100%}
  .lagbar{width:100%;max-width:54px;border-radius:7px 7px 0 0;background:linear-gradient(180deg,var(--blue),var(--blue-dark));height:0;transition:height .9s var(--ease);position:relative;min-height:3px}
  .lagbar b{position:absolute;top:-1.1rem;left:50%;transform:translateX(-50%);font:800 .66rem var(--mono);color:var(--ink-2)}
  .lagcol .ll{font:700 .58rem var(--mono);color:var(--muted);text-align:center;line-height:1.2}
  .lagcol .ll b{display:block;font:800 .72rem var(--grotesk);color:var(--ink-2)}

  /* ---- THE CAREERS ---- */
  .lead-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.6rem;padding:.2rem 1.1rem 1rem}
  @media(max-width:760px){.lead-grid{grid-template-columns:1fr}}
  .lcard2{display:grid;grid-template-columns:30px 50px 1fr auto;gap:.65rem;align-items:center;padding:.55rem .7rem;border-radius:13px;border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow-sm);cursor:pointer;transition:.14s}
  .lcard2:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
  .lcard2:focus-visible{outline:2px solid var(--blue);outline-offset:2px}
  .lrk{font:800 .9rem var(--mono);color:var(--muted);text-align:center}
  .lav{position:relative;width:50px;height:50px;border-radius:13px;overflow:hidden;background:linear-gradient(140deg,var(--lg,var(--blue)),var(--lgd,var(--blue-dark)));display:grid;place-items:center;color:#fff;font:800 .82rem var(--mono);flex:0 0 auto}
  .lav img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 12%}
  .llogo-inline,.lg2-inline,.fl-inline{width:14px;height:14px;object-fit:contain;vertical-align:-2px;margin:0 .22rem 0 .18rem;filter:drop-shadow(0 1px 1px rgba(0,0,0,.12))}
  .lmid{min-width:0}
  .lnm{font-weight:700;font-size:.96rem;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:.4rem}
  .lpath{font:600 .62rem var(--mono);color:var(--muted);margin-top:.18rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .lpath b{color:var(--lgd,var(--blue-dark))}
  .lstat{text-align:right;flex:0 0 auto}
  .lstat .pts{font:800 1.2rem var(--mono);color:var(--ink);line-height:1;font-variant-numeric:tabular-nums}
  .lstat .pts small{font-size:.46em;color:var(--muted);font-weight:700}
  .lstat .gline{font:700 .56rem var(--mono);color:var(--muted);margin-top:.2rem;white-space:nowrap}
  .live-tag{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 0 3px color-mix(in srgb,var(--green) 22%,transparent)}

  /* steals rail */
  .steals-wrap{padding:.2rem 1.1rem 1.3rem}
  .steals-lab{font:800 .56rem var(--grotesk);text-transform:uppercase;letter-spacing:.07em;color:var(--muted);margin:.5rem .3rem .6rem;display:flex;align-items:center;gap:.5rem}
  .steals-lab::after{content:"";flex:1;height:1px;background:var(--line)}
  .steals{display:flex;gap:.7rem;overflow-x:auto;padding:.2rem .3rem .6rem;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
  .steal{flex:0 0 190px;scroll-snap-align:start;border-radius:15px;border:1px solid var(--line);background:linear-gradient(160deg,color-mix(in srgb,var(--lg,var(--blue)) 9%,var(--surface)),var(--surface-2));
    box-shadow:var(--shadow-sm);padding:.85rem .9rem;cursor:pointer;transition:.15s;position:relative;overflow:hidden}
  .steal:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
  .steal:focus-visible{outline:2px solid var(--lg,var(--blue));outline-offset:2px}
  .steal .st-av{position:relative;width:54px;height:54px;border-radius:14px;overflow:hidden;background:linear-gradient(140deg,var(--lg,var(--blue)),var(--lgd,var(--blue-dark)));display:grid;place-items:center;color:#fff;font:800 .9rem var(--mono);margin-bottom:.55rem}
  .steal .st-av img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 12%}
  .steal .st-nm{font-weight:700;font-size:.92rem;line-height:1.1}
  .steal .st-jump{font:800 .66rem var(--mono);margin-top:.35rem;color:var(--lgd,var(--blue-dark))}
  .steal .st-jump .ar{color:var(--muted);margin:0 .2rem}
  .steal .st-pts{font:700 .62rem var(--mono);color:var(--muted);margin-top:.3rem}

  /* ---- EXPLORER ---- */
  .ex-controls{display:flex;flex-wrap:wrap;gap:.7rem .9rem;align-items:flex-end;padding:.4rem 1.35rem 1rem}
  .ex-ctl{display:flex;flex-direction:column;gap:.3rem}
  .ex-ctl label{font:800 .52rem var(--grotesk);text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}
  .ex-ctl select,.ex-ctl input{font:600 .82rem var(--body);color:var(--ink);background:var(--surface);border:1px solid var(--line-2);border-radius:9px;padding:.42rem .55rem}
  .ex-ctl select:focus,.ex-ctl input:focus{outline:0;border-color:var(--blue);box-shadow:0 0 0 3px color-mix(in srgb,var(--blue) 15%,transparent)}
  .ex-search{min-width:180px;flex:1}
  .ex-search input{width:100%}
  .ex-actions{display:flex;gap:.5rem;align-items:center;margin-left:auto}
  .ex-count{font:700 .68rem var(--mono);color:var(--muted)}
  .csvbtn{font:800 .62rem var(--grotesk);text-transform:uppercase;letter-spacing:.03em;padding:.42rem .7rem;border-radius:9px;border:1px solid var(--line-2);background:var(--surface);color:var(--ink-2);cursor:pointer;transition:.15s}
  .csvbtn:hover{border-color:var(--blue);color:var(--blue)}
  .csvbtn.ok{background:var(--green);border-color:var(--green);color:#fff}
  .ex-presets{display:flex;flex-wrap:wrap;gap:.45rem;padding:0 1.35rem .85rem}
  .ex-presets button{font:800 .6rem var(--grotesk);text-transform:uppercase;letter-spacing:.05em;border:1px solid color-mix(in srgb,var(--blue) 24%,var(--line));background:color-mix(in srgb,var(--blue) 6%,var(--surface));color:var(--blue-dark);border-radius:999px;padding:.38rem .65rem;cursor:pointer;transition:.15s}
  .ex-presets button:hover{background:color-mix(in srgb,var(--blue) 13%,var(--surface));border-color:var(--blue)}

  .ex-table{width:100%;border-collapse:collapse;font-variant-numeric:tabular-nums}
  .ex-wrap{padding:0 1.35rem 1.3rem;overflow-x:auto}
  .ex-table thead th{position:sticky;top:0;background:var(--surface-2);font:800 .54rem var(--grotesk);text-transform:uppercase;letter-spacing:.05em;color:var(--muted);
    text-align:left;padding:.55rem .6rem;border-bottom:1px solid var(--line);cursor:pointer;white-space:nowrap;user-select:none}
  .ex-table thead th.sortable:hover{color:var(--blue)}
  .ex-table thead th .arr{opacity:.4;margin-left:.2rem}
  .ex-table thead th[aria-sort] .arr{opacity:1;color:var(--blue)}
  .ex-table tbody tr{border-bottom:1px solid var(--line);cursor:pointer;transition:background .12s}
  .ex-table tbody tr:hover{background:var(--surface-2)}
  .ex-table tbody tr:focus-visible{outline:2px solid var(--blue);outline-offset:-2px}
  .ex-table td{padding:.5rem .6rem;font:600 .8rem var(--body);color:var(--ink-2);vertical-align:middle}
  .ex-table td.nm{font-weight:700;color:var(--ink);white-space:nowrap}
  .ex-table td.num{font-family:var(--mono);font-weight:700;text-align:right;white-space:nowrap}
  .ex-table .tlogo{width:22px;height:22px;object-fit:contain;vertical-align:middle;margin-right:.3rem}
  .ex-empty{padding:2.5rem 1rem;text-align:center;color:var(--muted);font:600 .85rem var(--body)}
  .ex-more td{cursor:default}
  .ex-morebtn{font:800 .68rem var(--grotesk);text-transform:uppercase;letter-spacing:.05em;color:var(--blue);background:color-mix(in srgb,var(--blue) 9%,transparent);
    border:1px solid color-mix(in srgb,var(--blue) 26%,var(--line));border-radius:999px;padding:.42rem 1rem;cursor:pointer;transition:.15s}
  .ex-morebtn:hover{background:color-mix(in srgb,var(--blue) 16%,transparent);border-color:var(--blue)}
  .ex-moremeta{display:inline-block;margin-left:.7rem;color:var(--muted);font:600 .68rem var(--mono)}
  @media(max-width:760px){.ex-more td{display:block;text-align:center}.ex-moremeta{display:block;margin:.4rem 0 0}}
  .ostat{display:inline-flex;align-items:center;gap:.3rem;font:700 .6rem var(--mono);padding:.15rem .4rem;border-radius:6px;white-space:nowrap}
  .ostat.drafted{color:var(--green-deep);background:color-mix(in srgb,var(--green) 12%,transparent)}
  .ostat.played{color:var(--blue-dark);background:color-mix(in srgb,var(--blue) 12%,transparent)}
  .ostat.und{color:var(--muted);background:var(--surface-3)}
  /* mobile: table collapses to cards */
  @media(max-width:760px){
    .ex-table thead{display:none}
    .ex-table,.ex-table tbody,.ex-table tr,.ex-table td{display:block;width:100%}
    .ex-table tbody tr{border:1px solid var(--line);border-radius:13px;margin-bottom:.6rem;padding:.6rem .8rem;background:var(--surface);box-shadow:var(--shadow-sm)}
    .ex-table td{padding:.2rem 0;text-align:left!important;display:flex;justify-content:space-between;gap:1rem}
    .ex-table td::before{content:attr(data-h);font:800 .54rem var(--grotesk);text-transform:uppercase;letter-spacing:.04em;color:var(--muted);flex:0 0 auto}
    .ex-table td.nm{font-size:1rem}
    .ex-table td.nm::before{content:""}
  }

  /* ---- DRAWER ---- */
  .drawer-scrim{position:fixed;inset:0;background:rgba(8,16,32,.5);backdrop-filter:blur(2px);z-index:80;opacity:0;pointer-events:none;transition:opacity .25s}
  .drawer-scrim.open{opacity:1;pointer-events:auto}
  .drawer{position:fixed;top:0;right:0;bottom:0;width:min(420px,92vw);background:var(--page);box-shadow:var(--shadow-lg);z-index:81;
    transform:translateX(100%);transition:transform .32s var(--ease);overflow-y:auto;display:flex;flex-direction:column}
  .drawer.open{transform:none}
  @media(max-width:520px){.drawer{width:100vw;top:auto;bottom:0;height:88vh;border-radius:22px 22px 0 0;transform:translateY(100%)}.drawer.open{transform:none}}
  .dr-hero{position:relative;padding:1.3rem 1.3rem 1.1rem;color:#fff;overflow:hidden}
  .dr-hero .drx{position:absolute;inset:0;z-index:0}
  .dr-hero>*{position:relative;z-index:1}
  .dr-close{position:absolute;top:.8rem;right:.8rem;z-index:2;width:34px;height:34px;border-radius:50%;border:0;background:rgba(255,255,255,.2);color:#fff;font-size:1.1rem;cursor:pointer;transition:.15s}
  .dr-close:hover{background:rgba(255,255,255,.32)}
  .dr-top{display:flex;align-items:center;gap:.85rem}
  .dr-av{position:relative;width:66px;height:66px;border-radius:16px;overflow:hidden;background:rgba(255,255,255,.18);display:grid;place-items:center;font:800 1.2rem var(--mono);flex:0 0 auto}
  .dr-av img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 12%}
  .dr-nm{font-family:var(--serif);font-weight:600;font-size:1.55rem;line-height:1.05}
  .dr-sub{opacity:.92;font:600 .72rem var(--mono);margin-top:.2rem}
  .dr-body{padding:1.1rem 1.3rem 2rem;flex:1}
  .dr-path{display:flex;align-items:center;gap:.6rem;padding:.85rem .9rem;border-radius:13px;background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow-sm);margin-bottom:1rem}
  .dr-path .node{text-align:center;flex:1}
  .dr-path .node .nk{font:700 .5rem var(--grotesk);text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}
  .dr-path .node .nv{font:800 .96rem var(--mono);color:var(--ink);margin-top:.2rem;line-height:1.1}
  .dr-path .node .ns{font:600 .58rem var(--mono);color:var(--muted);margin-top:.1rem}
  .dr-path .node img{width:28px;height:28px;object-fit:contain;margin:.15rem auto 0;display:block}
  .dr-path .arr{color:var(--muted-2);font-size:1.2rem;flex:0 0 auto}
  .dr-statgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(56px,1fr));gap:.5rem;margin-bottom:1rem}
  .dr-st{text-align:center;padding:.6rem .3rem;border-radius:11px;background:var(--surface);border:1px solid var(--line)}
  .dr-st b{font:800 1.25rem var(--mono);color:var(--ink);line-height:1;font-variant-numeric:tabular-nums}
  .dr-st span{display:block;font:700 .5rem var(--grotesk);text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin-top:.3rem}
  /* 5-up stat grid gets tight on phones — shrink so 4-digit comma totals (1,761) never clip */
  @media (max-width:480px){ .dr-statgrid{gap:.34rem} .dr-st{padding:.5rem .14rem} .dr-st b{font-size:1.02rem} }
  .dr-line{font:600 .82rem var(--body);color:var(--ink-2);line-height:1.6;margin-bottom:.9rem}
  .dr-line b{color:var(--ink)}
  .conf-badge{display:inline-flex;align-items:center;gap:.4rem;font:700 .66rem var(--mono);padding:.4rem .65rem;border-radius:9px}
.conf-badge.exact{color:var(--green-deep);background:color-mix(in srgb,var(--green) 12%,transparent);border:1px solid color-mix(in srgb,var(--green) 30%,transparent)}
.conf-badge.alias{color:var(--gold-deep);background:color-mix(in srgb,var(--gold) 12%,transparent);border:1px solid color-mix(in srgb,var(--gold) 32%,transparent)}
.conf-badge.variant{color:var(--blue-dark);background:color-mix(in srgb,var(--cyan) 12%,transparent);border:1px solid color-mix(in srgb,var(--cyan) 32%,transparent)}
.conf-badge.fallback{color:var(--red-deep);background:color-mix(in srgb,var(--red) 10%,transparent);border:1px solid color-mix(in srgb,var(--red) 30%,transparent)}
  .conf-badge.und{color:var(--muted);background:var(--surface-3);border:1px solid var(--line)}

  /* ---- METHOD ---- */
  .method{margin-top:1.5rem;border-radius:var(--radius-lg);border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow-sm);padding:1.15rem 1.3rem}
  .method h4{font:800 .62rem var(--grotesk);text-transform:uppercase;letter-spacing:.08em;color:var(--blue);margin-bottom:.55rem}
  .method p{font-size:.85rem;line-height:1.7;color:var(--ink-2);margin:0 0 .7rem;max-width:96ch}.method p:last-child{margin-bottom:0}
  .method b{color:var(--ink)}
  .method code{font:700 .82em var(--mono);color:var(--blue);background:var(--surface-3);padding:.05rem .3rem;border-radius:5px}
  .src-row{display:flex;flex-wrap:wrap;gap:.45rem;margin-bottom:.75rem}
  .src-row .src{display:inline-flex;align-items:center;gap:.28rem;text-decoration:none;font:800 .6rem var(--grotesk);text-transform:uppercase;letter-spacing:.05em;color:var(--blue-dark);background:color-mix(in srgb,var(--blue) 7%,var(--surface));border:1px solid color-mix(in srgb,var(--blue) 20%,var(--line));border-radius:999px;padding:.32rem .58rem}
  .src-row .src:hover{border-color:var(--blue);background:color-mix(in srgb,var(--blue) 13%,var(--surface))}
  .conf-key{display:flex;flex-wrap:wrap;gap:.5rem 1.1rem;margin-top:.3rem;font:700 .66rem var(--mono);color:var(--muted)}
  .conf-key i{display:inline-block;width:9px;height:9px;border-radius:50%;vertical-align:middle;margin-right:.35rem}

  /* ===== shared: compact NHL career stat tag (rows + explorer) ===== */
  .gp-tag{display:inline-flex;align-items:center;gap:.3rem;font:700 .58rem var(--mono);color:var(--blue-dark);
    background:color-mix(in srgb,var(--blue) 11%,transparent);border-radius:6px;padding:.05rem .34rem;white-space:nowrap;vertical-align:middle}
  .gp-tag.und{color:var(--muted);background:var(--surface-3)}

  /* ============ 1. WHAT THEY BECAME — career funnel ============ */
  .fn-toggle{display:flex;flex-wrap:wrap}
  .fn-toggle button.on{color:#fff}
  .fn-toggle .glider{background:linear-gradient(135deg,var(--lg,var(--blue)),var(--lgd,var(--blue-dark)))}
  .funnel{display:flex;flex-direction:column;gap:.55rem;padding:.3rem 1.35rem 1.1rem}
  .fn-row{display:grid;grid-template-columns:128px 1fr;gap:.8rem;align-items:center}
  @media(max-width:560px){.fn-row{grid-template-columns:96px 1fr;gap:.5rem}}
  .fn-l{text-align:right}
  .fn-l .fn-k{font:800 .6rem var(--grotesk);text-transform:uppercase;letter-spacing:.03em;color:var(--ink-2);line-height:1.1}
  .fn-l .fn-s{font:600 .54rem var(--mono);color:var(--muted);margin-top:.12rem;display:block}
  .fn-track{position:relative;height:42px;border-radius:10px;background:var(--surface-3);overflow:hidden}
  .fn-fill{position:absolute;left:0;top:0;bottom:0;width:0;border-radius:10px;transition:width 1.05s var(--ease);
    background:linear-gradient(90deg,var(--lg,var(--blue)),var(--lgd,var(--blue-dark)));display:flex;align-items:center;min-width:3px}
  .fn-fill.dim{opacity:.92;background:linear-gradient(90deg,color-mix(in srgb,var(--lg,var(--blue)) 62%,var(--surface)),var(--lg,var(--blue)))}
  .fn-in{display:flex;align-items:center;gap:.5rem;padding-left:.7rem;white-space:nowrap}
  .fn-in b{font:800 1.05rem var(--mono);color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.35);font-variant-numeric:tabular-nums}
  .fn-in .fn-pct{font:800 .64rem var(--mono);color:rgba(255,255,255,.92)}
  .fn-out{position:absolute;right:.6rem;top:50%;transform:translateY(-50%);font:700 .62rem var(--mono);color:var(--muted)}
  .fn-note{padding:0 1.35rem 1.2rem;font:600 .72rem var(--mono);color:var(--muted);line-height:1.5}
  .fn-note b{color:var(--ink-2)}

  /* ============ 2. SCATTER — pedigree translation ============ */
  .scat-wrap{padding:.3rem 1.35rem 1rem}
  .scat-svg{width:100%;height:auto;display:block;border-radius:14px;background:linear-gradient(180deg,var(--surface),var(--surface-2));border:1px solid var(--line);overflow:visible}
  .scat-svg .grid{stroke:var(--line);stroke-width:1}
  .scat-svg .axlab{fill:var(--muted);font:700 9px var(--mono)}
  .scat-svg .axttl{fill:var(--ink-2);font:800 10px var(--grotesk);text-transform:uppercase;letter-spacing:.06em}
  .scat-svg .trend{stroke:var(--ink-2);stroke-width:1.4;stroke-dasharray:5 4;opacity:.5}
  .scat-dot{cursor:pointer;transition:opacity .15s}
  .scat-dot:hover{stroke:var(--ink);stroke-width:1.5}
  .scat-corr{display:flex;flex-wrap:wrap;gap:.6rem;padding:.4rem 1.35rem 0}
  .corrcard{flex:1;min-width:150px;padding:.7rem .85rem;border-radius:12px;background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow-sm)}
  .corrcard b{font:800 1.6rem var(--mono);color:var(--blue-dark);line-height:1;font-variant-numeric:tabular-nums}
  .corrcard .ck{font:800 .54rem var(--grotesk);text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-top:.3rem}
  .corrcard .cd{font:600 .6rem var(--mono);color:var(--muted);margin-top:.25rem;line-height:1.4}
  .scat-tip{position:absolute;pointer-events:none;z-index:20;background:var(--ink);color:var(--page);font:700 .66rem var(--mono);
    padding:.3rem .5rem;border-radius:7px;box-shadow:var(--shadow);opacity:0;transition:opacity .12s;white-space:nowrap;transform:translate(-50%,-130%)}
  .scat-leg{display:flex;flex-wrap:wrap;gap:.8rem;padding:.5rem 1.35rem 0;font:700 .58rem var(--mono);color:var(--muted)}
  .scat-leg i{display:inline-block;width:10px;height:10px;border-radius:50%;vertical-align:middle;margin-right:.3rem}

  /* ============ 3. BEST AT EVERY SLOT ============ */
  .slotgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(168px,1fr));gap:.6rem;padding:.3rem 1.35rem 1.2rem}
  .slot{position:relative;border-radius:14px;border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow-sm);
    padding:.7rem .75rem;cursor:pointer;transition:.15s;overflow:hidden}
  .slot::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--lg,var(--blue))}
  .slot:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
  .slot:focus-visible{outline:2px solid var(--lg,var(--blue));outline-offset:2px}
  .slot-top{display:flex;align-items:center;gap:.55rem;margin-bottom:.5rem}
  .slot-pk{font:800 1.2rem var(--mono);color:var(--lgd,var(--blue-dark));line-height:1;flex:0 0 auto}
  .slot-pk small{display:block;font:700 .42rem var(--grotesk);color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
  .slot-av{position:relative;width:42px;height:42px;border-radius:11px;overflow:hidden;background:linear-gradient(140deg,var(--lg,var(--blue)),var(--lgd,var(--blue-dark)));
    display:grid;place-items:center;color:#fff;font:800 .72rem var(--mono);flex:0 0 auto;margin-left:auto}
  .slot-av img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 12%}
  .slot-av .sl-logo{position:absolute;right:-2px;bottom:-2px;width:18px;height:18px;object-fit:contain;background:var(--surface);border-radius:50%;padding:1px;box-shadow:var(--shadow-sm)}
  .slot-nm{font-weight:700;font-size:.84rem;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .slot-sub{font:600 .56rem var(--mono);color:var(--muted);margin-top:.15rem}
  .slot-foot{display:flex;justify-content:space-between;gap:.4rem;margin-top:.5rem;padding-top:.45rem;border-top:1px solid var(--line);font:700 .56rem var(--mono);color:var(--muted)}
  .slot-foot b{color:var(--ink-2);font-weight:800}

  /* ============ 4. DRAFT FACTORIES ============ */
  .factory{display:flex;flex-direction:column;gap:.4rem;padding:.3rem 1.35rem 1.2rem}
  .fac{display:grid;grid-template-columns:28px 46px 1fr 96px auto;gap:.65rem;align-items:center;padding:.5rem .55rem;border-radius:12px;
    border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow-sm);cursor:pointer;transition:.14s}
  .fac:hover{transform:translateY(-1px);box-shadow:var(--shadow)}
  .fac:focus-visible{outline:2px solid var(--lg,var(--blue));outline-offset:2px}
  .fac-rk{font:800 .82rem var(--mono);color:var(--muted);text-align:center}
  .fac-av{position:relative;width:46px;height:46px;border-radius:12px;overflow:hidden;background:linear-gradient(140deg,var(--lg,var(--blue)),var(--lgd,var(--blue-dark)));
    display:grid;place-items:center;color:#fff;font:800 .74rem var(--mono);flex:0 0 auto}
  .fac-av img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 12%}
  .fac-mid{min-width:0}
  .fac-nm{font-weight:700;font-size:.92rem;line-height:1.1;display:flex;align-items:center;gap:.4rem}
  .fac-sub{font:600 .58rem var(--mono);color:var(--muted);margin-top:.15rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .fac-sub b{color:var(--lgd,var(--blue-dark))}
  .fac-bar{flex:0 0 auto}
  .fac-track{position:relative;height:11px;border-radius:6px;background:var(--surface-3);overflow:hidden}
  .fac-fill{position:absolute;inset:0;width:0;border-radius:6px;transition:width 1s var(--ease);background:linear-gradient(90deg,var(--lg,var(--blue)),var(--lgd,var(--blue-dark)))}
  .fac-bar .fb-lab{font:700 .52rem var(--mono);color:var(--muted);margin-top:.18rem;text-align:right}
  .fac-st{text-align:right;flex:0 0 auto}
  .fac-st b{font:800 1.05rem var(--mono);color:var(--ink);line-height:1;font-variant-numeric:tabular-nums}
  .fac-st span{display:block;font:700 .48rem var(--grotesk);text-transform:uppercase;letter-spacing:.03em;color:var(--muted);margin-top:.2rem}
  @media(max-width:680px){.fac{grid-template-columns:24px 42px 1fr auto}.fac-bar{display:none}}

  /* ============ 5. POSITION TRANSLATION ============ */
  .posgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:.7rem;padding:0 1.35rem 1.2rem}
  @media(max-width:640px){.posgrid{grid-template-columns:1fr}}
  .poscard{position:relative;border-radius:15px;border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow-sm);padding:.9rem 1rem;overflow:hidden}
  .poscard::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--pc,var(--blue))}
  .poscard.F{--pc:var(--blue)} .poscard.D{--pc:var(--purple)} .poscard.G{--pc:var(--gold)}
  .pos-h{display:flex;align-items:baseline;justify-content:space-between;gap:.5rem;margin-bottom:.7rem}
  .pos-h b{font:800 1rem var(--grotesk);color:var(--ink)}
  .pos-h span{font:600 .58rem var(--mono);color:var(--muted)}
  .pos-bar{display:flex;flex-direction:column;gap:.3rem;margin-bottom:.6rem}
  .pos-bar .pb-row{display:flex;align-items:center;gap:.5rem}
  .pos-bar .pb-tag{font:700 .5rem var(--grotesk);text-transform:uppercase;letter-spacing:.03em;color:var(--muted);width:58px;flex:0 0 auto}
  .pos-bar .pb-track{flex:1;height:11px;border-radius:6px;background:var(--surface-3);overflow:hidden}
  .pos-bar .pb-fill{height:100%;width:0;border-radius:6px;transition:width 1s var(--ease);background:linear-gradient(90deg,var(--pc),color-mix(in srgb,var(--pc) 60%,#0a1424))}
  .pos-bar .pb-val{font:800 .66rem var(--mono);color:var(--ink-2);width:38px;text-align:right;flex:0 0 auto;font-variant-numeric:tabular-nums}
  .pos-foot{display:flex;justify-content:space-between;gap:.5rem;padding-top:.5rem;border-top:1px solid var(--line);font:700 .58rem var(--mono);color:var(--muted)}
  .pos-foot b{color:var(--ink-2);font-weight:800}

  /* ============ 6. ERA TRENDS ============ */
  .era-toggle{display:flex;flex-wrap:wrap}
  .era-toggle button.on{color:#fff}
  .era-toggle .glider{background:linear-gradient(135deg,var(--blue),var(--blue-dark))}
  .era-wrap{padding:.3rem 1.35rem .6rem}
  .era-svg{width:100%;height:auto;display:block}
  .era-svg .grid{stroke:var(--line);stroke-width:1}
  .era-svg .axlab{fill:var(--muted);font:700 9px var(--mono)}
  .era-svg .eline{fill:none;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round;opacity:.95}
  .era-svg .edot{stroke:var(--surface);stroke-width:1.5}
  .era-leg{display:flex;flex-wrap:wrap;gap:.9rem;padding:.2rem 1.35rem 1.2rem;font:700 .62rem var(--mono);color:var(--ink-2)}
  .era-leg i{display:inline-block;width:14px;height:4px;border-radius:2px;vertical-align:middle;margin-right:.35rem}

  /* ============ 7. BUSTS rail ============ */
  .busts{display:flex;gap:.7rem;overflow-x:auto;padding:.2rem .3rem .6rem;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
  .bust{flex:0 0 178px;scroll-snap-align:start;border-radius:15px;border:1px solid color-mix(in srgb,var(--red) 22%,var(--line));
    background:linear-gradient(160deg,color-mix(in srgb,var(--red) 8%,var(--surface)),var(--surface-2));box-shadow:var(--shadow-sm);padding:.85rem .9rem;position:relative;overflow:hidden}
  .bust .bx-av{width:50px;height:50px;border-radius:13px;background:var(--surface-3);display:grid;place-items:center;color:var(--muted);font:800 .85rem var(--mono);margin-bottom:.55rem}
  .bust .bx-pk{position:absolute;top:.7rem;right:.8rem;font:800 .82rem var(--mono);color:var(--red-deep)}
  .bust .bx-pk small{font:700 .42rem var(--grotesk);color:var(--muted);text-transform:uppercase;display:block;text-align:right}
  .bust .bx-nm{font-weight:700;font-size:.9rem;line-height:1.1}
  .bust .bx-meta{font:600 .58rem var(--mono);color:var(--muted);margin-top:.3rem}
  .bust .bx-out{font:800 .56rem var(--grotesk);text-transform:uppercase;letter-spacing:.03em;margin-top:.5rem;color:var(--red-deep)}
  .bust .bx-out.dr{color:var(--gold-deep)}

  /* ============ 8. NHL DESTINATIONS ============ */
  .destgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:.55rem;padding:.3rem 1.35rem 1.2rem}
  .dest{display:flex;align-items:center;gap:.6rem;padding:.55rem .65rem;border-radius:12px;border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow-sm)}
  .dest img{width:34px;height:34px;object-fit:contain;flex:0 0 auto;filter:drop-shadow(0 1px 2px rgba(11,28,60,.16))}
  .dest .d-av{width:34px;height:34px;border-radius:8px;background:var(--surface-3);display:grid;place-items:center;font:800 .62rem var(--mono);color:var(--muted);flex:0 0 auto}
  .dest .d-mid{min-width:0}
  .dest .d-n{font:800 1.15rem var(--mono);color:var(--ink);line-height:1;font-variant-numeric:tabular-nums}
  .dest .d-n small{font-size:.46em;font-weight:700;color:var(--muted)}
  .dest .d-s{font:600 .55rem var(--mono);color:var(--muted);margin-top:.18rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .dest .d-s b{color:var(--ink-2)}

  /* ============ 9. TIMING DECODER ============ */
  .decoder{display:grid;grid-template-columns:1fr 1fr;gap:1rem;padding:0 1.35rem 1rem}
  @media(max-width:760px){.decoder{grid-template-columns:1fr}}
  .dec-card{border-radius:var(--radius-lg);border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow-sm);padding:1rem 1.1rem}
  .dec-card h3{font:800 .62rem var(--grotesk);text-transform:uppercase;letter-spacing:.07em;color:var(--ink-2);margin-bottom:.7rem}
  .medlag{display:flex;flex-direction:column;gap:.6rem}
  .ml-row{display:grid;grid-template-columns:54px 1fr 38px;gap:.6rem;align-items:center}
  .ml-row .ml-lg{font:800 .72rem var(--grotesk)}
  .ml-track{position:relative;height:30px;border-radius:8px;background:var(--surface-3);overflow:hidden}
  .ml-fill{position:absolute;left:0;top:0;bottom:0;width:0;border-radius:8px;transition:width 1s var(--ease);background:linear-gradient(90deg,var(--lg),var(--lgd));display:flex;align-items:center}
  .ml-fill b{font:800 .68rem var(--mono);color:#fff;padding-left:.5rem;text-shadow:0 1px 2px rgba(0,0,0,.3)}
  .ml-row .ml-v{font:800 .8rem var(--mono);color:var(--ink-2);text-align:right}
  .late{display:flex;flex-direction:column;gap:.45rem}
  .lateb{display:grid;grid-template-columns:40px 1fr auto;gap:.6rem;align-items:center;padding:.4rem .5rem;border-radius:11px;border:1px solid var(--line);background:var(--surface-2);cursor:pointer;transition:.14s}
  .lateb:hover{background:var(--surface);box-shadow:var(--shadow-sm)}
  .lateb:focus-visible{outline:2px solid var(--lg,var(--blue));outline-offset:2px}
  .lb-av{position:relative;width:40px;height:40px;border-radius:10px;overflow:hidden;background:linear-gradient(140deg,var(--lg,var(--blue)),var(--lgd,var(--blue-dark)));display:grid;place-items:center;color:#fff;font:800 .66rem var(--mono);flex:0 0 auto}
  .lb-av img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 12%}
  .lb-mid{min-width:0}
  .lb-nm{font-weight:700;font-size:.84rem;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .lb-sub{font:600 .56rem var(--mono);color:var(--muted);margin-top:.12rem}
  .lb-sub b{color:var(--lgd,var(--blue-dark))}
  .lb-lag{font:800 .9rem var(--mono);color:var(--lgd,var(--blue-dark));text-align:right;flex:0 0 auto}
  .lb-lag small{display:block;font:700 .46rem var(--grotesk);color:var(--muted);text-transform:uppercase}
  .dec-note{padding:0 1.35rem 1.2rem;font:600 .74rem var(--mono);color:var(--muted);line-height:1.55}
  .dec-note b{color:var(--ink-2)}

  /* ============ 10. CLAIM BUILDER ============ */
  .claim{margin:0 1.35rem 1.3rem;position:relative;overflow:hidden;border-radius:var(--radius-lg);
    background:radial-gradient(120% 140% at 0 0,color-mix(in srgb,var(--blue) 10%,transparent),transparent 55%),linear-gradient(180deg,var(--surface-2),var(--surface));
    border:1px solid color-mix(in srgb,var(--blue) 24%,var(--line));box-shadow:var(--shadow-sm)}
  .claim::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,var(--blue),color-mix(in srgb,var(--blue) 35%,transparent))}
  .claim-in{padding:1rem 1.2rem 1.05rem 1.4rem}
  .claim-k{font:800 .56rem var(--mono);text-transform:uppercase;letter-spacing:.12em;color:var(--blue);margin-bottom:.5rem;display:flex;align-items:center;gap:.45rem}
  .claim-k::after{content:"";flex:1;height:1px;background:linear-gradient(90deg,color-mix(in srgb,var(--blue) 40%,transparent),transparent)}
  .claim-say{font-family:var(--serif);font-weight:500;font-size:1.16rem;line-height:1.5;color:var(--ink);letter-spacing:-.005em}
  .claim-say .num{font-family:var(--mono);font-weight:800;color:var(--blue-dark);font-variant-numeric:tabular-nums}
  .claim-foot{display:flex;align-items:center;justify-content:space-between;gap:.7rem;margin-top:.85rem;flex-wrap:wrap}
  .claim-meta{font:700 .6rem var(--mono);color:var(--muted)}
  .claim-cp{font:800 .64rem var(--grotesk);text-transform:uppercase;letter-spacing:.03em;padding:.42rem .8rem;border-radius:9px;border:1px solid var(--blue);background:var(--blue);color:#fff;cursor:pointer;transition:.15s;white-space:nowrap}
  .claim-cp:hover{filter:brightness(1.06);transform:translateY(-1px)}
  .claim-cp.ok{background:var(--green);border-color:var(--green)}

  /* ---- ROUND-DECAY CURVE ---- */
  .rd-wrap{padding:.5rem 1.35rem 1rem;display:flex;flex-direction:column;gap:.42rem}
  .rd-row{display:grid;grid-template-columns:44px 1fr 138px;gap:.7rem;align-items:center}
  .rd-rk{font:800 .82rem var(--mono);color:var(--lgd,var(--blue-dark));text-align:right;line-height:1}
  .rd-rk small{display:block;font:700 .44rem var(--grotesk);color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-top:.12rem}
  .rd-track{position:relative;height:22px;border-radius:7px;background:var(--surface-3);overflow:hidden;border:1px solid var(--line)}
  .rd-draft{position:absolute;left:0;top:0;bottom:0;border-radius:7px;width:0;background:color-mix(in srgb,var(--blue) 22%,transparent);transition:width .85s cubic-bezier(.22,1,.36,1)}
  .rd-play{position:absolute;left:0;top:0;bottom:0;border-radius:7px;width:0;background:linear-gradient(90deg,var(--blue),var(--blue-dark));transition:width .85s cubic-bezier(.22,1,.36,1)}
  .rd-val{display:flex;gap:.55rem;justify-content:flex-end;font:800 .7rem var(--mono);font-variant-numeric:tabular-nums;white-space:nowrap}
  .rd-val .d{color:var(--blue-dark)} .rd-val .p{color:var(--ink)} .rd-val .n{color:var(--muted);font-weight:700}
  .rd-leg{display:flex;flex-wrap:wrap;gap:.4rem 1.1rem;padding:0 1.35rem 1rem;font:700 .62rem var(--mono);color:var(--ink-2);align-items:center}
  .rd-leg i.rd-s{display:inline-block;width:14px;height:10px;border-radius:3px;margin-right:.35rem;vertical-align:middle}
  .rd-s.draft{background:color-mix(in srgb,var(--blue) 22%,transparent)} .rd-s.play{background:linear-gradient(90deg,var(--blue),var(--blue-dark))}
  @media(max-width:560px){.rd-row{grid-template-columns:36px 1fr 108px;gap:.4rem}.rd-val{gap:.32rem;font-size:.6rem}}

  @media(prefers-reduced-motion:reduce){.tb-fill,.bd-draft,.bd-play,.lagbar,.drawer,.drawer-scrim,
    .fn-fill,.fac-fill,.pb-fill,.ml-fill,.scat-dot,.rd-draft,.rd-play{transition:none}}

/* ============================ production header + local section nav ============================ */
.chl-top { position:sticky; top:0; z-index:60; background:var(--glass); -webkit-backdrop-filter:blur(18px); backdrop-filter:blur(18px); border-bottom:1px solid var(--line); color:var(--ink); }
.chl-top .wrap.chl-top-in { max-width:none; padding:0 clamp(1rem,3vw,2.4rem); }
.chl-top-in { display:flex; align-items:center; gap:1rem; height:64px; }
.chl-brand { display:inline-flex; align-items:center; gap:.65rem; color:var(--ink); font-family:var(--body); font-size:1.18rem; font-weight:800; text-decoration:none; letter-spacing:-.005em; white-space:nowrap; flex:0 0 auto; }
.chl-brand:hover { text-decoration:none; }
.chl-brand-mark { display:inline-flex; align-items:center; justify-content:center; width:32px; height:32px; border-radius:9px; background:transparent; box-shadow:0 8px 20px rgba(20,99,232,.18); overflow:hidden; flex:0 0 auto; }
.chl-brand-mark img { display:block; width:100%; height:100%; }
.chl-brand-tag { display:inline-flex; align-items:center; padding:2px 8px; margin-left:.4rem; border-radius:999px; background:color-mix(in srgb,var(--blue) 10%,transparent); color:var(--blue); font-size:.62rem; font-weight:800; letter-spacing:.08em; }
.chl-brand-short { display:none; }
.chl-topnav { display:flex; align-items:center; gap:.2rem; margin-left:.6rem; flex:1 1 auto; min-width:0; overflow-x:auto; scrollbar-width:none; -webkit-mask-image:linear-gradient(90deg,#000 calc(100% - 18px),transparent 100%); mask-image:linear-gradient(90deg,#000 calc(100% - 18px),transparent 100%); }
.chl-topnav::-webkit-scrollbar { display:none; }
.chl-topnav a { display:inline-flex; align-items:center; height:34px; padding:0 .75rem; border-radius:999px; color:var(--muted); font:700 .86rem var(--body); text-decoration:none; white-space:nowrap; transition:background .14s ease,color .14s ease; }
.chl-topnav a:hover, .chl-topnav a.active { color:var(--blue); background:color-mix(in srgb,var(--blue) 10%,transparent); }
.chl-theme { background:var(--surface-3); border:1px solid var(--line); color:var(--ink); width:34px; height:34px; border-radius:999px; cursor:pointer; font-size:1rem; flex:0 0 auto; }
.chl-secnav { position:sticky; top:64px; z-index:40; background:var(--glass); -webkit-backdrop-filter:blur(12px); backdrop-filter:blur(12px); border-bottom:1px solid var(--line); }
.chl-secnav-in { display:flex; gap:.3rem; min-height:42px; align-items:center; overflow-x:auto; scrollbar-width:none; }
.chl-secnav-in::-webkit-scrollbar { display:none; }
.chl-secnav a { display:inline-flex; align-items:center; min-height:32px; font:700 .68rem var(--mono); text-transform:uppercase; letter-spacing:.06em; color:var(--muted); text-decoration:none; padding:.3rem .55rem; border-radius:7px; white-space:nowrap; }
.chl-secnav a:hover, .chl-secnav a.active { color:var(--blue); background:color-mix(in srgb,var(--blue) 10%,transparent); }
/* anchor jumps + the translator's own sticky controls must clear both bars (header 64 + secnav 42) */
html.chl-page-root { scroll-padding-top: 116px; }
section[id], .proof[id] { scroll-margin-top: 116px; }
@media (max-width:720px){
  .chl-top .wrap.chl-top-in { padding:.55rem .75rem; }
  .chl-top-in{ flex-wrap:wrap; height:auto; min-height:64px; gap:.4rem .55rem; }
  .chl-brand{ order:0; flex:1 1 auto; min-width:0; font-size:1.05rem; gap:.45rem; }
  .chl-brand-full{ display:none; }
  .chl-brand-short{ display:inline; }
  .chl-brand-tag{ margin-left:.3rem; }
  .chl-topnav{ order:2; flex:0 0 100%; width:100%; max-width:100%; margin-left:0; padding-top:.45rem; padding-bottom:.1rem; border-top:1px solid var(--line); }
  .chl-topnav a{ flex:0 0 auto; min-height:44px; height:auto; padding:.5rem .7rem; }
  .chl-theme{ order:1; width:44px; height:44px; min-height:44px; }
  .chl-secnav{ top:122px; }
  .chl-secnav-in{ min-height:48px; padding:.1rem 0; }
  .chl-secnav a{ min-height:44px; padding:.5rem .7rem; }
  html.chl-page-root{ scroll-padding-top:174px; }
  section[id], .proof[id]{ scroll-margin-top:174px; }
}

/* ============================ reconciliation table · audit module · D+2 clarifier ============================ */
.proof-chk { display:block; }
.recon { width:100%; border-collapse:collapse; margin-top:.7rem; }
.recon th { text-align:left; font:800 .54rem var(--grotesk); text-transform:uppercase; letter-spacing:.07em; color:var(--muted); padding:.4rem .5rem; border-bottom:1px solid var(--line); }
.recon td { padding:.45rem .5rem; border-bottom:1px solid var(--line); font:600 .8rem var(--mono); vertical-align:middle; }
.recon td.rk { color:var(--ink-2); font-weight:700; font-family:var(--body); }
.recon td.re { color:var(--muted); }
.recon td.rd { color:var(--ink); font-weight:800; }
.recon td.rs { font-weight:800; white-space:nowrap; }
.recon tr.ok td.rs { color:var(--green-deep); }
.recon tr.bad td.rs { color:var(--red-deep); }
.recon .tick { color:var(--green); margin-right:.3rem; font-weight:900; }
.recon .cross { color:var(--red); margin-right:.3rem; font-weight:900; }
.recon-foot { margin-top:.55rem; font:800 .7rem var(--mono); padding:.45rem .65rem; border-radius:9px; }
.recon-foot.ok { color:var(--green-deep); background:color-mix(in srgb,var(--green) 12%,transparent); }
.recon-foot.bad { color:var(--red-deep); background:color-mix(in srgb,var(--red) 12%,transparent); }
.recon.conf td.rd { color:var(--red-deep); }
.recon.conf .cmut { color:var(--muted); font-weight:600; font-size:.85em; }
.audit-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; margin:0 1.35rem 1rem; }
.audit-card { background:var(--surface); padding:.85rem .9rem; display:flex; flex-direction:column; gap:.1rem; }
.audit-card b { font:800 1.55rem var(--mono); color:var(--ink); font-variant-numeric:tabular-nums; line-height:1; }
.audit-card.warn b { color:var(--gold-deep); }
.audit-card .ak { font:800 .6rem var(--grotesk); text-transform:uppercase; letter-spacing:.05em; color:var(--ink-2); margin-top:.28rem; }
.audit-card .as { font:600 .62rem var(--mono); color:var(--muted); line-height:1.4; }
.audit-conf { margin:0 1.35rem 1.35rem; }
.audit-conf-h { font-size:.82rem; color:var(--ink-2); line-height:1.55; margin-bottom:.55rem; }
.audit-conf-h b { color:var(--gold-deep); }
.audit-detail { margin:0 1.35rem 1.35rem; border:1px solid var(--line); border-radius:14px; background:var(--surface); overflow:hidden; box-shadow:var(--shadow-sm); }
.audit-tabs { display:flex; flex-wrap:wrap; gap:.35rem; padding:.7rem; border-bottom:1px solid var(--line); background:var(--surface-2); }
.audit-tabs button { font:800 .58rem var(--grotesk); text-transform:uppercase; letter-spacing:.05em; border:1px solid var(--line-2); background:var(--surface); color:var(--ink-2); border-radius:999px; padding:.38rem .62rem; cursor:pointer; }
.audit-tabs button.on { color:#fff; background:var(--blue); border-color:var(--blue); }
.audit-table-wrap { max-height:420px; overflow:auto; }
.audit-table { width:100%; border-collapse:collapse; min-width:760px; }
.audit-table th { position:sticky; top:0; z-index:1; text-align:left; font:800 .54rem var(--grotesk); text-transform:uppercase; letter-spacing:.06em; color:var(--muted); background:var(--surface-2); border-bottom:1px solid var(--line); padding:.5rem .6rem; }
.audit-table td { padding:.5rem .6rem; border-bottom:1px solid var(--line); font:650 .76rem var(--body); color:var(--ink-2); }
.audit-table td:nth-child(1),.audit-table td:nth-child(3),.audit-table td:nth-child(4){font-family:var(--mono);font-weight:750;color:var(--ink)}
@media(max-width:760px){.audit-detail{margin:0 1rem 1rem}.audit-table-wrap{max-height:360px}.ex-presets{padding:0 1rem .85rem}.sc-actions{width:100%;justify-content:flex-start}}
.sc-lag { grid-column:1 / -1; font:700 .73rem var(--mono); color:var(--muted); padding:.55rem .2rem 0; border-top:1px solid var(--line); margin-top:.3rem; }
.sc-lag b { color:var(--ink); }

/* funnel: baseline label + step-conversion chip; position: horizon sublabels */
.fn-base { font:700 .62rem var(--mono); color:rgba(255,255,255,.82); letter-spacing:.04em; }
.fn-keep { font:700 .56rem var(--mono); color:rgba(255,255,255,.72); margin-left:.4rem; }
.fn-fill.dim .fn-keep { color:var(--muted); }
.pb-tag small { font:700 .5rem var(--mono); color:var(--muted); opacity:.8; margin-left:.2rem; }

/* slot rework: team logo on the sub-line (off the headshot), scrollable grid, empty state */
.slot-av .sl-logo { display:none; }
.slot-sub .sl-tm { width:14px; height:14px; object-fit:contain; vertical-align:-2px; margin-right:.28rem; }
.slotgrid-wrap { max-height:660px; overflow-y:auto; border-radius:12px; }
.slotgrid-wrap::-webkit-scrollbar { width:8px; } .slotgrid-wrap::-webkit-scrollbar-thumb { background:var(--line-2); border-radius:8px; }
.slot-empty { grid-column:1/-1; padding:1.6rem; text-align:center; color:var(--muted); font:600 .85rem var(--body); }

/* eras rework: area fills, end-of-line labels, peak markers, insight note */
.era-svg .earea { stroke:none; }
.era-svg .eline { fill:none; stroke-width:2.6; stroke-linejoin:round; stroke-linecap:round; }
.era-svg .edot { stroke:var(--surface); stroke-width:1.4; }
.era-svg .edot.peak { stroke-width:2; }
.era-svg .end-lab { font:800 .62rem var(--mono); }
#eraNote { margin-top:.4rem; }

/* scatter polish: perfect-pedigree reference diagonal + dot/line styling */
.scat-svg .scat-ref { stroke:var(--muted); stroke-width:1.4; stroke-dasharray:5 5; opacity:.45; }
.scat-svg .scat-reflab { font:700 .56rem var(--mono); fill:var(--muted); }
.scat-svg .scat-trendlab { font:800 .58rem var(--mono); fill:var(--red); }
.scat-svg .scat-dot { stroke:var(--surface); stroke-width:.6; transition:stroke-width .12s; cursor:pointer; }
.scat-svg .scat-dot:hover { stroke:var(--ink); stroke-width:1.6; }
.scat-svg .trend { stroke-width:2.4; }

/* explorer polish (desktop only — mobile keeps the card view): zebra + firmer header */
@media (min-width:761px) {
  .ex-table tbody tr:nth-child(even) td { background:color-mix(in srgb, var(--surface-2) 55%, transparent); }
  .ex-table tbody tr:hover td { background:var(--surface-3); }
  .ex-table thead th { border-bottom:2px solid var(--line-2); }
}

/* ============================ collapsible "deep cuts" ============================ */
.sec.deep.collapsed > :not(.sec-head) { display:none; }
.sec.deep.collapsed .sec-head { padding-bottom:1.1rem; }
.deep-head { position:relative; cursor:pointer; user-select:none; padding-right:2.8rem; transition:background .15s; }
.deep-head:hover { background:color-mix(in srgb, var(--blue) 5%, transparent); }
.deep-head:focus-visible { outline:2px solid var(--blue); outline-offset:-3px; border-radius:8px; }
.deep-chev { position:absolute; right:1.2rem; top:1.35rem; font-size:1.05rem; line-height:1; color:var(--muted); transition:transform .2s var(--ease), color .2s; }
.sec.deep:not(.collapsed) .deep-chev { transform:rotate(90deg); color:var(--blue); }
.deep-peek{display:flex;flex-wrap:wrap;gap:.35rem .45rem;margin-top:.62rem}
.deep-peek span{display:inline-flex;align-items:center;min-height:24px;border:1px solid color-mix(in srgb,var(--blue) 20%,var(--line));background:color-mix(in srgb,var(--blue) 5%,var(--surface));border-radius:999px;padding:.26rem .52rem;font:800 .56rem var(--mono);color:var(--ink-2);white-space:nowrap}
.sec.deep.collapsed .deep-peek span{background:var(--surface)}
.deep-divider { margin:2.2rem 0 .4rem; padding:1.2rem 1.35rem .2rem; text-align:center; }
.deep-divider::before { content:""; display:block; width:60px; height:2px; margin:0 auto 1rem; border-radius:2px; background:linear-gradient(90deg,var(--blue),var(--cyan)); }
.deep-divider .dd-k { font:800 .6rem var(--grotesk); text-transform:uppercase; letter-spacing:.18em; color:var(--blue); }
.deep-divider h3 { font-family:var(--serif); font-weight:600; font-size:clamp(1.3rem,3vw,1.7rem); margin:.35rem 0 .4rem; letter-spacing:-.01em; line-height:1.05; }
.deep-divider p { font:600 .8rem var(--mono); color:var(--muted); max-width:62ch; margin:0 auto; line-height:1.55; }
.deep-kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.6rem;margin:1rem auto .8rem;max-width:980px}
.deep-kpis span{display:flex;flex-direction:column;gap:.18rem;border:1px solid var(--line);background:var(--surface);border-radius:12px;padding:.72rem .8rem;box-shadow:var(--shadow-sm);text-align:left}
.deep-kpis b{font:900 .98rem var(--mono);color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.deep-kpis small{font:750 .56rem/1.35 var(--grotesk);text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}
.deep-actions{display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap;margin:.65rem 0 .2rem}
.deep-actions button{font:800 .62rem var(--grotesk);text-transform:uppercase;letter-spacing:.05em;border:1px solid var(--blue);background:var(--blue);color:#fff;border-radius:999px;padding:.45rem .8rem;cursor:pointer}
.deep-actions button+button{background:var(--surface);color:var(--blue-dark);border-color:color-mix(in srgb,var(--blue) 35%,var(--line))}
@media(max-width:760px){.deep-kpis{grid-template-columns:1fr 1fr}.deep-kpis b{font-size:.82rem}.deep-peek span{font-size:.52rem;white-space:normal}}

/* explorer: player avatars (faces) for engagement */
.ex-av { display:inline-flex; align-items:center; justify-content:center; width:30px; height:30px; border-radius:9px; overflow:hidden; position:relative; background:linear-gradient(140deg, var(--lg,var(--blue)), var(--lgd,var(--blue-dark))); color:#fff; font:800 .56rem var(--mono); vertical-align:middle; margin-right:.55rem; flex:0 0 auto; }
.ex-av img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:center 12%; }
.ex-nm-txt { vertical-align:middle; }
@media (min-width:761px) { .ex-table td { padding-top:.42rem; padding-bottom:.42rem; } }
@media (max-width:760px) { .ex-table td.nm { justify-content:flex-start; gap:.4rem; align-items:center; } }

/* funnel redesign: centered bars that taper symmetrically into a true funnel shape */
.funnel { gap:.7rem; }
.fn-track { height:48px; border-radius:13px; background:var(--surface-3); }
.fn-fill { left:50%; transform:translateX(-50%); min-width:104px; display:flex; align-items:center; justify-content:center; border-radius:13px;
  background:linear-gradient(180deg, var(--lg,var(--blue)), var(--lgd,var(--blue-dark)));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.28), 0 6px 16px -8px color-mix(in srgb, var(--lg,var(--blue)) 60%, transparent); }
.fn-fill.dim { background:linear-gradient(180deg, color-mix(in srgb, var(--lg,var(--blue)) 80%, #fff), var(--lg,var(--blue))); opacity:1; }
.fn-in { padding:0 .85rem; gap:.55rem; justify-content:center; }
.fn-in b { font-size:1.12rem; }
.fn-pct { font-size:.68rem; }
.fn-base { font:700 .64rem var(--mono); color:rgba(255,255,255,.9); }

/* overview strip (replaces the 2024 cross-check): whole-dataset framing + stat chips */
.proof.overview::before { background:linear-gradient(180deg, var(--blue), color-mix(in srgb, var(--blue) 35%, transparent)); }
.proof.overview .proof-k { color:var(--blue-dark); }
.proof.overview .proof-k::after { background:linear-gradient(90deg, color-mix(in srgb, var(--blue) 45%, transparent), transparent); }
.proof.overview .proof-chk { display:flex; flex-wrap:wrap; gap:.7rem; margin-top:1rem; }
.ov-chip { flex:1 1 150px; min-width:138px; padding:.7rem .85rem; border-radius:12px; border:1px solid var(--line); background:var(--surface); box-shadow:var(--shadow-sm); display:flex; flex-direction:column; }
.ov-chip b { font:800 1.55rem var(--mono); color:var(--ink); font-variant-numeric:tabular-nums; line-height:1; }
.ov-chip .ovk { font:800 .62rem var(--grotesk); text-transform:uppercase; letter-spacing:.05em; color:var(--ink-2); margin-top:.32rem; }
.ov-chip .ovs { font:600 .6rem var(--mono); color:var(--muted); margin-top:.05rem; }

/* quick answers: reader-first entry points into the live translator/explorer */
.quick-answers { border-color:color-mix(in srgb,var(--blue) 18%,var(--line)); }
.quick-grid { display:grid; grid-template-columns:repeat(5,minmax(0,1fr)); gap:.75rem; padding:0 1.35rem 1.35rem; }
.qa-card { appearance:none; text-align:left; cursor:pointer; min-height:168px; border:1px solid var(--line); border-radius:var(--radius); background:linear-gradient(180deg,var(--surface),var(--surface-2)); box-shadow:var(--shadow-sm); padding:.92rem .95rem; display:flex; flex-direction:column; gap:.45rem; color:var(--ink); transition:transform .16s var(--ease), border-color .16s, box-shadow .16s; }
.qa-card:hover { transform:translateY(-2px); border-color:color-mix(in srgb,var(--blue) 42%,var(--line)); box-shadow:var(--shadow); }
.qa-card:focus-visible { outline:2px solid var(--blue); outline-offset:2px; }
.qa-k { font:800 .58rem var(--grotesk); letter-spacing:.08em; text-transform:uppercase; color:var(--blue-dark); line-height:1.2; }
.qa-card b { font:800 clamp(1.65rem,3vw,2.35rem)/.95 var(--mono); font-variant-numeric:tabular-nums; color:var(--ink); letter-spacing:-.03em; }
.qa-s { flex:1; font:650 .72rem/1.45 var(--mono); color:var(--muted); }
.qa-open { align-self:flex-start; font:800 .58rem var(--grotesk); letter-spacing:.06em; text-transform:uppercase; color:#fff; background:var(--blue); border-radius:8px; padding:.34rem .55rem; }
.tool-choice { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:.75rem; margin:0 1.35rem 1.35rem; }
.tool-choice > div { border:1px solid color-mix(in srgb,var(--blue) 20%,var(--line)); border-radius:12px; background:color-mix(in srgb,var(--blue) 5%,var(--surface)); padding:.78rem .9rem; }
.tool-choice span { display:block; font:800 .56rem var(--grotesk); text-transform:uppercase; letter-spacing:.08em; color:var(--muted); }
.tool-choice b { display:block; margin:.12rem 0 .2rem; font:800 .9rem var(--grotesk); color:var(--ink); }
.tool-choice p { margin:0; font:650 .72rem/1.45 var(--body); color:var(--ink-2); }
.league-snapshot { margin:0 1.35rem 1.35rem; border:1px solid var(--line); border-radius:14px; background:var(--surface); box-shadow:var(--shadow-sm); overflow:hidden; }
.ls-head { display:flex; align-items:center; justify-content:space-between; gap:.7rem; padding:.72rem .85rem; border-bottom:1px solid var(--line); }
.ls-head span { font:800 .58rem var(--grotesk); text-transform:uppercase; letter-spacing:.08em; color:var(--blue); }
.ls-head b { font:750 .68rem var(--mono); color:var(--muted); }
.ls-row { display:grid; grid-template-columns:64px 1fr; gap:.75rem; align-items:center; padding:.65rem .85rem; border-bottom:1px solid var(--line); --snap:var(--blue); }
.ls-row:last-child { border-bottom:0; }
.ls-row.lg-WHL { --snap:var(--red); } .ls-row.lg-QMJHL { --snap:var(--purple); }
.ls-lg { font:900 .76rem var(--mono); color:var(--snap); }
.ls-bars { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:.55rem; }
.ls-bars span { position:relative; min-height:38px; border-radius:10px; background:var(--surface-3); overflow:hidden; padding:.5rem .55rem; }
.ls-bars span::before { content:""; position:absolute; left:0; top:0; bottom:0; width:var(--w); background:color-mix(in srgb,var(--snap) 22%,transparent); }
.ls-bars b,.ls-bars small { position:relative; z-index:1; display:block; }
.ls-bars b { font:900 .82rem var(--mono); color:var(--ink); }
.ls-bars small { font:800 .5rem var(--grotesk); text-transform:uppercase; letter-spacing:.05em; color:var(--muted); margin-top:.08rem; }
@media(max-width:1120px){.quick-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media(max-width:760px){.quick-grid{grid-template-columns:1fr; padding:0 1rem 1rem}.qa-card{min-height:0}.qa-card b{font-size:1.65rem}.tool-choice{grid-template-columns:1fr;margin:0 1rem 1rem}.league-snapshot{margin:0 1rem 1rem}.ls-row{grid-template-columns:1fr}.ls-bars{grid-template-columns:1fr}}

/* translator "By NHL draft" mode: swap which controls show */
#translator.mode-nhl .chl-only { display:none; }
#translator:not(.mode-nhl) .nhl-only { display:none; }
