/* Model Radar — shared theme (hub + detail pages). Night-radar identity. */
:root{
  --bg:#05080e; --bg-2:#080d15; --panel:#0b121c; --panel-2:#0f1826;
  --ink:#dce8f0; --ink-soft:#93a9bd; --muted:#5a6f84; --line:#16222f; --line-2:#1d2c3b;
  --radar:#2fe0a8; --radar-dim:#178f6a; --radar-2:#3fb8ff;
  --amber:#ffc24d; --rose:#ff6b81;
  --grid:#0d1925;
  --accent:#2fe0a8;
  --disp:"Rajdhani",sans-serif; --mono:"Red Hat Mono",ui-monospace,monospace; --sans:"Outfit",system-ui,sans-serif;
  --ease:cubic-bezier(.2,.7,.2,1);
}
/* LIGHT THEME — keeps the teal radar-green identity on calm light surfaces */
:root[data-theme="light"]{
  --bg:#f3f6f8; --bg-2:#eaeff2; --panel:#ffffff; --panel-2:#f0f4f6;
  --ink:#0c1620; --ink-soft:#3c5163; --muted:#6f8395; --line:#d6e0e6; --line-2:#c4d2da;
  --radar:#0f9f73; --radar-dim:#7fcdb3; --radar-2:#1f8fd6;
  --amber:#c98412; --rose:#d6435a;
  --grid:#d2dde3;
  --accent:#0f9f73;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:var(--sans);-webkit-font-smoothing:antialiased;line-height:1.55;overflow-x:hidden;position:relative;transition:background .3s,color .3s}
::selection{background:var(--radar);color:#03130d}
a{color:inherit}

body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;
  background-image:linear-gradient(var(--grid) 1px,transparent 1px),linear-gradient(90deg,var(--grid) 1px,transparent 1px);
  background-size:46px 46px;mask-image:radial-gradient(ellipse 120% 80% at 30% 0%,#000 30%,transparent 80%);opacity:.5}
#radar{position:fixed;top:0;right:0;width:62vw;height:72vh;z-index:0;pointer-events:none;
  mask-image:radial-gradient(circle at 70% 42%,#000 50%,transparent 78%)}

.wrap{max-width:1180px;margin:0 auto;padding:0 36px;position:relative;z-index:2}
.mono{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase}
.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}

nav{position:fixed;top:0;left:0;right:0;z-index:100;backdrop-filter:blur(8px);
  background:linear-gradient(180deg,rgba(5,8,14,.92),rgba(5,8,14,.35));border-bottom:1px solid transparent;transition:border-color .4s,background .3s}
:root[data-theme="light"] nav{background:linear-gradient(180deg,rgba(243,246,248,.92),rgba(243,246,248,.35))}
nav.scrolled{border-color:var(--line);background:rgba(5,8,14,.96)}
:root[data-theme="light"] nav.scrolled{background:rgba(243,246,248,.97)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--disp);font-weight:700;font-size:19px;letter-spacing:.04em;text-decoration:none;color:var(--ink);text-transform:uppercase}
.brand .by{color:var(--muted);font-family:var(--mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;font-weight:400}
.nav-links{display:flex;gap:24px;align-items:center}
.nav-links a{font-family:var(--mono);font-size:11.5px;letter-spacing:.05em;text-decoration:none;color:var(--ink-soft);transition:color .25s}
.nav-links a:hover{color:var(--radar)}
.themebtn{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border:1px solid var(--line-2);background:var(--panel);border-radius:3px;cursor:pointer;color:var(--ink-soft);transition:.22s;padding:0}
.themebtn:hover{border-color:var(--radar);color:var(--radar)}
.themebtn svg{width:16px;height:16px}
.themebtn .ico-sun{display:none}.themebtn .ico-moon{display:block}
:root[data-theme="light"] .themebtn .ico-sun{display:block}
:root[data-theme="light"] .themebtn .ico-moon{display:none}
@media(max-width:720px){.nav-links a.hidem{display:none}}

header.hero{padding:126px 0 34px}
.eyebrow{display:inline-flex;align-items:center;gap:11px;color:var(--radar);margin-bottom:24px;flex-wrap:wrap;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;
  border:1px solid var(--line-2);background:var(--panel);padding:7px 13px;border-radius:2px}
.eyebrow .dot{width:7px;height:7px;background:var(--radar);border-radius:50%;box-shadow:0 0 10px var(--radar);animation:ping 2s infinite}
@keyframes ping{0%{box-shadow:0 0 0 0 rgba(47,224,168,.5)}70%,100%{box-shadow:0 0 0 7px rgba(47,224,168,0)}}
h1{font-family:var(--disp);font-size:clamp(42px,7vw,92px);font-weight:700;line-height:.96;letter-spacing:.005em;max-width:15ch;text-transform:uppercase}
h1 em{font-style:normal;color:var(--radar);text-shadow:0 0 30px rgba(47,224,168,.5)}
.lede{margin-top:22px;font-size:clamp(16px,1.85vw,20px);max-width:54ch;color:var(--ink-soft);font-weight:300}
.meta-row{display:flex;gap:0;margin-top:34px;flex-wrap:wrap;border:1px solid var(--line);background:rgba(11,18,28,.72);border-radius:3px;overflow:hidden;position:relative}
:root[data-theme="light"] .meta-row{background:rgba(255,255,255,.72)}
/* a thin sweep line travels across the stat strip on load — the radar acquiring a fix */
.meta-row::after{content:"";position:absolute;top:0;bottom:0;width:80px;pointer-events:none;
  background:linear-gradient(90deg,transparent,rgba(47,224,168,.10),transparent);
  animation:stripsweep 2.4s var(--ease) .25s 1 both}
:root[data-theme="light"] .meta-row::after{background:linear-gradient(90deg,transparent,rgba(15,159,115,.12),transparent)}
@keyframes stripsweep{from{left:-90px}to{left:100%}}
.meta-row .m{padding:15px 24px 13px;border-right:1px solid var(--line);flex:1 1 auto;min-width:128px}
.meta-row .m:last-child{border-right:none}
.meta-row .m b{display:block;font-family:var(--disp);font-size:31px;font-weight:700;letter-spacing:.01em;line-height:1;font-variant-numeric:tabular-nums}
.meta-row .m b .pct{color:var(--radar);font-size:.6em}
.meta-row .m span{color:var(--muted);font-family:var(--mono);font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;display:block;margin-top:8px}

section{position:relative;z-index:2}
.controls{border-top:1px solid var(--line);margin-top:38px;padding-top:30px}
.search{display:flex;align-items:center;gap:12px;border:1px solid var(--line);background:var(--panel);border-radius:4px;padding:0 16px;transition:border-color .25s,box-shadow .25s}
.search:focus-within{border-color:var(--radar);box-shadow:0 0 0 4px rgba(47,224,168,.12)}
.search svg{flex:0 0 auto;color:var(--muted)}
.search input{flex:1;border:none;background:none;outline:none;font-family:var(--mono);font-size:15px;color:var(--ink);padding:15px 0}
.search input::placeholder{color:var(--muted)}
.search .clear{font-family:var(--mono);font-size:11px;color:var(--muted);cursor:pointer;letter-spacing:.04em}
.filterbar{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;flex-wrap:wrap;margin-top:18px}
.filters{display:flex;gap:7px;flex-wrap:wrap}
.chip{font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;color:var(--ink-soft);
  border:1px solid var(--line);background:var(--panel);border-radius:2px;padding:7px 12px;cursor:pointer;transition:.22s;white-space:nowrap;text-transform:uppercase}
.chip:hover{border-color:var(--radar);color:var(--radar)}
.chip.active{background:var(--radar);color:#03130d;border-color:var(--radar)}
.chip .n{opacity:.55;margin-left:6px}
.toggles{display:flex;gap:7px;flex-wrap:wrap}
.count{font-family:var(--mono);font-size:11.5px;color:var(--muted);letter-spacing:.03em;margin:20px 0 0}
.count b{color:var(--ink);font-weight:500}

.rows{margin-top:14px;border-top:1px solid var(--line)}
.colhead{display:grid;grid-template-columns:1fr 120px 150px 132px;gap:22px;padding:13px 10px 12px;font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--line)}
.colhead .sortable{cursor:pointer;user-select:none;background:none;border:none;color:inherit;font:inherit;letter-spacing:.1em;text-transform:uppercase;padding:0;display:inline-flex;align-items:center;gap:5px;transition:color .2s}
.colhead .sortable:hover{color:var(--radar)}
.colhead .sortable:focus-visible{outline:2px solid var(--radar);outline-offset:3px;border-radius:2px;color:var(--radar)}
.colhead .sortable[aria-sort="ascending"],.colhead .sortable[aria-sort="descending"]{color:var(--radar)}
.colhead .sortable .arr{font-size:9px;opacity:0;transition:opacity .2s,transform .2s}
.colhead .sortable[aria-sort="ascending"] .arr,.colhead .sortable[aria-sort="descending"] .arr{opacity:1}
.colhead .c-name{display:inline-flex;align-items:center;gap:5px}

.row{display:grid;grid-template-columns:1fr 120px 150px 132px;gap:22px;align-items:center;
  padding:17px 10px;border-bottom:1px solid var(--line);text-decoration:none;color:inherit;position:relative;transition:background .3s,padding-left .3s var(--ease)}
.row:hover,.row:focus-visible{background:linear-gradient(90deg,rgba(47,224,168,.06),transparent);padding-left:18px;outline:none}
.row:focus-visible{box-shadow:inset 0 0 0 1px var(--radar-dim)}
.row::after{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--radar);box-shadow:0 0 10px var(--radar);transform:scaleY(0);transform-origin:top;transition:transform .3s var(--ease)}
.row:hover::after,.row:focus-visible::after{transform:scaleY(1)}
/* scroll-reveal: rows fade+rise in on first paint, staggered */
.row.reveal{opacity:0;transform:translateY(8px)}
.row.shown{opacity:1;transform:none;transition:opacity .5s var(--ease),transform .5s var(--ease)}
.nm{min-width:0}
.nm h3{font-family:var(--disp);font-size:19px;font-weight:600;letter-spacing:.01em;display:flex;align-items:center;gap:9px;flex-wrap:wrap}
.nm h3 .rk{color:var(--muted);font-family:var(--mono);font-size:13px;font-variant-numeric:tabular-nums}
.nm h3 mark{background:rgba(47,224,168,.22);color:var(--radar);border-radius:2px;padding:0 1px}
:root[data-theme="light"] .nm h3 mark{background:rgba(15,159,115,.18);color:var(--radar-dim)}
.nm .new{font-family:var(--mono);font-size:8.5px;letter-spacing:.08em;text-transform:uppercase;color:#03130d;background:var(--radar);padding:2px 6px;border-radius:3px;font-weight:500;box-shadow:0 0 0 0 rgba(47,224,168,.6);animation:freshpulse 2.6s var(--ease) infinite}
@keyframes freshpulse{0%{box-shadow:0 0 0 0 rgba(47,224,168,.45)}70%,100%{box-shadow:0 0 0 6px rgba(47,224,168,0)}}
.nm .ns{font-family:var(--mono);font-size:11px;color:var(--muted);margin-top:4px;word-break:break-all}
.nm .ns mark{background:none;color:var(--radar-2);font-weight:500}
.nm p{color:var(--ink-soft);font-size:13px;font-weight:300;margin-top:5px;max-width:64ch}
.cat{font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--radar-2)}
.reg{display:flex;gap:5px;flex-wrap:wrap;margin-top:7px}
.reg span{font-family:var(--mono);font-size:9px;letter-spacing:.04em;color:var(--muted);border:1px solid var(--line);padding:2px 6px;border-radius:3px;background:var(--panel)}
.health{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:10.5px;color:var(--muted);letter-spacing:.03em}
.health .d{width:8px;height:8px;border-radius:50%;flex:0 0 auto}
.health .active,.health .fresh{background:var(--radar);box-shadow:0 0 8px rgba(47,224,168,.6)}
.health .maintained,.health .recent{background:var(--amber)}
.health .stale,.health .older{background:#5f7488}.health .unknown{background:var(--line)}
/* trending column: number + signal meter (intensity bar, log-scaled) */
.trend{display:flex;flex-direction:column;gap:6px;align-items:flex-start}
.trend .tline{display:flex;align-items:center;gap:9px;font-family:var(--mono);font-size:10px;letter-spacing:.04em;color:var(--radar-2)}
.trend .tscore{color:var(--accent);font-weight:500;font-variant-numeric:tabular-nums}
.trend .tlikes{color:var(--muted)}
.trend .meter{width:100%;height:3px;border-radius:2px;background:var(--line);overflow:hidden;position:relative}
.trend .meter i{position:absolute;inset:0 auto 0 0;height:100%;width:var(--w,0%);background:linear-gradient(90deg,var(--radar-dim),var(--radar));border-radius:2px;box-shadow:0 0 8px rgba(47,224,168,.45);transform-origin:left;animation:meterin .7s var(--ease) both}
@keyframes meterin{from{transform:scaleX(0)}to{transform:scaleX(1)}}
.trend .go{color:var(--radar);font-size:14px;opacity:0;transform:translateX(-3px);transition:.3s var(--ease)}
.row:hover .trend .go,.row:focus-visible .trend .go{opacity:1;transform:none}
.more{text-align:center;padding:28px 0;font-family:var(--mono);font-size:12px;color:var(--muted);letter-spacing:.04em}
.more button{font-family:var(--mono);font-size:11.5px;letter-spacing:.06em;text-transform:uppercase;border:1px solid var(--radar-dim);background:var(--panel);color:var(--radar);padding:11px 22px;border-radius:3px;cursor:pointer;transition:.25s}
.more button:hover{background:var(--radar);color:#03130d;box-shadow:0 0 22px rgba(47,224,168,.25)}
@media(max-width:820px){
  .row,.colhead{grid-template-columns:1fr 110px;gap:14px}
  .row .health,.colhead .c-h,.colhead .c-r{display:none}
  .trend{align-items:flex-end}.trend .meter{display:none}
  #radar{width:100vw;opacity:.6}
}
.loading{padding:60px 0;text-align:center;color:var(--muted);font-family:var(--mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase}
.loading.sweep::before{content:"";display:inline-block;width:9px;height:9px;margin-right:10px;border-radius:50%;background:var(--radar);box-shadow:0 0 12px var(--radar);animation:freshpulse 1.4s var(--ease) infinite;vertical-align:middle}

footer{border-top:1px solid var(--radar-dim);margin-top:70px;padding:60px 0 44px;background:linear-gradient(180deg,var(--bg-2),#04070c)}
:root[data-theme="light"] footer{background:linear-gradient(180deg,var(--bg-2),#e2e9ed)}
footer h2{font-family:var(--disp);font-size:clamp(26px,4.2vw,44px);font-weight:700;letter-spacing:.01em;margin-bottom:18px;max-width:22ch;text-transform:uppercase}
footer h2 em{font-style:normal;color:var(--radar)}
footer p{color:var(--ink-soft);font-weight:300;max-width:64ch;margin-bottom:16px;line-height:1.65}
footer a.inl{color:var(--radar-2);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .25s}
footer a.inl:hover{border-color:var(--radar-2)}
.foot-row{display:flex;justify-content:space-between;flex-wrap:wrap;gap:18px;color:var(--muted);font-family:var(--mono);font-size:11px;margin-top:34px}
.foot-row a{color:var(--ink-soft);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .25s}
.foot-row a:hover{border-color:var(--radar)}

/* ── Detail page (/m/<slug>) ── */
.detail{padding:108px 0 20px}
.backlink{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);text-decoration:none;transition:color .22s;margin-bottom:26px}
.backlink:hover{color:var(--radar)}
.crumbs{font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
.crumbs a{color:var(--ink-soft);text-decoration:none}.crumbs a:hover{color:var(--radar)}
.crumbs .sep{margin:0 8px;color:var(--line-2)}
.d-head{display:flex;align-items:flex-start;justify-content:space-between;gap:22px;flex-wrap:wrap;border-bottom:1px solid var(--line);padding-bottom:26px}
.d-rank{font-family:var(--mono);font-size:13px;color:var(--muted)}
.d-title{font-family:var(--disp);font-size:clamp(32px,5.5vw,60px);font-weight:700;line-height:1;letter-spacing:.01em;text-transform:none;margin:6px 0 12px;word-break:break-word}
.d-author{font-family:var(--mono);font-size:13px;color:var(--ink-soft);word-break:break-all}
.d-badges{display:flex;gap:8px;flex-wrap:wrap;margin-top:16px}
.d-badge{font-family:var(--mono);font-size:10px;letter-spacing:.05em;text-transform:uppercase;color:var(--radar-2);border:1px solid var(--line-2);background:var(--panel);padding:6px 11px;border-radius:3px}
.d-badge.fresh{color:#03130d;background:var(--radar);border-color:var(--radar)}
.d-badge .hd{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:7px;vertical-align:middle}
.d-out{flex:0 0 auto}
.d-out a{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-size:12px;letter-spacing:.05em;text-transform:uppercase;color:#03130d;background:var(--radar);border:1px solid var(--radar);padding:13px 20px;border-radius:3px;text-decoration:none;transition:.22s}
.d-out a:hover{background:transparent;color:var(--radar)}
.d-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:0;margin-top:30px;border:1px solid var(--line);background:rgba(11,18,28,.5);border-radius:3px;overflow:hidden}
:root[data-theme="light"] .d-stats{background:rgba(255,255,255,.6)}
.d-stats .s{padding:20px 22px;border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
.d-stats .s b{display:block;font-family:var(--disp);font-size:30px;font-weight:700;line-height:1;font-variant-numeric:tabular-nums}
.d-stats .s span{display:block;margin-top:9px;color:var(--muted);font-family:var(--mono);font-size:9.5px;letter-spacing:.08em;text-transform:uppercase}
.d-meta{margin-top:30px;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:0;border:1px solid var(--line);border-radius:3px;overflow:hidden}
.d-meta .r{display:flex;justify-content:space-between;gap:16px;padding:14px 20px;border-bottom:1px solid var(--line);font-family:var(--mono);font-size:12px}
.d-meta .r .k{color:var(--muted);letter-spacing:.04em;text-transform:uppercase;font-size:10px}
.d-meta .r .v{color:var(--ink);text-align:right;word-break:break-all}
.d-meta .r .v.up{color:var(--radar)}.d-meta .r .v.down{color:var(--muted)}
.d-note{margin-top:26px;color:var(--ink-soft);font-weight:300;font-size:14px;max-width:70ch;line-height:1.7}
.d-note a{color:var(--radar-2);text-decoration:none;border-bottom:1px solid transparent}
.d-note a:hover{border-bottom-color:var(--radar-2)}
.d-stats .s{transition:background .25s}
.d-stats .s:hover{background:rgba(47,224,168,.05)}

/* ── Detail deep-dive: section scaffolding ── */
.d-sec{margin-top:46px}
.d-sec>.h{display:flex;align-items:baseline;gap:14px;margin-bottom:8px}
.d-sec>.h h2{font-family:var(--disp);font-size:23px;font-weight:700;letter-spacing:.02em;text-transform:uppercase}
.d-sec>.h .tag{font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--radar-2)}
.d-sec>.sub{color:var(--ink-soft);font-weight:300;font-size:13.5px;max-width:74ch;line-height:1.65;margin-bottom:22px}
.d-sec>.sub code{font-family:var(--mono);font-size:12px;color:var(--radar);background:var(--panel);border:1px solid var(--line);padding:1px 6px;border-radius:3px;white-space:nowrap}
.d-card{border:1px solid var(--line);background:rgba(11,18,28,.5);border-radius:4px;padding:24px 26px}
:root[data-theme="light"] .d-card{background:rgba(255,255,255,.6)}

/* surge composition — stacked horizontal bar + a legend of components with the math */
.surge-bar{display:flex;height:34px;border-radius:3px;overflow:hidden;border:1px solid var(--line-2);background:var(--bg-2)}
.surge-bar .seg{height:100%;display:flex;align-items:center;justify-content:center;min-width:2px;
  font-family:var(--mono);font-size:9px;letter-spacing:.04em;color:#03130d;white-space:nowrap;overflow:hidden;
  transform-origin:left;animation:segin .7s var(--ease) both}
@keyframes segin{from{transform:scaleX(0)}to{transform:scaleX(1)}}
.surge-bar .seg.s0{background:var(--radar)}
.surge-bar .seg.s1{background:var(--radar-2)}
.surge-bar .seg.s2{background:var(--amber)}
.surge-bar .seg.s3{background:#7d8ea0}
.surge-leg{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px 26px;margin-top:22px}
.surge-leg .it{display:flex;gap:12px;align-items:flex-start}
.surge-leg .sw{width:11px;height:11px;border-radius:2px;flex:0 0 auto;margin-top:4px}
.surge-leg .sw.s0{background:var(--radar)}.surge-leg .sw.s1{background:var(--radar-2)}
.surge-leg .sw.s2{background:var(--amber)}.surge-leg .sw.s3{background:#7d8ea0}
.surge-leg .lab{font-family:var(--disp);font-size:14px;font-weight:600;letter-spacing:.02em;display:flex;align-items:baseline;gap:9px}
.surge-leg .lab .pct{font-family:var(--mono);font-size:11px;color:var(--ink-soft);font-weight:400}
.surge-leg .ex{display:block;color:var(--muted);font-family:var(--mono);font-size:10.5px;line-height:1.5;margin-top:4px}
.surge-score{display:flex;align-items:baseline;gap:10px;margin-bottom:20px}
.surge-score b{font-family:var(--disp);font-size:40px;font-weight:700;line-height:1;color:var(--radar);font-variant-numeric:tabular-nums}
.surge-score span{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.04em;text-transform:uppercase}

/* comparative chart — this model vs category-peer median, real numbers, inline-svg-free bars */
.cmp{display:flex;flex-direction:column;gap:20px}
.cmp .grp .top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:9px;gap:14px}
.cmp .grp .lbl{font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft)}
.cmp .grp .val{font-family:var(--mono);font-size:11px;color:var(--ink);font-variant-numeric:tabular-nums}
.cmp .grp .val b{color:var(--radar);font-weight:500}
.cmp .grp .val .pk{color:var(--muted)}
.cmp .track{position:relative;height:13px;background:var(--bg-2);border:1px solid var(--line);border-radius:3px;overflow:hidden}
.cmp .track .me{position:absolute;left:0;top:0;bottom:0;background:linear-gradient(90deg,var(--radar-dim),var(--radar));border-radius:2px;
  width:var(--w,0%);transform-origin:left;animation:segin .8s var(--ease) both;box-shadow:0 0 10px rgba(47,224,168,.35)}
.cmp .track .peer{position:absolute;top:-3px;bottom:-3px;width:2px;background:var(--ink-soft);left:var(--p,50%);box-shadow:0 0 0 1px var(--bg-2)}
.cmp .track .peer::after{content:"peer median";position:absolute;top:-15px;left:50%;transform:translateX(-50%);font-family:var(--mono);font-size:8px;letter-spacing:.04em;color:var(--muted);white-space:nowrap;text-transform:uppercase}
.cmp-note{margin-top:18px;font-family:var(--mono);font-size:10.5px;color:var(--muted);line-height:1.6}

/* recency timeline — single honest marker on a fresh→recent→older scale */
.tl{position:relative;margin:18px 0 6px}
.tl .bands{display:flex;height:12px;border-radius:3px;overflow:hidden;border:1px solid var(--line)}
.tl .bands i{height:100%}
.tl .bands .b-fresh{background:rgba(47,224,168,.55)}
.tl .bands .b-recent{background:rgba(255,194,77,.5)}
.tl .bands .b-older{background:rgba(125,142,160,.4)}
.tl .mk{position:absolute;top:-7px;width:2px;height:26px;background:var(--ink);left:var(--x,0%);transform:translateX(-1px)}
.tl .mk::before{content:"";position:absolute;top:-5px;left:-4px;width:10px;height:10px;border-radius:50%;background:var(--radar);box-shadow:0 0 12px var(--radar);border:2px solid var(--bg)}
.tl .mk .cap{position:absolute;top:-26px;left:50%;transform:translateX(-50%);white-space:nowrap;font-family:var(--mono);font-size:9.5px;color:var(--ink);background:var(--panel);border:1px solid var(--line-2);padding:2px 7px;border-radius:3px}
.tl-axis{display:flex;justify-content:space-between;margin-top:11px;font-family:var(--mono);font-size:9px;letter-spacing:.05em;text-transform:uppercase;color:var(--muted)}

/* category peers — linked mini-rows */
.peers{display:grid;grid-template-columns:repeat(auto-fill,minmax(248px,1fr));gap:12px}
.peer-card{display:flex;align-items:center;gap:13px;border:1px solid var(--line);background:var(--panel);border-radius:4px;padding:13px 15px;text-decoration:none;color:inherit;transition:border-color .22s,transform .22s var(--ease),background .22s;position:relative;overflow:hidden}
.peer-card:hover{border-color:var(--radar-dim);transform:translateY(-2px);background:var(--panel-2)}
.peer-card .pr{font-family:var(--mono);font-size:11px;color:var(--muted);flex:0 0 auto;width:30px;font-variant-numeric:tabular-nums}
.peer-card .pn{min-width:0}
.peer-card .pn .t{font-family:var(--disp);font-size:15px;font-weight:600;letter-spacing:.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.peer-card .pn .s{font-family:var(--mono);font-size:9.5px;color:var(--muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.peer-card .pt{margin-left:auto;flex:0 0 auto;font-family:var(--mono);font-size:10px;color:var(--accent);font-variant-numeric:tabular-nums}
.peer-card.self{border-color:var(--radar-dim);background:linear-gradient(90deg,rgba(47,224,168,.07),var(--panel))}
.peer-card.self .pt{color:var(--radar)}

/* mini rank-arc — locates this model on the radar by rank */
.rankarc{display:flex;align-items:center;gap:22px;flex-wrap:wrap}
.rankarc svg{flex:0 0 auto}
.rankarc .ra-blip{animation:blipglow 2.6s var(--ease) infinite}
@keyframes blipglow{0%,100%{opacity:.6}50%{opacity:1}}
.rankarc .ra-txt b{font-family:var(--disp);font-size:34px;font-weight:700;color:var(--radar);line-height:1;font-variant-numeric:tabular-nums}
.rankarc .ra-txt span{display:block;font-family:var(--mono);font-size:10.5px;color:var(--muted);margin-top:7px;line-height:1.5;letter-spacing:.03em}

@media(max-width:560px){
  .d-card{padding:20px 18px}
  .surge-bar .seg{font-size:0}
}
@media(prefers-reduced-motion:reduce){
  #radar{display:none}
  .eyebrow .dot,.nm .new,.meta-row::after,.rankarc .ra-blip{animation:none}
  .surge-bar .seg,.cmp .track .me,.trend .meter i{animation:none}
  .row.reveal{opacity:1;transform:none}
  html{scroll-behavior:auto}
}

/* ── rank-movement tracking — per-row badge, movers strip, detail badge ── */
/* inline ▲/▼ next to the rank in the list rows */
.mv{margin-left:6px;font-family:var(--mono);font-size:10px;font-weight:500;letter-spacing:.02em;white-space:nowrap;font-variant-numeric:tabular-nums}
.mv.up{color:var(--radar)} .mv.dn{color:var(--rose)} .mv.flat{color:var(--muted)} .mv.new{color:var(--radar-2);opacity:.75}
@media(max-width:720px){.mv{font-size:9px;margin-left:4px}}

/* movers strip — board-wide biggest climbers, above the list */
.movers{display:flex;align-items:center;gap:14px;margin-top:24px;padding:14px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.movers-l{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--radar);flex:none;display:flex;align-items:center;gap:8px}
.movers-l::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--radar);box-shadow:0 0 9px var(--radar);animation:ping 1.4s infinite}
.movers-track{display:flex;gap:10px;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;padding-bottom:2px}
.movers-track::-webkit-scrollbar{display:none}
.mover{flex:none;display:flex;align-items:center;gap:9px;border:1px solid var(--line);background:var(--panel);border-radius:3px;padding:9px 14px;text-decoration:none;color:var(--ink);transition:border-color .25s,transform .25s var(--ease);animation:moverin .5s var(--ease) both;animation-delay:var(--d,0ms)}
.mover:hover{border-color:var(--radar);transform:translateY(-2px)}
.mover .mv{margin-left:0;font-size:13px;font-weight:600}
.mover .mvn{font-family:var(--sans);font-size:13.5px;font-weight:600;white-space:nowrap}
.mover .mvs{font-family:var(--mono);font-size:9.5px;color:var(--muted);letter-spacing:.04em;white-space:nowrap}
@keyframes moverin{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){.mover{animation:none}.movers-l::before{animation:none}}

/* detail-page movement badge (header h1 + the position section's "since prior" tile) */
.d-move{font-family:var(--mono);font-size:.46em;font-weight:600;letter-spacing:.02em;vertical-align:middle;padding:3px 8px;border-radius:3px;display:inline-block;border:1px solid transparent}
.d-move.up{color:var(--radar);border-color:color-mix(in srgb,var(--radar) 42%,transparent);background:color-mix(in srgb,var(--radar) 10%,transparent)}
.d-move.dn{color:var(--rose);border-color:color-mix(in srgb,var(--rose) 38%,transparent);background:color-mix(in srgb,var(--rose) 9%,transparent)}
.d-move.flat{color:var(--muted);border-color:var(--line-2)}
.d-move.new{color:var(--radar-2);border-color:color-mix(in srgb,var(--radar-2) 40%,transparent);letter-spacing:.08em}
.d-stats .s .d-move{font-size:20px;padding:4px 12px}
.d-spark.mini{margin-top:4px;height:90px;border:1px solid var(--line);border-radius:4px;background:rgba(11,18,28,.5);overflow:hidden}
:root[data-theme="light"] .d-spark.mini{background:rgba(255,255,255,.6)}
.d-spark.mini svg{display:block;width:100%;height:100%}

/* ── connective tissue + GEO about/faq — retrofit (collision-safe geo- classes) ── */
.geo-kstrip { position: relative; z-index: 60; background: var(--ink); color: var(--bg);
  font-family: ui-monospace, monospace; font-size: 10.5px; letter-spacing: .04em; }
.geo-kstrip .wrap { display: flex; align-items: center; gap: 16px; padding: 7px 28px; flex-wrap: wrap; max-width: 1200px; margin: 0 auto; }
.geo-kstrip a { color: var(--bg); text-decoration: none; opacity: .82; transition: opacity .2s; display: inline-flex; align-items: center; gap: 6px; }
.geo-kstrip a:hover { opacity: 1; }
.geo-kstrip .d { width: 7px; height: 7px; background: var(--muted); border-radius: 1px; display: inline-block; }
.geo-kstrip .s { opacity: .3; } .geo-kstrip .g { flex: 1; }
.geo-about { border-top: 1px solid var(--line); padding: 46px 28px 8px; max-width: 1200px; margin: 0 auto; }
.geo-about h2 { font-weight: 700; font-size: clamp(21px, 3vw, 28px); letter-spacing: -.02em; margin-bottom: 12px; color: var(--ink); }
.geo-about .intro { color: var(--muted); max-width: 72ch; font-size: 14px; line-height: 1.7; margin-bottom: 26px; }
.geo-about a { color: var(--ink); }
.geo-faq { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 16px; }
.geo-faq .q { background: var(--panel); border: 1px solid var(--line); border-radius: 6px; padding: 18px 20px; }
.geo-faq .q h3 { font-weight: 600; font-size: 14.5px; margin: 0 0 7px; color: var(--ink); }
.geo-faq .q p { font-size: 12.5px; color: var(--muted); line-height: 1.65; margin: 0; }
