/* Arbify shared design system — one palette, one type scale, one nav.
   Injected nav via nav.js; pages link this + add markup using these classes. */
:root{
  --bg:#0b0d11; --panel:#12151c; --panel2:#171b24; --line:#1e232d; --line2:#2a303c;
  --ink:#e6e9ef; --muted:#7c8598; --dim:#525b6d;
  --good:#46c26a; --warn:#d9a233; --bad:#e5484d; --info:#4aa3df;
  --accent:#3ecfd6;
  --mono:ui-monospace,"SF Mono",Menlo,Consolas,monospace;
  --sans:system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:14px;
  -webkit-font-smoothing:antialiased;font-variant-numeric:tabular-nums}
a{color:var(--accent)}

/* --- app shell (nav.js wraps content in <main class=appmain> + prepends .rail) --- */
body.has-rail{display:grid;grid-template-columns:212px 1fr;min-height:100vh}
.rail{background:#0c0e13;border-right:1px solid var(--line);padding:18px 0;position:sticky;top:0;height:100vh;overflow-y:auto}
.rail .brand{display:flex;align-items:center;gap:8px;padding:0 20px 22px;font-weight:700;letter-spacing:.5px;color:var(--ink);text-decoration:none}
.rail .brand .mk{width:10px;height:10px;border-radius:3px;background:var(--accent);box-shadow:0 0 10px var(--accent)}
.rail .grp{padding:16px 20px 6px;font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--dim)}
.rail .navlink{display:flex;align-items:center;gap:10px;padding:7px 20px;color:var(--muted);text-decoration:none;font-size:13.5px;border-left:2px solid transparent}
.rail .navlink:hover{color:var(--ink);background:var(--panel)}
.rail .navlink.on{color:var(--ink);border-left-color:var(--accent);background:linear-gradient(90deg,rgba(62,207,214,.08),transparent)}
.rail .navlink .d{width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.55}
.appmain{padding:22px 26px 60px;min-width:0}
@media(max-width:760px){body.has-rail{grid-template-columns:1fr}.rail{display:none}}

/* --- page head --- */
.pagehead{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:16px;flex-wrap:wrap}
.pagehead h1{font-size:20px;font-weight:650;margin:0;letter-spacing:-.01em}
.pagehead .sub{margin:4px 0 0;color:var(--muted);font-size:13px;max-width:80ch}
.live{font-family:var(--mono);font-size:11px;color:var(--good);display:flex;align-items:center;gap:6px}
.live .dot{width:7px;height:7px;border-radius:50%;background:var(--good);box-shadow:0 0 7px var(--good)}

/* --- summary stats --- */
.summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:20px}
.stat{background:var(--panel);border:1px solid var(--line);border-radius:9px;padding:13px 15px}
.stat .k{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.stat .v{font-family:var(--mono);font-size:23px;font-weight:600;margin-top:5px;letter-spacing:-.02em}
.stat .sub{font-size:11px;color:var(--dim);margin-top:2px}
.stat.good .v{color:var(--good)} .stat.bad .v{color:var(--bad)} .stat.warn .v{color:var(--warn)}

/* --- data table --- */
.card{background:var(--panel);border:1px solid var(--line);border-radius:11px;overflow:hidden}
.tbar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--line);gap:10px;flex-wrap:wrap}
.tbar h2{font-size:13px;margin:0;font-weight:600}
.tbar .note{font-size:12px;color:var(--muted)}
.scroll{overflow-x:auto}
table.data{border-collapse:collapse;width:100%}
table.data th{font-family:var(--mono);font-size:10.5px;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);
  font-weight:500;text-align:right;padding:9px 14px;border-bottom:1px solid var(--line);white-space:nowrap}
table.data th.l{text-align:left}
table.data td{padding:11px 14px;border-bottom:1px solid var(--line);text-align:right;vertical-align:middle;white-space:nowrap}
table.data td.l{text-align:left}
table.data tr:last-child td{border-bottom:none}
table.data tbody tr:hover{background:var(--panel2)}
td.stripe{width:3px;padding:0;border:none}
.s-good{background:var(--good)} .s-warn{background:var(--warn)} .s-bad{background:var(--bad)} .s-none{background:var(--line2)}

