/* ============================================================
   SteamIQHQ — shared design system
   dark-first · Bricolage Grotesque / Hanken Grotesk / JetBrains Mono
   ============================================================ */
:root{
  --bg:#0A0B0D;
  --surface:#121419;
  --surface-2:#1A1D24;
  --surface-3:#22262F;
  --line:#2A2F39;
  --line-soft:#21252D;
  --tx:#ECEEF2;
  --tx-2:#9AA1AD;
  --tx-3:#777E8A;
  --signal:#2DD6E8;
  --signal-2:#16B5C8;
  --signal-dim:rgba(45,214,232,.14);
  --hot:#FB5BA2;
  --hot-dim:rgba(251,91,162,.14);
  --buy:#36D399;
  --watch:#FBB834;
  --wait:#F4615C;
  --buy-dim:rgba(54,211,153,.13);
  --watch-dim:rgba(251,184,52,.13);
  --wait-dim:rgba(244,97,92,.13);
  --r:14px;
  --r-sm:9px;
  --font-display:'Bricolage Grotesque',sans-serif;
  --font-ui:'Hanken Grotesk',sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,monospace;
  --maxw:1280px;
}
[data-theme="light"]{
  --bg:#F4F2EC;--surface:#FBFAF6;--surface-2:#EFEDE5;--surface-3:#E6E3D9;
  --line:#DDD9CE;--line-soft:#E8E5DB;--tx:#16181C;--tx-2:#54585F;--tx-3:#6B6F77;
  --signal:#0E9BB0;--signal-2:#0E9BB0;--signal-dim:rgba(14,155,176,.12);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;background:var(--bg);color:var(--tx);
  font-family:var(--font-ui);font-size:15px;line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none;}
.num{font-family:var(--font-mono);font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;}
.mono{font-family:var(--font-mono);}
.muted{color:var(--tx-2);}
.dim{color:var(--tx-3);}

/* ---------- wordmark ---------- */
.wordmark{display:inline-flex;align-items:center;gap:2px;font-family:var(--font-display);font-weight:700;letter-spacing:-.02em;font-size:19px;color:var(--tx);}
.wordmark .iq{color:var(--signal);}
.live-dot{width:8px;height:8px;border-radius:50%;background:var(--buy);position:relative;flex:none;}
.live-dot::after{content:"";position:absolute;inset:-4px;border-radius:50%;border:1.5px solid var(--buy);animation:siq-pulse 2s ease-out infinite;}
.live-dot.signal{background:var(--signal);}
.live-dot.signal::after{border-color:var(--signal);}
@keyframes siq-pulse{0%{transform:scale(.7);opacity:.9}100%{transform:scale(1.9);opacity:0}}

/* ---------- nav ---------- */
.siq-nav{position:sticky;top:0;z-index:50;background:rgba(10,11,13,.78);backdrop-filter:blur(16px);border-bottom:1px solid var(--line-soft);}
[data-theme="light"] .siq-nav{background:rgba(244,242,236,.82);}
.siq-nav .bar{max-width:var(--maxw);margin:0 auto;padding:0 28px;height:62px;display:flex;align-items:center;gap:18px;}
.siq-nav .links{display:flex;gap:1px;align-items:center;}
.siq-nav .links a{font-size:13px;color:var(--tx-2);padding:8px 11px;border-radius:9px;display:inline-flex;align-items:center;gap:5px;white-space:nowrap;}
.siq-nav .links a:hover{color:var(--tx);background:var(--surface-2);}
.siq-nav .links a.on{color:var(--tx);background:var(--surface-2);}
.siq-nav .links a .caret{font-size:9px;color:var(--tx-3);}
.siq-nav .spacer{flex:1;}
.siq-nav .has-menu{position:relative;}
.siq-nav .menu{position:absolute;top:calc(100% + 8px);left:0;min-width:190px;background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:7px;opacity:0;visibility:hidden;transform:translateY(-5px);transition:.14s;box-shadow:0 16px 40px rgba(0,0,0,.45);z-index:60;}
.siq-nav .has-menu:hover .menu{opacity:1;visibility:visible;transform:translateY(0);}
.siq-nav .menu a{display:block;padding:8px 11px;border-radius:8px;font-size:13px;color:var(--tx-2);}
.siq-nav .menu a:hover{background:var(--surface-2);color:var(--tx);}
.siq-nav .menu a .d{font-family:var(--font-mono);font-size:10.5px;color:var(--tx-3);margin-left:8px;}
.siq-nav .right{display:flex;align-items:center;gap:10px;}
.search-box{display:flex;align-items:center;gap:8px;background:var(--surface-2);border:1px solid var(--line);border-radius:10px;padding:8px 11px;color:var(--tx-3);font-size:12.5px;font-family:var(--font-mono);cursor:text;white-space:nowrap;flex:none;}
.search-box kbd{margin-left:auto;font-family:var(--font-mono);font-size:10px;background:var(--surface-3);border:1px solid var(--line);border-radius:4px;padding:1px 5px;color:var(--tx-3);}
.nav-toggle{display:none;}

