*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--ink:#1a1a1a;--ink2:#4a4a4a;--ink3:#8a8a8a;--bg:#faf8f5;--surf:#f2efe9;--surf2:#e8e4dc;--line:rgba(26,26,26,.12);--line2:rgba(26,26,26,.22);--green:#1a6b47;--gbg:#edf7f2;--red:#b53a2a;--rbg:#fdf0ee;--amber:#7a5c00;--abg:#fdf8ee;--blue:#1a4a8a;--bbg:#eef3fc;--r:4px;--rl:8px}
@media(prefers-color-scheme:dark){:root{--ink:#e8e4dc;--ink2:#b4b0a8;--ink3:#6a6660;--bg:#1a1916;--surf:#232220;--surf2:#2e2c28;--line:rgba(232,228,220,.1);--line2:rgba(232,228,220,.2);--green:#4aad7a;--gbg:#0d2a1e;--red:#e06b58;--rbg:#2a0f0a;--amber:#c9a44a;--abg:#2a2008;--blue:#4a8adf;--bbg:#0d1a2e}}
html,body{height:100%;background:var(--bg);color:var(--ink);font-family:'DM Sans',sans-serif}

/* ── SPLASH ── */
#splash{position:fixed;inset:0;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:flex-start;z-index:100;padding:2.5rem 1.5rem 3rem;text-align:center;overflow-y:auto;-webkit-overflow-scrolling:touch}
@media(min-height:800px) and (min-width:720px){#splash{justify-content:center}}
#splash.gone{display:none}
.scoin{font-size:64px;margin-bottom:1.5rem;animation:bob 2s ease-in-out infinite;display:inline-block}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.seye{font-family:'DM Mono',monospace;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink2);margin-bottom:.75rem;font-weight:500}
.stit{font-family:'Playfair Display',serif;font-size:56px;font-weight:900;line-height:1.05;letter-spacing:-.5px;margin-bottom:.5rem}
.stit em{font-style:italic;color:var(--green)}
.ssub{font-family:'DM Mono',monospace;font-size:15px;color:var(--ink2);margin-bottom:.75rem;letter-spacing:.04em;font-weight:500}
.sapi{font-family:'DM Mono',monospace;font-size:11px;color:var(--green);margin-bottom:2rem;background:var(--gbg);border:1px solid rgba(26,107,71,.2);border-radius:var(--r);padding:7px 16px;display:inline-block;font-weight:500}
.sbtns{display:flex;flex-direction:column;gap:10px;width:100%;max-width:420px}
.sbtn{font-family:'DM Sans',sans-serif;font-size:15px;font-weight:500;padding:14px 24px;border-radius:var(--r);cursor:pointer;transition:all .15s;border:1px solid var(--line2);background:transparent;color:var(--ink);min-height:48px}
.sbtn:hover{background:var(--surf)}.sbtn:active{transform:scale(.98)}
.sbtn.p{background:var(--ink);color:var(--bg);border-color:var(--ink);font-size:16px;font-weight:600}.sbtn.p:hover{opacity:.88}
.sbtn.d{border-color:var(--red);color:var(--red)}.sbtn.d:hover{background:var(--rbg)}
.sdiv{width:40px;height:1px;background:var(--line2);margin:.25rem auto}

@media(min-width:1400px){
  .scoin{font-size:76px}
  .seye{font-size:14px}
  .stit{font-size:70px}
  .ssub{font-size:17px}
  .sapi{font-size:12px;padding:8px 18px}
  .sbtns{max-width:480px}
  .sbtn{font-size:16px;padding:15px 28px}
  .sbtn.p{font-size:17px}
}

@media(max-width:500px){
  #splash{padding:1.75rem 1rem 2.5rem}
  .scoin{font-size:44px;margin-bottom:.75rem}
  .seye{font-size:10px;margin-bottom:.5rem}
  .stit{font-size:34px;margin-bottom:.35rem}
  .ssub{font-size:12px;margin-bottom:.5rem}
  .sapi{font-size:9px;margin-bottom:1.25rem;padding:5px 12px}
  .mode-pick-label{font-size:10px;margin:.5rem 0 .6rem}
  .mode-pick{gap:8px;margin-bottom:1.25rem}
  .mode-head{padding:12px 12px;gap:10px}
  .mode-ico{font-size:26px}
  .mode-name{font-size:18px}
  .mode-meta{font-size:10px}
  .mode-toggle{width:28px;height:28px;font-size:16px}
  .mode-desc-full{font-size:13px;margin:10px 0 12px}
  .mode-features li{font-size:10px}
  .mode-start{font-size:13px;padding:11px 16px}
  #auth-area{margin-bottom:1rem}
  .sbtns{gap:7px}
  .sbtn{padding:11px 20px;font-size:14px;min-height:42px}
  .sbtn.p{font-size:15px}
  .sdiv{margin:.15rem auto}
}

/* ── HELP MODAL ── */
#help{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:300;display:none;align-items:center;justify-content:center;padding:1.5rem}
#help.on{display:flex}
.hbox{background:var(--bg);border:1px solid var(--line2);border-radius:var(--rl);padding:2rem;max-width:440px;width:100%;max-height:85vh;overflow-y:auto}
.hbox h2{font-family:'Playfair Display',serif;font-size:22px;font-weight:700;margin-bottom:1.5rem}
.hs{margin-bottom:1.25rem}.hs h3{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:.15em;text-transform:uppercase;color:var(--ink3);margin-bottom:.5rem}
.hs p,.hs ul{font-size:13px;color:var(--ink2);line-height:1.65}.hs ul{padding-left:1.25rem;line-height:1.9}
.hcl{font-family:'DM Mono',monospace;font-size:11px;padding:9px 22px;border:1px solid var(--line2);border-radius:var(--r);background:transparent;cursor:pointer;color:var(--ink);margin-top:.75rem}
.hcl:hover{background:var(--surf)}

/* ── HAMBURGER / DRAWER ── */
#hbg{position:fixed;top:14px;left:14px;z-index:250;width:38px;height:38px;border:1px solid var(--line2);border-radius:var(--r);background:var(--bg);cursor:pointer;display:none;flex-direction:column;align-items:center;justify-content:center;gap:5px;transition:background .12s}
#hbg:hover{background:var(--surf)}
#hbg span{display:block;width:16px;height:1.5px;background:var(--ink);border-radius:1px;transition:all .2s}
#hbg.on span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
#hbg.on span:nth-child(2){opacity:0}
#hbg.on span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
#drw{position:fixed;top:0;left:0;height:100%;width:260px;background:var(--bg);border-right:1px solid var(--line2);z-index:240;transform:translateX(-100%);transition:transform .25s ease;padding-top:64px;display:flex;flex-direction:column}
#drw.on{transform:translateX(0)}
#dbk{position:fixed;inset:0;z-index:230;display:none}
#dbk.on{display:block}
.dl{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink3);padding:.6rem 1.1rem .3rem;display:block}
.di{display:flex;align-items:center;gap:10px;padding:10px 1.1rem;font-size:13px;font-weight:500;cursor:pointer;transition:background .1s;border:none;background:transparent;color:var(--ink);width:100%;text-align:left;font-family:'DM Sans',sans-serif}
.di:hover{background:var(--surf)}.di .ico{font-size:15px;width:20px;text-align:center}
.di.rd{color:var(--red)}.di.rd:hover{background:var(--rbg)}
.ddv{border:none;border-top:1px solid var(--line);margin:.3rem 0}
#snote{font-family:'DM Mono',monospace;font-size:9px;color:var(--ink3);padding:.25rem 1.1rem .8rem;line-height:1.6;white-space:pre-line}
.drw-footer{margin-top:auto;border-top:1px solid var(--line);padding:1rem 1.1rem;display:flex;flex-direction:column;gap:5px}
.drw-vname{font-family:'DM Mono',monospace;font-size:12px;font-weight:500;color:var(--ink);letter-spacing:.02em}
.drw-vmeta{font-family:'DM Mono',monospace;font-size:9px;color:var(--ink3);line-height:1.55}
.drw-vbadge{display:inline-flex;align-items:center;gap:5px;font-family:'DM Mono',monospace;font-size:9px;color:var(--green);background:var(--gbg);border:1px solid rgba(26,107,71,.2);border-radius:3px;padding:3px 8px;margin-top:3px;width:fit-content}

/* ── GAME SHELL ── */
#game{display:none}
.shell{max-width:1080px;margin:0 auto;padding:1.5rem 2rem 4rem}

/* ── TABLET (600-899px) ── */
@media(max-width:899px){
  .shell{padding:1rem 1rem 3rem}
  .sts .scv{font-size:14px}
}

/* ── MOBILE (max 600px) ── */
@media(max-width:600px){
  html,body{-webkit-text-size-adjust:100%}
  body{padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}
  .shell{padding:.75rem .6rem calc(2.5rem + env(safe-area-inset-bottom))}

  /* Header */
  .mhd{flex-direction:column;gap:.4rem;padding-bottom:.75rem;margin-bottom:1rem}
  .ml{padding-left:44px}
  .mr{text-align:left;padding-left:44px;display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}
  .mcl{display:none}
  .mcv{font-size:18px}
  .mti{margin-top:0}
  .mtit{font-size:22px}
  .mbadge{font-size:7px;padding:1px 6px}

  /* Stats cards — 3 columns still but compact */
  .sts{grid-template-columns:repeat(3,1fr);margin-bottom:1rem}
  .sc{padding:8px 10px}
  .scv{font-size:12px}
  .scl{font-size:7px;letter-spacing:.08em}

  /* Tabs — horizontally scrollable if cramped */
  .tabs{overflow-x:auto;overflow-y:hidden;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .tabs::-webkit-scrollbar{display:none}
  .tabs .tb{padding:8px 12px 10px;font-size:12px;flex-shrink:0;min-height:40px}

  /* Market assets — data-rad oppe, knapper i egen rad under */
  .arow{
    grid-template-columns:28px minmax(0,1fr) 50px auto;
    grid-template-rows:auto auto;
    column-gap:8px;
    row-gap:8px;
    padding:14px 12px 12px;
    align-items:center;
  }
  .aic{grid-column:1;grid-row:1;width:28px;height:28px;font-size:14px}
  .anw{grid-column:2;grid-row:1;min-width:0;padding-right:4px}
  .anw > div:first-child{overflow-wrap:break-word;word-break:normal;line-height:1.25}
  .anm{font-size:12px;display:inline}
  .amet{font-size:9px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:2px}
  .minichart{grid-column:3;grid-row:1;display:block;width:50px;height:26px}
  .apc{grid-column:4;grid-row:1;text-align:right;min-width:0;padding-left:4px}
  .apr{font-size:12px;white-space:nowrap}
  .acg{font-size:9px;margin-top:1px;white-space:nowrap}
  /* Knapper i egen rad under data — fyller hele bredden, jevnt fordelt */
  .abts{grid-column:1/-1;grid-row:2;display:flex;flex-direction:row;gap:6px;margin-top:4px}
  .abts .btn{flex:1 1 0;padding:9px 4px;font-size:11px;min-height:38px;text-align:center;white-space:nowrap;line-height:1}

  /* Portfolio rows — name/ticker on top line, % and value side by side */
  .ph-row{grid-template-columns:32px 1fr auto;gap:8px;padding:10px 10px;row-gap:4px}
  .ph-ico{width:32px;font-size:18px}
  .ph-name{font-size:12px}
  .ph-tk{font-size:9px}
  .ph-pct{font-size:16px;min-width:0;grid-row:1;grid-column:3;text-align:right}
  .ph-val{min-width:0;grid-row:2;grid-column:2/4;text-align:right}
  .ph-val-main{font-size:13px}
  .ph-val-sub{font-size:8px}

  /* Portfolio detail dropdown */
  .ph-detail-grid{grid-template-columns:repeat(2,1fr)}
  .ph-detail-cell{padding:7px 9px}
  .ph-detail-val{font-size:11px}
  .ph-chart-wrap canvas{height:180px}
  .ph-actions{flex-direction:column;gap:6px}
  .ph-actions .btn{width:100%;min-height:42px;font-size:12px}

  /* Portfolio toolbar stacks */
  .port-toolbar{flex-direction:column;align-items:stretch;gap:8px}
  .port-sort-wrap{justify-content:space-between}
  .port-sort{flex:1;min-height:38px}
  .port-toolbar .sall{width:100%;min-height:40px}

  /* Trade modal */
  #tradeov{padding:.5rem;align-items:flex-start}
  .tbox{padding:1rem;max-height:calc(100vh - 1rem);overflow-y:auto;margin-top:.5rem}
  .tprice{font-size:17px;padding:8px}
  .tfl input{padding:12px;font-size:16px;min-height:44px} /* 16px prevents iOS zoom */
  .tact{flex-wrap:wrap;gap:6px}
  .tact .btn{padding:12px;font-size:12px;min-height:44px;flex:1 1 calc(50% - 3px)}
  .tpcts .ghost{min-height:36px;padding:8px}
  #TC{height:170px !important}
  .t-chart-stats{grid-template-columns:repeat(2,1fr)}

  /* Help / leaderboard / savepicker modals */
  .hbox{padding:1.25rem;max-height:calc(100vh - 1rem);margin-top:.5rem}
  .hbox h2{font-size:18px;margin-bottom:1rem}

  /* Auth forms on splash */
  #auth-area{max-width:100%;padding:0 4px}
  .auth-form input{font-size:16px;min-height:44px}

  /* Drawer — wider on mobile for easier tapping */
  #drw{width:85vw;max-width:300px}
  .di{min-height:44px;font-size:14px}

  /* Collapsible group toggles — larger tap area */
  .slab.grp-toggle{min-height:40px;padding:10px 12px}
  .slab{font-size:9px}

  /* Allocation bars */
  .alrow{gap:6px;margin-bottom:5px}
  .all{width:44px;font-size:8px}
  .alp{width:34px;font-size:8px}

  /* News / tips rows */
  .tipr{grid-template-columns:28px 1fr auto;gap:8px;padding:10px 12px}
  .tipr > :last-child{grid-column:1/-1;display:flex;justify-content:flex-end;margin-left:0}
  .newsi{padding:10px 12px}

  /* Stats chart height */
  #stats-chart{height:140px}
  .stat-card{padding:9px 11px}
  .stat-cv{font-size:12px}
  .ret-card{padding:8px 10px}
  .ret-val{font-size:12px}

  /* Win/game over modals */
  .wbox{padding:1.5rem}

  /* Toast positioning above safe area */
  .toast{bottom:calc(1.25rem + env(safe-area-inset-bottom))}
}

/* ── EXTRA SMALL (max 380px) ── */
@media(max-width:380px){
  .sts{grid-template-columns:repeat(3,1fr);gap:0}
  .sc{padding:7px 6px}
  .scv{font-size:11px}
  .arow{grid-template-columns:24px minmax(0,1fr) 40px auto;column-gap:6px;row-gap:6px;padding:10px 10px}
  .aic{width:24px;height:24px;font-size:12px}
  .minichart{width:40px;height:22px}
  .anm{font-size:11px}
  .amet{font-size:8px}
  .apr{font-size:11px}
  .acg{font-size:8px}
  .abts{gap:5px;margin-top:3px}
  .abts .btn{padding:8px 3px;font-size:10px;min-height:34px}
  .mtit{font-size:20px}
  .tabs .tb{padding:7px 9px 9px;font-size:11px}
  .ph-pct{font-size:14px}
  .ph-val-main{font-size:12px}
}
@media(min-width:900px){
  .arow{grid-template-columns:38px minmax(0,1fr) 100px 120px 120px;gap:12px;padding:11px 16px}
  .minichart{width:100px;height:36px}
  .sts .scv{font-size:17px}
  #stats-chart{height:220px}
  .ph-row{gap:14px;padding:13px 18px}
  .ph-pct{font-size:20px;min-width:100px}
  .ph-val-main{font-size:15px}
  .ph-expand-inner{padding:16px 18px 20px}
  .ph-chart-wrap canvas{height:200px}
  .tbox{max-width:680px}
}

/* ── LARGE MONITOR (≥1400px) — skaler opp tekst for lesbarhet ── */
@media(min-width:1400px){
  .shell{max-width:1280px;padding:2rem 2.5rem 5rem}

  /* Header */
  .mtit{font-size:34px}
  .meye{font-size:11px;letter-spacing:.2em}
  .mbadge{font-size:10px;padding:3px 10px}
  .mcv{font-size:24px}
  .mcl{font-size:11px}
  .mti{font-size:12px}

  /* Ticker */
  .tkwrap{height:34px}
  .tki{font-size:12px;padding:0 22px}

  /* Stats bar */
  .sc{padding:16px 22px}
  .scl{font-size:11px;letter-spacing:.15em}
  .sts .scv{font-size:22px}

  /* Tabs */
  .tabs .tb{font-size:14px;padding:10px 22px 12px}

  /* Section labels & collapsible toggles */
  .slab{font-size:11px;letter-spacing:.18em;margin:1.2rem 0 .6rem}
  .slab.grp-toggle{padding:14px 18px;min-height:52px;font-size:12px}
  .slab.grp-toggle .grp-meta{font-size:11px;letter-spacing:.1em}

  /* Asset rows */
  .arow{grid-template-columns:44px minmax(0,1fr) 120px 140px 150px;gap:16px;padding:14px 20px}
  .aic{width:38px;height:38px;font-size:16px}
  .anm{font-size:14px}
  .amet{font-size:11px}
  .apr{font-size:15px}
  .acg{font-size:11px}
  .rpill{font-size:9px;padding:2px 7px}
  .minichart{width:120px;height:42px}

  /* Banners */
  .rbanner{font-size:11px;padding:9px 16px}

  /* Buttons */
  .btn{font-size:12px;padding:7px 14px}
  .btn.ghost{font-size:11px;padding:6px 12px}
  .abts .btn{padding:8px 14px;font-size:12px}
  .sall{font-size:13px;padding:10px 20px}

  /* Portfolio rows */
  .ph-row{padding:16px 22px;gap:16px}
  .ph-ico{font-size:24px;width:40px}
  .ph-name{font-size:15px}
  .ph-tk{font-size:11px;margin-top:3px}
  .ph-pct{font-size:24px;min-width:110px}
  .ph-val-main{font-size:17px}
  .ph-val-sub{font-size:10px}
  .ph-detail-lbl{font-size:10px}
  .ph-detail-val{font-size:14px}

  /* Stats tab */
  .stat-card{padding:14px 18px}
  .stat-cl{font-size:10px;letter-spacing:.14em}
  .stat-cv{font-size:15px}
  .ret-card{padding:12px 16px}
  .ret-lbl{font-size:10px}
  .ret-val{font-size:17px}
  .inv-hdr,.inv-row{padding:11px 16px}
  .inv-h{font-size:10px}
  .inv-nm{font-size:14px}
  .inv-tk{font-size:11px}
  .inv-v,.inv-p{font-size:13px}
  #stats-chart{height:260px}

  /* Allocation bars */
  .all{font-size:11px;width:60px}
  .alp{font-size:11px;width:44px}

  /* Drawer */
  #drw{width:300px}
  .di{font-size:14px;padding:12px 1.25rem}

  /* Tips/news */
  .tipr{padding:12px 18px}
  .tipb{font-size:10px;padding:3px 10px}
  .newsi{padding:13px 18px}
  .nhl{font-size:14px}
  .ntk{font-size:11px}
  .ntm{font-size:11px}

  /* Trade modal */
  .tbox{max-width:760px;padding:1.75rem}
  .ttit{font-size:22px}
  .tsub{font-size:11px}
  .tcsl{font-size:10px}
  .tcsv{font-size:13px}
  .tprice{font-size:24px}
  .tfl input{font-size:15px;padding:11px 14px}
  .thint{font-size:11px}
  .tact .btn{font-size:13px;padding:12px}
}

/* ── EXTRA LARGE (≥1800px) — 4K eller ultrawide ── */
@media(min-width:1800px){
  .shell{max-width:1440px}
  .mtit{font-size:40px}
  .mcv{font-size:28px}
  .sts .scv{font-size:26px}
  .tabs .tb{font-size:15px}
  .slab.grp-toggle{padding:16px 22px;min-height:58px;font-size:13px}
  .anm{font-size:15px}
  .ph-pct{font-size:26px}
  .ph-val-main{font-size:18px}
  #stats-chart{height:300px}
}
.mhd{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1.5px solid var(--ink);padding-top:.25rem}
.ml{padding-left:50px}.meye{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink3);margin-bottom:3px}
.mtit{font-family:'Playfair Display',serif;font-size:28px;font-weight:900;line-height:1}
.mr{text-align:right}.mcl{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink3);margin-bottom:2px}
.mcv{font-family:'DM Mono',monospace;font-size:20px;font-weight:500}.mti{font-family:'DM Mono',monospace;font-size:10px;color:var(--ink3);margin-top:2px}
.mbadge{font-family:'DM Mono',monospace;font-size:8px;color:var(--green);background:var(--gbg);border:1px solid rgba(26,107,71,.2);border-radius:3px;padding:2px 7px;margin-top:4px;display:inline-flex;align-items:center;gap:4px}

