/* The MCP Index — shared theme (hub + detail pages). LIGHT blueprint is native; DARK overrides via :root[data-theme="dark"]. */
:root{
  --bg:#e7edf3; --bg-2:#dde5ee; --panel:#f4f7fa; --panel-2:#eaf0f6;
  --ink:#0d1a2b; --ink-soft:#37485d; --muted:#73849a; --line:#ccd8e4; --line-2:#d8e2ec;
  --node:#1d6fe0; --node-soft:#5b96ec; --cyan:#0891b2; --amber:#c98a1a; --rose:#d6455f;
  --grid:#d4dfea;
  --disp:"Archivo",sans-serif; --mono:"Space Mono",ui-monospace,monospace; --sans:"Hanken Grotesk",system-ui,sans-serif;
  --ease:cubic-bezier(.2,.7,.2,1);
}
/* DARK theme — tasteful dark slate surfaces, electric-blue node identity preserved */
:root[data-theme="dark"]{
  --bg:#0a1320; --bg-2:#0d1929; --panel:#101d30; --panel-2:#15273d;
  --ink:#e7eef6; --ink-soft:#a9bccf; --muted:#6f8198; --line:#21344b; --line-2:#1b2c41;
  --node:#3d8bf2; --node-soft:#76aef6; --cyan:#22b8d6; --amber:#e0a83c; --rose:#e26a80;
  --grid:#142539;
}
*{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.5;overflow-x:hidden;position:relative;transition:background .35s var(--ease),color .35s var(--ease)}
::selection{background:var(--node);color:#fff}
a{color:inherit}

/* blueprint grid backdrop */
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:38px 38px;mask-image:radial-gradient(ellipse 130% 80% at 50% 0%,#000 30%,transparent 85%);opacity:.55}
#mesh{position:fixed;top:0;left:0;width:100%;height:60vh;z-index:0;pointer-events:none;mask-image:linear-gradient(180deg,#000 60%,transparent 100%)}

.wrap{max-width:1200px;margin:0 auto;padding:0 36px;position:relative;z-index:2}
.mono{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase}

nav{position:fixed;top:0;left:0;right:0;z-index:100;backdrop-filter:blur(9px);
  background:color-mix(in srgb,var(--bg) 80%,transparent);border-bottom:1px solid transparent;transition:border-color .4s,background .35s}
nav.scrolled{border-color:var(--line)}
.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:17px;letter-spacing:-.02em;text-decoration:none;color:var(--ink)}
.mark{width:24px;height:24px;flex:0 0 auto}
.brand .by{color:var(--muted);font-family:var(--mono);font-size:9.5px;letter-spacing:.06em;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:.04em;text-decoration:none;color:var(--ink-soft);transition:color .25s}
.nav-links a:hover{color:var(--node)}
@media(max-width:720px){.nav-links a.hidem{display:none}}
/* theme toggle */
.themebtn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid var(--line);background:var(--panel);
  border-radius:6px;cursor:pointer;color:var(--ink-soft);transition:.22s;flex:0 0 auto}
.themebtn:hover{border-color:var(--node);color:var(--node)}
.themebtn svg{width:16px;height:16px}
.themebtn .moon{display:none}.themebtn .sun{display:block}
:root[data-theme="dark"] .themebtn .moon{display:block}:root[data-theme="dark"] .themebtn .sun{display:none}

header.hero{padding:126px 0 34px}
.eyebrow{display:inline-flex;align-items:center;gap:11px;color:var(--ink-soft);margin-bottom:24px;flex-wrap:wrap;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;
  border:1px solid var(--line);background:var(--panel);padding:7px 13px;border-radius:30px}