/* ---------- buttons ---------- */
.btn{font-family:var(--font-ui);font-size:13px;font-weight:600;padding:8px 15px;border-radius:10px;border:1px solid var(--line);background:transparent;color:var(--tx);cursor:pointer;display:inline-flex;align-items:center;gap:7px;transition:.14s;white-space:nowrap;}
.btn:hover{border-color:var(--tx-3);}
.btn.primary{background:var(--signal);color:#04181b;border-color:var(--signal);}
.btn.primary:hover{filter:brightness(1.08);border-color:var(--signal);}
.btn.ghost{border-color:transparent;color:var(--tx-2);}
.btn.ghost:hover{color:var(--tx);background:var(--surface-2);}
.btn.sm{padding:6px 11px;font-size:12px;}

/* ---------- section heads ---------- */
.sec-head{display:flex;align-items:center;gap:14px;margin-bottom:18px;}
.sec-head h2{font-family:var(--font-display);font-weight:700;font-size:22px;letter-spacing:-.02em;margin:0;}
.sec-head .ico{color:var(--signal);font-family:var(--font-mono);font-size:13px;}
.sec-head .more{margin-left:auto;font-size:13px;color:var(--tx-2);display:inline-flex;align-items:center;gap:5px;}
.sec-head .more:hover{color:var(--signal);}
.eyebrow{font-family:var(--font-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--tx-3);}

/* ---------- panel / card ---------- */
.panel{border:1px solid var(--line);border-radius:var(--r);background:var(--surface);overflow:hidden;}
.panel-h{padding:14px 18px;border-bottom:1px solid var(--line-soft);display:flex;align-items:center;gap:12px;}
.panel-h .t{font-family:var(--font-display);font-weight:600;font-size:15px;}
.panel-h .sub{font-family:var(--font-mono);font-size:11px;color:var(--tx-3);}
.panel-h .right{margin-left:auto;display:flex;align-items:center;gap:8px;}
.panel-b{padding:18px;}

/* ---------- badges (verdict) ---------- */
.badge{display:inline-flex;align-items:center;gap:7px;border-radius:8px;padding:5px 10px 5px 7px;font-family:var(--font-mono);font-weight:600;font-size:12px;letter-spacing:.04em;}
.badge .n{font-size:14px;font-weight:700;}
.badge.buy{background:var(--buy-dim);color:var(--buy);}
.badge.watch{background:var(--watch-dim);color:var(--watch);}
.badge.wait{background:var(--wait-dim);color:var(--wait);}
.badge.sm{padding:3px 7px 3px 5px;font-size:11px;}
.badge.sm .n{font-size:12px;}

/* ---------- chips (deltas) ---------- */
.chip{font-family:var(--font-mono);font-size:12px;font-weight:600;padding:3px 8px;border-radius:6px;display:inline-flex;align-items:center;gap:4px;white-space:nowrap;}
.chip.up{color:var(--buy);background:var(--buy-dim);}
.chip.dn{color:var(--wait);background:var(--wait-dim);}
.chip.flat{color:var(--tx-3);background:var(--surface-2);}
.chip.hot{color:var(--hot);background:var(--hot-dim);}

/* ---------- pills / tags ---------- */
.pill{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--tx-2);background:var(--surface-2);border:1px solid var(--line);border-radius:999px;padding:5px 11px;}
.pill:hover{color:var(--tx);border-color:var(--tx-3);}

/* ---------- segmented control ---------- */
.seg{display:inline-flex;background:var(--surface-2);border:1px solid var(--line);border-radius:9px;padding:3px;gap:2px;}
.seg button{font-family:var(--font-mono);font-size:12px;font-weight:600;color:var(--tx-3);background:transparent;border:0;padding:5px 11px;border-radius:6px;cursor:pointer;transition:.12s;white-space:nowrap;}
.seg button.on{background:var(--surface-3);color:var(--tx);}
.seg button:hover:not(.on){color:var(--tx-2);}

/* ---------- data table ---------- */
.dtable{width:100%;border-collapse:collapse;}
.dtable thead th{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--tx-3);text-align:right;padding:0 14px 11px;font-weight:600;}
.dtable thead th.l{text-align:left;}
.dtable tbody td{padding:9px 14px;border-top:1px solid var(--line-soft);font-size:13.5px;text-align:right;}
.dtable tbody td.l{text-align:left;}
.dtable tbody tr:hover{background:var(--surface-2);}
.dtable .rk{font-family:var(--font-mono);color:var(--tx-3);font-size:12.5px;width:30px;text-align:center;}
.game{display:flex;align-items:center;gap:11px;min-width:0;}
.game .art{width:54px;height:25px;border-radius:4px;background-size:cover;background-position:center;background-color:var(--surface-3);flex:none;}
.game .nm{display:flex;flex-direction:column;gap:1px;min-width:0;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.game .dev{font-family:var(--font-mono);font-size:11px;font-weight:400;color:var(--tx-3);}
.dtable .val{font-family:var(--font-mono);font-weight:600;}

/* ---------- sparkline ---------- */
.spark{display:block;}

/* ---------- deal card ---------- */
.deal{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--surface);display:flex;flex-direction:column;transition:.16s;}
.deal:hover{border-color:var(--tx-3);transform:translateY(-2px);}
.deal .img{height:118px;background-size:cover;background-position:center;position:relative;background-color:var(--surface-3);}
.deal .img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 38%,rgba(10,11,13,.82));}
.deal .off{position:absolute;top:10px;left:10px;background:var(--wait);color:#1a0606;font-family:var(--font-mono);font-weight:700;font-size:12px;padding:3px 8px;border-radius:6px;z-index:2;}
.deal .atl{position:absolute;top:10px;right:10px;background:rgba(10,11,13,.72);backdrop-filter:blur(4px);color:var(--signal);font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;padding:4px 8px;border-radius:6px;z-index:2;border:1px solid rgba(45,214,232,.3);}
.deal .body{padding:14px 16px;display:flex;flex-direction:column;gap:11px;flex:1;}
.deal .ttl{font-size:14.5px;font-weight:600;}
.deal .price{display:flex;align-items:baseline;gap:9px;font-family:var(--font-mono);}
.deal .price .now{font-size:19px;font-weight:700;}
.deal .price .was{font-size:13px;color:var(--tx-3);text-decoration:line-through;}
.deal .foot{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:12px;border-top:1px solid var(--line-soft);}
.deal .foot .why{font-size:11px;color:var(--tx-2);max-width:18ch;line-height:1.35;text-align:right;}

/* ---------- genre bars ---------- */
.gbar{display:flex;align-items:center;gap:14px;padding:9px 0;}
.gbar .lab{width:160px;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.gbar .track{flex:1;height:8px;background:var(--surface-2);border-radius:999px;overflow:hidden;}
.gbar .fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--signal-2),var(--signal));}
.gbar .pct{width:54px;text-align:right;font-family:var(--font-mono);font-size:12.5px;font-weight:600;}
.gbar .ccu{width:88px;text-align:right;font-family:var(--font-mono);font-size:12px;color:var(--tx-3);}

/* ---------- dev rank list ---------- */
.devrow{display:flex;align-items:center;gap:13px;padding:11px 0;border-top:1px solid var(--line-soft);}
.devrow:first-child{border-top:0;}
.devrow .rk{font-family:var(--font-mono);font-size:13px;color:var(--tx-3);width:18px;}
.devrow .art{width:46px;height:46px;border-radius:9px;background-size:cover;background-position:center;background-color:var(--surface-3);flex:none;}
.devrow .meta{flex:1;min-width:0;}
.devrow .meta .nm{font-weight:600;font-size:14px;}
.devrow .meta .sub{font-family:var(--font-mono);font-size:11.5px;color:var(--tx-3);}
.devrow .ccu{font-family:var(--font-mono);font-weight:600;font-size:14px;text-align:right;}