/* ── STATS BAR ── */
.sts{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--rl);overflow:hidden;margin-bottom:1.5rem}
.sc{background:var(--bg);padding:12px 16px}.scl{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:.13em;text-transform:uppercase;color:var(--ink3);margin-bottom:4px}
.scv{font-family:'DM Mono',monospace;font-size:15px;font-weight:500}
.up{color:var(--green)}.dn{color:var(--red)}.neu{color:var(--ink)}

/* ── TABS ── */
.tabs{display:flex;margin-bottom:1.25rem;border-bottom:1px solid var(--line2)}
.tb{font-family:'DM Sans',sans-serif;font-size:12px;font-weight:500;padding:7px 16px 9px;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;cursor:pointer;color:var(--ink3);transition:color .12s;position:relative}
.tb.on{color:var(--ink);border-bottom-color:var(--ink)}.tb:hover{color:var(--ink)}
.tb .dot{position:absolute;top:4px;right:2px;width:7px;height:7px;border-radius:50%;background:var(--red);display:none}.tb .dot.on{display:block}

/* ── RISK BANNERS ── */
.slab{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink3);margin:1.1rem 0 .5rem}.slab:first-child{margin-top:0}
.rbanner{border-radius:var(--r);padding:7px 12px;margin-bottom:.5rem;font-family:'DM Mono',monospace;font-size:9px;display:flex;align-items:center;gap:6px}
.rn{background:var(--surf);border:1px solid var(--line2);color:var(--ink3)}
.rm{background:var(--abg);border:1px solid rgba(122,92,0,.25);color:var(--amber)}
.rh{background:var(--rbg);border:1px solid rgba(181,58,42,.3);color:var(--red)}
.re{background:#1a0a0a;border:1px solid #8a2020;color:#ff7070}

/* ── ASSET ROW ── */
.atab{border:1px solid var(--line);border-radius:var(--rl);overflow:hidden;margin-bottom:.25rem}
.arow{display:grid;grid-template-columns:34px minmax(0,1fr) 80px 110px auto;align-items:center;gap:10px;padding:9px 12px;background:var(--bg);border-bottom:1px solid var(--line);transition:background .1s}
.arow.med-row{background:rgba(122,92,0,.025)}.arow.hr{background:rgba(181,58,42,.03)}.arow.er{background:rgba(26,10,10,.06)}
.arow:last-child{border-bottom:none}.arow:hover{background:var(--surf)}
.aic{width:32px;height:32px;border-radius:50%;background:var(--surf2);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;cursor:pointer;transition:transform .12s}
.aic:hover{transform:scale(1.12)}.aic.dng{background:rgba(181,58,42,.15)}.aic.ext{background:rgba(139,0,0,.2)}.aic.med{background:rgba(122,92,0,.12)}
.anw{min-width:0}.anm{font-size:12px;font-weight:500;display:inline;cursor:pointer;border-bottom:1px dotted var(--line2)}.anm:hover{border-bottom-color:var(--ink)}
.rpill{display:inline-block;font-family:'DM Mono',monospace;font-size:7px;letter-spacing:.07em;padding:1px 5px;border-radius:2px;vertical-align:middle;margin-left:3px;text-transform:uppercase}
.pm{background:var(--abg);color:var(--amber);border:1px solid rgba(122,92,0,.2)}
.ph{background:var(--rbg);color:var(--red);border:1px solid rgba(181,58,42,.25)}
.pe{background:#1a0a0a;color:#ff7070;border:1px solid #8a2020}
.amet{font-family:'DM Mono',monospace;font-size:9px;color:var(--ink3);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.minichart{width:80px;height:32px;flex-shrink:0}
.apc{text-align:right;overflow:hidden;min-width:0}.apr{font-family:'DM Mono',monospace;font-size:12px;font-weight:500;white-space:nowrap}.acg{font-family:'DM Mono',monospace;font-size:9px;margin-top:1px;white-space:nowrap}
.abts{display:flex;gap:5px;justify-content:flex-end;flex-wrap:nowrap;flex-shrink:0}

/* ── BUTTONS ── */
.btn{font-family:'DM Mono',monospace;font-size:10px;padding:5px 10px;border-radius:var(--r);cursor:pointer;transition:all .1s;border:1px solid var(--line2);background:transparent;color:var(--ink);white-space:nowrap}
.btn:hover{background:var(--surf)}.btn:active{transform:scale(.97)}
.buy{background:var(--ink);color:var(--bg);border-color:var(--ink)}.buy:hover{opacity:.85;background:var(--ink);color:var(--bg)}
.sell{border-color:var(--red);color:var(--red)}.sell:hover{background:var(--rbg)}
.ghost{border-color:var(--line);color:var(--ink3);font-size:9px;padding:4px 8px}.ghost:hover{border-color:var(--line2);color:var(--ink);background:var(--surf)}
.sall{background:var(--red);color:#fff;border-color:var(--red);font-size:11px;padding:8px 16px}.sall:hover{background:#8a2a1a;border-color:#8a2a1a;color:#fff}
.inst{background:var(--red);color:#fff;border-color:var(--red)}.inst:hover{background:#8a2a1a;border-color:#8a2a1a;color:#fff}

/* ── PORTFOLIO TABLE ── */
.ptab{border:1px solid var(--line);border-radius:var(--rl);overflow:hidden}
.phdr{display:grid;grid-template-columns:28px 1fr 90px 90px 92px 112px;align-items:center;gap:8px;padding:8px 14px;background:var(--surf);border-bottom:1px solid var(--line2)}
.ph2{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink3)}.ph2.r{text-align:right}
.prow{display:grid;grid-template-columns:28px 1fr 90px 90px 92px 112px;align-items:center;gap:8px;padding:11px 14px;background:var(--bg);border-bottom:1px solid var(--line);transition:background .15s}
.prow:last-child{border-bottom:none}.prow:hover{background:var(--surf)}
.pnm{font-size:12px;font-weight:500;cursor:pointer;border-bottom:1px dotted var(--line2);display:inline}.pnm:hover{border-bottom-color:var(--ink)}
.pq{font-family:'DM Mono',monospace;font-size:9px;color:var(--ink3);margin-top:1px}
.pmo{font-family:'DM Mono',monospace;font-size:11px;text-align:right}.pc{font-family:'DM Mono',monospace;font-size:9px;text-align:right;margin-top:1px}
.pact{display:flex;flex-direction:column;gap:4px}.pact .btn{text-align:center;padding:5px 0;width:100%}

/* ── ALLOCATION BARS ── */
.alrow{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.all{font-family:'DM Mono',monospace;font-size:9px;color:var(--ink3);width:52px;text-align:right;flex-shrink:0}
.altr{flex:1;height:5px;background:var(--surf2);border-radius:2px;overflow:hidden}.alfi{height:100%;border-radius:2px;transition:width .4s}.alp{font-family:'DM Mono',monospace;font-size:9px;color:var(--ink3);width:36px}

/* ── TICKER ── */
.tkwrap{overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--surf);margin-bottom:1.5rem;height:28px;display:flex;align-items:center}
.tkinn{display:flex;white-space:nowrap;animation:scroll 50s linear infinite}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.tki{font-family:'DM Mono',monospace;font-size:10px;padding:0 16px;display:inline-flex;align-items:center;gap:5px}.tkn{color:var(--ink3)}

/* ── BREAKING NEWS BANNER ── */
.brk{border-radius:var(--rl);padding:12px 16px;margin-bottom:1rem;display:flex;gap:12px;align-items:flex-start;animation:slIn .3s ease}
@keyframes slIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.brk.crash{background:var(--rbg);border:1px solid rgba(181,58,42,.3)}
.brk.surge{background:var(--gbg);border:1px solid rgba(26,107,71,.3)}
.bico{font-size:18px;flex-shrink:0;margin-top:1px}.btag{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:.15em;text-transform:uppercase;font-weight:500;margin-bottom:3px}
.brk.crash .btag{color:var(--red)}.brk.surge .btag{color:var(--green)}
.bhl{font-size:13px;font-weight:500;line-height:1.35;margin-bottom:3px}.bsub{font-size:11px;color:var(--ink3);font-family:'DM Mono',monospace}
.bx{margin-left:auto;font-family:'DM Mono',monospace;font-size:11px;color:var(--ink3);cursor:pointer;padding:2px 7px;border:1px solid var(--line);border-radius:var(--r);background:transparent;flex-shrink:0}.bx:hover{background:var(--surf)}

/* ── TIPS ── */
.tipc{border:1px solid var(--line);border-radius:var(--rl);overflow:hidden;margin-bottom:.5rem}
.tipr{display:grid;grid-template-columns:32px 1fr auto auto;align-items:center;gap:10px;padding:10px 14px;background:var(--bg);border-bottom:1px solid var(--line);transition:background .1s}
.tipr:last-child{border-bottom:none}.tipr:hover{background:var(--surf)}
.tipb{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:.1em;text-transform:uppercase;padding:2px 7px;border-radius:3px;white-space:nowrap}
.hot{background:var(--rbg);color:var(--red)}.ris{background:var(--gbg);color:var(--green)}.wat{background:var(--abg);color:var(--amber)}.cld{background:var(--surf2);color:var(--ink3)}

/* ── NEWS ── */
.newsl{border:1px solid var(--line);border-radius:var(--rl);overflow:hidden}
.newsi{padding:11px 14px;border-bottom:1px solid var(--line);background:var(--bg);display:flex;gap:10px;align-items:flex-start}
.newsi:last-child{border-bottom:none}.ndot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:4px}
.ntk{font-family:'DM Mono',monospace;font-size:9px;font-weight:500;letter-spacing:.06em;margin-bottom:2px}
.ntk.up{color:var(--green)}.ntk.dn{color:var(--red)}.nhl{font-size:12px;color:var(--ink2);line-height:1.35}.ntm{font-family:'DM Mono',monospace;font-size:9px;color:var(--ink3);margin-top:2px}

/* ── TRADE MODAL ── */
#tradeov{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:200;display:none;align-items:center;justify-content:center;padding:1rem}
#tradeov.on{display:flex}
.tbox{background:var(--bg);border:1px solid var(--line2);border-radius:var(--rl);padding:1.5rem;width:100%;max-width:600px}
.t-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}
.t-left{flex:1}
.tico{font-size:20px;margin-bottom:5px}.ttit{font-family:'Playfair Display',serif;font-size:18px;font-weight:700;margin-bottom:2px}
.tsub{font-family:'DM Mono',monospace;font-size:9px;color:var(--ink3);letter-spacing:.07em}
.t-close{font-family:'DM Mono',monospace;font-size:11px;color:var(--ink3);cursor:pointer;padding:5px 9px;border:1px solid var(--line);border-radius:var(--r);background:transparent;flex-shrink:0}
.t-close:hover{background:var(--surf)}
.t-chart-wrap{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin-bottom:1rem;background:var(--bg)}
#TC{display:block;width:100%;height:200px}
.t-chart-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin-bottom:1rem}
.tcs{background:var(--bg);padding:7px 10px}
.tcsl{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:.09em;text-transform:uppercase;color:var(--ink3);margin-bottom:2px}
.tcsv{font-family:'DM Mono',monospace;font-size:11px;font-weight:500}
.iv-window{font-family:'DM Mono',monospace;font-size:9px;color:var(--ink3);letter-spacing:.06em;margin:0 2px .5rem;padding-top:2px}
.tprice{font-family:'DM Mono',monospace;font-size:20px;font-weight:500;text-align:center;padding:10px;background:var(--surf);border-radius:var(--r);margin-bottom:1rem}
.tfl label{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink3);display:block;margin-bottom:4px}
.tfl input{width:100%;padding:9px 11px;border:1px solid var(--line2);border-radius:var(--r);font-family:'DM Mono',monospace;font-size:13px;background:transparent;color:var(--ink);outline:none;margin-bottom:5px}
.tfl input:focus{border-color:var(--ink)}.thint{font-family:'DM Mono',monospace;font-size:9px;color:var(--ink3);min-height:12px;margin-bottom:.9rem}
.tpcts{display:flex;gap:4px;margin-bottom:1.1rem}.tpcts .ghost{flex:1;text-align:center}
.tact{display:flex;gap:7px}.tact .btn{flex:1;padding:10px;font-size:11px}
.trisk{background:var(--rbg);border:1px solid rgba(181,58,42,.3);border-radius:var(--r);padding:8px 11px;font-family:'DM Mono',monospace;font-size:9px;color:var(--red);margin-bottom:1rem;line-height:1.55}
.tmrisk{background:var(--abg);border:1px solid rgba(122,92,0,.25);border-radius:var(--r);padding:8px 11px;font-family:'DM Mono',monospace;font-size:9px;color:var(--amber);margin-bottom:1rem;line-height:1.55}