.coin{font-family:var(--mono);font-weight:600;font-size:14.5px;color:var(--ink)}
.route{font-family:var(--mono);font-size:12px;color:var(--muted)}
.route b{color:#aeb6c6;font-weight:500}
.num{font-family:var(--mono)}
.big{font-size:15px;font-weight:600}
.pos{color:var(--good)} .neg{color:var(--bad)}
.ref{font-family:var(--mono);font-size:12.5px;color:var(--muted)}
.warnnum{color:var(--warn)}

/* --- chip system (replaces the glyph soup) --- */
.chips{display:flex;gap:5px;flex-wrap:wrap;margin-top:5px}
.chip{font-family:var(--mono);font-size:10px;letter-spacing:.03em;padding:1.5px 6px;border-radius:4px;border:1px solid transparent;cursor:help;white-space:nowrap}
.chip.bad{background:rgba(229,72,77,.13);color:#f0787c;border-color:rgba(229,72,77,.25)}
.chip.warn{background:rgba(217,162,51,.13);color:#e6b757;border-color:rgba(217,162,51,.22)}
.chip.info{background:rgba(74,163,223,.12);color:#79bceb;border-color:rgba(74,163,223,.2)}
.chip.good{background:rgba(70,194,106,.12);color:#6ed389;border-color:rgba(70,194,106,.22)}
.chip.dim{background:none;color:var(--dim);border-color:var(--line2)}

.verdict{font-family:var(--mono);font-size:11px;font-weight:600;letter-spacing:.04em}
.v-good{color:var(--good)} .v-warn{color:var(--warn)} .v-bad{color:var(--bad)} .v-none{color:var(--dim)}

/* --- buttons --- */
.btn{font-family:var(--mono);font-size:11px;padding:3px 9px;border-radius:5px;border:1px solid var(--line2);
  background:transparent;color:var(--muted);cursor:pointer}
.btn:hover{color:var(--ink);border-color:var(--accent)}
.btn:focus-visible{outline:2px solid var(--accent);outline-offset:1px}
.btn.pri{color:var(--accent);border-color:rgba(62,207,214,.35)}
.btn:disabled{opacity:.5;cursor:default}
.act{display:inline-flex;gap:6px}

/* --- legend --- */
.legend{margin-top:16px;display:flex;flex-wrap:wrap;gap:12px 20px;padding:13px 16px;background:var(--panel);
  border:1px solid var(--line);border-radius:9px;font-size:12px}
.legend .li{display:flex;align-items:center;gap:7px;color:var(--muted)}
.foot{margin-top:22px;color:var(--dim);font-size:12px;font-family:var(--mono)}

/* guest gate: locked nav items + the "private desk" login modal (nav.js) */
.rail .navlink.locked{opacity:.45}
.rail .navlink .lock{margin-left:auto;font-size:10px;opacity:.7}
.loginwall{position:fixed;inset:0;z-index:1000;background:rgba(8,10,14,.82);backdrop-filter:blur(6px);display:grid;place-items:center;padding:20px}
.loginwall .lw-card{background:var(--panel);border:1px solid var(--line2);border-radius:16px;padding:34px 30px;max-width:420px;text-align:center;box-shadow:0 24px 70px rgba(0,0,0,.55)}
.loginwall h2{font-size:22px;font-weight:700;margin:14px 0 10px}
.loginwall p{color:var(--muted);font-size:14px;line-height:1.6;margin-bottom:22px}
.loginwall .lw-btns{display:flex;flex-direction:column;gap:10px}
.loginwall .lw-btn{font-family:var(--mono);font-size:13px;padding:11px;border-radius:9px;border:1px solid var(--line2);color:var(--ink);text-decoration:none}
.loginwall .lw-btn.primary{background:var(--accent);color:#04252a;font-weight:700;border-color:var(--accent)}
.loginwall .lw-btn.ghost{color:var(--muted);border-color:transparent}
.pager{display:flex;align-items:center;justify-content:center;gap:14px;padding:14px;font-family:var(--mono);font-size:12px;color:var(--muted)}
.pager button{font-family:var(--mono);font-size:12px;padding:6px 14px;border:1px solid var(--line2);border-radius:7px;background:var(--panel);color:var(--ink);cursor:pointer}
.pager button:disabled{opacity:.4;cursor:default}
