/* ============================================================
   TRADERMIND PRO — Complete Design System v2.0
   Light mode. Dark charts. WHOOP + Zerodha inspired.
   Built clean — never patch this file, edit variables only.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Syne:wght@600;700;800&family=Inter:wght@400;500;600&family=JetBrains+Mono:wght@400;500&display=swap');

/* ── 1. DESIGN TOKENS ─────────────────────────────────────── */
:root {
  --bg:        #F4F5F7;
  --bg-card:   #FFFFFF;
  --bg-input:  #F8F9FA;
  --bg-hover:  #F0F1F3;
  --sb-bg:     #FFFFFF;
  --bd:        #E8E8F0;
  --bd2:       #D4D4E4;
  --tx:        #0B0B14;
  --tx2:       #6B6B8A;
  --tx3:       #A0A0BC;
  --gold:      #F59E0B;
  --gold-lt:   #FEF3C7;
  --gold-dk:   #D97706;
  --green:     #10B981;
  --green-lt:  #D1FAE5;
  --red:       #EF4444;
  --red-lt:    #FEE2E2;
  --blue:      #3B82F6;
  --blue-lt:   #DBEAFE;
  --purple:    #8B5CF6;
  --purple-lt: #EDE9FE;
  --orange:    #F97316;
  --orange-lt: #FFEDD5;
  --c-game:    #EF4444;
  --c-lt:      #FEE2E2;
  --b-game:    #F59E0B;
  --b-lt:      #FEF3C7;
  --a-game:    #10B981;
  --a-lt:      #D1FAE5;
  --sans:      'Inter', -apple-system, sans-serif;
  --disp:      'Syne', sans-serif;
  --mono:      'JetBrains Mono', monospace;
  --r:         8px;
  --rl:        12px;
  --rxl:       16px;
  --sw:        228px;
  --topbar-h:  52px;
  --shadow-sm: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);
  --shadow:    0 4px 6px rgba(0,0,0,.05), 0 2px 4px rgba(0,0,0,.04);
  --shadow-lg: 0 10px 15px rgba(0,0,0,.08), 0 4px 6px rgba(0,0,0,.05);
  --t:         .15s ease;
}