/* ---------- tool cards ---------- */
.tool{display:flex;align-items:center;gap:14px;padding:15px 17px;border:1px solid var(--line);border-radius:var(--r);background:var(--surface);transition:.15s;}
.tool:hover{border-color:var(--signal);background:var(--surface-2);}
.tool .gi{width:38px;height:38px;border-radius:10px;background:var(--signal-dim);color:var(--signal);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-weight:700;flex:none;font-size:15px;}
.tool .tt{font-weight:600;font-size:14px;}
.tool .td{font-size:12px;color:var(--tx-2);}
.tool .arr{margin-left:auto;color:var(--tx-3);}
.tool:hover .arr{color:var(--signal);}

/* ---------- footer ---------- */
.siq-foot{border-top:1px solid var(--line-soft);margin-top:60px;padding:46px 0 60px;}
.siq-foot .cols{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:30px;}
.siq-foot h5{font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--tx-3);margin:0 0 14px;}
.siq-foot a{display:block;color:var(--tx-2);font-size:13.5px;padding:4px 0;}
.siq-foot a:hover{color:var(--signal);}
.siq-foot .blurb{font-size:13.5px;color:var(--tx-2);max-width:30ch;margin:14px 0 0;}

/* ---------- utilities ---------- */
.grid{display:grid;}
.flex{display:flex;}
.between{justify-content:space-between;}
.center{align-items:center;}
.gap-s{gap:10px;}
.gap-m{gap:18px;}
.gap-l{gap:28px;}

/* ---------- search command palette ---------- */
.srch-bg{position:fixed;inset:0;z-index:200;background:rgba(5,6,8,.7);backdrop-filter:blur(6px);display:none;align-items:flex-start;justify-content:center;padding:88px 20px 20px;}
.srch-bg.on{display:flex;}
.srch{width:620px;max-width:100%;background:var(--surface);border:1px solid var(--line);border-radius:16px;overflow:hidden;box-shadow:0 36px 90px rgba(0,0,0,.6);display:flex;flex-direction:column;max-height:74vh;}
.srch-top{display:flex;align-items:center;gap:12px;padding:16px 18px;border-bottom:1px solid var(--line-soft);}
.srch-top .ic{font-size:18px;color:var(--tx-3);}
.srch-top input{flex:1;background:none;border:0;outline:none;color:var(--tx);font-family:var(--font-ui);font-size:16px;min-width:0;}
.srch-top input::placeholder{color:var(--tx-3);}
.srch-top kbd{font-family:var(--font-mono);font-size:10px;background:var(--surface-3);border:1px solid var(--line);border-radius:5px;padding:2px 6px;color:var(--tx-3);flex:none;}
.srch-results{overflow-y:auto;padding:8px;}
.srch-label{font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--tx-3);padding:8px 10px 6px;}
.srch-row{display:flex;align-items:center;gap:13px;padding:9px 11px;border-radius:10px;cursor:pointer;}
.srch-row.active{background:var(--surface-2);}
.srch-row .art{width:68px;height:32px;border-radius:5px;background-size:cover;background-position:center;background-color:var(--surface-3);flex:none;}
.srch-row .nm{font-size:14px;font-weight:600;display:flex;flex-direction:column;gap:1px;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.srch-row .nm .dev{font-family:var(--font-mono);font-size:11px;font-weight:400;color:var(--tx-3);}
.srch-row .rt{margin-left:auto;display:flex;align-items:center;gap:12px;flex:none;}
.srch-row .rt .pl{font-family:var(--font-mono);font-size:12px;color:var(--tx-2);}
.srch-row .rt .pr{font-family:var(--font-mono);font-size:12.5px;font-weight:700;width:52px;text-align:right;}
.srch-empty{padding:30px 14px;text-align:center;color:var(--tx-3);font-family:var(--font-mono);font-size:13px;}
.srch-foot{display:flex;align-items:center;gap:16px;padding:11px 16px;border-top:1px solid var(--line-soft);font-size:11.5px;color:var(--tx-3);}
.srch-foot .k{font-family:var(--font-mono);background:var(--surface-3);border:1px solid var(--line);border-radius:4px;padding:1px 6px;margin-right:5px;}

@media(max-width:840px){
  .siq-nav .links{display:none;}
  .nav-toggle{display:inline-flex;}
  .search-box{min-width:0;}
  .siq-foot .cols{grid-template-columns:1fr 1fr;}
}

/* ---------- homepage layout ---------- */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
.home-grid{display:grid;grid-template-columns:1fr 360px;gap:28px;align-items:start;}
.deal-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.bottom-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;margin-top:40px;}
@media(max-width:1040px){ .home-grid{grid-template-columns:1fr;} }
@media(max-width:640px){ .kpi-grid{grid-template-columns:1fr 1fr;} .deal-grid{grid-template-columns:1fr;} .bottom-grid{grid-template-columns:1fr;} }
@media(max-width:400px){ .kpi-grid{grid-template-columns:1fr;} }

/* focus ring for keyboard nav on clickable surfaces */
.panel:focus-visible,.tool:focus-visible,.devrow:focus-visible{outline:2px solid var(--signal);outline-offset:2px;}

/* ---------- game detail ---------- */
.gd-hero{position:relative;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin-bottom:28px;}
.gd-hero .bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.32;}
.gd-hero .bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,11,13,.4),var(--bg)),linear-gradient(90deg,var(--bg),transparent 60%);}
[data-theme="light"] .gd-hero .bg::after{background:linear-gradient(180deg,rgba(244,242,236,.4),var(--bg)),linear-gradient(90deg,var(--bg),transparent 60%);}
.gd-hero .inner{position:relative;display:grid;grid-template-columns:1fr 360px;gap:28px;padding:28px;align-items:start;}
.gd-hero .cap{width:300px;max-width:100%;border-radius:8px;box-shadow:0 16px 40px rgba(0,0,0,.5);display:block;margin-bottom:16px;}
.gd-title{font-family:var(--font-display);font-weight:800;letter-spacing:-.02em;font-size:clamp(26px,3.4vw,40px);margin:6px 0;}
.gd-sub{font-family:var(--font-mono);font-size:12.5px;color:var(--tx-3);}
.gd-tags{display:flex;flex-wrap:wrap;gap:7px;margin:14px 0;}
.gd-stats{display:flex;flex-wrap:wrap;gap:26px;margin-top:18px;}
.gd-stat .v{font-family:var(--font-mono);font-weight:700;font-size:22px;}
.gd-stat .k{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--tx-3);margin-top:3px;}
.verdict-card{position:sticky;top:78px;border:1px solid var(--line);border-radius:var(--r);background:var(--surface);padding:20px;}
.verdict-card .vhead{font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--tx-3);}
.verdict-card .gwrap{display:flex;justify-content:center;margin:14px 0 6px;}
.verdict-card .vlabel{text-align:center;font-family:var(--font-mono);font-weight:700;letter-spacing:.12em;text-transform:uppercase;}
.verdict-card .why{font-size:13px;color:var(--tx-2);text-align:center;margin:10px 0 16px;line-height:1.5;}
.verdict-card .pblock{display:flex;align-items:baseline;gap:10px;justify-content:center;font-family:var(--font-mono);margin-bottom:16px;}
.verdict-card .pblock .now{font-size:26px;font-weight:700;}
.verdict-card .pblock .off{color:var(--wait);font-weight:700;}
.verdict-card .pblock .was{color:var(--tx-3);text-decoration:line-through;font-size:14px;}
.verdict-card .meta{margin-top:16px;border-top:1px solid var(--line-soft);padding-top:14px;display:grid;gap:8px;}
.verdict-card .meta .row{display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:12px;}
.verdict-card .meta .row .k{color:var(--tx-3);}
@media(max-width:980px){ .gd-hero .inner{grid-template-columns:1fr;} .verdict-card{position:static;} }

