/* Atlas — design tokens & global styles
   Style aligned with vgtc.io: white/black with a blue accent, Geist throughout. */

:root{
  --paper: #ffffff;
  --paper-2: #f7f7f8;
  --paper-3: #eeeef0;
  --ink: #0a0a0a;
  --ink-2: #2a2a2c;
  --ink-3: #6b6b70;
  --ink-4: #a4a4aa;
  --rule: rgba(10,10,10,.08);
  --rule-strong: rgba(10,10,10,.16);
  --bg-card: #ffffff;
  --bg-inset: #f3f3f5;

  --accent: #1e63ff;
  --accent-soft: rgba(30,99,255,.08);
  --accent-line: rgba(30,99,255,.32);

  --cat-1: #1e63ff;
  --cat-2: #0a0a0a;
  --cat-3: #6b6b70;
  --cat-4: #a4a4aa;
  --cat-5: #2a2a2c;
  --cat-6: #4f4f54;

  --serif: "Geist", ui-sans-serif, -apple-system, BlinkMacSystemFont, sans-serif;
  --sans: "Geist", ui-sans-serif, -apple-system, BlinkMacSystemFont, sans-serif;
  --mono: "Geist Mono", ui-monospace, "SF Mono", Menlo, monospace;

  --gap: 24px;
  --pad: 28px;
  --row-h: 44px;
  --radius: 6px;
}

[data-theme="dark"]{
  --paper: #0a0a0b;
  --paper-2: #111113;
  --paper-3: #18181b;
  --ink: #f5f5f7;
  --ink-2: #d4d4d8;
  --ink-3: #8a8a90;
  --ink-4: #56565c;
  --rule: rgba(245,245,247,.10);
  --rule-strong: rgba(245,245,247,.20);
  --bg-card: #0d0d0f;
  --bg-inset: #18181b;
  --accent-soft: rgba(80,140,255,.14);
  --accent-line: rgba(80,140,255,.40);
}

[data-density="compact"]{ --gap:16px; --pad:18px; --row-h:36px; }
[data-density="comfortable"]{ --gap:32px; --pad:36px; --row-h:52px; }

*{box-sizing:border-box}
html, body{margin:0;padding:0;background:var(--paper);color:var(--ink);font-family:var(--sans);font-size:13.5px;line-height:1.45;-webkit-font-smoothing:antialiased;letter-spacing:-0.011em;}
body{min-height:100vh;}
button{font:inherit;color:inherit}
a{color:inherit;text-decoration:none}

.serif{font-family:var(--serif);font-weight:500;letter-spacing:-0.02em}
.mono{font-family:var(--mono);letter-spacing:0;}
.eyebrow{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3)}
.tabnum{font-variant-numeric:tabular-nums}
.rule{height:1px;background:var(--rule)}
.rule-strong{height:1px;background:var(--rule-strong)}

.app{display:grid;grid-template-columns:240px 1fr;min-height:100vh;background:var(--paper);}
.app[data-rail="narrow"]{grid-template-columns:64px 1fr;}