/* ── 2. RESET ─────────────────────────────────────────────── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html, body { height:100%; overflow:hidden; }
body { font-family:var(--sans); font-size:13px; line-height:1.5; color:var(--tx); background:var(--bg); -webkit-font-smoothing:antialiased; }
button, input, select, textarea { font-family:var(--sans); font-size:13px; }
a { color:var(--blue); text-decoration:none; }
a:hover { text-decoration:underline; }
::-webkit-scrollbar { width:4px; height:4px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:var(--bd2); border-radius:4px; }
::-webkit-scrollbar-thumb:hover { background:var(--tx3); }

/* ── 3. AUTH PAGE ─────────────────────────────────────────── */
#auth { position:fixed; inset:0; background:var(--bg); display:flex; align-items:center; justify-content:center; z-index:1000; }
#auth.hide { display:none; }
.auth-wrap { width:400px; }
.auth-logo { display:flex; align-items:center; gap:10px; justify-content:center; margin-bottom:28px; }
.auth-mark { width:40px; height:40px; background:var(--gold); border-radius:10px; display:flex; align-items:center; justify-content:center; font-family:var(--disp); font-weight:800; font-size:16px; color:#fff; box-shadow:0 4px 12px rgba(245,158,11,.3); }
.auth-brand-name { font-family:var(--disp); font-size:20px; font-weight:800; letter-spacing:.03em; }
.auth-card { background:var(--bg-card); border:1px solid var(--bd); border-radius:var(--rxl); box-shadow:var(--shadow-lg); overflow:hidden; }
.auth-tabs { display:flex; border-bottom:1px solid var(--bd); }
.auth-tab { flex:1; padding:14px; background:transparent; border:none; color:var(--tx3); font-size:13px; font-weight:600; cursor:pointer; transition:var(--t); border-bottom:2px solid transparent; margin-bottom:-1px; }
.auth-tab:hover { color:var(--tx2); }
.auth-tab.on { color:var(--tx); border-bottom-color:var(--gold); }
.auth-body { padding:24px; }
.auth-msg { border-radius:var(--r); padding:10px 14px; font-size:12px; font-weight:500; margin-bottom:14px; display:none; }
.auth-msg.err { background:var(--red-lt); color:var(--red); border:1px solid rgba(239,68,68,.2); display:block; }
.auth-msg.ok  { background:var(--green-lt); color:var(--green); border:1px solid rgba(16,185,129,.2); display:block; }

/* ── 4. APP LAYOUT ────────────────────────────────────────── */
#app { display:none; height:100vh; }
#app.show { display:flex; }
.sb { width:var(--sw); background:var(--sb-bg); border-right:1px solid var(--bd); display:flex; flex-direction:column; flex-shrink:0; overflow-y:auto; overflow-x:hidden; }
.layout { flex:1; min-width:0; display:flex; flex-direction:column; overflow:hidden; }
.topbar { height:var(--topbar-h); padding:0 20px; display:flex; align-items:center; justify-content:space-between; gap:12px; background:var(--bg-card); border-bottom:1px solid var(--bd); flex-shrink:0; }
.topbar-title { font-family:var(--disp); font-size:16px; font-weight:700; letter-spacing:.02em; white-space:nowrap; }
#tbr { display:flex; align-items:center; gap:8px; }
#pg { flex:1; overflow-y:auto; padding:20px; }

/* ── 5. SIDEBAR ───────────────────────────────────────────── */
.sb-brand { padding:16px 14px 10px; display:flex; align-items:center; gap:9px; border-bottom:1px solid var(--bd); }
.sb-mark { width:28px; height:28px; background:var(--gold); border-radius:7px; display:flex; align-items:center; justify-content:center; font-family:var(--disp); font-weight:800; font-size:12px; color:#fff; flex-shrink:0; }
.sb-brand-name { font-family:var(--disp); font-size:13px; font-weight:800; letter-spacing:.04em; }
.sb-user { margin:10px 10px 6px; background:var(--bg); border:1px solid var(--bd); border-radius:var(--rl); padding:10px 12px; }
.sb-user-top { display:flex; align-items:center; gap:9px; margin-bottom:8px; }
.sb-av { width:32px; height:32px; border-radius:50%; background:linear-gradient(135deg,var(--gold),var(--purple)); display:flex; align-items:center; justify-content:center; font-weight:700; font-size:12px; color:#fff; flex-shrink:0; }
.sb-uname { font-size:12px; font-weight:600; }
.sb-role { font-size:10px; color:var(--tx3); margin-top:1px; }
.sb-xpbar { height:3px; background:var(--bd); border-radius:2px; overflow:hidden; }
.sb-xpfill { height:100%; background:linear-gradient(90deg,var(--gold),var(--green)); border-radius:2px; transition:width .8s ease; }
.sb-mg { display:flex; gap:5px; margin-top:7px; align-items:center; }
.sb-mg-pill { display:inline-flex; align-items:center; gap:3px; padding:1px 7px; border-radius:20px; font-size:10px; font-weight:700; }
.sb-mg-c { background:var(--c-lt); color:var(--c-game); }
.sb-mg-b { background:var(--b-lt); color:var(--b-game); }
.sb-mg-a { background:var(--a-lt); color:var(--a-game); }
.sb-sec { display:block; padding:10px 14px 3px; font-size:9px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--tx3); }
.ni { width:100%; background:transparent; border:none; color:var(--tx2); padding:7px 10px; border-radius:var(--r); cursor:pointer; display:flex; align-items:center; gap:9px; font-size:12px; font-weight:500; text-align:left; transition:var(--t); margin-bottom:1px; position:relative; }
.ni:hover { background:var(--bg-hover); color:var(--tx); }
.ni.on { background:var(--gold-lt); color:var(--gold-dk); font-weight:600; }
.ni.on::before { content:''; position:absolute; left:0; top:50%; transform:translateY(-50%); width:3px; height:55%; background:var(--gold); border-radius:0 2px 2px 0; }
.ni svg { width:14px; height:14px; flex-shrink:0; stroke:currentColor; fill:none; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }
.sb-bot { margin-top:auto; padding:8px 10px 12px; border-top:1px solid var(--bd); }

/* ── 6. CARDS ─────────────────────────────────────────────── */
.card { background:var(--bg-card); border:1px solid var(--bd); border-radius:var(--rl); box-shadow:var(--shadow-sm); margin-bottom:16px; }
.card-body { padding:16px 18px; }
.card-header { padding:14px 18px; display:flex; align-items:center; justify-content:space-between; border-bottom:1px solid var(--bd); }
.card-title { font-family:var(--disp); font-size:13px; font-weight:700; letter-spacing:.03em; }
.stat-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; margin-bottom:16px; }
.stat-card { background:var(--bg-card); border:1px solid var(--bd); border-radius:var(--rl); padding:14px 16px; box-shadow:var(--shadow-sm); }
.stat-label { font-size:10px; font-weight:600; text-transform:uppercase; letter-spacing:.08em; color:var(--tx3); margin-bottom:7px; }
.stat-value { font-family:var(--disp); font-size:22px; font-weight:700; line-height:1; }
.stat-sub { font-size:11px; color:var(--tx3); margin-top:5px; }
.stat-card.up .stat-value { color:var(--green); }
.stat-card.dn .stat-value { color:var(--red); }
.stat-card.gold .stat-value { color:var(--gold-dk); }
.stat-card.blue .stat-value { color:var(--blue); }

/* ── 7. READINESS + XP ────────────────────────────────────── */
.readiness-card { background:var(--bg-card); border:1px solid var(--bd); border-radius:var(--rl); box-shadow:var(--shadow-sm); padding:18px 20px; margin-bottom:16px; position:relative; overflow:hidden; }
.readiness-card::before { content:''; position:absolute; top:0; left:0; width:4px; height:100%; border-radius:var(--rl) 0 0 var(--rl); }
.readiness-card.border-green::before { background:var(--green); }
.readiness-card.border-gold::before  { background:var(--gold); }
.readiness-card.border-orange::before{ background:var(--orange); }
.readiness-card.border-red::before   { background:var(--red); }
.readiness-score { font-family:var(--disp); font-size:48px; font-weight:800; line-height:1; }
.readiness-label { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.1em; margin-top:4px; }
.xp-bar { height:5px; background:var(--bg); border-radius:3px; overflow:hidden; margin-top:10px; }
.xp-fill { height:100%; border-radius:3px; background:linear-gradient(90deg,var(--gold),var(--green)); transition:width .8s ease; }
.xp-label { font-size:10px; color:var(--tx3); margin-top:5px; }
@keyframes xpPop { 0%{opacity:0;transform:translateY(0) scale(.8)} 40%{opacity:1;transform:translateY(-20px) scale(1)} 100%{opacity:0;transform:translateY(-40px) scale(.9)} }
.xp-popup { position:fixed; bottom:70px; right:20px; background:var(--gold); color:#fff; font-family:var(--disp); font-size:14px; font-weight:800; padding:6px 14px; border-radius:20px; animation:xpPop 1.5s forwards; z-index:9999; pointer-events:none; box-shadow:0 4px 12px rgba(245,158,11,.4); }

/* ── 8. MENTAL GAME ───────────────────────────────────────── */
.mg-board { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-bottom:16px; }
.mg-col { background:var(--bg-card); border:1px solid var(--bd); border-radius:var(--rl); overflow:hidden; box-shadow:var(--shadow-sm); }
.mg-col-header { padding:12px 14px; display:flex; align-items:center; gap:8px; border-bottom:1px solid var(--bd); }
.mg-col-dot { width:8px; height:8px; border-radius:50%; flex-shrink:0; }
.mg-col-title { font-family:var(--disp); font-size:12px; font-weight:700; letter-spacing:.05em; }
.mg-col-count { margin-left:auto; font-size:10px; font-weight:700; background:var(--bg); color:var(--tx3); padding:1px 7px; border-radius:20px; }
.mg-col-body { padding:10px; }
.mg-item { background:var(--bg); border:1px solid var(--bd); border-radius:var(--r); padding:10px 12px; margin-bottom:7px; transition:var(--t); }
.mg-item:hover { border-color:var(--bd2); box-shadow:var(--shadow-sm); }
.mg-item-name { font-size:12px; font-weight:600; margin-bottom:2px; }
.mg-item-sub { font-size:11px; color:var(--tx3); }
.mg-item-cost { font-size:11px; color:var(--red); font-weight:600; margin-top:3px; }
.mg-item-actions { display:flex; gap:5px; margin-top:8px; flex-wrap:wrap; }
.mg-btn { border:none; border-radius:5px; padding:3px 9px; font-size:10px; font-weight:600; cursor:pointer; transition:var(--t); font-family:var(--sans); }
.mg-btn-up  { background:var(--a-lt); color:var(--a-game); }
.mg-btn-dn  { background:var(--c-lt); color:var(--c-game); }
.mg-btn-del { background:var(--bg); color:var(--tx3); border:1px solid var(--bd); }
.mg-btn-up:hover  { background:var(--green); color:#fff; }
.mg-btn-del:hover { background:var(--red-lt); color:var(--red); }
.mg-add { width:100%; background:transparent; border:1px dashed var(--bd2); border-radius:var(--r); padding:8px; font-size:11px; color:var(--tx3); cursor:pointer; transition:var(--t); font-family:var(--sans); text-align:center; }
.mg-add:hover { border-color:var(--gold); color:var(--gold-dk); }
.game-c { background:var(--c-lt); color:var(--c-game); border:1px solid rgba(239,68,68,.2); font-size:11px; font-weight:700; padding:2px 8px; border-radius:5px; display:inline-block; }
.game-b { background:var(--b-lt); color:var(--b-game); border:1px solid rgba(245,158,11,.2); font-size:11px; font-weight:700; padding:2px 8px; border-radius:5px; display:inline-block; }
.game-a { background:var(--a-lt); color:var(--a-game); border:1px solid rgba(16,185,129,.2); font-size:11px; font-weight:700; padding:2px 8px; border-radius:5px; display:inline-block; }
.game-rate-btn { flex:1; padding:10px; border:2px solid var(--bd2); border-radius:var(--r); background:transparent; cursor:pointer; font-family:var(--disp); font-size:14px; font-weight:800; color:var(--tx3); transition:var(--t); }
.game-rate-btn.c-sel { border-color:var(--c-game); background:var(--c-lt); color:var(--c-game); }
.game-rate-btn.b-sel { border-color:var(--b-game); background:var(--b-lt); color:var(--b-game); }
.game-rate-btn.a-sel { border-color:var(--a-game); background:var(--a-lt); color:var(--a-game); }

/* ── 9. TABLES ────────────────────────────────────────────── */
.tw { overflow-x:auto; }
table { width:100%; border-collapse:collapse; font-size:12px; }
th { text-align:left; padding:9px 12px; font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.07em; color:var(--tx3); background:var(--bg); border-bottom:1px solid var(--bd); white-space:nowrap; }
td { padding:10px 12px; border-bottom:1px solid var(--bd); color:var(--tx2); vertical-align:middle; }
tr:last-child td { border-bottom:none; }
tr:hover td { background:var(--bg-hover); }

/* ── 10. BADGES ───────────────────────────────────────────── */
.bx { display:inline-flex; align-items:center; padding:2px 8px; border-radius:5px; font-size:10px; font-weight:700; letter-spacing:.04em; white-space:nowrap; }
.blong   { background:var(--green-lt); color:var(--green); }
.bshort  { background:var(--red-lt);   color:var(--red); }
.bwin    { background:var(--green-lt); color:var(--green); }
.bloss   { background:var(--red-lt);   color:var(--red); }
.bneu    { background:var(--bg); color:var(--tx3); border:1px solid var(--bd); }
.bgold   { background:var(--gold-lt);  color:var(--gold-dk); }
.bblue   { background:var(--blue-lt);  color:var(--blue); }
.bpurple { background:var(--purple-lt);color:var(--purple); }

/* ── 11. BUTTONS ──────────────────────────────────────────── */
.btn { border:none; border-radius:var(--r); padding:8px 14px; font-size:12px; font-weight:600; cursor:pointer; transition:var(--t); font-family:var(--sans); display:inline-flex; align-items:center; gap:6px; white-space:nowrap; }
.btn-p { background:var(--gold); color:#fff; }
.btn-p:hover { background:var(--gold-dk); }
.btn-s { background:var(--bg); color:var(--tx2); border:1px solid var(--bd2); }
.btn-s:hover { background:var(--bg-hover); color:var(--tx); }
.btn-d { background:var(--red-lt); color:var(--red); border:1px solid rgba(239,68,68,.2); }
.btn-d:hover { background:var(--red); color:#fff; }
.btn-sm { padding:5px 10px; font-size:11px; }
.btn-full { width:100%; justify-content:center; }
.btn:disabled { opacity:.5; cursor:not-allowed; }

/* ── 12. FORMS ────────────────────────────────────────────── */
.fg { margin-bottom:13px; }
.fl { display:block; font-size:11px; font-weight:600; color:var(--tx2); margin-bottom:5px; letter-spacing:.02em; }
.fi { width:100%; background:var(--bg-input); border:1px solid var(--bd2); border-radius:var(--r); padding:9px 12px; font-size:13px; color:var(--tx); transition:var(--t); }
.fi:focus { outline:none; border-color:var(--gold); box-shadow:0 0 0 3px rgba(245,158,11,.1); }
.fi::placeholder { color:var(--tx3); }
select.fi { cursor:pointer; }
textarea.fi { resize:vertical; min-height:80px; line-height:1.5; }
.fi-group { display:grid; gap:12px; }
.fi-group.cols-2 { grid-template-columns:1fr 1fr; }
.fi-group.cols-3 { grid-template-columns:repeat(3,1fr); }
.fi-group.cols-4 { grid-template-columns:repeat(4,1fr); }
.score-slider { display:flex; gap:4px; }
.score-btn { flex:1; padding:8px 4px; border:1px solid var(--bd2); border-radius:var(--r); background:var(--bg-input); color:var(--tx3); font-size:11px; font-weight:700; cursor:pointer; transition:var(--t); text-align:center; }
.score-btn.sel { background:var(--gold); color:#fff; border-color:var(--gold); }

/* ── 13. MODALS ───────────────────────────────────────────── */
.overlay { position:fixed; inset:0; background:rgba(0,0,0,.4); z-index:200; display:flex; align-items:center; justify-content:center; backdrop-filter:blur(3px); padding:20px; }
.modal { background:var(--bg-card); border:1px solid var(--bd); border-radius:var(--rxl); box-shadow:var(--shadow-lg); width:100%; max-width:480px; max-height:90vh; overflow-y:auto; }
.modal-wide { max-width:680px; }
.modal-header { padding:18px 20px 14px; border-bottom:1px solid var(--bd); display:flex; align-items:center; justify-content:space-between; }
.modal-title { font-family:var(--disp); font-size:15px; font-weight:800; }
.modal-close { width:28px; height:28px; border:none; border-radius:6px; background:var(--bg); color:var(--tx3); cursor:pointer; font-size:18px; display:flex; align-items:center; justify-content:center; transition:var(--t); }
.modal-close:hover { background:var(--red-lt); color:var(--red); }
.modal-body { padding:18px 20px; }
.modal-footer { padding:14px 20px; border-top:1px solid var(--bd); display:flex; gap:8px; justify-content:flex-end; }

/* ── 14. ALERTS ───────────────────────────────────────────── */
.alert { border-radius:var(--r); padding:11px 14px; font-size:12px; line-height:1.5; margin-bottom:12px; }
.alert-in   { background:var(--bg); border:1px solid var(--bd); }
.alert-ok   { background:var(--green-lt); border:1px solid rgba(16,185,129,.2); color:var(--green); }
.alert-warn { background:var(--gold-lt); border:1px solid rgba(245,158,11,.2); color:var(--gold-dk); }
.alert-err  { background:var(--red-lt); border:1px solid rgba(239,68,68,.2); color:var(--red); }
.alert-info { background:var(--blue-lt); border:1px solid rgba(59,130,246,.2); color:var(--blue); }

/* ── 15. CHARTS (DARK MODE ONLY) ─────────────────────────── */
.chart-wrap { background:#0B0B14; border-radius:var(--rl); overflow:hidden; border:1px solid var(--bd); }
.chart-topbar { background:#0f0f1a; padding:10px 14px; display:flex; align-items:center; gap:10px; border-bottom:1px solid #1a1a2e; flex-wrap:wrap; }
.chart-symbol { font-family:var(--mono); font-size:13px; font-weight:600; color:#f0f0ff; }
.chart-price  { font-family:var(--mono); font-size:18px; font-weight:700; color:#f0f0ff; }
.chart-up   { color:#10B981; font-size:12px; }
.chart-down { color:#EF4444; font-size:12px; }
.chart-tf { padding:3px 8px; border-radius:5px; border:none; cursor:pointer; font-size:11px; font-weight:600; background:transparent; color:#6060a0; transition:var(--t); }
.chart-tf.on { background:#1a1a2e; color:#f0f0ff; }
.chart-tf:hover { color:#f0f0ff; }
.depth-table { width:100%; border-collapse:collapse; font-size:11px; }
.depth-table th { padding:6px 8px; color:#6060a0; font-weight:600; font-size:10px; background:#0f0f1a; border-bottom:1px solid #1a1a2e; }
.depth-table td { padding:4px 8px; color:#c0c0e0; border-bottom:1px solid #0f0f1a; font-family:var(--mono); }
.depth-bid { color:#10B981; font-weight:600; }
.depth-ask { color:#EF4444; font-weight:600; }

/* ── 16. WHOOP ────────────────────────────────────────────── */
.whoop-card { background:var(--bg-card); border:1px solid var(--bd); border-radius:var(--rl); padding:16px 18px; box-shadow:var(--shadow-sm); }
.whoop-row { display:flex; align-items:center; justify-content:space-between; padding:7px 0; border-bottom:1px solid var(--bd); }
.whoop-row:last-child { border-bottom:none; }
.whoop-label { font-size:12px; color:var(--tx2); font-weight:500; }
.whoop-val { font-family:var(--mono); font-size:13px; font-weight:600; }
.whoop-bar-wrap { display:flex; align-items:center; gap:8px; }
.whoop-bar-track { width:80px; height:4px; background:var(--bd); border-radius:2px; overflow:hidden; }
.whoop-bar-fill { height:100%; border-radius:2px; }

/* ── 17. UTILITIES ────────────────────────────────────────── */
.flex   { display:flex; }
.flex-col { display:flex; flex-direction:column; }
.items-center { align-items:center; }
.justify-between { justify-content:space-between; }
.gap4  { gap:4px; } .gap6 { gap:6px; } .gap8 { gap:8px; } .gap12 { gap:12px; } .gap16 { gap:16px; }
.grid2 { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.grid3 { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.grid4 { display:grid; grid-template-columns:repeat(4,1fr); gap:10px; }
.mb4 { margin-bottom:4px; } .mb8 { margin-bottom:8px; } .mb12 { margin-bottom:12px; } .mb16 { margin-bottom:16px; } .mb20 { margin-bottom:20px; }
.mt4 { margin-top:4px; } .mt8 { margin-top:8px; } .mt12 { margin-top:12px; }
.w100 { width:100%; }
.bold { font-weight:600; } .bolder { font-weight:700; }
.xs { font-size:11px; } .sm { font-size:12px; }
.mono { font-family:var(--mono); } .disp { font-family:var(--disp); }
.c-tx2 { color:var(--tx2); } .c-tx3 { color:var(--tx3); }
.c-green  { color:var(--green); }  .c-red  { color:var(--red); }
.c-gold   { color:var(--gold-dk); } .c-blue { color:var(--blue); }
.center { text-align:center; }
.nowrap { white-space:nowrap; }
.ellipsis { overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.empty { text-align:center; padding:40px 20px; color:var(--tx3); font-size:12px; }
.divider { height:1px; background:var(--bd); margin:12px 0; }

/* ── 18. RESPONSIVE ───────────────────────────────────────── */
@media (max-width:1200px) {
  .stat-grid { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:1024px) {
  :root { --sw:200px; }
  .mg-board { grid-template-columns:1fr; }
}
@media (max-width:768px) {
  :root { --sw:0px; }
  .sb { display:none; }
  #pg { padding:14px; }
  .stat-grid { grid-template-columns:repeat(2,1fr); }
  .fi-group.cols-4 { grid-template-columns:repeat(2,1fr); }
}

/* ── MOBILE BOTTOM NAV ──────────────────────────────────── */
.mobile-nav {
  display: none;
  position: fixed;
  position: -webkit-sticky;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 100;
  background: var(--bg-card);
  border-top: 1px solid var(--bd);
  padding: 8px 0 8px;
  padding-bottom: calc(8px + env(safe-area-inset-bottom));
  -webkit-padding-after: calc(8px + env(safe-area-inset-bottom));
  box-shadow: 0 -4px 20px rgba(0,0,0,.08);
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
}

.mobile-nav-items {
  display: flex;
  justify-content: space-around;
  align-items: center;
}

.mni {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3px;
  padding: 6px 10px;
  border: none;
  background: none;
  cursor: pointer;
  color: var(--tx3);
  font-size: 9px;
  font-family: var(--sans);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .04em;
  transition: var(--t);
  border-radius: 8px;
  min-width: 52px;
}

.mni svg {
  width: 20px;
  height: 20px;
  stroke: currentColor;
  stroke-width: 1.8;
  fill: none;
}

.mni.active {
  color: var(--gold);
}

.mni.active svg {
  stroke: var(--gold);
}

/* More menu overlay */
.mobile-more {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 99;
  background: var(--bg-card);
  border-top: 1px solid var(--bd);
  border-radius: 20px 20px 0 0;
  padding: 16px 16px 80px;
  padding-bottom: calc(80px + env(safe-area-inset-bottom));
  box-shadow: 0 -8px 30px rgba(0,0,0,.15);
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  max-height: 85vh;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

.mobile-more.open {
  display: block;
}

.mobile-more-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
}

.mobile-more-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: 12px 8px;
  border: 1px solid var(--bd);
  border-radius: var(--r);
  background: var(--bg);
  cursor: pointer;
  font-size: 10px;
  color: var(--tx2);
  font-weight: 600;
  text-align: center;
  transition: var(--t);
}

.mobile-more-item svg {
  width: 20px;
  height: 20px;
  stroke: currentColor;
  stroke-width: 1.8;
  fill: none;
  color: var(--tx3);
}

.mobile-more-item:active {
  background: var(--bg-hover);
}

.mobile-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.4);
  z-index: 98;
}

.mobile-overlay.open {
  display: block;
}

/* Add bottom padding on mobile so content doesn't hide behind nav */
@media (max-width: 768px) {
  .mobile-nav { display: block !important; }
  #pg {
    padding-bottom: 80px !important;
    padding-bottom: calc(80px + env(safe-area-inset-bottom)) !important;
  }
}