/* ====================================================================
   LISTINGS FAMILY (Phase 4) — shared by Top 250 + browse-family views
   ==================================================================== */
/* page head + category tabs */
.listhead{border-bottom:1px solid var(--line-soft);padding:30px 0 26px;background-image:radial-gradient(900px 380px at 85% -30%, rgba(45,214,232,.06), transparent 60%);}
.listhead .crumb{font-family:var(--font-mono);font-size:11.5px;color:var(--tx-3);margin-bottom:14px;}
.listhead .crumb a:hover{color:var(--signal);}
.listhead h1{font-family:var(--font-display);font-weight:800;font-size:clamp(28px,4vw,40px);letter-spacing:-.02em;margin:0 0 8px;}
.listhead .sub{color:var(--tx-2);font-size:15px;max-width:62ch;}
.listhead .tabs{display:flex;gap:6px;margin-top:20px;flex-wrap:wrap;}
.listhead .tabs a{font-family:var(--font-ui);font-size:13.5px;font-weight:600;color:var(--tx-2);padding:8px 15px;border-radius:999px;border:1px solid var(--line);background:var(--surface);white-space:nowrap;}
.listhead .tabs a.on{color:#04181b;background:var(--signal);border-color:var(--signal);}
.listhead .tabs a:hover:not(.on){color:var(--tx);border-color:var(--tx-3);}

/* sticky filter toolbar */
.toolbar{position:sticky;top:62px;z-index:30;background:rgba(10,11,13,.86);backdrop-filter:blur(12px);border-bottom:1px solid var(--line-soft);padding:13px 0;}
[data-theme="light"] .toolbar{background:rgba(244,242,236,.9);}
.toolbar .row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;}
.filt{display:inline-flex;align-items:center;gap:8px;}
.filt label{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--tx-3);}
.sel{font-family:var(--font-ui);font-size:13px;font-weight:500;color:var(--tx);background:var(--surface-2);border:1px solid var(--line);border-radius:9px;padding:8px 11px;cursor:pointer;}
.sel:focus{outline:none;border-color:var(--signal);}
.toolbar .count{margin-left:auto;font-family:var(--font-mono);font-size:12px;color:var(--tx-3);}
.toolbar .count b{color:var(--tx);}
.clearbtn{font-family:var(--font-mono);font-size:11.5px;color:var(--signal);cursor:pointer;background:none;border:0;padding:6px;}
.clearbtn:hover{text-decoration:underline;}
.rng{display:flex;align-items:center;gap:9px;}
.rng input[type=range]{-webkit-appearance:none;appearance:none;width:96px;height:4px;border-radius:3px;background:var(--surface-3);outline:none;}
.rng input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--signal);cursor:pointer;border:2px solid var(--bg);}
.rng input[type=range]::-moz-range-thumb{width:14px;height:14px;border:0;border-radius:50%;background:var(--signal);cursor:pointer;}
.rng .val{font-family:var(--font-mono);font-size:12px;font-weight:600;color:var(--tx);width:40px;}

/* listing table chrome (layers on .dtable) */
.listwrap{padding:22px 0 0;}
.dtable thead th.sortable{cursor:pointer;user-select:none;white-space:nowrap;}
.dtable thead th.sortable:hover{color:var(--tx-2);}
.dtable thead th .ar{color:var(--signal);font-size:9px;margin-left:3px;}
.dtable td.price .now{font-family:var(--font-mono);font-weight:700;}
.dtable td.price .now.free{color:var(--signal);}
.dtable td.price .was{font-family:var(--font-mono);font-size:11px;color:var(--tx-3);text-decoration:line-through;display:block;}
.dtable td.price .offtag{font-family:var(--font-mono);font-size:11px;font-weight:700;color:var(--wait);}
.dtable td .rate{font-family:var(--font-mono);font-weight:700;}

