:root{--bg:#0c0f1a;--panel:#111828;--panel-2:#161e30;--line:#232d44;--text:#d8e0f2;--muted:#66769a;--accent:#6366f1;--accent-2:#06b6d4;--danger:#f87171;font-feature-settings:"cv11", "ss01";font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}body{background:var(--bg);color:var(--text);background-image:radial-gradient(90% 55% at 50% -5%,#6366f121 0%,#0000 70%),radial-gradient(60% 40% at 90% 110%,#06b6d412 0%,#0000 70%);background-attachment:fixed}button{font-family:inherit}input,textarea{color:var(--text);font-family:inherit}code{color:#a5b4fc;background:#6366f124;border-radius:5px;padding:1px 6px;font-size:.95em}.pong-wrap{flex-direction:column;align-items:center;gap:14px;padding:20px 16px;display:flex}.pong-scores{align-items:center;gap:18px;font-size:1.2rem;font-weight:700;display:flex}.pong-pname{color:var(--muted)}.pong-pname.pong-me{color:var(--text)}.pong-scorenums{color:var(--text);letter-spacing:.05em;text-align:center;min-width:80px;font-size:1.6rem;font-weight:800}.pong-field{aspect-ratio:16/9;border:1px solid var(--line);background:#050810;border-radius:6px;width:100%;max-width:800px;position:relative;overflow:hidden}.pong-midline{background:repeating-linear-gradient(to bottom, var(--line) 0, var(--line) 10px, transparent 10px, transparent 22px);width:2px;position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%)}.pong-paddle{background:var(--text);border-radius:3px;width:1.5%;height:17.8%;position:absolute;transform:translateY(-50%)}.pong-paddle-l{left:2.25%}.pong-paddle-r{right:2.25%}.pong-ball{aspect-ratio:1;background:#fff;border-radius:50%;width:2%;position:absolute;transform:translate(-50%,-50%);box-shadow:0 0 12px #ffffffbf}.pong-over{background:#050810d1;flex-direction:column;justify-content:center;align-items:center;gap:18px;display:flex;position:absolute;inset:0}.pong-over-msg{color:var(--text);font-size:1.8rem;font-weight:800}.pong-hint{color:var(--muted);text-align:center;font-size:.82rem}.av-view{flex-direction:column;gap:14px;max-width:520px;margin:0 auto;display:flex}.av-history{flex-wrap:wrap;justify-content:center;gap:6px;min-height:26px;display:flex}.av-chip{background:var(--panel-2);border-radius:20px;padding:2px 8px;font-size:.78rem;font-weight:700}.av-chip.low{color:#ff8a8a}.av-chip.mid{color:#ffd27a}.av-chip.high{color:#8ff0a4}.av-plot{aspect-ratio:5/3;border:1px solid var(--line);background:radial-gradient(circle at 30% 90%,#1a1030,#0c0f1a 70%);border-radius:16px;width:100%;position:relative;overflow:hidden}.av-plot.betting{background:radial-gradient(circle,#0e1828,#0c0f1a 70%)}.av-svg{width:100%;height:100%;position:absolute;inset:0}.av-overlay{pointer-events:none;text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.av-mult{letter-spacing:.02em;text-shadow:0 2px 12px #00000080;font-size:3.6rem;font-weight:800}.av-mult.flying{color:#fff}.av-mult.crashed{color:var(--danger)}.av-flewaway{color:var(--danger);letter-spacing:.18em;margin-top:4px;font-weight:800}.av-place{color:#cfe3ff;font-size:1.8rem;font-weight:700}.av-sub{color:var(--muted);margin-top:6px}.av-controls{flex-direction:column;align-items:center;gap:10px;display:flex}.av-balance{font-size:.95rem}.av-bet-row{gap:8px;display:flex}.av-bet-row input{border:1px solid var(--line);width:110px;color:var(--text);background:#ffffff0a;border-radius:8px;outline:none;padding:9px 12px;font-family:inherit}.av-bet-row input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #6366f124}.btn.cashout{color:#1a0e00;background:linear-gradient(135deg,#f59e0b,#d97706);padding:12px 26px;font-size:1.05rem;box-shadow:0 2px 10px #f59e0b59}.btn.cashout:hover{filter:brightness(1.08);box-shadow:0 4px 18px #f59e0b80}.av-won{color:var(--accent-2);font-weight:700}.av-players{font-size:.9rem}.av-prow{grid-template-columns:1.3fr auto 1.4fr;align-items:center;gap:10px;padding:4px 0;display:grid}.av-prow span:last-child{text-align:right}.av-prow span:nth-child(2){text-align:right;font-variant-numeric:tabular-nums;font-weight:700}.av-up{color:var(--accent-2)}.av-down{color:var(--danger)}.av-biggest{text-align:center;font-size:.92rem}.av-footer{text-align:center;font-size:.8rem}.btn{color:#fff;cursor:pointer;letter-spacing:.012em;background:linear-gradient(135deg,#6366f1 0%,#8b5cf6 100%);border:none;border-radius:9px;align-items:center;gap:6px;padding:10px 20px;font-size:.95rem;font-weight:600;transition:filter .15s,transform .1s,box-shadow .15s;display:inline-flex;box-shadow:0 2px 10px #6366f14d}.btn:hover{filter:brightness(1.1);transform:translateY(-1px);box-shadow:0 6px 20px #6366f170}.btn:active{filter:brightness(.93);transform:translateY(0)}.btn.ghost{border:1px solid var(--line);color:var(--text);box-shadow:none;background:0 0}.btn.ghost:hover{filter:none;box-shadow:none;background:#6366f117;border-color:#6366f180;transform:none}.btn.small{padding:7px 14px;font-size:.84rem}.panel{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:18px}.panel-title{text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:12px;font-size:.72rem;font-weight:600}.muted{color:var(--muted);font-size:.88rem}.status{font-size:1rem}.status.over{color:var(--accent-2);font-weight:700}.endgame{gap:8px;display:flex}.brand-logo{align-items:center;gap:12px;display:inline-flex}.brand-icon{filter:drop-shadow(0 0 14px #8b5cf68c);flex-shrink:0;display:block}.brand-name{letter-spacing:-.03em;background:linear-gradient(135deg,#e8ecff 0%,#a5b4fc 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:2.4rem;font-weight:800;line-height:1}.brand-logo--sm .brand-name{font-size:1.35rem}.landing{max-width:700px;margin:0 auto;padding:60px 20px 80px}.landing-hero{text-align:center;margin-bottom:46px}.landing-tagline{color:var(--muted);margin:16px 0 0;font-size:1.05rem;line-height:1.6}.landing-features{flex-wrap:wrap;justify-content:center;gap:8px;margin-top:22px;display:flex}.feature-chip{color:var(--text);border:1px solid var(--line);background:#ffffff0a;border-radius:20px;padding:6px 14px;font-size:.78rem;font-weight:600}.name-panel{flex-direction:column;gap:8px;margin-bottom:24px;display:flex}.name-panel label{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-size:.74rem;font-weight:600}.name-panel input,.join-row input{border:1px solid var(--line);color:var(--text);background:#ffffff0a;border-radius:10px;outline:none;padding:11px 14px;font-family:inherit;font-size:.97rem;transition:border-color .15s,box-shadow .15s}.name-panel input:focus,.join-row input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #6366f124}.play-options{grid-template-columns:repeat(auto-fit,minmax(272px,1fr));gap:14px;display:grid}.play-card{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:26px;transition:border-color .2s,box-shadow .2s}.play-card:hover{border-color:#6366f166;box-shadow:0 0 0 1px #6366f11a,0 10px 30px #00000059}.play-card h3{margin:0 0 8px;font-size:1.05rem;font-weight:700}.play-card p{color:var(--muted);margin:0 0 18px;font-size:.9rem;line-height:1.55}.join-row{gap:8px;margin-top:14px;display:flex}.join-row input{text-transform:uppercase;letter-spacing:.1em;flex:1;min-width:0}.join-row .btn{flex-shrink:0}.disabled-note{color:var(--muted);font-size:.85rem;line-height:1.6}.lobby{max-width:1120px;margin:0 auto;padding:22px 24px 80px}.lobby-topbar{border:1px solid var(--line);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#111828b3;border-radius:14px;align-items:center;gap:14px;margin-bottom:24px;padding:12px 16px;display:flex}.topbar-spacer{flex:1}.room-pill{cursor:pointer;color:var(--text);background:#06b6d414;border:1px solid #06b6d447;border-radius:10px;align-items:center;gap:9px;padding:6px 12px;font-family:inherit;transition:background .15s,border-color .15s;display:inline-flex}.room-pill:hover{background:#06b6d424;border-color:#06b6d480}.room-pill-label{letter-spacing:.1em;color:var(--muted);font-size:.62rem;font-weight:700}.room-pill-code{letter-spacing:.12em;color:var(--accent-2);font-family:ui-monospace,Cascadia Code,Consolas,monospace;font-size:1.05rem;font-weight:700}.room-pill-copy{color:var(--muted);font-size:.7rem}.room-pill--local{cursor:default;color:var(--muted);font-size:.8rem;font-weight:600}.room-pill--local:hover{background:#06b6d414;border-color:#06b6d447}.player-avatars{align-items:center;display:flex}.player-avatars .avatar:not(:first-child){margin-left:-8px}.avatar{color:#fff;border:2px solid var(--bg);text-shadow:0 1px 2px #00000059;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.72rem;font-weight:700;display:inline-flex}.avatar--sm{border-width:0;width:28px;height:28px;font-size:.66rem}.lobby-grid{grid-template-columns:240px 1fr;align-items:start;gap:20px;display:grid}@media (width<=760px){.lobby-grid{grid-template-columns:1fr}}.players{margin:0;padding:0;list-style:none}.players li{border-bottom:1px solid #ffffff0d;align-items:center;gap:10px;padding:9px 0;display:flex}.players li:last-child{border-bottom:none}.players .pname{flex:1;align-items:center;gap:7px;font-size:.9rem;display:flex}.players .pscore{font-variant-numeric:tabular-nums;color:var(--muted);font-size:.88rem;font-weight:700}.host-tag{letter-spacing:.08em;color:var(--accent-2);border:1px solid #06b6d466;border-radius:5px;padding:1px 5px;font-size:.56rem;font-weight:700}.library-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:16px;display:flex}.library-heading{align-items:baseline;gap:10px;display:flex}.library-heading h2{letter-spacing:-.025em;margin:0;font-size:1.5rem;font-weight:800}.library-count{color:var(--muted);font-size:.85rem;font-weight:500}.library-tools{align-items:center;gap:10px;display:flex}.search-box{align-items:center;display:flex;position:relative}.search-icon{color:var(--muted);pointer-events:none;font-size:1rem;position:absolute;left:12px}.search-box input{border:1px solid var(--line);color:var(--text);background:#ffffff0a;border-radius:10px;outline:none;width:230px;padding:9px 32px;font-family:inherit;font-size:.9rem;transition:border-color .15s,box-shadow .15s}.search-box input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #6366f124}.search-clear{color:var(--muted);cursor:pointer;background:0 0;border:none;padding:2px 4px;font-size:.8rem;position:absolute;right:8px}.search-clear:hover{color:var(--text)}.category-chips{flex-wrap:wrap;gap:8px;margin-bottom:20px;display:flex}.chip{border:1px solid var(--line);color:var(--muted);cursor:pointer;background:0 0;border-radius:20px;padding:6px 15px;font-size:.82rem;font-weight:600;transition:all .15s}.chip:hover{color:var(--text);border-color:#6366f173}.chip--active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 2px 10px #6366f152}.game-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;display:grid}.game-card{text-align:left;background:var(--panel);border:1px solid var(--line);cursor:pointer;color:var(--text);border-radius:16px;padding:0;transition:border-color .18s,transform .16s,box-shadow .2s;position:relative;overflow:hidden}.game-card:hover{border-color:var(--accent);box-shadow:0 14px 36px color-mix(in srgb, var(--accent) 28%, transparent);transform:translateY(-4px)}.game-card-thumb{border-bottom:1px solid var(--line);justify-content:center;align-items:center;height:116px;display:flex;position:relative;overflow:hidden}.game-card-thumb:after{content:"";background:radial-gradient(circle at 50% 38%, color-mix(in srgb, var(--accent) 22%, transparent), transparent 70%);position:absolute;inset:0}.game-card-emoji{filter:drop-shadow(0 4px 12px #0006);z-index:1;font-size:3.1rem;line-height:1;transition:transform .2s}.game-card:hover .game-card-emoji{transform:scale(1.12)rotate(-4deg)}.game-card-players{letter-spacing:.03em;color:#e8ecff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1;background:#00000073;border-radius:20px;padding:3px 8px;font-size:.65rem;font-weight:700;position:absolute;top:9px;left:9px}.game-card-custom{letter-spacing:.06em;background:var(--accent);color:#fff;z-index:1;border-radius:6px;padding:3px 7px;font-size:.58rem;font-weight:700;position:absolute;top:9px;right:9px}.game-card-delete{color:#ffffff8c;z-index:2;font-size:.8rem;position:absolute;bottom:8px;right:9px}.game-card-delete:hover{color:var(--danger)}.game-card-play{color:#fff;background:color-mix(in srgb, var(--accent) 55%, #00000080);opacity:0;z-index:1;justify-content:center;align-items:center;font-size:.9rem;font-weight:700;transition:opacity .18s;display:flex;position:absolute;inset:0}.game-card:hover .game-card-play{opacity:1}.game-card-body{padding:13px 15px 16px}.game-card-name{letter-spacing:-.01em;margin-bottom:6px;font-size:.98rem;font-weight:700}.game-card-cat{text-transform:uppercase;letter-spacing:.06em;color:var(--accent);background:color-mix(in srgb, var(--accent) 14%, transparent);border-radius:6px;margin-bottom:9px;padding:2px 8px;font-size:.62rem;font-weight:700;display:inline-block}.game-card-desc{color:var(--muted);font-size:.8rem;line-height:1.45}.library-empty{text-align:center;color:var(--muted);flex-direction:column;align-items:center;gap:12px;padding:60px 20px;display:flex}.library-empty-emoji{opacity:.7;font-size:2.4rem}.canvas-wrap{background:#000;border-radius:12px;width:100%;line-height:0;position:relative;overflow:hidden}.game-canvas{width:100%;height:auto;display:block}.canvas-overlay{pointer-events:none;position:absolute;inset:0}.canvas-overlay>*{pointer-events:auto}.rogue-hud{background:#0b0e18;border:1px solid #1e2840;border-top:none;border-radius:0 0 12px 12px;flex-wrap:wrap;align-items:center;gap:16px;padding:10px 14px;display:flex}.rogue-dpad{grid-template-areas:".u.""l d r";gap:4px;display:grid}.rogue-actions{flex-wrap:wrap;gap:6px;display:flex}.rogue-btn{color:#bec8d8;cursor:pointer;text-align:center;background:#1a2030;border:1px solid #2a3850;border-radius:6px;min-width:40px;padding:8px 10px;font-size:.82rem;line-height:1;transition:background 80ms}.rogue-btn:hover{background:#243040;border-color:#4a6890}.rogue-btn:active{background:#1a3050}.rogue-action{padding:8px 13px}.rogue-stair{color:gold}.stage{max-width:980px;margin:0 auto;padding:20px 16px 60px}.stage-head{border-bottom:1px solid var(--line);flex-wrap:wrap;align-items:center;gap:16px;margin-bottom:20px;padding-bottom:16px;display:flex}.stage-title{letter-spacing:-.01em;font-size:1.15rem;font-weight:700}.stage-title .emoji{margin-right:6px}.stage-seats{color:var(--muted);flex-wrap:wrap;flex:1;gap:12px;font-size:.88rem;display:flex}.seat.me{color:var(--accent-2);font-weight:600}.seat.empty{font-style:italic}.connecting{text-align:center;color:var(--muted);padding:80px 20px}.chess-view{flex-wrap:wrap;justify-content:center;align-items:flex-start;gap:22px;display:flex}.board{width:min(70vh,540px);max-width:100%}.chess-side{flex-direction:column;gap:12px;width:280px;display:flex}.checks{color:var(--muted);justify-content:space-between;font-size:.85rem;display:flex}.moves{font-variant-numeric:tabular-nums;max-height:300px;margin:0;padding:0;list-style:none;overflow-y:auto}.moves li{border-radius:5px;grid-template-columns:34px 1fr 1fr;gap:6px;padding:3px 4px;display:grid}.moves li:nth-child(odd){background:#ffffff08}.moves .num{color:var(--muted)}.moves .empty{color:var(--muted);font-style:italic;display:block}.c4-view{flex-direction:column;align-items:center;gap:16px;display:flex}.c4-board{background:#1e3a8a;border-radius:12px;grid-template-columns:repeat(7,1fr);gap:6px;width:min(92vw,460px);padding:10px;display:grid;box-shadow:0 6px 24px #0006}.c4-col{cursor:pointer;background:0 0;border:none;flex-direction:column;gap:6px;padding:0;display:flex}.c4-col:disabled{cursor:default}.c4-col:not(:disabled):hover{background:#ffffff14;border-radius:8px}.c4-cell{aspect-ratio:1;background:#0f1e42;border-radius:50%}.c4-cell.disc-r{background:radial-gradient(circle at 35% 30%,#ff7a7a,#d83434)}.c4-cell.disc-y{background:radial-gradient(circle at 35% 30%,#ffe27a,#e6b800)}.ttt-view{flex-direction:column;align-items:center;gap:16px;display:flex}.ttt-board{grid-template-rows:repeat(3,96px);grid-template-columns:repeat(3,96px);gap:8px;display:grid}.ttt-cell{background:var(--panel-2);border:1px solid var(--line);color:var(--text);cursor:pointer;border-radius:10px;font-size:2.6rem;transition:border-color .15s,box-shadow .15s}.ttt-cell:not(:disabled):hover{border-color:var(--accent);box-shadow:0 0 0 3px #6366f126}.ttt-cell:disabled{cursor:default}.custom-badge{text-transform:uppercase;letter-spacing:.06em;background:var(--accent);color:#fff;border-radius:6px;padding:2px 7px;font-size:.58rem;font-weight:700;position:absolute;top:8px;right:8px}.card-delete{color:var(--muted);cursor:pointer;background:0 0;border:none;padding:0;font-size:.85rem;position:absolute;bottom:8px;right:10px}.card-delete:hover{color:var(--danger)}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:50;background:#000000b8;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:var(--panel);border:1px solid var(--line);border-radius:16px;width:min(720px,100%);max-height:90vh;padding:24px;overflow-y:auto;box-shadow:0 24px 80px #0009}.modal-head{justify-content:space-between;align-items:center;display:flex}.modal-head h2{letter-spacing:-.01em;margin:0}.code-area{width:100%;height:320px;color:var(--text);border:1px solid var(--line);resize:vertical;background:#00000059;border-radius:10px;outline:none;margin-top:12px;padding:12px;font-family:ui-monospace,Cascadia Code,Consolas,monospace;font-size:.82rem;line-height:1.5}.code-area:focus{border-color:var(--accent);box-shadow:0 0 0 3px #6366f11f}.modal-actions{justify-content:flex-end;gap:10px;margin-top:14px;display:flex}.file-btn{cursor:pointer}.format-help{margin-top:16px;font-size:.85rem}.format-help summary{cursor:pointer;color:var(--accent-2)}.game-error{flex-direction:column;align-items:flex-start;gap:10px;max-width:420px;margin:40px auto;display:flex}