/* ── WIN / GAME OVER OVERLAY ── */
#winov,#gameoverov{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:400;display:none;align-items:center;justify-content:center;padding:1rem}
#winov.on,#gameoverov.on{display:flex}
#gameoverov{background:rgba(40,10,10,.7)}
.wbox{background:var(--bg);border:1px solid var(--line2);border-radius:var(--rl);padding:2.5rem;max-width:340px;width:100%;text-align:center}

/* ── MISC ── */
.ai-pulse{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--green);animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1)}}
.empty{text-align:center;padding:3rem 1rem;color:var(--ink3);font-family:'DM Mono',monospace;font-size:12px;line-height:1.7}
#freeze-banner{position:fixed;top:1rem;left:50%;transform:translateX(-50%);z-index:500;background:var(--abg);border:1px solid rgba(122,92,0,.4);border-radius:var(--rl);padding:14px 20px;box-shadow:0 6px 24px rgba(0,0,0,.2);animation:fbIn .3s ease}
@keyframes fbIn{from{opacity:0;transform:translateX(-50%) translateY(-10px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
.fb-content{display:flex;align-items:center;gap:14px}
.fb-ico{font-size:28px}
.fb-title{font-family:'Playfair Display',serif;font-size:16px;font-weight:700;color:var(--amber)}
.fb-sub{font-family:'DM Mono',monospace;font-size:11px;color:var(--amber);margin-top:2px}
#freeze-countdown{font-weight:700}
.toast{position:fixed;bottom:1.75rem;left:50%;transform:translateX(-50%) translateY(4px);background:var(--ink);color:var(--bg);font-family:'DM Mono',monospace;font-size:11px;padding:9px 20px;border-radius:var(--r);opacity:0;transition:opacity .18s,transform .18s;pointer-events:none;white-space:nowrap;z-index:9999}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ── FLOATING TOOLTIP (for sell previews) ── */
#floating-tip{position:fixed;z-index:9998;background:var(--bg);border:1px solid var(--line2);border-radius:var(--r);padding:10px 12px;font-family:'DM Mono',monospace;font-size:10px;box-shadow:0 6px 20px rgba(0,0,0,.25);pointer-events:none;opacity:0;transition:opacity .12s;max-width:260px;min-width:200px;display:none}
#floating-tip.on{display:block;opacity:1}
.tip-title{font-weight:500;margin-bottom:6px;padding-bottom:5px;border-bottom:1px solid var(--line);font-size:10px;letter-spacing:.05em;color:var(--ink3);text-transform:uppercase}
.tip-row{display:flex;justify-content:space-between;gap:14px;margin:3px 0;color:var(--ink2);font-size:11px}
.tip-row .lbl{color:var(--ink3)}
.tip-row.neg{color:var(--red)}
.tip-row.pos{color:var(--green)}
.tip-net{font-weight:700;color:var(--ink);margin-top:6px;padding-top:6px;border-top:1px solid var(--line);font-size:12px}
.tip-gain{display:flex;justify-content:space-between;gap:14px;font-size:11px;font-weight:500;margin-top:6px;padding-top:6px;border-top:1px dashed var(--line);letter-spacing:.04em;color:var(--ink2)}
.tip-gain .lbl{color:var(--ink3);font-weight:400}
.tip-gain.pos{color:var(--green)}
.tip-gain.neg{color:var(--red)}


/* ── PORTFOLIO ASSET ROW ── */
.ph-row{display:grid;grid-template-columns:36px 1fr auto auto;align-items:center;gap:10px;padding:11px 14px;background:var(--bg);border-bottom:1px solid var(--line);cursor:pointer;transition:background .12s;user-select:none}
.ph-row:hover{background:var(--surf)}
.ph-row.expanded{background:var(--surf);border-bottom-color:transparent}
.ph-ico{font-size:20px;width:36px;text-align:center;flex-shrink:0}
.ph-info{min-width:0}
.ph-name{font-size:13px;font-weight:600;display:flex;align-items:center;gap:5px}
.ph-tk{font-family:'DM Mono',monospace;font-size:9px;color:var(--ink3);margin-top:1px}
.ph-pct{font-family:'DM Mono',monospace;font-size:18px;font-weight:700;text-align:right;min-width:80px;letter-spacing:-.02em}
.ph-val{text-align:right;min-width:90px}
.ph-val-main{font-family:'DM Mono',monospace;font-size:14px;font-weight:600}
.ph-val-sub{font-family:'DM Mono',monospace;font-size:9px;color:var(--ink3);margin-top:1px}
/* dropdown expand area */
.ph-expand{max-height:0;overflow:hidden;transition:max-height .3s ease;border-bottom:1px solid var(--line);background:var(--surf)}
.ph-expand.open{max-height:700px}
.ph-expand-inner{padding:12px 14px 16px}
.ph-detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin-bottom:.75rem}
@media(min-width:480px){.ph-detail-grid{grid-template-columns:repeat(4,1fr)}}
.ph-detail-cell{background:var(--bg);padding:8px 10px}
.ph-detail-lbl{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink3);margin-bottom:2px}
.ph-detail-val{font-family:'DM Mono',monospace;font-size:12px;font-weight:500}
.ph-chart-wrap{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin-bottom:.75rem;background:var(--bg);max-width:680px;margin-left:auto;margin-right:auto}
.ph-chart-wrap canvas{display:block;width:100%;height:200px}
.ph-actions{display:flex;gap:6px;flex-wrap:wrap}
.ph-actions .btn{flex:1;min-width:80px;padding:9px 12px;font-size:11px;text-align:center}
.ph-iv-bar{display:flex;gap:3px;margin-bottom:.5rem;flex-wrap:wrap}
.ph-iv-bar span{font-family:'DM Mono',monospace;font-size:8px;color:var(--ink3);align-self:center;letter-spacing:.1em;text-transform:uppercase;margin-right:2px}

/* ── STATS TAB ── */
.stat-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--rl);overflow:hidden;margin-bottom:1.25rem}
@media(min-width:480px){.stat-cards{grid-template-columns:repeat(4,1fr)}}
.stat-card{background:var(--bg);padding:11px 14px}
.stat-cl{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink3);margin-bottom:4px}
.stat-cv{font-family:'DM Mono',monospace;font-size:13px;font-weight:500}
.ret-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;margin-bottom:1.25rem}
@media(min-width:480px){.ret-grid{grid-template-columns:repeat(4,1fr)}}
.ret-card{background:var(--surf);border:1px solid var(--line);border-radius:var(--r);padding:10px 12px;text-align:center}
.ret-lbl{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink3);margin-bottom:4px}
.ret-val{font-family:'DM Mono',monospace;font-size:14px;font-weight:500}
.val-chart-wrap{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--bg);margin-bottom:1.25rem}
#stats-chart{display:block;width:100%;height:160px;cursor:crosshair}