.eyebrow .dot{width:7px;height:7px;background:var(--node);border-radius:50%;box-shadow:0 0 0 0 rgba(29,111,224,.4);animation:pulse 2.4s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(29,111,224,.4)}50%{box-shadow:0 0 0 6px rgba(29,111,224,0)}}
h1{font-family:var(--disp);font-size:clamp(38px,6vw,80px);font-weight:800;line-height:.96;letter-spacing:-.04em;max-width:15ch}
h1 em{font-style:normal;color:var(--node)}
.lede{margin-top:22px;font-size:clamp(16px,1.85vw,20px);max-width:58ch;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:var(--panel);border-radius:6px;overflow:hidden}
.meta-row .m{padding:16px 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:29px;font-weight:700;letter-spacing:-.02em;line-height:1;font-variant-numeric:tabular-nums}
.meta-row .m b .pct{color:var(--node);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:6px;padding:0 16px;transition:border-color .25s,box-shadow .25s}
.search:focus-within{border-color:var(--node);box-shadow:0 0 0 4px rgba(29,111,224,.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:11px;letter-spacing:.03em;color:var(--ink-soft);
  border:1px solid var(--line);background:var(--panel);border-radius:5px;padding:7px 12px;cursor:pointer;transition:.22s;white-space:nowrap}
.chip:hover{border-color:var(--node);color:var(--node)}
.chip.active{background:var(--node);color:#fff;border-color:var(--node)}
.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:700}

.rows{margin-top:14px;border-top:1px solid var(--line)}
.colhead{display:grid;grid-template-columns:1fr 120px 150px 120px;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)}
/* sortable column headers */
.colhead .sortable{background:none;border:none;font:inherit;color:inherit;letter-spacing:inherit;text-transform:inherit;cursor:pointer;padding:0;display:inline-flex;align-items:center;gap:5px;transition:color .2s}
.colhead .sortable:hover{color:var(--node)}
.colhead .sortable .arr{opacity:0;font-size:9px;transition:opacity .2s}
.colhead .sortable[aria-sort="ascending"] .arr,.colhead .sortable[aria-sort="descending"] .arr{opacity:1;color:var(--node)}
.colhead .sortable[aria-sort="ascending"] .arr::after{content:"▲"}
.colhead .sortable[aria-sort="descending"] .arr::after{content:"▼"}
.colhead .sortable:focus-visible{outline:2px solid var(--node);outline-offset:2px;border-radius:3px}
.row{display:grid;grid-template-columns:1fr 120px 150px 120px;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{background:var(--panel-2);padding-left:18px}
.row::after{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--node);transform:scaleY(0);transform-origin:top;transition:transform .3s var(--ease)}
.row:hover::after{transform:scaleY(1)}
.nm h3{font-family:var(--disp);font-size:17px;font-weight:600;letter-spacing:-.01em;display:flex;align-items:center;gap:9px;flex-wrap:wrap}
.nm .new{font-family:var(--mono);font-size:8.5px;letter-spacing:.08em;text-transform:uppercase;color:#fff;background:var(--node);padding:2px 6px;border-radius:3px;font-weight:700}
.nm .ns{font-family:var(--mono);font-size:11px;color:var(--muted);margin-top:4px;word-break:break-all}
.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(--cyan)}
.nm .reg{display:flex;gap:5px;flex-wrap:wrap;margin-top:7px}
.nm .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%}
.health .active{background:var(--node);box-shadow:0 0 8px rgba(29,111,224,.6)}.health .maintained{background:var(--amber)}.health .stale{background:#aab6c4}.health .unknown{background:var(--line)}
.go{justify-self:end;color:var(--node);font-size:15px;opacity:0;transition:.3s var(--ease)}
.row:hover .go{opacity:1}
.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(--node);background:var(--panel);color:var(--node);padding:11px 22px;border-radius:5px;cursor:pointer;transition:.25s}
.more button:hover{background:var(--node);color:#fff}
@media(max-width:820px){
  .row,.colhead{grid-template-columns:1fr 96px;gap:14px}
  .row .health,.colhead .c-h,.row .go,.colhead .c-r,.row .tcell{display:none}
}
.loading{padding:60px 0;text-align:center;color:var(--muted);font-family:var(--mono);font-size:12px;letter-spacing:.08em}

/* search-hit highlight */
mark{background:color-mix(in srgb,var(--node) 22%,transparent);color:inherit;border-radius:2px;padding:0 1px;
  box-shadow:inset 0 -1px 0 color-mix(in srgb,var(--node) 45%,transparent)}
:root[data-theme="dark"] mark{background:color-mix(in srgb,var(--node) 30%,transparent)}

/* per-row freshness micro-bar (the mesh, quantified) */
.health{flex-direction:column;align-items:flex-start;gap:7px}
.health .hl{display:flex;align-items:center;gap:8px}
.spark{display:block;width:64px;height:4px;border-radius:4px;background:var(--line-2);overflow:hidden;position:relative}
.spark i{display:block;height:100%;border-radius:4px;background:var(--node);transition:width .4s var(--ease)}
.spark.maintained i{background:var(--amber)}.spark.stale i{background:#aab6c4}.spark.unknown i{background:var(--line)}
.row:hover .spark.active i{box-shadow:0 0 7px rgba(29,111,224,.7)}

/* row entrance reveal (first paint + load-more only) */
@keyframes rowin{from{opacity:0;transform:translateY(9px)}to{opacity:1;transform:none}}
.row.reveal{animation:rowin .5s var(--ease) both}
@media(prefers-reduced-motion:reduce){.row.reveal{animation:none}.spark i{transition:none}}

/* richer empty state */
.empty{padding:64px 0 56px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:10px}
.empty-mark{font-family:var(--disp);font-size:46px;color:var(--line);line-height:1;margin-bottom:6px}
.empty b{font-family:var(--disp);font-size:20px;font-weight:700;letter-spacing:-.01em;color:var(--ink)}
.empty span{font-family:var(--mono);font-size:12px;color:var(--muted);letter-spacing:.03em}
.empty button{margin-top:14px;font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;
  border:1px solid var(--node);background:var(--panel);color:var(--node);padding:9px 18px;border-radius:5px;cursor:pointer;transition:.22s}
.empty button:hover{background:var(--node);color:#fff}
.more button b{font-weight:700}

footer{border-top:1px solid var(--ink);margin-top:70px;padding:60px 0 44px;background:var(--ink);color:#dfe8f1}
footer h2{font-family:var(--disp);font-size:clamp(24px,4vw,40px);font-weight:700;letter-spacing:-.03em;margin-bottom:18px;max-width:22ch;color:#fff}
footer h2 em{font-style:normal;color:var(--node-soft)}
footer p{color:#9fb0c2;font-weight:300;max-width:64ch;margin-bottom:16px;line-height:1.65}
footer a.inl{color:var(--node-soft);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .25s}
footer a.inl:hover{border-color:var(--node-soft)}
.foot-row{display:flex;justify-content:space-between;flex-wrap:wrap;gap:18px;color:#8499ad;font-family:var(--mono);font-size:11px;margin-top:34px}
.foot-row a{color:#dfe8f1;text-decoration:none;border-bottom:1px solid transparent;transition:border-color .25s}
.foot-row a:hover{border-color:var(--node-soft)}
:root[data-theme="dark"] footer{border-top-color:#22364d;background:#06101c}

/* ============ detail page (/s/<slug>) ============ */
.detail{padding:120px 0 20px}
.crumbs{font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--muted);margin-bottom:22px;display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.crumbs a{color:var(--ink-soft);text-decoration:none;transition:color .2s}
.crumbs a:hover{color:var(--node)}
.crumbs .sep{opacity:.5}
.back{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:11.5px;letter-spacing:.04em;color:var(--node);text-decoration:none;margin-bottom:26px;transition:gap .25s var(--ease)}
.back:hover{gap:11px}
.d-head{display:flex;align-items:flex-start;gap:14px;flex-wrap:wrap;justify-content:space-between}
.d-title h1{font-family:var(--disp);font-size:clamp(30px,5vw,52px);font-weight:800;letter-spacing:-.03em;line-height:1.02;max-width:18ch;display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.d-title .new{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:#fff;background:var(--node);padding:4px 9px;border-radius:4px;font-weight:700;vertical-align:middle}
.d-name{font-family:var(--mono);font-size:13px;color:var(--muted);margin-top:12px;word-break:break-all}
.d-desc{margin-top:20px;font-size:clamp(16px,1.7vw,19px);max-width:62ch;color:var(--ink-soft);font-weight:300;line-height:1.6}
.d-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:26px}
.d-actions a{font-family:var(--mono);font-size:12px;letter-spacing:.04em;text-decoration:none;padding:11px 18px;border-radius:6px;transition:.22s;display:inline-flex;align-items:center;gap:8px}
.d-actions .primary{background:var(--node);color:#fff;border:1px solid var(--node)}
.d-actions .primary:hover{filter:brightness(1.08)}
.d-actions .ghost{border:1px solid var(--line);background:var(--panel);color:var(--ink-soft)}
.d-actions .ghost:hover{border-color:var(--node);color:var(--node)}
/* facts grid: fixed 3-col (6 cells → clean 3×2, never ragged). 1px gap over a
   line-colored container draws the separators. */
.d-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;margin-top:40px;background:var(--line);
  border:1px solid var(--line);border-radius:8px;overflow:hidden}
.d-grid .cell{padding:17px 22px;background:var(--panel);display:flex;flex-direction:column;justify-content:center;min-height:78px}
.d-grid .cell span{display:block;font-family:var(--mono);font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:9px}
.d-grid .cell b{font-family:var(--disp);font-size:17px;font-weight:600;letter-spacing:-.01em;color:var(--ink);display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.d-grid .cell .d{width:8px;height:8px;border-radius:50%;flex:0 0 auto}
.d-grid .cell .d.active{background:var(--node);box-shadow:0 0 8px rgba(29,111,224,.6)}.d-grid .cell .d.maintained{background:var(--amber)}.d-grid .cell .d.stale{background:#aab6c4}.d-grid .cell .d.unknown{background:var(--line)}
.d-grid .reg b{display:flex;gap:6px;flex-wrap:wrap}
.d-grid .reg b span{display:inline-block;font-family:var(--mono);font-size:9px;letter-spacing:.04em;color:var(--muted);border:1px solid var(--line);padding:3px 7px;border-radius:3px;background:var(--bg);margin:0}
.d-meta{margin-top:30px;font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.03em;line-height:1.9;
  border-top:1px solid var(--line);padding-top:22px}
.d-meta b{color:var(--ink-soft);font-weight:400}
@media(max-width:720px){.d-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:440px){.d-grid{grid-template-columns:1fr}}

/* ── deep-dive additions ── */
.d-kicker{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;
  text-transform:uppercase;color:var(--ink-soft);border:1px solid var(--line);background:var(--panel);
  padding:6px 12px;border-radius:30px;margin-bottom:18px}
.d-kicker .d{width:7px;height:7px;border-radius:50%;flex:0 0 auto}
.d-kicker .d.active{background:var(--node);box-shadow:0 0 7px rgba(29,111,224,.65)}
.d-kicker .d.maintained{background:var(--amber)}.d-kicker .d.stale{background:#aab6c4}.d-kicker .d.unknown{background:var(--line)}
/* clickable registry name → copy */
.d-name[data-copy]{cursor:pointer;display:inline-flex;align-items:center;gap:9px;transition:color .2s}
.d-name[data-copy]:hover{color:var(--ink-soft)}
.d-name .ncopy{font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);border:1px solid var(--line);
  border-radius:4px;padding:2px 6px;transition:.2s}
.d-name[data-copy]:hover .ncopy{border-color:var(--node);color:var(--node)}
.d-name .ncopy.ok{color:var(--node);border-color:var(--node)}
.cell-link{color:var(--ink);text-decoration:none;border-bottom:1px solid transparent;transition:.2s}
.cell-link:hover{color:var(--node);border-bottom-color:var(--node)}
.d-grid .cell .kind{font-family:var(--mono);font-size:8.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);
  border:1px solid var(--line);border-radius:3px;padding:1px 5px;font-weight:400}

/* two-column card row (install + freshness) */
.d-cols{display:grid;grid-template-columns:1.25fr 1fr;gap:18px;margin-top:18px;align-items:start}
@media(max-width:820px){.d-cols{grid-template-columns:1fr}}
.d-card{border:1px solid var(--line);background:var(--panel);border-radius:8px;padding:22px 24px;
  opacity:0;transform:translateY(14px);transition:opacity .55s var(--ease),transform .55s var(--ease)}
.d-card.in{opacity:1;transform:none}
.d-grid{opacity:0;transform:translateY(14px);transition:opacity .55s var(--ease),transform .55s var(--ease)}
.d-grid.in{opacity:1;transform:none}
.d-h{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);
  margin-bottom:16px;display:flex;align-items:center;gap:10px;font-weight:700}
.d-h-n,.d-h .d-h-n{font-family:var(--mono);font-size:9.5px;color:var(--node);border:1px solid var(--line);
  border-radius:20px;padding:2px 8px;font-weight:400;letter-spacing:.04em}

/* install / connect code panel */
.run .run-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:11px}
.run-label{font-family:var(--mono);font-size:11px;letter-spacing:.05em;color:var(--ink-soft)}
.run-verb{font-family:var(--mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--cyan);
  border:1px solid color-mix(in srgb,var(--cyan) 45%,var(--line));border-radius:4px;padding:2px 7px;background:color-mix(in srgb,var(--cyan) 8%,transparent)}
pre.code{position:relative;background:var(--bg-2);border:1px solid var(--line-2);border-radius:6px;
  padding:14px 84px 14px 15px;overflow-x:auto;font-family:var(--mono);font-size:12.5px;line-height:1.6;color:var(--ink)}
:root[data-theme="dark"] pre.code{background:#08111e}
pre.code code{font-family:var(--mono)}
pre.code .prompt{color:var(--node);user-select:none;margin-right:8px;opacity:.8}
pre.code .copy{position:absolute;top:9px;right:9px;font-family:var(--mono);font-size:9.5px;letter-spacing:.06em;
  text-transform:uppercase;color:var(--muted);background:var(--panel);border:1px solid var(--line);border-radius:4px;
  padding:4px 9px;cursor:pointer;transition:.2s}
pre.code .copy:hover{border-color:var(--node);color:var(--node)}
pre.code .copy.ok{color:var(--node);border-color:var(--node)}
.run-note{margin-top:12px;font-size:12.5px;color:var(--ink-soft);font-weight:300;line-height:1.6}

/* freshness lifecycle arc */
.rec-state{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-size:12px;letter-spacing:.02em;
  color:var(--ink-soft);margin-bottom:18px}
.rec-state .d{width:9px;height:9px;border-radius:50%}
.rec-state .d.active{background:var(--node);box-shadow:0 0 8px rgba(29,111,224,.6)}
.rec-state .d.maintained{background:var(--amber)}.rec-state .d.stale{background:#aab6c4}.rec-state .d.unknown{background:var(--line)}
.rec-track{margin-top:4px}
.rec-scale{display:flex;justify-content:space-between;font-family:var(--mono);font-size:8.5px;letter-spacing:.06em;
  text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.rec-bar{position:relative;height:6px;border-radius:6px;background:linear-gradient(90deg,
  color-mix(in srgb,var(--node) 70%,transparent),color-mix(in srgb,var(--amber) 55%,transparent) 55%,#aab6c4 100%);
  opacity:.32}
.rec-fill{position:absolute;left:0;top:0;bottom:0;border-radius:6px;background:linear-gradient(90deg,
  var(--node),var(--amber) 55%,#aab6c4 100%);width:0;
  animation:recgrow 1.1s var(--ease) both;animation-delay:.25s}
@keyframes recgrow{from{width:0}}
.rec-dot{position:absolute;top:50%;width:13px;height:13px;border-radius:50%;transform:translate(-50%,-50%);
  border:2.5px solid var(--panel);box-shadow:0 1px 5px rgba(0,0,0,.22);
  animation:recpop .5s var(--ease) both;animation-delay:1.15s}
@keyframes recpop{from{transform:translate(-50%,-50%) scale(0)}}
.rec-dot.active{background:var(--node)}.rec-dot.maintained{background:var(--amber)}
.rec-dot.stale{background:#aab6c4}.rec-dot.unknown{background:var(--muted)}
@media(prefers-reduced-motion:reduce){.rec-fill,.rec-dot{animation:none}.rec-fill{transition:none}}

/* about prose */
.about-p{font-size:15px;color:var(--ink-soft);font-weight:300;line-height:1.7;max-width:70ch}
.about-p.sub{font-size:13px;margin-top:14px;color:var(--muted)}
.about-p b{color:var(--ink-soft);font-weight:500}

/* category peers — the mesh made navigable */
.peers .peer-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:8px}
.peer{display:flex;align-items:center;gap:10px;text-decoration:none;color:inherit;border:1px solid var(--line);
  background:var(--bg-2);border-radius:6px;padding:11px 13px;transition:.22s;min-width:0}
.peer:hover{border-color:var(--node);background:var(--panel-2);transform:translateY(-1px)}
.peer .pd{width:7px;height:7px;border-radius:50%;flex:0 0 auto}
.peer .pd.active{background:var(--node)}.peer .pd.maintained{background:var(--amber)}
.peer .pd.stale{background:#aab6c4}.peer .pd.unknown{background:var(--line)}
.peer .pn{font-family:var(--disp);font-size:13px;font-weight:600;letter-spacing:-.01em;white-space:nowrap;
  overflow:hidden;text-overflow:ellipsis;flex:1 1 auto;min-width:0;color:var(--ink)}
.peer .pm{font-family:var(--mono);font-size:8.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);flex:0 0 auto}
.peer:hover .pn{color:var(--node)}
.peer-all{display:inline-block;margin-top:16px;font-family:var(--mono);font-size:11px;letter-spacing:.04em;
  color:var(--node);text-decoration:none;transition:gap .2s}
.peer-all:hover{text-decoration:underline}

/* ── movement tracking: row badge, movers strip, detail section ─────────────── */
/* up = climbed toward the top (node-blue, the live accent); dn = slipped (rose). */
.mv{font-family:var(--mono);font-size:9.5px;font-weight:700;letter-spacing:.02em;white-space:nowrap;
  font-variant-numeric:tabular-nums;vertical-align:middle;margin-left:2px}
.mv.up{color:var(--node)} .mv.dn{color:var(--rose)} .mv.flat{color:var(--muted)} .mv.new{color:var(--node);opacity:.75}
@media(max-width:720px){.mv{font-size:9px}}

.movers{display:flex;align-items:center;gap:14px;margin:0 0 22px;padding:14px 0;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.movers-l{font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--node);
  flex:none;display:flex;align-items:center;gap:8px}
.movers-l::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--node);
  box-shadow:0 0 9px var(--node);animation:mvpulse 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:5px;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(--node);transform:translateY(-2px)}
.mover .mv{font-size:13px;margin-left:0}
.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;text-transform:uppercase;white-space:nowrap}
@keyframes moverin{from{opacity:0;transform:translateX(10px)}to{opacity:1;transform:none}}
@keyframes mvpulse{0%,100%{opacity:1}50%{opacity:.35}}
@media(prefers-reduced-motion:reduce){.mover{animation:none}.movers-l::before{animation:none}}

/* detail-page move badge (next to the H1) + the registry-position section */
.d-move{font-family:var(--mono);font-size:.4em;font-weight:700;letter-spacing:.02em;vertical-align:middle;
  padding:3px 8px;border-radius:4px;display:inline-block;border:1px solid transparent}
.d-move.up{color:var(--node);border-color:color-mix(in srgb,var(--node) 40%,transparent);background:color-mix(in srgb,var(--node) 9%,transparent)}
.d-move.dn{color:var(--rose);border-color:color-mix(in srgb,var(--rose) 36%,transparent);background:color-mix(in srgb,var(--rose) 8%,transparent)}
.d-move.flat{color:var(--muted);border-color:var(--line-2)}
.d-move.new{color:var(--node);border-color:color-mix(in srgb,var(--node) 40%,transparent);letter-spacing:.08em}
.d-card.position .pos-stats .cell b .d-move{font-size:14px;padding:3px 10px}
.mv-sparkwrap{margin-top:16px;border:1px solid var(--line);border-radius:6px;background:var(--panel);padding:12px 14px}
.mv-spark{display:block;width:100%;height:90px}

/* ── 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; }