/* mobile card collapse */
.mcards{display:none;flex-direction:column;gap:11px;padding:18px 0 0;}
.mcard{border:1px solid var(--line);border-radius:var(--r);background:var(--surface);padding:13px;display:flex;gap:13px;align-items:center;text-decoration:none;color:inherit;}
.mcard .art{width:96px;height:45px;border-radius:6px;background-size:cover;background-position:center;background-color:var(--surface-3);flex:none;}
.mcard .mid{flex:1;min-width:0;}
.mcard .nm{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.mcard .meta{font-family:var(--font-mono);font-size:11.5px;color:var(--tx-3);margin-top:3px;display:flex;gap:10px;align-items:center;}
.mcard .meta .pl{color:var(--tx-2);}
.mcard .rt{display:flex;flex-direction:column;align-items:flex-end;gap:7px;}
.mcard .price-m{font-family:var(--font-mono);font-weight:700;font-size:15px;}

.loadmore{display:flex;justify-content:center;padding:34px 0 10px;}
.loadmore .btn{padding:11px 26px;}
.empty{padding:60px 0;text-align:center;color:var(--tx-3);font-family:var(--font-mono);font-size:13px;}

@media(max-width:880px){
  .lst-table{display:none;}
  .mcards{display:flex;}
}

/* ====================================================================
   ANALYTICS FAMILY (Phase 5) — Charts / Compare / Rank Tracking
   ==================================================================== */
.anhead{border-bottom:1px solid var(--line-soft);padding:26px 0 0;background-image:radial-gradient(900px 400px at 85% -30%, rgba(45,214,232,.06), transparent 60%);}
.anhead .crumb{font-family:var(--font-mono);font-size:11.5px;color:var(--tx-3);margin-bottom:12px;}
.anhead .crumb a:hover{color:var(--signal);}
.anhead h1{font-family:var(--font-display);font-weight:800;font-size:clamp(26px,3.6vw,38px);letter-spacing:-.02em;margin:0 0 4px;}
.anhead .sub{color:var(--tx-2);font-size:14.5px;}
.vtabs{display:flex;gap:2px;margin-top:22px;}
.vtabs a{font-family:var(--font-ui);font-size:14px;font-weight:600;color:var(--tx-2);border-bottom:2px solid transparent;padding:11px 16px;cursor:pointer;display:inline-flex;align-items:center;gap:8px;}
.vtabs a .ic{font-family:var(--font-mono);font-size:12px;color:var(--tx-3);}
.vtabs a.on{color:var(--tx);border-bottom-color:var(--signal);}
.vtabs a.on .ic{color:var(--signal);}
.vtabs a:hover:not(.on){color:var(--tx);}

/* charts view */
.total-hero{display:grid;grid-template-columns:300px 1fr;gap:28px;align-items:stretch;margin:30px 0;}
.total-card{border:1px solid var(--line);border-radius:var(--r);background:var(--surface);padding:24px;display:flex;flex-direction:column;justify-content:center;}
.total-card .lab{display:flex;align-items:center;gap:9px;font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--tx-3);margin-bottom:14px;}
.total-card .big{font-family:var(--font-mono);font-weight:700;font-size:clamp(38px,4.4vw,52px);letter-spacing:-.03em;line-height:.95;}
.total-card .delta{margin-top:14px;display:flex;align-items:center;gap:9px;}
.total-card .delta .sub{font-family:var(--font-mono);font-size:11.5px;color:var(--tx-3);}
.total-card .mini{margin-top:18px;display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.total-card .mini .m{border:1px solid var(--line-soft);border-radius:9px;padding:10px 12px;}
.total-card .mini .m .v{font-family:var(--font-mono);font-weight:700;font-size:16px;}
.total-card .mini .m .k{font-size:10px;color:var(--tx-3);font-family:var(--font-mono);letter-spacing:.05em;text-transform:uppercase;margin-top:2px;}
.total-chart{border:1px solid var(--line);border-radius:var(--r);background:var(--surface);overflow:hidden;display:flex;flex-direction:column;}
.total-chart .tc-top{padding:16px 20px 6px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;}
.total-chart .tc-top .t{font-family:var(--font-display);font-weight:600;font-size:15px;}
.total-chart .host{padding:8px 12px 12px;flex:1;min-height:262px;position:relative;}

/* compare view */
.cmp-pickbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:24px;}
.cmp-slot{display:flex;align-items:center;gap:10px;border:1px solid var(--line);border-radius:11px;background:var(--surface);padding:8px 10px 8px 8px;}
.cmp-slot .dot{width:10px;height:10px;border-radius:3px;flex:none;}
.cmp-slot .art{width:54px;height:25px;border-radius:4px;background-size:cover;background-position:center;background-color:var(--surface-3);flex:none;}
.cmp-slot .nm{font-size:13px;font-weight:600;white-space:nowrap;}
.cmp-slot .x{color:var(--tx-3);cursor:pointer;font-size:14px;padding:0 4px;}
.cmp-slot .x:hover{color:var(--wait);}
.cmp-add{border:1px dashed var(--line);border-radius:11px;background:none;color:var(--tx-2);font-family:var(--font-ui);font-size:13px;font-weight:600;padding:11px 16px;cursor:pointer;}
.cmp-add:hover{border-color:var(--signal);color:var(--signal);}
.cmp-add:disabled{opacity:.4;cursor:not-allowed;}
.cmp-grid{display:grid;grid-template-columns:1fr 340px;gap:24px;}
.cmp-chartcard .panel-h{justify-content:space-between;}
.cmp-chartcard .host{padding:8px;position:relative;height:300px;}
.cmp-legend{display:flex;gap:18px;flex-wrap:wrap;padding:6px 14px 14px;}
.cmp-legend .lg{display:inline-flex;align-items:center;gap:8px;font-size:12.5px;}
.cmp-legend .lg .sw{width:14px;height:3px;border-radius:2px;}
.cmp-legend .lg .pl{font-family:var(--font-mono);color:var(--tx-3);font-size:11px;margin-left:2px;}
.stat-tbl{width:100%;border-collapse:collapse;}
.stat-tbl th{font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--tx-3);padding:0 10px 11px;text-align:right;font-weight:600;}
.stat-tbl th.l{text-align:left;}
.stat-tbl td{padding:11px 10px;border-top:1px solid var(--line-soft);font-family:var(--font-mono);font-size:13px;font-weight:600;text-align:right;}
.stat-tbl td.l{text-align:left;font-family:var(--font-ui);color:var(--tx-2);font-weight:500;font-size:12.5px;}
.stat-tbl td.best{color:var(--buy);}
.stat-tbl .ghead{display:flex;align-items:center;gap:7px;justify-content:flex-end;}
.stat-tbl .ghead .dot{width:8px;height:8px;border-radius:2px;}
.price-cmp{display:flex;flex-direction:column;gap:12px;}
.price-cmp .pc{display:flex;align-items:center;gap:12px;}
.price-cmp .pc .dot{width:9px;height:9px;border-radius:3px;flex:none;}
.price-cmp .pc .nm{width:120px;font-size:12.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.price-cmp .pc .track{flex:1;height:22px;background:var(--surface-2);border-radius:6px;position:relative;overflow:hidden;}
.price-cmp .pc .fill{height:100%;border-radius:6px;opacity:.85;}
.price-cmp .pc .amt{font-family:var(--font-mono);font-size:12.5px;font-weight:700;width:108px;text-align:right;}
.price-cmp .pc .amt .was{color:var(--tx-3);text-decoration:line-through;font-weight:400;font-size:10.5px;margin-left:5px;}
.cmp-empty{padding:60px 0;text-align:center;color:var(--tx-3);font-family:var(--font-mono);font-size:13px;}

/* game picker modal */
.modal-bg{position:fixed;inset:0;background:rgba(5,6,8,.66);backdrop-filter:blur(4px);z-index:100;display:none;align-items:flex-start;justify-content:center;padding:80px 20px;}
.modal-bg.on{display:flex;}
.modal{width:520px;max-width:100%;background:var(--surface);border:1px solid var(--line);border-radius:16px;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.6);}
.modal .mh{padding:16px 18px;border-bottom:1px solid var(--line-soft);display:flex;align-items:center;gap:10px;}
.modal .mh input{flex:1;background:var(--surface-2);border:1px solid var(--line);border-radius:9px;padding:9px 12px;color:var(--tx);font-family:var(--font-ui);font-size:14px;outline:none;}
.modal .mh input:focus{border-color:var(--signal);}
.modal .mh .x{cursor:pointer;color:var(--tx-3);font-size:18px;padding:4px;}
.modal .mlist{max-height:50vh;overflow:auto;padding:8px;}
.modal .mi{display:flex;align-items:center;gap:12px;padding:9px 11px;border-radius:9px;cursor:pointer;}
.modal .mi:hover{background:var(--surface-2);}
.modal .mi .art{width:64px;height:30px;border-radius:5px;background-size:cover;background-position:center;background-color:var(--surface-3);flex:none;}
.modal .mi .nm{font-size:13.5px;font-weight:600;}
.modal .mi .pl{margin-left:auto;font-family:var(--font-mono);font-size:12px;color:var(--tx-3);}
.modal .mi.dis{opacity:.4;pointer-events:none;}

