@import url('https://fonts.googleapis.com/css2?family=Share+Tech+Mono&family=Orbitron:wght@700;900&display=swap');
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#0b0c10;--panel:#13151c;--border:#1f2535;
  --accent:#e94560;--accent2:#4ecca3;--gold:#f5c842;
  --warn:#f5a623;--dim:#3a3f55;--text:#c8cfe0;
  --cell-hidden:#1a1f30;--cell-hover:#252c42;--cell-rev:#0d1018;
  --perk-color:#b07aff;--use-color:#4ecca3;--upg-color:#f5a623;
  --relic-color:#ff6b6b;--gem-color:#a78bfa;
}
html,body{width:100%;height:100%;background:var(--bg);color:var(--text);font-family:'Share Tech Mono',monospace;overflow:hidden}
#bg-canvas{position:fixed;inset:0;z-index:100;pointer-events:none}

/* ── Screens ── */
.screen{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:10}
.screen.hidden{display:none}
.screen.fading-out{opacity:0;transform:scale(0.97);pointer-events:none;transition:opacity .3s,transform .3s}
.screen.fading-in{animation:fadeIn .3s ease forwards}
@keyframes fadeIn{from{opacity:0;transform:scale(1.03)}to{opacity:1;transform:scale(1)}}

/* ── MENU ── */
#menu-content{display:flex;flex-direction:column;align-items:center;gap:28px}
#menu-logo{display:flex;flex-direction:column;align-items:center;gap:6px}
.logo-mine{font-size:4rem;animation:float 3s ease-in-out infinite;filter:drop-shadow(0 0 18px #e94560aa)}
@keyframes float{0%,100%{transform:translateY(0) rotate(-5deg)}50%{transform:translateY(-12px) rotate(5deg)}}
#menu-logo h1{font-family:'Orbitron',sans-serif;font-size:clamp(2.8rem,8vw,5rem);font-weight:900;letter-spacing:.15em;color:#fff;text-shadow:0 0 30px var(--accent),0 0 60px var(--accent)}
.logo-sub{font-size:.85rem;letter-spacing:.4em;color:var(--dim)}
#menu-buttons{display:flex;flex-direction:column;gap:10px;width:240px}
#menu-footer{display:flex;flex-direction:column;align-items:center;gap:4px}
#best-score-display,#gems-display{font-size:.8rem;color:var(--dim);letter-spacing:.1em}
#gems-display{color:var(--gem-color)}

/* Play + Run Mod quick-access row */
.play-row{display:flex;gap:8px;width:100%}
.play-row .menu-btn.primary{flex:1}
.play-row .menu-btn.run-mod-quick-btn{width:48px;padding:13px 0;font-size:1.1rem;flex-shrink:0;border-color:var(--accent);color:var(--accent)}
.play-row .menu-btn.run-mod-quick-btn:hover{background:var(--accent);color:#fff;box-shadow:0 0 14px #e9456055}

/* Top-right corner settings button */
.corner-settings-btn{
  position:absolute;top:16px;right:20px;background:transparent;
  border:1px solid var(--dim);color:var(--dim);
  width:40px;height:40px;border-radius:10px;cursor:pointer;transition:all .2s;
  z-index:20;display:flex;align-items:center;justify-content:center;
}
.corner-settings-btn:hover{border-color:var(--accent2);color:var(--accent2);box-shadow:0 0 12px #4ecca344}
.corner-settings-btn svg{transition:transform .4s ease}
.corner-settings-btn:hover svg{transform:rotate(60deg)}

.menu-btn{width:100%;padding:13px 0;border:1px solid var(--dim);background:transparent;color:var(--text);font-family:'Orbitron',sans-serif;font-size:.85rem;font-weight:700;letter-spacing:.15em;border-radius:6px;cursor:pointer;transition:all .2s}
.menu-btn:hover{border-color:var(--accent2);color:var(--accent2);box-shadow:0 0 14px #4ecca355;transform:translateY(-2px)}
.menu-btn.primary{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 0 20px #e9456055}
.menu-btn.primary:hover{background:#ff5577;border-color:#ff5577;box-shadow:0 0 30px #e9456099;transform:translateY(-2px)}
.menu-btn.gacha-btn{border-color:var(--gem-color);color:var(--gem-color)}
.menu-btn.gacha-btn:hover{box-shadow:0 0 14px #a78bfa55;border-color:var(--gem-color);color:#fff;background:var(--gem-color)}
.menu-btn.wide{width:100%;margin-top:4px}
.menu-btn:disabled{opacity:.35;cursor:not-allowed;transform:none!important}

/* ── HOW TO PLAY ── */
#howto-screen{overflow-y:auto;padding:20px;align-items:flex-start;justify-content:center}
#howto-box{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:32px 40px;max-width:560px;width:95vw;display:flex;flex-direction:column;gap:20px;box-shadow:0 0 60px #00000088;margin:auto}
#howto-box h2{font-family:'Orbitron',sans-serif;font-size:1.4rem;letter-spacing:.2em;color:var(--accent2);text-align:center}
.howto-section{display:flex;flex-direction:column;gap:8px}
.howto-section-title{font-family:'Orbitron',sans-serif;font-size:.65rem;font-weight:700;letter-spacing:.2em;color:var(--dim);padding-bottom:6px;border-bottom:1px solid var(--border)}
.howto-hint{font-size:.7rem;color:var(--dim);letter-spacing:.04em}
.howto-list{list-style:none;display:flex;flex-direction:column;gap:9px}
.howto-list li{display:flex;align-items:center;gap:10px;font-size:.85rem}
.key{background:var(--border);border:1px solid var(--dim);border-radius:4px;padding:2px 8px;font-size:.78rem;color:var(--accent2);white-space:nowrap;flex-shrink:0}
.hl{color:var(--accent2);font-weight:bold}.hl.red{color:var(--accent)}

/* Mini minefield */
#howto-grid-wrap{background:#0d1018;border:1px solid var(--border);border-radius:10px;padding:10px;display:inline-flex;align-self:center}
#howto-grid{display:grid;gap:3px;user-select:none}
#howto-grid-msg{font-family:'Orbitron',sans-serif;font-size:.8rem;text-align:center;min-height:20px;color:var(--accent2)}
.howto-reset-btn{background:transparent;border:1px solid var(--dim);color:var(--dim);font-family:'Orbitron',sans-serif;font-size:.65rem;font-weight:700;letter-spacing:.12em;padding:7px 16px;border-radius:6px;cursor:pointer;transition:all .2s}
.howto-reset-btn:hover{border-color:var(--accent2);color:var(--accent2)}
.howto-grid-controls{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}
.howto-flag-btn{background:transparent;border:1px solid var(--dim);color:var(--dim);font-family:'Orbitron',sans-serif;font-size:.65rem;font-weight:700;letter-spacing:.1em;padding:7px 14px;border-radius:6px;cursor:pointer;transition:all .2s}
.howto-flag-btn.active{border-color:var(--gold);color:var(--gold);background:rgba(245,200,66,.08)}
.howto-flag-btn:hover{border-color:var(--gold);color:var(--gold)}

/* Number demo row */
.howto-numbers-demo{display:flex;gap:6px;justify-content:center;flex-wrap:wrap}
.howto-numbers-labels{display:flex;gap:6px;justify-content:center;flex-wrap:wrap;font-size:.6rem;color:var(--dim)}
.howto-numbers-labels span{width:52px;text-align:center}
.hnd-cell{width:52px;height:52px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:bold;border-radius:6px;font-family:'Orbitron',sans-serif;border:1px solid transparent}
.hnd-cell.revealed{background:var(--cell-rev);border-color:#131820}
.hnd-cell.hidden{background:var(--cell-hidden);border-color:#252c42}
.hnd-cell.flagged{background:#1e1508;border-color:#3a2a10}
.hnd-cell.mine{background:#3a0a10;border-color:var(--accent)}

/* ── GACHA ── */
#gacha-screen{overflow-y:auto;padding:20px}
#gacha-box{background:var(--panel);border:1px solid var(--gem-color);border-radius:16px;padding:32px 36px;width:min(600px,95vw);display:flex;flex-direction:column;gap:20px;box-shadow:0 0 60px #a78bfa22;margin:auto}
#gacha-header{display:flex;align-items:center;justify-content:space-between}
#gacha-header h2{font-family:'Orbitron',sans-serif;font-size:1.6rem;font-weight:900;letter-spacing:.15em;color:var(--gem-color);text-shadow:0 0 20px #a78bfa66}
#gacha-gems-display{font-family:'Orbitron',sans-serif;font-size:1.3rem;color:var(--gem-color)}
#gacha-sub{font-size:.75rem;color:var(--dim);letter-spacing:.08em}
#gacha-machine{display:flex;flex-direction:column;align-items:center;gap:16px;background:#0d1018;border:1px solid var(--border);border-radius:12px;padding:24px}
#gacha-slots{display:flex;gap:12px}
.gacha-slot{width:90px;height:90px;background:#13151c;border:2px solid var(--border);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:2rem;transition:all .15s,border-color .3s,box-shadow .3s;position:relative;overflow:hidden}
.gacha-slot.spinning{animation:slot-spin .1s linear infinite;border-color:var(--gem-color);box-shadow:0 0 20px #a78bfa44}
.gacha-slot.landed{animation:slot-land .4s ease-out forwards;border-color:var(--gold);box-shadow:0 0 20px #f5c84266}
@keyframes slot-spin{0%{transform:translateY(-4px)}50%{transform:translateY(4px)}100%{transform:translateY(-4px)}}
@keyframes slot-land{0%{transform:scale(1.3)}60%{transform:scale(.9)}100%{transform:scale(1)}}
#gacha-btns{display:flex;gap:12px}
.gacha-roll-btn{background:transparent;border:1px solid var(--gem-color);color:var(--gem-color);font-family:'Orbitron',sans-serif;font-size:.8rem;font-weight:700;letter-spacing:.1em;padding:10px 20px;border-radius:6px;cursor:pointer;transition:all .2s}
.gacha-roll-btn:hover:not(:disabled){background:var(--gem-color);color:var(--bg);box-shadow:0 0 16px #a78bfa55}
.gacha-roll-btn.gold{border-color:var(--gold);color:var(--gold)}
.gacha-roll-btn.gold:hover:not(:disabled){background:var(--gold);color:var(--bg);box-shadow:0 0 16px #f5c84255}
.gacha-roll-btn:disabled{opacity:.3;cursor:not-allowed}
#gacha-result{font-size:.8rem;color:var(--dim);min-height:20px;text-align:center}
#gacha-inventory{display:flex;flex-direction:column;gap:10px}
.gacha-inv-title{font-family:'Orbitron',sans-serif;font-size:.7rem;letter-spacing:.15em;color:var(--dim);border-bottom:1px solid var(--border);padding-bottom:6px}
#gacha-inv-list{display:flex;flex-wrap:wrap;gap:8px;min-height:32px}
.gacha-inv-tag{background:#1a1f30;border:1px solid var(--gem-color);border-radius:6px;padding:4px 10px;font-size:.72rem;color:var(--gem-color);display:flex;align-items:center;gap:6px}
.gacha-inv-tag .remove-tag{cursor:pointer;color:var(--dim);font-size:.8rem;margin-left:2px}
.gacha-inv-tag .remove-tag:hover{color:var(--accent)}

/* ── MODIFIER SCREEN ── */
#modifier-box{background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:44px 52px;display:flex;flex-direction:column;align-items:center;gap:16px;min-width:340px;max-width:500px;width:90vw;text-align:center;box-shadow:0 0 80px #00000099}
#modifier-floor-label{font-family:'Orbitron',sans-serif;font-size:.75rem;letter-spacing:.3em;color:var(--dim)}
#modifier-icon{font-size:3.5rem;animation:float 2s ease-in-out infinite}
#modifier-name{font-family:'Orbitron',sans-serif;font-size:1.6rem;font-weight:900;letter-spacing:.1em}
#modifier-desc{font-size:.88rem;color:var(--dim);line-height:1.6;max-width:360px}
#modifier-relics{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:4px}
.modifier-relic-tag{background:#1a0a0a;border:1px solid var(--relic-color);border-radius:6px;padding:4px 10px;font-size:.72rem;color:var(--relic-color)}

/* ── GAME SCREEN ── */
/* HUD styles moved to bottom of file */
#game-screen{flex-direction:column;gap:10px;padding:16px;overflow-y:auto;align-items:center}
#modifier-banner{height:22px;font-size:.75rem;letter-spacing:.1em;text-align:center;flex-shrink:0}
#message-bar{height:20px;font-size:.82rem;letter-spacing:.06em;color:var(--warn);text-align:center;transition:opacity .3s;flex-shrink:0}
#bomb-legend{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;font-size:.68rem;color:var(--dim);flex-shrink:0;min-height:16px}
.legend-item{display:flex;align-items:center;gap:3px}
#grid-wrap{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:12px;box-shadow:0 0 40px #00000066}
#grid{display:grid;gap:3px;user-select:none}

/* ── CELLS ── */
.cell{width:44px;height:44px;display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:bold;border-radius:6px;cursor:pointer;transition:background .1s,transform .1s,box-shadow .1s;border:1px solid transparent;font-family:'Orbitron',sans-serif;touch-action:none;-webkit-tap-highlight-color:transparent;user-select:none}
.cell.hidden{background:var(--cell-hidden);border-color:#252c42;box-shadow:inset 0 1px 0 #2a3248,inset 0 -1px 0 #0d1018}
.cell.hidden:hover{background:var(--cell-hover);border-color:var(--dim);transform:scale(1.06);box-shadow:0 0 10px #4ecca322}
.cell.hidden:active{background:var(--cell-hover);transform:scale(0.94);}
.cell.revealed{background:var(--cell-rev);border-color:#131820;cursor:default}
.cell.flagged{background:#1e1508;border-color:#3a2a10;box-shadow:0 0 8px #f5a62333;animation:flag-plant .2s ease-out forwards}
.cell.mine-explode{background:#3a0a10;border-color:var(--accent);box-shadow:0 0 16px var(--accent);animation:explode-cell .4s ease-out forwards}
.cell.mine-dead{background:#1a0508;border-color:#3a1020}
/* Bounty mine */
.cell.bounty{border-color:var(--gold)!important;box-shadow:0 0 8px #f5c84244!important}
@keyframes explode-cell{0%{transform:scale(1.3);background:#ff4466}60%{transform:scale(.9)}100%{transform:scale(1)}}
@keyframes cell-popin{0%{transform:scale(.5);opacity:0}70%{transform:scale(1.08)}100%{transform:scale(1);opacity:1}}
.cell.popin{animation:cell-popin .2s ease-out forwards}
@keyframes flag-plant{0%{transform:scale(.5) rotate(-20deg)}60%{transform:scale(1.2) rotate(5deg)}100%{transform:scale(1) rotate(0)}}
.n1{color:#5bc8f5}.n2{color:#4ecca3}.n3{color:#e94560}.n4{color:#b07aff}.n5{color:#ff7043}.n6{color:#26c6da}.n7{color:#f06292}.n8{color:#78909c}

/* ── SHOP (old rules kept for card internals) ── */
.card-top{display:flex;align-items:center;gap:10px}
.card-icon{font-size:1.6rem;flex-shrink:0}
.card-name{font-family:'Orbitron',sans-serif;font-size:.78rem;font-weight:700;color:#fff;line-height:1.3}
.card-tag{font-size:.6rem;letter-spacing:.1em;margin-top:2px}
.perk-card .card-tag{color:var(--perk-color)}
.relic-card .card-tag{color:var(--relic-color)}
.use-card .card-tag{color:var(--use-color)}
.upgrade-card .card-tag{color:var(--upg-color)}
.card-desc{font-size:.72rem;color:var(--dim);line-height:1.5;flex:1}
.card-curse{font-size:.7rem;color:var(--relic-color);margin-top:2px;line-height:1.4}
.card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:2px}
.card-stack{font-size:.65rem;color:var(--dim)}
.card-buy{background:transparent;border:1px solid;font-family:'Orbitron',sans-serif;font-size:.7rem;font-weight:700;letter-spacing:.08em;padding:6px 12px;border-radius:5px;cursor:pointer;transition:all .2s;white-space:nowrap}
.perk-card .card-buy{border-color:var(--perk-color);color:var(--perk-color)}
.relic-card .card-buy{border-color:var(--relic-color);color:var(--relic-color)}
.use-card .card-buy{border-color:var(--use-color);color:var(--use-color)}
.upgrade-card .card-buy{border-color:var(--upg-color);color:var(--upg-color)}
.perk-card .card-buy:hover:not(:disabled){background:var(--perk-color);color:var(--bg);box-shadow:0 0 10px #b07aff55}
.relic-card .card-buy:hover:not(:disabled){background:var(--relic-color);color:var(--bg);box-shadow:0 0 10px #ff6b6b55}
.use-card .card-buy:hover:not(:disabled){background:var(--use-color);color:var(--bg);box-shadow:0 0 10px #4ecca355}
.upgrade-card .card-buy:hover:not(:disabled){background:var(--upg-color);color:var(--bg);box-shadow:0 0 10px #f5a62355}
.card-buy:disabled{opacity:.3;cursor:not-allowed}

/* ── END SCREEN ── */
#end-box{background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:40px 48px;display:flex;flex-direction:column;align-items:center;gap:18px;min-width:320px;max-width:520px;width:90vw;box-shadow:0 0 80px #00000099;text-align:center}
#end-icon{font-size:3.5rem;animation:float 2s ease-in-out infinite}
#end-title{font-family:'Orbitron',sans-serif;font-size:2rem;font-weight:900;letter-spacing:.1em}
#end-title.death{color:var(--accent);text-shadow:0 0 20px var(--accent)}
#end-title.win{color:var(--accent2);text-shadow:0 0 20px var(--accent2)}
#end-stats{display:flex;flex-direction:column;gap:5px;color:var(--dim);font-size:.88rem}
#end-stats span{color:var(--text)}
#end-perks-display{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;font-size:.7rem}
.end-perk-tag{background:#1a1f30;border:1px solid var(--border);border-radius:4px;padding:3px 8px;color:var(--dim)}
.end-relic-tag{background:#1a0a0a;border:1px solid var(--relic-color);border-radius:4px;padding:3px 8px;color:var(--relic-color)}
#end-buttons{display:flex;flex-direction:column;gap:10px;width:200px;margin-top:4px}

/* ── VFX ── */
.score-popup{position:fixed;pointer-events:none;font-family:'Orbitron',sans-serif;font-size:.9rem;font-weight:700;z-index:998;animation:score-rise 1s ease-out forwards}
@keyframes score-rise{0%{transform:translateY(0);opacity:1}100%{transform:translateY(-55px);opacity:0}}
#floor-transition{position:fixed;inset:0;background:rgba(11,12,16,.93);z-index:500;display:flex;align-items:center;justify-content:center;font-family:'Orbitron',sans-serif;font-size:3rem;font-weight:900;color:var(--accent2);letter-spacing:.25em;text-shadow:0 0 40px var(--accent2),0 0 80px var(--accent2);pointer-events:none}

/* Timer pulse when low */
@keyframes timer-pulse{0%,100%{color:var(--accent);text-shadow:0 0 8px var(--accent)}50%{color:#fff;text-shadow:0 0 16px var(--accent)}}
.timer-danger{animation:timer-pulse .6s ease-in-out infinite}

/* ═══════════════════════════════════════════════════════════════
   SHARED PANEL BOX (Settings / Inventory / Run Mods)
═══════════════════════════════════════════════════════════════ */
.panel-box{
  background:var(--panel);border:1px solid var(--border);border-radius:18px;
  padding:32px 36px;width:min(520px,95vw);display:flex;flex-direction:column;
  gap:22px;box-shadow:0 0 80px #00000099;margin:auto;
}
.panel-box.wide{width:min(680px,95vw)}

.panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}
.panel-header-left{display:flex;align-items:center;gap:14px}
.panel-icon{font-size:2rem;line-height:1}
.panel-title{font-family:'Orbitron',sans-serif;font-size:1.5rem;font-weight:900;letter-spacing:.12em;color:var(--accent2)}
.panel-sub{font-size:.72rem;color:var(--dim);letter-spacing:.06em;margin-top:3px}
.panel-header-right{display:flex;align-items:center;flex-shrink:0}

.panel-section{display:flex;flex-direction:column;gap:10px}
.panel-section-label{font-family:'Orbitron',sans-serif;font-size:.62rem;font-weight:700;letter-spacing:.2em;color:var(--dim);padding-bottom:8px;border-bottom:1px solid var(--border)}
.panel-section-label.danger-label{color:#ff6b6b;border-color:#3a1010}

/* ── Settings rows ── */
.setting-row{display:flex;align-items:center;justify-content:space-between;gap:16px;
  background:#0d1018;border:1px solid var(--border);border-radius:12px;padding:14px 18px}
.setting-info{display:flex;flex-direction:column;gap:3px;flex:1}
.setting-name{font-size:.82rem;color:var(--text);letter-spacing:.04em}
.setting-hint{font-size:.65rem;color:var(--dim)}

/* ── Toggle group ── */
.toggle-group{display:flex;gap:0;border:1px solid var(--border);border-radius:8px;overflow:hidden;flex-shrink:0}
.toggle-btn{
  background:transparent;border:none;border-right:1px solid var(--border);
  color:var(--dim);font-family:'Orbitron',sans-serif;font-size:.65rem;font-weight:700;
  letter-spacing:.1em;padding:8px 14px;cursor:pointer;transition:all .18s;white-space:nowrap;
}
.toggle-btn:last-child{border-right:none}
.toggle-btn:hover:not(.active){background:#1a1f30;color:var(--text)}
.toggle-btn.active{background:var(--accent2);color:var(--bg);box-shadow:inset 0 0 12px #4ecca344}

/* ── Volume sliders ── */
.slider-wrap{display:flex;align-items:center;gap:10px;flex-shrink:0;width:210px}
.slider-icon{font-size:1rem;flex-shrink:0;width:20px;text-align:center}
.slider-track-wrap{position:relative;flex:1;display:flex;align-items:center;height:24px}
.setting-slider{
  -webkit-appearance:none;appearance:none;
  width:100%;height:5px;border-radius:3px;
  background:linear-gradient(to right, var(--accent2) 0%, var(--accent2) var(--pct,50%), var(--border) var(--pct,50%), var(--border) 100%);
  outline:none;cursor:pointer;position:relative;z-index:2;
}
.setting-slider::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;
  width:20px;height:20px;border-radius:50%;
  background:var(--accent2);border:2px solid #0b0c10;
  box-shadow:0 0 10px #4ecca388;cursor:pointer;
  transition:transform .12s,box-shadow .12s;
}
.setting-slider:active::-webkit-slider-thumb,
.setting-slider:hover::-webkit-slider-thumb{transform:scale(1.25);box-shadow:0 0 16px #4ecca3cc}
.setting-slider::-moz-range-thumb{
  width:20px;height:20px;border-radius:50%;
  background:var(--accent2);border:2px solid #0b0c10;
  box-shadow:0 0 10px #4ecca388;cursor:pointer;
}
.setting-slider::-moz-range-progress{background:var(--accent2);border-radius:3px;height:5px}
/* hide the old fill div — we use CSS custom property on the input now */
.slider-fill{display:none}
.slider-val{
  font-family:'Orbitron',sans-serif;font-size:.72rem;font-weight:700;
  color:var(--accent2);width:30px;text-align:right;flex-shrink:0;
}

/* Settings panel sizing */
.settings-panel{width:min(560px,95vw)}
.settings-icon{font-size:1.8rem;line-height:1}

/* Mute button */
.audio-row-right{display:flex;align-items:center;gap:8px;flex-shrink:0}
.mute-btn{
  background:transparent;border:1px solid var(--dim);color:var(--dim);
  font-size:1rem;width:36px;height:36px;border-radius:8px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0;
}
.mute-btn:hover{border-color:var(--accent2);color:var(--accent2)}
.mute-btn.muted{border-color:var(--accent);color:var(--accent);background:rgba(233,69,96,.1)}

/* Audio reset button */
.audio-reset-btn{
  background:transparent;border:1px solid var(--dim);color:var(--dim);
  font-family:'Orbitron',sans-serif;font-size:.62rem;font-weight:700;letter-spacing:.12em;
  padding:7px 14px;border-radius:6px;cursor:pointer;transition:all .2s;align-self:flex-start;
}
.audio-reset-btn:hover{border-color:var(--accent2);color:var(--accent2)}

.danger-zone{display:flex;align-items:center;justify-content:space-between;gap:12px;
  background:#1a0808;border:1px solid #3a1010;border-radius:10px;padding:12px 16px}
.danger-btn{background:transparent;border:1px solid var(--accent);color:var(--accent);
  font-family:'Orbitron',sans-serif;font-size:.72rem;font-weight:700;letter-spacing:.1em;
  padding:8px 16px;border-radius:6px;cursor:pointer;transition:all .2s;white-space:nowrap;flex-shrink:0}
.danger-btn:hover{background:var(--accent);color:#fff;box-shadow:0 0 16px #e9456055}

/* ═══════════════════════════════════════════════════════════════
   INVENTORY
═══════════════════════════════════════════════════════════════ */
#inventory-screen{overflow-y:auto;padding:20px;align-items:flex-start;justify-content:center}
#inventory-gems-display{font-family:'Orbitron',sans-serif;font-size:1.1rem;color:var(--gem-color);
  background:#110d1a;border:1px solid var(--gem-color);border-radius:8px;padding:6px 14px;
  box-shadow:0 0 12px #a78bfa22}

.inv-panel{max-height:90vh;overflow-y:auto}

/* Equipped slots row */
#equipped-slots{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.equipped-slot{
  position:relative;min-height:110px;background:#0d1018;
  border:2px dashed var(--border);border-radius:14px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:6px;padding:16px 12px;transition:all .2s;text-align:center;
}
.equipped-slot.empty{cursor:default}
.equipped-slot.empty:hover{border-color:var(--dim)}
.equipped-slot.filled{border-style:solid;border-color:var(--gem-color);background:linear-gradient(135deg,#110d1a,#0d1018);cursor:default;box-shadow:0 0 20px #a78bfa18}
.equipped-slot.filled:hover{box-shadow:0 0 24px #a78bfa33}
.slot-num{
  position:absolute;top:7px;left:9px;
  font-family:'Orbitron',sans-serif;font-size:.55rem;font-weight:700;
  color:var(--dim);letter-spacing:.1em;
  background:#13151c;border:1px solid var(--border);border-radius:4px;padding:1px 5px;
}
.slot-empty-text{font-size:.62rem;letter-spacing:.18em;color:var(--dim)}
.slot-item-icon{font-size:2rem;line-height:1;filter:drop-shadow(0 0 6px #a78bfa66)}
.slot-item-name{font-size:.68rem;color:var(--text);line-height:1.3;font-weight:700}
.slot-item-rarity{font-size:.58rem;letter-spacing:.1em;margin-top:1px}
.unequip-btn{
  position:absolute;top:6px;right:7px;
  background:rgba(233,69,96,.15);border:1px solid var(--accent);color:var(--accent);
  border-radius:5px;width:22px;height:22px;font-size:.7rem;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  opacity:0;transition:opacity .2s,background .2s;
}
.equipped-slot.filled:hover .unequip-btn{opacity:1}
.unequip-btn:hover{background:var(--accent);color:#fff}

/* Collection header */
.inv-collection-header{display:flex;align-items:center;justify-content:space-between;
  padding-bottom:10px;border-bottom:1px solid var(--border)}

/* Inventory close button (top-right X) */
.inv-close-btn{
  background:transparent;border:1px solid var(--dim);color:var(--dim);
  font-size:.9rem;width:34px;height:34px;border-radius:8px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0;
}
.inv-close-btn:hover{border-color:var(--accent);color:var(--accent);box-shadow:0 0 10px #e9456033}

/* Item preview modal */
#item-preview-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:200;
  display:flex;align-items:center;justify-content:center;
  backdrop-filter:blur(4px);
}
#item-preview-overlay.hidden{display:none}
#item-preview-box{
  background:var(--panel);border:1px solid var(--border);border-radius:18px;
  padding:28px 32px;width:min(480px,94vw);display:flex;flex-direction:column;
  align-items:center;gap:10px;box-shadow:0 0 80px #00000099;position:relative;
  max-height:90vh;overflow-y:auto;
}
#item-preview-close{
  position:absolute;top:12px;right:14px;
  background:transparent;border:1px solid var(--dim);color:var(--dim);
  font-size:.85rem;width:30px;height:30px;border-radius:7px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:all .2s;
}
#item-preview-close:hover{border-color:var(--accent);color:var(--accent)}
#item-preview-icon{font-size:3rem;filter:drop-shadow(0 0 12px #a78bfa88)}
#item-preview-name{font-family:'Orbitron',sans-serif;font-size:1.1rem;font-weight:900;letter-spacing:.1em;color:#fff;text-align:center}
#item-preview-rarity{font-size:.65rem;letter-spacing:.18em;font-weight:700;padding:3px 10px;border-radius:10px;border:1px solid currentColor}
#item-preview-desc{font-size:.82rem;color:var(--text);text-align:center;line-height:1.6;max-width:340px}
#item-preview-detail{font-size:.72rem;color:var(--dim);text-align:center;line-height:1.6;max-width:340px;background:#0d1018;border:1px solid var(--border);border-radius:8px;padding:10px 14px;width:100%}
#item-preview-demo-label{font-family:'Orbitron',sans-serif;font-size:.6rem;letter-spacing:.2em;color:var(--dim);margin-top:4px}
#item-preview-canvas{border:1px solid var(--border);border-radius:8px;background:#0d1018;display:block}
#item-preview-demo-hint{font-size:.65rem;color:var(--dim);text-align:center;letter-spacing:.04em}
.inv-count-badge{
  font-family:'Share Tech Mono',monospace;font-size:.7rem;font-weight:400;
  color:var(--accent2);background:#0d1a14;border:1px solid #1f3a2a;
  border-radius:10px;padding:1px 8px;margin-left:8px;
}
.inv-actions{display:flex;gap:8px;align-items:center}

/* Inventory list */
#inventory-list{display:flex;flex-direction:column;gap:6px;min-height:60px}
.inv-empty{color:var(--dim);font-size:.75rem;padding:24px;text-align:center;
  background:#0d1018;border:1px dashed var(--border);border-radius:10px;letter-spacing:.06em}
.inventory-item{
  display:flex;align-items:center;gap:14px;
  background:#0d1018;border:1px solid var(--border);border-radius:12px;
  padding:12px 16px;cursor:pointer;transition:all .18s;
}
.inventory-item:hover:not(.equipped){
  border-color:var(--gem-color);background:#110d1a;
  box-shadow:0 0 14px #a78bfa1a;transform:translateX(4px);
}
.inventory-item.equipped{opacity:.45;cursor:not-allowed}
.inv-item-icon{font-size:1.8rem;flex-shrink:0;width:38px;text-align:center;
  filter:drop-shadow(0 0 4px #a78bfa44)}
.inv-item-body{flex:1;display:flex;flex-direction:column;gap:3px}
.inv-item-name{font-family:'Orbitron',sans-serif;font-size:.78rem;font-weight:700;color:#fff}
.inv-item-desc{font-size:.68rem;color:var(--dim);line-height:1.4}
.inv-item-right{display:flex;flex-direction:column;align-items:flex-end;gap:5px;flex-shrink:0}
.inv-item-rarity{font-size:.6rem;letter-spacing:.12em;font-weight:700;
  padding:2px 7px;border-radius:4px;background:#0d1018;border:1px solid currentColor;opacity:.85}
.inv-equipped-badge{font-size:.58rem;letter-spacing:.1em;color:var(--gem-color);
  background:#1a1030;border:1px solid var(--gem-color);border-radius:4px;padding:2px 6px}
.inv-equip-hint{font-size:.58rem;color:var(--dim);letter-spacing:.06em}
.inv-preview-btn{
  background:transparent;border:1px solid var(--dim);color:var(--dim);
  font-family:'Orbitron',sans-serif;font-size:.6rem;font-weight:700;
  width:20px;height:20px;border-radius:50%;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all .18s;flex-shrink:0;padding:0;
}
.inv-preview-btn:hover{border-color:var(--accent2);color:var(--accent2);box-shadow:0 0 8px #4ecca333}

/* ═══════════════════════════════════════════════════════════════
   RUN MODIFIERS
═══════════════════════════════════════════════════════════════ */
#run-mods-screen{overflow-y:auto;padding:20px;align-items:flex-start;justify-content:center}

.run-mods-mult-display{display:flex;flex-direction:column;align-items:center;
  background:#1a0a0a;border:1px solid var(--accent);border-radius:10px;padding:10px 18px;gap:2px}
.rmd-label{font-size:.55rem;letter-spacing:.2em;color:var(--dim)}
.rmd-val{font-family:'Orbitron',sans-serif;font-size:1.6rem;font-weight:900;color:var(--accent);
  text-shadow:0 0 16px #e9456066}

#run-mods-list{display:flex;flex-direction:column;gap:8px}
.run-mod-card{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  background:#0d1018;border:1px solid var(--border);border-radius:12px;
  padding:16px 18px;cursor:pointer;transition:all .2s;
}
.run-mod-card:hover:not(.locked){border-color:var(--accent);box-shadow:0 0 14px #e9456022;transform:translateX(3px)}
.run-mod-card.active{border-color:var(--accent);background:#1a0808;box-shadow:0 0 14px #e9456033}
.run-mod-card.locked{opacity:.4;cursor:not-allowed}
.rmc-left{display:flex;align-items:center;gap:14px;flex:1}
.rmc-icon{font-size:1.6rem;flex-shrink:0;width:32px;text-align:center}
.rmc-body{display:flex;flex-direction:column;gap:4px}
.rmc-name{font-family:'Orbitron',sans-serif;font-size:.82rem;font-weight:700;color:#fff}
.rmc-desc{font-size:.7rem;color:var(--dim);line-height:1.4}
.rmc-right{display:flex;flex-direction:column;align-items:center;gap:6px;flex-shrink:0}
.rmc-mult{font-family:'Orbitron',sans-serif;font-size:.9rem;font-weight:700;color:var(--dim)}
.rmc-mult.active{color:var(--accent)}
.rmc-toggle{font-size:1.2rem;color:var(--dim);transition:color .2s}
.rmc-toggle.on{color:var(--accent);text-shadow:0 0 8px var(--accent)}

/* ═══════════════════════════════════════════════════════════════
   HUD — improved
═══════════════════════════════════════════════════════════════ */
#hud{
  display:flex;background:var(--panel);border:1px solid var(--border);
  border-radius:12px;overflow:hidden;flex-shrink:0;
  box-shadow:0 4px 24px #00000066;
}
.hud-block{
  display:flex;flex-direction:column;align-items:center;
  padding:10px 20px;gap:3px;border-right:1px solid var(--border);
  position:relative;
}
.hud-block:last-child{border-right:none}
.hud-label{font-size:.52rem;letter-spacing:.22em;color:var(--dim);text-transform:uppercase}
.hud-val{font-family:'Orbitron',sans-serif;font-size:1.1rem;font-weight:700;color:#fff}
.hud-val.accent2{color:var(--accent2);text-shadow:0 0 10px #4ecca344}
.hud-val.warn{color:var(--warn)}
.hud-val.gold{color:var(--gold)}
.hearts-full{color:#e94560;text-shadow:0 0 8px #e9456066;letter-spacing:.05em}
.hearts-empty{color:#2a1520;letter-spacing:.05em}
.hud-hp-block .hud-val{font-size:.95rem;letter-spacing:.1em}

/* ── Boss floor banner pulse ── */
@keyframes boss-pulse{0%,100%{opacity:1;text-shadow:0 0 10px #ff4466}50%{opacity:.7;text-shadow:0 0 24px #ff4466,0 0 48px #ff446688}}
.boss-banner{animation:boss-pulse 1.2s ease-in-out infinite;font-weight:700;letter-spacing:.15em}

/* ═══════════════════════════════════════════════════════════════
   PAUSE SCREEN
═══════════════════════════════════════════════════════════════ */
#pause-screen{z-index:50}
#pause-box{
  background:rgba(13,16,24,.97);border:1px solid var(--border);border-radius:18px;
  padding:40px 52px;display:flex;flex-direction:column;align-items:center;
  gap:18px;min-width:300px;max-width:420px;width:90vw;
  box-shadow:0 0 80px #00000099;text-align:center;
  backdrop-filter:blur(8px);
}
#pause-icon{font-size:2.5rem;color:var(--accent2);animation:float 2s ease-in-out infinite}
#pause-title{font-family:'Orbitron',sans-serif;font-size:1.8rem;font-weight:900;letter-spacing:.2em;color:var(--accent2)}
#pause-stats{display:flex;flex-direction:column;gap:5px;font-size:.85rem;color:var(--dim);width:100%}
#pause-stats div{display:flex;justify-content:space-between;padding:4px 0;border-bottom:1px solid var(--border)}
#pause-stats span{color:var(--text)}
#pause-buttons{display:flex;flex-direction:column;gap:10px;width:100%;margin-top:4px}
.pause-hint{font-size:.65rem;color:var(--dim);letter-spacing:.1em}

/* ═══════════════════════════════════════════════════════════════
   SHOP — TABBED
═══════════════════════════════════════════════════════════════ */
#shop-screen{overflow-y:auto;padding:20px;align-items:flex-start;justify-content:center}
#shop-box{
  background:var(--panel);border:1px solid var(--border);border-radius:18px;
  padding:24px 28px;width:min(760px,96vw);display:flex;flex-direction:column;
  gap:16px;box-shadow:0 0 80px #00000099;margin:auto;
}
#shop-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}
#shop-header-left{display:flex;flex-direction:column;gap:4px}
#shop-title{font-family:'Orbitron',sans-serif;font-size:1.6rem;font-weight:900;letter-spacing:.12em;color:var(--gold);text-shadow:0 0 20px #f5c84255}
#shop-subtitle{font-size:.7rem;color:var(--dim);letter-spacing:.08em}
#shop-gold-display{font-family:'Orbitron',sans-serif;font-size:1.4rem;color:var(--gold);white-space:nowrap;padding-top:2px}

/* Tabs */
#shop-tabs{display:flex;gap:6px;border-bottom:1px solid var(--border);padding-bottom:0}
.shop-tab{
  background:transparent;border:1px solid var(--border);border-bottom:none;
  color:var(--dim);font-family:'Orbitron',sans-serif;font-size:.65rem;font-weight:700;
  letter-spacing:.1em;padding:8px 14px;border-radius:8px 8px 0 0;cursor:pointer;
  transition:all .2s;position:relative;bottom:-1px;
}
.shop-tab:hover{color:var(--text);border-color:var(--dim)}
.shop-tab.active{background:var(--panel);border-color:var(--border);color:#fff;border-bottom-color:var(--panel)}
.shop-tab:nth-child(1).active{color:var(--perk-color)}
.shop-tab:nth-child(2).active{color:var(--relic-color)}
.shop-tab:nth-child(3).active{color:var(--use-color)}
.shop-tab:nth-child(4).active{color:var(--upg-color)}

/* Pages */
#shop-pages{min-height:280px}
.shop-page{display:none;flex-direction:column;gap:12px;animation:fadeIn .2s ease}
.shop-page.active{display:flex}
.shop-page-header{display:flex;align-items:baseline;gap:10px}
.shop-page-title{font-family:'Orbitron',sans-serif;font-size:.85rem;font-weight:700;letter-spacing:.12em}
.shop-page-sub{font-size:.65rem;color:var(--dim)}
.shop-items-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px}

/* Arrow nav */
#shop-nav{display:flex;align-items:center;justify-content:center;gap:16px}
.shop-arrow{
  background:transparent;border:1px solid var(--dim);color:var(--dim);
  font-size:.9rem;width:36px;height:36px;border-radius:8px;cursor:pointer;
  transition:all .2s;display:flex;align-items:center;justify-content:center;
}
.shop-arrow:hover{border-color:var(--gold);color:var(--gold);box-shadow:0 0 10px #f5c84233}
#shop-dots{display:flex;gap:8px;align-items:center}
.shop-dot{
  width:8px;height:8px;border-radius:50%;background:var(--dim);
  cursor:pointer;transition:all .2s;
}
.shop-dot.active{background:var(--gold);box-shadow:0 0 6px #f5c84288;width:20px;border-radius:4px}

/* Keep card styles working inside pages */
.shop-card{display:flex;flex-direction:column;gap:8px;background:#0d1018;border:1px solid var(--border);border-radius:10px;padding:14px 16px;transition:border-color .2s,box-shadow .2s,transform .15s;cursor:default}
.shop-card:hover:not(.sold-out):not(.cant-afford){transform:translateY(-2px)}
.perk-card:hover:not(.sold-out){border-color:var(--perk-color);box-shadow:0 0 14px #b07aff22}
.relic-card:hover:not(.sold-out){border-color:var(--relic-color);box-shadow:0 0 14px #ff6b6b22}
.use-card:hover:not(.sold-out){border-color:var(--use-color);box-shadow:0 0 14px #4ecca322}
.upgrade-card:hover:not(.sold-out){border-color:var(--upg-color);box-shadow:0 0 14px #f5a62322}
.shop-card.sold-out{opacity:.35}.shop-card.cant-afford{opacity:.55}

/* Run mods page nav */
#run-mods-nav{display:flex;align-items:center;justify-content:center;gap:16px;min-height:36px}
.run-mods-page-label{font-family:'Orbitron',sans-serif;font-size:.7rem;color:var(--dim);letter-spacing:.15em}

/* ── Gacha improvements ── */
.gacha-roll-btn.epic{border-color:var(--gold);color:var(--gold)}
.gacha-roll-btn.epic:hover:not(:disabled){background:var(--gold);color:var(--bg);box-shadow:0 0 20px #f5c84266}
#gacha-pity{font-size:.65rem;color:var(--dim);letter-spacing:.08em;text-align:center}
#gacha-result{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;min-height:24px}
.gacha-result-item{font-size:.78rem;font-weight:700;letter-spacing:.05em}

.gacha-extra-badge{
  position:absolute;bottom:-22px;left:50%;transform:translateX(-50%);
  font-size:1rem;background:#0d1018;border:1px solid var(--gem-color);
  border-radius:6px;padding:2px 8px;white-space:nowrap;
}

/* ── In-game consumable bar ── */
#consumable-bar{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;flex-shrink:0;min-height:0}
.consumable-btn{
  display:flex;align-items:center;gap:6px;
  background:#0d1018;border:1px solid var(--use-color);color:var(--use-color);
  font-family:'Orbitron',sans-serif;font-size:.65rem;font-weight:700;letter-spacing:.08em;
  padding:6px 12px;border-radius:8px;cursor:pointer;transition:all .2s;
}
.consumable-btn:hover{background:var(--use-color);color:var(--bg);box-shadow:0 0 12px #4ecca355;transform:translateY(-2px)}
.cb-icon{font-size:1rem}
.cb-name{font-size:.6rem;letter-spacing:.1em}

/* ── Inventory delete mode ── */
.inv-trash-btn{background:transparent;border:1px solid var(--dim);color:var(--dim);font-family:'Orbitron',sans-serif;font-size:.7rem;font-weight:700;letter-spacing:.1em;padding:8px 14px;border-radius:6px;cursor:pointer;transition:all .2s}
.inv-trash-btn:hover,.inv-trash-btn.active{border-color:var(--accent);color:var(--accent);box-shadow:0 0 10px #e9456033}
.inv-confirm-delete{background:var(--accent);border:none;color:#fff;font-family:'Orbitron',sans-serif;font-size:.7rem;font-weight:700;letter-spacing:.1em;padding:10px 16px;border-radius:6px;cursor:pointer;transition:all .2s}
.inv-confirm-delete:hover{background:#ff5577;box-shadow:0 0 12px #e9456055}
.inventory-item.delete-mode{cursor:pointer}
.inventory-item.delete-mode:hover{border-color:var(--accent)!important;box-shadow:0 0 10px #e9456033}
.inventory-item.selected-delete{border-color:var(--accent)!important;background:#1a0808!important}
.inv-delete-check{font-size:1.1rem;color:var(--accent)}

/* ── Skill Tree (canvas) ── */
#skill-screen{flex-direction:column;padding:0;align-items:stretch;justify-content:stretch}
#skill-screen-inner{display:flex;flex-direction:column;height:100vh;width:100%}
#skill-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;background:var(--panel);border-bottom:1px solid var(--border);flex-shrink:0;gap:16px}
#skill-header-left{display:flex;align-items:center;gap:12px}
.skill-header-icon{font-size:1.6rem}
.skill-header-title{font-family:'Orbitron',sans-serif;font-size:1.1rem;font-weight:900;letter-spacing:.12em;color:#4ecca3}
.skill-header-sub{font-size:.62rem;color:var(--dim);letter-spacing:.06em;margin-top:2px}
#skill-exp-display{font-family:'Orbitron',sans-serif;font-size:1rem;color:#f5c842;white-space:nowrap}
#skill-tree-container{flex:1;position:relative;overflow:hidden;background:var(--bg);min-height:0}
#skill-canvas{display:block}
.skill-tooltip{
  position:absolute;pointer-events:none;z-index:50;
  background:rgba(13,16,24,.97);border:1px solid var(--border);border-radius:10px;
  padding:10px 14px;max-width:200px;display:flex;flex-direction:column;gap:5px;
  box-shadow:0 4px 20px #00000088;
}
.st-name{font-family:'Orbitron',sans-serif;font-size:.78rem;font-weight:700}
.st-desc{font-size:.68rem;color:var(--dim);line-height:1.4}
.st-cost{font-size:.65rem;color:#f5c842;margin-top:2px}

/* Skill tree menu button */
.menu-btn.skill-btn{border-color:#4ecca3;color:#4ecca3}
.menu-btn.skill-btn:hover{background:#4ecca3;color:var(--bg);box-shadow:0 0 14px #4ecca355}

/* ── Changelog ── */
.menu-btn.changelog-btn{border-color:var(--dim);color:var(--dim);font-size:.75rem}
.menu-btn.changelog-btn:hover{border-color:var(--accent2);color:var(--accent2)}

#changelog-screen{overflow-y:auto;padding:20px;align-items:flex-start;justify-content:center}
.cl-panel{
  background:var(--panel);border:1px solid var(--border);border-radius:18px;
  width:min(620px,96vw);max-height:88vh;display:flex;flex-direction:column;
  box-shadow:0 0 80px #00000099;margin:auto;overflow:hidden;
}
.cl-panel-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 28px;border-bottom:1px solid var(--border);flex-shrink:0;
  background:linear-gradient(135deg,#13151c,#0d1018);
}
.cl-panel-header-left{display:flex;align-items:center;gap:14px}
.cl-header-icon{font-size:1.8rem;line-height:1}
.cl-header-title{font-family:'Orbitron',sans-serif;font-size:1.3rem;font-weight:900;letter-spacing:.12em;color:var(--accent2)}
.cl-header-sub{font-size:.65rem;color:var(--dim);letter-spacing:.06em;margin-top:2px}

#changelog-list{overflow-y:auto;padding:20px 28px;display:flex;flex-direction:column;gap:0}

.cl-section{display:flex;flex-direction:column;gap:0;margin-bottom:4px}
.cl-version-header{
  display:flex;align-items:center;gap:12px;
  padding:14px 16px;border-radius:10px;cursor:pointer;
  background:#0d1018;border:1px solid var(--border);
  transition:border-color .2s,background .2s;user-select:none;
}
.cl-version-header:hover{border-color:var(--accent2);background:#0d1a14}
.cl-version-badge{
  font-family:'Orbitron',sans-serif;font-size:.85rem;font-weight:900;
  color:var(--accent2);letter-spacing:.08em;
  background:linear-gradient(135deg,#0d1a14,#0d1018);
  border:1px solid var(--accent2);border-radius:6px;padding:3px 10px;flex-shrink:0;
}
.cl-version-badge.latest{
  color:var(--gold);border-color:var(--gold);
  background:linear-gradient(135deg,#1a1408,#0d1018);
  box-shadow:0 0 10px #f5c84222;
}
.cl-version-date{font-size:.65rem;color:var(--dim);letter-spacing:.1em;flex:1}
.cl-version-count{font-size:.62rem;color:var(--dim);letter-spacing:.06em}
.cl-chevron{font-size:.7rem;color:var(--dim);transition:transform .2s;margin-left:4px}
.cl-section.open .cl-chevron{transform:rotate(90deg)}

.cl-entries-wrap{
  overflow:hidden;max-height:0;transition:max-height .25s ease;
  border-left:2px solid var(--border);margin-left:16px;
}
.cl-section.open .cl-entries-wrap{max-height:600px}
.cl-entries{list-style:none;display:flex;flex-direction:column;gap:0;padding:8px 0 8px 16px}
.cl-entries li{
  font-size:.75rem;color:var(--dim);line-height:1.6;
  padding:5px 8px;border-radius:6px;transition:background .15s,color .15s;
  display:flex;align-items:flex-start;gap:6px;
}
.cl-entries li:hover{background:#0d1018;color:var(--text)}
.cl-entry-dot{width:4px;height:4px;border-radius:50%;background:var(--border);flex-shrink:0;margin-top:7px}

/* ── Mobile flag toggle button ── */
#mobile-flag-bar{display:none;justify-content:center;flex-shrink:0}
.mobile-flag-btn{
  background:transparent;border:2px solid var(--dim);color:var(--dim);
  font-family:'Orbitron',sans-serif;font-size:.8rem;font-weight:700;letter-spacing:.12em;
  padding:10px 28px;border-radius:10px;cursor:pointer;transition:all .2s;
}
.mobile-flag-btn.active{
  border-color:var(--gold);color:var(--gold);background:rgba(245,200,66,.1);
  box-shadow:0 0 14px #f5c84244;
}

/* ═══════════════════════════════════════════════════════════════
   MOBILE / RESPONSIVE
═══════════════════════════════════════════════════════════════ */
@media (pointer:coarse),(max-width:600px){
  /* Show mobile flag bar */
  #mobile-flag-bar{display:flex}

  /* Cells scale to fit screen — use CSS variable set by JS */
  .cell{width:var(--cell-size,32px);height:var(--cell-size,32px);font-size:calc(var(--cell-size,32px) * 0.42);border-radius:4px}
  #grid{gap:2px}
  #grid-wrap{padding:6px;max-width:100vw;overflow-x:auto}

  /* Game screen fits viewport */
  #game-screen{padding:8px;gap:6px}

  /* Tighter HUD — scrollable on tiny screens */
  #hud{overflow-x:auto;max-width:100vw}
  .hud-block{padding:6px 10px}
  .hud-val{font-size:.88rem}
  .hud-label{font-size:.42rem;letter-spacing:.12em}

  /* Menu buttons full width */
  #menu-buttons{width:min(300px,90vw)}

  /* Panels scroll properly */
  .panel-box,.panel-box.wide{width:96vw;padding:16px 12px}
  .inv-panel{max-height:92vh}

  /* Settings slider */
  .slider-wrap{width:150px}

  /* Equipped slots 2-col on small screens */
  #equipped-slots{grid-template-columns:repeat(2,1fr)}

  /* Shop grid single column */
  .shop-items-grid{grid-template-columns:1fr}

  /* Howto grid smaller cells */
  #howto-grid .cell{width:30px;height:30px;font-size:.7rem}

  /* Prevent text selection on tap */
  *{-webkit-tap-highlight-color:transparent}

  /* Touch targets */
  .menu-btn{padding:14px 0;font-size:.8rem}
  .toggle-btn{padding:9px 11px}

  /* Modifier banner smaller */
  #modifier-banner{font-size:.65rem}
  #bomb-legend{font-size:.6rem}
  #message-bar{font-size:.72rem}
}

@media (max-width:400px){
  .cell{width:var(--cell-size,26px);height:var(--cell-size,26px)}
  .hud-block{padding:5px 7px}
  .hud-val{font-size:.8rem}
}

/* ═══════════════════════════════════════════════════════════════
   ADMIN PANEL
═══════════════════════════════════════════════════════════════ */
#admin-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:900;
  display:flex;align-items:center;justify-content:center;
  backdrop-filter:blur(6px);
  transition:opacity .25s ease, backdrop-filter .25s ease;
}
#admin-overlay.hidden{display:none}
#admin-overlay.closing{opacity:0;backdrop-filter:blur(0px);pointer-events:none;}

/* Panel entrance / exit */
@keyframes admin-slide-in{
  0%  {opacity:0;transform:translateY(36px) scale(.95);}
  65% {opacity:1;transform:translateY(-5px) scale(1.005);}
  100%{opacity:1;transform:translateY(0) scale(1);}
}
@keyframes admin-slide-out{
  0%  {opacity:1;transform:translateY(0) scale(1);}
  100%{opacity:0;transform:translateY(28px) scale(.95);}
}
/* Scan-line sweep on open */
@keyframes admin-scan{
  0%  {top:0;opacity:.8;}
  100%{top:100%;opacity:0;}
}
/* Periodic border glow pulse */
@keyframes admin-glow{
  0%,100%{box-shadow:0 0 20px #e9456033,0 0 60px #e9456011;}
  50%    {box-shadow:0 0 40px #e9456077,0 0 100px #e9456033;}
}
/* Title glitch */
@keyframes title-glitch{
  0%,88%,100%{clip-path:none;transform:none;opacity:1;}
  90%{clip-path:inset(15% 0 55% 0);transform:translateX(-4px);opacity:.9;}
  92%{clip-path:inset(55% 0 15% 0);transform:translateX(4px);opacity:.9;}
  94%{clip-path:none;transform:none;opacity:1;}
}
/* Tab stagger */
@keyframes tab-pop{
  from{opacity:0;transform:translateY(-10px);}
  to  {opacity:1;transform:translateY(0);}
}
/* Page content slide */
@keyframes page-fade{
  from{opacity:0;transform:translateX(10px);}
  to  {opacity:1;transform:translateX(0);}
}

#admin-panel{
  background:#0d0f16;border:1px solid #e94560;border-radius:16px;
  width:min(640px,96vw);max-height:88vh;display:flex;flex-direction:column;
  overflow:hidden;position:relative;
  animation:admin-slide-in .22s cubic-bezier(.22,1,.36,1) forwards,
             admin-glow 3s ease-in-out .3s infinite;
}
#admin-panel.closing{
  animation:admin-slide-out .22s ease-in forwards!important;
}
/* Scan line sweeps down once on open */
#admin-panel::after{
  content:'';position:absolute;left:0;right:0;height:3px;top:0;
  background:linear-gradient(90deg,transparent,#e9456066,#e94560cc,#e9456066,transparent);
  animation:admin-scan .3s ease-out .02s forwards;
  pointer-events:none;z-index:20;
}

#admin-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 20px;background:linear-gradient(135deg,#1a0810,#0d0f16);
  border-bottom:1px solid #e94560;flex-shrink:0;
}
#admin-title{
  display:flex;align-items:center;gap:10px;
  font-family:'Orbitron',sans-serif;font-size:1rem;font-weight:900;
  letter-spacing:.2em;color:#e94560;text-shadow:0 0 16px #e9456088;
  animation:title-glitch 7s ease-in-out 2s infinite;
}
}
#admin-title-icon{font-size:1.2rem;animation:pulse-red 1.5s ease-in-out infinite}
@keyframes pulse-red{0%,100%{filter:drop-shadow(0 0 4px #e94560)}50%{filter:drop-shadow(0 0 12px #e94560)}}
#admin-status-dot{
  width:8px;height:8px;border-radius:50%;background:#4ecca3;
  box-shadow:0 0 8px #4ecca3;animation:blink-dot 2s ease-in-out infinite;
}
@keyframes blink-dot{0%,100%{opacity:1}50%{opacity:.3}}
#admin-close{
  background:transparent;border:1px solid #e94560;color:#e94560;
  width:30px;height:30px;border-radius:6px;cursor:pointer;font-size:.85rem;
  display:flex;align-items:center;justify-content:center;transition:all .2s;
}
#admin-close:hover{background:#e94560;color:#fff}

#admin-tabs{
  display:flex;gap:0;border-bottom:1px solid #1f2535;flex-shrink:0;
  overflow-x:auto;scrollbar-width:none;
}
#admin-tabs::-webkit-scrollbar{display:none}
.admin-tab{
  background:transparent;border:none;border-bottom:2px solid transparent;
  color:#3a3f55;font-family:'Orbitron',sans-serif;font-size:.6rem;font-weight:700;
  letter-spacing:.1em;padding:10px 14px;cursor:pointer;transition:all .18s;white-space:nowrap;
}
.admin-tab:hover{color:#c8cfe0}
.admin-tab.active{color:#e94560;border-bottom-color:#e94560}

.admin-page{display:none;flex-direction:column;gap:10px;padding:16px 20px;overflow-y:auto;flex:1}
.admin-page.active{display:flex}

.admin-section-label{
  font-family:'Orbitron',sans-serif;font-size:.58rem;font-weight:700;
  letter-spacing:.2em;color:#3a3f55;padding-bottom:6px;border-bottom:1px solid #1f2535;
}
.admin-textarea{
  background:#0b0c10;border:1px solid #1f2535;color:#c8cfe0;
  font-family:'Share Tech Mono',monospace;font-size:.82rem;
  padding:10px 12px;border-radius:8px;resize:vertical;min-height:70px;
  outline:none;transition:border-color .2s;width:100%;
}
.admin-textarea:focus{border-color:#e94560}
.admin-input{
  background:#0b0c10;border:1px solid #1f2535;color:#c8cfe0;
  font-family:'Share Tech Mono',monospace;font-size:.8rem;
  padding:8px 10px;border-radius:6px;outline:none;transition:border-color .2s;
}
.admin-input:focus{border-color:#e94560}
.admin-input.wide{flex:1;width:100%}
.admin-select{
  background:#0b0c10;border:1px solid #1f2535;color:#c8cfe0;
  font-family:'Share Tech Mono',monospace;font-size:.75rem;
  padding:8px 10px;border-radius:6px;outline:none;cursor:pointer;
}
.admin-select.wide{flex:1}
.admin-hint{font-size:.65rem;color:#3a3f55;white-space:nowrap}
.admin-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}

.admin-btn{
  background:transparent;border:1px solid #3a3f55;color:#c8cfe0;
  font-family:'Orbitron',sans-serif;font-size:.62rem;font-weight:700;letter-spacing:.1em;
  padding:8px 14px;border-radius:6px;cursor:pointer;transition:all .2s;white-space:nowrap;
}
.admin-btn:hover{border-color:#c8cfe0;color:#fff}
.admin-btn.primary{border-color:#e94560;color:#e94560}
.admin-btn.primary:hover{background:#e94560;color:#fff;box-shadow:0 0 12px #e9456055}
.admin-btn.gold{border-color:#f5c842;color:#f5c842}
.admin-btn.gold:hover{background:#f5c842;color:#0b0c10;box-shadow:0 0 12px #f5c84255}
.admin-btn.gem{border-color:#a78bfa;color:#a78bfa}
.admin-btn.gem:hover{background:#a78bfa;color:#0b0c10;box-shadow:0 0 12px #a78bfa55}
.admin-btn.danger{border-color:#e94560;color:#e94560}
.admin-btn.danger:hover{background:#e94560;color:#fff}

/* Quick message buttons */
#admin-quick-msgs{display:flex;flex-wrap:wrap;gap:6px}
.admin-quick-btn{
  background:#13151c;border:1px solid #1f2535;color:#3a3f55;
  font-family:'Share Tech Mono',monospace;font-size:.68rem;
  padding:6px 10px;border-radius:6px;cursor:pointer;transition:all .18s;
}
.admin-quick-btn:hover{border-color:#e94560;color:#e94560}

/* Poll options */
#admin-poll-options{display:flex;flex-direction:column;gap:6px}
#admin-poll-results{display:flex;flex-direction:column;gap:6px}
.admin-poll-result-row{display:flex;align-items:center;gap:8px;font-size:.75rem}
.admin-poll-bar-wrap{flex:1;background:#1f2535;border-radius:4px;height:8px;overflow:hidden}
.admin-poll-bar{height:100%;background:#e94560;border-radius:4px;transition:width .4s ease}
.admin-poll-label{color:#c8cfe0;min-width:80px}
.admin-poll-count{color:#3a3f55;font-size:.65rem;min-width:30px;text-align:right}

/* Abuse grid */
#admin-abuse-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.admin-abuse-btn{
  background:#13151c;border:1px solid #1f2535;color:#c8cfe0;
  font-family:'Orbitron',sans-serif;font-size:.62rem;font-weight:700;letter-spacing:.08em;
  padding:14px 10px;border-radius:10px;cursor:pointer;transition:all .2s;text-align:center;
}
.admin-abuse-btn:hover{border-color:#e94560;color:#e94560;background:#1a0808;box-shadow:0 0 12px #e9456022}
.admin-abuse-btn.danger{border-color:#e94560;color:#e94560}
.admin-abuse-btn.danger:hover{background:#e94560;color:#fff;box-shadow:0 0 16px #e9456066}

/* Log */
#admin-log-list{display:flex;flex-direction:column;gap:4px;max-height:300px;overflow-y:auto}
.admin-log-entry{
  font-size:.68rem;color:#3a3f55;padding:5px 8px;border-radius:4px;
  background:#0b0c10;border-left:2px solid #1f2535;
}
.admin-log-entry.sent{border-left-color:#e94560;color:#c8cfe0}

#admin-footer{
  display:flex;align-items:center;justify-content:space-between;
  padding:8px 20px;border-top:1px solid #1f2535;flex-shrink:0;
  font-size:.6rem;color:#3a3f55;letter-spacing:.06em;
}

/* ── Announcement overlay — stacking toasts ── */
#announce-overlay{
  position:fixed;top:20px;right:20px;
  z-index:800;pointer-events:none;
  display:flex;flex-direction:column;gap:8px;align-items:flex-end;
  max-width:min(360px,90vw);
}
@keyframes toast-in{
  from{opacity:0;transform:translateX(20px) scale(.96);}
  to  {opacity:1;transform:translateX(0) scale(1);}
}
@keyframes toast-out{
  from{opacity:1;transform:translateX(0) scale(1);max-height:200px;margin-bottom:0}
  to  {opacity:0;transform:translateX(20px) scale(.94);max-height:0;margin-bottom:-8px}
}
.announce-toast{
  background:rgba(13,15,22,.97);border-radius:12px;
  padding:12px 34px 10px 14px;width:100%;
  display:flex;flex-direction:column;gap:6px;position:relative;
  box-shadow:0 4px 24px #00000088;cursor:pointer;pointer-events:auto;
  animation:toast-in .3s cubic-bezier(.22,1,.36,1) forwards;
}
.announce-toast.announce-toast-out{animation:toast-out .28s ease-in forwards}
.announce-toast.style-info   {border:1px solid #4ecca3}
.announce-toast.style-warning{border:1px solid #f5a623}
.announce-toast.style-success{border:1px solid #4ecca3}
.announce-toast.style-danger {border:1px solid #e94560}
.announce-toast.style-gold   {border:1px solid #f5c842}
.announce-icon{font-size:1rem}
.announce-text{font-family:'Share Tech Mono',monospace;font-size:.8rem;color:#c8cfe0;line-height:1.5}
.announce-bar{height:3px;background:#1f2535;border-radius:2px;overflow:hidden}
.announce-bar-fill{height:100%;background:#e94560;border-radius:2px;width:100%}
.announce-toast.style-info    .announce-bar-fill,
.announce-toast.style-success .announce-bar-fill{background:#4ecca3}
.announce-toast.style-warning .announce-bar-fill{background:#f5a623}
.announce-toast.style-gold    .announce-bar-fill{background:#f5c842}
.announce-close{
  position:absolute;top:7px;right:9px;
  background:transparent;border:none;color:rgba(255,255,255,.3);
  font-size:.7rem;cursor:pointer;line-height:1;padding:2px 4px;transition:color .15s;
}
.announce-close:hover{color:#fff}

/* ── Poll overlay ── */
#poll-overlay{
  position:fixed;bottom:24px;right:20px;z-index:800;
  width:min(280px,90vw);
}
#poll-overlay.hidden{display:none}
#poll-box{
  background:rgba(13,15,22,.97);border:1px solid #b07aff;border-radius:12px;
  padding:14px 16px;display:flex;flex-direction:column;gap:10px;
  box-shadow:0 4px 32px #b07aff22;
  animation:announce-drop .4s cubic-bezier(.34,1.56,.64,1) forwards;
}
#poll-question{
  font-family:'Orbitron',sans-serif;font-size:.72rem;font-weight:700;
  color:#b07aff;letter-spacing:.06em;line-height:1.4;
}
#poll-options{display:flex;flex-direction:column;gap:5px}
.poll-option-btn{
  background:#13151c;border:1px solid #1f2535;color:#c8cfe0;
  font-family:'Share Tech Mono',monospace;font-size:.75rem;
  padding:8px 12px;border-radius:6px;cursor:pointer;transition:all .18s;
  text-align:left;display:flex;align-items:center;justify-content:space-between;
}
.poll-option-btn:hover:not(:disabled){border-color:#b07aff;color:#b07aff}
.poll-option-btn.voted{border-color:#b07aff;background:#1a1030;color:#b07aff}
.poll-option-btn:disabled{cursor:default}
.poll-option-pct{font-size:.65rem;color:#3a3f55;margin-left:8px}
.poll-option-btn.voted .poll-option-pct{color:#b07aff}
#poll-timer{font-size:.6rem;color:#3a3f55;text-align:right;letter-spacing:.06em}

/* ── Inventory stacking & merge ── */
.inv-item-name-row{display:flex;align-items:center;gap:6px}
.inv-stack-badge{
  font-family:'Orbitron',sans-serif;font-size:.58rem;font-weight:700;
  color:var(--accent2);background:#0d1a14;border:1px solid #1f3a2a;
  border-radius:8px;padding:1px 7px;flex-shrink:0;
}
.inv-stack-badge.merge-ready{
  color:#ff9f43;background:#1a1000;border-color:#ff9f43;
  box-shadow:0 0 8px #ff9f4344;animation:merge-pulse .9s ease-in-out infinite;
}
@keyframes merge-pulse{0%,100%{box-shadow:0 0 6px #ff9f4344}50%{box-shadow:0 0 14px #ff9f43aa}}

.inv-merge-btn{
  background:linear-gradient(135deg,#1a1000,#0d0c00);
  border:1px solid #ff9f43;color:#ff9f43;
  font-family:'Orbitron',sans-serif;font-size:.6rem;font-weight:700;letter-spacing:.1em;
  padding:5px 12px;border-radius:6px;cursor:pointer;transition:all .2s;
  margin-top:4px;align-self:flex-start;
}
.inv-merge-btn:hover{background:#ff9f43;color:#0b0c10;box-shadow:0 0 14px #ff9f4366}

/* Evolved item rarity in inventory list */
.inv-item-rarity[style*="ff9f43"]{
  box-shadow:0 0 6px #ff9f4333;
}

/* ── Evolved equipped slot ── */
.equipped-slot.evolved-slot{
  border-color:#ff9f43!important;
  background:linear-gradient(135deg,#1a1000,#0d1018)!important;
  box-shadow:0 0 20px #ff9f4322!important;
}
.equipped-slot.evolved-slot:hover{box-shadow:0 0 28px #ff9f4344!important}
.slot-stack-count{
  font-family:'Orbitron',sans-serif;font-size:.58rem;font-weight:700;
  color:var(--accent2);background:#0d1a14;border:1px solid #1f3a2a;
  border-radius:6px;padding:1px 6px;margin-top:2px;
}

/* ═══════════════════════════════════════════════════════════════
   ADMIN PASSWORD GATE
═══════════════════════════════════════════════════════════════ */
#admin-password-gate{
  position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:1000;
  display:flex;align-items:center;justify-content:center;
  backdrop-filter:blur(8px);outline:none;
}
#admin-password-gate.hidden{display:none}

#pw-box{
  background:#0d0f16;border:1px solid #e94560;border-radius:16px;
  padding:32px 28px;width:min(360px,94vw);display:flex;flex-direction:column;
  align-items:center;gap:16px;box-shadow:0 0 60px #e9456044;
}
#pw-title{
  font-family:'Orbitron',sans-serif;font-size:1rem;font-weight:900;
  letter-spacing:.2em;color:#e94560;text-shadow:0 0 16px #e9456088;
}
#pw-subtitle{font-size:.7rem;color:#3a3f55;letter-spacing:.1em}

#pw-dots{display:flex;gap:12px;align-items:center}
.pw-dot{
  width:14px;height:14px;border-radius:50%;
  border:2px solid #3a3f55;background:transparent;
  transition:all .15s;
}
.pw-dot.filled{background:#e94560;border-color:#e94560;box-shadow:0 0 8px #e9456088}
@keyframes pw-shake{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-6px)}40%,80%{transform:translateX(6px)}}
#pw-dots.pw-shake{animation:pw-shake .4s ease}

#pw-error{
  font-family:'Orbitron',sans-serif;font-size:.65rem;font-weight:700;
  color:#e94560;letter-spacing:.15em;min-height:16px;
}

#pw-keypad{
  display:grid;grid-template-columns:repeat(7,1fr);gap:5px;width:100%;
}
.pw-key{
  background:#13151c;border:1px solid #1f2535;color:#c8cfe0;
  font-family:'Orbitron',sans-serif;font-size:.65rem;font-weight:700;
  padding:10px 4px;border-radius:6px;cursor:pointer;transition:all .15s;
  text-align:center;
}
.pw-key:hover{background:#1f2535;border-color:#e94560;color:#e94560}
.pw-key:active{transform:scale(.92);background:#e94560;color:#fff}
.pw-back{grid-column:span 2;color:#f5a623;border-color:#f5a623}
.pw-back:hover{background:#f5a623;color:#0b0c10}
.pw-enter{grid-column:span 3;background:#e94560;border-color:#e94560;color:#fff;font-size:.7rem}
.pw-enter:hover{background:#ff5577;box-shadow:0 0 12px #e9456055}

.pw-cancel{
  background:transparent;border:none;color:#3a3f55;
  font-family:'Orbitron',sans-serif;font-size:.6rem;letter-spacing:.1em;
  cursor:pointer;transition:color .2s;padding:4px 8px;
}
.pw-cancel:hover{color:#c8cfe0}

/* ── Admin panel scrollable fix ── */
.admin-page{overflow-y:auto;flex:1;min-height:0}
/* Staggered tab pop-in — fast */
#admin-tabs .admin-tab{opacity:0;animation:tab-pop .18s ease forwards;}
#admin-tabs .admin-tab:nth-child(1){animation-delay:.08s}
#admin-tabs .admin-tab:nth-child(2){animation-delay:.11s}
#admin-tabs .admin-tab:nth-child(3){animation-delay:.14s}
#admin-tabs .admin-tab:nth-child(4){animation-delay:.17s}
#admin-tabs .admin-tab:nth-child(5){animation-delay:.20s}
#admin-tabs .admin-tab:nth-child(6){animation-delay:.23s}
/* Page content slide on tab switch */
.admin-page.active{animation:page-fade .12s ease forwards;}

/* ═══════════════════════════════════════════════════════════════
   PRIVACY POLICY
═══════════════════════════════════════════════════════════════ */
.privacy-link{
  font-size:.62rem;color:#3a3f55;letter-spacing:.08em;
  text-decoration:none;transition:color .2s;margin-top:2px;
}
.privacy-link:hover{color:var(--accent2)}

#privacy-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:500;
  display:flex;align-items:center;justify-content:center;
  backdrop-filter:blur(4px);padding:20px;
}
#privacy-overlay.hidden{display:none}
#privacy-box{
  background:var(--panel);border:1px solid var(--border);border-radius:16px;
  width:min(600px,96vw);max-height:88vh;display:flex;flex-direction:column;
  box-shadow:0 0 80px #00000099;overflow:hidden;
}
#privacy-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 24px;border-bottom:1px solid var(--border);flex-shrink:0;
}
#privacy-title{
  font-family:'Orbitron',sans-serif;font-size:1rem;font-weight:900;
  letter-spacing:.12em;color:var(--accent2);
}
#btn-privacy-close{
  background:transparent;border:1px solid var(--dim);color:var(--dim);
  width:28px;height:28px;border-radius:6px;cursor:pointer;font-size:.8rem;
  display:flex;align-items:center;justify-content:center;transition:all .2s;
}
#btn-privacy-close:hover{border-color:var(--accent);color:var(--accent)}
#privacy-content{
  overflow-y:auto;padding:20px 24px;flex:1;display:flex;flex-direction:column;gap:10px;
}
.pp-updated{font-size:.65rem;color:var(--dim);letter-spacing:.06em}
.pp-h{
  font-family:'Orbitron',sans-serif;font-size:.72rem;font-weight:700;
  letter-spacing:.1em;color:var(--accent2);margin-top:6px;
}
.pp-p{font-size:.75rem;color:var(--dim);line-height:1.7}
.pp-p strong{color:var(--text)}
.pp-p code{background:#0d1018;border:1px solid var(--border);border-radius:3px;padding:1px 5px;font-size:.7rem;color:var(--accent2)}
.pp-p a{color:var(--accent2);text-decoration:none}
.pp-p a:hover{text-decoration:underline}
.pp-list{list-style:none;display:flex;flex-direction:column;gap:4px;padding-left:8px}
.pp-list li{font-size:.73rem;color:var(--dim);line-height:1.6;padding-left:12px;border-left:2px solid var(--border)}
#privacy-box .menu-btn{flex-shrink:0;margin:0 24px 20px}

/* ── Poll live results bars ── */
.poll-live-bar-wrap{
  height:4px;background:#1f2535;border-radius:2px;overflow:hidden;
  margin:-2px 0 4px 0;
}
.poll-live-bar{
  height:100%;background:#b07aff;border-radius:2px;
  transition:width .4s ease;
}
.poll-option-btn.voted .poll-option-pct{color:#b07aff;font-weight:700}

/* ── Admin quick-access button ── */
.admin-quick-access-btn{
  position:fixed;bottom:20px;right:20px;
  background:rgba(13,15,22,.95);border:2px solid #e94560;color:#e94560;
  font-size:1.1rem;width:44px;height:44px;border-radius:50%;
  cursor:pointer;z-index:400;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 0 16px #e9456055;
  transition:all .2s;
  animation:quick-pulse 2s ease-in-out infinite;
}
.admin-quick-access-btn:hover{
  background:#e94560;color:#fff;
  box-shadow:0 0 24px #e9456099;transform:scale(1.1);
}
@keyframes quick-pulse{
  0%,100%{box-shadow:0 0 12px #e9456055}
  50%{box-shadow:0 0 24px #e9456099}
}

/* ── Password gate: hide cancel when mode is 'open' ── */
#admin-password-gate[data-mode="open"] .pw-cancel{opacity:0;pointer-events:none}

/* (announce close button styles now in .announce-close above) */

/* ── Achievements ── */
#achievements-list{display:flex;flex-direction:column;gap:8px}
.ach-item{
  display:flex;align-items:center;gap:14px;
  background:#0d1018;border:1px solid var(--border);border-radius:10px;
  padding:12px 16px;transition:border-color .2s;
}
.ach-item:not(.ach-locked){border-color:var(--gold);background:linear-gradient(135deg,#1a1408,#0d1018)}
.ach-locked{opacity:.45}
.ach-icon{font-size:1.8rem;flex-shrink:0;width:36px;text-align:center}
.ach-body{flex:1;display:flex;flex-direction:column;gap:3px}
.ach-name{font-family:'Orbitron',sans-serif;font-size:.78rem;font-weight:700;color:#fff}
.ach-locked .ach-name{color:var(--dim)}
.ach-desc{font-size:.68rem;color:var(--dim);line-height:1.4}
.ach-badge{font-size:.65rem;color:var(--gold);white-space:nowrap;flex-shrink:0}