/* ── STATS SNAPSHOT PANEL ── */
.stats-snap{border:1px solid var(--line);border-radius:var(--rl);padding:12px 14px;background:var(--bg);margin-bottom:1.25rem;min-height:60px}
.stats-snap-hint{font-family:'DM Mono',monospace;font-size:10px;color:var(--ink3);text-align:center;padding:10px 0;letter-spacing:.05em}
.snap-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px;padding-bottom:6px;border-bottom:1px solid var(--line)}
.snap-time{font-family:'DM Mono',monospace;font-size:10px;color:var(--ink3);letter-spacing:.1em;text-transform:uppercase}
.snap-total{font-family:'DM Mono',monospace;font-size:15px;font-weight:700}
.snap-split{display:flex;gap:18px;margin-bottom:8px;font-family:'DM Mono',monospace;font-size:11px;color:var(--ink2)}
.snap-split .snap-lbl{font-size:8px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink3);margin-right:4px}
.snap-empty{font-family:'DM Mono',monospace;font-size:11px;color:var(--ink3);text-align:center;padding:10px 0;font-style:italic}
.snap-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:6px}
.snap-item{display:flex;align-items:center;gap:8px;padding:7px 9px;background:var(--surf);border:1px solid var(--line);border-radius:var(--r)}
.snap-ico{font-size:16px;width:24px;text-align:center;flex-shrink:0}
.snap-mid{flex:1;min-width:0}
.snap-name{font-size:11px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.snap-meta{font-family:'DM Mono',monospace;font-size:9px;color:var(--ink3);margin-top:1px}
.snap-val{text-align:right;flex-shrink:0}
.snap-vmain{font-family:'DM Mono',monospace;font-size:11px;font-weight:500}
.snap-vchg{font-family:'DM Mono',monospace;font-size:8px;margin-top:1px;letter-spacing:.04em}
.inv-table{border:1px solid var(--line);border-radius:var(--rl);overflow:hidden}
.inv-hdr{display:grid;grid-template-columns:28px 1fr 90px 90px;gap:8px;padding:7px 12px;background:var(--surf);border-bottom:1px solid var(--line2)}
.inv-row{display:grid;grid-template-columns:28px 1fr 90px 90px;gap:8px;padding:10px 12px;background:var(--bg);border-bottom:1px solid var(--line);align-items:center}
.inv-row:last-child{border-bottom:none}
.inv-h{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:.09em;text-transform:uppercase;color:var(--ink3)}.inv-h.r{text-align:right}
.inv-nm{font-size:12px;font-weight:500}.inv-tk{font-family:'DM Mono',monospace;font-size:9px;color:var(--ink3)}
.inv-v{font-family:'DM Mono',monospace;font-size:11px;text-align:right}
.inv-p{font-family:'DM Mono',monospace;font-size:11px;text-align:right}

/* ── COLLAPSIBLE GROUP TOGGLE ── */
.slab.grp-toggle{display:flex;justify-content:space-between;align-items:center;cursor:pointer;user-select:none;padding:8px 10px;border:1px solid var(--line);border-radius:var(--r);background:var(--surf);margin:1rem 0 .5rem;transition:background .12s}
.slab.grp-toggle:first-child{margin-top:0}
.slab.grp-toggle:hover{background:var(--surf2)}
.slab.grp-toggle .grp-meta{font-family:'DM Mono',monospace;font-size:9px;color:var(--ink3);letter-spacing:.08em}

/* ── PORTFOLIO TOOLBAR ── */
.port-toolbar{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:.75rem;flex-wrap:wrap}
.port-sort-wrap{display:flex;align-items:center;gap:8px}
.port-sort-lbl{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink3)}
.port-sort{font-family:'DM Mono',monospace;font-size:11px;padding:6px 10px;border:1px solid var(--line2);border-radius:var(--r);background:var(--bg);color:var(--ink);cursor:pointer;outline:none}
.port-sort:focus{border-color:var(--ink)}