@media(max-width:980px){ .total-hero{grid-template-columns:1fr;} .cmp-grid{grid-template-columns:1fr;} }
@media(max-width:680px){ .rankpanel .hide-sm{display:none;} }
@media(max-width:880px){ .rt-panels{grid-template-columns:1fr !important;} }

/* ============================================================
   Phase 6 — Deals board (steamiqhq redesign)
   Reuses existing .deal/.toolbar/.filt/.sel/.empty/.badge/.btn.
   ============================================================ */

/* ---- deal head + scoreboard ---- */
.dealhead{border-bottom:1px solid var(--line-soft);padding:30px 0 26px;background-image:radial-gradient(900px 420px at 88% -30%, rgba(54,211,153,.07), transparent 60%);}
.dealhead .crumb{font-family:var(--font-mono);font-size:11.5px;color:var(--tx-3);margin-bottom:14px;}
.dealhead .crumb a:hover{color:var(--signal);}
.dealhead .htop{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap;}
.dealhead h1{font-family:var(--font-display);font-weight:800;font-size:clamp(28px,4vw,42px);letter-spacing:-.02em;margin:0 0 8px;}
.dealhead .sub{color:var(--tx-2);font-size:15px;max-width:60ch;}
.scoreboard{display:flex;gap:0;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--surface);flex:none;}
.scoreboard .sb{padding:13px 20px;border-right:1px solid var(--line-soft);text-align:center;}
.scoreboard .sb:last-child{border-right:0;}
.scoreboard .sb .v{font-family:var(--font-mono);font-weight:700;font-size:22px;}
.scoreboard .sb.buy .v{color:var(--buy);}
.scoreboard .sb.watch .v{color:var(--watch);}
.scoreboard .sb.wait .v{color:var(--wait);}
.scoreboard .sb .k{font-size:10.5px;color:var(--tx-3);font-family:var(--font-mono);letter-spacing:.07em;text-transform:uppercase;margin-top:3px;}

/* ---- featured top pick ---- */
.featured{display:grid;grid-template-columns:1.4fr 1fr;gap:0;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--surface);margin:30px 0 8px;}
.featured .fimg{position:relative;background-size:cover;background-position:center;min-height:300px;}
.featured .fimg::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 40%,var(--surface)),linear-gradient(180deg,transparent 60%,rgba(10,11,13,.5));}
.featured .ftag{position:absolute;top:16px;left:16px;z-index:2;display:flex;gap:8px;}
.featured .ftag .lbl{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;font-weight:700;color:#04181b;background:var(--signal);padding:5px 10px;border-radius:7px;white-space:nowrap;}
.featured .ftag .atl{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--buy);background:var(--buy-dim);border:1px solid rgba(54,211,153,.35);padding:5px 10px;border-radius:7px;white-space:nowrap;}
.featured .fbody{padding:28px 30px;display:flex;flex-direction:column;justify-content:center;}
.featured .fbody .dev{font-family:var(--font-mono);font-size:12px;color:var(--tx-3);margin-bottom:6px;}
.featured .fbody h2{font-family:var(--font-display);font-weight:800;font-size:30px;letter-spacing:-.02em;margin:0 0 14px;line-height:1;}
.featured .fverdict{display:flex;align-items:center;gap:16px;margin-bottom:16px;}
.featured .fverdict .vmeta .k{font-family:var(--font-mono);font-size:12px;color:var(--tx-3);letter-spacing:.08em;text-transform:uppercase;white-space:nowrap;}
.featured .fverdict .vmeta .verdict{font-family:var(--font-display);font-weight:700;font-size:20px;margin-top:2px;}
.featured .fwhy{font-size:14px;color:var(--tx-2);line-height:1.5;margin-bottom:20px;max-width:42ch;}
.featured .fprice{display:flex;align-items:baseline;gap:12px;margin-bottom:22px;font-family:var(--font-mono);}
.featured .fprice .now{font-weight:700;font-size:34px;}
.featured .fprice .off{font-weight:700;font-size:14px;color:var(--wait);background:var(--wait-dim);padding:5px 11px;border-radius:8px;}
.featured .fprice .was{font-size:16px;color:var(--tx-3);text-decoration:line-through;}
.featured .fbtns{display:flex;gap:10px;align-items:center;flex-wrap:wrap;}
.featured .fbtns .ends-f{margin-left:auto;font-family:var(--font-mono);font-size:11.5px;color:var(--tx-3);}
.gauge-big{position:relative;flex:none;}
.gauge-big .lbl{position:absolute;left:0;right:0;top:58%;text-align:center;font-family:var(--font-mono);font-size:10px;letter-spacing:.16em;font-weight:700;}
.gauge-big .lbl.buy{color:var(--buy);}
.gauge-big .lbl.watch{color:var(--watch);}
.gauge-big .lbl.wait{color:var(--wait);}

/* ---- verdict-pill filter (toolbar) ---- */
.vfilter{display:inline-flex;background:var(--surface-2);border:1px solid var(--line);border-radius:9px;padding:3px;gap:2px;}
.vfilter button{font-family:var(--font-mono);font-size:12px;font-weight:600;color:var(--tx-3);background:transparent;border:0;padding:6px 13px;border-radius:6px;cursor:pointer;display:inline-flex;align-items:center;gap:6px;}
.vfilter button .d{width:7px;height:7px;border-radius:50%;}
.vfilter button.on{background:var(--surface-3);color:var(--tx);}
.vfilter button[data-v=buy].on{color:var(--buy);}
.vfilter button[data-v=watch].on{color:var(--watch);}
.vfilter button[data-v=wait].on{color:var(--wait);}
.atl-check{display:inline-flex;align-items:center;gap:6px;cursor:pointer;}
.atl-check input{accent-color:var(--buy);}
.atl-check span{font-size:12.5px;color:var(--tx-2);}

