:root{--color-gold:gold;--color-gold-light:#ffea00;--color-gold-dark:#ca0;--color-purple:#c4f;--color-purple-light:#f8f;--color-red:#f44;--color-red-light:#f66;--color-green:#4eff4e;--color-blue:#4af;--color-blue-dark:#4da6ff;--color-orange:#fa4;--color-orange-warm:#f80;--color-white:#fff;--color-text:#ccc;--color-text-dim:#aaa;--color-text-muted:#888;--color-text-faint:#888;--color-bg-darkest:#0a0a1a;--color-bg-dark:#151530;--color-bg-medium:#0a1020;--font-sans:"Segoe UI", system-ui, -apple-system, sans-serif;--font-mono:"Cascadia Code", "Fira Code", "Courier New", monospace;--font-ui:"Segoe UI", system-ui, -apple-system, sans-serif;--radius-sm:4px;--radius-md:6px;--radius-lg:8px;--radius-xl:10px;--radius-2xl:14px;--radius-3xl:16px;--radius-full:50%;--space-xs:4px;--space-sm:8px;--space-md:12px;--space-lg:16px;--space-xl:20px;--space-2xl:24px;--space-3xl:30px;--z-vignette:9;--z-ui-layer:10;--z-mobile:20;--z-debug:200;--z-overlay-pause:40;--z-hud-buttons:41;--z-cheat-buttons:42;--z-overlay-codex:45;--z-overlay-levelup:50;--z-overlay-stage:55;--z-overlay-gameover:60;--z-overlay-win:65;--z-overlay-settings:120;--z-screen:100;--z-menu:110;--z-codex-menu:115;--transition-fast:.15s ease;--transition-normal:.25s ease;--transition-slow:.3s ease;--bg-dark-screen:radial-gradient(ellipse at 30% 20%, #3c64c81f 0%, transparent 60%), radial-gradient(ellipse at 70% 80%, #643cc814 0%, transparent 60%), linear-gradient(135deg, #0a0a1a 0%, #151530 50%, #0a1020 100%);--bg-overlay-dark:radial-gradient(ellipse at center, #0a0514d9 0%, #000000e6 100%);--bg-overlay-purple:radial-gradient(ellipse at center, #190523e0 0%, #000000eb 100%);--bg-overlay-red:radial-gradient(ellipse at center, #1e0505e0 0%, #000000eb 100%);--bg-overlay-win:radial-gradient(ellipse at center, #140f05e0 0%, #000000f0 100%);--bg-overlay-codex:radial-gradient(ellipse at center, #0a0514eb 0%, #000000f5 100%);--bg-overlay-stage:radial-gradient(ellipse at center, #000000d9 0%, #000000f2 100%);--bg-hud-panel:linear-gradient(135deg, #0a0a12d9, #0f0f1ec7);--bg-xp-fill:linear-gradient(90deg, #650, #ca0, gold 70%, #ffea00);--bg-card:linear-gradient(180deg, #191932eb, #0f0f1eeb);--bg-card-levelup:linear-gradient(180deg, #191932f0, #0f0f1ef0);--bg-card-codex:linear-gradient(180deg, #19192de6, #0f0f1ce6);--bg-card-evo:#1e1402f0;--btn-primary-bg:linear-gradient(135deg, #2a5a8a, #1a3a5a);--btn-primary-hover:linear-gradient(135deg, #3a7aba, #2a4a6a);--btn-gold-bg:linear-gradient(135deg, #5a4a2a, #3a2a1a);--btn-gold-hover:linear-gradient(135deg, #7a6a3a, #5a4a2a);--btn-secondary-bg:linear-gradient(135deg, #3a3a3a, #1a1a1a);--btn-secondary-hover:linear-gradient(135deg, #5a5a5a, #3a3a3a);--btn-menu-bg:linear-gradient(135deg, #3a3a5a, #2a2a3a);--btn-menu-hover:linear-gradient(135deg, #5a5a7a, #3a3a5a);--btn-ready-bg:linear-gradient(135deg, #2a6a2a, #1a4a1a);--btn-unready-bg:linear-gradient(135deg, #6a3a2a, #4a1a1a);--btn-lobby-start-bg:linear-gradient(135deg, #8a6a2a, #5a4a1a);--shadow-hud:0 4px 20px #00000080, inset 0 1px 0 #ffffff0d;--shadow-card:0 4px 16px #0006;--shadow-card-hover-gold:0 12px 32px #ffc8004d, 0 0 60px #ffc8001a;--shadow-card-hover-purple:0 12px 32px #b43cff4d, 0 0 60px #9628ff1a;--shadow-btn-primary:0 4px 15px #3264c833;--shadow-btn-primary-hover:0 6px 25px #3264c866;--shadow-btn-gold:0 4px 15px #c8960026;--shadow-btn-gold-hover:0 6px 25px #c896004d;--text-glow-gold:0 0 40px #ffc80099, 0 0 80px #ffb40033;--text-glow-purple:0 0 30px #b43cffb3, 0 0 60px #9628ff4d;--text-glow-red:0 0 40px #ff0000b3, 0 0 80px #ff00004d;--text-glow-white:0 0 30px #fff6, 0 0 60px #ffffff1a;--glass-bg:#ffffff08;--glass-border:#ffffff14;--glass-blur:12px}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}@media (prefers-contrast:more){:root{--color-text:#fff;--color-text-dim:#ddd;--color-text-muted:#bbb;--color-text-faint:#999;--color-gold:#ffe44d;--color-purple:#e7f;--color-red:#f66;--color-green:#6f6;--color-blue:#6cf;--color-orange:#fb6}.hud-panel,#stats-bar,#survival-timer{background:#000000eb!important;border-color:#ffffff4d!important}.levelup-card,.menu-card,.codex-card{background:#000000f0!important;border-color:#ffffff40!important}}*{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}html,body{width:100%;height:100%;font-family:var(--font-sans);background:#000;overflow:hidden}#game-container{width:100%;height:100%;position:absolute;top:0;left:0}canvas{display:block}#ui-layer{pointer-events:none;width:100%;height:100%;z-index:var(--z-ui-layer);position:absolute;top:0;left:0}#vignette{pointer-events:none;width:100%;height:100%;z-index:var(--z-vignette);background:radial-gradient(#0000 60%,#0006 100%);position:absolute;top:0;left:0}.fullscreen-panel{width:100%;height:100%;position:absolute;top:0;left:0}.overlay{visibility:hidden;opacity:0;pointer-events:none;transition:opacity var(--transition-slow), visibility var(--transition-slow)}.overlay.active{visibility:visible;opacity:1;pointer-events:auto}.overlay-block{visibility:hidden;opacity:0;pointer-events:none;transition:opacity var(--transition-slow), visibility var(--transition-slow)}.overlay-block.active{visibility:visible;opacity:1;pointer-events:auto}:focus-visible{outline:2px solid var(--color-gold);outline-offset:2px}.hud-panel{background:var(--bg-hud-panel);box-shadow:var(--shadow-hud);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid #ffffff1f}.icon-wrap{flex-shrink:0;justify-content:center;align-items:center;transition:transform .5s cubic-bezier(.4,0,.2,1);display:inline-flex;position:relative}.icon-glow{opacity:.7;border-radius:50%;transition:opacity .5s cubic-bezier(.4,0,.2,1);position:absolute;inset:0}.icon-wrap:hover .icon-glow{opacity:1}.icon-wrap img{z-index:1;width:100%;height:100%;display:block;position:relative}#stats-bar,#survival-timer{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:linear-gradient(135deg,#0c0c16e0,#101020d1);border:1px solid #ffffff1a;border-left:2px solid #ffc80040;box-shadow:0 4px 20px #00000080,inset 0 1px #ffffff0a,0 0 30px #0003}#stats-bar{color:#fff;text-shadow:0 0 3px #000000b3;background:linear-gradient(135deg,#0c0c16e6,#101020e0);border-left:3px solid #ffc80059;border-radius:10px;max-width:340px;padding:10px 16px;font-size:.8125rem;position:absolute;top:30px;left:12px}#stats-bar .hp{color:#4eff4e;text-shadow:0 0 6px #50ff504d;margin-bottom:6px;font-weight:700;display:block}#stats-bar .items{margin-bottom:3px;display:block}#stats-bar .score{color:#fa4;text-shadow:0 0 6px #ff88004d;margin-bottom:3px;display:block}#stats-bar .kills{color:#f64;margin-bottom:3px;display:block}#stats-bar .stage{color:#b9f;text-shadow:0 0 6px #aa88ff4d;font-size:.6875rem;display:block}#interaction-msg{color:#ffc;text-shadow:0 0 12px #ffffc880,0 0 4px #000c;opacity:0;letter-spacing:2px;font-size:1.25rem;font-weight:700;transition:opacity .2s;position:absolute;top:42%;left:50%;transform:translate(-50%,-50%)}#minimap{pointer-events:none;background:#000000bf;border:2px solid #ffffff4d;border-radius:50%;width:180px;height:180px;position:absolute;bottom:16px;right:16px;box-shadow:0 0 20px #0009,inset 0 0 30px #0000004d,0 0 0 4px #0000004d}#help-text{color:#ffffff8c;text-shadow:0 0 2px #000c;font-size:.75rem;transition:opacity 2s;position:absolute;bottom:14px;left:50%;transform:translate(-50%)}#xp-bar-container{pointer-events:none;background:#000000b3;border-bottom:1px solid #ffc80026;align-items:center;width:100%;height:23px;display:flex;position:absolute;top:0;left:0;box-shadow:0 1px 8px #0006}#xp-bar-label{z-index:2;color:gold;text-shadow:0 0 8px #ffc80066,0 0 2px #000c;font-size:.8125rem;font-weight:700;position:absolute;left:14px}#xp-bar-fill{background:var(--bg-xp-fill);border-radius:0 3px 3px 0;width:0%;height:100%;transition:width .2s ease-out;box-shadow:inset 0 0 12px #ffc80033}#survival-timer{color:#fff;text-shadow:0 0 12px #fff3,0 0 2px #000000b3;letter-spacing:1px;border:1px solid #ffffff26;border-radius:8px;padding:6px 12px;font-size:.9375rem;font-weight:700;line-height:1.4;position:absolute;top:88px;right:12px;box-shadow:0 2px 12px #0006}#upgrades-list{pointer-events:none;z-index:5;flex-direction:row;gap:8px;display:flex;position:absolute;top:165px;left:12px}.upgrades-col{flex-direction:column;gap:4px;display:flex}.upgrade-row{color:#ddd;text-shadow:0 0 2px #000c;background:#000000bf;border:1px solid #ffffff14;border-radius:4px;align-items:center;gap:6px;padding:3px 8px;font-size:.6875rem;display:flex}.upgrade-row .upg-icon{font-size:.875rem;line-height:0}.upgrade-row .upg-icon .icon-wrap{width:.875rem;height:.875rem}.upgrade-row .upg-name{color:#eee;min-width:80px}.upgrade-row .upg-rank{color:gold;font-weight:700}#status-sidebar{pointer-events:none;z-index:5;flex-direction:column;gap:6px;min-width:100px;font-size:.6875rem;display:flex;position:absolute;top:130px;right:12px}#player-stats{color:#bbb;text-shadow:0 0 2px #000c;background:#000000bf;border:1px solid #ffffff1a;border-radius:6px;flex-direction:column;gap:3px;padding:6px 10px;display:flex}#player-stats .stat-row{justify-content:space-between;gap:14px;display:flex}#player-stats .stat-val{color:gold;font-weight:700}#buff-indicator{flex-direction:column;gap:2px;display:flex}.buff-row{color:#ddd;text-shadow:0 0 2px #000c;background:#000000bf;border:1px solid #ffffff1a;border-radius:4px;align-items:center;gap:5px;padding:3px 8px;display:flex}.buff-time{color:#999;margin-left:auto;font-size:.625rem}.buff-shared{opacity:.65;border-color:#88ccff4d}#boss-passives{flex-direction:column;gap:2px;display:flex}#boss-passives .buff-row{border-left-style:solid;border-left-width:3px}#boss-hp-bar{background:#000000b3;border:1px solid #fff3;border-radius:4px;width:320px;height:18px;display:none;position:absolute;top:22px;left:50%;overflow:hidden;transform:translate(-50%)}#boss-hp-bar.active{display:block}#boss-hp-label{color:#fff;text-shadow:0 0 4px #000c;z-index:2;font-size:.6875rem;font-weight:700;line-height:18px;position:absolute;top:0;left:50%;transform:translate(-50%)}#boss-hp-fill{background:linear-gradient(90deg,#800,red);width:100%;height:100%;transition:width .15s ease-out}#boss-stagger-bar{background:#0009;border:1px solid #ffffff1a;border-radius:3px;width:320px;height:6px;display:none;position:absolute;top:42px;left:50%;overflow:hidden;transform:translate(-50%)}#boss-stagger-bar.active{display:block}#boss-stagger-fill{background:linear-gradient(90deg,#860,#fa0,#fd4);width:0%;height:100%;transition:width .2s ease-out;box-shadow:0 0 8px #fa06}#boss-stagger-bar.flash #boss-stagger-fill{background:linear-gradient(90deg,#fa0,#fd4,#fff);transition:width 50ms ease-out;box-shadow:0 0 16px #ffc800e6}#boss-announce{color:#f44;text-shadow:0 0 30px #ff0000b3,0 0 60px #ff00004d;letter-spacing:4px;font-size:1.875rem;font-weight:700;transition:opacity .5s;animation:.8s ease-in-out infinite boss-announce-pulse;display:none;position:absolute;top:30%;left:50%;transform:translate(-50%,-50%)}@keyframes boss-announce-pulse{0%,to{text-shadow:0 0 30px #ff0000b3,0 0 60px #ff00004d}50%{text-shadow:0 0 40px #ff3232e6,0 0 80px #ff000080}}#streak-indicator{color:gold;text-shadow:0 0 12px #ffc80099;opacity:0;pointer-events:none;letter-spacing:2px;font-size:1.25rem;font-weight:700;transition:opacity .2s;position:absolute;top:110px;left:50%;transform:translate(-50%)}#streak-indicator.active{opacity:1}#streak-indicator.tier2{color:#fa0;text-shadow:0 0 16px #ff9600b3}#streak-indicator.tier3{color:#f44;text-shadow:0 0 24px #ff3200e6,0 0 48px #ff140080;letter-spacing:3px;font-size:1.75rem}@media (width<=768px){#stats-bar{max-width:220px;padding:4px 8px;font-size:.625rem;top:24px}#survival-timer{padding:4px 8px;font-size:.8125rem;top:78px;right:44px}#xp-bar-container{height:18px}#xp-bar-label{font-size:.625rem;left:8px}#status-sidebar{right:4px}#player-stats{padding:3px 6px;font-size:.5625rem}#upgrades-list{gap:4px;font-size:.5625rem;top:165px;left:4px}#help-text{display:none}}#btn-settings{color:#fff;cursor:pointer;z-index:120;pointer-events:auto;background:#000000bf;border:1px solid #ffffff40;border-radius:6px;justify-content:center;align-items:center;width:38px;height:36px;font-size:1.125rem;display:flex;position:fixed;top:30px;right:12px}#btn-settings:hover{background:#ffffff26}#btn-fullscreen{color:#fff;cursor:pointer;z-index:120;pointer-events:auto;background:#000000bf;border:1px solid #ffffff40;border-radius:6px;justify-content:center;align-items:center;width:38px;height:36px;font-size:1rem;display:flex;position:fixed;top:30px;right:58px}#btn-fullscreen:hover{background:#ffffff26}#btn-codex{color:gold;cursor:pointer;width:38px;height:36px;z-index:var(--z-hud-buttons);pointer-events:auto;background:#000000a6;border:1px solid #ffc8004d;border-radius:6px;justify-content:center;align-items:center;font-size:1rem;display:flex;position:absolute;top:30px;right:104px}#btn-codex:hover{background:#ffc8001a;border-color:#ffc80080}#btn-pause{color:#fff;cursor:pointer;width:38px;height:36px;z-index:var(--z-hud-buttons);pointer-events:auto;background:#000000a6;border:1px solid #fff3;border-radius:6px;justify-content:center;align-items:center;font-size:1rem;display:flex;position:absolute;top:30px;right:150px}#btn-pause:hover{background:#ffffff1a}@media (width<=768px){#btn-pause{width:30px;height:30px;font-size:.8125rem;top:24px;right:110px}#btn-codex{width:30px;height:30px;font-size:.875rem;top:24px;right:76px}#btn-fullscreen{width:30px;height:30px;font-size:.8125rem;top:24px;right:42px}#btn-settings{width:30px;height:30px;font-size:.9375rem;top:24px;right:8px}}.btn-icon{font-family:var(--font-sans);border-radius:var(--radius-md);cursor:pointer;pointer-events:auto;width:38px;height:36px;color:var(--color-white);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;border:1px solid #ffffff1f;justify-content:center;align-items:center;font-size:1rem;font-weight:700;transition:all .2s cubic-bezier(.25,.46,.45,.94);display:flex}.btn-icon:hover{background:#ffffff14;border-color:#ffffff4d;box-shadow:0 0 16px #ffffff0f}.btn-icon.btn-gold{color:var(--color-gold);border-color:#ffc80040}.btn-icon.btn-gold:hover{background:#ffc80014;border-color:#ffc80080;box-shadow:0 0 20px #ffc8001a}.btn-primary{font-family:var(--font-sans);letter-spacing:4px;cursor:pointer;color:var(--color-white);border-radius:var(--radius-lg);background:linear-gradient(135deg,#2a5a8a 0%,#1e3f62 50%,#1a3a5a 100%);border:1px solid #64b4ff4d;padding:14px 56px;font-size:1rem;font-weight:700;transition:all .3s cubic-bezier(.25,.46,.45,.94);position:relative;box-shadow:0 4px 15px #3264c833,inset 0 1px #ffffff14}.btn-primary:hover{background:linear-gradient(135deg,#3575b0 0%,#2a5580 50%,#2a4a6a 100%);border-color:#96d2ff80;transform:scale(1.05);box-shadow:0 8px 30px #3c82ff59,0 0 60px #3c82ff1f,inset 0 1px #ffffff1f}.btn-primary:active{transition:all .1s;transform:scale(.97)}.btn-primary.btn-gold{color:var(--color-gold);background:linear-gradient(135deg,#5a4a2a 0%,#3a2a1a 50%,#2a1a0a 100%);border-color:#ffc8004d;box-shadow:0 4px 15px #c8960026,inset 0 1px #ffc8000f}.btn-primary.btn-gold:hover{background:linear-gradient(135deg,#7a6a3a 0%,#5a4a2a 50%,#3a2a1a 100%);border-color:#ffdc6480;box-shadow:0 8px 30px #c8a0004d,0 0 60px #c8a0001a,inset 0 1px #ffc8001a}.btn-secondary{font-family:var(--font-sans);letter-spacing:3px;cursor:pointer;color:#aaa;border-radius:var(--radius-lg);background:linear-gradient(135deg,#2a2a2a 0%,#1a1a1a 50%,#0f0f0f 100%);border:1px solid #ffffff1a;padding:12px 36px;font-size:.875rem;font-weight:700;transition:all .3s cubic-bezier(.25,.46,.45,.94);box-shadow:inset 0 1px #ffffff08}.btn-secondary:hover{color:#ddd;background:linear-gradient(135deg,#4a4a4a 0%,#3a3a3a 50%,#2a2a2a 100%);border-color:#ffffff40;box-shadow:0 4px 16px #0006,inset 0 1px #ffffff0f}.btn-secondary.btn-menu{color:#ccc;background:linear-gradient(135deg,#3a3a5a 0%,#2a2a3a 50%,#1a1a2a 100%);border-color:#788cc826}.btn-secondary.btn-menu:hover{color:#fff;background:linear-gradient(135deg,#5a5a7a 0%,#4a4a5a 50%,#3a3a4a 100%);border-color:#b4c8ff4d;box-shadow:0 4px 20px #5064b426,0 0 40px #5064b40d}.btn-ghost{font-family:var(--font-sans);cursor:pointer;pointer-events:auto;color:#ffffff4d;border-radius:var(--radius-sm);transition:all var(--transition-fast);background:#ffffff0f;border:1px solid #ffffff1a;padding:4px 8px;font-size:.875rem}.btn-tab{font-family:var(--font-sans);cursor:pointer;pointer-events:auto;color:#aaa;transition:all var(--transition-fast);background:#ffffff08;border:1px solid #ffffff14;border-radius:5px 5px 0 0;padding:6px 12px;font-size:.6875rem}.btn-tab:hover{color:#ddd;background:#ffffff0f;border-color:#ffffff26}.btn-tab.active{color:var(--color-gold);text-shadow:0 0 8px #ffc8004d;background:#ffc80014;border-color:#ffc80066 #ffc80066 #0000}.btn-subtab{font-family:var(--font-sans);cursor:pointer;pointer-events:auto;border-radius:var(--radius-sm);color:#b9c;transition:all var(--transition-fast);background:#b478ff0d;border:1px solid #b478ff26;padding:5px 14px;font-size:.6875rem}.btn-subtab:hover{color:#dce;background:#b478ff1a;border-color:#b478ff4d}.btn-subtab.active{color:var(--color-purple);text-shadow:0 0 8px #c850ff66;background:#b43cff1f;border-color:#c850ff80}#levelup-overlay{background:var(--bg-overlay-dark);width:100%;height:100%;z-index:var(--z-overlay-levelup);pointer-events:auto;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);flex-direction:column;justify-content:center;align-items:center;display:none;position:absolute;top:0;left:0}#levelup-overlay.active{background:0 0;display:flex}.levelup-title{color:gold;text-shadow:0 0 20px #ffc80066,0 0 40px #ffc80099,0 0 80px #ffb4004d;letter-spacing:8px;margin-bottom:6px;font-size:2.625rem;font-weight:700;animation:1.8s ease-in-out infinite levelup-glow}@keyframes levelup-glow{0%,to{text-shadow:0 0 20px #ffc80066,0 0 40px #ffc80099,0 0 80px #ffb4004d}50%{text-shadow:0 0 30px #ffdc0099,0 0 60px #ffdc00cc,0 0 100px #ffc80080}}.levelup-subtitle{color:#aaa;letter-spacing:3px;margin-bottom:32px;font-size:.875rem}.levelup-choices{flex-wrap:wrap;justify-content:center;gap:18px;display:flex}.levelup-card{text-align:center;cursor:pointer;color:#eee;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:linear-gradient(#14162df5,#0c0e1cf5);border:1px solid #ffffff14;border-radius:16px;width:230px;padding:26px 20px;transition:all .3s cubic-bezier(.25,.46,.45,.94);position:relative;overflow:hidden;box-shadow:0 4px 20px #00000080,inset 0 1px #ffffff08}.levelup-card:after{content:"";background:linear-gradient(90deg,#0000,#ffffff0d,#0000);width:70%;height:1px;transition:all .3s;position:absolute;top:0;left:15%}.levelup-card:hover:after{background:linear-gradient(90deg,#0000,#ffc80033,#0000)}.levelup-card:hover,.levelup-card:focus{border-color:gold;transform:translateY(-8px)scale(1.02);box-shadow:0 16px 40px #0009,0 0 40px #ffc80033,0 0 80px #ffc80014}.levelup-card .card-icon{filter:drop-shadow(0 0 8px #ffffff1a);margin-bottom:12px;font-size:2.625rem;transition:transform .3s}.levelup-card .card-icon .icon-wrap{width:4rem;height:4rem;margin:0 auto}.levelup-card:hover .card-icon{transform:scale(1.1)}.levelup-card .card-name{color:#fff;margin-bottom:6px;font-size:1.1875rem;font-weight:700}.levelup-card .card-rank{color:gold;letter-spacing:1px;margin-bottom:8px;font-size:.75rem}.levelup-card .card-desc{color:#aaa;font-size:.75rem;line-height:1.5}.levelup-card .card-key{color:#888;letter-spacing:1px;margin-top:10px;font-size:.6875rem}.levelup-card.maxed{opacity:.35;pointer-events:none;border-color:#ffffff0d}.levelup-card .card-preview{border-top:1px solid #ffffff14;margin-top:10px;padding-top:10px;font-size:.75rem}.card-preview .preview-stat{justify-content:center;align-items:center;gap:5px;margin-bottom:3px;display:flex}.card-preview .preview-label{color:#888;text-align:right;min-width:55px;font-size:.6875rem}.card-preview .preview-before{color:#777;text-decoration:line-through}.card-preview .preview-arrow{color:#888;margin:0 2px}.card-preview .preview-after{color:#4da6ff;font-weight:700}.card-preview .preview-delta{color:#4f4;margin-left:2px;font-size:.625rem}.card-preview .preview-maxed{color:#f44;text-align:center;letter-spacing:2px;font-size:.6875rem}.card-preview .preview-desc{color:#c4f;text-align:center;font-size:.6875rem;line-height:1.4}.card-preview .preview-evo-bonus{color:gold;text-align:center;margin-bottom:2px;font-size:.6875rem}.levelup-card.evo-card{background:linear-gradient(#1e1605f5,#140e03f5);border-color:#ffc80066;animation:2s ease-in-out infinite evo-card-pulse;box-shadow:0 0 24px #ffc80040,0 0 60px #ffc80014}@keyframes evo-card-pulse{0%,to{box-shadow:0 0 24px #ffc80040,0 0 60px #ffc80014}50%{box-shadow:0 0 36px #ffc80066,0 0 80px #ffc80026}}.levelup-card.evo-card:hover,.levelup-card.evo-card:focus{border-color:#ffea00;box-shadow:0 12px 40px #ffc80066,0 0 80px #ffc80033}.reroll-hint{color:#888;text-align:center;cursor:pointer;letter-spacing:2px;margin-top:16px;font-size:.8125rem;transition:color .2s}.reroll-hint:hover{color:gold}.reroll-hint.used{color:#666;cursor:default}.card-evo-badge{color:#000;letter-spacing:2px;background:linear-gradient(135deg,#f80,gold);border-radius:4px;margin-bottom:6px;padding:2px 10px;font-size:.625rem;font-weight:700;display:inline-block}#gameover-overlay{background:var(--bg-overlay-red);width:100%;height:100%;z-index:var(--z-overlay-gameover);pointer-events:auto;color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);flex-direction:column;justify-content:center;align-items:center;display:none;position:absolute;top:0;left:0}#gameover-overlay.active{display:flex}.gameover-title{color:#f44;text-shadow:0 0 20px #f006,0 0 40px #f009,0 0 80px #ff00004d;letter-spacing:10px;margin-bottom:20px;font-size:3rem;font-weight:700;animation:2.5s ease-in-out infinite gameover-pulse}@keyframes gameover-pulse{0%,to{text-shadow:0 0 20px #f006,0 0 40px #f009,0 0 80px #ff00004d}50%{text-shadow:0 0 30px #ff282899,0 0 60px #ff2828cc,0 0 100px #ff141480}}.gameover-stats{color:#ccc;text-align:center;margin-bottom:36px;font-size:1.0625rem;line-height:2.2}.gameover-stats span{color:gold;font-weight:700}#leaderboard{text-align:center;width:360px;max-width:90vw;max-height:200px;margin-top:16px;margin-bottom:16px;font-size:.75rem;overflow-y:auto}#leaderboard .lb-title{color:gold;letter-spacing:2px;margin-bottom:6px;font-size:.8125rem;font-weight:700}#leaderboard .lb-row{color:#ddd;justify-content:space-between;padding:2px 0;display:flex}#leaderboard .lb-row:nth-child(odd){color:#bbb}#leaderboard .lb-rank{color:gold;text-align:right;width:24px;margin-right:8px}#leaderboard .lb-name{text-align:left;flex:1}#leaderboard .lb-score{color:#f80;margin-left:12px}#leaderboard .lb-new{color:#f44;text-align:left;width:32px;margin-left:8px;font-size:.625rem;display:inline-block}#pause-overlay{width:100%;height:100%;z-index:var(--z-overlay-pause);pointer-events:auto;color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0000008c;flex-direction:column;justify-content:center;align-items:center;display:none;position:absolute;top:0;left:0}#pause-overlay.active{display:flex}.pause-title{color:#fff;letter-spacing:14px;text-shadow:0 0 20px #ffffff4d,0 0 40px #fff6,0 0 80px #ffffff26;margin-bottom:14px;font-size:3.5rem;font-weight:700;animation:3s ease-in-out infinite pause-title-fade}@keyframes pause-title-fade{0%,to{opacity:.85}50%{opacity:1}}.pause-subtitle{color:#aaa;letter-spacing:4px;font-size:.9375rem}#stage-transition{background:var(--bg-overlay-stage);width:100%;height:100%;z-index:var(--z-overlay-stage);pointer-events:auto;color:#fff;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);flex-direction:column;justify-content:center;align-items:center;display:none;position:absolute;top:0;left:0}#stage-transition.active{display:flex}.stage-label{color:#aaa;letter-spacing:10px;text-transform:uppercase;margin-bottom:12px;font-size:1.25rem}.stage-name{color:gold;letter-spacing:12px;text-shadow:0 0 20px #ffc80066,0 0 40px #ffc80099,0 0 80px #ffc80033;font-size:3rem;font-weight:700;animation:1.2s ease-in-out infinite stage-name-glow}@keyframes stage-name-glow{0%,to{text-shadow:0 0 20px #ffc80066,0 0 40px #ffc80099,0 0 80px #ffc80033}50%{text-shadow:0 0 30px #ffdc0099,0 0 60px #ffdc00cc,0 0 100px #ffc80066}}#win-overlay{background:var(--bg-overlay-win);width:100%;height:100%;z-index:var(--z-overlay-win);pointer-events:auto;color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);flex-direction:column;justify-content:center;align-items:center;display:none;position:absolute;top:0;left:0}#win-overlay.active{display:flex}.win-title{color:gold;text-shadow:0 0 50px #ffc800cc,0 0 100px #ffc8004d;letter-spacing:10px;margin-bottom:24px;font-size:3.125rem;font-weight:700;animation:1.2s ease-in-out infinite win-glow}@keyframes win-glow{0%,to{text-shadow:0 0 50px #ffc800cc,0 0 100px #ffc8004d}50%{text-shadow:0 0 60px #ffdc00,0 0 120px #ffc80080}}.win-stats{color:#ccc;text-align:center;margin-bottom:30px;font-size:1rem;line-height:2}.win-stats span{color:gold;font-weight:700}#codex-overlay{width:100%;height:100%;z-index:var(--z-overlay-codex);pointer-events:auto;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;background:radial-gradient(at 30% 20%,#3c64c814 0%,#0000 60%),radial-gradient(at 70% 80%,#643cc80d 0%,#0000 60%),linear-gradient(135deg,#0a0a1ac7 0%,#151530c7 50%,#0a1020c7 100%);flex-direction:column;align-items:center;padding-top:70px;animation:12s ease-in-out infinite menu-bg-shift;display:none;position:absolute;top:0;left:0}#codex-overlay.active{display:flex}.codex-header{justify-content:space-between;align-items:center;width:100%;max-width:860px;padding:20px 24px 10px;display:flex}.codex-title{color:gold;text-shadow:0 0 24px #ffc80080,0 0 48px #ffb40033;letter-spacing:6px;font-size:2.25rem;font-weight:700}.codex-subtitle{color:#a98;letter-spacing:2px;font-size:.75rem}.codex-close{color:#fff;cursor:pointer;width:40px;height:40px;font-size:1.375rem;font-family:var(--font-sans);pointer-events:auto;background:#ffffff08;border:1px solid #ffffff26;border-radius:8px;justify-content:center;align-items:center;transition:all .2s cubic-bezier(.25,.46,.45,.94);display:flex}.codex-close:hover{background:#ff3c3c26;border-color:#ff505080;transform:scale(1.05);box-shadow:0 0 16px #ff3c3c26}.codex-tabs{border-bottom:1px solid #ffffff14;flex-wrap:wrap;justify-content:center;gap:4px;max-width:860px;padding:4px 16px;display:flex}.codex-tab{color:#aaa;font-family:var(--font-sans);cursor:pointer;pointer-events:auto;background:#ffffff08;border:1px solid #ffffff14;border-radius:5px 5px 0 0;padding:6px 12px;font-size:.6875rem;transition:all .15s}.codex-tab:hover{color:#ddd;background:#ffffff0f;border-color:#ffffff26}.codex-tab.active{color:gold;text-shadow:0 0 8px #ffc8004d;background:#ffc80014;border-color:#ffc80066 #ffc80066 #0000}.codex-subtabs{flex-wrap:wrap;justify-content:center;gap:6px;padding:8px 16px 0;display:flex}.codex-subtab{color:#b9c;font-family:var(--font-sans);cursor:pointer;pointer-events:auto;background:#b478ff0d;border:1px solid #b478ff26;border-radius:4px;padding:5px 14px;font-size:.6875rem;transition:all .15s}.codex-subtab:hover{color:#dce;background:#b478ff1a;border-color:#b478ff4d}.codex-subtab.active{color:#c4f;text-shadow:0 0 8px #c850ff66;background:#b43cff1f;border-color:#c850ff80}.codex-content{scrollbar-width:thin;scrollbar-color:#ffffff1a transparent;flex:1;width:100%;max-width:860px;padding:16px 24px 30px;overflow:hidden auto}.codex-content::-webkit-scrollbar{width:4px}.codex-content::-webkit-scrollbar-track{background:0 0}.codex-content::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.codex-card-grid{flex-direction:column;gap:12px;display:flex}.codex-card{background:linear-gradient(#19192de6,#0f0f1ce6);border:1px solid #ffffff1a;border-radius:10px;padding:16px 20px;transition:border-color .15s}.codex-card:hover{border-color:#fff3}.codex-card-header{align-items:center;gap:10px;margin-bottom:8px;display:flex}.codex-card-icon{font-size:1.75rem}.codex-card-icon .icon-wrap{width:1.75rem;height:1.75rem}.codex-card-name{color:gold;font-size:1rem;font-weight:700}.codex-card-rank{color:#bbb;margin-left:auto;font-size:.6875rem}.codex-card-rank .current{color:gold;font-weight:700}.codex-card-desc{color:#bbb;font-size:.75rem;line-height:1.6}.codex-card-stats{color:#999;margin-top:4px;font-size:.6875rem}.codex-card-meta{flex-wrap:wrap;gap:8px;margin-top:6px;display:flex}.codex-tag{color:#aaa;border:1px solid #ffffff1a;border-radius:3px;padding:2px 8px;font-size:.625rem}.codex-tag.gold{color:gold;background:#ffc8000f;border-color:#ffc8004d}.codex-tag.purple{color:#c4f;background:#c850ff0f;border-color:#c850ff4d}.codex-tag.red{color:#f44;background:#ff50500f;border-color:#ff50504d}.codex-tag.green{color:#4eff4e;background:#50ff500f;border-color:#50ff504d}.codex-tag.blue{color:#4af;background:#50a0ff0f;border-color:#50a0ff4d}.codex-section{margin-bottom:20px}.codex-section-title{color:#c4f;letter-spacing:2px;border-bottom:1px solid #c850ff26;margin-bottom:8px;padding-bottom:4px;font-size:.875rem;font-weight:700}.codex-mechanic{background:#ffffff05;border-left:2px solid #ffc8004d;border-radius:6px;margin-bottom:14px;padding:10px 14px}.codex-mechanic h4{color:gold;margin-bottom:4px;font-size:.8125rem}.codex-mechanic p{color:#aaa;font-size:.6875rem;line-height:1.5}.codex-stat-table{border-collapse:collapse;width:100%;font-size:.6875rem}.codex-stat-table th{text-align:left;color:#999;letter-spacing:1px;border-bottom:1px solid #ffffff14;padding:4px 10px;font-size:.625rem;font-weight:700}.codex-stat-table td{color:#ddd;border-bottom:1px solid #ffffff0a;padding:4px 10px}.codex-stat-table td.val{color:gold}@media (width<=768px){.codex-title{font-size:1.5rem}.codex-tabs{gap:3px;padding:4px 8px}.codex-tab{min-height:40px;padding:8px 10px;font-size:.625rem}.codex-subtab{min-height:38px;padding:8px 14px;font-size:.625rem}.codex-close{width:44px;height:44px;font-size:1.75rem}.codex-card{padding:12px 14px}.codex-card-name{font-size:.8125rem}.codex-content{padding:12px 12px 24px}#levelup-choices{flex-direction:column;gap:8px}.levelup-card{width:180px;padding:14px 12px}.levelup-title{font-size:1.5rem}#gameover-overlay .gameover-title{font-size:1.75rem}}#settings-panel{width:100%;height:100%;z-index:var(--z-overlay-settings,100);pointer-events:auto;display:none;position:absolute;top:0;left:0}.settings-overlay{background:#000000b3;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:absolute;top:0;left:0}.settings-content{color:#ddd;background:#1a1a2e;border:1px solid #333;border-radius:8px;min-width:320px;max-width:400px;padding:24px 28px;box-shadow:0 0 40px #00000080}.settings-content h2{color:gold;letter-spacing:3px;text-align:center;margin:0 0 16px;font-size:1.3rem}.settings-group{margin-bottom:14px}.settings-group label{color:#aaa;justify-content:space-between;align-items:center;margin-bottom:2px;font-size:.85rem;display:flex}.settings-tip{color:#666;margin-bottom:6px;font-size:.7rem;line-height:1.3;display:block}.settings-divider{border-top:1px solid #ffffff14;margin:16px 0 12px}.settings-row{margin-bottom:10px}.settings-row label{cursor:pointer;color:#ccc;justify-content:flex-start;gap:10px}.settings-group input[type=range]{accent-color:gold;cursor:pointer;width:100%;height:6px}.settings-group input[type=checkbox]{accent-color:gold;cursor:pointer;width:16px;height:16px}.settings-group select{color:#ddd;cursor:pointer;background:#222;border:1px solid #444;border-radius:4px;width:100%;padding:6px 10px;font-size:.85rem}#settings-close{color:#ddd;cursor:pointer;letter-spacing:2px;background:#333;border:1px solid #555;border-radius:4px;width:100%;margin-top:18px;padding:8px;font-size:.9rem;display:block}#settings-close:hover{color:gold;background:#444;border-color:gold}@media (width<=480px){.settings-content{min-width:280px;padding:16px 18px}}#main-menu{width:100%;height:100%;z-index:var(--z-menu);color:#fff;background:radial-gradient(at 30% 20%,#3c64c814 0%,#0000 60%),radial-gradient(at 70% 80%,#643cc80d 0%,#0000 60%),linear-gradient(135deg,#0a0a1ac7 0%,#151530c7 50%,#0a1020c7 100%);flex-direction:column;justify-content:center;align-items:center;animation:12s ease-in-out infinite menu-bg-shift;display:flex;position:absolute;top:0;left:0}@keyframes menu-bg-shift{0%,to{background:radial-gradient(at 30% 20%,#3c64c814 0%,#0000 60%),radial-gradient(at 70% 80%,#643cc80d 0%,#0000 60%),linear-gradient(135deg,#0a0a1ac7 0%,#151530c7 50%,#0a1020c7 100%)}33%{background:radial-gradient(at 60% 40%,#643cc814 0%,#0000 60%),radial-gradient(at 30% 60%,#3c64c80f 0%,#0000 60%),linear-gradient(135deg,#0a0a20c7 0%,#151540c7 50%,#0a1025c7 100%)}66%{background:radial-gradient(at 20% 70%,#5078c80f 0%,#0000 60%),radial-gradient(at 80% 30%,#7850c80d 0%,#0000 60%),linear-gradient(135deg,#0a0a18c7 0%,#151535c7 50%,#0a1022c7 100%)}}#main-menu:before{content:"";pointer-events:none;z-index:1;opacity:.4;background:repeating-linear-gradient(0deg,#0000,#0000 2px,#00000008 2px 4px);width:100%;height:100%;position:absolute;top:0;left:0}.menu-title{color:var(--color-gold);letter-spacing:16px;text-shadow:0 0 20px #ffc8004d,0 0 40px #ffc80080,0 0 80px #ffb4004d,0 0 120px #ffc80026;z-index:2;margin-bottom:4px;font-size:3.625rem;font-weight:700;animation:2.5s ease-in-out infinite menu-title-glow;position:relative}@keyframes menu-title-glow{0%,to{text-shadow:0 0 20px #ffc8004d,0 0 40px #ffc80080,0 0 80px #ffb4004d,0 0 120px #ffc80026}50%{text-shadow:0 0 30px #ffdc0080,0 0 60px #ffdc00b3,0 0 100px #ffc80080,0 0 160px #ffc80040}}.menu-subtitle{color:#987;letter-spacing:8px;z-index:2;text-transform:uppercase;margin-bottom:56px;font-size:.8125rem;position:relative}.menu-cards{z-index:2;flex-wrap:wrap;justify-content:center;gap:28px;display:flex;position:relative}.menu-card{text-align:center;cursor:pointer;color:#ccc;width:270px;-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));background:linear-gradient(#14142df2,#0c0c19f2);border:1px solid #ffffff0f;border-radius:20px;padding:36px 28px;transition:all .35s cubic-bezier(.25,.46,.45,.94);position:relative;overflow:hidden;box-shadow:0 4px 24px #00000080,inset 0 1px #ffffff08}.menu-card:after{content:"";background:linear-gradient(90deg,#0000,#ffffff14,#0000);width:80%;height:1px;transition:all .35s;position:absolute;top:0;left:10%}.menu-card:hover:after{background:linear-gradient(90deg,#0000,#fff3,#0000)}.menu-card:hover{transform:translateY(-12px)scale(1.02);box-shadow:0 20px 48px #0009,0 0 60px #ffc8000f}.menu-card.solo{border-color:#508cdc26}.menu-card.solo:hover{border-color:#64b4ff80;box-shadow:0 20px 48px #0009,0 0 60px #5096ff26,0 0 100px #5096ff0f}.menu-card.coop{border-color:#c8a0501f}.menu-card.coop:hover{border-color:#ffc86480;box-shadow:0 20px 48px #0009,0 0 60px #ffb45026,0 0 100px #ffb4500f}.menu-card-icon{filter:drop-shadow(0 0 12px #ffffff1a);margin-bottom:16px;font-size:3.25rem;transition:transform .35s cubic-bezier(.25,.46,.45,.94)}.menu-card:hover .menu-card-icon{transform:scale(1.1)}.menu-card-title{color:#fff;letter-spacing:6px;margin-bottom:10px;font-size:1.375rem;font-weight:700;transition:text-shadow .35s}.menu-card:hover .menu-card-title{text-shadow:0 0 16px #ffffff4d}.menu-card-desc{color:#888;margin-bottom:4px;font-size:.75rem;line-height:1.7}.menu-card-hint{color:#888;letter-spacing:2px;text-transform:uppercase;margin-top:14px;font-size:.625rem;transition:color .35s}.menu-card:hover .menu-card-hint{color:#987}.menu-footer{color:#ffffff40;letter-spacing:4px;z-index:2;font-size:.625rem;position:absolute;bottom:36px}#customize-screen{width:100%;height:100%;z-index:var(--z-screen);color:#fff;background:radial-gradient(at 30% 20%,#3c64c814 0%,#0000 60%),radial-gradient(at 70% 80%,#643cc80d 0%,#0000 60%),linear-gradient(135deg,#0a0a1ac7 0%,#151530c7 50%,#0a1020c7 100%);flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;top:0;left:0}#customize-screen h1{letter-spacing:8px;text-shadow:0 0 20px #78a0ff66,0 0 40px #648cdc33;margin-bottom:4px;font-size:2rem;font-weight:700}#customize-screen .subtitle{color:#89a;letter-spacing:4px;text-transform:uppercase;margin-bottom:28px;font-size:.75rem}#customize-preview{background:#00000080;border:1px solid #ffffff1a;border-radius:14px;width:190px;height:230px;margin-bottom:24px;position:relative;overflow:hidden;box-shadow:0 4px 24px #0006,0 0 40px #6496dc0f}#customize-preview canvas{width:100%;height:100%}.option-row{align-items:center;gap:14px;width:540px;margin-bottom:16px;display:flex}.option-row label{text-align:right;color:#999;letter-spacing:1px;flex-shrink:0;width:80px;font-size:.8125rem}.swatches{gap:10px;display:flex}.swatch{cursor:pointer;border:2px solid #ffffff1a;border-radius:50%;width:30px;height:30px;transition:all .2s cubic-bezier(.25,.46,.45,.94)}.swatch:hover{border-color:#ffffff80;transform:scale(1.2)}.swatch.selected{border-color:#fff;box-shadow:0 0 14px #ffffff80,0 0 28px #ffffff26}.hat-options{gap:10px;display:flex}.hat-opt{cursor:pointer;color:#999;letter-spacing:1px;background:#ffffff05;border:1px solid #ffffff1a;border-radius:6px;padding:6px 14px;font-size:.6875rem;transition:all .2s cubic-bezier(.25,.46,.45,.94)}.hat-opt:hover{color:#ccc;background:#ffffff0f;border-color:#ffffff40}.hat-opt.selected{color:#fff;background:#ffffff14;border-color:#ffffff80;box-shadow:0 0 12px #ffffff1a}.weapon-opts .hat-opt{text-align:center;flex-direction:column;align-items:center;gap:3px;min-width:120px;padding:8px 14px;display:flex}.weapon-opt-name{font-size:.8125rem}.weapon-opt-name .icon-wrap{vertical-align:text-bottom;width:1rem;height:1rem}.weapon-opt-desc{color:#abc;font-size:.6875rem;line-height:1.4}#lobby-cust-preview{background:#0009;border:1px solid #ffffff1a;border-radius:10px;flex-shrink:0;width:150px;height:190px;position:relative;overflow:hidden}#lobby-cust-preview canvas{width:100%;height:100%}.lobby-option-row{align-items:center;gap:8px;margin-bottom:8px;padding:10px 0;display:flex}.lobby-option-row label{text-align:right;color:#888;flex-shrink:0;width:55px;font-size:.8125rem}.lobby-option-row .swatches{gap:4px;display:flex}.lobby-option-row .swatch{cursor:pointer;border:2px solid #0000;border-radius:50%;width:20px;height:20px;transition:all .15s}.lobby-option-row .swatch:hover{transform:scale(1.15)}.lobby-option-row .swatch.selected{border-color:#fff;box-shadow:0 0 6px #fff6}.lobby-option-row .hat-options{flex-wrap:wrap;gap:4px;display:flex}.lobby-option-row .hat-opt{cursor:pointer;color:#aaa;background:#ffffff08;border:1px solid #ffffff1f;border-radius:3px;padding:2px 7px;font-size:.625rem;transition:all .15s}.lobby-option-row .hat-opt:hover{background:#ffffff14}.lobby-option-row .hat-opt.selected{color:#fff;background:#ffffff1a;border-color:#fff}.lobby-option-row .weapon-opt-name{font-size:.75rem}.lobby-option-row .weapon-opt-desc{color:#aaa;font-size:.6875rem;line-height:1.35}@media (width<=768px){.btn-primary{padding:12px 32px;font-size:.875rem}}#mobile-controls{pointer-events:none;width:100%;height:100%;z-index:var(--z-mobile);display:none;position:absolute;bottom:0;left:0}#mobile-controls.active{display:block}#mobile-joystick-area{pointer-events:auto;width:140px;height:140px;position:absolute;bottom:30px;left:30px}#mobile-joystick-base{background:#ffffff14;border:2px solid #fff3;border-radius:50%;justify-content:center;align-items:center;width:140px;height:140px;display:flex;position:relative}#mobile-joystick-thumb{will-change:transform;background:#ffffff40;border:1px solid #fff6;border-radius:50%;width:56px;height:56px;transition:none;position:absolute}.mobile-btn{color:#fff;letter-spacing:1px;pointer-events:auto;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;touch-action:manipulation;background:#000000b3;border:1px solid #ffffff4d;border-radius:50%;width:60px;height:60px;font-size:.6875rem;font-weight:700}.mobile-btn:active{background:#fff3}.mobile-btn-top{color:#fff;letter-spacing:1px;pointer-events:auto;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;touch-action:manipulation;background:#000000b3;border:1px solid #ffffff40;border-radius:6px;padding:8px 16px;font-size:.75rem;font-weight:700;position:absolute;top:30px}.mobile-btn-top:active{background:#ffffff26}#debug-overlay{color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);min-width:170px;max-width:260px;max-height:400px;z-index:var(--z-debug);pointer-events:none;font-size:.6875rem;font-family:var(--font-mono);background:#000000c7;border:1px solid #ffc80040;border-radius:8px;padding:10px 14px;line-height:1.5;display:none;position:absolute;bottom:40px;left:12px;overflow-y:auto;box-shadow:0 4px 20px #00000080,0 0 12px #ffc80014}#debug-overlay.active{display:block}.debug-title{color:gold;letter-spacing:2px;border-bottom:1px solid #ffc80026;margin-bottom:6px;padding-bottom:4px;font-size:.625rem;font-weight:700}.debug-source{justify-content:space-between;gap:12px;display:flex}.debug-source .ds-name{color:#ddd}.debug-source .ds-dmg{color:#f80;font-weight:700}.debug-source .ds-pct{color:#999;font-size:.625rem}.debug-total{color:gold;border-top:1px solid #ffffff1a;margin-top:4px;padding-top:4px;font-weight:700}.debug-dps{color:#fa4;margin-top:2px;font-size:.625rem}#debug-console{color:#0f0;height:40%;max-height:340px;z-index:var(--z-debug);font-family:var(--font-mono);background:#000000e0;border-top:1px solid #00ff004d;flex-direction:column;font-size:.6875rem;display:none;position:absolute;bottom:0;left:0;right:0;overflow:hidden;box-shadow:0 -4px 20px #0009}#debug-console.active{pointer-events:auto;display:flex}.dbg-console-output{white-space:pre-wrap;word-break:break-all;scroll-behavior:smooth;flex:1;min-height:0;padding:8px 12px;line-height:1.45;overflow-y:auto}.dbg-console-output .dbg-cmd{color:gold}.dbg-console-output .dbg-out{color:#bbb}.dbg-console-output .dbg-err{color:#f44}.dbg-console-input{color:#0f0;font-family:var(--font-mono);pointer-events:auto;background:#000f00e6;border:none;border-top:1px solid #0f03;outline:none;flex-shrink:0;padding:8px 12px;font-size:.75rem}.dbg-console-input::placeholder{color:#00ff0040}#lobby-overlay{width:100%;height:100%;z-index:var(--z-screen);color:#fff;font-family:var(--font-sans);background:radial-gradient(at 30% 20%,#3c64c814 0%,#0000 60%),radial-gradient(at 70% 80%,#643cc80d 0%,#0000 60%),linear-gradient(135deg,#0a0a1ac7 0%,#151530c7 50%,#0a1020c7 100%);flex-direction:column;align-items:center;padding:30px 20px 40px;animation:12s ease-in-out infinite menu-bg-shift;display:flex;position:absolute;top:0;left:0;overflow-y:auto}#lobby-overlay h1{letter-spacing:12px;color:gold;text-shadow:0 0 30px #ffc80080;margin-bottom:4px;font-size:2.625rem}#lobby-overlay .lobby-subtitle{color:#888;letter-spacing:4px;margin-bottom:24px;font-size:.75rem}.lobby-main{flex:1;align-items:flex-start;gap:20px;width:100%;max-width:920px;min-height:0;display:flex}.lobby-left{background:#ffffff05;border:1px solid #ffffff0f;border-radius:12px;flex-direction:column;flex:0 0 350px;gap:10px;padding:18px;display:flex}.lobby-right{flex-direction:column;flex:1;min-width:0;display:flex}#lobby-overlay .lobby-name-section{text-align:center}#lobby-overlay .lobby-name-label{color:#888;letter-spacing:2px;margin-bottom:4px;font-size:.625rem}#lobby-name-input{text-align:center;width:220px;font-size:.875rem;font-family:var(--font-sans);color:#fff;background:#00000080;border:1px solid #fff3;border-radius:8px;outline:none;padding:10px 12px}#lobby-room-section{flex-direction:column;gap:8px;display:flex}#lobby-room-section #lobby-btn-create{width:100%}.lobby-join-row{align-items:center;gap:8px;display:flex}.lobby-join-row #lobby-room-code{flex:1}#lobby-room-code{text-align:center;width:80px;font-size:1.125rem;font-family:var(--font-mono);color:gold;letter-spacing:4px;text-transform:uppercase;background:#00000080;border:1px solid #ffc8004d;border-radius:8px;outline:none;padding:12px 8px;font-weight:700}#lobby-room-code-display{text-align:center;display:none}#lobby-room-code-display .lobby-code-label{color:#888;letter-spacing:2px;margin-bottom:4px;font-size:.625rem}#lobby-room-code-value{color:gold;letter-spacing:8px;text-shadow:0 0 20px #ffc80066;font-size:2.25rem;font-weight:700}.lobby-code-row{justify-content:center;align-items:center;gap:8px;display:flex}#lobby-room-code-display .lobby-code-hint{color:#888;margin-top:4px;font-size:.625rem}#lobby-btn-copy-code{color:#ccc;cursor:pointer;text-align:center;background:#ffffff0f;border:1px solid #ffffff1f;border-radius:6px;width:32px;height:32px;padding:0;font-size:.875rem;line-height:32px;transition:background .15s,color .15s}#lobby-btn-copy-code:hover{color:#fff;background:#ffffff24}.lobby-leave-link{color:#d44;cursor:pointer;letter-spacing:1px;font-size:.625rem;font-family:var(--font-sans);background:#c828281f;border:1px solid #c8282840;border-radius:6px;margin:8px auto 0;padding:4px 16px;transition:background .15s,border-color .15s;display:block}.lobby-leave-link:hover{background:#c8282840;border-color:#dc323266}#lobby-player-list{flex-direction:column;gap:4px;display:flex}.lobby-player-row{background:#ffffff0a;border:1px solid #ffffff14;border-radius:6px;align-items:center;gap:12px;padding:8px 16px;display:flex}.lobby-player-row.ready{border-color:#64ff644d}.lobby-player-status{width:20px;font-size:.875rem}.lobby-player-status.ready{color:#4eff4e}.lobby-player-status.not-ready{color:#999}.lobby-player-name{color:#fff;flex:1;font-size:.8125rem}.lobby-player-host{color:gold;text-align:right;width:40px;font-size:.625rem}.lobby-btn{letter-spacing:2px;padding:12px 24px;font-size:.875rem}.lobby-btn:disabled{opacity:.4}#lobby-btn-ready{background:var(--btn-ready-bg)}#lobby-btn-ready.is-ready{background:var(--btn-unready-bg)}#lobby-btn-start{background:var(--btn-lobby-start-bg)}#lobby-cust-panel{background:#ffffff05;border:1px solid #ffffff0f;border-radius:10px;align-items:flex-start;gap:16px;padding:14px;display:flex}#lobby-cust-panel .lobby-cust-opts{flex-direction:column;display:flex}#lobby-actions{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}#lobby-status{color:#999;text-align:center;min-height:16px;font-size:.6875rem}#lobby-connection-status{color:#999;text-align:center;font-size:.625rem}#lobby-connection-status.connected{color:#4eff4e}#lobby-chat-section{width:100%;margin-top:16px}#lobby-chat-messages{color:#ccc;background:#0000004d;border-radius:6px;height:100px;margin-bottom:6px;padding:8px;font-size:.6875rem;overflow-y:auto}.lobby-chat-row{gap:6px;display:flex}#lobby-chat-input{font-size:.75rem;font-family:var(--font-sans);color:#fff;background:#00000080;border:1px solid #ffffff26;border-radius:6px;outline:none;flex:1;padding:8px}.lobby-chat-msg{word-break:break-word;margin-bottom:3px}.lobby-chat-author{color:gold}#lobby-btn-back{align-self:center;margin-top:16px}@media (width<=800px){.lobby-main{flex-direction:column;gap:16px}.lobby-left{flex:none;width:100%}.lobby-right{width:100%}}