/* ── SAVED GAMES (splash, logged in) ── */
#saved-games{width:100%;max-width:520px;margin-bottom:1.25rem}
.saved-games-label{font-family:'DM Mono',monospace;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink2);margin-bottom:.6rem;font-weight:500}
.saved-game-btn{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;padding:12px 16px;margin-bottom:6px;border:1.5px solid var(--green);border-radius:var(--r);background:var(--gbg);cursor:pointer;transition:all .14s;font-family:inherit;color:var(--ink);text-align:left}
.saved-game-btn:hover{background:var(--green);color:#fff;transform:translateY(-1px);box-shadow:0 3px 10px rgba(26,107,71,.2)}
.saved-game-btn:active{transform:translateY(0)}
.sg-slot{font-family:'DM Mono',monospace;font-size:11px;font-weight:600;white-space:nowrap;min-width:60px}
.sg-val{font-family:'DM Mono',monospace;font-size:14px;font-weight:700;flex:1;text-align:center}
.sg-date{font-family:'DM Mono',monospace;font-size:9px;color:var(--ink3);white-space:nowrap}
.saved-game-btn:hover .sg-date{color:rgba(255,255,255,.7)}
@media(max-width:500px){
  .saved-game-btn{padding:10px 12px}
  .sg-val{font-size:12px}
  .sg-slot{font-size:10px}
}

/* ── MODE PICKER (splash) ── */
.mode-pick-label{font-family:'DM Mono',monospace;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink2);margin:.75rem 0 1rem;font-weight:500}
.mode-pick{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;width:100%;max-width:720px;margin-bottom:1.75rem;align-items:start}
@media(max-width:720px){.mode-pick{grid-template-columns:1fr;max-width:420px}}

