*{margin:0;padding:0;box-sizing:border-box}:root{--theme-bg: #0a0a0f;--theme-board-bg: #0f0f1a;--theme-board-border: rgba(0, 200, 255, .2);--theme-grid-line: rgba(255, 255, 255, .03);--theme-panel-bg: rgba(15, 15, 26, .8);--theme-panel-border: rgba(255, 255, 255, .08);--theme-text-primary: #ffffff;--theme-text-secondary: rgba(255, 255, 255, .4);--theme-text-accent: #00c8ff;--theme-glow: rgba(0, 100, 180, .03);--theme-surface: #1a1a2e;--theme-surface-border: #2a2a4a;--theme-surface-hover: #1f1f3a}.menu-focus{outline:none!important;border-color:var(--theme-text-accent)!important;box-shadow:0 0 15px color-mix(in srgb,var(--theme-text-accent) 40%,transparent)!important;transform:translateY(-2px) scale(1.02);z-index:10}.engaged{background:var(--theme-text-accent)!important;box-shadow:0 0 25px var(--theme-text-accent)!important}.engaged::-webkit-slider-thumb{background:#fff!important;transform:scale(1.4)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:#ffffff05;border-radius:10px}::-webkit-scrollbar-thumb{background:color-mix(in srgb,var(--theme-text-accent) 30%,transparent);border-radius:10px;transition:background .2s}::-webkit-scrollbar-thumb:hover{background:var(--theme-text-accent)}*{scrollbar-width:thin;scrollbar-color:color-mix(in srgb,var(--theme-text-accent) 30%,transparent) rgba(255,255,255,.02)}body{background:var(--theme-bg);color:var(--theme-text-primary);font-family:Segoe UI,Inter,system-ui,-apple-system,sans-serif;overflow:hidden;width:100vw;height:100vh}#app{width:100%;height:100%;position:relative}.screen{position:absolute;top:0;left:0;width:100%;height:100%;display:none;justify-content:center;align-items:center}.screen.active{display:flex}.menu-layout{display:flex;align-items:center;gap:2.5rem;max-height:100vh;padding:2rem}.menu-container{text-align:center;flex-shrink:0;max-height:100vh;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none}.menu-container::-webkit-scrollbar{display:none}.game-title{font-size:clamp(2rem,5vw,3.2rem);font-weight:900;letter-spacing:.05em;color:var(--theme-text-primary);text-shadow:0 0 40px color-mix(in srgb,var(--theme-text-accent) 30%,transparent);margin-bottom:.25rem;line-height:1;white-space:nowrap}.game-title span{color:var(--theme-text-accent)}.tagline{font-size:.9rem;color:var(--theme-text-secondary);letter-spacing:.3em;text-transform:uppercase;margin-bottom:.5rem}.version-tag{font-size:.65rem;color:var(--theme-text-secondary);font-family:Courier New,monospace;letter-spacing:.1em;margin-bottom:2.5rem}.menu-buttons{display:flex;flex-direction:column;gap:.75rem;margin-bottom:2.5rem;min-width:320px}.menu-btn{background:linear-gradient(135deg,var(--theme-surface) 0%,color-mix(in srgb,var(--theme-surface) 80%,var(--theme-bg)) 100%);border:1px solid var(--theme-surface-border);color:var(--theme-text-primary);padding:1rem 1.5rem;border-radius:8px;cursor:pointer;font-size:1rem;font-family:inherit;display:flex;align-items:center;gap:1rem;transition:all .2s ease;text-align:left}.menu-btn:hover{background:linear-gradient(135deg,var(--theme-surface-hover) 0%,color-mix(in srgb,var(--theme-surface-hover) 80%,var(--theme-bg)) 100%);border-color:var(--theme-text-accent);box-shadow:0 0 20px color-mix(in srgb,var(--theme-text-accent) 15%,transparent);transform:translateY(-1px)}.menu-btn:active{transform:translateY(0)}.menu-btn.small{padding:.75rem 1.5rem;justify-content:center;gap:0}.btn-icon{font-size:1.5rem;width:2rem;text-align:center;color:var(--theme-text-accent)}.btn-text{font-weight:700;font-size:1.1rem}.btn-desc{font-size:.75rem;color:var(--theme-text-secondary);margin-left:auto}.controls-info{text-align:left;flex-shrink:0;align-self:center}.controls-info h3{font-size:.75rem;text-transform:uppercase;letter-spacing:.2em;color:var(--theme-text-secondary);margin-bottom:.75rem;text-align:center}.controls-grid{display:grid;grid-template-columns:auto 1fr;gap:.3rem 1rem;font-size:.8rem;color:var(--theme-text-secondary)}@media(max-width:640px){.menu-layout{flex-direction:column;gap:1.5rem}.controls-info{display:none}}.key{background:var(--theme-surface);border:1px solid var(--theme-surface-border);border-radius:4px;padding:.1rem .5rem;font-family:Consolas,Courier New,monospace;font-size:.7rem;color:var(--theme-text-secondary);text-align:center}#game-canvas{display:block;width:100%;height:100%}.overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:color-mix(in srgb,var(--theme-bg) 85%,transparent);display:none;justify-content:center;align-items:center;z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.overlay.active{display:flex}.overlay-content{text-align:center;display:flex;flex-direction:column;gap:1rem;min-width:240px}.overlay-content h2{font-size:2.5rem;font-weight:900;letter-spacing:.1em;color:var(--theme-text-primary);margin-bottom:.5rem}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;text-align:left;padding:1rem;background:color-mix(in srgb,var(--theme-surface) 50%,transparent);border-radius:8px;border:1px solid var(--theme-surface-border)}.stats-grid .stat-label{color:var(--theme-text-secondary);font-size:.75rem;text-transform:uppercase;letter-spacing:.1em}.stats-grid .stat-value{color:var(--theme-text-accent);font-size:1.1rem;font-weight:700;text-align:right}.countdown-number{font-size:8rem;font-weight:900;color:var(--theme-text-accent);text-shadow:0 0 60px color-mix(in srgb,var(--theme-text-accent) 50%,transparent);animation:countPulse 1s ease-in-out}@keyframes countPulse{0%{transform:scale(1.5);opacity:0}30%{transform:scale(1);opacity:1}80%{opacity:1}to{opacity:0}}.settings-overlay{z-index:200}.settings-container{background:color-mix(in srgb,var(--theme-bg) 90%,var(--theme-surface));border:1px solid var(--theme-surface-border);border-radius:12px;width:480px;max-width:95vw;max-height:85vh;display:flex;flex-direction:column;overflow:hidden}.settings-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem .75rem}.settings-header h2{font-size:1.6rem;font-weight:900;letter-spacing:.1em;color:var(--theme-text-primary)}.settings-close-btn{background:none;border:none;color:var(--theme-text-secondary);font-size:1.4rem;cursor:pointer;padding:.25rem .5rem;border-radius:4px;transition:color .15s,background .15s}.settings-close-btn:hover{color:#fff;background:#ffffff14}.settings-tabs{display:flex;gap:0;padding:0 1.5rem;border-bottom:1px solid var(--theme-surface-border)}.settings-tab{background:none;border:none;border-bottom:2px solid transparent;color:var(--theme-text-secondary);font-family:inherit;font-size:.85rem;font-weight:600;padding:.7rem 1.2rem;cursor:pointer;transition:color .15s,border-color .15s;letter-spacing:.05em}.settings-tab:hover{color:#aaa}.settings-tab.active{color:var(--theme-text-accent);border-bottom-color:var(--theme-text-accent)}.settings-body{padding:1.25rem 1.5rem;overflow-y:auto;flex:1}.settings-panel{display:none}.settings-panel.active{display:block}.handling-presets{margin-bottom:1.5rem}.setting-label{display:flex;justify-content:space-between;align-items:center;font-size:.8rem;font-weight:600;color:var(--theme-text-primary);margin-bottom:.4rem;letter-spacing:.04em}.setting-value{color:var(--theme-text-accent);font-weight:700;font-size:.85rem}.preset-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.preset-btn{background:var(--theme-surface);border:1px solid var(--theme-surface-border);color:var(--theme-text-primary);padding:.4rem .9rem;border-radius:6px;font-family:inherit;font-size:.78rem;font-weight:600;cursor:pointer;transition:all .15s}.preset-btn:hover{border-color:var(--theme-text-accent);color:#fff;background:color-mix(in srgb,var(--theme-surface) 80%,var(--theme-text-accent))}.handling-sliders{display:flex;flex-direction:column;gap:1.2rem;margin-bottom:1.5rem}.slider-row{display:flex;flex-direction:column;gap:.2rem}.setting-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:6px;border-radius:3px;background:var(--theme-surface);outline:none;cursor:pointer}.setting-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--theme-text-accent);cursor:pointer;border:2px solid var(--theme-bg);box-shadow:0 0 8px color-mix(in srgb,var(--theme-text-accent) 30%,transparent)}.setting-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--theme-text-accent);cursor:pointer;border:2px solid var(--theme-bg)}.slider-range{display:flex;justify-content:space-between;font-size:.65rem;color:var(--theme-text-secondary)}.keybind-group{margin-bottom:1.2rem}.keybind-group-title{font-size:.7rem;text-transform:uppercase;letter-spacing:.15em;color:var(--theme-text-secondary);margin-bottom:.5rem;padding-bottom:.3rem;border-bottom:1px solid var(--theme-surface-border)}.keybind-row{display:grid;grid-template-columns:1fr auto auto;gap:.5rem;align-items:center;padding:.35rem 0}.keybind-action{font-size:.82rem;color:var(--theme-text-primary);font-weight:500}.keybind-key{background:var(--theme-surface);border:1px solid var(--theme-surface-border);color:var(--theme-text-primary);padding:.3rem .8rem;border-radius:5px;font-family:Consolas,Courier New,monospace;font-size:.75rem;min-width:60px;text-align:center;cursor:pointer;transition:all .15s}.keybind-key:hover{border-color:var(--theme-text-accent);background:color-mix(in srgb,var(--theme-surface) 80%,var(--theme-text-accent))}.keybind-key.listening{border-color:#f80;color:#f80;animation:keybindPulse .8s infinite}@keyframes keybindPulse{0%,to{box-shadow:0 0 #ff88004d}50%{box-shadow:0 0 0 4px #ff880026}}.toast-container{position:fixed;top:1rem;right:1rem;z-index:9999;display:flex;flex-direction:column;gap:.5rem;pointer-events:none}.toast{pointer-events:auto;background:var(--theme-surface);border:1px solid var(--theme-surface-border);border-radius:10px;padding:.75rem 1rem;display:flex;align-items:center;gap:.75rem;min-width:280px;max-width:360px;cursor:pointer;box-shadow:0 4px 20px #0006;transform:translate(120%);transition:transform .35s cubic-bezier(.34,1.56,.64,1),opacity .35s;opacity:0;overflow:hidden;position:relative}.toast-show{transform:translate(0);opacity:1}.toast-hide{transform:translate(120%);opacity:0}.toast-achievement{border-color:#fa0;box-shadow:0 4px 24px #ffaa0026}.toast-icon{font-size:1.6rem;flex-shrink:0}.toast-body{flex:1;min-width:0}.toast-title{font-weight:700;font-size:.85rem;color:#ffcc40;margin-bottom:.15rem}.toast-msg{font-size:.75rem;color:var(--theme-text-secondary)}.toast-progress{position:absolute;bottom:0;left:0;height:2px;width:100%;background:#fa0;border-radius:0 0 10px 10px}.achievements-list{display:flex;flex-direction:column;gap:.5rem;text-align:left;margin:1rem 0;overflow-y:auto;overflow-x:hidden;max-height:60vh;width:520px;max-width:90vw}.achievement-item{display:flex;align-items:center;gap:.75rem;padding:.6rem .8rem;border-radius:8px;background:color-mix(in srgb,var(--theme-surface) 50%,transparent);border:1px solid var(--theme-surface-border);transition:border-color .2s}.achievement-item.unlocked{border-color:#ffaa004d;background:#28231480}.achievement-item.locked{opacity:.5}.achievement-item .achievement-icon,.achievement-item .ach-icon{font-size:1.5rem;width:2rem;text-align:center}.achievement-item .achievement-info,.achievement-item .ach-info{flex:1;min-width:0}.achievement-item .achievement-name,.achievement-item .ach-name{font-weight:700;font-size:.85rem;color:var(--theme-text-primary)}.achievement-item .achievement-desc,.achievement-item .ach-desc{font-size:.72rem;color:var(--theme-text-secondary)}.achievement-item .ach-check{color:#fa0;font-size:1.1rem}.ach-category-title{font-size:.7rem;text-transform:uppercase;letter-spacing:.15em;color:var(--theme-text-secondary);margin-top:.8rem;margin-bottom:.3rem;padding-bottom:.2rem;border-bottom:1px solid var(--theme-surface-border)}.leaderboard-list{margin:1rem 0;overflow-y:auto;overflow-x:hidden;max-height:60vh;width:480px;max-width:90vw}.leaderboard-list table{width:100%;border-collapse:collapse}.leaderboard-list th{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--theme-text-secondary);padding:.5rem .3rem;border-bottom:1px solid var(--theme-surface-border);text-align:left}.leaderboard-list td{padding:.45rem .3rem;font-size:.85rem;border-bottom:1px solid color-mix(in srgb,var(--theme-surface-border) 40%,transparent);color:var(--theme-text-primary)}.leaderboard-list .rank-col{color:var(--theme-text-secondary);font-weight:600;width:2rem}.leaderboard-list .name-col{font-family:Consolas,monospace;font-weight:700;color:var(--theme-text-accent)}.leaderboard-list .time-col{font-weight:700;color:#fff}.leaderboard-list .pps-col{color:var(--theme-text-secondary);font-size:.78rem}.leaderboard-list .empty-msg{color:var(--theme-text-secondary);font-size:.85rem;padding:2rem 0;text-align:center}.name-input{background:var(--theme-surface);border:2px solid var(--theme-surface-border);color:var(--theme-text-accent);font-family:Consolas,Courier New,monospace;font-size:1.5rem;font-weight:800;text-align:center;letter-spacing:.1em;width:14rem;padding:.6rem;border-radius:8px;text-transform:uppercase;outline:none;margin:0 auto;display:block}.name-input:focus{border-color:var(--theme-text-accent);box-shadow:0 0 12px color-mix(in srgb,var(--theme-text-accent) 20%,transparent)}.theme-list{display:flex;flex-direction:column;gap:.5rem;margin:1rem 0;overflow-y:auto;overflow-x:hidden;max-height:60vh;width:520px;max-width:90vw}.theme-item{display:flex;align-items:center;gap:.75rem;padding:.7rem .9rem;border-radius:8px;background:color-mix(in srgb,var(--theme-surface) 50%,transparent);border:1px solid var(--theme-surface-border);cursor:pointer;transition:all .2s}.theme-item:hover{border-color:var(--theme-text-accent);background:color-mix(in srgb,var(--theme-surface) 70%,transparent)}.theme-item.active{border-color:var(--theme-text-accent);box-shadow:0 0 12px color-mix(in srgb,var(--theme-text-accent) 15%,transparent)}.theme-preview{display:flex;gap:2px;flex-shrink:0}.theme-preview .swatch,.theme-preview .theme-swatch{width:14px;height:14px;border-radius:3px;display:inline-block}.theme-info{flex:1;min-width:0}.theme-name{font-weight:700;font-size:.9rem;color:var(--theme-text-primary)}.theme-desc{font-size:.7rem;color:var(--theme-text-secondary)}#battle-canvas{display:block;width:100%;height:100%}.lobby-ui{width:100%;height:100%;display:flex;flex-direction:column}#lobby-canvas{flex:1;width:100%;height:100%}.lobby-header{width:100%;padding:1rem 2rem;background:#0a0a0fe6;border-bottom:1px solid var(--theme-surface-border);display:flex;align-items:center;gap:2rem}#lobby-room-name{font-size:1.5rem;font-weight:900;letter-spacing:.1em;color:var(--theme-text-accent)}.lobby-stats{font-size:.8rem;color:var(--theme-text-secondary)}.lobby-actions{display:flex;gap:.5rem;margin-left:auto}.side-panel{position:absolute;top:50%;right:20px;transform:translateY(-50%);width:280px;background:#0a0a0fcc;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1.5rem;z-index:100;display:none;flex-direction:column;gap:1.5rem}#game-screen.practice-mode .side-panel{display:flex}.side-panel h3{margin:0;font-size:1rem;color:var(--theme-text-accent);text-transform:uppercase;letter-spacing:.1em}.side-panel-section{display:flex;flex-direction:column;gap:.5rem}.side-panel-section label{font-size:.8rem;color:var(--theme-text-secondary);display:flex;justify-content:space-between}.side-panel-section .row{display:flex;gap:.5rem}.side-panel-section .menu-btn.small{padding:.5rem;font-size:.8rem;flex:1}.settings-tab[data-tab=audio]{border-bottom-color:#ff0080}.settings-tab[data-tab=audio].active{background:#ff00801a}.arena-leaderboard{position:absolute;top:80px;left:20px;background:#0006;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:1rem;border-radius:8px;border:1px solid rgba(255,255,255,.1);min-width:180px;z-index:100;pointer-events:none;transition:all .4s cubic-bezier(.165,.84,.44,1)}.arena-leaderboard.centered{display:block!important;top:50%;left:50%;transform:translate(-50%,-50%);width:400px;max-width:90vw;background:#0a0a0ff2;border:2px solid var(--theme-text-accent);box-shadow:0 0 40px #00c8ff26;padding:2rem}.arena-leaderboard.centered .leaderboard-title{font-size:1.2rem;margin-bottom:1.5rem}.arena-leaderboard.centered .leaderboard-entry{padding:.6rem 0;font-size:1.1rem}.arena-leaderboard.centered .leaderboard-entry.header{font-size:.8rem;margin-bottom:.8rem}.leaderboard-title{font-size:.75rem;font-weight:800;color:var(--theme-text-accent);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.1em}.leaderboard-entry{display:flex;justify-content:space-between;font-size:.85rem;padding:.2rem 0;border-bottom:1px solid rgba(255,255,255,.05)}.leaderboard-entry.header{font-weight:800;font-size:.65rem;color:#666;border-bottom:2px solid rgba(255,255,255,.1);margin-bottom:.3rem}.leaderboard-entry:last-child{border-bottom:none}.leaderboard-entry span:last-child{color:var(--theme-text-accent);font-weight:600}.lobby-room-controls{display:flex;gap:.5rem;align-items:center;background:#0000004d;padding:.3rem .5rem;border-radius:6px;border:1px solid var(--theme-surface-border)}.small-input{background:var(--theme-surface);border:1px solid var(--theme-surface-border);color:var(--theme-text-accent);font-family:Consolas,monospace;font-size:.85rem;font-weight:700;padding:.4rem .6rem;border-radius:4px;width:100px;text-transform:uppercase;outline:none}.small-input:focus{border-color:var(--theme-text-accent)}.lobby-ui .menu-btn.small{white-space:nowrap}.lobby-content{display:flex;flex:1;width:100%;position:relative;overflow:hidden}.lobby-leaderboard{position:absolute;top:1rem;right:1rem;width:220px;background:#0a0a0fd9;border:1px solid var(--theme-surface-border);border-radius:12px;padding:1rem;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);pointer-events:none}.lobby-leaderboard h3{font-size:.75rem;color:var(--theme-text-secondary);letter-spacing:.2em;margin-bottom:.75rem;text-align:center}.lobby-entry{display:flex;justify-content:space-between;font-size:.85rem;padding:.4rem 0;border-bottom:1px solid rgba(255,255,255,.05)}.lobby-entry:last-child{border-bottom:none}.lobby-entry .rank{color:var(--theme-text-secondary);width:1.5rem}.lobby-entry .name{flex:1;font-weight:600;padding:0 .5rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lobby-entry .score{color:var(--theme-text-accent);font-family:Consolas,monospace;font-weight:700}.lobby-entry .meta{font-size:.65rem;color:var(--theme-text-secondary);margin-left:.5rem}.public-rooms-container{margin-top:1.5rem;border-top:1px solid var(--theme-surface-border);padding-top:1rem;text-align:left;min-width:300px}.public-rooms-container h3{font-size:.7rem;color:var(--theme-text-secondary);letter-spacing:.15em;margin-bottom:.5rem}.public-rooms-list{display:flex;flex-direction:column;gap:.5rem;max-height:200px;overflow-y:auto}.room-entry{display:flex;justify-content:space-between;align-items:center;background:var(--theme-surface);border:1px solid var(--theme-surface-border);padding:.5rem .75rem;border-radius:6px;cursor:pointer;transition:all .2s}.room-entry:hover{border-color:var(--theme-text-accent);background:var(--theme-surface-hover)}.room-entry .room-info-left{display:flex;flex-direction:column;gap:2px}.room-entry .room-id{font-weight:700;color:var(--theme-text-primary);font-size:.9rem}.room-entry .room-tag{font-size:.6rem;font-weight:800;color:var(--theme-text-accent);letter-spacing:.05em;opacity:.8}.room-entry .room-meta{font-size:.75rem;color:var(--theme-text-secondary)}.room-setup-row{display:flex;gap:.5rem;justify-content:center;margin-bottom:1rem}.room-options{display:flex;flex-direction:column;align-items:center;gap:.5rem}.check-container{display:flex;align-items:center;gap:.75rem;cursor:pointer;font-size:.85rem;color:var(--theme-text-secondary);-webkit-user-select:none;user-select:none}.check-container input{display:none}.checkmark{width:20px;height:20px;background:var(--theme-surface);border:2px solid var(--theme-surface-border);border-radius:4px;position:relative;transition:all .2s}.check-container:hover .checkmark{border-color:var(--theme-text-accent)}.check-container input:checked+.checkmark{background:var(--theme-text-accent);border-color:var(--theme-text-accent)}.check-container input:checked+.checkmark:after{content:"✔";position:absolute;color:var(--theme-bg);font-size:14px;top:50%;left:50%;transform:translate(-50%,-50%)}.touch-pause-btn{display:none;position:absolute;top:env(safe-area-inset-top,8px);right:10px;z-index:60;width:44px;height:44px;border-radius:12px;background:#ffffff12;border:1.5px solid rgba(255,255,255,.12);color:#ffffff8c;font-size:1.3rem;line-height:1;cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-user-select:none;user-select:none;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);transition:background .15s,border-color .15s}.touch-pause-btn:active{background:#00c8ff26;border-color:var(--theme-text-accent, #00c8ff);color:#fff}.touch-active .touch-pause-btn{display:flex;align-items:center;justify-content:center}.touch-overlay{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:50;display:flex}.touch-overlay>*{pointer-events:auto}.touch-overlay-left{position:absolute;bottom:env(safe-area-inset-bottom,16px);left:12px;display:flex;gap:10px;padding-bottom:16px}.touch-overlay-right{position:absolute;bottom:env(safe-area-inset-bottom,16px);right:12px;display:flex;gap:10px;padding-bottom:16px}.touch-overlay-center{position:absolute;top:env(safe-area-inset-top,12px);right:12px;display:flex;padding-top:12px}.touch-overlay-bottom{position:absolute;bottom:calc(env(safe-area-inset-bottom,16px) + 76px);left:50%;transform:translate(-50%);display:flex;gap:16px}.touch-btn{width:60px;height:60px;border-radius:50%;background:#ffffff14;border:2px solid rgba(255,255,255,.15);color:#fff9;font-size:1.4rem;font-weight:700;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-user-select:none;user-select:none;transition:background .1s,border-color .1s}.touch-btn:active{background:#00c8ff33;border-color:var(--theme-text-accent);color:#fff}.touch-btn-hold{width:auto;border-radius:24px;padding:0 16px;height:44px;font-size:.8rem;letter-spacing:.1em}.touch-btn-harddrop{background:#ff3c3c1f;border-color:#ff3c3c4d}.touch-btn-harddrop:active{background:#ff3c3c4d;border-color:#ff3c3c99}.landscape-warning{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:var(--theme-bg);z-index:10000;justify-content:center;align-items:center;flex-direction:column;gap:1rem;color:var(--theme-text-primary);text-align:center;padding:2rem}.landscape-warning .rotate-icon{font-size:4rem;animation:rotatePhone 2s ease-in-out infinite}.landscape-warning h2{font-size:1.5rem;font-weight:900;letter-spacing:.1em}.landscape-warning p{color:var(--theme-text-secondary);font-size:.9rem}@keyframes rotatePhone{0%,to{transform:rotate(0)}25%{transform:rotate(-90deg)}50%{transform:rotate(-90deg)}75%{transform:rotate(0)}}@media(max-width:768px)and (orientation:landscape){.landscape-warning{display:flex!important}#app{display:none!important}}#app{touch-action:manipulation}canvas{touch-action:none}body{padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}@media(max-width:640px){.menu-buttons{min-width:auto;width:100%}.menu-layout{padding:1rem;padding-top:env(safe-area-inset-top,1rem)}.menu-container{width:100%;padding:0 .5rem}.game-title{font-size:clamp(1.6rem,8vw,2.5rem)}.tagline{font-size:.75rem;letter-spacing:.15em}.menu-btn{padding:.75rem 1rem;font-size:.9rem}.btn-icon{font-size:1.2rem;width:1.5rem}.btn-text{font-size:.95rem}.btn-desc{font-size:.65rem}.overlay-content{min-width:200px;max-width:90vw;padding:1rem}.overlay-content h2{font-size:1.8rem}.countdown-number{font-size:5rem}.settings-container{width:100%;max-width:100vw;max-height:100vh;height:100%;border-radius:0}.settings-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap;padding:0 .5rem}.settings-tabs::-webkit-scrollbar{display:none}.settings-tab{white-space:nowrap;padding:.6rem .8rem;font-size:.75rem;flex-shrink:0}.settings-body{padding:1rem}.lobby-header{flex-wrap:wrap;padding:.75rem 1rem;gap:.5rem}.lobby-actions{flex-wrap:wrap;gap:.4rem}.lobby-leaderboard{width:160px;padding:.5rem;font-size:.75rem;display:none}.lobby-leaderboard.show-mobile{display:block}.arena-leaderboard{display:none}.arena-leaderboard.show-mobile{display:block}.side-panel{position:fixed;top:auto;bottom:0;right:0;left:0;width:100%;transform:none;border-radius:12px 12px 0 0;max-height:40vh;overflow-y:auto;padding:1rem}.toast-container{top:auto;bottom:1rem;right:.5rem;left:.5rem}.toast{min-width:auto;max-width:100%}}@media(max-width:360px){.menu-btn{padding:.6rem .75rem;gap:.5rem}.btn-icon{font-size:1rem;width:1.2rem}.btn-text{font-size:.85rem}.game-title{font-size:1.4rem}}@media(display-mode:standalone){body{overscroll-behavior:none}}