.sb{border-right:1px solid var(--rule);padding:22px 18px;display:flex;flex-direction:column;gap:6px;background:var(--paper);position:sticky;top:0;height:100vh;}
.sb-brand{display:flex;align-items:baseline;gap:10px;padding:6px 6px 22px}
.sb-brand .mark{font-family:var(--sans);font-weight:600;font-size:20px;line-height:1;color:var(--ink);letter-spacing:-0.025em}
.sb-brand .mark::before{content:"";display:inline-block;width:8px;height:8px;background:var(--accent);margin-right:8px;border-radius:1px;vertical-align:1px}
.sb-brand .sb-tagline{font-family:var(--mono);font-size:10px;color:var(--ink-3);letter-spacing:.10em;text-transform:uppercase}
.sb-section{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-4);padding:18px 8px 6px}
.sb-item{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-radius:4px;color:var(--ink-2);cursor:default;font-size:13px;font-weight:400;}
.sb-item:hover{background:var(--bg-inset)}
.sb-item .num{font-family:var(--mono);font-size:10px;color:var(--ink-4);letter-spacing:.04em}
.sb-item[data-active="true"]{color:var(--ink);background:var(--bg-inset);font-weight:500}
.sb-item[data-active="true"] .num{color:var(--accent)}
.sb-foot{margin-top:auto;font-family:var(--mono);font-size:10px;color:var(--ink-4);letter-spacing:.04em;padding:10px 8px;display:flex;justify-content:space-between}
.sb-foot .dot{width:6px;height:6px;border-radius:50%;background:#22c55e;display:inline-block;margin-right:6px;vertical-align:middle}

.tb{display:flex;align-items:center;justify-content:space-between;padding:18px var(--pad);border-bottom:1px solid var(--rule);background:var(--paper);position:sticky;top:0;z-index:5;}
.tb-l{display:flex;align-items:baseline;gap:14px}
.tb-crumbs{font-family:var(--mono);font-size:10.5px;letter-spacing:.10em;text-transform:uppercase;color:var(--ink-3);display:flex;gap:8px;align-items:baseline}
.tb-crumbs .sep{color:var(--ink-4)}
.tb-r{display:flex;align-items:center;gap:8px}
.chip{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border:1px solid var(--rule-strong);border-radius:4px;font-family:var(--mono);font-size:11px;color:var(--ink-2);background:transparent;cursor:default}
.chip:hover{border-color:var(--ink-3);color:var(--ink)}
.chip[data-active="true"]{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.chip .k{color:var(--ink-4)}
.chip[data-active="true"] .k{color:var(--paper-3)}
.seg{display:inline-flex;border:1px solid var(--rule-strong);border-radius:4px;overflow:hidden}
.seg button{padding:6px 10px;font-family:var(--mono);font-size:11px;color:var(--ink-3);background:transparent;border:0;cursor:default;border-right:1px solid var(--rule)}
.seg button:last-child{border-right:0}
.seg button[data-active="true"]{background:var(--ink);color:var(--paper)}

.page{padding:36px var(--pad) 80px;max-width:1480px;margin:0 auto;}
.page-head{display:grid;grid-template-columns:1fr auto;gap:24px;align-items:end;padding-bottom:28px;border-bottom:1px solid var(--rule-strong);margin-bottom:36px}
.page-head .eyebrow{margin-bottom:14px}
.page-head h1{font-family:var(--sans);font-weight:600;font-size:54px;line-height:1.04;letter-spacing:-0.035em;margin:0;text-wrap:balance;color:var(--ink);}
.page-head h1 em{font-style:normal;color:var(--accent);font-weight:600;}
.page-head .sub{color:var(--ink-3);max-width:560px;margin-top:22px;font-size:14px;line-height:1.55}
.page-head .meta{font-family:var(--mono);font-size:10.5px;color:var(--ink-3);letter-spacing:.04em;text-align:right;display:flex;flex-direction:column;gap:6px}
.page-head .meta .big{font-family:var(--sans);font-weight:600;font-size:36px;color:var(--ink);letter-spacing:-0.025em;line-height:1;font-variant-numeric:tabular-nums}

.card{border:1px solid var(--rule);background:var(--bg-card);border-radius:var(--radius);padding:var(--pad);position:relative;}
.card .card-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:18px;gap:16px}
.card .card-title{font-family:var(--sans);font-size:20px;line-height:1.15;letter-spacing:-0.02em;margin:0;font-weight:600;color:var(--ink);}
.card .card-sub{color:var(--ink-3);font-size:13px;max-width:54ch;line-height:1.5;}
.card .card-eye{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3)}