.mode-card{background:var(--bg);border:1.5px solid var(--line2);border-radius:var(--rl);overflow:hidden;transition:border-color .2s,box-shadow .2s,transform .2s}
.mode-card:hover{border-color:var(--ink);box-shadow:0 4px 16px rgba(0,0,0,.1)}
.mode-card.hard-card{border-color:rgba(181,58,42,.4)}
.mode-card.hard-card:hover{border-color:var(--red);box-shadow:0 4px 16px rgba(181,58,42,.15)}
.mode-card.open{box-shadow:0 6px 24px rgba(0,0,0,.15)}
.mode-card.open.hard-card{box-shadow:0 6px 24px rgba(181,58,42,.2);border-color:var(--red)}

.mode-head{display:flex;align-items:center;gap:12px;padding:16px 14px;cursor:pointer;user-select:none;transition:background .14s}
.mode-head:hover{background:var(--surf)}
.mode-ico{font-size:32px;line-height:1;flex-shrink:0}
.mode-info{flex:1;text-align:left;min-width:0}
.mode-name{font-family:'Playfair Display',serif;font-size:22px;font-weight:700;line-height:1.1;margin-bottom:3px}
.mode-card.hard-card .mode-name{color:var(--red)}
.mode-meta{font-family:'DM Mono',monospace;font-size:11px;color:var(--ink3);letter-spacing:.04em}
.mode-toggle{font-size:20px;opacity:.55;transition:all .2s;flex-shrink:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--surf)}
.mode-head:hover .mode-toggle{opacity:1;background:var(--surf2);transform:scale(1.1)}
.mode-card.open .mode-toggle{transform:rotate(180deg);opacity:1}

