:root{--bg: #0b0d17;--bg-elev: #141728;--bg-elev-2: #1c2039;--border: #2a2f4a;--text: #e7e9f4;--text-muted: #9aa0c0;--accent: #7c3aed;--accent-2: #ec4899;--success: #10b981;--danger: #ef4444;--warning: #f59e0b;--radius: 14px;--radius-sm: 8px;--shadow: 0 10px 30px rgba(0, 0, 0, .4);--font-sans: "Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px);--safe-right: env(safe-area-inset-right, 0px)}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;min-height:100%;background:var(--bg);color:var(--text);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;text-size-adjust:100%;-webkit-text-size-adjust:100%}body{background:radial-gradient(circle at 20% 20%,rgba(124,58,237,.25),transparent 50%),radial-gradient(circle at 80% 0%,rgba(236,72,153,.18),transparent 45%),var(--bg);min-height:100vh;min-height:100dvh;overscroll-behavior:none}body.in-game{overflow:hidden;position:fixed;inset:0;width:100%;height:100%}a{color:var(--accent-2);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit;cursor:pointer;touch-action:manipulation}input,select,textarea{font-family:inherit;font-size:16px}.app-shell{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;padding-left:var(--safe-left);padding-right:var(--safe-right)}.app-header{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;padding-top:calc(14px + var(--safe-top));border-bottom:1px solid var(--border);backdrop-filter:blur(10px);background:#0b0d1799;position:sticky;top:0;z-index:10}.brand{display:flex;align-items:center;gap:12px;font-weight:700;font-size:18px;letter-spacing:.02em}.brand-mark{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:grid;place-items:center;color:#fff;font-weight:900}.app-main{flex:1;width:100%;max-width:1100px;margin:0 auto;padding:24px;padding-bottom:calc(24px + var(--safe-bottom))}.app-footer{padding:16px 24px;padding-bottom:calc(16px + var(--safe-bottom));border-top:1px solid var(--border);color:var(--text-muted);font-size:13px;text-align:center}.card{background:linear-gradient(180deg,var(--bg-elev),var(--bg-elev-2));border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px;padding:10px 18px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-elev);color:var(--text);font-weight:600;font-size:15px;transition:transform .05s ease,background .15s ease,border-color .15s ease}.btn:hover{background:var(--bg-elev-2);border-color:var(--accent)}.btn:active{transform:translateY(1px)}.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent-2));border-color:transparent;color:#fff}.btn-primary:hover{filter:brightness(1.1)}.btn-ghost{background:transparent}.btn:disabled{opacity:.5;cursor:not-allowed}.input{width:100%;padding:12px 14px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:16px;outline:none;transition:border-color .15s ease,box-shadow .15s ease}.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #7c3aed40}.label{display:block;font-size:13px;color:var(--text-muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.06em}.hero{text-align:center;padding:36px 8px 24px}.hero h1{font-size:clamp(32px,7vw,56px);line-height:1.1;margin:0 0 12px;background:linear-gradient(135deg,#fff,#c4b5fd 60%,var(--accent-2));-webkit-background-clip:text;background-clip:text;color:transparent}.hero p{color:var(--text-muted);font-size:clamp(15px,2.4vw,18px);margin:0}.games-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;margin-top:20px}.game-card{display:flex;flex-direction:column;gap:12px;cursor:pointer;transition:transform .15s ease,border-color .15s ease}.game-card:hover{transform:translateY(-2px);border-color:var(--accent)}.game-card.unavailable{opacity:.6;cursor:not-allowed}.game-card .thumb{width:100%;aspect-ratio:16 / 9;border-radius:10px;background:linear-gradient(135deg,#1e1b4b,#4c1d95);display:grid;place-items:center;overflow:hidden}.game-card .thumb img{width:100%;height:100%;object-fit:cover}.game-card h3{margin:0;font-size:20px}.game-card p{margin:0;color:var(--text-muted);font-size:14px;line-height:1.5}.tags{display:flex;flex-wrap:wrap;gap:6px}.tag{font-size:11px;padding:3px 8px;border-radius:99px;background:#7c3aed26;color:#c4b5fd;border:1px solid rgba(124,58,237,.4);text-transform:uppercase;letter-spacing:.06em}.section-title{display:flex;align-items:center;justify-content:space-between;margin:20px 0 4px}.section-title h2{margin:0;font-size:22px}.row{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.row>*{flex:1 1 0}.dialog{position:fixed;inset:0;background:#0009;display:grid;place-items:center;z-index:50;padding:16px;padding-top:calc(16px + var(--safe-top));padding-bottom:calc(16px + var(--safe-bottom))}.dialog .card{width:min(440px,100%);max-height:100%;overflow:auto}.lobby{display:grid;grid-template-columns:2fr 1fr;gap:20px}@media (max-width: 800px){.lobby{grid-template-columns:1fr}}.code-pill{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:var(--radius-sm);background:var(--bg);border:1px dashed var(--border);font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:18px;letter-spacing:.2em}.player-list{display:flex;flex-direction:column;gap:8px}.player-row{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm)}.player-dot{width:14px;height:14px;border-radius:50%;flex-shrink:0}.chat{display:flex;flex-direction:column;gap:8px;height:240px}.chat-log{flex:1;overflow-y:auto;padding:10px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px}.chat-log .msg{margin-bottom:4px}.chat-log .name{font-weight:600;margin-right:6px}.game-canvas-wrap{position:relative;display:flex;justify-content:center}.game-canvas{width:100%;max-width:1280px;aspect-ratio:16 / 9;background:#000;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);touch-action:none;user-select:none;-webkit-user-select:none}body.in-game,body.in-game *:not(input):not(textarea):not(select){user-select:none!important;-webkit-user-select:none!important;-webkit-touch-callout:none!important;-webkit-tap-highlight-color:transparent!important;-webkit-user-drag:none!important}body.in-game canvas{-webkit-user-select:none!important;-webkit-touch-callout:none!important;-webkit-user-drag:none!important;user-select:none!important;touch-action:none}.game-page.fullscreen{position:fixed;inset:0;z-index:40;background:#0b0d17;padding:0;display:flex;flex-direction:column}.game-page.fullscreen .game-toolbar{position:absolute;top:0;left:var(--safe-left);right:var(--safe-right);z-index:60;padding:8px 12px;padding-top:calc(8px + var(--safe-top));margin:0;background:linear-gradient(180deg,rgba(0,0,0,.55),transparent)}.game-page.fullscreen .game-canvas-wrap{flex:1;position:relative;display:flex;align-items:stretch;justify-content:stretch}.voice-bar-floating{justify-content:center;margin:0 0 10px}.game-page.fullscreen .voice-bar-floating{position:absolute;top:calc(48px + var(--safe-top));left:50%;transform:translate(-50%);margin:0;z-index:55;pointer-events:none}.game-page.fullscreen .voice-bar-floating .voice-peer{pointer-events:auto}.game-page.fullscreen .game-canvas{width:100vw;height:100vh;height:100dvh;max-width:none;aspect-ratio:auto;border-radius:0;box-shadow:none}.game-page.fullscreen .game-canvas canvas{display:block;width:100%!important;height:100%!important}.game-toolbar{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:14px;flex-wrap:wrap}.game-toolbar .meta{min-width:0}.game-toolbar .meta h2{margin:0;font-size:18px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.game-toolbar .meta p{margin:2px 0 0;font-size:13px;color:var(--text-muted)}.game-page.fullscreen .game-toolbar{margin-bottom:0;flex-wrap:nowrap}.game-page.fullscreen .game-toolbar .meta p{display:none}.game-page.fullscreen .game-toolbar .meta h2{font-size:15px;color:#ffffffeb}.touch-btn{border:0;outline:0;background:#ffffff0a;color:#ffffffd9;font-weight:500;display:grid;place-items:center;user-select:none;-webkit-user-select:none;touch-action:none;transition:transform .04s ease,background .1s ease,color .1s ease}.touch-btn:active,.touch-btn.active{background:#ffffff2e;color:#fff;transform:scale(.96)}.touch-btn.jump{background:#ec48991a;color:#ffffffeb}.touch-btn.jump:active,.touch-btn.jump.active{background:#ec48996b}.touch-btn.shoot{background:#fbbf241a;color:#ffffffeb}.touch-btn.shoot:active,.touch-btn.shoot.active{background:#fbbf246b}.touch-controls-overlay{position:absolute;inset:0;pointer-events:none;z-index:30;padding:16px;padding-left:calc(16px + var(--safe-left));padding-right:calc(16px + var(--safe-right));padding-bottom:calc(12px + var(--safe-bottom));display:flex;align-items:flex-end;justify-content:space-between;gap:16px}.touch-controls-overlay .touch-pad{display:flex;gap:12px;pointer-events:auto}.touch-controls-overlay .touch-btn{width:74px;height:74px;border-radius:22px;font-size:26px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.touch-controls-overlay .touch-btn.jump,.touch-controls-overlay .touch-btn.shoot{width:84px;height:84px;font-size:24px}.touch-controls-bar{flex:1;display:grid;grid-template-columns:1fr 1.1fr 1fr 1.1fr;gap:8px;padding:12px 10px calc(16px + var(--safe-bottom));align-content:center;width:100%}.touch-controls-bar .touch-btn{width:100%;height:100%;min-height:90px;border-radius:18px;font-size:30px}.touch-controls-bar .touch-btn.jump,.touch-controls-bar .touch-btn.shoot{font-size:26px}.character-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.character-tile{display:flex;align-items:center;gap:14px;padding:12px;border-radius:var(--radius);border:2px solid var(--border);background:var(--bg);color:var(--text);text-align:left;cursor:pointer;transition:transform .05s ease,border-color .15s ease,background .15s ease}.character-tile:hover:not(:disabled){border-color:var(--accent)}.character-tile:active:not(:disabled){transform:translateY(1px)}.character-tile.active{border-color:var(--accent);background:linear-gradient(180deg,#7c3aed2e,#ec48991f);box-shadow:0 0 0 3px #7c3aed40}.character-tile:disabled{opacity:.6;cursor:not-allowed}.character-meta{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.character-name{font-weight:700;font-size:15px}.character-desc{color:var(--text-muted);font-size:12px;line-height:1.4}.mode-picker{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.mode-tile{display:flex;flex-direction:column;gap:6px;padding:14px;border-radius:var(--radius);border:2px solid var(--border);background:var(--bg);color:var(--text);text-align:left;cursor:pointer;transition:transform .05s ease,border-color .15s ease,background .15s ease}.mode-tile:hover:not(:disabled){border-color:var(--accent)}.mode-tile:active:not(:disabled){transform:translateY(1px)}.mode-tile.active{background:linear-gradient(180deg,#7c3aed2e,#38bdf814)}.mode-tile:disabled{opacity:.55;cursor:not-allowed}.mode-title{font-weight:800;font-size:15px;letter-spacing:.5px}.mode-desc{color:var(--text-muted);font-size:12.5px;line-height:1.45}.sounds-panel{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}.sounds-panel.hero{margin-bottom:20px;border:1px solid rgba(236,72,153,.35);box-shadow:0 10px 30px #0006,0 0 0 1px #7c3aed2e,0 0 40px #ec48991f;background:radial-gradient(circle at 0% 0%,rgba(124,58,237,.25),transparent 60%),radial-gradient(circle at 100% 0%,rgba(236,72,153,.22),transparent 55%),var(--bg-elev);animation:sounds-glow 4.5s ease-in-out infinite}@keyframes sounds-glow{0%,to{box-shadow:0 10px 30px #0006,0 0 0 1px #7c3aed2e,0 0 40px #ec48991f}50%{box-shadow:0 14px 36px #00000073,0 0 0 1px #ec489959,0 0 60px #ec489938}}.sounds-panel-header{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 18px;background:transparent;border:0;color:var(--text);cursor:pointer;text-align:left;font:inherit}.sounds-panel-header:hover{background:#ffffff0a}.sounds-panel-title{display:flex;align-items:center;gap:14px;font-weight:700;flex:1;min-width:0}.sounds-panel-emoji{font-size:28px;line-height:1;filter:drop-shadow(0 0 8px rgba(236,72,153,.55));animation:sounds-bounce 2.2s ease-in-out infinite}@keyframes sounds-bounce{0%,to{transform:translateY(0) rotate(-3deg)}50%{transform:translateY(-2px) rotate(3deg)}}.sounds-panel-titletext{display:flex;flex-direction:column;gap:2px;min-width:0}.sounds-panel-headline{display:inline-flex;align-items:center;gap:10px;font-size:16px;font-weight:800;letter-spacing:.2px;background:linear-gradient(90deg,#fff,#fbcfe8 60%,#c4b5fd);-webkit-background-clip:text;background-clip:text;color:transparent}.sounds-panel-subline{font-size:12.5px;font-weight:500;color:var(--text-muted);line-height:1.4}.sounds-panel-title .badge{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 6px;border-radius:11px;background:var(--accent);color:#fff;font-size:12px;font-weight:700}.sounds-panel-chevron{color:var(--text-muted);font-size:14px;flex:0 0 auto}.sounds-panel-body{padding:12px 18px 18px;border-top:1px solid rgba(255,255,255,.08)}.sounds-warn{background:#fbbf241f;border:1px solid rgba(251,191,36,.35);color:#fde68a;border-radius:10px;padding:8px 12px;margin:8px 0 12px;font-size:13px}.sounds-error{background:#dc262626;border:1px solid rgba(220,38,38,.45);color:#fecaca;border-radius:10px;padding:8px 12px;margin:8px 0 12px;font-size:13px}.sounds-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.sound-row{display:flex;align-items:center;gap:14px;padding:10px 12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);flex-wrap:wrap}.sound-info{flex:1;min-width:200px;display:flex;flex-direction:column;gap:3px}.sound-name{display:flex;align-items:center;gap:8px;font-weight:700;font-size:14px}.sound-hint{color:var(--text-muted);font-size:12.5px;line-height:1.4}.sound-meta{color:var(--text-muted);font-size:12px}.sound-actions{display:flex;gap:8px;flex-wrap:wrap}.tag-custom{background:#38bdf82e;color:#7dd3fc}.tag-default{background:#ffffff14;color:var(--text-muted)}.btn-small{padding:6px 12px;font-size:13px}.btn-danger{background:var(--danger);color:#fff;border-color:transparent}.sound-progress{position:relative;height:6px;background:#ffffff0f;border-radius:3px;margin-top:6px;overflow:hidden}.sound-progress-bar{position:absolute;inset:0 auto 0 0;background:linear-gradient(90deg,var(--accent),var(--accent-2));transition:width .1s linear}.sound-progress-label{position:absolute;inset:-22px 0 auto;text-align:right;color:var(--accent-2);font-size:12px;font-weight:700}.player-avatar{width:28px;height:28px;border-radius:8px;overflow:hidden;flex-shrink:0;background:#0b0d17;display:grid;place-items:center}.player-avatar svg{width:100%;height:100%}.audio-panel{display:flex;flex-direction:column;gap:16px}.audio-panel-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.audio-panel-head h3{margin:0;font-size:18px}.audio-master{font-size:13px;min-height:36px;padding:6px 12px}.audio-row{display:flex;flex-direction:column;gap:8px}.audio-row-head{display:flex;align-items:center;gap:10px}.audio-mute{border:1px solid var(--border);background:var(--bg);color:var(--text);width:40px;height:40px;border-radius:var(--radius-sm);font-size:18px;display:grid;place-items:center;flex:0 0 auto}.audio-mute.muted{background:#ef444426;border-color:var(--danger);color:var(--danger)}.audio-label-block{display:flex;flex-direction:column;flex:1;min-width:0}.audio-label{font-weight:600;font-size:14px}.audio-hint{font-size:12px;color:var(--text-muted)}.audio-value{font-variant-numeric:tabular-nums;font-size:13px;color:var(--text-muted);flex:0 0 auto;min-width:48px;text-align:right}.audio-slider{-webkit-appearance:none;appearance:none;width:100%;height:6px;background:var(--bg);border:1px solid var(--border);border-radius:999px;outline:none;touch-action:manipulation}.audio-slider:disabled{opacity:.4}.audio-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:22px;height:22px;background:linear-gradient(135deg,var(--accent),var(--accent-2));border-radius:50%;border:2px solid var(--bg);cursor:pointer;box-shadow:0 2px 8px #7c3aed80}.audio-slider::-moz-range-thumb{width:22px;height:22px;background:linear-gradient(135deg,var(--accent),var(--accent-2));border-radius:50%;border:2px solid var(--bg);cursor:pointer}.settings-fab{display:inline-grid;place-items:center;width:44px;height:44px;border-radius:50%;border:1px solid var(--border);background:#141728b3;backdrop-filter:blur(6px);color:var(--text);font-size:20px;flex:0 0 auto}.settings-fab:hover{border-color:var(--accent)}.voice-bar{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.voice-peer{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:999px;background:#00000073;border:1px solid var(--border);font-size:12px;color:var(--text);backdrop-filter:blur(4px)}.voice-peer.speaking{border-color:var(--success);background:#10b98126;box-shadow:0 0 0 2px #10b9814d}.voice-peer.muted{opacity:.5}.voice-dot{width:8px;height:8px;border-radius:50%}.toast{position:fixed;bottom:calc(24px + var(--safe-bottom));left:50%;transform:translate(-50%);background:var(--bg-elev-2);border:1px solid var(--border);padding:10px 16px;border-radius:var(--radius-sm);z-index:100;box-shadow:var(--shadow);max-width:calc(100% - 32px)}.toast.error{border-color:var(--danger)}@media (max-width: 640px){.app-header{padding:12px 16px;padding-top:calc(12px + var(--safe-top))}.app-main{padding:16px;padding-bottom:calc(16px + var(--safe-bottom))}.card{padding:16px}.games-grid{grid-template-columns:1fr}.row{flex-direction:column;align-items:stretch}.row>*{flex:1 1 auto}.brand span:not(.brand-mark){display:none}}