.metric{display:flex;flex-direction:column;gap:6px;padding:18px 0;border-top:1px solid var(--rule);}
.metric:first-child{border-top:0;padding-top:0}
.metric .lbl{font-family:var(--mono);font-size:10.5px;letter-spacing:.10em;text-transform:uppercase;color:var(--ink-3)}
.metric .val{font-family:var(--sans);font-weight:600;font-size:36px;line-height:1.05;letter-spacing:-0.03em;color:var(--ink);font-variant-numeric:tabular-nums}
.metric .val em{font-style:normal;color:var(--accent)}
.metric .delta{font-family:var(--mono);font-size:11px;color:var(--ink-3)}
.metric .delta.up{color:#118a4e}
.metric .delta.down{color:#c2410c}

.bigstat{padding:0;border-radius:var(--radius)}
.bigstat .num{font-family:var(--sans);font-size:96px;line-height:.95;letter-spacing:-0.045em;color:var(--ink);font-variant-numeric:tabular-nums;font-weight:600}
.bigstat .num em{font-style:normal;color:var(--accent)}
.bigstat .denom{font-family:var(--mono);font-size:12.5px;color:var(--ink-3);letter-spacing:.04em}
.bigstat .copy{font-family:var(--sans);font-weight:400;font-size:18px;line-height:1.4;color:var(--ink-2);max-width:36ch;margin-top:18px;letter-spacing:-0.01em;}

.tbl{width:100%;border-collapse:collapse;font-size:13px}
.tbl thead th{text-align:left;padding:10px 12px;font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);border-bottom:1px solid var(--rule-strong);font-weight:500}
.tbl tbody td{padding:14px 12px;border-bottom:1px solid var(--rule);vertical-align:middle}
.tbl tbody tr:hover{background:var(--bg-inset)}
.tbl td.num{font-family:var(--mono);font-variant-numeric:tabular-nums;text-align:right}
.tbl td .name{font-weight:500}
.tbl td .sub{color:var(--ink-3);font-size:12px}

.bar{position:relative;height:6px;background:var(--bg-inset);border-radius:2px;overflow:hidden}
.bar > i{position:absolute;left:0;top:0;bottom:0;background:var(--ink-2);}
.bar > i.acc{background:var(--accent)}

.tag{display:inline-flex;align-items:center;gap:6px;padding:3px 8px;border:1px solid var(--rule-strong);border-radius:3px;font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;color:var(--ink-2);text-transform:uppercase}
.tag.acc{border-color:var(--accent-line);color:var(--accent);background:var(--accent-soft)}
.tag.warn{border-color:rgba(194,65,12,.40);color:#c2410c;background:rgba(194,65,12,.06)}
.tag.ok{border-color:rgba(17,138,78,.40);color:#118a4e;background:rgba(17,138,78,.06)}

.note{font-family:var(--mono);font-size:10.5px;color:var(--ink-3);letter-spacing:.04em}
.kbd{font-family:var(--mono);font-size:10.5px;border:1px solid var(--rule-strong);border-bottom-width:2px;padding:1px 5px;border-radius:3px;color:var(--ink-2)}

.grid{display:grid;gap:var(--gap)}
.g-12{grid-template-columns:repeat(12,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}
.col-4{grid-column:span 4}
.col-5{grid-column:span 5}
.col-6{grid-column:span 6}
.col-7{grid-column:span 7}
.col-8{grid-column:span 8}
.col-12{grid-column:span 12}

.section{margin:64px 0 24px;display:grid;grid-template-columns:200px 1fr;gap:24px;align-items:baseline;padding-top:28px;border-top:1px solid var(--rule-strong)}
.section .lbl{font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3)}
.section h2{font-family:var(--sans);font-weight:600;font-size:30px;line-height:1.1;letter-spacing:-0.03em;margin:0;color:var(--ink);max-width:28ch}
.section h2 em{font-style:normal;color:var(--accent)}

.filterbar{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:24px;flex-wrap:wrap}
.filterbar .group{display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.filterbar .lbl{font-family:var(--mono);font-size:10.5px;color:var(--ink-3);letter-spacing:.10em;text-transform:uppercase;margin-right:4px}

.tip{position:absolute;background:var(--ink);color:var(--paper);padding:8px 10px;font-family:var(--mono);font-size:11px;line-height:1.4;border-radius:3px;pointer-events:none;z-index:50;max-width:240px;box-shadow:0 6px 18px rgba(0,0,0,.18)}
.tip b{color:var(--paper);font-weight:500}
.tip .k{color:var(--paper-3)}

.axis text{font-family:var(--mono);font-size:10px;fill:var(--ink-3);letter-spacing:0.04em;text-transform:uppercase}
.axis line, .axis path{stroke:var(--rule-strong)}
.gridline{stroke:var(--rule)}

.callout{position:absolute;background:var(--paper);border:1px solid var(--rule-strong);padding:10px 12px;font-family:var(--mono);font-size:10.5px;line-height:1.4;color:var(--ink-2);border-radius:4px;max-width:240px;box-shadow:0 4px 16px rgba(0,0,0,.06)}
.callout b{font-family:var(--sans);font-weight:600;font-size:13px;color:var(--accent);font-style:normal;display:block;margin-bottom:4px;letter-spacing:-0.01em}

.dot-acc{width:8px;height:8px;border-radius:50%;background:var(--accent);display:inline-block;vertical-align:middle;margin-right:6px}