.mode-expand{max-height:0;overflow:hidden;transition:max-height .4s cubic-bezier(.4,0,.2,1)}
.mode-card.open .mode-expand{max-height:500px}
.mode-expand-inner{padding:4px 16px 16px;border-top:1px solid var(--line)}
.mode-desc-full{font-family:'DM Sans',sans-serif;font-size:14px;line-height:1.5;color:var(--ink2);margin:12px 0 14px;text-align:left}
.mode-features{list-style:none;margin:0 0 16px;padding:0;text-align:left}
.mode-features li{font-family:'DM Mono',monospace;font-size:11px;color:var(--ink2);padding:4px 0;display:flex;gap:8px;align-items:center}
.mf-ok{color:var(--green);font-weight:700;width:14px;display:inline-block}
.mf-warn{color:var(--red);font-weight:700;width:14px;display:inline-block}
.mf-neutral{color:var(--ink3);width:14px;display:inline-block}
.mode-start{width:100%;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:600;padding:13px 20px;border:none;border-radius:var(--r);cursor:pointer;transition:all .14s;letter-spacing:.02em}
.mode-start.easy{background:var(--green);color:#fff}
.mode-start.easy:hover{background:#14573a}
.mode-start.normal{background:var(--ink);color:var(--bg)}
.mode-start.normal:hover{opacity:.9}
.mode-start.hard{background:var(--red);color:#fff}
.mode-start.hard:hover{background:#8a2a1a}
.mode-start:active{transform:scale(.98)}

/* ── MODE BADGE (in-game header) ── */
.mode-badge{display:inline-flex;align-items:center;gap:4px;font-family:'DM Mono',monospace;font-size:8px;padding:2px 7px;border-radius:3px;margin-left:6px;letter-spacing:.08em;text-transform:uppercase}
.mode-badge.easy{background:var(--gbg);color:var(--green);border:1px solid rgba(26,107,71,.2)}
.mode-badge.normal{background:var(--surf);color:var(--ink3);border:1px solid var(--line2)}
.mode-badge.hard{background:var(--rbg);color:var(--red);border:1px solid rgba(181,58,42,.3)}

/* ── AUTH AREA (splash) ── */
#auth-area{width:100%;max-width:360px;margin-bottom:1.5rem}
.auth-toggle{display:flex;border:1px solid var(--line2);border-radius:var(--r);overflow:hidden;margin-bottom:.75rem}
.auth-tab{flex:1;font-family:'DM Mono',monospace;font-size:12px;padding:10px;border:none;background:transparent;color:var(--ink3);cursor:pointer;transition:all .12s;font-weight:500;letter-spacing:.04em}
.auth-tab.on{background:var(--ink);color:var(--bg)}
.auth-form{display:flex;flex-direction:column;gap:9px}
.auth-form input{font-family:'DM Mono',monospace;font-size:14px;padding:11px 13px;border:1px solid var(--line2);border-radius:var(--r);background:transparent;color:var(--ink);outline:none}
.auth-form input:focus{border-color:var(--ink)}
.auth-form input::placeholder{color:var(--ink3)}
.auth-divider{display:flex;align-items:center;gap:12px;margin:.85rem 0;color:var(--ink3);font-family:'DM Mono',monospace;font-size:10px;letter-spacing:.1em}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--line2)}
.google-btn{display:block;text-align:center;text-decoration:none;font-family:'DM Mono',monospace;font-size:13px;padding:11px;border:1px solid var(--line2);border-radius:var(--r);background:transparent;color:var(--ink);transition:background .12s;cursor:pointer;font-weight:500}
.google-btn:hover{background:var(--surf)}
.auth-error{font-family:'DM Mono',monospace;font-size:11px;color:var(--red);min-height:16px;margin-top:6px;text-align:center}
.auth-guest{font-family:'DM Mono',monospace;font-size:11px;color:var(--ink2);text-align:center;margin-top:.85rem;letter-spacing:.03em}
.link-btn{background:none;border:none;color:var(--ink);cursor:pointer;border-bottom:1px dotted var(--line2);font-family:inherit;font-size:inherit;padding:0}
.link-btn:hover{border-bottom-color:var(--ink)}
.auth-user-badge{font-family:'DM Mono',monospace;font-size:12px;color:var(--green);background:var(--gbg);border:1px solid rgba(26,107,71,.2);border-radius:var(--r);padding:10px 14px;text-align:center;margin-bottom:.5rem}
.auth-user-badge button{font-family:'DM Mono',monospace;font-size:10px;color:var(--red);background:none;border:none;cursor:pointer;margin-left:8px;border-bottom:1px dotted var(--red)}
.admin-tag{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:.1em;padding:2px 6px;border-radius:3px;background:var(--ink);color:var(--bg);margin-left:6px;vertical-align:middle}

@media(min-width:1400px){
  #auth-area{max-width:420px}
  .auth-tab{font-size:13px;padding:11px}
  .auth-form input{font-size:15px;padding:12px 14px}
  .google-btn{font-size:14px;padding:12px}
  .auth-guest{font-size:12px}
}

/* ── LEADERBOARD MODAL ── */
#leaderboard{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:300;display:none;align-items:center;justify-content:center;padding:1.5rem}
#leaderboard.on{display:flex}
.lb-table{width:100%;border-collapse:collapse;font-family:'DM Mono',monospace;font-size:11px;margin:.75rem 0}
.lb-table th{font-size:8px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink3);text-align:left;padding:6px 8px;border-bottom:1px solid var(--line2)}
.lb-table th.r{text-align:right}
.lb-table td{padding:8px;border-bottom:1px solid var(--line)}
.lb-table td.r{text-align:right;font-weight:500}
.lb-table tr.me{background:var(--gbg)}
.lb-rank{color:var(--ink3);width:28px}
.lb-mode{font-size:9px;padding:2px 6px;border-radius:3px;letter-spacing:.04em;display:inline-block}
.lb-mode.normal{background:var(--surf);color:var(--ink3);border:1px solid var(--line2)}
.lb-mode.hard{background:var(--rbg);color:var(--red);border:1px solid rgba(181,58,42,.3)}
.lb-note{font-family:'DM Mono',monospace;font-size:9px;color:var(--ink3);text-align:center;margin-top:.75rem;padding-top:.5rem;border-top:1px dashed var(--line);font-style:italic}

/* ── SAVE PICKER MODAL ── */
#savepicker{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:300;display:none;align-items:center;justify-content:center;padding:1.5rem}
#savepicker.on{display:flex}
.sp-slot{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border:1px solid var(--line2);border-radius:var(--r);margin-bottom:6px;cursor:pointer;transition:all .12s;background:var(--bg)}
.sp-slot:hover{background:var(--surf);border-color:var(--ink)}
.sp-slot-info{min-width:0}
.sp-slot-name{font-family:'DM Mono',monospace;font-size:12px;font-weight:500}
.sp-slot-meta{font-family:'DM Mono',monospace;font-size:9px;color:var(--ink3);margin-top:2px}
.sp-slot-empty{color:var(--ink3);font-style:italic}
.sp-local{font-family:'DM Mono',monospace;font-size:10px;color:var(--ink3);text-align:center;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--line)}
.sp-local button{background:none;border:none;color:var(--ink);cursor:pointer;border-bottom:1px dotted var(--line2);font-family:inherit;font-size:inherit;padding:0}
.sp-local button:hover{border-bottom-color:var(--ink)}