/* ---- deal grid + card extras (layer on existing .deal) ---- */
.dealgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;padding:26px 0 0;}
.dealgrid .empty{grid-column:1/-1;}
.deal{position:relative;}
.deal .scorebar{position:absolute;bottom:0;left:0;right:0;height:3px;z-index:2;}
.deal .scorebar.buy{background:var(--buy);}
.deal .scorebar.watch{background:var(--watch);}
.deal .scorebar.wait{background:var(--wait);}
.deal .img .gi{position:absolute;bottom:10px;right:10px;z-index:2;}
.deal .why-sm{font-size:11.5px;color:var(--tx-2);line-height:1.4;}
.deal .foot .ends{font-family:var(--font-mono);font-size:10.5px;color:var(--tx-3);}
.deal .foot .dev{font-family:var(--font-mono);font-size:10.5px;color:var(--tx-2);max-width:16ch;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}

@media(max-width:1080px){ .dealgrid{grid-template-columns:repeat(3,1fr);} }
@media(max-width:920px){
  .featured{grid-template-columns:1fr;}
  .featured .fimg{min-height:200px;}
  .dealgrid{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:560px){
  .dealgrid{grid-template-columns:1fr;}
  .scoreboard{width:100%;}
  .scoreboard .sb{flex:1;}
}

/* ============================================================
   Phase 7 — Account (Watchlist, Dashboard, Auth)
   ============================================================ */

/* Summary strip */
.summary{display:flex;gap:12px;margin:18px 0 14px;flex-wrap:wrap;}
.summary .s{flex:1;min-width:120px;border:1px solid var(--line);border-radius:var(--r);
  background:var(--surface);padding:14px 16px;}
.summary .s .v{font-size:26px;font-weight:700;line-height:1;color:var(--tx);}
.summary .s .k{margin-top:6px;font-size:11px;text-transform:uppercase;letter-spacing:.08em;
  font-family:var(--font-mono);color:var(--tx-3);}
.summary .s.buy .v{color:var(--buy);}

.wltoolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;
  margin-bottom:14px;flex-wrap:wrap;}
.wltoolbar .hint{font-size:12px;color:var(--tx-3);font-family:var(--font-mono);}

/* Watchlist rows */
.wllist{display:flex;flex-direction:column;gap:10px;}
.wlrow{display:grid;grid-template-columns:96px 1.6fr 120px 120px 150px 130px 40px;gap:16px;
  align-items:center;padding:14px;border:1px solid var(--line);border-radius:var(--r);
  background:var(--surface);transition:border-color .14s,transform .14s;}
.wlrow:hover{border-color:var(--line-soft);}
.wlrow .art{display:block;width:96px;height:45px;border-radius:6px;background-size:cover;
  background-position:center;background-color:var(--surface-3);}
.wlrow .gmeta{min-width:0;}
.wlrow .gmeta .nm{font-weight:700;font-size:14.5px;color:var(--tx);white-space:nowrap;
  overflow:hidden;text-overflow:ellipsis;}
.wlrow .gmeta .dev{margin-top:2px;font-size:12px;font-family:var(--font-mono);color:var(--tx-3);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.wlrow .col{display:flex;flex-direction:column;gap:4px;min-width:0;}
.wlrow .col .lab{font-size:10px;text-transform:uppercase;letter-spacing:.07em;
  font-family:var(--font-mono);color:var(--tx-3);}
.wlrow .col .val{font-family:var(--font-mono);font-variant-numeric:tabular-nums;
  font-feature-settings:"tnum" 1;font-size:14px;color:var(--tx);}
.wlrow .col.players .val{color:var(--buy);display:inline-flex;align-items:center;gap:6px;}
.wlrow .col.peak .val{color:var(--tx-2);}
.wlrow .price .now{font-family:var(--font-mono);font-variant-numeric:tabular-nums;
  font-size:16px;font-weight:700;color:var(--tx);}
.wlrow .price .now.free{color:var(--signal);}
.wlrow .price .sub{margin-top:2px;font-size:11px;color:var(--tx-3);}
.wlrow .price .sub .off{color:var(--wait);font-weight:600;}
.wlrow .rm{justify-self:end;width:30px;height:30px;border:1px solid var(--line);border-radius:8px;
  background:transparent;color:var(--tx-3);cursor:pointer;font-size:13px;line-height:1;transition:.14s;}
.wlrow .rm:hover{color:var(--wait);border-color:var(--wait);}

/* Live dot (CSS only — no fake number animation; scoped to watchlist rows to avoid the nav .live-dot) */
.wlrow .live-dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--buy);
  box-shadow:0 0 0 0 rgba(54,211,153,.55);}
@media(prefers-reduced-motion:no-preference){
  .wlrow .live-dot{animation:siq-pulse 2s infinite;}
}

/* Watchlist empty state */
.wlempty{border:1px dashed var(--line);border-radius:var(--r);background:var(--surface);
  text-align:center;padding:64px 30px;}
.wlempty .ic{font-size:34px;color:var(--tx-3);line-height:1;}

/* ============================================================
   Phase 8A — shared content classes (cards + article/legal prose)
   ============================================================ */
.card{border:1px solid var(--line);border-radius:var(--r);background:var(--surface);padding:18px;}
.card.tight{padding:14px;}
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px;}

/* Article / legal / blog prose — token-driven, theme-safe */
.legal{max-width:760px;margin:0 auto;color:var(--tx-2);font-size:15px;line-height:1.65;}
.legal h1{font-family:var(--font-display);font-weight:800;font-size:30px;color:var(--tx);margin:0 0 6px;}
.legal h2{font-family:var(--font-display);font-weight:700;font-size:21px;color:var(--tx);margin:30px 0 10px;}
.legal h3{font-weight:700;font-size:16px;color:var(--tx);margin:22px 0 8px;}
.legal p{margin:0 0 14px;}
.legal a{color:var(--signal);}
.legal ul,.legal ol{margin:0 0 14px;padding-left:22px;}
.legal li{margin:4px 0;}
.legal code{font-family:var(--font-mono);background:var(--surface-2);padding:1px 5px;border-radius:6px;font-size:13px;}
.legal .updated{font-family:var(--font-mono);font-size:12px;color:var(--tx-3);margin-bottom:24px;display:block;}
.legal hr{border:0;border-top:1px solid var(--line);margin:24px 0;}
.wlempty h3{margin:14px 0 8px;font-family:var(--font-display);font-weight:700;font-size:22px;color:var(--tx);}
.wlempty p{max-width:440px;margin:0 auto 18px;color:var(--tx-2);font-size:14px;line-height:1.55;}

