:root{--bg-deep: #020210;--bg-panel: #08081A;--bg-card: #0c0c22;--bg-btn: #10102a;--border-cyan: #00b4c8;--border-dim: #1a1a40;--cyan: #00ffff;--magenta: #ff00ff;--pink: #ff3296;--green: #32ff64;--gold: #ffd700;--orange: #ffa028;--ice: #96dcff;--blue: #5078ff;--red: #ff3232;--text: #c8c8dc;--text-dim: #606080;--text-bright: #e8e8f0;--font-display: "Orbitron", sans-serif;--font-mono: "Share Tech Mono", "Consolas", monospace}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body{width:100%;height:100%;overflow:hidden;background:var(--bg-deep);font-family:var(--font-mono);color:var(--text);-webkit-user-select:none;user-select:none}body{display:flex;justify-content:center;align-items:center}.game-container{display:flex;flex-direction:row;border:1px solid var(--border-cyan);box-shadow:0 0 30px #00b4c826,inset 0 0 30px #00000080}.game-container.hidden{display:none}#renderTarget{display:block;background:#040410;cursor:crosshair}#renderTarget canvas{display:block}.css2d-renderer{position:absolute;top:0;left:0;pointer-events:none}.sidebar{width:280px;height:960px;background:var(--bg-panel);border-left:2px solid var(--border-cyan);display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:var(--border-dim) var(--bg-panel)}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-track{background:var(--bg-panel)}.sidebar::-webkit-scrollbar-thumb{background:var(--border-dim);border-radius:3px}.sb-header{display:flex;justify-content:space-between;align-items:center;padding:6px 14px 4px;border-bottom:1px solid var(--border-dim)}.sb-title{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--pink);text-shadow:0 0 10px rgba(255,50,150,.5);letter-spacing:2px}.sb-controls{display:flex;align-items:center;gap:8px}.sb-icon-btn{background:none;border:1px solid var(--border-dim);color:var(--text);font-size:16px;cursor:pointer;padding:2px 6px;border-radius:3px;transition:border-color .2s,box-shadow .2s}.sb-icon-btn:hover{border-color:var(--cyan);box-shadow:0 0 8px #00ffff4d}.sb-icon-btn-fs{color:var(--green);border-color:#32ff6459;font-size:18px}.sb-icon-btn-fs:hover{border-color:var(--green);box-shadow:0 0 8px #32ff6466}.speed-badge{font-family:var(--font-display);font-size:11px;color:var(--orange);background:#ffa0281f;border:1px solid var(--orange);padding:2px 6px;border-radius:3px;animation:pulse-glow-orange 1.5s ease-in-out infinite}.speed-badge.hidden{display:none}@keyframes pulse-glow-orange{0%,to{box-shadow:0 0 4px #ffa0284d}50%{box-shadow:0 0 12px #ffa02899}}.sb-resources{padding:5px 14px;border-bottom:1px solid var(--border-dim)}.res-inline{display:flex;align-items:baseline;gap:10px}.res-cell{display:flex;align-items:baseline;gap:4px}.res-label{font-family:var(--font-display);font-size:9px;color:var(--text-dim);letter-spacing:.5px}.res-value{font-family:var(--font-display);font-size:16px;font-weight:700}.res-wave{color:var(--magenta);text-shadow:0 0 8px rgba(255,0,255,.4)}.res-gold{color:var(--gold);text-shadow:0 0 8px rgba(255,215,0,.4)}.res-lives{color:var(--green);text-shadow:0 0 8px rgba(50,255,100,.4)}.res-lives.warning{color:#fd4;text-shadow:0 0 8px rgba(255,220,60,.5)}.res-lives.critical{color:var(--red);text-shadow:0 0 12px rgba(255,50,50,.6);animation:pulse-crit .8s infinite}@keyframes pulse-crit{0%,to{opacity:1}50%{opacity:.6}}.res-status{font-size:11px;color:var(--text-dim);margin-left:auto}.res-status.active{color:var(--cyan)}.res-status.preparing{color:var(--orange)}.gold-delta{font-size:14px;font-weight:700;transition:opacity .3s}.gold-delta.positive{color:var(--green)}.gold-delta.negative{color:var(--red)}.sb-section{padding:4px 14px;border-bottom:1px solid var(--border-dim)}.sb-section-title{font-family:var(--font-display);font-size:10px;color:var(--border-cyan);letter-spacing:2px;margin-bottom:3px;padding-bottom:2px;border-bottom:1px solid rgba(0,180,200,.2)}.sb-tower-panel{flex:1;min-height:160px;border-bottom:none}.research-progress{position:relative;height:18px;background:var(--bg-card);border:1px solid var(--blue);border-radius:3px;margin-bottom:4px;overflow:hidden;transition:opacity .15s}.research-progress.hidden{opacity:0;pointer-events:none}.res-prg-fill{height:100%;background:linear-gradient(90deg,#5078ff4d,#5078ff26);transition:width .15s}.res-prg-text{position:absolute;top:0;left:8px;line-height:18px;font-size:10px;color:var(--blue)}.research-tracks{display:flex;flex-direction:column;gap:4px}.research-track{background:#08081899;border:1px solid var(--border-dim);border-radius:4px;padding:4px 5px}.rt-header{display:flex;align-items:center;gap:5px;margin-bottom:2px}.rt-icon{font-size:12px}.rt-name{flex:1;font-family:var(--font-display);font-size:11px;color:var(--text);text-transform:uppercase;letter-spacing:.5px}.rt-progress{font-size:10px;color:var(--text-dim);font-family:var(--font-mono)}.rt-completed{display:flex;flex-wrap:wrap;gap:2px;margin-bottom:2px}.rt-chip{font-size:8px;padding:0 4px;border-radius:2px;background:#00ffff14;border:1px solid rgba(0,255,255,.2);color:var(--cyan);font-family:var(--font-mono);cursor:default}.rt-chip-branch{background:#ffd70014;border-color:#ffd70040;color:var(--gold)}.rt-chip-final{background:#32ff6414;border-color:#32ff6440;color:var(--green)}.rt-actions{display:flex;flex-direction:column;gap:2px}.rt-complete{font-size:9px;color:var(--green);text-align:center;padding:1px;font-family:var(--font-mono)}.rt-choice-label{font-size:8px;color:var(--gold);text-transform:uppercase;letter-spacing:.5px;margin-bottom:1px;font-family:var(--font-display)}.rt-choice-row{display:flex;gap:3px}.rt-btn{display:flex;flex-direction:column;width:100%;padding:3px 6px;background:var(--bg-btn);border:1px solid var(--border-dim);border-radius:3px;cursor:pointer;color:var(--text);font-family:var(--font-mono);font-size:10px;transition:all .15s;text-align:left}.rt-btn:hover:not(.disabled){border-color:var(--green);box-shadow:0 0 8px #32ff6433}.rt-btn.disabled{opacity:.5;cursor:default}.rt-btn.active-research{border-color:var(--blue);background:#5078ff14}.rt-btn-choice{flex:1;min-width:0}.rt-btn-name{font-weight:700;font-size:10px;color:var(--text)}.rt-btn-desc{font-size:8px;color:var(--text-dim);margin:0;line-height:1.2}.rt-btn-cost{font-size:9px;text-align:right;align-self:flex-end}.rt-btn-cost.affordable{color:var(--gold)}.rt-btn-cost.unaffordable{color:var(--text-dim)}.rt-btn-cost.researching{color:var(--blue)}.rt-btn-unlocks{font-size:8px;color:var(--gold);opacity:.85;font-style:italic;margin-top:1px}.tower-buttons{display:flex;flex-direction:column;gap:2px}.tower-btn{display:block;width:100%;padding:4px 8px;background:var(--bg-btn);border:1px solid var(--border-dim);border-radius:4px;cursor:pointer;color:var(--text);font-family:var(--font-mono);text-align:left;transition:all .15s;touch-action:manipulation}.tower-btn:hover:not(.unaffordable){border-color:var(--tw-color);box-shadow:0 0 10px var(--tw-glow);background:#ffffff08}.tower-btn.selected{border-color:var(--tw-color);box-shadow:0 0 14px var(--tw-glow),inset 0 0 20px #0000004d;background:#ffffff0a}.tower-btn.unaffordable{opacity:.4;cursor:default}.tw-header{display:flex;align-items:center;gap:6px}.tw-hotkey{display:inline-block;width:18px;height:18px;line-height:18px;text-align:center;font-size:11px;font-family:var(--font-display);color:var(--text-dim);border:1px solid var(--border-dim);border-radius:3px}.tw-name{font-family:var(--font-display);font-size:13px;font-weight:700;color:var(--tw-color)}.tw-cost{margin-left:auto;font-size:13px;color:var(--gold)}.tw-desc{font-size:11px;color:var(--text-dim);margin-top:1px;padding-left:0}.tower-panel{min-height:120px}.tower-panel-empty{color:var(--text-dim);font-size:12px;text-align:center;padding:14px 10px}.tp-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2px}.tp-name{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--tw-color);text-shadow:0 0 6px var(--tw-color)}.tp-level{font-size:11px;color:var(--gold)}.tp-desc{font-size:11px;color:var(--text-dim);margin-bottom:2px}.tp-stats{font-size:11px;color:var(--text);margin-bottom:1px}.tp-stats-extra{font-size:10px;color:var(--ice);margin-bottom:2px}.tp-hint{font-size:11px;color:var(--text-dim);font-style:italic}.tp-stat{font-size:11px;color:var(--text)}.tp-tracker{font-size:10px;color:var(--text-dim);margin:1px 0}.tp-hp{margin:2px 0}.tp-hp-text{font-size:11px}.tp-hp.hp-good .tp-hp-text{color:var(--green)}.tp-hp.hp-warn .tp-hp-text{color:#fd4}.tp-hp.hp-crit .tp-hp-text{color:var(--red)}.tp-hp-bar{height:8px;background:#1a1a2e;border:1px solid #333;border-radius:2px;margin-top:2px;overflow:hidden}.tp-hp-fill{height:100%;transition:width .2s}.tp-hp.hp-good .tp-hp-fill{background:var(--green)}.tp-hp.hp-warn .tp-hp-fill{background:#fd4}.tp-hp.hp-crit .tp-hp-fill{background:var(--red)}.tp-shield{margin:2px 0}.tp-shield-text{font-size:11px;color:var(--ice)}.tp-shield-bar{height:6px;background:#1a1a2e;border:1px solid rgba(100,180,255,.3);border-radius:2px;margin-top:2px;overflow:hidden}.tp-shield-fill{height:100%;background:linear-gradient(90deg,#64b4ff99,#64b4ffe6);transition:width .2s}.tp-progress{position:relative;height:28px;background:var(--bg-card);border:1px solid var(--border-dim);border-radius:3px;margin:3px 0;overflow:hidden}.tp-prg-fill{height:100%;transition:width .15s}.tp-prg-building{background:#0ff3}.tp-prg-upgrading{background:#32ff6433}.tp-prg-branching{background:#ffd70033}.tp-prg-repairing{background:#64ff9633}.tp-prg-shielding{background:#64b4ff33}.tp-prg-label{position:absolute;top:0;left:8px;line-height:28px;font-size:11px;color:var(--text-bright)}.tp-actions{display:flex;flex-direction:column;gap:2px;margin-top:3px}.tp-btn{width:100%;padding:4px 10px;font-family:var(--font-mono);font-size:12px;border-radius:3px;cursor:pointer;transition:all .15s;text-align:left;border:1px solid}.tp-btn.disabled{opacity:.4;cursor:default}.tp-btn-repair{color:var(--green);background:#64ff960f;border-color:#64ff964d}.tp-btn-repair:hover:not(.disabled){box-shadow:0 0 8px #64ff964d}.tp-btn-upgrade{color:var(--green);background:#32ff640f;border-color:#32ff644d}.tp-btn-upgrade:hover:not(.disabled){box-shadow:0 0 8px #32ff644d}.tp-btn-branch{color:var(--gold);background:#ffd7000f;border-color:#ffd7004d;display:flex;flex-direction:column}.tp-btn-branch:hover:not(.disabled){box-shadow:0 0 8px #ffd7004d}.br-key{font-weight:700}.br-desc{font-size:10px;color:var(--text-dim);margin-top:1px}.br-cost{font-size:11px;color:var(--gold);margin-top:2px}.tp-branches{display:flex;gap:4px}.tp-branches .tp-btn-branch{flex:1}.tp-btn-aim{color:var(--magenta);background:#ff00ff0f;border-color:#ff00ff4d}.tp-btn-aim:hover{box-shadow:0 0 8px #ff00ff4d}.tp-btn-sell{color:#cc6060;background:#c83c3c0f;border-color:#c83c3c4d}.tp-btn-sell:hover{box-shadow:0 0 8px #c83c3c4d}.tp-btn-shield{color:var(--ice);background:#64b4ff0f;border-color:#64b4ff4d}.tp-btn-shield:hover:not(.disabled){box-shadow:0 0 8px #64b4ff4d}.tp-btn-overcharge{color:#ffc832;background:#ffc83214;border-color:#ffc83259}.tp-btn-overcharge:hover:not(.disabled){box-shadow:0 0 10px #ffc83259}.tp-overcharge-active{font-size:11px;padding:4px 8px;margin-top:2px;color:#ffc832;background:#ffc8321a;border:1px solid rgba(255,200,50,.3);border-radius:4px;text-align:center;animation:overcharge-pulse 1.5s ease-in-out infinite}@keyframes overcharge-pulse{0%,to{border-color:#ffc8324d}50%{border-color:#ffc832b3;box-shadow:0 0 8px #ffc83233}}.tp-maxed{font-size:11px;color:var(--text-dim);padding:2px 0}.tp-power{font-size:10px;padding:2px 6px;margin:2px 0;border-radius:3px;font-family:Share Tech Mono,monospace}.tp-power-on{color:#ffc832;background:#ffc8321a;border:1px solid rgba(255,200,50,.3)}.tp-power-off{color:#ff6464;background:#ff50501a;border:1px solid rgba(255,80,80,.3);animation:power-pulse 1.5s ease-in-out infinite}@keyframes power-pulse{0%,to{opacity:.7}50%{opacity:1}}.message-area{padding:2px 14px 4px;display:flex;flex-direction:column;gap:2px}.hud-message{font-size:11px;padding:3px 8px;border-radius:3px;border-left:2px solid var(--pink);background:#ff32960f;color:var(--pink);transition:opacity .3s}.hud-msg-gold{border-left-color:var(--gold);color:var(--gold);background:#ffd7000f}.hud-msg-warn{border-left-color:var(--red);color:var(--red);background:#ff32320f}.hud-msg-success{border-left-color:var(--green);color:var(--green);background:#32ff640f}.hud-tooltip{display:none;position:fixed;z-index:1000;background:#0a0a24;border:1px solid var(--border-cyan);border-radius:6px;padding:10px 14px;min-width:180px;max-width:240px;box-shadow:0 0 20px #00b4c84d;pointer-events:none}.tt-title{font-family:var(--font-display);font-size:14px;font-weight:700;margin-bottom:4px}.tt-desc{font-size:11px;color:var(--text-dim);margin-bottom:6px}.tt-stat{font-size:11px;color:var(--text);padding:1px 0}.tt-note{font-size:10px;color:var(--magenta);margin-top:4px;font-style:italic}.overlay{position:fixed;inset:0;z-index:100;display:flex;justify-content:center;align-items:center;background:var(--bg-deep)}.overlay.hidden{display:none}.overlay-dim{background:#020210d1}.scanlines{position:absolute;inset:0;pointer-events:none;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.08) 2px,rgba(0,0,0,.08) 4px);z-index:1}.menu-content{position:relative;z-index:2;text-align:center;max-width:560px;width:100%;padding:20px}.menu-title{font-family:var(--font-display);font-size:56px;font-weight:900;color:var(--cyan);text-shadow:0 0 40px rgba(0,255,255,.5),0 0 80px rgba(0,255,255,.2);letter-spacing:6px;line-height:1.1;margin-bottom:8px;animation:title-glow 3s ease-in-out infinite}@keyframes title-glow{0%,to{text-shadow:0 0 30px rgba(0,255,255,.4),0 0 60px rgba(0,255,255,.15)}50%{text-shadow:0 0 50px rgba(0,255,255,.7),0 0 100px rgba(0,255,255,.3)}}.menu-subtitle{font-family:var(--font-display);font-size:18px;color:var(--magenta);letter-spacing:8px;margin-bottom:16px;text-shadow:0 0 12px rgba(255,0,255,.4)}.menu-divider{width:200px;height:1px;background:linear-gradient(90deg,transparent,var(--border-cyan),transparent);margin:16px auto}.menu-keys{font-size:12px;color:var(--text-dim);line-height:1.8;margin-top:12px}.menu-section-title{font-family:var(--font-display);font-size:13px;color:var(--gold);letter-spacing:3px;margin-bottom:10px;text-shadow:0 0 8px rgba(255,215,0,.3)}.menu-btn{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--cyan);background:#00b4c814;border:2px solid var(--cyan);border-radius:6px;padding:12px 32px;cursor:pointer;letter-spacing:2px;transition:all .2s;display:inline-block;margin:6px;touch-action:manipulation}.menu-btn:hover{background:#00ffff26;box-shadow:0 0 24px #0ff6;transform:translateY(-1px)}.menu-btn-quit{color:var(--red);border-color:var(--red);background:#ff32320f}.menu-btn-quit:hover{background:#ff323226;box-shadow:0 0 24px #ff323266}.pulse-btn{animation:pulse-glow-cyan 2s ease-in-out infinite}.leaderboard-table{text-align:left;max-height:320px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border-dim) transparent}.lb-loading{text-align:center;color:var(--text-dim);padding:20px;font-size:12px}.lb-header,.lb-row{display:grid;grid-template-columns:36px 1fr 60px 60px 60px;padding:5px 10px;font-size:12px;align-items:center}.lb-header{color:var(--text-dim);border-bottom:1px solid var(--border-dim);font-family:var(--font-display);font-size:10px;letter-spacing:1px;position:sticky;top:0;background:var(--bg-deep)}.lb-row{border-bottom:1px solid rgba(26,26,64,.5);transition:background .15s}.lb-row:hover{background:#00b4c80f}.lb-row:nth-child(2n){background:#ffffff03}.lb-row:nth-child(2n):hover{background:#00b4c80f}.lb-rank{font-family:var(--font-display);font-weight:700}.lb-row.rank-1 .lb-rank{color:var(--gold);text-shadow:0 0 6px rgba(255,215,0,.5)}.lb-row.rank-2 .lb-rank{color:#c0c0e0}.lb-row.rank-3 .lb-rank{color:#cd7f32}.lb-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-bright)}.lb-row.rank-1 .lb-name{color:var(--gold)}.lb-waves{color:var(--magenta);text-align:center}.lb-kills{color:var(--cyan);text-align:center}.lb-time{color:var(--text-dim);text-align:center}.lb-empty{text-align:center;color:var(--text-dim);padding:20px;font-size:12px}.menu-btn-help{color:var(--gold);border-color:var(--gold);background:#ffd7000f;font-size:14px;padding:10px 28px}.menu-btn-help:hover{background:#ffd70026;box-shadow:0 0 24px #ffd70066}.htp-content{position:relative;z-index:2;max-width:640px;width:100%;max-height:90vh;display:flex;flex-direction:column;background:#040412f7;border:2px solid var(--border-cyan);border-radius:12px;box-shadow:0 0 60px #00b4c833;margin:16px}.htp-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px 12px;border-bottom:1px solid var(--border-dim);flex-shrink:0}.htp-title{font-family:var(--font-display);font-size:24px;font-weight:900;color:var(--cyan);letter-spacing:4px;text-shadow:0 0 20px rgba(0,255,255,.5);margin:0}.htp-close-btn{background:none;border:1px solid var(--border-dim);color:var(--text-dim);font-size:20px;cursor:pointer;padding:4px 10px;border-radius:4px;transition:all .2s;line-height:1}.htp-close-btn:hover{color:var(--red);border-color:var(--red);box-shadow:0 0 8px #ff32324d}.htp-scroll{flex:1;overflow-y:auto;padding:8px 24px 16px;scrollbar-width:thin;scrollbar-color:var(--border-dim) transparent}.htp-scroll::-webkit-scrollbar{width:6px}.htp-scroll::-webkit-scrollbar-track{background:transparent}.htp-scroll::-webkit-scrollbar-thumb{background:var(--border-dim);border-radius:3px}.htp-section{margin-bottom:18px}.htp-section-title{font-family:var(--font-display);font-size:13px;color:var(--gold);letter-spacing:3px;margin-bottom:8px;padding-bottom:4px;border-bottom:1px solid rgba(255,215,0,.15);text-shadow:0 0 6px rgba(255,215,0,.3)}.htp-section p{font-size:13px;color:var(--text);line-height:1.6;margin-bottom:8px}.htp-hl-gold{color:var(--gold);font-weight:700}.htp-hl-green{color:var(--green);font-weight:700}.htp-hl-cyan{color:var(--cyan);font-weight:700}.htp-note{font-size:12px!important;color:var(--text-dim)!important;margin-top:8px;font-style:italic}.htp-controls-grid{display:grid;grid-template-columns:auto 1fr;gap:6px 14px;align-items:center;font-size:13px;color:var(--text)}.htp-key{font-family:var(--font-display);font-size:11px;color:var(--cyan);background:#00ffff0f;border:1px solid rgba(0,255,255,.2);padding:2px 8px;border-radius:3px;text-align:center;min-width:48px;white-space:nowrap}.htp-tower-list{display:flex;flex-direction:column;gap:6px;margin-top:8px}.htp-tower{background:#ffffff05;border:1px solid var(--border-dim);border-left:3px solid var(--tw-c, var(--text-dim));border-radius:4px;padding:6px 10px}.htp-tw-name{font-family:var(--font-display);font-size:13px;font-weight:700;color:var(--tw-c, var(--text));letter-spacing:1px}.htp-tw-cost{font-family:var(--font-mono);font-size:12px;color:var(--gold);margin-left:6px}.htp-tw-desc{font-size:12px;color:var(--text);margin-top:2px;line-height:1.4}.htp-tw-branches{font-size:11px;color:var(--text-dim);margin-top:3px;font-style:italic}.htp-enemy-list{display:flex;flex-direction:column;gap:4px}.htp-enemy{font-size:12px;color:var(--text);line-height:1.5;padding:2px 0}.htp-en-name{font-family:var(--font-display);font-size:11px;font-weight:700;letter-spacing:.5px}.htp-en-wave{font-size:10px;color:var(--text-dim);background:#ffffff0a;border:1px solid var(--border-dim);padding:0 5px;border-radius:2px;font-family:var(--font-mono)}.htp-research-list{display:flex;flex-direction:column;gap:4px;margin-top:6px}.htp-research{font-size:12px;color:var(--text);line-height:1.5}.htp-res-icon{display:inline-block;width:20px;text-align:center}.htp-shield-stats{display:flex;flex-direction:column;gap:4px;margin-top:8px;padding:8px 12px;background:#64b4ff0a;border:1px solid rgba(100,180,255,.15);border-radius:4px;font-size:12px;color:var(--ice)}.htp-footer{padding:12px 24px 16px;text-align:center;border-top:1px solid var(--border-dim);flex-shrink:0}.pause-box{text-align:center;background:#08081af2;border:2px solid var(--cyan);border-radius:12px;padding:40px 60px;box-shadow:0 0 40px #0ff3}.pause-title{font-family:var(--font-display);font-size:36px;font-weight:700;color:var(--cyan);margin-bottom:20px;text-shadow:0 0 20px rgba(0,255,255,.5)}.pause-keys{display:flex;flex-direction:column;gap:10px;align-items:center}.gameover-box{text-align:center;background:#08081af2;border:2px solid var(--red);border-radius:12px;padding:30px 50px;max-width:480px;box-shadow:0 0 40px #ff323233}.gameover-title{font-family:var(--font-display);font-size:32px;font-weight:900;color:var(--red);margin-bottom:16px;text-shadow:0 0 20px rgba(255,50,50,.5);letter-spacing:4px}.gameover-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px 20px;margin-bottom:16px}.go-stat{display:flex;justify-content:space-between;padding:4px 8px;background:#ffffff05;border-radius:3px}.go-label{color:var(--text-dim);font-size:12px}.go-val{color:var(--text-bright);font-family:var(--font-display);font-size:14px}.gameover-submit{margin:12px 0}.go-name-label{font-size:12px;color:var(--text-dim);display:block;margin-bottom:6px}.go-name-row{display:flex;gap:8px;justify-content:center}.go-name-input{font-family:var(--font-mono);font-size:16px;color:var(--text-bright);background:var(--bg-card);border:1px solid var(--border-cyan);border-radius:4px;padding:8px 12px;width:200px;outline:none;transition:border-color .2s;-webkit-user-select:text;user-select:text}.go-name-input:focus{border-color:var(--cyan);box-shadow:0 0 10px #00ffff4d}.go-name-input::placeholder{color:var(--text-dim)}.go-submit-status{font-size:12px;margin-top:6px;min-height:18px}.go-submit-status.success{color:var(--green)}.go-submit-status.error{color:var(--red)}.canvas-wrap{position:relative;flex-shrink:0}.mobile-controls,.drawer-toggle{display:none}@media(max-height:980px)and (min-width:1025px){.game-container{transform-origin:center center;transform:scale(.85)}}@media(max-height:840px)and (min-width:1025px){.game-container{transform:scale(.75)}}@media(max-width:1024px){html,body{overflow:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}body{align-items:flex-start;justify-content:flex-start}.game-container{flex-direction:column;width:100vw;height:100dvh;border:none;box-shadow:none;overflow:hidden}.canvas-wrap{width:100%;flex-shrink:0;overflow:hidden;touch-action:none}#renderTarget{width:100%;height:auto;display:block;touch-action:none;cursor:default}.mobile-controls{display:flex;position:absolute;top:8px;right:8px;gap:8px;z-index:20}.mobile-btn{width:44px;height:44px;border-radius:8px;border:1px solid var(--border-cyan);background:#040410d9;color:var(--text);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.mobile-btn:active{background:#00b4c840}.mobile-btn-cancel{color:var(--red);border-color:var(--red);font-size:20px;font-weight:700}.mobile-btn-speed{color:var(--orange);border-color:var(--orange);font-size:14px}.mobile-btn-speed.active{background:#ffa02833;box-shadow:0 0 8px #ffa02866}.mobile-btn-pause{color:var(--cyan)}.drawer-toggle{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:10px 16px;background:var(--bg-panel);border-top:2px solid var(--border-cyan);border-bottom:1px solid var(--border-dim);cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation;flex-shrink:0;z-index:15}.drawer-arrow{font-size:14px;color:var(--cyan);transition:transform .3s ease}.drawer-toggle.open .drawer-arrow{transform:rotate(180deg)}.drawer-label{font-family:var(--font-display);font-size:11px;color:var(--border-cyan);letter-spacing:2px}.drawer-res{font-family:var(--font-display);font-size:11px;color:var(--gold);margin-left:auto}.sidebar{width:100%;height:0;max-height:0;border-left:none;border-top:none;overflow:hidden;transition:max-height .35s ease,height .35s ease;flex-shrink:1}.sidebar.drawer-open{height:auto;max-height:55dvh;overflow-y:auto}.tower-btn{padding:10px;min-height:52px}.tw-header{gap:8px}.tw-hotkey{display:none}.tw-name,.tw-cost{font-size:14px}.tw-desc{padding-left:0;font-size:12px}.rt-btn{padding:6px 8px;min-height:40px}.rt-btn-name{font-size:12px}.rt-btn-desc{font-size:10px}.rt-btn-cost{font-size:11px}.tp-btn{padding:10px 12px;font-size:13px;min-height:44px}.tp-branches{flex-direction:column}.sb-section{padding:6px 12px}.sb-resources{padding:4px 12px}.sb-header{padding:6px 12px 4px}.menu-content{max-width:100%;padding:16px}.menu-title{font-size:36px;letter-spacing:3px}.menu-subtitle{font-size:14px;letter-spacing:4px}.menu-keys{display:none}.menu-btn{padding:14px 24px;font-size:14px;min-height:48px}.htp-content{max-width:100%;max-height:95vh;margin:8px;border-radius:8px}.htp-header{padding:12px 16px 10px}.htp-title{font-size:18px;letter-spacing:2px}.htp-scroll{padding:6px 16px 12px}.htp-section p{font-size:12px}.htp-controls-grid{font-size:12px;gap:4px 10px}.htp-key{font-size:10px;min-width:40px;padding:2px 6px}.htp-tw-name{font-size:12px}.htp-tw-desc{font-size:11px}.htp-tw-branches{font-size:10px}.htp-enemy{font-size:11px}.htp-footer{padding:10px 16px 12px}.pause-box{padding:30px 24px;margin:16px}.pause-title{font-size:28px}.gameover-box{padding:20px 16px;margin:16px;max-width:calc(100vw - 32px)}.gameover-title{font-size:24px}.gameover-stats{grid-template-columns:1fr;gap:6px}.go-name-row{flex-direction:column;gap:8px}.go-name-input{width:100%;font-size:16px}.leaderboard-table{max-height:200px}.lb-header,.lb-row{grid-template-columns:28px 1fr 50px 50px 50px;padding:5px 6px;font-size:11px}.hud-tooltip{display:none!important}.sb-icon-btn{padding:6px 10px;font-size:18px;min-width:36px;min-height:36px}}@media(max-width:480px){.menu-title{font-size:28px}.menu-subtitle{font-size:12px;letter-spacing:3px}.menu-btn{padding:12px 18px;font-size:13px}.pause-box{padding:24px 16px}.gameover-box{padding:16px 12px}.gameover-title{font-size:20px;letter-spacing:2px}.leaderboard-table{max-height:160px}}@media(max-height:500px)and (max-width:1024px){.sidebar.drawer-open{max-height:45dvh}.mobile-btn{width:36px;height:36px;font-size:14px}}@media(max-width:1024px)and (orientation:landscape)and (max-height:600px){html,body{overflow:hidden}.game-container{flex-direction:row;width:100vw;height:100dvh}.canvas-wrap{flex:1 1 auto;height:100%;width:auto;display:flex;align-items:center;justify-content:center;overflow:hidden}#renderTarget{height:100%;width:auto;max-width:100%;max-height:100%}.drawer-toggle{display:none}.sidebar{width:min(220px,30vw);height:100%;max-height:none;overflow-y:auto;border-left:2px solid var(--border-cyan);flex-shrink:0}.sidebar.drawer-open{height:100%;max-height:none;overflow-y:auto}.sb-header{padding:4px 8px 3px}.sb-title{font-size:11px;letter-spacing:1px}.sb-icon-btn{padding:2px 4px;font-size:14px;min-width:28px;min-height:28px}.speed-badge{font-size:9px;padding:1px 4px}.sb-resources{padding:3px 8px}.res-inline{gap:6px}.res-label{font-size:8px;letter-spacing:.5px}.res-value{font-size:13px}.res-status{font-size:9px}.gold-delta{font-size:11px}.sb-section{padding:3px 8px}.sb-section-title{font-size:9px;letter-spacing:1px;margin-bottom:3px;padding-bottom:2px}.sb-tower-panel{min-height:100px}.research-progress{height:16px;margin-bottom:4px}.res-prg-text{font-size:9px;line-height:16px}.research-tracks{gap:3px}.research-track{padding:3px 5px}.rt-header{margin-bottom:2px}.rt-name{font-size:9px}.rt-progress{font-size:8px}.rt-chip{font-size:8px;padding:0 3px}.rt-btn{padding:3px 5px;font-size:9px;min-height:28px}.rt-btn-name{font-size:9px}.rt-btn-desc,.rt-btn-cost,.rt-choice-label{font-size:8px}.tower-buttons{gap:2px}.tower-btn{padding:4px 6px;min-height:36px}.tw-header{gap:4px}.tw-hotkey{display:none}.tw-name,.tw-cost{font-size:11px}.tw-desc{font-size:9px;padding-left:0;margin-top:1px}.tower-panel{min-height:80px}.tower-panel-empty{font-size:10px;padding:10px 6px}.tp-header{margin-bottom:2px}.tp-name{font-size:11px}.tp-level{font-size:9px}.tp-stats{font-size:9px;margin-bottom:1px}.tp-stats-extra{font-size:9px;margin-bottom:2px}.tp-tracker{font-size:9px;margin:2px 0}.tp-hp{margin:3px 0}.tp-hp-text{font-size:9px}.tp-hp-bar{height:6px}.tp-shield{margin:2px 0}.tp-shield-text{font-size:9px}.tp-shield-bar{height:4px}.tp-progress{height:22px;margin:3px 0}.tp-prg-label{font-size:9px;line-height:22px}.tp-actions{gap:2px;margin-top:3px}.tp-btn{padding:4px 6px;font-size:10px;min-height:30px}.tp-branches{gap:2px}.br-desc,.br-cost,.tp-maxed{font-size:9px}.message-area{padding:2px 8px 4px}.hud-message{font-size:9px;padding:2px 5px}}@media(max-width:600px)and (orientation:portrait){.canvas-wrap:after{content:"📱 Rotate for best experience";position:absolute;bottom:8px;left:50%;transform:translate(-50%);font-family:var(--font-display);font-size:10px;color:var(--text-dim);background:#040410cc;padding:4px 12px;border-radius:12px;pointer-events:none;z-index:10;white-space:nowrap;animation:fade-out-hint 1s 4s forwards}}@keyframes fade-out-hint{to{opacity:0}}.hp-bar-container,.build-bar-container{position:relative;pointer-events:none;transform:translate(-50%)}.hp-bar-bg,.build-bar-bg{width:36px;height:4px;background:#0009;border:1px solid rgba(255,255,255,.15);border-radius:2px;overflow:hidden}.hp-bar-fill,.build-bar-fill{height:100%;border-radius:1px;transition:width .1s linear}