/* Auth (no handoff design — built from tokens) */
.authwrap{max-width:1040px;margin:0 auto;padding:40px 28px;display:grid;
  grid-template-columns:1fr 1fr;gap:24px;align-items:start;}
.authcard{border:1px solid var(--line);border-radius:var(--r);background:var(--surface);padding:32px;}
.authcard h1{font-family:var(--font-display);font-weight:800;font-size:26px;margin:0 0 6px;color:var(--tx);}
.authcard .lead{color:var(--tx-2);font-size:14px;margin:0 0 22px;}
.field{margin-bottom:16px;}
.field label{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.08em;
  font-family:var(--font-mono);color:var(--tx-3);margin-bottom:6px;}
.field input[type=text],.field input[type=password],.field input[type=email]{width:100%;background:var(--surface-2);
  border:1px solid var(--line);border-radius:var(--r-sm);color:var(--tx);font-family:var(--font-ui);
  font-size:15px;padding:10px 12px;outline:none;transition:border-color .14s;}
.field input:focus{border-color:var(--signal);}
.field .help{margin-top:6px;font-size:12px;color:var(--tx-3);}
.field .err{margin-top:6px;font-size:12.5px;color:var(--wait);display:block;}
.field-check{display:flex;align-items:center;gap:8px;margin-bottom:18px;color:var(--tx-2);font-size:13px;}
.authcard .btn.primary{width:100%;justify-content:center;padding:11px 16px;font-size:14px;}
.authcard .altlink{margin-top:18px;font-size:13px;color:var(--tx-2);}
.authcard .altlink a{color:var(--signal);}
.auth-summary{color:var(--wait);font-size:13px;margin-bottom:14px;}
.authaside{border:1px solid var(--line);border-radius:var(--r);background:var(--surface);padding:28px;}
.authaside h2{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--tx);margin:0 0 14px;}
.authaside ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px;}
.authaside li{display:flex;gap:10px;color:var(--tx-2);font-size:13.5px;line-height:1.45;}
.authaside li::before{content:"→";color:var(--signal);}
.cmpcard{border:1px solid var(--line);border-radius:var(--r);background:var(--surface);transition:border-color .14s;}
.cmpcard:hover{border-color:var(--line-soft);}

/* Phase 7 responsive */
@media(max-width:900px){
  .wlrow{grid-template-columns:80px 1fr 40px;grid-template-areas:
    "art meta rm" "art players price" "art verdict peak";row-gap:8px;}
  .wlrow .art{grid-area:art;align-self:start;}
  .wlrow .gmeta{grid-area:meta;}
  .wlrow .col.players{grid-area:players;}
  .wlrow .col.peak{grid-area:peak;}
  .wlrow .col.verdict{grid-area:verdict;}
  .wlrow .price{grid-area:price;}
  .wlrow .rm{grid-area:rm;}
  .authwrap{grid-template-columns:1fr;}
  .authaside{display:none;}
}

/* ============================================================
   Phase 8A-Admin — admin shell + components
   ============================================================ */
/* Sidebar */
.adm-side{display:flex;flex-direction:column;gap:2px;padding:14px 10px;border-right:1px solid var(--line);background:var(--surface);min-height:100%;}
.adm-side .grp{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--tx-3);padding:12px 10px 4px;}
.adm-side a{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:var(--r-sm);color:var(--tx-2);font-size:13.5px;font-weight:500;text-decoration:none;transition:.12s;}
.adm-side a:hover{background:var(--surface-2);color:var(--tx);}
.adm-side a.on{background:var(--surface-3);color:var(--tx);}

/* Status badges (map by meaning) */
.badge.ok{background:var(--buy-dim);color:var(--buy);}
.badge.warn{background:var(--watch-dim);color:var(--watch);}
.badge.err{background:var(--wait-dim);color:var(--wait);}
.badge.muted{background:var(--surface-2);color:var(--tx-3);}

/* Progress bar */
.adm-bar{height:8px;border-radius:6px;background:var(--surface-2);overflow:hidden;}
.adm-bar > i{display:block;height:100%;background:var(--signal);border-radius:6px;}

/* Modal */
.adm-modal{position:fixed;inset:0;background:rgba(0,0,0,.55);display:flex;align-items:center;justify-content:center;z-index:60;padding:20px;}
.adm-modal-card{width:100%;max-width:480px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:24px;box-shadow:0 24px 60px rgba(0,0,0,.5);}
.adm-modal-card h3{font-family:var(--font-display);font-size:18px;color:var(--tx);margin:0 0 14px;}

/* Utility hidden — used by JS classList toggle */
.hidden{display:none!important;}

/* Stat tile (dashboard) */
.adm-stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;}
.adm-stat{border:1px solid var(--line);border-radius:var(--r);background:var(--surface);padding:16px;}
.adm-stat .v{font-size:24px;font-weight:700;color:var(--tx);}
.adm-stat .k{margin-top:5px;font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.07em;color:var(--tx-3);}

/* ====================================================================
   ENTITY INDEX (Phase 8) — Tags / Categories index card grids
   ==================================================================== */
.egrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:13px;}
.ecard{border:1px solid var(--line);border-radius:var(--r);background:var(--surface);padding:15px 16px;text-decoration:none;color:inherit;display:flex;flex-direction:column;gap:9px;transition:.15s;}
.ecard:hover{border-color:var(--tx-3);transform:translateY(-2px);}
.ecard.feat{border-color:var(--signal);}
.ecard .top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;}
.ecard .nm{font-weight:600;font-size:14px;color:var(--tx);display:flex;align-items:center;gap:6px;line-height:1.3;min-width:0;}
.ecard .ct{font-family:var(--font-mono);font-size:11.5px;color:var(--tx-3);white-space:nowrap;flex:none;}
.ecard .cat{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.04em;color:var(--tx-3);text-transform:uppercase;}
.ecard .rt{font-family:var(--font-mono);font-size:11.5px;font-weight:600;color:var(--watch);}
.ecard .bar{height:4px;border-radius:3px;background:var(--surface-3);overflow:hidden;}
.ecard .bar>i{display:block;height:100%;border-radius:3px;background:var(--signal);}
.epills{display:flex;flex-wrap:wrap;gap:8px;}
@media(max-width:560px){ .egrid{grid-template-columns:1fr 1fr;} }
@media(max-width:380px){ .egrid{grid-template-columns:1fr;} }

/* ============================================================
   Phase 8B — global reduced-motion guard
   Respect prefers-reduced-motion: reduce — neutralize animations
   and transitions site-wide without removing them for everyone else.
   ============================================================ */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.001ms !important;
    scroll-behavior:auto !important;
  }
}
