.reconnect-overlay{position:fixed;inset:0;z-index:9998;display:flex;align-items:center;justify-content:center;background:#0a0a1aeb;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:reconnect-fade-in .3s ease-out}@keyframes reconnect-fade-in{0%{opacity:0}to{opacity:1}}.reconnect-overlay.dismissing{animation:reconnect-fade-out .4s ease-in forwards}@keyframes reconnect-fade-out{0%{opacity:1}to{opacity:0}}.reconnect-card{text-align:center;padding:2.5rem 2rem;max-width:380px;width:90%;border-radius:1.25rem;background:linear-gradient(145deg,#1e1e3cf2,#14142df2);border:1px solid rgba(0,217,255,.2);box-shadow:0 0 40px #00d9ff14,0 8px 32px #0006}.reconnect-icon{font-size:3rem;margin-bottom:1rem;animation:reconnect-pulse 2s ease-in-out infinite}@keyframes reconnect-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.reconnect-title{font-size:1.5rem;font-weight:700;color:#fff;margin-bottom:.5rem;font-family:var(--font-title, "Orbitron", sans-serif)}.reconnect-phase{font-size:.875rem;color:#ffffff80;margin-bottom:1.5rem;text-transform:capitalize}.reconnect-players{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-bottom:1.5rem;padding:.75rem 1rem;border-radius:.75rem;background:#00d9ff14;border:1px solid rgba(0,217,255,.15)}.reconnect-player-dots{display:flex;gap:.35rem}.reconnect-dot{width:10px;height:10px;border-radius:50%;background:#ffffff26;transition:background .3s ease,box-shadow .3s ease}.reconnect-dot.connected{background:#00d9ff;box-shadow:0 0 6px #00d9ff80}.reconnect-count{font-size:.9rem;color:#ffffffb3;font-variant-numeric:tabular-nums}.reconnect-action{margin-top:.5rem}.reconnect-resume-btn{padding:.75rem 2rem;border:none;border-radius:.75rem;font-size:1rem;font-weight:600;cursor:pointer;color:#fff;background:linear-gradient(135deg,#00d9ff,#0084ff);box-shadow:0 0 20px #00d9ff4d;transition:transform .15s ease,box-shadow .15s ease;font-family:var(--font-title, "Orbitron", sans-serif)}.reconnect-resume-btn:hover{transform:translateY(-1px);box-shadow:0 0 30px #00d9ff80}.reconnect-resume-btn:active{transform:translateY(0)}.reconnect-waiting{font-size:.9rem;color:#ffffff80;display:flex;align-items:center;justify-content:center;gap:.5rem}.reconnect-waiting-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.2);border-top-color:#00d9ff;border-radius:50%;animation:reconnect-spin .8s linear infinite}@keyframes reconnect-spin{to{transform:rotate(360deg)}}@media(prefers-reduced-motion:reduce){.reconnect-icon,.reconnect-waiting-spinner,.reconnect-overlay,.reconnect-overlay.dismissing{animation:none}}.wheel-container{position:relative;width:100%;max-width:320px;aspect-ratio:1;margin:0 auto}.wheel-pointer{position:absolute;top:-10px;left:50%;transform:translate(-50%);z-index:10;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.pointer-svg{width:40px;height:30px}.wheel-svg{width:100%;height:100%;filter:drop-shadow(0 4px 12px rgba(26,75,140,.3))}.wheel-container text{-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:none}@media(min-width:480px){.wheel-container{max-width:380px}}@media(min-width:768px){.wheel-container{max-width:420px}}.wheel-center-text{fill:var(--ink-blue);font-size:12px;font-weight:600;font-family:var(--font-hand)}.stop-overlay{position:fixed;inset:0;background:#fefcf3f2;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:100}.stop-overlay.stop-overlay-contained{position:absolute;inset:0}.stop-overlay.stop-overlay-contained .stop-text{font-size:clamp(3.25rem,10vw,7rem)}.stop-overlay.stop-overlay-contained .stopped-by{font-size:1.1rem}.stop-overlay.stop-overlay-contained .grace-countdown{font-size:1.3rem}.stop-text{font-size:clamp(4rem,20vw,10rem);font-weight:900;font-family:var(--font-title);color:var(--ink-red);text-shadow:3px 3px 0 rgba(0,0,0,.15);letter-spacing:.1em;animation:stopTextPulse .5s ease-in-out infinite alternate}.stopped-by{margin-top:1rem;font-size:1.25rem;font-family:var(--font-hand);color:var(--ink-blue)}.grace-countdown{margin-top:1.5rem;font-size:1.5rem;font-weight:600;font-family:var(--font-hand);color:var(--ink-red);animation:graceCountdownPulse 1s ease-in-out infinite}@keyframes stopTextPulse{0%{transform:scale(1)}to{transform:scale(1.05)}}@keyframes graceCountdownPulse{0%,to{opacity:1}50%{opacity:.7}}.streamer-broadcast-root{display:flex;height:100vh;width:100vw;overflow:hidden;background:#06080f;color:#e8ecf4;font-family:Segoe UI,system-ui,-apple-system,sans-serif}.streamer-broadcast-root.setup-mode{flex-direction:row}.streamer-broadcast-root.stream-mode{flex-direction:row;position:relative}.streamer-broadcast-preview{flex:1;display:flex;flex-direction:column;position:relative;border:1px solid rgba(0,229,255,.12);margin:6px;border-radius:6px;overflow:hidden;background:#080b14;box-shadow:inset 0 0 40px #00e5ff08,0 0 1px #00e5ff33}.streamer-preview-label{position:absolute;top:6px;left:50%;transform:translate(-50%);background:#00e5ff1a;color:#00e5ff;font-size:9px;font-weight:700;letter-spacing:.15em;padding:2px 12px;border-radius:3px;border:1px solid rgba(0,229,255,.15);z-index:10;pointer-events:none;text-transform:uppercase}.streamer-settings-panel-container{flex-shrink:0;display:flex;flex-direction:column;overflow:hidden;min-height:0}.streamer-settings-panel{width:100%;flex:1;min-height:0;background:#0a0d16;border-left:1px solid rgba(0,229,255,.08);display:flex;flex-direction:column;padding:14px 12px;gap:16px;overflow-y:auto;background-image:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,229,255,.008) 2px,rgba(0,229,255,.008) 4px)}.streamer-settings-panel::-webkit-scrollbar{width:4px}.streamer-settings-panel::-webkit-scrollbar-track{background:transparent}.streamer-settings-panel::-webkit-scrollbar-thumb{background:#00e5ff26;border-radius:2px}.streamer-settings-header{padding-bottom:10px;border-bottom:1px solid rgba(0,229,255,.08)}.streamer-settings-title{font-size:11px;font-weight:700;letter-spacing:.12em;color:#00e5ff;text-transform:uppercase}.streamer-settings-section{display:flex;flex-direction:column;gap:8px}.streamer-settings-section-title{font-size:10px;font-weight:600;letter-spacing:.08em;color:#00e5ff73;text-transform:uppercase}.streamer-layout-cards{display:flex;gap:5px}.streamer-layout-card{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 4px;background:#ffffff05;border:1px solid rgba(255,255,255,.06);border-radius:5px;cursor:pointer;transition:all .15s ease;color:#e8ecf480}.streamer-layout-card:hover{background:#00e5ff0f;border-color:#00e5ff40;color:#00e5ff}.streamer-layout-card.active{background:#00e5ff1a;border-color:#00e5ff;color:#00e5ff;box-shadow:0 0 8px #00e5ff26}.streamer-layout-card-icon{font-size:18px;line-height:1}.streamer-layout-card-label{font-size:10px;font-weight:600;letter-spacing:.04em}.streamer-overlay-toggles{display:flex;flex-direction:column;gap:5px}.streamer-overlay-toggle{display:flex;align-items:center;gap:8px;cursor:pointer;padding:2px 0}.streamer-overlay-toggle input[type=checkbox]{display:none}.streamer-toggle-track{width:30px;height:16px;border-radius:8px;background:#ffffff14;flex-shrink:0;position:relative;transition:background .2s;border:1px solid rgba(255,255,255,.06)}.streamer-toggle-track:after{content:"";position:absolute;top:2px;left:2px;width:10px;height:10px;border-radius:50%;background:#ffffff4d;transition:transform .2s ease,background .2s}.streamer-overlay-toggle input:checked+.streamer-toggle-track{background:#00e5ff40;border-color:#00e5ff4d}.streamer-overlay-toggle input:checked+.streamer-toggle-track:after{transform:translate(14px);background:#00e5ff;box-shadow:0 0 6px #00e5ff66}.streamer-overlay-label{font-size:11px;color:#e8ecf4b3}.streamer-settings-controls{margin-top:auto;gap:6px}.streamer-lock-btn{width:100%;padding:8px 12px;background:#00e5ff14;border:1px solid rgba(0,229,255,.25);border-radius:5px;color:#00e5ff;font-size:11px;font-weight:600;cursor:pointer;transition:all .15s;text-align:center;letter-spacing:.03em}.streamer-lock-btn:hover{background:#00e5ff26;box-shadow:0 0 12px #00e5ff26}.streamer-close-btn{width:100%;padding:6px 12px;background:transparent;border:1px solid rgba(255,255,255,.08);border-radius:5px;color:#e8ecf466;font-size:10px;cursor:pointer;transition:all .15s;text-align:center}.streamer-close-btn:hover{border-color:#ff3c5066;color:#ff3c50}.streamer-settings-hint{font-size:9px;color:#e8ecf433;line-height:1.4;text-align:center}.streamer-broadcast-main{flex:1;display:flex;flex-direction:column;overflow:hidden}.streamer-gear-strip{width:28px;flex-shrink:0;background:#0009;display:flex;align-items:flex-start;justify-content:center;padding-top:8px;cursor:pointer;position:relative;border-left:1px solid rgba(255,255,255,.04)}.streamer-gear-icon{font-size:14px;color:#fff3;line-height:1;transition:color .15s}.streamer-gear-strip:hover .streamer-gear-icon{color:#00e5ff80}.streamer-gear-menu{position:absolute;right:28px;top:6px;background:#0c0f1a;border:1px solid rgba(0,229,255,.2);border-radius:5px;padding:4px;display:flex;flex-direction:column;gap:2px;z-index:100;white-space:nowrap;box-shadow:0 4px 20px #0009}.streamer-gear-menu-btn{padding:6px 10px;background:transparent;border:none;color:#e8ecf4b3;font-size:11px;cursor:pointer;border-radius:3px;text-align:left;transition:all .1s}.streamer-gear-menu-btn:hover{background:#00e5ff14;color:#00e5ff}.streamer-broadcast-area{flex:1;display:flex;flex-direction:column;overflow:hidden;height:100%;background:#080b14}.streamer-layout-grid-mode,.streamer-layout-spotlight-mode,.streamer-layout-stage-mode{flex-direction:column}.streamer-webcam-strip{display:flex;flex-direction:row;height:90px;flex-shrink:0;background:#0006;border-bottom:1px solid rgba(0,229,255,.06);overflow-x:auto;overflow-y:hidden;gap:2px;padding:2px}.sb-strip-tile{flex-shrink:0;height:calc(100% - 4px);position:relative;border-radius:4px;overflow:hidden;background:#0c0f1a;border:1px solid rgba(255,255,255,.04)}.sb-strip-tile video{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.sb-strip-name{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#000c);padding:12px 6px 3px;font-size:10px;color:#e8ecf4d9;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-shadow:0 1px 3px rgba(0,0,0,.8)}.streamer-webcam-grid{display:grid;gap:2px;padding:2px;background:#080b14}.streamer-webcam-grid.strip-mode{height:90px;grid-template-columns:repeat(auto-fill,120px);grid-template-rows:1fr}.streamer-webcam-grid.sb-grid-1{grid-template-columns:1fr;grid-template-rows:1fr}.streamer-webcam-grid.sb-grid-2{grid-template-columns:1fr 1fr;grid-template-rows:1fr}.streamer-webcam-grid.sb-grid-4{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}.streamer-webcam-grid.sb-grid-6{grid-template-columns:1fr 1fr 1fr;grid-template-rows:1fr 1fr}.streamer-webcam-grid.sb-grid-9{grid-template-columns:1fr 1fr 1fr;grid-template-rows:1fr 1fr 1fr}.sb-webcam-tile{position:relative;overflow:hidden;border-radius:4px;background:#0c0f1a;border:1px solid rgba(255,255,255,.04);transition:border-color .3s ease}.sb-webcam-tile video{width:100%;height:100%;-o-object-fit:contain;object-fit:contain;background:#0c0f1a}.sb-webcam-tile video.mirrored{transform:scaleX(-1)}.sb-webcam-name{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#000c);padding:14px 8px 5px;font-size:11px;font-weight:500;color:#e8ecf4e6;text-align:center;text-shadow:0 1px 3px rgba(0,0,0,.8)}.sb-you-tag{opacity:.5;font-size:9px}.sb-tile-inner{position:relative;width:100%;height:100%}.sb-no-video-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0c0f1a,#101425);pointer-events:none}.sb-no-video-overlay span{font-size:2em;font-weight:700;color:#00e5ff26;text-shadow:0 0 20px rgba(0,229,255,.08)}.streamer-spotlight-layout{display:flex;flex-direction:row;flex:1;overflow:hidden}.streamer-spotlight-main{flex:1;position:relative;overflow:hidden}.streamer-spotlight-sidebar{flex-shrink:0;display:flex;flex-direction:column;gap:2px;padding:2px;background:#0000004d;overflow-y:auto}.sb-spotlight-tile{position:relative;overflow:hidden;border-radius:4px;cursor:pointer;background:#0c0f1a;border:1px solid rgba(255,255,255,.04);transition:border-color .2s}.sb-spotlight-tile:hover{border-color:#00e5ff33}.sb-spotlight-tile.large{width:100%;height:100%;border-radius:0;border:none}.sb-spotlight-tile.small{flex-shrink:0}.sb-spotlight-tile video{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.sb-spotlight-tile video.mirrored{transform:scaleX(-1)}.sb-spotlight-empty{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#e8ecf433;font-size:14px}.sb-spotlight-name{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#000c);padding:14px 8px 5px;font-size:11px;color:#e8ecf4e6;text-align:center;text-shadow:0 1px 3px rgba(0,0,0,.8)}.sb-spotlight-tile.recording{border:2px solid #ff3c50;box-shadow:0 0 16px #ff3c504d}.sb-rec-overlay{position:absolute;top:8px;left:8px;background:#ff3c50;color:#fff;font-size:10px;font-weight:700;padding:2px 8px;border-radius:3px;letter-spacing:.06em;animation:rec-blink 1s ease-in-out infinite}@keyframes rec-blink{0%,to{opacity:1}50%{opacity:.4}}.sb-inter-tile-handle-v{width:6px;min-width:6px;flex-shrink:0;align-self:stretch;position:relative;cursor:col-resize;z-index:10;-moz-user-select:none;user-select:none;-webkit-user-select:none}.sb-inter-tile-handle-h{height:6px;min-height:6px;flex-shrink:0;position:relative;cursor:row-resize;z-index:10;-moz-user-select:none;user-select:none;-webkit-user-select:none}.sb-inter-tile-handle-v:before,.sb-inter-tile-handle-h:before{content:"";position:absolute;border-radius:1px;background:#ffffff0f;transition:background .15s,box-shadow .15s}.sb-inter-tile-handle-v:before{top:0;bottom:0;left:50%;width:2px;transform:translate(-50%)}.sb-inter-tile-handle-h:before{left:0;right:0;top:50%;height:2px;transform:translateY(-50%)}.sb-inter-tile-handle-v:hover:before,.sb-inter-tile-handle-v.dragging:before,.sb-inter-tile-handle-h:hover:before,.sb-inter-tile-handle-h.dragging:before{background:#00e5ff80;box-shadow:0 0 6px #00e5ff40}.streamer-resize-handle-v,.streamer-resize-handle-h{position:relative;flex-shrink:0;z-index:20;-moz-user-select:none;user-select:none;-webkit-user-select:none}.streamer-resize-handle-v{width:8px;cursor:col-resize}.streamer-resize-handle-h{height:8px;cursor:row-resize}.streamer-resize-handle-v:before,.streamer-resize-handle-h:before{content:"";position:absolute;border-radius:1px;background:#ffffff14;transition:background .15s,box-shadow .15s}.streamer-resize-handle-v:before{top:0;bottom:0;left:50%;width:2px;transform:translate(-50%)}.streamer-resize-handle-h:before{left:0;right:0;top:50%;height:2px;transform:translateY(-50%)}.streamer-resize-handle-v:after,.streamer-resize-handle-h:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:2px;background:#ffffff1f;transition:background .15s,box-shadow .15s}.streamer-resize-handle-v:after{width:3px;height:18px}.streamer-resize-handle-h:after{width:18px;height:3px}.streamer-resize-handle-v:hover:before,.streamer-resize-handle-h:hover:before{background:#00e5ff66;box-shadow:0 0 6px #00e5ff33}.streamer-resize-handle-v:hover:after,.streamer-resize-handle-h:hover:after{background:#00e5ff99;box-shadow:0 0 8px #00e5ff4d}.streamer-resize-handle-v.dragging:before,.streamer-resize-handle-h.dragging:before{background:#00e5ff;box-shadow:0 0 12px #00e5ff80}.streamer-resize-handle-v.dragging:after,.streamer-resize-handle-h.dragging:after{background:#00e5ff;box-shadow:0 0 10px #00e5ff66}.streamer-game-stage{flex:1;display:flex;flex-direction:column;background:linear-gradient(180deg,#080b14,#0a0e19,#080b14);overflow:hidden;position:relative}.streamer-game-stage:before{content:"";position:absolute;inset:0;pointer-events:none;background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(0,229,255,.008) 3px,rgba(0,229,255,.008) 4px);z-index:1}.streamer-stage-header{display:flex;align-items:center;justify-content:space-between;padding:8px 14px;background:#0006;border-bottom:1px solid rgba(0,229,255,.06);flex-shrink:0;position:relative;z-index:2}.streamer-stage-header-left,.streamer-stage-header-right{display:flex;align-items:center;gap:10px}.streamer-game-title{font-size:14px;font-weight:700;color:#00e5ff;letter-spacing:.06em;text-shadow:0 0 12px rgba(0,229,255,.3)}.streamer-room-code{font-size:11px;color:#00e5ff66;font-weight:600;letter-spacing:.05em}.gb-phase-badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:3px;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase}.gb-phase-badge.phase-WAITING,.gb-phase-badge.phase-lobby{background:#ffffff0f;color:#e8ecf480}.gb-phase-badge.phase-PLAYING,.gb-phase-badge.phase-playing{background:#00e5ff1f;color:#00e5ff}.gb-phase-badge.phase-VOTING,.gb-phase-badge.phase-voting{background:#ff408126;color:#ff4081}.gb-phase-badge.phase-FINALE,.gb-phase-badge.phase-finale{background:#ffd70026;color:gold}.gb-phase-badge.phase-FINISHED,.gb-phase-badge.phase-finished{background:#4cff961f;color:#4cff96}.streamer-stage-content{flex:1;overflow:hidden;display:flex;flex-direction:column;position:relative;z-index:2}.streamer-stage-inner{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:20px;text-align:center}.streamer-stage-inner.stage-waiting{opacity:.7}.streamer-stage-title{font-size:24px;font-weight:700;color:#e8ecf4;line-height:1.2}.streamer-stage-subtitle{font-size:14px;color:#e8ecf480}.streamer-broadcast-area.streamer-layout-grid-only{background:#080b14}.streamer-broadcast-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;background:#00000059;border-bottom:1px solid rgba(0,229,255,.06);flex-shrink:0}.streamer-broadcast-header-group{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.streamer-grid-status{font-size:11px;color:#e8ecf4ad;letter-spacing:.04em;text-transform:uppercase}.streamer-grid-stage{flex:1;min-height:0;display:flex;position:relative}.streamer-grid-stage>div{flex:1;min-height:0}.streamer-settings-subcopy{margin:6px 0 0;font-size:11px;line-height:1.5;color:#e8ecf485}.streamer-settings-summary-list{display:flex;flex-direction:column;gap:6px}.streamer-settings-summary-row{display:flex;align-items:center;justify-content:space-between;gap:10px;font-size:11px;color:#e8ecf4a3}.streamer-settings-summary-row strong{color:#e8ecf4e6;font-weight:600}.streamer-overlay-toggles.simplified{gap:8px}.streamer-overlay-toggles.simplified .streamer-overlay-toggle{justify-content:space-between;gap:10px}.streamer-lock-btn,.streamer-close-btn,.streamer-gear-menu-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px}.streamer-gear-icon,.streamer-gear-menu-btn svg,.streamer-lock-btn svg,.streamer-close-btn svg{flex-shrink:0}.streamer-webcam-grid.responsive-grid{height:100%;min-height:0;gap:8px;padding:8px;overflow:hidden}.streamer-webcam-grid.responsive-grid.sb-grid-1{grid-template-columns:minmax(0,1fr);grid-template-rows:minmax(0,1fr)}.streamer-webcam-grid.responsive-grid.sb-grid-2{grid-template-columns:repeat(2,minmax(0,1fr));grid-template-rows:minmax(0,1fr)}.streamer-webcam-grid.responsive-grid.sb-grid-4{grid-template-columns:repeat(2,minmax(0,1fr));grid-template-rows:repeat(2,minmax(0,1fr))}.streamer-webcam-grid.responsive-grid.sb-grid-6{grid-template-columns:repeat(3,minmax(0,1fr));grid-template-rows:repeat(2,minmax(0,1fr))}.streamer-webcam-grid.responsive-grid.sb-grid-9{grid-template-columns:repeat(3,minmax(0,1fr));grid-template-rows:repeat(3,minmax(0,1fr))}.streamer-broadcast-root.setup-mode .streamer-webcam-grid.responsive-grid:not(.strip-mode){align-content:start}.streamer-broadcast-root.setup-mode .streamer-webcam-grid.responsive-grid.sb-grid-1,.streamer-broadcast-root.setup-mode .streamer-webcam-grid.responsive-grid.sb-grid-2{grid-template-rows:auto}.streamer-broadcast-root.setup-mode .streamer-webcam-grid.responsive-grid.sb-grid-4,.streamer-broadcast-root.setup-mode .streamer-webcam-grid.responsive-grid.sb-grid-6{grid-template-rows:repeat(2,auto)}.streamer-broadcast-root.setup-mode .streamer-webcam-grid.responsive-grid.sb-grid-9{grid-template-rows:repeat(3,auto)}.streamer-webcam-grid.responsive-grid .sb-webcam-tile{display:flex;flex-direction:column;min-width:0;min-height:0}.streamer-broadcast-root.setup-mode .streamer-webcam-grid.responsive-grid:not(.strip-mode) .sb-webcam-tile{align-self:start}.streamer-webcam-grid.responsive-grid .sb-webcam-media{position:relative;flex:1;min-height:0;overflow:hidden}.streamer-webcam-grid.responsive-grid .sb-tile-inner{height:100%;display:flex;align-items:center;justify-content:center}.streamer-webcam-grid.responsive-grid .sb-webcam-namebar{padding:8px 10px 9px;border-top:1px solid rgba(255,255,255,.05);background:#080b14f2;flex-shrink:0}.streamer-webcam-grid.responsive-grid .sb-webcam-name{position:static;background:none;padding:0;font-size:11px;font-weight:600;color:#e8ecf4e0;text-align:left;text-shadow:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.streamer-webcam-grid.responsive-grid .sb-you-tag{opacity:.55}.streamer-webcam-grid.responsive-grid .sb-inter-tile-handle-v{display:none}.streamer-webcam-grid.responsive-grid .sb-webcam-media video{max-width:100%;max-height:100%;-o-object-fit:contain;object-fit:contain;-o-object-position:center;object-position:center;background:#0c0f1a}.streamer-webcam-grid.responsive-grid.sidebar-stack{grid-template-columns:minmax(0,1fr)!important;grid-template-rows:none;grid-auto-rows:max-content;align-content:start;overflow-y:auto;overflow-x:hidden}.streamer-webcam-grid.responsive-grid.sidebar-stack .sb-webcam-tile{height:auto}.streamer-webcam-grid.responsive-grid.sidebar-stack .sb-webcam-media{width:100%;flex:0 0 auto;aspect-ratio:4 / 3}.streamer-webcam-grid.responsive-grid.sidebar-stack .sb-tile-inner{width:100%;height:100%}.streamer-broadcast-header.branded{padding:12px 16px}.streamer-lobby-status{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:#fff9;letter-spacing:.04em;text-transform:uppercase;padding:4px 12px;border-radius:999px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1)}.streamer-lobby-status-dot{width:6px;height:6px;border-radius:50%;background:var(--gb-cyan, #00d9ff);animation:lobby-dot-pulse 2s ease-in-out infinite}@keyframes lobby-dot-pulse{0%,to{opacity:.4}50%{opacity:1}}@media(prefers-reduced-motion:reduce){.streamer-lobby-status-dot{animation:none;opacity:.8}}.streamer-broadcast-branding{display:flex;align-items:center;gap:12px;min-width:0}.streamer-broadcast-mascot{width:40px;height:40px;-o-object-fit:contain;object-fit:contain;flex-shrink:0}.streamer-broadcast-brandcopy{display:flex;flex-direction:column;min-width:0}.streamer-broadcast-title{font-size:18px;font-weight:700;line-height:1.05;color:var(--text-primary, #e8ecf4);letter-spacing:.01em}.streamer-broadcast-title-accent{background:linear-gradient(135deg,var(--gb-pink, #e94560) 0%,var(--gb-cyan, #00d9ff) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.streamer-broadcast-subbrand{display:flex;align-items:baseline;gap:0;font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.streamer-broadcast-subbrand .brand-game{color:var(--gb-pink, #e94560)}.streamer-broadcast-subbrand .brand-buddies{color:var(--gb-cyan, #00d9ff)}.streamer-broadcast-subbrand .brand-io{color:#e8ecf480}.streamer-broadcast-hud{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 16px;background:linear-gradient(180deg,#0a0d16f0,#080b14db);border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0}.streamer-broadcast-pills{display:flex;align-items:center;flex-wrap:wrap;gap:8px}.streamer-hud-pill{display:inline-flex;align-items:center;justify-content:center;min-height:28px;padding:6px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.08);background:#ffffff0f;color:#e8ecf4;font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.streamer-hud-pill.round{background:#ffc22e1f;border-color:#ffc22e47;color:#ffd76c}.streamer-hud-pill.phase.phase-playing{background:#00e5ff1f;border-color:#00e5ff47;color:#7ef6ff}.streamer-hud-pill.phase.phase-voting,.streamer-hud-pill.phase.phase-tie-breaking{background:#ff408124;border-color:#ff40814d;color:#ff8db4}.streamer-hud-pill.phase.phase-finale{background:#ffd15429;border-color:#ffd15452;color:#ffe082}.streamer-hud-pill.phase.phase-finished{background:#39d07a29;border-color:#39d07a47;color:#8bf0b2}.streamer-hud-pill.timer.is-live{background:#2cc57f24;border-color:#2cc57f52;color:#7ff2b2}.streamer-hud-pill.timer.is-warning{background:#ffbc3826;border-color:#ffbc384d;color:#ffd36b}.streamer-hud-pill.timer.is-critical{background:#ff5b5b29;border-color:#ff5b5b57;color:#ff9b9b;box-shadow:0 0 18px #ff5b5b29}.streamer-hud-pill.timer.is-idle{background:#ffffff0d;color:#e8ecf4b8}.streamer-broadcast-status-text{color:#e8ecf4b8;font-size:12px;font-weight:600;letter-spacing:.03em;text-align:right}.streamer-countdown-overlay{position:absolute;inset:0;z-index:18;display:flex;align-items:center;justify-content:center;pointer-events:none;background:radial-gradient(circle at center,#ffffff14,#06080f0a 40%,#06080f00)}.streamer-countdown-badge{min-width:180px;padding:20px 28px;border-radius:28px;background:#080b14e0;border:1px solid rgba(255,255,255,.08);box-shadow:0 22px 60px #00000061;color:#fff;font-size:76px;font-weight:900;line-height:1;letter-spacing:.04em;text-align:center;text-transform:uppercase;animation:streamer-countdown-pop .85s ease-out}@keyframes streamer-countdown-pop{0%{opacity:0;transform:scale(.78)}35%{opacity:1;transform:scale(1.04)}to{opacity:1;transform:scale(1)}}@media(max-width:960px){.streamer-broadcast-hud{align-items:flex-start;flex-direction:column}.streamer-broadcast-status-text{text-align:left}.streamer-countdown-badge{min-width:150px;font-size:58px;padding:18px 24px}}.streamer-webcam-grid.responsive-grid .sb-webcam-tile.no-video{border-color:#ffffff14;box-shadow:inset 0 0 0 1px #ffffff05}.streamer-webcam-grid.responsive-grid .sb-webcam-media.is-placeholder{background:none}.streamer-webcam-grid.responsive-grid .sb-no-video-bg{position:absolute;inset:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover;pointer-events:none;z-index:0}.streamer-webcam-grid.responsive-grid .sb-no-video-overlay{padding:0;position:absolute;inset:0;overflow:hidden}.streamer-webcam-grid.responsive-grid .sb-no-video-overlay .sb-no-video-icon{position:absolute;bottom:8px;left:8px;width:16px;height:16px;color:#d8b4fe80;z-index:1}.streamer-webcam-grid.responsive-grid .sb-no-video-status{display:inline-flex;align-items:center;gap:8px;padding:7px 14px;border-radius:999px;background:#c084fc1f;border:1px solid rgba(192,132,252,.25);color:#d8b4fee6;font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase}.streamer-webcam-grid.responsive-grid .sb-no-video-icon{width:14px;height:14px}.streamer-hud-pill.phase.phase-second-vote{background:#885cff2e;border-color:#885cff52;color:#c9b7ff}.streamer-hud-pill.phase.phase-gm{background:#ff8d382e;border-color:#ff8d3857;color:#ffc48a}.streamer-webcam-grid.responsive-grid .sb-webcam-media video,.streamer-webcam-grid.responsive-grid .sb-webcam-tile.local .sb-webcam-media video{-o-object-fit:contain;object-fit:contain;-o-object-position:center;object-position:center;background:transparent}body.lr-broadcast-body{font-family:var(--font-body, "Patrick Hand", cursive);background:linear-gradient(#fefcf3f5,#fefcf3fa),linear-gradient(90deg,transparent 46px,rgba(233,69,96,.16) 46px,rgba(233,69,96,.16) 49px,transparent 49px),repeating-linear-gradient(180deg,transparent 0,transparent 30px,rgba(0,217,255,.12) 30px,rgba(0,217,255,.12) 32px);color:var(--ink-blue, #1a4b8c)}.lr-broadcast{color:var(--ink-blue, #1a4b8c);background:transparent;font-family:var(--font-body, "Patrick Hand", cursive)}.lr-broadcast .streamer-broadcast-preview{margin:12px;border:3px solid rgba(26,75,140,.22);border-radius:var(--border-wobbly-md, 28px);background:#fefcf3f0;box-shadow:12px 14px #1a4b8c1f,0 24px 48px #0f172a2e}.lr-broadcast .streamer-preview-label{top:14px;padding:5px 16px;border:2px solid rgba(26,75,140,.18);border-radius:var(--border-wobbly-sm, 999px);background:var(--highlighter-yellow, #fde68a);color:var(--ink-blue, #1a4b8c);font-family:var(--font-marker, "Permanent Marker", cursive);font-size:11px;letter-spacing:.12em}.lr-broadcast .streamer-broadcast-area{background:linear-gradient(180deg,#fefcf3f5,#f8fafcf0),linear-gradient(90deg,transparent 52px,rgba(233,69,96,.08) 52px,rgba(233,69,96,.08) 54px,transparent 54px),repeating-linear-gradient(180deg,transparent 0,transparent 33px,rgba(0,217,255,.08) 33px,rgba(0,217,255,.08) 35px)}.lr-broadcast .streamer-settings-panel{background:#fefcf3fa;border-left-color:#1a4b8c1f;color:var(--ink-blue, #1a4b8c)}.lr-broadcast .streamer-settings-header{border-bottom-color:#1a4b8c24}.lr-broadcast .streamer-settings-title{color:var(--ink-blue, #1a4b8c);font-family:var(--font-marker, "Permanent Marker", cursive);font-size:14px;letter-spacing:.08em}.lr-broadcast .streamer-settings-subcopy,.lr-broadcast .streamer-overlay-label,.lr-broadcast .streamer-settings-hint{color:#1a4b8cbd}.lr-broadcast .streamer-settings-section-title{color:#1a4b8c8c}.lr-broadcast .streamer-settings-summary-list{padding:12px 14px;border:2px dashed rgba(26,75,140,.16);border-radius:var(--border-wobbly-sm, 16px);background:#ffffffb8}.lr-broadcast .streamer-settings-summary-row{color:#1a4b8cbd}.lr-broadcast .streamer-settings-summary-row strong{color:var(--ink-red, #e94560)}.lr-broadcast .streamer-toggle-track{background:#1a4b8c14;border-color:#1a4b8c24}.lr-broadcast .streamer-overlay-toggle input:checked+.streamer-toggle-track{background:#00d9ff38;border-color:#00d9ff47}.lr-broadcast .streamer-overlay-toggle input:checked+.streamer-toggle-track:after{background:var(--ink-blue, #1a4b8c);box-shadow:0 0 6px #1a4b8c40}.lr-broadcast .streamer-lock-btn{background:var(--ink-blue, #1a4b8c);border-color:var(--ink-blue, #1a4b8c);color:#fefcf3}.lr-broadcast .streamer-lock-btn:hover{background:#133968;box-shadow:0 12px 24px #1a4b8c2e}.lr-broadcast .streamer-close-btn{border-color:#e9456038;color:var(--ink-red, #e94560)}.lr-broadcast .streamer-close-btn:hover{background:#e9456014;border-color:#e9456057}.lr-broadcast .streamer-broadcast-header.branded{padding:18px 18px 16px;border-bottom:2px dashed rgba(26,75,140,.16);background:#ffffff85}.lr-broadcast .streamer-broadcast-title{font-family:var(--font-title, "Gloria Hallelujah", cursive);font-size:24px;color:var(--ink-blue, #1a4b8c)}.lr-broadcast .streamer-broadcast-title-accent{background:linear-gradient(135deg,var(--ink-red, #e94560),var(--accent-color, #00d9ff));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.lr-broadcast .streamer-broadcast-subbrand{color:#1a4b8c73}.lr-broadcast .streamer-room-code,.lr-broadcast .streamer-lobby-status{background:#ffffffd1;border-color:#1a4b8c24;color:var(--ink-blue, #1a4b8c)}.lr-broadcast .streamer-lobby-status-dot{background:var(--ink-green, #15803d)}.lr-broadcast .streamer-broadcast-hud{padding:12px 18px;border-bottom:1px dashed rgba(26,75,140,.14);background:#ffffff7a}.lr-broadcast .streamer-hud-pill{font-family:var(--font-hand, "Patrick Hand", cursive)}.lr-broadcast .streamer-hud-pill.round{background:var(--highlighter-yellow, #fde68a);border-color:#1a4b8c1f;color:var(--ink-blue, #1a4b8c)}.lr-broadcast .streamer-hud-pill.phase.phase-input{background:#00d9ff24;border-color:#00d9ff3d;color:var(--ink-blue, #1a4b8c)}.lr-broadcast .streamer-hud-pill.phase.phase-review{background:var(--highlighter-pink, #f9a8d4);border-color:#e9456033;color:var(--ink-blue, #1a4b8c)}.lr-broadcast .streamer-hud-pill.phase.phase-scoring,.lr-broadcast .streamer-hud-pill.timer{background:var(--highlighter-green, #bbf7d0);border-color:#22c55e33;color:var(--ink-blue, #1a4b8c)}.lr-broadcast .streamer-broadcast-status-text{color:#1a4b8cb8}.lr-broadcast .streamer-webcam-grid.responsive-grid{gap:10px;padding:10px;background:transparent}.lr-broadcast .streamer-webcam-grid.responsive-grid .sb-webcam-tile{border:2px solid rgba(26,75,140,.14);border-radius:var(--border-wobbly-sm, 16px);background:#ffffffc2;box-shadow:0 10px 24px #1a4b8c14}.lr-broadcast .streamer-webcam-grid.responsive-grid .sb-webcam-media{background:#f1f5f9d9}.lr-broadcast .streamer-webcam-grid.responsive-grid .sb-webcam-namebar{background:#ffffffd1}.lr-broadcast .streamer-webcam-grid.responsive-grid .sb-webcam-name{color:var(--ink-blue, #1a4b8c)}.lr-broadcast .streamer-webcam-grid.responsive-grid.strip-mode .sb-webcam-media{aspect-ratio:4 / 3}.streamer-broadcast-root.setup-mode.lr-broadcast .streamer-webcam-grid.responsive-grid:not(.strip-mode) .sb-webcam-media{aspect-ratio:4 / 3}.streamer-broadcast-root.setup-mode.lr-broadcast .streamer-webcam-grid.responsive-grid:not(.strip-mode) .sb-webcam-media video{-o-object-fit:contain;object-fit:contain;background:#e6eef8e6}.lr-broadcast-stage-shell{display:flex;flex:1;min-height:0;overflow:hidden;gap:12px;padding:12px}.lr-broadcast-stage-column{flex:1;min-width:0;display:flex;flex-direction:column}.lr-broadcast-webcam-column{width:clamp(170px,24%,300px);flex-shrink:0;display:flex;flex-direction:column;min-width:0;min-height:0;overflow:hidden;padding:10px;border-left:2px dashed rgba(26,75,140,.12);background:linear-gradient(180deg,#fefcf3d1,#f8fafcc7),repeating-linear-gradient(180deg,transparent 0,transparent 31px,rgba(0,217,255,.08) 31px,rgba(0,217,255,.08) 33px)}.lr-broadcast .lr-broadcast-webcam-column .streamer-webcam-grid.responsive-grid.sidebar-stack{border:2px dashed rgba(26,75,140,.14);border-radius:var(--border-wobbly-md, 22px);background:#ffffff6b;box-shadow:inset 0 0 0 1px #ffffff57}.lr-broadcast-live-stage{display:flex;flex:1;min-height:0}.lr-broadcast-live-frame,.lr-broadcast-live-fallback{position:relative;flex:1;min-width:0;min-height:0;overflow:hidden;border:2px solid rgba(26,75,140,.16);border-radius:var(--border-wobbly-md, 24px);background:linear-gradient(180deg,#fefcf3fa,#f7f9fcf5),repeating-linear-gradient(180deg,transparent 0,transparent 31px,rgba(0,217,255,.08) 31px,rgba(0,217,255,.08) 33px);box-shadow:inset 0 0 0 1px #fff6,0 16px 36px #1a4b8c1a}.lr-broadcast-live-host{position:relative;z-index:0;display:flex;flex-direction:column;width:100%;height:100%;overflow:auto;pointer-events:none}.lr-broadcast-live-fallback{position:absolute;inset:0;z-index:1}.lr-broadcast-live-host>*{flex:1 0 auto;min-height:0}.lr-broadcast-live-host .main-scroll-area{display:flex;flex-direction:column;flex:1;min-height:100%;padding:0!important;overflow:auto}.lr-broadcast-live-host .main-scroll-area>*{flex:1 0 auto;min-height:100%}.lr-broadcast-live-host .input-phase{max-width:none;margin:0}.lr-broadcast-live-host .stop-button{pointer-events:none}.lr-broadcast-live-fallback>.streamer-game-stage{height:100%}.lr-broadcast .streamer-game-stage{background:linear-gradient(180deg,#fefcf3fa,#f7f9fcf5),linear-gradient(90deg,transparent 44px,rgba(233,69,96,.08) 44px,rgba(233,69,96,.08) 47px,transparent 47px),repeating-linear-gradient(180deg,transparent 0,transparent 31px,rgba(0,217,255,.08) 31px,rgba(0,217,255,.08) 33px);color:var(--ink-blue, #1a4b8c)}.lr-broadcast .streamer-game-stage:before{background:none}.lr-broadcast .streamer-stage-header{background:#ffffff85;border-bottom:2px dashed rgba(26,75,140,.14)}.lr-broadcast .streamer-game-title,.lr-broadcast .streamer-stage-title,.lr-broadcast .streamer-stage-subtitle,.lr-broadcast .streamer-room-code{color:var(--ink-blue, #1a4b8c)}.lr-broadcast .streamer-stage-subtitle,.lr-broadcast .streamer-room-code{opacity:.72}.lr-broadcast .gb-phase-badge.phase-playing,.lr-broadcast .gb-phase-badge.phase-voting,.lr-broadcast .gb-phase-badge.phase-finished,.lr-broadcast .gb-phase-badge.phase-finale{border:1px solid rgba(26,75,140,.12);color:var(--ink-blue, #1a4b8c)}.lr-broadcast .gb-phase-badge.phase-playing{background:#00d9ff29}.lr-broadcast .gb-phase-badge.phase-voting{background:#f9a8d447}.lr-broadcast .gb-phase-badge.phase-finished,.lr-broadcast .gb-phase-badge.phase-finale{background:#bbf7d05c}.lr-broadcast .streamer-gear-strip{background:#f8fafce6;border-left-color:#1a4b8c1f}.lr-broadcast .streamer-gear-icon{color:#1a4b8c57}.portal-overlay{position:fixed;inset:0;z-index:10000;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden;opacity:0;pointer-events:none;transition:opacity .4s ease-out;background:linear-gradient(135deg,#1a1a2ef7,#16213ef7,#1a1a2ef7,#0f0f23f7,#1a1a2ef7);background-size:400% 400%;animation:portalGradientShift 6s ease infinite}.portal-overlay.visible{opacity:1;pointer-events:all}.portal-overlay.collapsing{animation:portalVortex .5s ease-in forwards}@keyframes portalGradientShift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}@keyframes portalVortex{0%{opacity:1}to{opacity:0}}.portal-particles{position:absolute;inset:0;overflow:hidden;pointer-events:none}.portal-particle{position:absolute;border-radius:50%;opacity:0;animation:portalParticleConverge 3s ease-in-out infinite;will-change:transform,opacity}.portal-particle:nth-child(1){width:8px;height:8px;background:#ff6b9d;left:10%;top:20%;animation-delay:0s}.portal-particle:nth-child(2){width:6px;height:6px;background:#c084fc;left:85%;top:15%;animation-delay:.3s}.portal-particle:nth-child(3){width:10px;height:10px;background:#60a5fa;left:15%;top:75%;animation-delay:.6s}.portal-particle:nth-child(4){width:7px;height:7px;background:#4ade80;left:90%;top:70%;animation-delay:.9s}.portal-particle:nth-child(5){width:9px;height:9px;background:#facc15;left:5%;top:50%;animation-delay:1.2s}.portal-particle:nth-child(6){width:5px;height:5px;background:#fb923c;left:95%;top:45%;animation-delay:1.5s}.portal-particle:nth-child(7){width:8px;height:8px;background:#f472b6;left:25%;top:10%;animation-delay:1.8s}.portal-particle:nth-child(8){width:6px;height:6px;background:#a78bfa;left:75%;top:85%;animation-delay:2.1s}@keyframes portalParticleConverge{0%{opacity:0;transform:translate(0) scale(1)}20%{opacity:.9}to{opacity:0;transform:translate(calc(50vw - 100%),calc(50vh - 100%)) scale(0)}}.portal-ring-container{position:relative;width:220px;height:220px;display:flex;align-items:center;justify-content:center}.portal-glow{position:absolute;inset:-30px;border-radius:50%;background:radial-gradient(circle,rgba(192,132,252,.4) 0%,rgba(96,165,250,.3) 30%,rgba(255,107,157,.2) 50%,transparent 70%);animation:portalGlowPulse 2s ease-in-out infinite;will-change:transform,opacity}.portal-glow:before{content:"";position:absolute;inset:10px;border-radius:50%;background:radial-gradient(circle,rgba(250,204,21,.3) 0%,rgba(74,222,128,.2) 40%,transparent 60%);animation:portalGlowPulse 2s ease-in-out infinite reverse;will-change:transform,opacity}@keyframes portalGlowPulse{0%,to{transform:scale(1);opacity:.7}50%{transform:scale(1.15);opacity:1}}.portal-outer-ring{position:absolute;border-radius:50%;border:2px solid transparent;will-change:transform}.portal-outer-ring-1{width:200px;height:200px;border-top-color:#ff6b9d;border-right-color:#c084fc;animation:portalRingRotate 4s linear infinite}.portal-outer-ring-2{width:230px;height:230px;border-bottom-color:#60a5fa;border-left-color:#4ade80;animation:portalRingRotate 5s linear infinite reverse}.portal-outer-ring-3{width:260px;height:260px;border-top-color:#facc1580;border-right-color:#fb923c80;animation:portalRingRotate 6s linear infinite}@keyframes portalRingRotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.portal-ring{position:absolute;width:180px;height:180px;transform:rotate(-90deg)}.portal-ring-bg{fill:none;stroke:#ffffff1a;stroke-width:8}.portal-ring-progress{fill:none;stroke:url(#portalGradient);stroke-width:8;stroke-linecap:round;stroke-dasharray:502.65;stroke-dashoffset:0;transition:stroke-dashoffset .1s linear}.portal-logo{position:relative;width:100px;height:100px;display:flex;align-items:center;justify-content:center;animation:portalLogoFloat 2s ease-in-out infinite;z-index:2;will-change:transform}.portal-logo img{width:80px;height:80px;-o-object-fit:contain;object-fit:contain;filter:drop-shadow(0 4px 20px rgba(192,132,252,.5))}.portal-logo-fallback{font-size:52px;filter:drop-shadow(0 4px 20px rgba(192,132,252,.5))}@keyframes portalLogoFloat{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-6px) scale(1.05)}}.portal-countdown{position:absolute;bottom:-50px;width:56px;height:56px;display:flex;align-items:center;justify-content:center;font-size:1.75rem;font-weight:800;color:#fff;background:linear-gradient(135deg,#c084fc,#60a5fa);border-radius:50%;box-shadow:0 4px 20px #c084fc66,inset 0 -2px 4px #0003,inset 0 2px 4px #fff3;animation:countdownPop 1s ease-in-out infinite}@keyframes countdownPop{0%,to{transform:scale(1)}10%{transform:scale(1.15)}20%{transform:scale(1)}}.portal-message{margin-top:48px;font-size:1.5rem;font-weight:700;text-align:center;background:linear-gradient(135deg,#ff6b9d,#c084fc,#60a5fa);background-size:200% 200%;background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;animation:portalMessageShimmer 3s ease-in-out infinite}@keyframes portalMessageShimmer{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.portal-players{display:flex;gap:0;margin-top:24px;animation:portalPlayersAppear .5s ease-out forwards}@keyframes portalPlayersAppear{0%{transform:scale(.5) translateY(20px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.portal-player-avatar{width:44px;height:44px;border-radius:50%;border:3px solid;border-color:#c084fc;background:linear-gradient(135deg,#1a1a2e,#16213e);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600;color:#fff;margin-left:-12px;box-shadow:0 4px 16px #c084fc4d;animation:playerAvatarBounce .5s ease-out backwards;transition:transform .2s ease,border-color .2s ease}.portal-player-avatar:nth-child(1){margin-left:0;border-color:#ff6b9d;animation-delay:0s}.portal-player-avatar:nth-child(2){border-color:#c084fc;animation-delay:.1s}.portal-player-avatar:nth-child(3){border-color:#60a5fa;animation-delay:.2s}.portal-player-avatar:nth-child(4){border-color:#4ade80;animation-delay:.3s}.portal-player-avatar:nth-child(5){border-color:#facc15;animation-delay:.4s}.portal-player-avatar:nth-child(6){border-color:#fb923c;animation-delay:.5s}@keyframes playerAvatarBounce{0%{transform:scale(0);opacity:0}60%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}.portal-player-avatar:hover{transform:scale(1.1) translateY(-4px);z-index:10}.portal-player-avatar img{width:100%;height:100%;border-radius:50%;-o-object-fit:cover;object-fit:cover}.portal-subtitle{margin-top:16px;font-size:.875rem;color:#fff9;animation:portalSubtitleFade 2s ease-in-out infinite}@keyframes portalSubtitleFade{0%,to{opacity:.6}50%{opacity:.9}}@media(max-width:480px){.portal-ring-container{width:180px;height:180px}.portal-outer-ring-1{width:160px;height:160px}.portal-outer-ring-2{width:190px;height:190px}.portal-outer-ring-3{width:220px;height:220px}.portal-ring{width:140px;height:140px}.portal-ring-bg,.portal-ring-progress{stroke-width:6}.portal-ring-progress{stroke-dasharray:392.7}.portal-logo{width:80px;height:80px}.portal-logo img{width:60px;height:60px}.portal-logo-fallback{font-size:40px}.portal-countdown{width:48px;height:48px;font-size:1.5rem;bottom:-44px}.portal-message{font-size:1.25rem;margin-top:40px;padding:0 16px}.portal-player-avatar{width:36px;height:36px;margin-left:-10px;font-size:14px}}@media(prefers-reduced-motion:reduce){.portal-overlay{transition:opacity .15s;animation:none;background-size:100% 100%}.portal-overlay.collapsing{animation:simpleFade .2s ease-out forwards}@keyframes simpleFade{to{opacity:0}}.portal-glow,.portal-glow:before,.portal-logo,.portal-outer-ring-1,.portal-outer-ring-2,.portal-outer-ring-3,.portal-countdown,.portal-message,.portal-subtitle,.portal-particle{animation:none}.portal-ring-progress{transition:stroke-dashoffset .05s linear}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.xp-toast-container{position:fixed;top:100px;right:20px;z-index:10001;display:flex;flex-direction:column;gap:12px;pointer-events:none;width:min(360px,calc(100vw - 40px));isolation:isolate}.xp-toast{--xp-accent: #4ade80;--xp-glow: rgba(74, 222, 128, .3);pointer-events:auto;background:linear-gradient(135deg,#151b30,#0d0f1a)!important;border-radius:16px;overflow:hidden;box-shadow:0 10px 40px #00000080,0 0 25px var(--xp-glow),inset 0 1px #ffffff14;animation:xpToastSlideIn .5s cubic-bezier(.34,1.56,.64,1);position:relative;border:2px solid var(--xp-accent);opacity:1!important;backdrop-filter:none!important;-webkit-backdrop-filter:none!important;isolation:isolate}.xp-toast.level-up{--xp-accent: #F59E0B;--xp-glow: rgba(245, 158, 11, .4);animation:xpToastSlideIn .5s cubic-bezier(.34,1.56,.64,1),xpLevelUpPulse 2s ease-in-out infinite}.xp-toast.exiting{animation:xpToastSlideOut .5s ease-in forwards}@keyframes xpToastSlideIn{0%{transform:translate(100px) scale(.9)}to{transform:translate(0) scale(1)}}@keyframes xpToastSlideOut{0%{opacity:1;transform:translate(0) scale(1)}to{opacity:0;transform:translate(100px) scale(.9)}}@keyframes xpLevelUpPulse{0%,to{box-shadow:0 10px 40px #00000080,0 0 25px #f59e0b4d,inset 0 1px #ffffff14}50%{box-shadow:0 10px 40px #00000080,0 0 45px #f59e0b80,inset 0 1px #ffffff14}}.xp-toast-header{display:flex;align-items:center;padding:10px 14px;background:linear-gradient(90deg,#1e322d,#151b30);border-bottom:1px solid rgb(40,60,55)}.xp-toast.level-up .xp-toast-header{background:linear-gradient(90deg,#322d1e,#151b30);border-bottom-color:#3c3723}.xp-toast-header-icon{font-size:18px;margin-right:8px;filter:drop-shadow(0 0 6px var(--xp-accent));animation:xpIconBounce .6s ease .3s}@keyframes xpIconBounce{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.xp-toast-header-title{flex:1;font-weight:800;font-size:12px;color:var(--xp-accent);text-transform:uppercase;letter-spacing:1.5px;text-shadow:0 0 10px var(--xp-glow)}.xp-toast-close{background:#232837;border:none;color:#a0aab4;width:28px;height:28px;min-width:44px;min-height:44px;border-radius:6px;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;margin:-6px -6px -6px 0;padding:6px}.xp-toast-close:hover{background:#323746;color:#fff}.xp-toast-body{display:flex;gap:14px;padding:14px;background:#151b30}.xp-toast-icon{width:52px;height:52px;flex-shrink:0;background:linear-gradient(135deg,#233732,#19282a);border-radius:12px;display:flex;align-items:center;justify-content:center;border:2px solid var(--xp-accent);box-shadow:0 0 15px var(--xp-glow);animation:xpIconPop .5s cubic-bezier(.34,1.56,.64,1) .2s both;font-size:26px;filter:drop-shadow(0 0 8px var(--xp-accent))}.xp-toast.level-up .xp-toast-icon{background:linear-gradient(135deg,#373223,#28261e)}@keyframes xpIconPop{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}.xp-toast-content{flex:1;min-width:0}.xp-toast-amount{font-size:28px;font-weight:800;color:#4ade80;text-shadow:0 0 15px rgba(74,222,128,.5);line-height:1.1;animation:xpAmountPop .5s ease-out .3s both}.xp-toast.level-up .xp-toast-amount{color:#f59e0b;text-shadow:0 0 15px rgba(245,158,11,.5)}@keyframes xpAmountPop{0%{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}.xp-toast-message{font-size:13px;color:#94a3b8;margin-top:4px;line-height:1.3}.xp-toast-level-message{font-size:14px;font-weight:700;color:#f59e0b;text-shadow:0 0 10px rgba(245,158,11,.4);margin-top:6px}.xp-progress-container{display:flex;align-items:center;gap:8px;margin-top:10px}.xp-progress-bar{flex:1;height:6px;background:#232837;border-radius:3px;overflow:hidden}.xp-progress-fill{height:100%;background:linear-gradient(90deg,var(--xp-accent),rgb(60,180,110));border-radius:3px;transition:width .5s ease-out;box-shadow:0 0 10px var(--xp-glow)}.xp-toast.level-up .xp-progress-fill{background:linear-gradient(90deg,#f59e0b,#c88c1e)}.xp-progress-text{font-size:11px;font-weight:600;color:#a0aab4;min-width:32px;text-align:right}.celebration-particles{position:absolute;inset:0;overflow:hidden;pointer-events:none}.particle{position:absolute;top:50%;left:50%;width:8px;height:8px;background:var(--xp-accent);border-radius:50%;box-shadow:0 0 6px var(--xp-glow)}.particle-1{animation:xpParticle1 1s ease-out forwards .1s}.particle-2{animation:xpParticle2 1s ease-out forwards .15s}.particle-3{animation:xpParticle3 1s ease-out forwards .2s}.particle-4{animation:xpParticle4 1s ease-out forwards .25s}.particle-5{animation:xpParticle5 1s ease-out forwards .3s}.particle-6{animation:xpParticle6 1s ease-out forwards .35s}.particle-7{animation:xpParticle7 1s ease-out forwards .4s}.particle-8{animation:xpParticle8 1s ease-out forwards .45s}@keyframes xpParticle1{0%{transform:scale(0);opacity:1}to{transform:translate(60px,-35px) scale(.5);opacity:0}}@keyframes xpParticle2{0%{transform:scale(0);opacity:1}to{transform:translate(45px,-50px) scale(.5);opacity:0}}@keyframes xpParticle3{0%{transform:scale(0);opacity:1}to{transform:translate(-15px,-55px) scale(.5);opacity:0}}@keyframes xpParticle4{0%{transform:scale(0);opacity:1}to{transform:translate(-55px,-30px) scale(.5);opacity:0}}@keyframes xpParticle5{0%{transform:scale(0);opacity:1}to{transform:translate(-60px,20px) scale(.5);opacity:0}}@keyframes xpParticle6{0%{transform:scale(0);opacity:1}to{transform:translate(-30px,50px) scale(.5);opacity:0}}@keyframes xpParticle7{0%{transform:scale(0);opacity:1}to{transform:translate(30px,50px) scale(.5);opacity:0}}@keyframes xpParticle8{0%{transform:scale(0);opacity:1}to{transform:translate(55px,20px) scale(.5);opacity:0}}.xp-toast:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,#151b30,#2d3746,#151b30);animation:xpToastShine 2s ease-in-out .5s;pointer-events:none}@keyframes xpToastShine{0%{left:-100%}to{left:100%}}@media(max-width:767px){.xp-toast-container{inset:auto 10px 80px;width:auto}.xp-toast{border-radius:12px}.xp-toast-header{padding:8px 12px}.xp-toast-header-title{font-size:11px}.xp-toast-body{padding:12px;gap:12px}.xp-toast-icon{width:44px;height:44px;font-size:22px}.xp-toast-amount{font-size:24px}.xp-toast-message{font-size:12px}}@media(prefers-reduced-motion:reduce){.xp-toast,.xp-toast.level-up,.xp-toast-header-icon,.xp-toast-icon,.xp-toast-amount,.xp-toast:before{animation:none}.particle{display:none}.xp-toast{opacity:1;transform:none}}.game-ad-container{display:flex;justify-content:center;align-items:center;margin:1.5rem auto;max-width:300px}.game-ad-placeholder{width:300px;height:250px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:1.5rem;box-shadow:0 4px 20px #0000004d}.game-ad-placeholder .ad-badge{background:#fff3;color:#fff;font-size:.65rem;font-weight:700;padding:.2rem .5rem;border-radius:4px;letter-spacing:.5px}.game-ad-placeholder .ad-text{display:flex;flex-direction:column;align-items:center;gap:.5rem;text-align:center}.game-ad-placeholder .ad-title{color:#fff;font-size:1.25rem;font-weight:700}.game-ad-placeholder .ad-subtitle{color:#fffc;font-size:.9rem}@media(max-width:480px){.game-ad-container{margin:1rem auto}.game-ad-placeholder{width:280px;height:230px}}.wheel-phase{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100%;padding:24px 16px;text-align:center;background:var(--paper-bg)}.wheel-phase-header{margin-bottom:32px}.wheel-phase-header h2{font-size:1.75rem;font-weight:700;font-family:var(--font-title);color:var(--ink-blue);margin:0 0 8px}.wheel-phase-subtitle{font-size:1rem;font-family:var(--font-hand);color:var(--ink-blue);opacity:.7;margin:0}.wheel-phase-content{width:100%;max-width:420px;margin-bottom:32px}.wheel-result{position:fixed;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#fefcf3f2;z-index:100;pointer-events:none}.wheel-result-letter{font-size:8rem;font-weight:900;font-family:var(--font-title);color:var(--ink-blue);line-height:1;margin-bottom:16px}.wheel-result-text{font-size:1.5rem;font-family:var(--font-hand);color:var(--ink-blue);margin:0;animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.7}50%{opacity:1}}.wheel-waiting{display:flex;flex-direction:column;align-items:center;gap:16px}.wheel-waiting-text{font-family:var(--font-hand);color:var(--ink-blue);opacity:.7;font-size:1.125rem}.wheel-spin-button{padding:16px 48px;font-size:1.25rem;font-weight:700;font-family:var(--font-hand);color:var(--paper-bg);background:var(--ink-blue);border:2px solid #0d3a6b;border-radius:var(--border-wobbly-sm);cursor:pointer;transition:transform .15s,box-shadow .15s;box-shadow:3px 3px #0003}.wheel-spin-button:hover:not(:disabled){transform:translate(-1px,-1px);box-shadow:4px 4px #0003}.wheel-spin-button:active:not(:disabled){transform:translate(1px,1px);box-shadow:2px 2px #0003}.wheel-spin-button:disabled{opacity:.5;cursor:not-allowed}@media(max-width:480px){.wheel-phase{padding:16px 12px}.wheel-phase-header h2{font-size:1.5rem}.wheel-result-letter{font-size:6rem}.wheel-result-text{font-size:1.25rem}}@media(min-width:768px){.wheel-phase-header h2{font-size:2rem}.wheel-result-letter{font-size:10rem}}.game-timer{position:relative;display:inline-flex;align-items:center;justify-content:center;width:4rem;height:4rem}.game-timer.small{width:3rem;height:3rem}.game-timer.large{width:5rem;height:5rem}.timer-progress-ring{position:absolute;inset:0}.timer-progress-ring svg{width:100%;height:100%}.progress-bg{stroke:#1a4b8c33}.progress-fill{stroke:var(--ink-blue);transition:stroke-dasharray .5s ease}.timer-content{display:flex;flex-direction:column;align-items:center;z-index:1}.timer-value{font-size:1.25rem;font-weight:700;font-family:var(--font-hand);color:var(--ink-blue);font-variant-numeric:tabular-nums}.game-timer.small .timer-value{font-size:.875rem}.game-timer.large .timer-value{font-size:1.5rem}.timer-label{font-size:.6rem;font-family:var(--font-hand);color:#1a4b8c99;text-transform:uppercase}.game-timer.urgent .progress-fill{stroke:var(--ink-red)}.game-timer.urgent .timer-value{color:var(--ink-red);animation:timerPulse .5s ease-in-out infinite}.game-timer.critical .progress-fill{stroke:var(--ink-red)}.game-timer.critical .timer-value{color:var(--ink-red);animation:timerPulse .25s ease-in-out infinite}.timer-pulse{position:absolute;inset:-4px;border-radius:50%;border:2px solid var(--ink-red);animation:timerPulseRing 1s ease-out infinite}@keyframes timerPulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes timerPulseRing{0%{transform:scale(1);opacity:.8}to{transform:scale(1.3);opacity:0}}.input-phase{display:flex;flex-direction:column;min-height:100%;padding:1rem;gap:1rem;background:var(--paper-bg)}.input-header{display:flex;align-items:center;justify-content:space-between;padding:.5rem 0}.current-letter{font-size:4rem;font-weight:700;font-family:var(--font-title);color:var(--ink-blue);line-height:1}.answer-form{display:flex;flex-direction:column;gap:1rem;flex:1;overflow-y:auto;padding-bottom:1rem}.answer-row{display:flex;flex-direction:column;gap:.25rem}.category-label{font-size:.875rem;font-weight:600;font-family:var(--font-hand);color:var(--ink-blue);text-transform:uppercase;letter-spacing:.05em}.answer-input-wrapper{display:flex;align-items:center;background:#fefcf380;border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-sm);transition:border-color .2s,box-shadow .2s}.answer-input-wrapper:focus-within{box-shadow:0 0 0 2px #1a4b8c33}.letter-prefix{padding:.75rem 0 .75rem 1rem;font-size:1.25rem;font-weight:700;font-family:var(--font-hand);color:var(--ink-blue);min-width:2rem}.answer-input{flex:1;background:transparent;border:none;outline:none;padding:.75rem 1rem .75rem 0;font-size:1.125rem;font-family:var(--font-hand);color:var(--ink-blue)}.answer-input:disabled{opacity:.5;cursor:not-allowed}.answer-input::-moz-placeholder{color:#1a4b8c80}.answer-input::placeholder{color:#1a4b8c80}.stop-button{position:sticky;bottom:env(safe-area-inset-bottom,0px);padding:1.25rem;font-size:1.5rem;font-weight:700;font-family:var(--font-hand);background:var(--ink-red);color:var(--paper-bg);border:2px solid #8b1225;border-radius:var(--border-wobbly-md);cursor:pointer;transition:transform .1s,box-shadow .1s;box-shadow:3px 3px #0003;z-index:50;margin:0 -1rem;width:calc(100% + 2rem)}.stop-button:hover:not(:disabled){transform:translate(-1px,-1px);box-shadow:4px 4px #0003}.stop-button:active:not(:disabled){transform:translate(1px,1px);box-shadow:2px 2px #0003}.stop-button:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:3px 3px #0003}@media(max-width:480px){.current-letter{font-size:3rem}.stop-button{font-size:1.25rem;padding:1rem}.answer-input,.letter-prefix{font-size:1rem}}@media(max-width:360px){.current-letter{font-size:2.5rem}}@media(min-width:768px){.input-phase{padding:2rem}.stop-button{max-width:500px;margin:0 auto;width:100%}}.answer-grid{display:grid;grid-template-columns:120px repeat(var(--player-count, 2),minmax(100px,1fr));gap:2px;background:var(--paper-bg);border-radius:var(--border-wobbly-md);overflow-x:auto;overflow-y:visible;padding:2px;margin:1rem 0;-webkit-overflow-scrolling:touch;scroll-behavior:smooth}.grid-header-cell,.corner-cell{position:sticky;left:0;z-index:3;background:var(--paper-bg);padding:.5rem}.player-header{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;padding:.5rem;background:#fefcf3cc;font-family:var(--font-hand);font-weight:600;font-size:.875rem;min-height:60px}.player-header.is-me{background:#1a4b8c1a}.player-avatar{width:32px;height:32px;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:2px solid var(--ink-blue);opacity:.6}.player-name{color:var(--ink-blue);text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:90px}.category-label{position:sticky;left:0;z-index:2;background:var(--paper-bg);padding:.75rem .5rem;font-family:var(--font-hand);font-weight:600;font-size:.875rem;color:var(--ink-blue);display:flex;align-items:center;border-right:1px solid rgba(26,75,140,.3)}.answer-cell{display:flex;flex-direction:column;align-items:stretch;justify-content:center;gap:.25rem;padding:.5rem;background:#fefcf3e6;min-height:60px;transition:background-color .2s ease}.answer-text{font-size:.9rem;font-family:var(--font-hand);color:var(--ink-blue);word-break:break-word;text-align:center}.answer-text.empty{color:var(--ink-blue);opacity:.4;font-style:italic}.answer-text.strikethrough{text-decoration:line-through;text-decoration-color:var(--ink-red);text-decoration-thickness:2px;opacity:.5}.answer-cell.is-invalid{background:#c41e3a14;border:2px solid rgba(196,30,58,.3)}.duplicate-1{background:var(--highlighter-yellow)!important}.duplicate-2{background:var(--highlighter-green)!important}.duplicate-3{background:var(--highlighter-pink)!important}.duplicate-4{background:#add8e680!important}.duplicate-5{background:#dda0dd80!important}.dispute-controls{display:flex;align-items:center;justify-content:center;gap:.25rem;margin-top:.15rem}.dispute-btn{width:24px;height:24px;padding:0;font-size:.75rem;font-weight:700;background:transparent;color:var(--ink-blue);border:1.5px solid rgba(26,75,140,.3);border-radius:4px;cursor:pointer;transition:all .15s ease;opacity:.5;line-height:1;display:flex;align-items:center;justify-content:center}.dispute-btn:hover{opacity:1;border-color:var(--ink-red);color:var(--ink-red)}.dispute-btn.voted{background:#c41e3a26;border-color:var(--ink-red);color:var(--ink-red);opacity:1}.dispute-count{font-size:.65rem;font-family:var(--font-hand);font-weight:600;color:var(--ink-red);opacity:.8}.dispute-count.majority{font-weight:800;opacity:1}.host-ruling{display:flex;align-items:center;justify-content:center;gap:.25rem;margin-top:.15rem}.host-ruling-label{font-size:.55rem;font-family:var(--font-hand);font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--ink-blue);opacity:.4}.ruling-btn{width:22px;height:22px;padding:0;font-size:.7rem;font-weight:700;background:transparent;border:1.5px solid rgba(26,75,140,.2);border-radius:4px;cursor:pointer;transition:all .15s ease;opacity:.4;line-height:1;display:flex;align-items:center;justify-content:center}.ruling-btn:hover{opacity:1}.ruling-btn.ruling-valid{color:#2a7d2a}.ruling-btn.ruling-valid:hover{border-color:#2a7d2a;background:#2a7d2a1a}.ruling-btn.ruling-valid.active{border-color:#2a7d2a;background:#2a7d2a26;opacity:1}.ruling-btn.ruling-invalid{color:var(--ink-red)}.ruling-btn.ruling-invalid:hover{border-color:var(--ink-red);background:#c41e3a1a}.ruling-btn.ruling-invalid.active{border-color:var(--ink-red);background:#c41e3a26;opacity:1}@media(max-width:600px){.answer-grid{grid-template-columns:100px repeat(var(--player-count, 2),minmax(80px,1fr));gap:1px}.category-label{font-size:.75rem;padding:.5rem .25rem}.answer-cell{padding:.375rem;min-height:50px}.answer-text{font-size:.8rem}.player-header{min-height:50px;padding:.375rem}.player-avatar{width:24px;height:24px}.player-name{font-size:.75rem;max-width:70px}.dispute-btn{width:20px;height:20px;font-size:.65rem}.ruling-btn{width:18px;height:18px;font-size:.6rem}}@media(max-width:400px){.answer-grid{grid-template-columns:80px repeat(var(--player-count, 2),minmax(60px,1fr))}.player-name{font-size:.625rem;max-width:55px}.player-avatar{width:20px;height:20px}}.review-phase{display:flex;flex-direction:column;min-height:100%;padding:1rem;gap:1rem;background:var(--paper-bg)}.review-header{display:flex;align-items:center;gap:1rem;padding:.5rem 0}.review-phase .current-letter{font-size:3.5rem;font-weight:700;font-family:var(--font-title);color:var(--ink-blue);line-height:1;flex-shrink:0}.review-title{display:flex;flex-direction:column}.review-title h2{font-size:1.25rem;font-weight:600;font-family:var(--font-title);color:var(--ink-blue);margin:0}.review-subtitle{font-size:.875rem;font-family:var(--font-hand);color:var(--ink-blue);opacity:.7;margin:0}.review-hint{font-size:.8rem;font-family:var(--font-hand);color:var(--ink-blue);opacity:.6;text-align:center;margin:0}.invalid-summary{font-size:.8rem;font-family:var(--font-hand);font-weight:600;color:var(--ink-red);text-align:center;margin:0}.review-grid-container{flex:1;min-height:0;overflow-x:auto;overflow-y:hidden;background:#fefcf380;border-radius:var(--border-wobbly-md);border:2px solid var(--ink-blue)}.advance-container{padding:.5rem 0;padding-bottom:calc(.5rem + env(safe-area-inset-bottom,0px))}.advance-button{width:100%;padding:1rem 1.5rem;font-size:1.125rem;font-weight:600;font-family:var(--font-hand);background:var(--ink-green);color:var(--paper-bg);border:2px solid #1a6b1a;border-radius:var(--border-wobbly-sm);cursor:pointer;box-shadow:3px 3px #00000026;transition:transform .1s,box-shadow .1s}.advance-button:hover:not(:disabled){transform:translate(-1px,-1px);box-shadow:4px 4px #00000026}.advance-button:active:not(:disabled){transform:translate(1px,1px);box-shadow:2px 2px #00000026}.advance-button:disabled{background:var(--ink-blue);border-color:var(--ink-blue);opacity:.5;cursor:not-allowed;transform:none;box-shadow:3px 3px #00000026}@media(max-width:480px){.review-phase{padding:.75rem;gap:.75rem}.review-phase .current-letter{font-size:2.5rem}.review-title h2{font-size:1rem}.review-subtitle{font-size:.75rem}.advance-button{font-size:1rem;padding:.875rem 1rem}}@media(min-width:768px){.review-phase{padding:1.5rem}.review-phase .current-letter{font-size:4rem}.review-title h2{font-size:1.5rem}.advance-button{max-width:500px;margin:0 auto;display:block}}.scoring-phase{display:flex;flex-direction:column;min-height:100%;padding:1rem;gap:1rem;background:var(--paper-bg)}.scoring-header{display:flex;align-items:center;gap:1rem;padding:.5rem 0}.scoring-phase .current-letter{font-size:3.5rem;font-weight:700;font-family:var(--font-title);color:var(--ink-blue);line-height:1;flex-shrink:0}.scoring-title{display:flex;flex-direction:column}.scoring-title h2{font-size:1.25rem;font-weight:600;font-family:var(--font-title);color:var(--ink-blue);margin:0}.round-counter{font-size:.875rem;font-family:var(--font-hand);color:var(--ink-blue);opacity:.7;margin:0}.score-grid-container{flex:1;min-height:0;overflow:hidden;background:#fefcf380;border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-md)}.score-grid{display:grid;grid-template-columns:120px repeat(var(--player-count, 2),minmax(100px,1fr));gap:2px;background:var(--paper-bg);border-radius:var(--border-wobbly-sm);overflow-x:auto;overflow-y:visible;padding:2px;-webkit-overflow-scrolling:touch;scroll-behavior:smooth}.score-grid .grid-header-cell,.score-grid .corner-cell{position:sticky;left:0;z-index:3;background:var(--paper-bg);padding:.5rem}.score-grid .player-header{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;padding:.5rem;background:#fefcf3e6;font-family:var(--font-hand);font-weight:600;font-size:.875rem;min-height:60px}.score-grid .player-header.is-me{background:#1a4b8c1a}.score-grid .player-avatar{width:32px;height:32px;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:2px solid var(--ink-blue);opacity:.6}.score-grid .player-name{color:var(--ink-blue);text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:90px}.score-grid .category-label{position:sticky;left:0;z-index:2;background:var(--paper-bg);padding:.75rem .5rem;font-family:var(--font-hand);font-weight:600;font-size:.875rem;color:var(--ink-blue);display:flex;align-items:center;border-right:1px solid rgba(26,75,140,.3)}.score-cell{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;padding:.5rem;min-height:60px;transition:background-color .2s ease}.score-cell .answer-text{font-size:.85rem;font-family:var(--font-hand);word-break:break-word;text-align:center;line-height:1.2}.score-cell .answer-text.empty{color:var(--ink-blue);opacity:.4;font-style:italic}.points-badge{font-size:.75rem;font-family:var(--font-hand);font-weight:700;padding:.15rem .4rem;border-radius:4px}.score-cell.unique{background:var(--highlighter-green)}.score-cell.unique .answer-text{color:var(--ink-green)}.score-cell.unique .points-badge{background:var(--ink-green);color:var(--paper-bg)}.score-cell.duplicate{background:var(--highlighter-yellow)}.score-cell.duplicate .answer-text{color:var(--ink-blue)}.score-cell.duplicate .points-badge{background:#1a4b8c4d;color:var(--ink-blue)}.score-cell.empty{background:transparent}.score-cell.empty .answer-text{color:var(--ink-blue);opacity:.4}.score-cell.empty .points-badge{background:#1a4b8c33;color:var(--ink-blue);opacity:.6}.score-cell.invalid{background:var(--highlighter-pink)}.score-cell.invalid .points-badge{background:var(--ink-red);color:var(--paper-bg)}.score-cell.invalid .answer-text{text-decoration:line-through;text-decoration-thickness:2px;color:var(--ink-red)}.total-label{position:sticky;left:0;z-index:2;background:var(--paper-bg);padding:.75rem .5rem;font-family:var(--font-hand);font-weight:700;font-size:.875rem;color:var(--ink-blue);display:flex;align-items:center;border-right:1px solid rgba(26,75,140,.3);border-top:2px solid var(--ink-blue)}.total-cell{display:flex;align-items:center;justify-content:center;padding:.75rem .5rem;background:#1a4b8c1a;border-top:2px solid var(--ink-blue)}.total-points{font-size:1.25rem;font-family:var(--font-title);font-weight:700;color:var(--ink-blue)}.score-legend{display:flex;justify-content:center;gap:1.5rem;padding:.5rem;flex-wrap:wrap;font-family:var(--font-hand)}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:var(--ink-blue)}.legend-item:before{content:"";width:12px;height:12px;border-radius:3px}.legend-item.unique:before{background:var(--ink-green)}.legend-item.duplicate:before{background:var(--highlighter-yellow);border:1px solid var(--ink-blue)}.legend-item.empty:before{background:#1a4b8c33}.scoring-actions{padding:.5rem 0;padding-bottom:calc(.5rem + env(safe-area-inset-bottom,0px))}.scoring-actions .action-button{width:100%;padding:1rem 1.5rem;font-size:1.125rem;font-family:var(--font-hand);font-weight:600;background:var(--ink-green);color:var(--paper-bg);border:2px solid #1a6b1a;border-radius:var(--border-wobbly-sm);cursor:pointer;box-shadow:3px 3px #00000026;transition:transform .1s,box-shadow .1s}.scoring-actions .action-button:hover{transform:translate(-1px,-1px);box-shadow:4px 4px #00000026}.scoring-actions .action-button:active{transform:translate(1px,1px);box-shadow:2px 2px #00000026}.waiting-text{text-align:center;font-family:var(--font-hand);color:var(--ink-blue);opacity:.7;font-size:.875rem;padding:1rem 0;padding-bottom:calc(1rem + env(safe-area-inset-bottom,0px))}@media(max-width:480px){.scoring-phase{padding:.75rem;gap:.75rem}.scoring-phase .current-letter{font-size:2.5rem}.scoring-title h2{font-size:1rem}.round-counter{font-size:.75rem}.score-grid{grid-template-columns:100px repeat(var(--player-count, 2),minmax(80px,1fr));gap:1px}.score-grid .category-label{font-size:.75rem;padding:.5rem .25rem}.score-cell{padding:.375rem;min-height:50px}.score-cell .answer-text{font-size:.75rem}.points-badge{font-size:.65rem;padding:.1rem .3rem}.score-grid .player-header{min-height:50px;padding:.375rem}.score-grid .player-avatar{width:24px;height:24px}.score-grid .player-name{font-size:.75rem;max-width:70px}.score-legend{gap:.75rem}.legend-item{font-size:.65rem}.scoring-actions .action-button{font-size:1rem;padding:.875rem 1rem}}@media(min-width:768px){.scoring-phase{padding:1.5rem}.scoring-phase .current-letter{font-size:4rem}.scoring-title h2{font-size:1.5rem}.scoring-actions .action-button{max-width:500px;margin:0 auto;display:block}}.ranking-phase{display:flex;flex-direction:column;min-height:100%;padding:1rem;gap:1rem;background:var(--paper-bg)}.ranking-header{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.5rem 0;text-align:center}.ranking-phase .current-letter{font-size:3.5rem;font-weight:700;font-family:var(--font-title);color:var(--ink-blue);line-height:1}.ranking-header h2{font-size:1.25rem;font-weight:600;font-family:var(--font-title);color:var(--ink-blue);margin:0}.ranking-instruction{font-size:.85rem;font-family:var(--font-hand);color:var(--ink-blue);opacity:.6;margin:0}.ranking-categories{display:flex;flex-direction:column;gap:1.25rem;flex:1;min-height:0;overflow-y:auto;padding-bottom:.5rem}.ranking-category{background:#fefcf3b3;border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-md, 4px 12px 4px 12px / 12px 4px 12px 4px);padding:.75rem;box-shadow:3px 3px #1a4b8c1a}.ranking-category-title{font-family:var(--font-hand);font-size:1rem;font-weight:600;color:var(--ink-blue);margin:0 0 .5rem;padding-bottom:.375rem;border-bottom:2px dashed var(--paper-lines, #c4d4e8)}.ranking-list{display:flex;flex-direction:column;gap:.375rem}.ranking-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .625rem;background:var(--paper-bg, #fefcf3);border:1.5px solid var(--paper-lines, #c4d4e8);border-radius:6px;transition:border-color .15s,box-shadow .15s,opacity .15s,transform .15s;cursor:grab;touch-action:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.ranking-item:hover{border-color:var(--ink-blue);box-shadow:2px 2px #1a4b8c14}.ranking-item:active{cursor:grabbing}.ranking-grip{display:flex;align-items:center;color:var(--paper-lines, #c4d4e8);flex-shrink:0;transition:color .15s}.ranking-item:hover .ranking-grip{color:var(--ink-blue)}.ranking-item--dragging{opacity:.4;border-style:dashed}.ranking-item--drag-over{border-color:var(--ink-green, #2d8a2d);box-shadow:0 -2px 0 0 var(--ink-green, #2d8a2d);transform:translateY(2px)}.ranking-position{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:50%;border:2px solid var(--ink-blue);font-family:var(--font-title);font-size:.85rem;font-weight:700;color:var(--ink-blue);flex-shrink:0;background:#c4d4e840}.ranking-answer-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.125rem}.ranking-player-name{font-family:var(--font-hand);font-size:.7rem;color:var(--ink-blue);opacity:.55;text-transform:lowercase}.ranking-answer-text{font-family:var(--font-hand);font-size:.95rem;color:var(--ink-blue);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ranking-controls{display:flex;flex-direction:column;gap:2px;flex-shrink:0}.ranking-btn{display:flex;align-items:center;justify-content:center;width:1.75rem;height:1.75rem;border:1.5px solid var(--ink-blue);border-radius:4px;background:var(--paper-bg, #fefcf3);color:var(--ink-blue);cursor:pointer;transition:background .1s,transform .1s;padding:0}.ranking-btn:hover:not(:disabled){background:#1a4b8c1a;transform:scale(1.05)}.ranking-btn:active:not(:disabled){transform:scale(.95)}.ranking-btn:disabled{opacity:.25;cursor:not-allowed}.ranking-submit-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:1rem 1.5rem;font-size:1.125rem;font-weight:600;font-family:var(--font-hand);background:var(--ink-green, #2d8a2d);color:var(--paper-bg, #fefcf3);border:2px solid #1a6b1a;border-radius:var(--border-wobbly-sm, 4px 8px 4px 8px / 8px 4px 8px 4px);cursor:pointer;box-shadow:3px 3px #00000026;transition:transform .1s,box-shadow .1s;margin-top:.5rem;padding-bottom:calc(1rem + env(safe-area-inset-bottom,0px))}.ranking-submit-btn:hover{transform:translate(-1px,-1px);box-shadow:4px 4px #00000026}.ranking-submit-btn:active{transform:translate(1px,1px);box-shadow:2px 2px #00000026}.ranking-phase--submitted{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100%;padding:2rem;background:var(--paper-bg);text-align:center;gap:1rem}.ranking-submitted-icon{color:var(--ink-green, #2d8a2d);animation:ranking-check-pop .4s ease}@keyframes ranking-check-pop{0%{transform:scale(.5);opacity:0}60%{transform:scale(1.15)}to{transform:scale(1);opacity:1}}.ranking-phase--submitted h2{font-family:var(--font-title);font-size:1.5rem;color:var(--ink-green, #2d8a2d);margin:0}.ranking-phase--submitted p{font-family:var(--font-hand);font-size:1rem;color:var(--ink-blue);opacity:.7;margin:0}@media(max-width:480px){.ranking-phase{padding:.75rem;gap:.75rem}.ranking-phase .current-letter{font-size:2.5rem}.ranking-header h2{font-size:1rem}.ranking-category{padding:.625rem}.ranking-item{padding:.375rem .5rem;gap:.375rem}.ranking-position{width:1.625rem;height:1.625rem;font-size:.75rem}.ranking-answer-text{font-size:.85rem}.ranking-btn{width:1.5rem;height:1.5rem}.ranking-submit-btn{font-size:1rem;padding:.875rem 1rem}}@media(min-width:768px){.ranking-phase{padding:1.5rem}.ranking-phase .current-letter{font-size:4rem}.ranking-header h2{font-size:1.5rem}.ranking-submit-btn{max-width:500px;margin:.5rem auto 0}}@media(prefers-reduced-motion:reduce){.ranking-submitted-icon{animation:none}.ranking-btn,.ranking-submit-btn,.ranking-item{transition:none}}.confetti-container{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;overflow:hidden;z-index:100}.confetti-particle{position:absolute;top:-20px;border-radius:50%;animation:confetti-fall linear forwards}@keyframes confetti-fall{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(100vh) rotate(720deg);opacity:0}}.game-over-screen{position:fixed;top:0;left:0;width:100%;height:100%;background:#fefcf3f2;display:flex;align-items:center;justify-content:center;z-index:50;padding:1rem;box-sizing:border-box}.game-over-content{background:var(--paper-bg);border:3px solid var(--ink-blue);border-radius:var(--border-wobbly-lg);padding:2rem;max-width:500px;width:100%;text-align:center;box-shadow:6px 6px #00000026}.game-over-title{font-size:2.5rem;font-family:var(--font-title);font-weight:700;color:var(--ink-blue);margin:0 0 1.5rem}.winner-announcement{display:flex;flex-direction:column;align-items:center;gap:.25rem;margin-bottom:2rem}.winner-name{font-size:1.75rem;font-family:var(--font-title);font-weight:700;color:var(--ink-blue);background:linear-gradient(104deg,#ff00 .9%,#ff06 2.4%,#ffff004d 97.6%,#ff00);border-radius:.3em .8em;padding:.1em .5em}.winner-label{font-size:1.25rem;font-family:var(--font-hand);font-weight:600;color:var(--ink-green);text-transform:uppercase;letter-spacing:.1em}.winner-score{font-size:1rem;font-family:var(--font-hand);color:var(--ink-blue);opacity:.7}.podium-container{display:flex;align-items:flex-end;justify-content:center;gap:.5rem;margin-bottom:1.5rem}.podium-place{display:flex;flex-direction:column;align-items:center;min-width:80px}.podium-players{display:flex;flex-direction:column;align-items:center;gap:.25rem;margin-bottom:.5rem}.podium-player{display:flex;flex-direction:column;align-items:center}.podium-name{font-size:.875rem;font-family:var(--font-hand);font-weight:600;color:var(--ink-blue);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:80px}.podium-score{font-size:.75rem;font-family:var(--font-hand);color:var(--ink-blue);opacity:.7}.podium-empty{font-size:.875rem;font-family:var(--font-hand);color:var(--ink-blue);opacity:.4}.podium-stand{width:100%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;color:#1e293b;border-radius:var(--border-wobbly-xs)}.podium-place.first .podium-stand{height:6rem;background:linear-gradient(135deg,#fbbf24,#eab308)}.podium-place.second .podium-stand{height:4rem;background:linear-gradient(135deg,#d1d5db,#9ca3af)}.podium-place.third .podium-stand{height:2.5rem;background:linear-gradient(135deg,#d97706,#b45309)}.other-players{margin-bottom:1.5rem}.other-players h3{font-size:.875rem;font-family:var(--font-hand);font-weight:600;color:var(--ink-blue);opacity:.6;text-transform:uppercase;letter-spacing:.05em;margin:0 0 .75rem}.other-players ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.other-players li{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-family:var(--font-hand);color:var(--ink-blue)}.other-rank{color:var(--ink-blue);opacity:.6;font-weight:600;min-width:1.5rem}.other-name{flex:1;text-align:left}.other-score{color:var(--ink-blue);opacity:.6}.game-over-actions{display:flex;justify-content:center;gap:1rem;margin-top:1rem}.action-button{padding:.75rem 2rem;border-radius:var(--border-wobbly-sm);font-size:1rem;font-family:var(--font-hand);font-weight:600;cursor:pointer;border:none;box-shadow:3px 3px #00000026;transition:transform .15s,box-shadow .15s}.action-button:hover{transform:translate(-1px,-1px);box-shadow:4px 4px #00000026}.action-button:active{transform:translate(1px,1px);box-shadow:2px 2px #00000026}.action-button.primary{background:var(--ink-blue);color:var(--paper-bg)}.action-button.primary:hover{opacity:.95}.waiting-text{font-family:var(--font-hand);color:var(--ink-blue);opacity:.6;font-size:.875rem;margin:1rem 0 0}@media(max-width:360px){.game-over-content{padding:1.5rem}.game-over-title{font-size:2rem}.winner-name{font-size:1.5rem}.podium-place{min-width:60px}.podium-name{max-width:60px;font-size:.75rem}.podium-stand{font-size:1.25rem}.podium-place.first .podium-stand{height:4.5rem}.podium-place.second .podium-stand{height:3rem}.podium-place.third .podium-stand{height:2rem}}.loading-screen{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;overflow:hidden;background:linear-gradient(135deg,#1a1a2e,#16213e,#1a1a2e,#0f0f23,#1a1a2e);background-size:400% 400%;animation:gradientShift 8s ease infinite}.loading-particles{position:absolute;top:0;left:0;width:100%;height:100%;overflow:hidden;pointer-events:none}.loading-particle{position:absolute;width:6px;height:6px;border-radius:50%;bottom:-10%;opacity:0;will-change:transform,opacity;animation:particleFloat 4s ease-in-out infinite}.loading-particle:nth-child(1){left:10%;background:#ff6b9d;animation-delay:0s}.loading-particle:nth-child(2){left:25%;background:#c084fc;animation-delay:.5s}.loading-particle:nth-child(3){left:40%;background:#60a5fa;animation-delay:1s}.loading-particle:nth-child(4){left:55%;background:#4ade80;animation-delay:1.5s}.loading-particle:nth-child(5){left:70%;background:#facc15;animation-delay:2s}.loading-particle:nth-child(6){left:85%;background:#fb923c;animation-delay:2.5s}.loading-particle:nth-child(7){left:15%;background:#f472b6;animation-delay:3s}.loading-particle:nth-child(8){left:60%;background:#a78bfa;animation-delay:3.5s}.loading-content{position:relative;text-align:center;z-index:1}.loading-mascot-wrapper{position:relative;width:140px;height:140px;margin:0 auto 32px}.loading-ring{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:50%;border:2px solid transparent;will-change:transform}.loading-ring-1{width:160px;height:160px;border-top-color:#ff6b9d;border-right-color:#c084fc;animation:ringRotate 3s linear infinite}.loading-ring-2{width:180px;height:180px;border-bottom-color:#60a5fa;border-left-color:#4ade80;animation:ringRotate 4s linear infinite reverse}.loading-ring-3{width:200px;height:200px;border-top-color:#facc1580;border-right-color:#fb923c80;animation:ringRotate 5s linear infinite}.loading-mascot{width:100%;height:100%;-o-object-fit:contain;object-fit:contain;position:relative;z-index:2;animation:mascotFloat 2s ease-in-out infinite;border-radius:20px;will-change:transform}.loading-mascot-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:4rem;position:relative;z-index:2;animation:mascotFloat 2s ease-in-out infinite}.loading-mascot-glow{position:absolute;top:50%;left:50%;width:120px;height:120px;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(139,92,246,.5) 0%,rgba(99,102,241,.3) 40%,transparent 70%);animation:glowPulse 2s ease-in-out infinite;z-index:1;will-change:transform,opacity}.loading-title{font-size:1.75rem;font-weight:800;margin-bottom:8px;background:linear-gradient(135deg,#ff6b9d,#c084fc,#60a5fa);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;animation:titleShimmer 3s ease-in-out infinite;background-size:200% 200%}.loading-status{font-size:1rem;font-weight:500;color:#fffc;margin-bottom:24px;min-height:24px}.loading-status-text{display:inline-block;animation:textFadeIn .3s ease-out}.loading-progress-container{width:240px;margin:0 auto}.loading-progress-track{height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden;position:relative}.loading-progress-fill{height:100%;width:30%;border-radius:3px;background:linear-gradient(90deg,#ff6b9d,#c084fc,#60a5fa,#4ade80,#facc15);background-size:200% 100%;animation:progressSlide 2s ease-in-out infinite,progressGradient 2s linear infinite;position:relative}.loading-progress-fill:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.4) 50%,transparent 100%);animation:shimmer 1.5s ease-in-out infinite}.loading-hint{margin-top:32px;font-size:.875rem;color:#ffffff80;animation:hintFade 4s ease-in-out infinite}.loading-screen.fade-out{animation:fadeOut .4s ease-out forwards}@keyframes gradientShift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}@keyframes particleFloat{0%{opacity:0;transform:translate(0) translateY(0) scale(.5)}10%{opacity:.8}90%{opacity:.8}to{opacity:0;transform:translate(30px) translateY(-120vh) scale(1)}}@keyframes ringRotate{0%{transform:translate(-50%,-50%) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg)}}@keyframes mascotFloat{0%,to{transform:translateY(0) rotate(-2deg)}25%{transform:translateY(-8px) rotate(0)}50%{transform:translateY(-4px) rotate(2deg)}75%{transform:translateY(-12px) rotate(0)}}@keyframes glowPulse{0%,to{opacity:.6;transform:translate(-50%,-50%) scale(1)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.2)}}@keyframes titleShimmer{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}@keyframes textFadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes progressSlide{0%{transform:translate(-100%)}50%{transform:translate(250%)}to{transform:translate(500%)}}@keyframes progressGradient{0%{background-position:0% 50%}to{background-position:200% 50%}}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(200%)}}@keyframes hintFade{0%,to{opacity:.5}50%{opacity:.8}}@keyframes fadeOut{0%{opacity:1}to{opacity:0;visibility:hidden}}@media(max-width:480px){.loading-mascot-wrapper{width:100px;height:100px;margin-bottom:24px}.loading-ring-1{width:120px;height:120px}.loading-ring-2{width:140px;height:140px}.loading-ring-3{width:160px;height:160px}.loading-mascot-glow{width:90px;height:90px}.loading-mascot-fallback{font-size:3rem}.loading-title{font-size:1.5rem}.loading-status{font-size:.875rem}.loading-progress-container{width:200px}.loading-hint{font-size:.75rem;padding:0 16px}}@media(prefers-reduced-motion:reduce){.loading-screen,.loading-particle,.loading-ring-1,.loading-ring-2,.loading-ring-3,.loading-mascot,.loading-mascot-fallback,.loading-mascot-glow,.loading-title,.loading-progress-fill,.loading-progress-fill:after,.loading-hint{animation:none}.loading-progress-fill{width:100%;transform:none}}@font-face{font-family:Gloria Hallelujah;font-style:normal;font-weight:400;font-display:swap;src:url(/letter-rush/fonts/gloria-hallelujah-400.woff2) format("woff2")}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(/letter-rush/fonts/inter-400.woff2) format("woff2")}@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(/letter-rush/fonts/inter-500.woff2) format("woff2")}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(/letter-rush/fonts/inter-600.woff2) format("woff2")}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(/letter-rush/fonts/inter-700.woff2) format("woff2")}@font-face{font-family:Patrick Hand;font-style:normal;font-weight:400;font-display:swap;src:url(/letter-rush/fonts/patrick-hand-400.woff2) format("woff2")}@font-face{font-family:Permanent Marker;font-style:normal;font-weight:400;font-display:swap;src:url(/letter-rush/fonts/permanent-marker-400.woff2) format("woff2")}:root{--paper-bg: #fefcf3;--paper-lines: #c4d4e8;--paper-margin: #e88a8a;--ink-blue: #1a4b8c;--ink-red: #c41e3a;--ink-green: #228b22;--highlighter-yellow: rgba(255, 255, 0, .4);--highlighter-pink: rgba(255, 182, 193, .5);--highlighter-green: rgba(144, 238, 144, .4);--timing-fast: .15s ease-out;--timing-normal: .3s ease-out;--timing-slow: .5s ease-out}.paper-background{background-color:var(--paper-bg);background-image:linear-gradient(90deg,transparent 47px,var(--paper-margin) 47px,var(--paper-margin) 49px,transparent 49px),repeating-linear-gradient(to bottom,transparent 0px,transparent 31px,var(--paper-lines) 31px,var(--paper-lines) 32px);position:relative}.paper-background:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 400 400' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E");opacity:.03;pointer-events:none;z-index:0}.paper-background-clean{background-color:var(--paper-bg);background-image:linear-gradient(90deg,transparent 47px,var(--paper-margin) 47px,var(--paper-margin) 49px,transparent 49px),repeating-linear-gradient(to bottom,transparent 0px,transparent 31px,var(--paper-lines) 31px,var(--paper-lines) 32px)}.wobbly-xs{border-radius:var(--border-wobbly-xs)}.wobbly-sm{border-radius:var(--border-wobbly-sm)}.wobbly-md{border-radius:var(--border-wobbly-md)}.wobbly-lg{border-radius:var(--border-wobbly-lg)}.highlight-yellow{background:linear-gradient(104deg,#ff00 .9%,#ff06 2.4%,#ffff004d 97.6%,#ff00);border-radius:.3em .8em;padding:.1em .3em}.highlight-pink{background:linear-gradient(104deg,#ffb6c100 .9%,#ffb6c180 2.4%,#ffb6c166 97.6%,#ffb6c100);border-radius:.3em .8em;padding:.1em .3em}.highlight-green{background:linear-gradient(104deg,#90ee9000 .9%,#90ee9066 2.4%,#90ee904d 97.6%,#90ee9000);border-radius:.3em .8em;padding:.1em .3em}.ink-blue{color:var(--ink-blue)}.ink-red{color:var(--ink-red)}.ink-green{color:var(--ink-green)}.ink-invalid{color:var(--ink-red);text-decoration:line-through;text-decoration-thickness:2px}.paper-button{font-family:var(--font-hand);font-size:1.25rem;padding:.75rem 1.5rem;background:var(--paper-bg);border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-sm);color:var(--ink-blue);cursor:pointer;transition:transform var(--timing-fast),box-shadow var(--timing-fast);box-shadow:2px 2px 0 var(--ink-blue);text-decoration:none;display:inline-block;text-align:center}.paper-button:hover{transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--ink-blue)}.paper-button:active{transform:translate(1px,1px);box-shadow:1px 1px 0 var(--ink-blue)}.paper-button:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:2px 2px 0 var(--ink-blue)}.paper-button-primary{font-family:var(--font-hand);font-size:1.25rem;padding:.75rem 1.5rem;background:var(--ink-blue);border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-sm);color:var(--paper-bg);cursor:pointer;transition:transform var(--timing-fast),box-shadow var(--timing-fast);box-shadow:2px 2px #0000004d;text-decoration:none;display:inline-block;text-align:center}.paper-button-primary:hover{transform:translate(-1px,-1px);box-shadow:3px 3px #0000004d}.paper-button-primary:active{transform:translate(1px,1px);box-shadow:1px 1px #0000004d}.paper-button-primary:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:2px 2px #0000004d}.paper-button-danger{font-family:var(--font-hand);font-size:1.25rem;padding:.75rem 1.5rem;background:var(--paper-bg);border:2px solid var(--ink-red);border-radius:var(--border-wobbly-sm);color:var(--ink-red);cursor:pointer;transition:transform var(--timing-fast),box-shadow var(--timing-fast);box-shadow:2px 2px 0 var(--ink-red);text-decoration:none;display:inline-block;text-align:center}.paper-button-danger:hover{transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--ink-red)}.paper-button-danger:active{transform:translate(1px,1px);box-shadow:1px 1px 0 var(--ink-red)}.paper-button-success{font-family:var(--font-hand);font-size:1.25rem;padding:.75rem 1.5rem;background:var(--paper-bg);border:2px solid var(--ink-green);border-radius:var(--border-wobbly-sm);color:var(--ink-green);cursor:pointer;transition:transform var(--timing-fast),box-shadow var(--timing-fast);box-shadow:2px 2px 0 var(--ink-green);text-decoration:none;display:inline-block;text-align:center}.paper-button-success:hover{transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--ink-green)}.paper-button-success:active{transform:translate(1px,1px);box-shadow:1px 1px 0 var(--ink-green)}.paper-card{background:var(--paper-bg);border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-md);padding:var(--padding-card);box-shadow:3px 3px #1a4b8c33}.paper-input{font-family:var(--font-hand);font-size:1.125rem;padding:.5rem .75rem;background:var(--paper-bg);border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-xs);color:var(--ink-blue);width:100%;outline:none;transition:box-shadow var(--timing-fast)}.paper-input:focus{box-shadow:0 0 0 2px #1a4b8c33}.paper-input::-moz-placeholder{color:#1a4b8c80}.paper-input::placeholder{color:#1a4b8c80}.score-unique{color:var(--ink-green);font-weight:700}.score-duplicate{color:var(--ink-blue)}.score-invalid{color:var(--ink-red);text-decoration:line-through;text-decoration-thickness:2px}.score-winner{background:linear-gradient(104deg,#ff00 .9%,#ff06 2.4%,#ffff004d 97.6%,#ff00);border-radius:.3em .8em;padding:.1em .5em}.paper-text-shadow{text-shadow:0 1px 0 rgba(255,255,255,.5)}.paper-theme{font-family:var(--font-hand);color:var(--ink-blue)}.paper-theme h1,.paper-theme h2,.paper-theme h3{font-family:var(--font-title)}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Space Grotesk,Poppins,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:JetBrains Mono,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}html{height:100%;background:var(--paper-bg);height:var(--viewport-height);min-height:100dvh;font-size:16px}body{font-family:Space Grotesk,Poppins,sans-serif;font-family:var(--font-body);background:var(--paper-bg);min-height:100dvh;overflow-x:hidden;overflow-y:auto;color:var(--ink-blue);margin:0;padding:0}body:has(.game-page){height:100dvh;overflow:hidden}#root{min-height:100vh;background:var(--paper-bg)}*{--tw-border-opacity: 1;border-color:rgb(71 85 105 / var(--tw-border-opacity, 1));box-sizing:border-box}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);color:var(--ink-blue)}p,label{color:var(--ink-blue)}a{color:var(--ink-blue);text-decoration:none}a:hover{color:var(--ink-red)}.container{width:100%}@media(min-width:640px){.container{max-width:640px}}@media(min-width:768px){.container{max-width:768px}}@media(min-width:1024px){.container{max-width:1024px}}@media(min-width:1280px){.container{max-width:1280px}}@media(min-width:1536px){.container{max-width:1536px}}.input{width:100%;padding:.75rem 1rem;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s;font-family:var(--font-hand);background:#fff;border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-sm);color:var(--ink-blue)}.input:focus{outline:none;border-color:var(--ink-blue);box-shadow:3px 3px #1a4b8c66;background:var(--highlighter-yellow)}.input::-moz-placeholder{color:var(--ink-blue);opacity:.5;font-style:italic}.input::placeholder{color:var(--ink-blue);opacity:.5;font-style:italic}.card{padding:1.5rem;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s;background:var(--bg-secondary);border:2px solid var(--panel-border);border-radius:var(--border-wobbly-sm);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.card:hover{border-color:var(--accent-glow);transform:scale(1.005) rotate(.3deg)}.panel{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:var(--radius-lg)}.\!visible{visibility:visible!important}.visible{visibility:visible}.collapse{visibility:collapse}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.grid{display:grid}.hidden{display:none}.h-3{height:.75rem}.h-3\.5{height:.875rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-8{height:2rem}.w-3{width:.75rem}.w-3\.5{width:.875rem}.w-4{width:1rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-8{width:2rem}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.resize{resize:both}.border{border-width:1px}.uppercase{text-transform:uppercase}.lowercase{text-transform:lowercase}.outline{outline-style:solid}.ring{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.blur{--tw-blur: blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}:root{--z-background: -2;--z-background-grid: -1;--z-content: 1;--z-webcam: 10;--z-game: 20;--z-filmstrip: 100;--z-theme-toggle: 995;--z-settings-fab: 996;--z-chat-drawer-backdrop: 997;--z-mobile-drawer: 998;--z-mobile-fab-cluster: 999;--z-mobile-nav: 1000;--z-mobile-menu: 9000;--z-mobile-menu-backdrop: 8999;--z-orientation-prompt: 9997;--z-settings-modal-backdrop: 9998;--z-settings-modal: 9999;--z-round-start-overlay: 10000;--z-mobile-toast: 10001;--z-skip-link: 10002;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--spacing-fluid-xs: clamp(.125rem, .5vw, .25rem);--spacing-fluid-sm: clamp(.25rem, 1vw, .5rem);--spacing-fluid-md: clamp(.5rem, 2vw, 1rem);--spacing-fluid-lg: clamp(.75rem, 3vw, 1.5rem);--spacing-fluid-xl: clamp(1rem, 4vw, 2rem);--gap-xs: clamp(.25rem, .5vw, .5rem);--gap-sm: clamp(.5rem, 1vw, .75rem);--gap-md: clamp(.75rem, 1.5vw, 1rem);--gap-lg: clamp(1rem, 2vw, 1.5rem);--gap-xl: clamp(1.5rem, 3vw, 2rem);--padding-section: clamp(1rem, 4vw, 2.5rem);--padding-card: clamp(.75rem, 2vw, 1.5rem);--radius-sm: clamp(.25rem, .5vw, .5rem);--radius-md: clamp(.5rem, 1vw, .75rem);--radius-lg: clamp(.75rem, 1.5vw, 1rem);--radius-xl: clamp(1rem, 2vw, 1.5rem);--safe-bottom: max(var(--spacing-md), env(safe-area-inset-bottom));--safe-left: max(var(--spacing-md), env(safe-area-inset-left));--safe-right: max(var(--spacing-md), env(safe-area-inset-right));--safe-top: max(var(--spacing-md), env(safe-area-inset-top));--viewport-height: 100dvh;--viewport-width: 100dvw;--primary: #e94560;--primary-light: #f06292;--primary-dark: #c73e54;--primary-rgb: 233, 69, 96;--secondary: #00d9ff;--secondary-light: #33e0ff;--secondary-glow: rgba(0, 217, 255, .4);--secondary-rgb: 0, 217, 255;--gb-pink: #e94560;--gb-cyan: #00d9ff;--success-400: #4ADE80;--success-500: #22c55e;--success-600: #16a34a;--danger-400: #f87171;--danger-500: #ef4444;--danger-600: #dc2626;--warning-400: #FB923C;--warning-500: #f97316;--warning-600: #ea580c;--gold-400: #fbbf24;--gold-500: #f59e0b;--gold-600: #d97706;--bg-dark: #0d0f1a;--bg-darker: #0a0c14;--bg-card: rgba(21, 27, 48, .35);--bg-card-hover: rgba(30, 41, 59, .5);--panel-bg: rgba(13, 15, 26, .45);--panel-bg-hover: rgba(21, 27, 48, .6);--panel-border: rgba(255, 255, 255, .1);--panel-border-strong: rgba(0, 217, 255, .4);--bg-primary: #0F172A;--bg-secondary: #1E293B;--bg-tertiary: #1E293B;--bg-quaternary: #0F172A;--text-primary: #F8FAFC;--text-secondary: #94A3B8;--text-accent: #1a4b8c;--border-color: #334155;--card-bg: rgba(30, 41, 59, .8);--accent-color: #1a4b8c;--accent-color-rgb: 26, 75, 140;--accent-hover: #153d73;--accent-glow: rgba(26, 75, 140, .4);--accent-primary: var(--accent-color);--accent-primary-rgb: var(--accent-color-rgb);--gradient-start: #e94560;--gradient-end: #00d9ff;--gradient-button: linear-gradient(135deg, var(--gradient-start), var(--gradient-end));--border-wobbly-xs: 240px 12px 220px 12px / 12px 220px 12px 240px;--border-wobbly-sm: 255px 15px 225px 15px / 15px 225px 15px 255px;--border-wobbly-md: 265px 25px 235px 25px / 25px 235px 25px 265px;--border-wobbly-lg: 275px 35px 245px 35px / 35px 245px 35px 275px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition: .3s cubic-bezier(.4, 0, .2, 1);--transition-slow: .5s cubic-bezier(.4, 0, .2, 1);--font-hand: "Patrick Hand", cursive;--font-title: "Gloria Hallelujah", cursive;--font-marker: "Permanent Marker", cursive;--font-heading: var(--font-title);--font-body: var(--font-hand);--header-height: 66px;--header-height-mobile: 48px;--sidebar-width: 320px;--sidebar-width-collapsed: 0px;--filmstrip-height: 120px;--filmstrip-height-collapsed: 40px}:root{--zoom-factor: 1;--vh-adjusted: 100vh;--dvh-adjusted: 100dvh}body:before{content:"";position:fixed;inset:0;background-image:linear-gradient(90deg,transparent 47px,var(--paper-margin) 47px,var(--paper-margin) 49px,transparent 49px),repeating-linear-gradient(to bottom,transparent 0px,transparent 31px,var(--paper-lines) 31px,var(--paper-lines) 32px);pointer-events:none;z-index:var(--z-background-grid)}*{scrollbar-width:thin;scrollbar-color:var(--ink-blue) var(--paper-lines)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--paper-lines);border-radius:var(--border-wobbly-xs)}::-webkit-scrollbar-thumb{background:var(--ink-blue);border-radius:var(--border-wobbly-xs);border:2px solid var(--paper-bg);-webkit-transition:all .3s ease;transition:all .3s ease}::-webkit-scrollbar-thumb:hover{background:var(--ink-red)}::-webkit-scrollbar-thumb:active{background:var(--ink-green)}::-webkit-scrollbar-corner{background:var(--paper-bg)}::-webkit-scrollbar-thumb:horizontal{background:var(--ink-blue)}::-webkit-scrollbar-thumb:horizontal:hover{background:var(--ink-red)}.font-hand{font-family:var(--font-hand)}.font-title{font-family:var(--font-title)}.font-marker{font-family:var(--font-marker)}.text-gradient{background:var(--gradient-button);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.brand-gb .game{color:#fff;font-weight:700}.brand-gb .buddies{color:var(--gb-pink);font-weight:700}.brand-gb .io{color:var(--gb-cyan);font-weight:700}.app-root{min-height:100dvh;width:100%;position:relative;overflow-x:hidden;overflow-y:auto}.app-root.in-room{display:flex!important;flex-direction:column!important;height:var(--vh-adjusted, 100vh)!important;height:var(--dvh-adjusted, 100dvh)!important;overflow:auto!important}.app-layout{display:flex;flex-direction:column;width:100%;background:var(--panel-bg)}.app-root:not(.in-room) .app-layout{min-height:100vh;min-height:100dvh}.app-root.in-room .app-layout{display:flex;flex-direction:column;flex:1!important;min-height:0!important;width:100%;overflow:hidden!important}@media(max-width:63.9375rem){html.has-filmstrip .app-layout{padding-bottom:calc(var(--bottom-tab-bar-height, 0px) + env(safe-area-inset-bottom,0px) + var(--filmstrip-safe-space, 0px))}html.has-filmstrip .app-root:not(.filmstrip-resizing) .app-layout{transition:padding-bottom .3s cubic-bezier(.4,0,.2,1)}}.app-content{flex:1;display:flex;overflow:auto;padding-top:var(--header-height)}.main-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:var(--spacing-md)}.sidebar{width:var(--sidebar-width);flex-shrink:0;display:flex;flex-direction:column;background:var(--panel-bg);border-left:1px solid var(--panel-border);overflow:hidden}.sidebar-section{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.sidebar-section.chat-section{flex:2;border-top:1px solid var(--panel-border)}.desktop-only{display:none}@media(min-width:1024px){.desktop-only{display:flex}}.mobile-only{display:flex}@media(min-width:1024px){.mobile-only{display:none}}.lobby-page,.game-page{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}@media(max-width:767px){.lobby-page{overflow-y:auto;-webkit-overflow-scrolling:touch}.app-root.in-room .app-layout:has(.lobby-page){overflow-y:auto!important}}.game-content-wrapper{display:flex;flex:1;min-height:0;overflow:hidden}.app-root.in-room .game-content-wrapper{display:flex!important;flex:1!important;min-height:0!important;overflow:auto!important;padding:0!important;margin:0!important;gap:0!important}.main-scroll-area{display:flex;flex-direction:column;flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding:var(--spacing-md)}.app-root.in-room .main-scroll-area{display:flex!important;flex-direction:column!important;flex:1!important;min-height:0!important;overflow:auto!important;padding:0!important;margin:0!important}.app-root.in-room .main-scroll-area>.wheel-phase,.app-root.in-room .main-scroll-area>.input-phase,.app-root.in-room .main-scroll-area>.review-phase,.app-root.in-room .main-scroll-area>.ranking-phase,.app-root.in-room .main-scroll-area>.scoring-phase,.app-root.in-room .main-scroll-area>.game-over-screen{flex:1;min-height:0}.lobby-content-wrapper{width:100%;display:flex;flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-md)}.app-root.in-room .lobby-content-wrapper{width:100%;display:flex;flex-direction:column;gap:var(--spacing-md)}.right-sidebar{width:var(--sidebar-width);flex-shrink:0;display:flex;flex-direction:column;background:var(--panel-bg);border-left:1px solid var(--panel-border);overflow:hidden}@media(min-width:1024px){.app-root.in-room .right-sidebar{width:var(--sidebar-width)!important;flex-shrink:0!important;display:flex!important;flex-direction:column!important;background:var(--panel-bg)!important;overflow:hidden!important;margin-left:auto!important}}.lobby-sidebar-section,.game-sidebar-section{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden;padding:var(--spacing-sm)}.lobby-sidebar-section.chat-section,.game-sidebar-section.chat-section{flex:2;border-top:1px solid var(--panel-border)}@media(min-width:64rem){.video-filmstrip{position:relative!important;bottom:auto;left:auto;right:auto;width:100%;flex-shrink:0!important;z-index:auto!important}body .video-filmstrip,html body .video-filmstrip{position:relative!important;bottom:auto!important;left:auto!important;right:auto!important;flex-shrink:0!important;width:100%!important}}@media(min-width:64rem){html.has-filmstrip .app-root.in-room .app-layout{max-height:calc(var(--vh-adjusted, 100vh) - var(--filmstrip-safe-space, 0px))!important;max-height:calc(var(--dvh-adjusted, 100dvh) - var(--filmstrip-safe-space, 0px))!important}html.has-filmstrip .app-root:not(.filmstrip-resizing) .app-layout{transition:max-height .3s cubic-bezier(.4,0,.2,1)}}.floating-label-container{width:100%}.floating-label-wrapper{position:relative;width:100%}.floating-label-input{width:100%;padding:1.25rem 1rem .75rem;font-size:1rem;font-family:var(--font-hand);border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-sm);background:#fff;color:var(--ink-blue);transition:all .2s ease}.floating-label-input:focus{outline:none;border-color:var(--ink-blue);box-shadow:3px 3px #1a4b8c66;background:var(--highlighter-yellow)}.floating-label-input::-moz-placeholder{color:var(--ink-blue);opacity:.5;-moz-transition:opacity .2s ease;transition:opacity .2s ease}.floating-label-input::placeholder{color:var(--ink-blue);opacity:.5;transition:opacity .2s ease}.floating-label-wrapper.floating .floating-label-input::-moz-placeholder{opacity:.5}.floating-label-wrapper.floating .floating-label-input::placeholder{opacity:.5}.floating-label{position:absolute;left:1rem;top:50%;transform:translateY(-50%);font-size:1rem;font-family:var(--font-hand);color:var(--ink-blue);opacity:.6;pointer-events:none;transition:all .2s ease;background:transparent}.floating-label.floating{top:.25rem;transform:translateY(0);font-size:.75rem;color:var(--ink-blue);opacity:1}.floating-label-wrapper.focused .floating-label{color:var(--ink-blue);opacity:1}.floating-label-wrapper.error .floating-label-input{border-color:var(--ink-red);background:var(--highlighter-pink)}.floating-label-wrapper.error .floating-label{color:var(--ink-red)}.floating-label-error{display:block;margin-top:.25rem;font-size:.875rem;font-family:var(--font-hand);color:var(--ink-red)}.required-asterisk{color:var(--ink-red);margin-left:.25rem}.game-header{width:100%;height:var(--header-height);box-sizing:border-box;background:var(--paper-bg);border-bottom:3px solid var(--ink-blue);box-shadow:0 2px 0 var(--ink-blue);position:relative;z-index:var(--z-mobile-nav)}.game-header-container{display:flex;align-items:center;justify-content:space-between;height:100%;padding:0 1.5rem}.game-header-left{display:flex;align-items:center;gap:var(--spacing-md)}.game-header-logo{display:flex;align-items:center;gap:var(--spacing-sm);text-decoration:none;transition:transform .2s ease}.game-header-logo:hover{transform:scale(1.02)}.game-header-logo-icon{width:36px;height:36px;-o-object-fit:contain;object-fit:contain;filter:drop-shadow(0 2px 8px rgba(233,69,96,.3))}.game-header-logo-text-container{display:flex;flex-direction:column;line-height:1.1}.game-header-logo-text{font-family:var(--font-title);font-size:1.15rem;font-weight:700;color:var(--ink-blue)}.game-header-accent{color:var(--ink-blue);background:linear-gradient(104deg,#ff00 .9%,#ff06 2.4%,#ffff004d 97.6%,#ff00);border-radius:.3em .8em;padding:.1em .3em}.game-header-gb-branding{display:flex;align-items:baseline;gap:.1em;font-family:var(--font-marker);font-size:.65rem;letter-spacing:.02em}.game-header-gb-by{color:var(--ink-blue);opacity:.6}.game-header-gb-game{color:var(--ink-red)}.game-header-gb-buddies{color:var(--ink-blue)}.game-header-gb-io{color:var(--ink-blue);opacity:.6}.game-header-divider{width:2px;height:28px;background:var(--ink-blue);opacity:.3}.game-header-room-info{display:flex;align-items:center;gap:var(--spacing-md)}.game-header-room-code{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:var(--paper-bg);border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-sm);box-shadow:2px 2px 0 var(--ink-blue)}.game-header-room-label{font-family:var(--font-hand);font-size:.85rem;color:var(--ink-blue);opacity:.7}.game-header-room-value{font-family:var(--font-marker);font-size:1rem;color:var(--ink-blue);letter-spacing:.15em}.game-header-copy-btn{display:flex;align-items:center;justify-content:center;min-width:44px;min-height:44px;width:44px;height:44px;background:transparent;border:2px solid transparent;border-radius:var(--border-wobbly-xs);color:var(--ink-blue);cursor:pointer;transition:all .2s ease}.game-header-copy-btn:hover{background:var(--highlighter-yellow);border-color:var(--ink-blue)}.game-header-streamer-badge{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:var(--highlighter-pink);border:2px solid var(--ink-red);border-radius:var(--border-wobbly-xs);font-family:var(--font-hand);font-size:.85rem;color:var(--ink-red)}.game-header-phase-badge{padding:var(--spacing-xs) var(--spacing-sm);background:var(--highlighter-green);border:2px solid var(--ink-green);border-radius:var(--border-wobbly-xs);font-family:var(--font-hand);font-size:.8rem;color:var(--ink-green)}.game-header-right{display:flex;align-items:center;gap:.75rem}@media(max-width:767px){.game-header-right{gap:.35rem}}@media(max-width:374px){.game-header-right{gap:.2rem}.game-header-player-info,.game-header-divider{display:none}.game-header-player-count{padding:2px 6px;font-size:.8rem}}.game-header-player-count{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:var(--paper-bg);border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-xs);font-family:var(--font-hand);font-size:.9rem;color:var(--ink-blue)}.game-header-player-count svg{color:var(--ink-blue)}.game-header-player-info{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:var(--paper-bg);border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-xs);font-family:var(--font-hand);font-size:.9rem;color:var(--ink-blue)}.game-header-player-info.host{background:var(--highlighter-yellow);border:2px solid var(--ink-blue)}.game-header-player-info.host svg{color:var(--ink-blue)}.game-header-settings-btn,.game-header-lobby-btn,.game-header-leave-btn{display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);min-width:44px;min-height:44px;padding:var(--spacing-sm);background:var(--paper-bg);border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-sm);color:var(--ink-blue);font-family:var(--font-hand);font-size:.9rem;cursor:pointer;transition:all .2s ease;box-shadow:2px 2px 0 var(--ink-blue)}.game-header-settings-btn:hover{background:var(--highlighter-yellow);transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--ink-blue)}.game-header-lobby-btn:hover{background:var(--highlighter-blue);transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--ink-blue)}.game-header-leave-btn:hover{background:var(--highlighter-pink);border-color:var(--ink-red);color:var(--ink-red);box-shadow:2px 2px 0 var(--ink-red)}.game-header-copy-btn:active,.game-header-settings-btn:active,.game-header-lobby-btn:active,.game-header-leave-btn:active{transform:scale(.95)}.game-header-logo:active{transform:scale(.98)}.game-header-copy-btn:focus-visible,.game-header-mute-btn:focus-visible,.game-header-settings-btn:focus-visible,.game-header-lobby-btn:focus-visible,.game-header-leave-btn:focus-visible{outline:3px solid var(--ink-blue);outline-offset:2px}.game-header-logo:focus-visible{outline:3px solid var(--ink-blue);outline-offset:4px;border-radius:var(--border-wobbly-xs)}.game-header-copy-btn.copied,.game-header-copy-btn:has(svg.lucide-check){background:var(--highlighter-green);border-color:var(--ink-green);color:var(--ink-green);animation:copyPop .3s ease}@keyframes copyPop{0%{transform:scale(1)}50%{transform:scale(1.15)}to{transform:scale(1)}}@supports (padding-top: env(safe-area-inset-top)){.game-header{padding-left:max(var(--spacing-md),env(safe-area-inset-left));padding-right:max(var(--spacing-md),env(safe-area-inset-right))}}.desktop-only{display:flex}@media(max-width:1023px){.game-header{height:var(--header-height-mobile);padding:0 var(--spacing-sm)}.game-header-logo-icon{width:28px;height:28px}.game-header-logo-text{font-size:1rem}.game-header-gb-branding{display:none}.desktop-only{display:none!important}}@media(max-width:926px)and (orientation:landscape){.game-header{height:var(--header-height-mobile)}.game-header-logo-icon{width:24px;height:24px}.game-header-logo-text{font-size:.9rem}}@media(max-height:500px)and (orientation:landscape){.game-header{height:var(--header-height-mobile)}.game-header-logo-icon{width:22px;height:22px}}.header-left{display:flex;align-items:center;gap:var(--spacing-md)}.header-logo{display:flex;align-items:center;gap:var(--spacing-sm);font-family:var(--font-title)}.header-room-info{display:flex;align-items:center;gap:var(--spacing-md)}.room-code{padding:.25rem .625rem;background:#e9456026;border:2px solid var(--gb-pink);border-radius:var(--radius-sm)}.player-count{display:flex;align-items:center;gap:.375rem;color:var(--text-secondary)}.header-right{display:flex;align-items:center;gap:var(--spacing-sm)}.header-btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;min-width:44px;min-height:44px;background:#33415580;border:2px solid var(--panel-border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.header-btn:hover{background:#00d9ff33;border-color:var(--gb-cyan);color:#fff}.header-btn.active{background:#00d9ff4d;border-color:var(--gb-cyan);color:var(--gb-cyan)}.header-btn.danger:hover{background:#ef444433;border-color:var(--danger-500);color:var(--danger-400)}.video-filmstrip{position:fixed;bottom:0;left:0;right:0;padding-bottom:env(safe-area-inset-bottom,0px);padding-left:env(safe-area-inset-left,0px);padding-right:env(safe-area-inset-right,0px);background:var(--paper-bg);border-top:3px solid var(--ink-blue);z-index:var(--z-filmstrip)}.video-filmstrip.collapsed{height:12px;cursor:pointer;display:flex;align-items:center;justify-content:center}.video-filmstrip.expanded{height:var(--filmstrip-height)}.filmstrip-resize-handle{position:absolute;top:0;left:0;right:0;height:8px;cursor:row-resize;z-index:10}.filmstrip-resize-handle:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:40px;height:4px;background:var(--ink-blue);opacity:.4;border-radius:2px;transition:opacity .2s}.filmstrip-resize-handle:hover:before{opacity:.8}.app-root.filmstrip-resizing{-webkit-user-select:none;-moz-user-select:none;user-select:none}.app-root.filmstrip-resizing .video-filmstrip,.video-filmstrip.resizing{transition:none!important}.video-filmstrip.resizing *{pointer-events:none}.video-filmstrip.resizing .filmstrip-resize-handle{pointer-events:auto}.video-filmstrip-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-xs) var(--spacing-md);border-bottom:2px dashed var(--paper-lines)}.video-filmstrip-expand-btn,.video-filmstrip-collapse-btn,.filmstrip-toggle{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md);background:var(--paper-bg);border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-sm);color:var(--ink-blue);font-family:var(--font-hand);font-size:.8125rem;font-weight:600;cursor:pointer;transition:all .15s ease;box-shadow:2px 2px #1a4b8c4d}.video-filmstrip-expand-btn:hover,.video-filmstrip-collapse-btn:hover,.filmstrip-toggle:hover{background:var(--highlighter-yellow);transform:translate(-1px,-1px);box-shadow:3px 3px #1a4b8c4d}.video-filmstrip-feeds,.filmstrip-content{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);padding-top:12px;height:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--ink-blue) transparent}.video-filmstrip-feeds::-webkit-scrollbar{height:4px}.video-filmstrip-feeds::-webkit-scrollbar-track{background:transparent}.video-filmstrip-feeds::-webkit-scrollbar-thumb{background:var(--ink-blue);border-radius:2px}.video-filmstrip-empty{display:flex;align-items:center;justify-content:center;width:100%;color:var(--ink-blue);opacity:.6;font-family:var(--font-hand);font-style:italic}.video-filmstrip-expand-btn:focus-visible,.video-filmstrip-collapse-btn:focus-visible,.filmstrip-toggle:focus-visible{outline:2px solid var(--ink-blue);outline-offset:2px}.video-filmstrip-expand-btn:active,.video-filmstrip-collapse-btn:active,.filmstrip-toggle:active{transform:translate(1px,1px);box-shadow:1px 1px #1a4b8c4d;background:var(--highlighter-yellow)}.video-filmstrip{box-shadow:0 -4px #1a4b8c33}.video-filmstrip-feeds{position:relative;mask-image:linear-gradient(to right,transparent 0%,black 2%,black 98%,transparent 100%);-webkit-mask-image:linear-gradient(to right,transparent 0%,black 2%,black 98%,transparent 100%)}@keyframes videoFeedEnter{0%{opacity:0;transform:scale(.9) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.video-filmstrip-feeds>*{animation:videoFeedEnter .3s ease-out backwards}.video-filmstrip-feeds>*:nth-child(1){animation-delay:.05s}.video-filmstrip-feeds>*:nth-child(2){animation-delay:.1s}.video-filmstrip-feeds>*:nth-child(3){animation-delay:.15s}.video-filmstrip-feeds>*:nth-child(4){animation-delay:.2s}.video-filmstrip-feeds>*:nth-child(5){animation-delay:.25s}.video-filmstrip-feeds>*:nth-child(6){animation-delay:.3s}.video-filmstrip-feeds>*:nth-child(7){animation-delay:.35s}.video-filmstrip-feeds>*:nth-child(8){animation-delay:.4s}.video-filmstrip-collapse-btn svg,.video-filmstrip-expand-btn svg{transition:transform .2s ease}.video-filmstrip-collapse-btn:hover svg{transform:translateY(2px)}.video-filmstrip-expand-btn:hover svg{transform:translateY(-2px)}@media(min-width:768px)and (max-width:1023px){.video-filmstrip-header{padding:var(--spacing-xs) var(--spacing-sm)}.video-filmstrip-feeds{padding:var(--spacing-xs) var(--spacing-sm);gap:var(--spacing-xs)}.video-filmstrip-expand-btn,.video-filmstrip-collapse-btn{padding:4px var(--spacing-sm);font-size:.75rem}}@media(max-width:374px){.video-filmstrip-header{padding:4px var(--spacing-xs)}.video-filmstrip-expand-btn,.video-filmstrip-collapse-btn{padding:3px 8px;font-size:.6875rem;gap:4px}.video-filmstrip-expand-btn svg,.video-filmstrip-collapse-btn svg{width:12px;height:12px}.video-filmstrip-feeds{padding:4px var(--spacing-xs);gap:6px}.video-filmstrip.collapsed{height:28px}}@media(min-width:1536px){.video-filmstrip-header{padding:var(--spacing-sm) var(--spacing-lg)}.video-filmstrip-expand-btn,.video-filmstrip-collapse-btn{padding:var(--spacing-xs) var(--spacing-lg);font-size:.9375rem}.video-filmstrip-feeds{padding:var(--spacing-md) var(--spacing-lg);gap:var(--spacing-md)}.video-filmstrip.expanded{height:140px}.video-filmstrip.collapsed{height:48px}}.video-control-cluster,.video-controls{display:flex;gap:.25rem;padding:.25rem;background:var(--paper-bg);border-radius:var(--border-wobbly-sm);border:2px solid var(--ink-blue);box-shadow:2px 2px #1a4b8c4d}.video-control-cluster.compact{padding:.125rem;gap:.125rem}.video-control-cluster.compact .video-control-btn{width:36px;height:36px;min-width:36px;min-height:36px}.video-control-btn{display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);width:44px;height:44px;min-width:44px;min-height:44px;background:transparent;border:none;border-radius:var(--border-wobbly-xs);color:var(--ink-blue);font-family:var(--font-hand);font-size:.75rem;cursor:pointer;transition:all .15s ease}.video-control-btn:hover{background:var(--highlighter-yellow);color:var(--ink-blue)}.video-control-btn.muted,.video-control-btn.off{background:var(--highlighter-pink);color:var(--ink-red)}.video-control-btn.off:hover{background:var(--highlighter-pink);opacity:.8}.video-control-btn.leave{background:var(--highlighter-pink);color:var(--ink-red)}.video-control-btn.leave:hover{background:var(--ink-red);color:var(--paper-bg)}.video-join-btn{display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background:var(--paper-bg);border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-sm);color:var(--ink-blue);font-family:var(--font-hand);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .15s ease;box-shadow:2px 2px #1a4b8c4d}.video-join-btn:hover{background:var(--highlighter-yellow);transform:translate(-1px,-1px);box-shadow:3px 3px #1a4b8c4d}.video-join-btn:active{transform:scale(.98)}.video-join-text{display:none}@media(min-width:768px){.video-join-text{display:inline}}.video-preparing-badge{display:flex;align-items:center;gap:.375rem;padding:.375rem .625rem;background:#fbbf2433;border:1px solid rgba(251,191,36,.4);border-radius:.5rem;color:#fbbf24;font-size:.75rem;font-weight:500;animation:preparingPulse 2s infinite}@keyframes preparingPulse{0%,to{opacity:1}50%{opacity:.7}}.video-control-btn:focus-visible{outline:2px solid var(--ink-blue);outline-offset:2px;background:var(--highlighter-yellow)}.video-control-btn.off:focus-visible{outline-color:var(--ink-red)}.video-control-btn:active{transform:scale(.9)}.video-control-btn:not(.off):not(.muted){color:var(--ink-blue)}.video-control-btn:not(.off):not(.muted):hover{background:var(--highlighter-yellow)}.video-control-btn.off svg,.video-control-btn.muted svg{filter:drop-shadow(0 0 2px rgba(196,30,58,.5))}@keyframes mutedPulse{0%,to{box-shadow:0 0 #ef44444d}50%{box-shadow:0 0 6px 2px #ef444400}}.video-control-btn.off,.video-control-btn.muted{animation:mutedPulse 3s ease-in-out infinite}.video-control-btn.off:hover,.video-control-btn.muted:hover{animation:none}.video-control-btn:has(svg.lucide-settings):hover svg{animation:settingsSpin 1s ease-in-out}@keyframes settingsSpin{0%{transform:rotate(0)}to{transform:rotate(180deg)}}@media(min-width:768px)and (max-width:1023px){.video-control-cluster{padding:.125rem;gap:.125rem}.video-control-btn{width:40px;height:40px;min-width:40px;min-height:40px}.video-control-cluster.compact .video-control-btn{width:32px;height:32px;min-width:32px;min-height:32px}}@media(max-width:374px){.video-control-cluster{padding:2px;gap:2px;border-radius:var(--radius-sm)}.video-control-btn{width:36px;height:36px;min-width:36px;min-height:36px}.video-control-btn svg{width:14px;height:14px}.video-control-cluster.compact .video-control-btn{width:28px;height:28px;min-width:28px;min-height:28px}.video-control-cluster.compact .video-control-btn svg{width:12px;height:12px}}@media(min-width:1536px){.video-control-cluster{padding:var(--spacing-xs);gap:var(--spacing-xs)}.video-control-btn{width:52px;height:52px;min-width:52px;min-height:52px}.video-control-btn svg{width:20px;height:20px}.video-control-cluster.compact .video-control-btn{width:44px;height:44px;min-width:44px;min-height:44px}}@media(max-width:926px)and (orientation:landscape){.video-control-cluster{padding:2px;gap:2px}.video-control-btn{width:32px;height:32px;min-width:32px;min-height:32px}.video-control-btn svg{width:14px;height:14px}}.webcam-display,.video-feed{position:relative;flex-shrink:0;background:var(--paper-bg);border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-sm);overflow:hidden;transition:all .15s ease;box-shadow:2px 2px #1a4b8c4d}.webcam-display.small,.video-feed{width:120px;height:90px}.webcam-display.medium{width:180px;height:135px}.webcam-display.large{width:240px;height:180px}.webcam-display:hover,.video-feed:hover{border-color:var(--ink-blue);transform:translate(-1px,-1px);box-shadow:3px 3px #1a4b8c4d}.webcam-display.is-turn,.video-feed.current-turn{border-color:var(--ink-red);box-shadow:3px 3px 0 var(--ink-red)}.video-feed.self{border-color:var(--ink-green);box-shadow:3px 3px 0 var(--ink-green)}.webcam-video-container{position:relative;width:100%;height:100%}.webcam-video,.video-feed video{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.webcam-display .webcam-video{transform:scaleX(-1)}.webcam-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%;background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-tertiary) 100%)}.webcam-avatar,.video-feed-avatar{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;background:var(--ink-blue);border:2px solid var(--paper-bg);font-weight:700;color:var(--paper-bg);font-family:var(--font-title);overflow:hidden}.webcam-display.small .webcam-avatar{width:36px;height:36px;font-size:1rem}.webcam-display.large .webcam-avatar{width:64px;height:64px;font-size:1.5rem}.webcam-avatar-img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.webcam-avatar-initial{font-size:1.25rem}.webcam-local-indicator{position:absolute;top:4px;left:4px;padding:2px 6px;background:var(--gb-cyan);border-radius:var(--radius-sm);font-size:.625rem;font-weight:700;color:var(--bg-primary);text-transform:uppercase}.webcam-overlay{position:absolute;bottom:0;left:0;right:0;padding:4px 6px;background:linear-gradient(transparent,#000000d9);display:flex;align-items:center;justify-content:space-between}.webcam-name,.video-feed-name{display:flex;align-items:center;gap:4px;font-size:.6875rem;font-weight:600;font-family:var(--font-hand);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#fff}.webcam-host-icon{color:var(--ink-red);flex-shrink:0}.webcam-you-tag{font-size:.5625rem;color:var(--gb-cyan);opacity:.9}.webcam-muted,.video-feed-status{display:flex;align-items:center;justify-content:center;width:20px;height:20px;background:#ef4444cc;border-radius:var(--radius-sm);color:#fff}.video-feed-status span{font-size:.75rem;background:#000000b3;padding:.125rem .25rem;border-radius:.25rem}.webcam-turn-indicator{position:absolute;top:0;left:0;right:0;padding:4px;background:var(--highlighter-yellow);border-bottom:2px solid var(--ink-blue);text-align:center;color:var(--ink-blue);font-size:.625rem;font-weight:700;font-family:var(--font-title);color:#fff;text-transform:uppercase;letter-spacing:.05em;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes turnGlow{0%,to{box-shadow:3px 3px 0 var(--ink-red)}50%{box-shadow:4px 4px 0 var(--ink-red)}}.webcam-display.is-turn,.video-feed.current-turn{animation:turnGlow 1.5s ease-in-out infinite}@keyframes hostCrownGlow{0%,to{filter:drop-shadow(0 0 2px rgba(196,30,58,.5))}50%{filter:drop-shadow(0 0 4px rgba(196,30,58,.8))}}.webcam-host-icon{animation:hostCrownGlow 2s ease-in-out infinite}.webcam-muted{animation:mutedPulse 2s ease-in-out infinite}@keyframes avatarFadeIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.webcam-avatar{animation:avatarFadeIn .3s ease-out}@keyframes videoLoading{0%{background-position:-200% 0}to{background-position:200% 0}}.webcam-placeholder:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 25%,rgba(0,217,255,.05) 50%,transparent 75%);background-size:200% 100%;animation:videoLoading 2s ease-in-out infinite;pointer-events:none}.webcam-local-indicator{box-shadow:0 0 8px #00d9ff80}.webcam-overlay{transition:all .2s ease}.webcam-display:hover .webcam-overlay{background:linear-gradient(transparent 0%,#000000e6);padding-bottom:8px}@media(min-width:768px)and (max-width:1023px){.webcam-display.small,.video-feed{width:100px;height:75px}.webcam-display.medium{width:150px;height:112px}.webcam-avatar,.video-feed-avatar{width:40px;height:40px}.webcam-display.small .webcam-avatar{width:32px;height:32px;font-size:.875rem}.webcam-name,.video-feed-name{font-size:.625rem}.webcam-local-indicator{padding:1px 4px;font-size:.5625rem}.webcam-muted,.video-feed-status{width:16px;height:16px}}@media(max-width:374px){.webcam-display.small,.video-feed{width:80px;height:60px}.webcam-display.medium{width:120px;height:90px}.webcam-avatar,.video-feed-avatar{width:32px;height:32px}.webcam-display.small .webcam-avatar{width:24px;height:24px;font-size:.75rem}.webcam-avatar-initial{font-size:.875rem}.webcam-overlay{padding:2px 4px}.webcam-name,.video-feed-name{font-size:.5625rem;gap:2px}.webcam-host-icon{width:10px;height:10px}.webcam-you-tag{font-size:.5rem}.webcam-local-indicator{padding:1px 3px;font-size:.5rem;top:2px;left:2px}.webcam-muted,.video-feed-status{width:14px;height:14px}.webcam-muted svg{width:10px;height:10px}.webcam-turn-indicator{padding:2px;font-size:.5rem}}@media(min-width:1536px){.webcam-display.small,.video-feed{width:140px;height:105px}.webcam-display.medium{width:220px;height:165px}.webcam-display.large{width:300px;height:225px}.webcam-avatar,.video-feed-avatar{width:56px;height:56px}.webcam-display.small .webcam-avatar{width:44px;height:44px;font-size:1.125rem}.webcam-display.large .webcam-avatar{width:80px;height:80px;font-size:2rem}.webcam-avatar-initial{font-size:1.5rem}.webcam-overlay{padding:6px 8px}.webcam-name,.video-feed-name{font-size:.8125rem;gap:6px}.webcam-host-icon{width:14px;height:14px}.webcam-you-tag{font-size:.6875rem}.webcam-local-indicator{padding:3px 8px;font-size:.6875rem;top:6px;left:6px}.webcam-muted,.video-feed-status{width:24px;height:24px}.webcam-turn-indicator{padding:6px;font-size:.75rem}}@media(max-width:926px)and (orientation:landscape){.webcam-display.small,.video-feed{width:90px;height:68px}.webcam-display.medium{width:120px;height:90px}.webcam-avatar,.video-feed-avatar{width:32px;height:32px}.webcam-overlay{padding:2px 4px}.webcam-name,.video-feed-name{font-size:.5625rem}.webcam-turn-indicator{padding:2px;font-size:.5rem}}.mobile-video-grid{display:grid;gap:var(--spacing-xs);padding:var(--spacing-sm);height:100%;width:100%}.mobile-video-grid.grid-1{grid-template-columns:1fr;grid-template-rows:1fr}.mobile-video-grid.grid-2{grid-template-columns:1fr 1fr;grid-template-rows:1fr}.mobile-video-grid.grid-3{grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,1fr)}.mobile-video-grid.grid-3 .mobile-video-grid-item:first-child{grid-column:1 / -1}.mobile-video-grid.grid-4{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}.mobile-video-grid.grid-5,.mobile-video-grid.grid-6{grid-template-columns:repeat(3,1fr);grid-template-rows:1fr 1fr}.mobile-video-grid-item{position:relative;background:var(--bg-secondary);border:2px solid var(--panel-border);border-radius:var(--radius-md);overflow:hidden;min-height:0}.mobile-video-grid-item .webcam-display{width:100%!important;height:100%!important}.mobile-video-grid-item .webcam-video-container{width:100%;height:100%}.mobile-video-grid-item.self,.mobile-video-grid-item.local{border-color:var(--gb-cyan);box-shadow:0 0 10px #00d9ff4d}.mobile-video-grid-item.active-speaker,.mobile-video-grid-item.is-turn{border-color:var(--gb-pink);box-shadow:0 0 15px #e9456066}.mobile-video-grid-item video{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.mobile-video-grid-item .video-overlay{position:absolute;bottom:0;left:0;right:0;padding:.25rem .5rem;background:linear-gradient(transparent,#000c);display:flex;align-items:center;justify-content:space-between}.mobile-video-grid-item .video-name{font-size:.75rem;font-family:var(--font-hand);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mobile-video-grid-item .video-status{display:flex;gap:.25rem;font-size:.75rem}.mobile-video-grid-overflow{display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:2px dashed var(--panel-border);border-radius:var(--radius-md);font-family:var(--font-hand);font-size:1rem;color:var(--text-secondary)}.mobile-video-controls{position:absolute;bottom:0;left:0;right:0;display:flex;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-md);padding-bottom:calc(var(--spacing-md) + env(safe-area-inset-bottom,0px));background:linear-gradient(transparent,#000c);z-index:10}.mobile-video-control-btn{width:48px;height:48px;border-radius:50%;border:none;background:var(--bg-tertiary);color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.mobile-video-control-btn:active{transform:scale(.95)}.mobile-video-control-btn.off{background:#ffffff1a;color:var(--text-muted)}.mobile-video-control-btn.leave{background:var(--gb-pink);color:#fff}.mobile-video-control-btn.leave:active{background:#c73b53}@media(orientation:landscape)and (max-width:1023px){.mobile-video-grid.grid-2{grid-template-columns:1fr 1fr}.mobile-video-grid.grid-3{grid-template-columns:repeat(3,1fr);grid-template-rows:1fr}.mobile-video-grid.grid-3 .mobile-video-grid-item:first-child{grid-column:auto}.mobile-video-grid.grid-4{grid-template-columns:repeat(4,1fr);grid-template-rows:1fr}.mobile-video-grid.grid-5,.mobile-video-grid.grid-6{grid-template-columns:repeat(6,1fr);grid-template-rows:1fr}}@keyframes gridItemEnter{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.mobile-video-grid-item{animation:gridItemEnter .3s ease-out backwards}.mobile-video-grid-item:nth-child(1){animation-delay:.05s}.mobile-video-grid-item:nth-child(2){animation-delay:.1s}.mobile-video-grid-item:nth-child(3){animation-delay:.15s}.mobile-video-grid-item:nth-child(4){animation-delay:.2s}.mobile-video-grid-item:nth-child(5){animation-delay:.25s}.mobile-video-grid-item:nth-child(6){animation-delay:.3s}.mobile-video-grid-item:active{transform:scale(.98);transition:transform .1s ease}.mobile-video-grid-item.local{animation:gridItemEnter .3s ease-out backwards,localGlow 3s ease-in-out .3s infinite}@keyframes localGlow{0%,to{box-shadow:0 0 10px #00d9ff4d}50%{box-shadow:0 0 18px #00d9ff80}}.mobile-video-grid-item.is-turn{animation:gridItemEnter .3s ease-out backwards,turnGlow 1.5s ease-in-out .3s infinite}.mobile-video-grid-overflow{transition:all .2s ease}.mobile-video-grid-overflow:hover{background:var(--highlighter-yellow);border-style:solid;border-color:var(--ink-blue);color:var(--ink-blue)}@keyframes overflowPulse{0%,to{opacity:.8}50%{opacity:1}}.mobile-video-grid-overflow span{animation:overflowPulse 2s ease-in-out infinite}@media(max-width:374px){.mobile-video-grid{gap:4px;padding:var(--spacing-xs)}.mobile-video-grid-item{border-radius:var(--radius-sm);border-width:1.5px}.mobile-video-grid-item .video-overlay{padding:2px 4px}.mobile-video-grid-item .video-name{font-size:.625rem}.mobile-video-grid-item .video-status{font-size:.625rem;gap:2px}.mobile-video-grid-overflow{font-size:.8125rem;border-radius:var(--radius-sm)}}@media(max-height:400px)and (orientation:landscape){.mobile-video-grid{gap:3px;padding:4px}.mobile-video-grid-item{border-radius:var(--radius-sm);border-width:1px}.mobile-video-grid-item .video-overlay{padding:1px 3px}.mobile-video-grid-item .video-name{font-size:.5625rem}.mobile-video-grid-overflow{font-size:.75rem}}.video-enhancements{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md)}.enhancement-section{background:#3341554d;border:1px solid var(--panel-border);border-radius:var(--radius-md);overflow:hidden}.enhancement-toggle{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:none;color:var(--text-primary);font-family:var(--font-hand);font-size:.875rem;cursor:pointer;transition:all .2s ease;text-align:left;min-height:44px}.enhancement-toggle:hover{background:#00d9ff1a}.enhancement-toggle.active{background:#00d9ff26}.enhancement-toggle svg{flex-shrink:0;color:var(--text-secondary)}.enhancement-toggle.active svg{color:var(--gb-cyan)}.enhancement-toggle span:first-of-type{flex:1}.enhancement-status{font-size:.75rem;font-weight:600;padding:2px 8px;background:#33415580;border-radius:var(--radius-full);color:var(--text-secondary)}.enhancement-toggle.active .enhancement-status{background:#00d9ff33;color:var(--gb-cyan)}.enhancement-content{padding:var(--spacing-sm) var(--spacing-md);border-top:1px solid var(--panel-border);background:#0f172a4d}.background-options{display:grid;grid-template-columns:repeat(auto-fill,minmax(60px,1fr));gap:var(--spacing-sm)}.background-option{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;aspect-ratio:4/3;padding:var(--spacing-xs);background:#33415580;border:2px solid var(--panel-border);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.625rem;cursor:pointer;transition:all .2s ease;overflow:hidden}.background-option:hover{border-color:var(--gb-cyan);background:#00d9ff1a}.background-option.selected{border-color:var(--gb-pink);background:#e9456026}.background-option.image{padding:0;background:#f0f0f0}.background-option.image img{width:100%;height:100%;-o-object-fit:contain;object-fit:contain}.selected-indicator{position:absolute;top:4px;right:4px;display:flex;align-items:center;justify-content:center;width:20px;height:20px;background:var(--gb-pink);border-radius:50%;color:#fff}@media(max-width:767px){.background-options{grid-template-columns:repeat(4,1fr)}}@media(max-width:374px){.background-options{grid-template-columns:repeat(3,1fr)}}.enhancement-toggle:focus-visible{outline:2px solid var(--gb-cyan);outline-offset:-2px;background:#00d9ff26}.background-option:focus-visible{outline:2px solid var(--gb-cyan);outline-offset:2px}.enhancement-toggle:active{transform:scale(.98)}.background-option:active{transform:scale(.95)}@keyframes enhancementExpand{0%{opacity:0;max-height:0}to{opacity:1;max-height:300px}}.enhancement-content{animation:enhancementExpand .25s ease-out;overflow:hidden}.enhancement-section{animation:sectionSlideIn .2s ease-out backwards}.enhancement-section:nth-child(1){animation-delay:.05s}.enhancement-section:nth-child(2){animation-delay:.1s}.enhancement-section:nth-child(3){animation-delay:.15s}@keyframes sectionSlideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes optionSelect{0%{transform:scale(1)}50%{transform:scale(.92)}to{transform:scale(1)}}.background-option.selected{animation:optionSelect .2s ease}@keyframes indicatorPop{0%{transform:scale(0)}to{transform:scale(1)}}.selected-indicator{animation:indicatorPop .2s ease-out}.enhancement-status{transition:all .2s ease}.enhancement-toggle svg:first-of-type{transition:transform .2s ease}.enhancement-toggle:hover svg:first-of-type{transform:scale(1.1)}.enhancement-toggle.active svg:first-of-type{transform:rotate(10deg)}@media(min-width:768px)and (max-width:1023px){.video-enhancements{padding:var(--spacing-sm);gap:var(--spacing-xs)}.enhancement-toggle{padding:var(--spacing-xs) var(--spacing-sm);font-size:.8125rem;min-height:40px}.enhancement-content{padding:var(--spacing-xs) var(--spacing-sm)}.background-options{grid-template-columns:repeat(5,1fr);gap:var(--spacing-xs)}}@media(min-width:1536px){.video-enhancements{padding:var(--spacing-lg);gap:var(--spacing-md)}.enhancement-toggle{padding:var(--spacing-md);font-size:1rem;min-height:52px}.enhancement-toggle svg{width:20px;height:20px}.enhancement-status{font-size:.8125rem;padding:3px 10px}.enhancement-content{padding:var(--spacing-md)}.background-options{grid-template-columns:repeat(6,1fr);gap:var(--spacing-md)}.background-option{font-size:.75rem;border-radius:var(--radius-lg)}.selected-indicator{width:24px;height:24px}}@media(max-width:926px)and (orientation:landscape){.video-enhancements{padding:var(--spacing-xs);gap:var(--spacing-xs)}.enhancement-toggle{padding:var(--spacing-xs) var(--spacing-sm);font-size:.75rem;min-height:36px}.enhancement-content{padding:var(--spacing-xs)}.background-options{grid-template-columns:repeat(6,1fr);gap:4px}.background-option{font-size:.5rem}}.chat-window{display:flex;flex-direction:column;height:100%;background:var(--paper-bg);border-radius:var(--border-wobbly-md);overflow:hidden;border:2px solid var(--ink-blue)}.chat-window.sidebar{border-radius:0;background:transparent;border:none}.chat-window.sidebar .chat-input-container{background:transparent}.chat-window.floating{position:fixed;bottom:var(--spacing-md);right:var(--spacing-md);width:320px;max-height:400px;background:var(--paper-bg);border:2px solid var(--ink-blue);box-shadow:4px 4px 0 var(--ink-blue);z-index:var(--z-modal)}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);border-bottom:2px solid var(--ink-blue);background:var(--highlighter-yellow)}.chat-title{font-family:var(--font-title);font-weight:600;font-size:1rem;color:var(--ink-blue);margin:0}.chat-close-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:2px solid transparent;border-radius:var(--border-wobbly-xs);color:var(--ink-blue);cursor:pointer;transition:all .2s ease}.chat-close-btn:hover{background:var(--highlighter-pink);border-color:var(--ink-red);color:var(--ink-red)}.chat-messages{flex:1;overflow-y:auto;padding:var(--spacing-sm);-webkit-overflow-scrolling:touch;display:flex;flex-direction:column;gap:var(--spacing-xs)}.chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:var(--ink-blue);opacity:.6;padding:clamp(1rem,3dvh,2.5rem)}.chat-empty p{margin:0;font-family:var(--font-hand)}.chat-empty-hint{font-size:.875rem;opacity:.7;margin-top:var(--spacing-sm)!important}.chat-message{margin-bottom:var(--spacing-xs);max-width:85%}.chat-message.mine{align-self:flex-end}.chat-message.theirs{align-self:flex-start}.chat-message.system{align-self:center;max-width:100%;padding:var(--spacing-xs) var(--spacing-sm);background:var(--highlighter-yellow);border-left:3px solid var(--ink-blue);border-radius:var(--border-wobbly-xs);font-size:.75rem;color:var(--ink-blue);text-align:center}.chat-message-sender{display:block;font-size:.75rem;font-weight:600;font-family:var(--font-hand);color:var(--ink-blue);margin-bottom:.125rem}.chat-message-bubble{padding:var(--spacing-sm) var(--spacing-md);background:var(--paper-bg);border:2px solid var(--paper-lines);border-radius:var(--border-wobbly-sm)}.chat-message.mine .chat-message-bubble{background:var(--highlighter-yellow);border-color:var(--ink-blue)}.chat-message-text{font-family:var(--font-hand);font-size:.9375rem;color:var(--ink-blue);word-wrap:break-word;line-height:1.4}.chat-message-time{display:block;font-size:.625rem;color:var(--ink-blue);margin-top:.25rem;opacity:.5}.chat-message.mine .chat-message-time{text-align:right;color:var(--ink-blue);opacity:.5}.chat-message-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:.25rem}.chat-message-author{font-weight:600;font-family:var(--font-hand);color:var(--ink-blue)}.chat-message-content{font-family:var(--font-hand);color:var(--ink-blue);word-wrap:break-word}.chat-input-container{display:flex;gap:var(--spacing-sm);padding:var(--spacing-sm);border-top:2px solid var(--ink-blue);background:var(--paper-bg)}.chat-input{flex:1;padding:var(--spacing-sm) var(--spacing-md);background:var(--paper-bg);border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-sm);color:var(--ink-blue);font-family:var(--font-hand);font-size:16px;min-height:44px}.chat-input::-moz-placeholder{color:var(--ink-blue);opacity:.5}.chat-input::placeholder{color:var(--ink-blue);opacity:.5}.chat-input:focus{outline:none;border-color:var(--ink-blue);box-shadow:0 0 0 3px #1a4b8c33}.chat-send-btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;min-width:44px;min-height:44px;background:var(--ink-blue);border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-sm);color:var(--paper-bg);cursor:pointer;transition:all .2s ease;box-shadow:2px 2px #1a4b8c4d}.chat-send-btn:hover:not(:disabled){transform:translate(-1px,-1px);box-shadow:3px 3px #1a4b8c4d}.chat-send-btn:disabled{opacity:.5;cursor:not-allowed}.chat-send-btn:active:not(:disabled){transform:translate(1px,1px);box-shadow:1px 1px #1a4b8c4d}.chat-close-btn:focus-visible,.chat-send-btn:focus-visible{outline:3px solid var(--ink-blue);outline-offset:2px}.chat-input:focus-visible{outline:none}@keyframes chatMessageSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.chat-message{animation:chatMessageSlideIn .2s ease-out}.chat-message.system{animation:chatMessageSlideIn .3s ease-out}.chat-typing-indicator{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm);color:var(--text-secondary);font-style:italic}.chat-typing-dots{display:flex;gap:3px}.chat-typing-dots span{width:6px;height:6px;background:var(--text-muted);border-radius:50%;animation:typingBounce 1.4s ease-in-out infinite}.chat-typing-dots span:nth-child(2){animation-delay:.2s}.chat-typing-dots span:nth-child(3){animation-delay:.4s}@keyframes typingBounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-4px)}}@media(max-width:374px){.chat-header{padding:var(--spacing-xs) var(--spacing-sm)}.chat-title{font-size:.95rem}.chat-message-bubble{padding:var(--spacing-xs) var(--spacing-sm)}.chat-message-text{font-size:.875rem}.chat-input-container{padding:var(--spacing-xs);gap:var(--spacing-xs)}.chat-send-btn{width:40px;height:40px;min-width:40px;min-height:40px}}@media(min-width:768px)and (max-width:1023px){.chat-window.sidebar{max-height:300px}.chat-messages{max-height:200px}}@media(min-width:1536px){.chat-header{padding:var(--spacing-md) var(--spacing-lg)}.chat-title{font-size:1.15rem}.chat-messages{padding:var(--spacing-md) var(--spacing-lg)}.chat-message-bubble{padding:var(--spacing-sm) var(--spacing-lg)}.chat-message-text{font-size:1rem}.chat-input-container{padding:var(--spacing-md) var(--spacing-lg)}.chat-input{padding:var(--spacing-md);font-size:1rem}.chat-send-btn{width:48px;height:48px}}.player-list{display:flex;flex-direction:column;height:100%;overflow:hidden;background:var(--paper-bg)}.player-list.compact{flex-direction:row;flex-wrap:wrap;gap:var(--spacing-xs);height:auto;overflow:visible;justify-content:center}.player-list-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);border-bottom:2px solid var(--ink-blue);background:var(--highlighter-yellow);flex-shrink:0}.player-list-title{font-family:var(--font-title);font-weight:600;font-size:1rem;color:var(--ink-blue);margin:0}.player-list-count{font-family:var(--font-hand);font-size:.875rem;color:var(--ink-blue);padding:.125rem .5rem;background:var(--paper-bg);border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-xs)}.player-list-items{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:var(--spacing-sm);display:flex;flex-direction:column;gap:var(--spacing-sm);margin:0;list-style:none}.player-list-item,.player-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);background:var(--paper-bg);border-radius:var(--border-wobbly-sm);border:2px solid var(--paper-lines);transition:all .2s ease}.player-list-item:hover,.player-item:hover{background:var(--highlighter-yellow);border-color:var(--ink-blue)}.player-list-item.is-me,.player-item.self,.player-item.is-me{border-color:var(--ink-blue);background:var(--highlighter-yellow);box-shadow:2px 2px 0 var(--ink-blue)}.player-list-item.disconnected,.player-item.disconnected{opacity:.5}.player-list.compact .player-list-item,.player-list-item.compact{padding:var(--spacing-xs) var(--spacing-sm);background:var(--paper-bg);gap:var(--spacing-xs)}.player-avatar-container{position:relative;flex-shrink:0}.player-avatar{width:40px;height:40px;border-radius:50%;background:var(--ink-blue);display:flex;align-items:center;justify-content:center;font-weight:700;font-family:var(--font-title);font-size:1rem;color:var(--paper-bg);overflow:hidden;border:2px solid var(--ink-blue)}.player-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.player-avatar.placeholder{background:var(--paper-lines);color:var(--ink-blue)}.player-avatar.compact,.player-list.compact .player-avatar{width:24px;height:24px;font-size:.625rem}.player-status{position:absolute;bottom:0;right:0;width:12px;height:12px;border-radius:50%;border:2px solid var(--paper-bg);display:flex;align-items:center;justify-content:center}.player-status.online{background:var(--ink-green);color:var(--paper-bg)}.player-status.offline,.player-status.disconnected{background:var(--ink-red);color:var(--paper-bg)}.player-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.125rem}.player-name{display:flex;align-items:center;gap:var(--spacing-xs);font-weight:600;font-family:var(--font-hand);font-size:.9375rem;color:var(--ink-blue);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-me-tag{font-size:.75rem;font-weight:400;color:var(--ink-blue);opacity:.6}.player-host-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.125rem .5rem;background:var(--highlighter-yellow);border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-xs);font-size:.625rem;font-weight:700;font-family:var(--font-title);color:var(--ink-blue);text-transform:uppercase;letter-spacing:.05em}.host-icon{color:var(--ink-blue);flex-shrink:0}.player-badges{display:flex;gap:.25rem;margin-top:.125rem}.player-badge{padding:.125rem .375rem;background:var(--highlighter-yellow);border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-xs);font-size:.625rem;font-weight:700;color:var(--ink-blue)}.player-badge.host{background:var(--highlighter-yellow);border-color:var(--ink-blue);color:var(--ink-blue)}.player-badge.you{background:var(--highlighter-green);border-color:var(--ink-green);color:var(--ink-green)}.player-score{display:flex;align-items:baseline;gap:.25rem;margin-left:auto;padding-right:.5rem}.player-score-value{font-weight:700;font-size:1rem;font-family:var(--font-hand);color:var(--ink-blue)}.player-score-label{font-size:.75rem;font-family:var(--font-hand);color:var(--ink-blue);opacity:.6}.player-score-compact{font-weight:700;font-size:.75rem;font-family:var(--font-hand);color:var(--ink-blue);margin-left:auto;padding:.125rem .375rem;background:var(--highlighter-yellow);border:1px solid var(--ink-blue);border-radius:var(--border-wobbly-xs)}@media(max-width:767px){.chat-window.floating{right:var(--spacing-sm);left:var(--spacing-sm);bottom:var(--spacing-sm);width:auto;max-height:50vh}.chat-input{font-size:16px}.player-avatar{width:36px;height:36px;font-size:.875rem}}@media(max-width:1023px)and (orientation:landscape){.chat-window.floating{max-height:40vh;width:280px}.chat-messages{max-height:30vh}.player-list-items{max-height:25vh}.player-avatar{width:32px;height:32px;font-size:.75rem}.player-list-item,.player-item{padding:var(--spacing-xs) var(--spacing-sm)}}@keyframes playerEnter{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}.player-list-item,.player-item{animation:playerEnter .25s ease-out backwards}.player-list-item:nth-child(1){animation-delay:.05s}.player-list-item:nth-child(2){animation-delay:.1s}.player-list-item:nth-child(3){animation-delay:.15s}.player-list-item:nth-child(4){animation-delay:.2s}.player-list-item:nth-child(5){animation-delay:.25s}.player-list-item:nth-child(6){animation-delay:.3s}.player-list-item:nth-child(7){animation-delay:.35s}.player-list-item:nth-child(8){animation-delay:.4s}.player-list-item:focus-visible,.player-item:focus-visible{outline:2px solid var(--gb-cyan);outline-offset:2px;background:#00d9ff26}.player-list-item:active,.player-item:active{transform:scale(.98);background:#33415599}.player-list-item.is-me,.player-item.is-me{box-shadow:0 0 12px #00d9ff40,inset 0 1px #00d9ff26}.player-list-item.disconnected,.player-item.disconnected{filter:grayscale(.5)}.player-list-item.disconnected .player-avatar,.player-item.disconnected .player-avatar{border-color:#ef44444d}@keyframes statusPulse{0%,to{box-shadow:0 0 #22c55e66}50%{box-shadow:0 0 0 4px #22c55e00}}.player-status.online{animation:statusPulse 2s ease-in-out infinite}.player-status.offline{animation:none}@keyframes hostCrownShimmer{0%,to{filter:drop-shadow(0 0 2px rgba(233,69,96,.4))}50%{filter:drop-shadow(0 0 6px rgba(233,69,96,.8))}}.player-host-badge{animation:hostCrownShimmer 2.5s ease-in-out infinite}.player-host-badge svg,.host-icon{animation:hostCrownShimmer 2s ease-in-out infinite}.player-list-item:hover .player-host-badge{background:linear-gradient(135deg,#e9456066,#e9456033);transform:scale(1.05);transition:all .2s ease}@media(min-width:768px)and (max-width:1023px){.player-list-header{padding:var(--spacing-sm)}.player-list-title{font-size:.9375rem}.player-list-items{padding:var(--spacing-xs);gap:var(--spacing-xs)}.player-list-item,.player-item{padding:var(--spacing-xs) var(--spacing-sm)}.player-avatar{width:36px;height:36px;font-size:.875rem}.player-name{font-size:.875rem}.player-host-badge{padding:.1rem .375rem;font-size:.5625rem}}@media(max-width:374px){.player-list-header{padding:var(--spacing-xs) var(--spacing-sm)}.player-list-title{font-size:.8125rem}.player-list-count{font-size:.75rem;padding:.1rem .375rem}.player-list-items{padding:var(--spacing-xs);gap:6px}.player-list-item,.player-item{padding:6px 8px;gap:6px}.player-avatar{width:32px;height:32px;font-size:.75rem;border-width:1px}.player-status{width:10px;height:10px;border-width:1.5px}.player-name{font-size:.8125rem}.player-me-tag{font-size:.625rem}.player-host-badge{padding:.1rem .25rem;font-size:.5rem;gap:.125rem}.player-host-badge svg{width:8px;height:8px}.player-list.compact .player-avatar,.player-avatar.compact{width:20px;height:20px;font-size:.5rem}}@media(min-width:1536px){.player-list-header{padding:var(--spacing-md)}.player-list-title{font-size:1.125rem}.player-list-count{font-size:1rem;padding:.25rem .625rem}.player-list-items{padding:var(--spacing-md);gap:var(--spacing-md)}.player-list-item,.player-item{padding:var(--spacing-sm) var(--spacing-md);gap:var(--spacing-md)}.player-avatar{width:48px;height:48px;font-size:1.125rem;border-width:3px}.player-status{width:14px;height:14px;border-width:2.5px}.player-status svg{width:8px;height:8px}.player-name{font-size:1.0625rem}.player-me-tag{font-size:.875rem}.player-host-badge{padding:.25rem .625rem;font-size:.6875rem;gap:.375rem}.player-host-badge svg{width:14px;height:14px}}@media(max-width:926px)and (orientation:landscape){.player-list{max-height:100%}.player-list-header{padding:var(--spacing-xs) var(--spacing-sm);min-height:36px}.player-list-title{font-size:.8125rem}.player-list-items{padding:var(--spacing-xs);gap:4px}.player-list-item,.player-item{padding:4px 8px;gap:6px}.player-avatar{width:28px;height:28px;font-size:.6875rem}.player-status{width:8px;height:8px;border-width:1px}.player-name{font-size:.75rem}.player-host-badge{padding:.05rem .25rem;font-size:.5rem}}@supports (padding-bottom: env(safe-area-inset-bottom)){.mobile-drawer .player-list-items{padding-bottom:max(var(--spacing-sm),env(safe-area-inset-bottom))}}.mobile-menu-btn{display:none;align-items:center;justify-content:center;width:44px;height:44px;min-width:44px;min-height:44px;background:#33415580;border:2px solid var(--panel-border);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;transition:all .2s ease}.mobile-menu-btn:hover{background:#00d9ff33;border-color:var(--gb-cyan)}@media(max-width:1023px){.mobile-menu-btn{display:flex}}.mobile-menu-overlay{position:fixed;inset:0;background:#000000b3;z-index:var(--z-mobile-menu-backdrop);opacity:0;visibility:hidden;transition:all .3s ease}.mobile-menu-overlay.open{opacity:1;visibility:visible}.mobile-menu{position:fixed;top:0;right:0;width:280px;max-width:80vw;height:100dvh;padding-top:env(safe-area-inset-top,0px);padding-right:env(safe-area-inset-right,0px);padding-bottom:env(safe-area-inset-bottom,0px);background:var(--bg-secondary);border-left:2px solid var(--gb-pink);z-index:var(--z-mobile-menu);transform:translate(100%);transition:transform .3s ease;display:flex;flex-direction:column}.mobile-menu.open{transform:translate(0)}.mobile-menu-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);border-bottom:1px solid var(--panel-border)}.mobile-menu-close{display:flex;align-items:center;justify-content:center;width:44px;height:44px;min-width:44px;min-height:44px;background:transparent;border:none;color:var(--text-secondary);cursor:pointer}.mobile-menu-content{flex:1;overflow-y:auto;padding:var(--spacing-md);-webkit-overflow-scrolling:touch}.mobile-menu-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-hand);font-size:1rem;width:100%;text-align:left;cursor:pointer;transition:all .2s ease}.mobile-menu-item:hover{background:#00d9ff1a}.mobile-menu-item.danger{color:var(--danger-400)}.mobile-menu-item.danger:hover{background:#ef44441a}.mobile-menu-badge{margin-left:auto;padding:.125rem .5rem;background:var(--gb-pink);border-radius:1rem;font-size:.75rem;font-weight:700;color:#fff}.mobile-game-menu-trigger{position:relative;display:flex;align-items:center}.mobile-game-menu-btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;min-width:44px;min-height:44px;background:var(--paper-bg);border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-sm);color:var(--ink-blue);cursor:pointer;transition:all .15s ease;box-shadow:2px 2px #1a4b8c66}.mobile-game-menu-btn:hover{background:var(--highlighter-yellow);transform:translate(-1px,-1px);box-shadow:3px 3px #1a4b8c66}.mobile-game-menu-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 4px;background:var(--ink-red);border-radius:9px;font-size:.625rem;font-weight:700;color:var(--paper-bg);display:flex;align-items:center;justify-content:center}.mobile-game-menu-backdrop{position:fixed;inset:0;background:#00000080;z-index:var(--z-mobile-menu-backdrop)}.mobile-game-menu-panel{position:fixed;top:calc(var(--header-height-mobile) + 8px);right:12px;width:min(240px,calc(100vw - 24px));max-height:calc(100dvh - var(--header-height-mobile) - 24px);padding-right:env(safe-area-inset-right,0px);background:var(--paper-bg);border:3px solid var(--ink-blue);border-radius:var(--border-wobbly-md);box-shadow:4px 4px #1a4b8c66;overflow:hidden;display:flex;flex-direction:column;z-index:var(--z-mobile-menu)}.mobile-game-menu-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);border-bottom:2px dashed var(--paper-lines)}.mobile-game-menu-title{font-family:var(--font-title);font-weight:600;font-size:.875rem;color:var(--ink-blue)}.mobile-game-menu-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:none;border-radius:var(--border-wobbly-xs);color:var(--ink-blue);cursor:pointer;transition:all .15s ease}.mobile-game-menu-close:hover{background:var(--highlighter-pink);color:var(--ink-red)}.mobile-game-menu-items{flex:1;overflow-y:auto;padding:var(--spacing-xs);-webkit-overflow-scrolling:touch}.mobile-game-menu-item{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-sm);background:transparent;border:none;border-radius:var(--border-wobbly-xs);text-align:left;cursor:pointer;transition:all .15s ease}.mobile-game-menu-item:hover{background:var(--highlighter-yellow)}.mobile-game-menu-item:disabled{opacity:.5;cursor:not-allowed}.mobile-game-menu-item.danger:hover{background:var(--highlighter-pink)}.mobile-game-menu-item.highlight{background:#fff7c880}.mobile-game-menu-item.highlight:hover{background:var(--highlighter-yellow)}.mobile-game-menu-item-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:#1a4b8c1a;border-radius:var(--border-wobbly-xs);color:var(--ink-blue);flex-shrink:0}.mobile-game-menu-item-icon.highlight{background:var(--highlighter-yellow);color:var(--ink-blue)}.mobile-game-menu-item-icon.danger{background:var(--highlighter-pink);color:var(--ink-red)}.mobile-game-menu-item-content{flex:1;min-width:0}.mobile-game-menu-item-label{display:flex;align-items:center;gap:var(--spacing-sm);font-family:var(--font-hand);font-size:.875rem;font-weight:600;color:var(--ink-blue)}.mobile-game-menu-item .danger .mobile-game-menu-item-label{color:var(--ink-red)}.mobile-game-menu-item-badge{padding:0 6px;height:16px;background:var(--ink-red);border-radius:8px;font-size:.625rem;font-weight:700;color:var(--paper-bg);display:flex;align-items:center;justify-content:center}.mobile-game-menu-item-sublabel{font-family:var(--font-hand);font-size:.75rem;color:var(--ink-blue);opacity:.7;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(orientation:landscape)and (max-width:1023px){.mobile-game-menu-panel{top:calc(var(--header-height-mobile) + 4px);max-height:calc(100dvh - var(--header-height-mobile) - 16px)}.mobile-game-menu-items{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-xs);padding:var(--spacing-xs)}.mobile-game-menu-item{padding:var(--spacing-xs);font-size:.75rem}.mobile-game-menu-item-icon{width:24px;height:24px}.mobile-game-menu-item-sublabel{display:none}}.mobile-game-menu-btn:focus-visible{outline:2px solid var(--ink-blue);outline-offset:2px}.mobile-game-menu-close:focus-visible{outline:2px solid var(--ink-blue);outline-offset:2px}.mobile-game-menu-item:focus-visible{outline:2px solid var(--ink-blue);outline-offset:-2px;background:var(--highlighter-yellow)}.mobile-game-menu-btn:active{transform:scale(.95);background:var(--highlighter-yellow)}.mobile-game-menu-close:active{transform:scale(.9);background:var(--highlighter-pink)}.mobile-game-menu-item:active:not(:disabled){transform:scale(.98);background:var(--highlighter-yellow)}.mobile-game-menu-item.danger:active{background:var(--highlighter-pink)}.mobile-game-menu-item.highlight:active{background:var(--highlighter-yellow)}@keyframes menuBadgePulse{0%,to{transform:scale(1);box-shadow:0 0 #e9456080}50%{transform:scale(1.1);box-shadow:0 0 8px 2px #e9456000}}.mobile-game-menu-badge{animation:menuBadgePulse 2s ease-in-out infinite}.mobile-game-menu-item-badge{animation:menuBadgePulse 2s ease-in-out infinite;animation-delay:.5s}@keyframes menuItemSlideIn{0%{opacity:0;transform:translate(10px)}to{opacity:1;transform:translate(0)}}.mobile-game-menu-item{animation:menuItemSlideIn .2s ease-out backwards}.mobile-game-menu-item:nth-child(1){animation-delay:.02s}.mobile-game-menu-item:nth-child(2){animation-delay:.04s}.mobile-game-menu-item:nth-child(3){animation-delay:.06s}.mobile-game-menu-item:nth-child(4){animation-delay:.08s}.mobile-game-menu-item:nth-child(5){animation-delay:.1s}.mobile-game-menu-item:nth-child(6){animation-delay:.12s}.mobile-game-menu-item:nth-child(7){animation-delay:.14s}.mobile-game-menu-item:nth-child(8){animation-delay:.16s}.mobile-game-menu-item:hover .mobile-game-menu-item-icon{background:#1a4b8c33;color:var(--ink-blue);transition:all .15s ease}.mobile-game-menu-item.danger:hover .mobile-game-menu-item-icon{background:var(--highlighter-pink);color:var(--ink-red)}.mobile-game-menu-item.highlight:hover .mobile-game-menu-item-icon{background:var(--highlighter-yellow);color:var(--ink-blue)}@media(max-width:374px){.mobile-game-menu-btn{width:40px;height:40px;min-width:40px;min-height:40px}.mobile-game-menu-badge{min-width:16px;height:16px;font-size:.5625rem;top:-3px;right:-3px}.mobile-game-menu-panel{width:calc(100vw - 16px);right:8px;max-height:calc(100dvh - var(--header-height-mobile) - 16px)}.mobile-game-menu-header{padding:var(--spacing-xs) var(--spacing-sm)}.mobile-game-menu-title{font-size:.75rem}.mobile-game-menu-close{width:28px;height:28px}.mobile-game-menu-items{padding:4px}.mobile-game-menu-item{padding:6px 8px;gap:6px}.mobile-game-menu-item-icon{width:24px;height:24px}.mobile-game-menu-item-icon svg{width:12px;height:12px}.mobile-game-menu-item-label{font-size:.75rem}.mobile-game-menu-item-badge{height:14px;padding:0 4px;font-size:.5625rem}.mobile-game-menu-item-sublabel{font-size:.625rem}}@supports (padding-right: env(safe-area-inset-right)){.mobile-game-menu-panel{padding-right:max(0px,env(safe-area-inset-right))}.mobile-game-menu-items{padding-bottom:max(var(--spacing-xs),env(safe-area-inset-bottom))}}.mobile-drawer-backdrop,.mobile-drawer-overlay{position:fixed;inset:0;background:#00000080;z-index:var(--z-chat-drawer-backdrop)}.mobile-drawer-overlay{opacity:0;visibility:hidden;transition:all .3s ease}.mobile-drawer-overlay.open{opacity:1;visibility:visible}.mobile-drawer{position:fixed;top:0;right:0;bottom:0;width:min(320px,85vw);max-height:100dvh;padding-bottom:env(safe-area-inset-bottom,0px);padding-right:env(safe-area-inset-right,0px);background:var(--paper-bg);border-left:3px solid var(--ink-blue);box-shadow:-4px 0 #1a4b8c66;z-index:var(--z-mobile-drawer);display:flex;flex-direction:column}.mobile-drawer:not([style*=transform]){transform:translate(100%);transition:transform .3s ease}.mobile-drawer.open:not([style*=transform]){transform:translate(0)}.mobile-drawer-handle{display:flex;justify-content:center;padding:var(--spacing-sm)}.mobile-drawer-handle-bar{width:40px;height:4px;background:var(--ink-blue);border-radius:2px;opacity:.5}.mobile-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);border-bottom:2px dashed var(--paper-lines);background:transparent;flex-shrink:0}.mobile-drawer-title{display:flex;align-items:center;gap:var(--spacing-sm);font-family:var(--font-title);font-weight:600;font-size:1.125rem;color:var(--ink-blue)}.mobile-drawer-title svg{color:var(--ink-blue)}.mobile-drawer-close{display:flex;align-items:center;justify-content:center;width:44px;height:44px;min-width:44px;min-height:44px;background:transparent;border:none;border-radius:var(--border-wobbly-xs);color:var(--ink-blue);cursor:pointer;transition:all .15s ease}.mobile-drawer-close:hover{background:var(--highlighter-pink);color:var(--ink-red)}.mobile-drawer-content{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}.mobile-drawer-backdrop{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.mobile-drawer-close:focus-visible{outline:2px solid var(--ink-blue);outline-offset:2px;background:var(--highlighter-yellow)}.mobile-drawer-close:active{transform:scale(.9);background:var(--highlighter-pink)}.mobile-drawer-title svg{filter:none}.mobile-drawer-handle-bar{transition:all .15s ease}.mobile-drawer:hover .mobile-drawer-handle-bar{background:var(--ink-blue);opacity:1;width:60px}@keyframes drawerContentFadeIn{0%{opacity:0;transform:translate(10px)}to{opacity:1;transform:translate(0)}}.mobile-drawer-content>*{animation:drawerContentFadeIn .25s ease-out .1s backwards}.mobile-drawer{box-shadow:-4px 0 #1a4b8c66}@media(max-width:374px){.mobile-drawer{width:100vw;border-left:none;border-radius:0}.mobile-drawer-header{padding:var(--spacing-sm)}.mobile-drawer-title{font-size:1rem;gap:var(--spacing-xs)}.mobile-drawer-title svg{width:18px;height:18px}.mobile-drawer-close{width:40px;height:40px;min-width:40px;min-height:40px}}@media(max-height:500px)and (orientation:landscape){.mobile-drawer{width:min(240px,60vw)}.mobile-drawer-header{padding:var(--spacing-xs) var(--spacing-sm);min-height:40px}.mobile-drawer-title{font-size:.875rem}.mobile-drawer-title svg{width:16px;height:16px}.mobile-drawer-close{width:36px;height:36px;min-width:36px;min-height:36px}}@supports (padding-top: env(safe-area-inset-top)){.mobile-drawer{padding-top:env(safe-area-inset-top)}.mobile-drawer-header{padding-top:max(var(--spacing-md),env(safe-area-inset-top))}}.mobile-overlay-backdrop{position:fixed;inset:0;background:#000000d9;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:9997}.mobile-overlay-modal{position:fixed;inset:0;background:var(--bg-primary);z-index:9998;display:flex;flex-direction:column;padding-top:env(safe-area-inset-top,0px);padding-bottom:env(safe-area-inset-bottom,0px);padding-left:env(safe-area-inset-left,0px);padding-right:env(safe-area-inset-right,0px)}.mobile-overlay-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--panel-border);background:var(--bg-secondary);flex-shrink:0;min-height:56px}.mobile-overlay-title{display:flex;align-items:center;gap:var(--spacing-sm);font-family:var(--font-title);font-weight:600;font-size:1.25rem;color:var(--text-primary)}.mobile-overlay-title svg{color:var(--gb-cyan);filter:drop-shadow(0 0 4px rgba(0,217,255,.4))}.mobile-overlay-close{display:flex;align-items:center;justify-content:center;width:48px;height:48px;min-width:48px;min-height:48px;background:#e945601a;border:1px solid rgba(233,69,96,.3);border-radius:var(--radius-md);color:var(--gb-pink);cursor:pointer;transition:all .2s ease}.mobile-overlay-close:hover{background:#e9456033;border-color:var(--gb-pink)}.mobile-overlay-close:active{transform:scale(.95);background:#e945604d}.mobile-overlay-close:focus-visible{outline:2px solid var(--gb-cyan);outline-offset:2px}.mobile-overlay-content{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;display:flex;flex-direction:column}.mobile-overlay-content>*{flex:1;min-height:0}.mobile-overlay-content .chat-container{height:100%;max-height:none}.mobile-overlay-content .chat-window{width:100%;height:100%;max-height:none}.mobile-overlay-content .chat-messages{max-height:none}.mobile-overlay-content .player-list{padding:var(--spacing-md)}.mobile-overlay-content .player-list-items{gap:var(--spacing-sm)}.mobile-overlay-content .mobile-video-grid{height:100%;padding:var(--spacing-md)}@keyframes overlayContentFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.mobile-overlay-content>*{animation:overlayContentFadeIn .2s ease-out}@media(max-width:374px){.mobile-overlay-header{padding:var(--spacing-sm) var(--spacing-md);min-height:48px}.mobile-overlay-title{font-size:1.125rem;gap:var(--spacing-xs)}.mobile-overlay-title svg{width:18px;height:18px}.mobile-overlay-close{width:44px;height:44px;min-width:44px;min-height:44px}}@media(max-height:500px)and (orientation:landscape){.mobile-overlay-header{padding:var(--spacing-xs) var(--spacing-md);min-height:44px}.mobile-overlay-title{font-size:1rem}.mobile-overlay-close{width:40px;height:40px;min-width:40px;min-height:40px}.mobile-overlay-content .player-list{padding:var(--spacing-sm)}}@media(max-width:767px){:root{--header-height: var(--header-height-mobile)}.lobby-content,.game-content{flex-direction:column}.lobby-sidebar,.game-sidebar{display:none}.main-content,.lobby-main,.game-main{padding:var(--spacing-sm)}.card{padding:1rem}.video-filmstrip{--filmstrip-height: 100px}.video-feed{width:100px}}@media(min-width:768px)and (max-width:1023px){:root{--sidebar-width: 280px}.lobby-sidebar,.game-sidebar{display:none}}@media(min-width:1024px){.mobile-menu-btn{display:none}.lobby-sidebar,.game-sidebar{display:flex}}@media(min-width:1536px){:root{--sidebar-width: 384px}.video-feed{width:180px}}@media(max-width:1023px)and (orientation:landscape){:root{--filmstrip-height: 60px;--filmstrip-height-collapsed: 32px}.game-header{height:var(--header-height-mobile);padding:0 var(--spacing-sm)}.header-logo{font-size:.875rem}.video-filmstrip.expanded{height:60px}.video-filmstrip.collapsed{height:32px}.video-feed{width:80px}.mobile-drawer{width:min(280px,70vw)}.mobile-drawer-content{max-height:calc(100dvh - 80px)}.mobile-game-menu-panel{max-height:calc(100dvh - 60px);width:min(280px,calc(100vw - 24px))}.mobile-game-menu-items{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-xs)}.mobile-game-menu-item{padding:var(--spacing-xs) var(--spacing-sm);font-size:.8125rem}.mobile-game-menu-item-icon{width:24px;height:24px}.mobile-game-menu-item-sublabel{display:none}.mobile-menu-content{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-sm)}.mobile-menu-item{padding:var(--spacing-sm);font-size:.875rem}}@media(max-height:500px)and (orientation:landscape){:root{--filmstrip-height: 50px}.game-header{height:var(--header-height-mobile)}.video-filmstrip.expanded{height:50px}.video-feed{width:70px}.settings-modal{max-height:95vh;max-width:calc(100vw - 2 * var(--spacing-md))}}@media(min-width:768px)and (max-width:1023px)and (orientation:landscape){.lobby-content,.game-content{flex-direction:row}.mobile-drawer{max-height:60vh}}@media(max-width:374px){:root{--spacing-md: .75rem;--spacing-lg: 1rem}.player-avatar{width:36px;height:36px}.card{min-width:260px;padding:var(--spacing-sm)}.home-card{min-width:260px;padding:var(--spacing-md)}.input,input,select,textarea{font-size:16px}.chat-message{padding:var(--spacing-xs)}.player-name,.header-logo{font-size:.875rem}.video-feed{width:70px}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes bounceIn{0%{opacity:0;transform:scale(.8) translateY(20px)}50%{transform:scale(1.05) translateY(-5px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes pulseGlow{0%,to{box-shadow:0 0 20px #00d9ff66}50%{box-shadow:0 0 40px #00d9ffcc}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}@keyframes wobble{0%,to{transform:rotate(0)}25%{transform:rotate(.5deg)}75%{transform:rotate(-.5deg)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear infinite}.home-header{position:fixed;top:0;left:0;right:0;height:var(--header-height);display:flex;align-items:center;justify-content:space-between;padding:0 var(--spacing-lg);background:var(--paper-bg);border-bottom:3px solid var(--ink-blue);box-shadow:0 2px 0 var(--ink-blue);z-index:var(--z-mobile-nav)}.home-header-logo{display:flex;align-items:center;gap:var(--spacing-sm);text-decoration:none;color:inherit}.home-header-mascot{width:36px;height:36px;-o-object-fit:contain;object-fit:contain;filter:drop-shadow(0 2px 8px rgba(233,69,96,.3))}.home-header-text{display:flex;flex-direction:column;gap:0;line-height:1.1}.home-header-title{font-family:var(--font-title);font-size:1.25rem;color:var(--ink-blue)}.home-header-accent{color:var(--ink-blue);background:var(--highlighter-yellow);border-radius:.3em .8em;padding:.1em .3em}.home-header-branding{display:flex;align-items:baseline;gap:.1em;font-family:var(--font-marker);font-size:.7rem;letter-spacing:.02em}.home-header-by{color:var(--ink-blue);opacity:.6;font-size:.9em}.home-header-game{color:var(--ink-red)}.home-header-buddies{color:var(--ink-blue)}.home-header-io{color:var(--ink-blue);opacity:.6;font-size:.9em}.home-header-settings-btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:var(--paper-bg);border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-sm);color:var(--ink-blue);cursor:pointer;transition:all .2s ease;box-shadow:2px 2px 0 var(--ink-blue)}.home-header-settings-btn:hover{background:var(--highlighter-yellow);transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--ink-blue)}.home-header-hamburger{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:var(--paper-bg);border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-sm);color:var(--ink-blue);cursor:pointer;transition:all .2s ease;box-shadow:2px 2px 0 var(--ink-blue)}.home-header-hamburger:hover{background:var(--highlighter-yellow);transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--ink-blue)}.home-header-menu-backdrop{position:fixed;inset:0;background:#00000080;z-index:var(--z-mobile-menu-backdrop)}.home-header-menu{position:fixed;top:var(--spacing-md);right:var(--spacing-md);width:min(280px,calc(100vw - var(--spacing-xl)));background:var(--paper-bg);border:3px solid var(--ink-blue);border-radius:var(--border-wobbly-md);box-shadow:4px 4px 0 var(--ink-blue);z-index:var(--z-mobile-menu);overflow:hidden}.home-header-menu-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);border-bottom:2px solid var(--ink-blue);background:var(--highlighter-yellow)}.home-header-menu-title{font-family:var(--font-title);font-size:1.1rem;color:var(--ink-blue)}.home-header-menu-close{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:transparent;border:2px solid transparent;border-radius:var(--border-wobbly-xs);color:var(--ink-blue);cursor:pointer;transition:all .2s ease}.home-header-menu-close:hover{background:var(--highlighter-pink);border-color:var(--ink-red);color:var(--ink-red)}.home-header-menu-items{padding:var(--spacing-sm)}.home-header-menu-item{display:flex;align-items:center;gap:var(--spacing-md);width:100%;padding:var(--spacing-md);background:transparent;border:2px solid transparent;border-radius:var(--border-wobbly-sm);color:var(--ink-blue);cursor:pointer;transition:all .2s ease;text-align:left}.home-header-menu-item:hover{background:var(--highlighter-yellow);border-color:var(--ink-blue)}.home-header-menu-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--paper-bg);border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-xs);color:var(--ink-blue)}.home-header-menu-content{display:flex;flex-direction:column;gap:2px}.home-header-menu-label{font-family:var(--font-hand);font-size:1rem;color:var(--ink-blue)}.home-header-menu-sublabel{font-family:var(--font-hand);font-size:.8rem;color:var(--ink-blue);opacity:.6}.home-checkbox-label{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) 0;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.home-checkbox{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:20px;height:20px;background:var(--paper-bg);border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-xs);cursor:pointer;transition:all .2s ease;flex-shrink:0}.home-checkbox:checked{background:var(--ink-blue);border-color:var(--ink-blue)}.home-checkbox:checked:after{content:"✓";display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:var(--paper-bg);font-size:14px;font-weight:700}.home-checkbox:focus{outline:none;box-shadow:0 0 0 3px #1a4b8c33}.home-checkbox-text{font-family:var(--font-hand);font-size:.9rem;color:var(--ink-blue)}.home-mp-badge{display:flex;align-items:center;justify-content:center;width:-moz-fit-content;width:fit-content;margin:0 auto var(--spacing-md);gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-lg);background:#1a4b8c14;border:1px solid rgba(26,75,140,.2);border-radius:var(--radius-full);font-family:var(--font-hand);font-size:.9rem;animation:fadeInUp .6s ease-out .15s backwards}.home-mp-badge svg{color:var(--accent-color);flex-shrink:0}.home-mp-badge-count{color:var(--accent-color);font-weight:600}.home-mp-badge-sep{color:#1a4b8c4d}.home-mp-badge-category{color:#1a4b8cb3}.home-steps{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg);animation:fadeInUp .6s ease-out .25s backwards}.home-step{display:flex;align-items:center;gap:var(--spacing-xs)}.home-step-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:rgba(var(--accent-color-rgb),.15);border-radius:var(--radius-sm);color:var(--accent-color);flex-shrink:0}.home-step-text{font-family:var(--font-hand);font-size:.85rem;color:#1a4b8cb3;white-space:nowrap}.home-step-arrow{color:#1a4b8c4d;font-size:1rem;flex-shrink:0}.home-tip-banner{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);margin-top:var(--spacing-lg);padding:var(--spacing-sm) var(--spacing-lg);background:var(--highlighter-green);border:2px solid var(--ink-green);border-radius:var(--border-wobbly-sm);color:var(--ink-green);font-family:var(--font-hand);font-size:.9rem;animation:fadeInUp .6s ease-out .4s backwards}.home-tip-banner svg{flex-shrink:0}.home-gb-banner{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);margin-top:calc(var(--header-height) + var(--spacing-md));margin-bottom:calc(-1 * var(--spacing-lg));padding:var(--spacing-xs) var(--spacing-md);background:var(--highlighter-yellow);border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-sm);font-family:var(--font-hand);font-size:.85rem;animation:fadeInUp .4s ease-out}.home-gb-banner svg{flex-shrink:0;color:var(--ink-blue)}.home-gb-banner span{color:var(--ink-blue);font-weight:600}@media(max-width:767px){.home-header{height:var(--header-height-mobile);padding:0 var(--spacing-md)}.home-header-mascot{width:28px;height:28px}.home-header-title{font-size:1rem}.home-header-branding{font-size:.6rem}.home-tip-banner{font-size:.8rem;padding:var(--spacing-xs) var(--spacing-md)}.home-gb-banner{margin-top:calc(var(--header-height-mobile) + var(--spacing-sm));font-size:.75rem;padding:var(--spacing-xs) var(--spacing-sm)}.home-steps,.home-tagline,.home-gb-branding{display:none}.home-mascot{width:60px}.home-title{font-size:clamp(1.5rem,6vw,2rem)}.home-mp-badge{padding:4px 12px;font-size:.8rem;margin-bottom:8px}.home-hero{gap:6px;margin-bottom:8px}.home-cards-wrapper{margin-top:0}.home-card{padding:12px 16px}.home-form .form-group{margin-bottom:8px}}.home-page{min-height:100dvh;display:flex;flex-direction:column;align-items:center;padding:clamp(1rem,3dvh,2.5rem);padding-top:calc(var(--header-height) + clamp(.75rem,2dvh,2rem));padding-bottom:max(clamp(1rem,3dvh,2.5rem),env(safe-area-inset-bottom));overflow-y:auto;background-color:var(--paper-bg);background-image:linear-gradient(90deg,transparent 47px,var(--paper-margin) 47px,var(--paper-margin) 49px,transparent 49px),repeating-linear-gradient(to bottom,transparent 0px,transparent 31px,var(--paper-lines) 31px,var(--paper-lines) 32px)}.home-hero{display:flex;flex-direction:column;align-items:center;text-align:center;gap:clamp(.25rem,1.5dvh,1rem);margin-bottom:clamp(.5rem,2dvh,2rem);animation:fadeInUp .6s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.home-mascot{width:clamp(60px,min(20vw,14dvh),140px);height:auto;filter:drop-shadow(0 8px 24px rgba(233,69,96,.3));animation:mascotBounce 3s ease-in-out infinite}@keyframes mascotBounce{0%,to{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-8px) rotate(2deg)}}.home-title{font-family:var(--font-title);font-size:clamp(2rem,8vw,3.5rem);font-weight:700;color:var(--ink-blue);line-height:1.1}.home-title-accent{color:var(--ink-blue);background:var(--highlighter-yellow);border-radius:.3em .8em;padding:.1em .3em}.home-tagline{font-family:var(--font-hand);font-size:clamp(1rem,3vw,1.35rem);color:var(--ink-blue);opacity:.8;max-width:400px;line-height:1.4}.home-gb-branding{display:flex;align-items:baseline;gap:.15em;font-family:var(--font-marker);font-size:clamp(.9rem,2.5vw,1.1rem);letter-spacing:.02em}.home-gb-by{color:var(--ink-blue);opacity:.6;font-size:.85em}.home-gb-game{color:var(--ink-red)}.home-gb-buddies{color:var(--ink-blue)}.home-gb-io{color:var(--ink-blue);opacity:.6;font-size:.85em}.home-error{width:100%;max-width:400px;padding:var(--spacing-md);margin-bottom:var(--spacing-lg);background:var(--highlighter-pink);border:2px solid var(--ink-red);border-radius:var(--border-wobbly-md);color:var(--ink-red);text-align:center;font-family:var(--font-hand);animation:shake .4s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-6px)}40%,80%{transform:translate(6px)}}.home-tabs{display:none;width:100%;max-width:400px;margin-bottom:var(--spacing-lg);background:var(--paper-bg);border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-md);padding:var(--spacing-xs);gap:var(--spacing-xs)}.home-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);min-height:44px;padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:2px solid transparent;border-radius:var(--border-wobbly-sm);color:var(--ink-blue);font-family:var(--font-hand);font-size:1rem;cursor:pointer;transition:all .2s ease}.home-tab:hover{background:var(--highlighter-yellow)}.home-tab.active{background:var(--highlighter-yellow);color:var(--ink-blue);font-weight:600;border-color:var(--ink-blue);box-shadow:2px 2px 0 var(--ink-blue)}.home-cards-wrapper{display:flex;justify-content:center;align-items:flex-start;width:100%;position:relative}.home-cards-wrapper .tutorial-sidebar{position:fixed;right:2rem;top:var(--tutorial-top, 50%);transform:translateY(0)}@media(max-width:1400px){.home-cards-wrapper .tutorial-sidebar{display:none}}.home-cards{display:flex;gap:var(--spacing-lg);flex-wrap:wrap;justify-content:center;max-width:800px;width:100%}.home-card{flex:1;min-width:280px;max-width:360px;padding:clamp(1rem,3dvh,2.5rem);background:var(--paper-bg);border:3px solid var(--ink-blue);border-radius:var(--border-wobbly-lg);text-align:center;transition:all .3s ease;animation:fadeInUp .6s ease-out backwards;box-shadow:4px 4px 0 var(--ink-blue)}.home-card:nth-child(1){animation-delay:.1s}.home-card:nth-child(2){animation-delay:.2s}.home-card:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--ink-blue)}.home-card .card-header{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.home-card .card-header h2{font-family:var(--font-title);font-size:1.5rem;color:var(--ink-blue);margin:0}.home-card .card-header svg{color:var(--ink-blue)}.home-card .card-description{font-family:var(--font-hand);font-size:.95rem;color:var(--ink-blue);opacity:.8;margin-bottom:var(--spacing-lg);line-height:1.4}.home-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.home-input{width:100%;padding:var(--spacing-md);background:var(--paper-bg);border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-sm);color:var(--ink-blue);font-family:var(--font-hand);font-size:16px;text-align:center;transition:all .2s ease}.home-input::-moz-placeholder{color:var(--ink-blue);opacity:.5}.home-input::placeholder{color:var(--ink-blue);opacity:.5}.home-input:focus{outline:none;border-color:var(--ink-blue);box-shadow:0 0 0 3px #1a4b8c33}.home-btn{width:100%;min-height:48px;padding:var(--spacing-md) var(--spacing-lg);border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-sm);font-family:var(--font-marker);font-size:1.1rem;cursor:pointer;transition:all .2s ease}.home-btn.primary{background:var(--ink-blue);color:var(--paper-bg);box-shadow:3px 3px #1a4b8c80}.home-btn.primary:hover:not(:disabled){transform:translate(-2px,-2px);box-shadow:5px 5px #1a4b8c80}.home-btn.secondary{background:var(--highlighter-yellow);color:var(--ink-blue);box-shadow:3px 3px 0 var(--ink-blue)}.home-btn.secondary:hover:not(:disabled){transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--ink-blue)}.home-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.home-how-to-play{display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);margin-top:var(--spacing-xl);padding:var(--spacing-sm) var(--spacing-lg);min-height:44px;background:var(--paper-bg);border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-sm);color:var(--ink-blue);font-family:var(--font-hand);font-size:1rem;cursor:pointer;transition:all .2s ease}.home-how-to-play:hover{background:var(--highlighter-yellow)}@media(min-width:1280px){.home-how-to-play{display:none}}.mobile-hidden{display:block}@media(max-width:767px){.home-page{padding:var(--spacing-md);padding-top:calc(var(--header-height-mobile) + var(--spacing-md))}.home-hero{gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.home-mascot{width:80px}.home-tabs{display:flex}.home-cards{flex-direction:column;align-items:center}.home-card{max-width:100%;padding:var(--spacing-lg)}.mobile-hidden{display:none!important}}@media(max-width:926px)and (orientation:landscape){.home-page{padding:var(--spacing-sm);padding-top:calc(var(--header-height-mobile) + var(--spacing-md));flex-direction:row;flex-wrap:wrap;justify-content:center;align-items:flex-start;gap:var(--spacing-md)}.home-hero{flex-direction:row;gap:var(--spacing-md);margin-bottom:0;width:100%;justify-content:center}.home-mascot{width:50px}.home-title{font-size:1.5rem}.home-tagline,.home-gb-branding{display:none}.home-tabs{display:flex;max-width:300px}.home-cards{flex-direction:row;flex-wrap:nowrap;gap:var(--spacing-md)}.home-card{min-width:240px;max-width:300px;padding:var(--spacing-md)}.home-card .card-description,.home-how-to-play{display:none}}@media(max-width:374px){.home-page{padding:var(--spacing-sm);padding-top:calc(var(--header-height-mobile) + var(--spacing-md))}.home-mascot{width:60px}.home-title{font-size:1.75rem}.home-card{padding:var(--spacing-md)}.home-btn{font-size:1rem}}@media(min-width:768px)and (max-width:1023px){.home-cards{flex-direction:row;max-width:700px}.home-card{min-width:300px;max-width:340px}}@media(min-width:1536px){.home-mascot{animation:mascotFloat 3s ease-in-out infinite}@keyframes mascotFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.home-cards{gap:var(--spacing-xl);max-width:900px}.home-card{min-width:380px}}.home-btn:active:not(:disabled){transform:translateY(1px)}.home-btn:focus-visible{outline:2px solid var(--gb-cyan);outline-offset:2px}.home-tab:focus-visible{outline:2px solid var(--gb-cyan);outline-offset:-2px}.home-tab:active{transform:scale(.98)}.home-input:focus-visible{outline:none}.home-how-to-play:focus-visible{outline:2px solid var(--gb-cyan);outline-offset:2px}.home-how-to-play:active{transform:scale(.98)}.home-btn.loading{position:relative;color:transparent}.home-btn.loading:after{content:"";position:absolute;width:20px;height:20px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:btnSpin .8s linear infinite}@keyframes btnSpin{to{transform:rotate(360deg)}}.home-page:before{display:none}.lobby-waiting-card{max-width:480px;margin:0 auto;padding:clamp(1rem,3dvh,2.5rem);background:var(--paper-bg);border:3px solid var(--ink-blue);border-radius:var(--border-wobbly-lg);text-align:center;box-shadow:4px 4px 0 var(--ink-blue)}@media(max-width:767px){.lobby-waiting-card{padding:var(--spacing-md) var(--spacing-sm);border-radius:var(--radius-lg)}}.lobby-waiting-header{margin-bottom:var(--spacing-lg)}@media(max-width:767px){.lobby-waiting-header{margin-bottom:var(--spacing-sm)}}.lobby-waiting-header h2{font-family:var(--font-title);font-size:1.5rem;color:var(--ink-blue);margin-bottom:var(--spacing-sm)}.lobby-player-count{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);color:var(--ink-blue);font-family:var(--font-hand)}.lobby-room-code-section{margin-bottom:var(--spacing-lg)}.lobby-room-label{color:var(--ink-blue);opacity:.7;margin-bottom:var(--spacing-sm)}.lobby-room-code-box{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--highlighter-yellow);border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-md)}.lobby-room-code{font-family:var(--font-marker);font-size:2rem;color:var(--ink-blue);letter-spacing:.25em}.lobby-copy-btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;min-width:44px;min-height:44px;background:var(--paper-bg);border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-sm);color:var(--ink-blue);cursor:pointer;transition:all .2s ease;box-shadow:2px 2px 0 var(--ink-blue)}.lobby-copy-btn:hover{background:var(--highlighter-green);transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--ink-blue)}.lobby-start-section{margin-top:var(--spacing-lg)}$STICKY_CSS @media (max-width: 767px){.lobby-start-section{position:sticky;bottom:0;margin-top:var(--spacing-sm);padding:var(--spacing-sm) 0;background:var(--bg-primary);z-index:10}.lobby-start-btn{font-size:1rem;padding:var(--spacing-sm) var(--spacing-md);min-height:44px}.lobby-start-hint{font-size:.75rem}}.lobby-start-btn{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-md) var(--spacing-xl);background:var(--ink-blue);border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-md);color:var(--paper-bg);font-family:var(--font-marker);font-size:1.25rem;cursor:pointer;transition:all .2s ease;box-shadow:3px 3px #1a4b8c80}.lobby-start-btn:hover:not(:disabled){transform:translate(-2px,-2px);box-shadow:5px 5px #1a4b8c80}.lobby-start-btn:disabled{opacity:.5;cursor:not-allowed}.lobby-start-hint{margin-top:var(--spacing-sm);color:var(--text-secondary);font-size:.875rem}.lobby-waiting-host{margin-top:var(--spacing-lg);color:var(--text-secondary);font-family:var(--font-hand)}.lobby-players-compact{margin:var(--spacing-lg) 0}.lobby-game-area{margin-top:var(--spacing-xl)}.lobby-copy-btn:active{transform:scale(.95)}.lobby-start-btn:active:not(:disabled){transform:scale(.98)}.lobby-copy-btn:focus-visible{outline:2px solid var(--gb-cyan);outline-offset:2px}.lobby-start-btn:focus-visible{outline:2px solid white;outline-offset:2px}.lobby-copy-btn.copied,.lobby-copy-btn:has(svg.lucide-check){background:#22c55e40;border-color:var(--success);color:var(--success);animation:lobbyPop .3s ease}@keyframes lobbyPop{0%{transform:scale(1)}50%{transform:scale(1.15)}to{transform:scale(1)}}.lobby-start-btn:not(:disabled){animation:startPulse 2s ease-in-out infinite}@keyframes startPulse{0%,to{box-shadow:0 0 #e9456066}50%{box-shadow:0 0 20px 4px #e945604d}}.lobby-start-btn:hover:not(:disabled){animation:none}@media(max-width:767px){.lobby-waiting-card{padding:var(--spacing-lg);margin:0 var(--spacing-sm)}.lobby-room-code{font-size:1.5rem;letter-spacing:.2em}.lobby-start-btn{font-size:1.125rem;padding:var(--spacing-md);min-height:52px}}@media(max-width:374px){.lobby-waiting-card{padding:var(--spacing-md)}.lobby-room-code,.lobby-waiting-header h2{font-size:1.25rem}}@media(max-width:926px)and (orientation:landscape){.lobby-waiting-card{max-width:380px;padding:var(--spacing-md)}.lobby-waiting-header{margin-bottom:var(--spacing-sm)}.lobby-waiting-header h2{font-size:1.25rem;margin-bottom:var(--spacing-xs)}.lobby-room-code-section{margin-bottom:var(--spacing-sm)}.lobby-room-code-box{padding:var(--spacing-sm)}.lobby-room-code{font-size:1.25rem}.lobby-start-section{margin-top:var(--spacing-sm)}.lobby-start-btn{padding:var(--spacing-sm) var(--spacing-md);font-size:1rem;min-height:44px}.lobby-players-compact{display:none}}@media(min-width:768px)and (max-width:1023px){.lobby-waiting-card{max-width:420px}}@media(min-width:1536px){.lobby-waiting-card{max-width:560px}}.game-placeholder{display:flex;align-items:center;justify-content:center;min-height:clamp(250px,50dvh,500px);padding:clamp(1rem,3dvh,2.5rem)}.game-placeholder-card{max-width:480px;padding:clamp(1rem,3dvh,2.5rem);background:var(--bg-secondary);border:2px solid var(--panel-border);border-radius:var(--radius-xl);text-align:center}.game-placeholder-title{font-family:var(--font-title);font-size:1.5rem;margin-bottom:var(--spacing-lg);color:var(--gb-cyan)}.game-placeholder-info{margin-bottom:var(--spacing-lg);font-family:var(--font-hand);color:var(--text-secondary)}.game-placeholder-content{margin-bottom:var(--spacing-lg)}.game-placeholder-hint{padding:var(--spacing-md);background:#e945601a;border:1px dashed var(--gb-pink);border-radius:var(--radius-md);color:var(--text-secondary);font-style:italic}.game-placeholder-actions{display:flex;gap:var(--spacing-md);justify-content:center;margin-top:var(--spacing-lg)}.game-placeholder-btn{padding:var(--spacing-sm) var(--spacing-lg);min-height:44px;min-width:44px;background:var(--gb-cyan);border:none;border-radius:var(--radius-md);color:var(--bg-primary);font-family:var(--font-hand);font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease}.game-placeholder-btn:hover{background:var(--accent-hover);transform:scale(1.02)}.game-placeholder-btn:active{transform:scale(.98)}.game-placeholder-btn.danger{background:var(--danger-500);color:#fff}.game-placeholder-btn.danger:hover{background:var(--danger-400)}@media(max-width:767px){.game-placeholder{min-height:clamp(200px,40dvh,300px);padding:var(--spacing-md)}.game-placeholder-card{width:100%;max-width:none;padding:var(--spacing-md)}.game-placeholder-title{font-size:1.25rem}.game-placeholder-actions{flex-direction:column;gap:var(--spacing-sm)}.game-placeholder-btn{width:100%;justify-content:center}}@media(max-width:1023px)and (orientation:landscape){.game-placeholder{min-height:clamp(180px,35dvh,250px);padding:var(--spacing-sm)}.game-placeholder-card{padding:var(--spacing-sm) var(--spacing-md)}.game-placeholder-info{margin-bottom:var(--spacing-sm)}}.game-placeholder-debug{margin-top:var(--spacing-lg);text-align:left}.game-placeholder-debug summary{cursor:pointer;color:var(--text-secondary);font-size:.875rem}.game-placeholder-debug pre{margin-top:var(--spacing-sm);padding:var(--spacing-sm);background:var(--bg-tertiary);border-radius:var(--radius-sm);font-size:.75rem;overflow-x:auto}@keyframes placeholderCardEnter{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes placeholderHintPulse{0%,to{border-color:var(--gb-pink);background:#e945601a}50%{border-color:#e9456099;background:#e9456026}}@keyframes debugPanelExpand{0%{opacity:0;max-height:0}to{opacity:1;max-height:300px}}.game-placeholder-card{animation:placeholderCardEnter .4s ease-out}.game-placeholder-hint{animation:placeholderHintPulse 3s ease-in-out infinite}.game-placeholder-btn:focus-visible{outline:2px solid var(--gb-cyan);outline-offset:2px;box-shadow:0 0 0 4px #00d9ff33}.game-placeholder-btn.danger:focus-visible{outline-color:var(--danger-400);box-shadow:0 0 0 4px #ef444433}.game-placeholder-btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.game-placeholder-btn:disabled:hover{background:var(--gb-cyan);transform:none!important}.game-placeholder-btn.danger:disabled:hover{background:var(--danger-500)}.game-placeholder-debug summary{padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);transition:background .2s ease,color .2s ease}.game-placeholder-debug summary:hover{background:#ffffff0d;color:var(--text-primary)}.game-placeholder-debug summary:focus-visible{outline:2px solid var(--gb-cyan);outline-offset:2px}.game-placeholder-debug[open] summary{color:var(--gb-cyan);margin-bottom:var(--spacing-sm)}.game-placeholder-debug[open] pre{animation:debugPanelExpand .3s ease-out}.game-placeholder-debug pre::-webkit-scrollbar{height:6px}.game-placeholder-debug pre::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:3px}.game-placeholder-debug pre::-webkit-scrollbar-thumb{background:var(--panel-border);border-radius:3px}.game-placeholder-debug pre::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}@media(min-width:768px)and (max-width:1023px){.game-placeholder{min-height:clamp(220px,45dvh,350px);padding:var(--spacing-lg)}.game-placeholder-card{max-width:420px;padding:var(--spacing-lg)}.game-placeholder-title{font-size:1.375rem}}@media(min-width:1536px){.game-placeholder-card{max-width:560px}}@media(max-width:374px){.game-placeholder{min-height:clamp(180px,35dvh,260px);padding:var(--spacing-sm)}.game-placeholder-card{padding:var(--spacing-sm)}.game-placeholder-title{font-size:1.125rem;margin-bottom:var(--spacing-md)}.game-placeholder-info{font-size:.875rem;margin-bottom:var(--spacing-md)}.game-placeholder-hint{padding:var(--spacing-sm);font-size:.8125rem}.game-placeholder-btn{font-size:.875rem;padding:var(--spacing-sm) var(--spacing-md)}.game-placeholder-debug summary{font-size:.8125rem}.game-placeholder-debug pre{font-size:.6875rem;max-height:150px}}@media(max-height:500px)and (orientation:landscape){.game-placeholder{min-height:200px;padding:var(--spacing-xs)}.game-placeholder-card{padding:var(--spacing-xs) var(--spacing-sm)}.game-placeholder-title{font-size:1rem;margin-bottom:var(--spacing-xs)}.game-placeholder-info,.game-placeholder-content{margin-bottom:var(--spacing-xs)}.game-placeholder-hint{padding:var(--spacing-xs);font-size:.75rem}.game-placeholder-actions{margin-top:var(--spacing-sm);flex-direction:row;flex-wrap:wrap}.game-placeholder-btn{min-height:36px;font-size:.8125rem;padding:var(--spacing-xs) var(--spacing-sm)}.game-placeholder-debug{margin-top:var(--spacing-sm)}}.settings-modal-backdrop{position:fixed;inset:0;background:#00000080;z-index:var(--z-settings-modal-backdrop);display:flex;align-items:center;justify-content:center;padding:var(--spacing-md);padding-top:max(var(--spacing-md),env(safe-area-inset-top,0px));padding-bottom:max(var(--spacing-md),env(safe-area-inset-bottom,0px));padding-left:max(var(--spacing-md),env(safe-area-inset-left,0px));padding-right:max(var(--spacing-md),env(safe-area-inset-right,0px))}.settings-modal{width:100%;max-width:480px;max-height:80vh;background:var(--paper-bg);border:3px solid var(--ink-blue);border-radius:var(--border-wobbly-lg);z-index:var(--z-settings-modal);display:flex;flex-direction:column;overflow:hidden;box-shadow:4px 4px 0 var(--ink-blue)}.settings-modal-header,.settings-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);border-bottom:2px solid var(--ink-blue);background:var(--highlighter-yellow)}.settings-modal-title,.settings-title{font-family:var(--font-title);font-size:1.25rem;color:var(--ink-blue);margin:0}.settings-modal-close,.settings-close{display:flex;align-items:center;justify-content:center;width:44px;height:44px;min-width:44px;min-height:44px;background:transparent;border:2px solid transparent;border-radius:var(--border-wobbly-sm);color:var(--ink-blue);cursor:pointer;transition:all .2s ease}.settings-modal-close:hover,.settings-close:hover{background:var(--highlighter-pink);border-color:var(--ink-red);color:var(--ink-red)}.settings-modal-tabs,.settings-tabs{display:flex;border-bottom:2px solid var(--ink-blue)}.settings-modal-tab,.settings-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);min-height:44px;background:transparent;border:none;border-bottom:3px solid transparent;color:var(--ink-blue);font-family:var(--font-hand);font-size:.875rem;cursor:pointer;transition:all .2s ease}.settings-modal-tab:hover,.settings-tab:hover{background:var(--highlighter-yellow)}.settings-modal-tab.active,.settings-tab.active{color:var(--ink-blue);border-bottom-color:var(--ink-blue);background:var(--highlighter-yellow)}.settings-modal-content,.settings-content{flex:1;overflow-y:auto;padding:var(--spacing-md);-webkit-overflow-scrolling:touch}.settings-section{margin-bottom:var(--spacing-lg)}.settings-section-title{font-family:var(--font-title);font-size:1rem;margin-bottom:var(--spacing-sm);color:var(--ink-blue)}.settings-row{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md) 0;border-bottom:1px solid var(--paper-lines)}.settings-row:last-child{border-bottom:none}.settings-row-header{display:flex;align-items:center;justify-content:space-between;width:100%}.settings-row-label,.settings-label{display:flex;align-items:center;gap:var(--spacing-sm);font-family:var(--font-hand);font-size:.9375rem;color:var(--ink-blue)}.settings-row-label svg{color:var(--ink-blue)}.settings-description,.settings-info{font-size:.875rem;color:var(--ink-blue);opacity:.7;margin-top:.25rem;font-style:italic}.settings-toggle-btn{padding:var(--spacing-xs) var(--spacing-md);min-height:36px;background:var(--paper-bg);border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-sm);color:var(--ink-blue);font-family:var(--font-hand);font-size:.875rem;cursor:pointer;transition:all .2s ease}.settings-toggle-btn:hover{background:var(--highlighter-yellow)}.settings-language-btns{display:flex;gap:var(--spacing-xs)}.settings-lang-btn{padding:var(--spacing-xs) var(--spacing-md);min-height:36px;background:var(--paper-bg);border:2px solid var(--paper-lines);border-radius:var(--border-wobbly-sm);color:var(--ink-blue);font-family:var(--font-hand);font-size:.875rem;cursor:pointer;transition:all .2s ease}.settings-lang-btn:hover{border-color:var(--ink-blue);background:var(--highlighter-yellow)}.settings-lang-btn.active{background:var(--highlighter-yellow);border-color:var(--ink-blue);color:var(--ink-blue);box-shadow:2px 2px 0 var(--ink-blue)}.settings-toggle,.toggle-switch{padding:var(--spacing-xs) var(--spacing-sm);min-width:48px;min-height:32px;background:var(--paper-bg);border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-xs);color:var(--ink-blue);font-family:var(--font-title);font-size:.75rem;font-weight:700;cursor:pointer;transition:all .2s ease}.settings-toggle.on,.toggle-switch.active{background:var(--highlighter-green);border-color:var(--ink-green);color:var(--ink-green)}.settings-toggle.off{background:var(--highlighter-pink);border-color:var(--ink-red);color:var(--ink-red)}.settings-slider,.range-slider{flex:1;max-width:200px;height:8px;background:var(--paper-lines);border-radius:var(--border-wobbly-xs);-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.settings-slider::-webkit-slider-thumb,.range-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;background:var(--ink-blue);border-radius:50%;cursor:pointer;box-shadow:2px 2px #1a4b8c4d}.settings-slider::-moz-range-thumb,.range-slider::-moz-range-thumb{width:20px;height:20px;background:var(--ink-blue);border-radius:50%;cursor:pointer;border:none;box-shadow:2px 2px #1a4b8c4d}.settings-slider:disabled{opacity:.5;cursor:not-allowed}.settings-volume-value{font-family:var(--font-title);font-size:.875rem;font-weight:600;color:var(--ink-blue);min-width:40px;text-align:right}@media(max-width:767px){.settings-modal{max-width:100%;max-height:90vh;margin:var(--spacing-sm)}.settings-modal-tabs,.settings-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.settings-modal-tab,.settings-tab{min-width:80px;flex-shrink:0}.settings-language-btns{flex-wrap:wrap}}@media(max-width:1023px)and (orientation:landscape){.settings-modal{max-height:90vh}.settings-modal-content,.settings-content{max-height:50vh}}.settings-modal-close:focus-visible,.settings-close:focus-visible{outline:2px solid var(--gb-cyan);outline-offset:2px;background:#00d9ff1a}.settings-modal-tab:focus-visible,.settings-tab:focus-visible{outline:2px solid var(--gb-cyan);outline-offset:-2px;background:#00d9ff1a}.settings-toggle-btn:focus-visible{outline:2px solid var(--gb-cyan);outline-offset:2px;box-shadow:0 0 0 4px #00d9ff33}.settings-lang-btn:focus-visible{outline:2px solid var(--gb-cyan);outline-offset:2px;box-shadow:0 0 0 4px #00d9ff33}.settings-toggle:focus-visible,.toggle-switch:focus-visible{outline:2px solid var(--gb-cyan);outline-offset:2px}.settings-slider:focus-visible,.range-slider:focus-visible{outline:2px solid var(--gb-cyan);outline-offset:4px}.settings-modal-close:active,.settings-close:active{transform:scale(.95)}.settings-modal-tab:active,.settings-tab:active{background:#00d9ff26}.settings-toggle-btn:active,.settings-lang-btn:active{transform:scale(.98)}.settings-toggle:active,.toggle-switch:active{transform:scale(.95)}.settings-modal-tab.active,.settings-tab.active{position:relative}.settings-modal-tab.active:after,.settings-tab.active:after{content:"";position:absolute;bottom:-2px;left:50%;width:60%;height:2px;background:var(--gb-cyan);transform:translate(-50%);animation:tabIndicatorExpand .25s ease-out}@keyframes tabIndicatorExpand{0%{width:0%;opacity:0}to{width:60%;opacity:1}}.settings-slider:not(:disabled):hover::-webkit-slider-thumb,.range-slider:not(:disabled):hover::-webkit-slider-thumb{transform:scale(1.15);box-shadow:0 2px 12px #00d9ff99}.settings-slider:not(:disabled):hover::-moz-range-thumb,.range-slider:not(:disabled):hover::-moz-range-thumb{transform:scale(1.15);box-shadow:0 2px 12px #00d9ff99}.settings-slider:disabled::-webkit-slider-thumb,.range-slider:disabled::-webkit-slider-thumb{background:var(--text-secondary);box-shadow:none}.settings-slider:disabled::-moz-range-thumb,.range-slider:disabled::-moz-range-thumb{background:var(--text-secondary);box-shadow:none}.settings-section{animation:settingsSectionFadeIn .3s ease-out}@keyframes settingsSectionFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.settings-row{transition:background .2s ease;border-radius:var(--radius-sm);margin:0 calc(-1 * var(--spacing-sm));padding-left:var(--spacing-sm);padding-right:var(--spacing-sm)}.settings-row:hover{background:#ffffff05}@media(min-width:768px)and (max-width:1023px){.settings-modal{max-width:420px;max-height:75vh}.settings-modal-tabs,.settings-tabs{overflow-x:visible}.settings-modal-content,.settings-content{padding:var(--spacing-lg)}}@media(min-width:1536px){.settings-modal{max-width:560px;max-height:70vh;border-width:3px}.settings-modal-header,.settings-header{padding:var(--spacing-lg)}.settings-modal-title,.settings-title{font-size:1.5rem}.settings-modal-tab,.settings-tab{padding:var(--spacing-md) var(--spacing-lg);font-size:1rem}.settings-modal-content,.settings-content{padding:var(--spacing-lg)}.settings-row-label,.settings-label{font-size:1rem}.settings-slider,.range-slider{max-width:250px;height:10px}.settings-slider::-webkit-slider-thumb,.range-slider::-webkit-slider-thumb{width:24px;height:24px}.settings-slider::-moz-range-thumb,.range-slider::-moz-range-thumb{width:24px;height:24px}}@media(max-width:374px){.settings-modal{margin:var(--spacing-xs);max-height:95vh;border-radius:var(--radius-lg)}.settings-modal-header,.settings-header{padding:var(--spacing-sm)}.settings-modal-title,.settings-title{font-size:1rem}.settings-modal-close,.settings-close{width:40px;height:40px;min-width:40px;min-height:40px}.settings-modal-tabs,.settings-tabs{gap:0}.settings-modal-tab,.settings-tab{min-width:0;padding:var(--spacing-xs) var(--spacing-sm);font-size:.75rem}.settings-modal-tab span,.settings-tab span{display:none}.settings-modal-tab svg,.settings-tab svg{width:18px;height:18px}.settings-modal-content,.settings-content{padding:var(--spacing-sm)}.settings-row-label,.settings-label{font-size:.875rem}.settings-toggle-btn,.settings-lang-btn{padding:var(--spacing-xs) var(--spacing-sm);font-size:.75rem;min-height:32px}.settings-toggle,.toggle-switch{min-width:40px;min-height:28px;font-size:.625rem}.settings-slider,.range-slider{max-width:140px}.settings-volume-value{font-size:.75rem;min-width:32px}}@media(max-height:500px)and (orientation:landscape){.settings-modal{max-height:95vh;max-width:500px}.settings-modal-header,.settings-header{padding:var(--spacing-xs) var(--spacing-sm)}.settings-modal-title,.settings-title{font-size:1rem}.settings-modal-tabs,.settings-tabs{min-height:0}.settings-modal-tab,.settings-tab{padding:var(--spacing-xs) var(--spacing-sm);min-height:36px}.settings-modal-content,.settings-content{padding:var(--spacing-sm);max-height:45vh}.settings-row{padding:var(--spacing-xs) var(--spacing-sm)}}.error-boundary{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-dark) 0%,#1a0a10 50%,var(--bg-dark) 100%);z-index:var(--z-modal);padding:var(--spacing-md);overflow:auto}.error-boundary:before{content:"";position:absolute;inset:0;background-image:radial-gradient(ellipse at 20% 30%,rgba(233,69,96,.15) 0%,transparent 50%),radial-gradient(ellipse at 80% 70%,rgba(0,217,255,.1) 0%,transparent 50%);pointer-events:none}.error-boundary-content{position:relative;background:var(--bg-card);border:2px solid var(--gb-pink);border-radius:var(--radius-lg);padding:clamp(1rem,3dvh,2.5rem);max-width:480px;width:100%;text-align:center;box-shadow:0 0 40px #e9456033,0 20px 60px #00000080;animation:errorBounce .5s ease-out,errorPulse 3s ease-in-out .5s infinite}@keyframes errorBounce{0%{opacity:0;transform:scale(.9) translateY(-20px)}50%{transform:scale(1.02) translateY(0)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes errorPulse{0%,to{box-shadow:0 0 40px #e9456033,0 20px 60px #00000080}50%{box-shadow:0 0 60px #e9456059,0 0 100px #e9456026,0 20px 60px #00000080}}@keyframes glitchFlicker{0%,92%,to{opacity:1}93%{opacity:.8;transform:translate(-2px)}94%{opacity:1;transform:translate(2px)}95%{opacity:.9;transform:translate(0)}}.error-boundary-title{font-family:var(--font-display);font-size:2rem;font-weight:700;color:var(--gb-pink);margin:0 0 var(--spacing-md);text-shadow:0 0 20px rgba(233,69,96,.4);letter-spacing:-.02em;animation:glitchFlicker 8s ease-in-out infinite}.error-boundary-title:hover{text-shadow:-2px 0 rgba(0,217,255,.6),2px 0 rgba(233,69,96,.6),0 0 20px rgba(233,69,96,.4)}.error-boundary-message{font-family:var(--font-body);font-size:1.125rem;color:var(--text-secondary);margin:0 0 var(--spacing-lg);line-height:1.5}.error-boundary-details{background:#0006;border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--spacing-md);margin:0 0 var(--spacing-lg);font-family:SF Mono,Monaco,Consolas,monospace;font-size:.875rem;color:var(--gb-pink);text-align:left;overflow-x:auto;white-space:pre-wrap;word-break:break-word;max-height:150px;overflow-y:auto}.error-boundary-actions{display:flex;gap:var(--spacing-md);justify-content:center;flex-wrap:wrap}.error-boundary-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);min-height:48px;min-width:140px;font-family:var(--font-title);font-size:1rem;font-weight:600;border-radius:var(--radius-md);border:2px solid transparent;cursor:pointer;transition:all .2s ease}.error-boundary-btn.primary{background:var(--gb-pink);color:#fff;border-color:var(--gb-pink);box-shadow:0 4px 20px #e9456066}.error-boundary-btn.primary:hover{background:var(--gb-pink-light);border-color:var(--gb-pink-light);transform:translateY(-2px);box-shadow:0 6px 24px #e9456080}.error-boundary-btn.primary:active{transform:translateY(0)}.error-boundary-btn.secondary{background:transparent;color:var(--text-primary);border-color:var(--border-subtle)}.error-boundary-btn.secondary:hover{background:var(--bg-overlay);border-color:var(--gb-cyan);color:var(--gb-cyan)}.error-boundary-btn.secondary:active{transform:scale(.98);background:#00d9ff1a}.error-boundary-btn:focus-visible{outline:2px solid var(--gb-cyan);outline-offset:2px}.error-boundary-btn.primary:focus-visible{box-shadow:0 4px 20px #e9456066,0 0 0 4px #e9456033}.error-boundary-btn.secondary:focus-visible{box-shadow:0 0 0 4px #00d9ff33}.error-boundary-details::-webkit-scrollbar{width:6px;height:6px}.error-boundary-details::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:3px}.error-boundary-details::-webkit-scrollbar-thumb{background:var(--gb-pink);border-radius:3px;opacity:.6}.error-boundary-details::-webkit-scrollbar-thumb:hover{opacity:1}@media(max-width:767px){.error-boundary{padding:var(--spacing-md);padding-top:env(safe-area-inset-top,0);padding-bottom:env(safe-area-inset-bottom,0)}.error-boundary-content{padding:var(--spacing-lg)}.error-boundary-title{font-size:1.5rem}.error-boundary-message{font-size:1rem}.error-boundary-actions{flex-direction:column}.error-boundary-btn{width:100%;min-height:52px}}@media(max-width:1023px)and (orientation:landscape){.error-boundary-content{max-height:90vh;overflow-y:auto;padding:var(--spacing-md)}.error-boundary-title{font-size:1.25rem;margin-bottom:var(--spacing-sm)}.error-boundary-message{font-size:.875rem;margin-bottom:var(--spacing-sm)}.error-boundary-details{max-height:80px;margin-bottom:var(--spacing-sm)}.error-boundary-actions{flex-direction:row}.error-boundary-btn{min-height:44px;padding:var(--spacing-xs) var(--spacing-md)}}@media(min-width:768px)and (max-width:1023px){.error-boundary-content{max-width:440px;padding:var(--spacing-lg)}.error-boundary-title{font-size:1.75rem}.error-boundary-message{font-size:1rem}}@media(min-width:1536px){.error-boundary-content{max-width:560px;padding:var(--spacing-2xl);border-width:3px}.error-boundary-title{font-size:2.5rem;margin-bottom:var(--spacing-lg)}.error-boundary-message{font-size:1.25rem;margin-bottom:var(--spacing-xl)}.error-boundary-details{font-size:.9375rem;padding:var(--spacing-lg);max-height:200px;margin-bottom:var(--spacing-xl)}.error-boundary-actions{gap:var(--spacing-lg)}.error-boundary-btn{min-height:56px;min-width:160px;font-size:1.125rem;padding:var(--spacing-md) var(--spacing-xl)}}@media(max-width:374px){.error-boundary{padding:var(--spacing-sm)}.error-boundary-content{padding:var(--spacing-md);border-radius:var(--radius-md)}.error-boundary-title{font-size:1.25rem;margin-bottom:var(--spacing-sm)}.error-boundary-message{font-size:.875rem;margin-bottom:var(--spacing-md)}.error-boundary-details{font-size:.75rem;padding:var(--spacing-sm);max-height:100px;margin-bottom:var(--spacing-md)}.error-boundary-actions{gap:var(--spacing-sm)}.error-boundary-btn{min-height:48px;min-width:0;font-size:.875rem;padding:var(--spacing-sm) var(--spacing-md)}}@media(max-height:400px)and (orientation:landscape){.error-boundary-content{max-height:95vh;padding:var(--spacing-sm) var(--spacing-md)}.error-boundary-title{font-size:1rem;margin-bottom:var(--spacing-xs)}.error-boundary-message{font-size:.75rem;margin-bottom:var(--spacing-xs)}.error-boundary-details{max-height:50px;font-size:.6875rem;margin-bottom:var(--spacing-xs);padding:var(--spacing-xs)}.error-boundary-btn{min-height:36px;font-size:.8125rem;padding:var(--spacing-xs) var(--spacing-sm)}}.gamebuddies-return-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-xs);font-family:var(--font-title);font-weight:600;cursor:pointer;transition:all .2s ease;border:none;text-decoration:none}.gamebuddies-return-btn svg{flex-shrink:0}.gamebuddies-return-btn.inline{padding:var(--spacing-xs) var(--spacing-sm);min-height:36px;font-size:.875rem;color:var(--text-secondary);background:transparent;border-radius:var(--radius-sm)}.gamebuddies-return-btn.inline:hover{color:var(--gb-cyan);background:var(--bg-overlay)}.gamebuddies-return-btn.inline:active{transform:scale(.98)}@keyframes returnBtnPulse{0%,to{box-shadow:0 4px 16px #e9456066,0 2px 4px #0003}50%{box-shadow:0 4px 24px #e9456099,0 0 40px #e9456033,0 2px 4px #0003}}.gamebuddies-return-btn.floating{position:fixed;bottom:calc(var(--spacing-lg) + env(safe-area-inset-bottom,0px));left:calc(var(--spacing-lg) + env(safe-area-inset-left,0px));z-index:var(--z-floating);padding:var(--spacing-sm) var(--spacing-md);min-height:44px;font-size:.875rem;color:#fff;background:linear-gradient(135deg,var(--gb-pink) 0%,#c93a52 100%);border-radius:var(--radius-full);box-shadow:0 4px 16px #e9456066,0 2px 4px #0003;animation:returnBtnPulse 4s ease-in-out infinite}.gamebuddies-return-btn.floating:hover{animation-play-state:paused;transform:translateY(-2px);box-shadow:0 6px 24px #e9456080,0 4px 8px #0000004d}.gamebuddies-return-btn.floating:active{transform:translateY(0)}@media(max-width:767px){.gamebuddies-return-btn.floating{bottom:calc(var(--spacing-md) + env(safe-area-inset-bottom,0px));left:calc(var(--spacing-md) + env(safe-area-inset-left,0px));padding:var(--spacing-sm) var(--spacing-md);min-height:48px;font-size:.8125rem}.gamebuddies-return-btn.floating span{display:none}.gamebuddies-return-btn.floating{padding:var(--spacing-sm);width:48px;border-radius:50%}.gamebuddies-return-btn.inline{min-height:44px;padding:var(--spacing-sm) var(--spacing-md)}}@media(min-width:375px)and (max-width:767px){.gamebuddies-return-btn.floating span{display:inline}.gamebuddies-return-btn.floating{width:auto;border-radius:var(--radius-full);padding:var(--spacing-sm) var(--spacing-md)}}@media(max-width:1023px)and (orientation:landscape){.gamebuddies-return-btn.floating{bottom:calc(var(--spacing-sm) + env(safe-area-inset-bottom,0px));left:calc(var(--spacing-sm) + env(safe-area-inset-left,0px));min-height:40px;padding:var(--spacing-xs) var(--spacing-sm);font-size:.75rem}}.gb-return-label{display:flex;flex-direction:column;align-items:flex-start;line-height:1.2}.gb-return-main{font-size:inherit}.gb-return-sub{font-size:.65rem;opacity:.6}.gamebuddies-return-btn.inline:focus-visible{outline:2px solid var(--gb-cyan);outline-offset:2px;background:var(--bg-overlay);color:var(--gb-cyan)}.gamebuddies-return-btn.floating:focus-visible{outline:2px solid white;outline-offset:2px;animation-play-state:paused;box-shadow:0 0 0 4px #e945604d,0 6px 24px #e9456080}@keyframes floatingBtnEnter{0%{opacity:0;transform:translateY(20px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.gamebuddies-return-btn.floating{animation:floatingBtnEnter .4s ease-out,returnBtnPulse 4s ease-in-out .4s infinite}.gamebuddies-return-btn.inline svg{transition:transform .3s ease}.gamebuddies-return-btn.inline:hover svg{transform:translate(-2px)}.gamebuddies-return-btn.floating svg{transition:transform .2s ease}.gamebuddies-return-btn.floating:hover svg{transform:translate(-3px)}@media(min-width:768px)and (max-width:1023px){.gamebuddies-return-btn.floating{bottom:calc(var(--spacing-md) + env(safe-area-inset-bottom,0px));left:calc(var(--spacing-md) + env(safe-area-inset-left,0px));padding:var(--spacing-sm) var(--spacing-lg)}.gamebuddies-return-btn.inline{padding:var(--spacing-xs) var(--spacing-md)}}@media(min-width:1536px){.gamebuddies-return-btn.floating{bottom:calc(var(--spacing-xl) + env(safe-area-inset-bottom,0px));left:calc(var(--spacing-xl) + env(safe-area-inset-left,0px));padding:var(--spacing-md) var(--spacing-lg);min-height:52px;font-size:1rem}.gamebuddies-return-btn.floating svg{width:18px;height:18px}.gamebuddies-return-btn.inline{padding:var(--spacing-sm) var(--spacing-md);font-size:.9375rem;min-height:40px}}@media(max-width:374px){.gamebuddies-return-btn.floating{width:44px;height:44px;padding:0;border-radius:50%;bottom:calc(var(--spacing-sm) + env(safe-area-inset-bottom,0px));left:calc(var(--spacing-sm) + env(safe-area-inset-left,0px))}.gamebuddies-return-btn.floating span{display:none}.gamebuddies-return-btn.floating svg{width:18px;height:18px}.gamebuddies-return-btn.inline{min-height:40px;padding:var(--spacing-xs) var(--spacing-sm);font-size:.8125rem}}@media(max-height:400px)and (orientation:landscape){.gamebuddies-return-btn.floating{width:36px;height:36px;min-height:36px;padding:0;border-radius:50%;bottom:calc(var(--spacing-xs) + env(safe-area-inset-bottom,0px));left:calc(var(--spacing-xs) + env(safe-area-inset-left,0px))}.gamebuddies-return-btn.floating span{display:none}.gamebuddies-return-btn.floating svg{width:16px;height:16px}.gamebuddies-return-btn.inline{min-height:32px;font-size:.75rem}}.kick-toast{position:fixed;top:20px;left:50%;transform:translate(-50%) translateY(-100px);background:linear-gradient(135deg,#dc2626,#991b1b);color:#fff;padding:16px 20px;border-radius:12px;display:flex;align-items:center;gap:12px;box-shadow:0 8px 32px #dc262666;z-index:10002;opacity:0;transition:transform .3s ease,opacity .3s ease;max-width:90vw}.kick-toast.visible{transform:translate(-50%) translateY(0);opacity:1}.kick-toast-icon{background:#fff3;padding:8px;border-radius:8px;display:flex;align-items:center;justify-content:center}.kick-toast-content{display:flex;flex-direction:column;gap:2px}.kick-toast-title{font-weight:600;font-size:14px}.kick-toast-message{font-size:13px;opacity:.9}.kick-toast-close{background:transparent;border:none;color:#fff;cursor:pointer;padding:4px;opacity:.7;transition:opacity .2s;display:flex;align-items:center;justify-content:center}.kick-toast-close:hover{opacity:1}.game-header-mute-btn{display:flex;align-items:center;justify-content:center;min-width:44px;min-height:44px;width:44px;height:44px;border-radius:var(--border-wobbly-sm);border:2px solid var(--ink-blue);background:var(--paper-bg);color:var(--ink-blue);cursor:pointer;transition:all .2s ease;flex-shrink:0;box-shadow:2px 2px 0 var(--ink-blue)}.game-header-mute-btn:hover{background:var(--highlighter-green, #d4f5d4);transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--ink-blue);color:var(--ink-blue)}.game-header-mute-btn:active{transform:scale(.95)}.game-header-mute-btn.muted{color:var(--ink-red, #c0392b);border-color:var(--ink-red, #c0392b);background:var(--highlighter-pink, #ffe0e6);box-shadow:2px 2px 0 var(--ink-red, #c0392b)}.game-header-mute-btn.muted:hover{background:var(--highlighter-pink, #ffc8d4);transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--ink-red, #c0392b)}.home-header-mobile-controls{display:flex;align-items:center;gap:var(--spacing-xs, 6px)}.home-header-mute.game-header-mute-btn{width:38px;height:38px}@media(prefers-reduced-motion:reduce){.game-header-mute-btn{transition:none}}.scrollbar-hide{-ms-overflow-style:none;scrollbar-width:none}.scrollbar-hide::-webkit-scrollbar{display:none}.focus-visible:focus-visible{outline:2px solid var(--gb-cyan);outline-offset:2px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}@keyframes gameMainFadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes gameSidebarSlideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes sidebarSectionReveal{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.game-page{position:relative}.game-page:before{content:"";position:fixed;inset:0;background:radial-gradient(ellipse at 20% 30%,rgba(233,69,96,.03) 0%,transparent 50%),radial-gradient(ellipse at 80% 70%,rgba(0,217,255,.03) 0%,transparent 50%);pointer-events:none;z-index:0}.game-main{animation:gameMainFadeIn .4s ease-out;position:relative;z-index:1}.game-sidebar{animation:gameSidebarSlideIn .4s ease-out .15s both;position:relative;z-index:1;transition:width .3s ease,opacity .3s ease}.game-sidebar-section{animation:sidebarSectionReveal .35s ease-out both}.game-sidebar-section:first-child{animation-delay:.25s}.game-sidebar-section:nth-child(2){animation-delay:.35s}.game-sidebar-section.chat-section{animation-delay:.4s}.game-sidebar-section:focus-within{background:#ffffff05}.game-content{position:relative;z-index:1}@media(min-width:1024px){.game-sidebar{transition:box-shadow .3s ease}.game-sidebar:hover{box-shadow:-4px 0 20px #00000026}.game-sidebar-section:focus-within{border-left:2px solid var(--gb-cyan);margin-left:-1px}}@media(min-width:1536px){.game-sidebar{border-left-width:2px}.game-sidebar-section{padding:var(--spacing-md)}.game-main{padding:var(--spacing-lg)}}@media(min-width:768px)and (max-width:1023px){.game-main{padding:var(--spacing-md);animation:gameMainFadeIn .35s ease-out}}@media(max-width:767px){.game-page:before{background:radial-gradient(ellipse at 50% 20%,rgba(233,69,96,.04) 0%,transparent 60%)}.game-main{padding:var(--spacing-sm);padding-bottom:calc(var(--spacing-sm) + env(safe-area-inset-bottom));animation:gameMainFadeIn .3s ease-out}.game-content{gap:0}}@media(max-width:374px){.game-main{padding:var(--spacing-xs);padding-bottom:calc(var(--spacing-xs) + env(safe-area-inset-bottom))}.game-page:before{opacity:.7}}@media(max-width:1023px)and (orientation:landscape){.game-page:before{background:radial-gradient(ellipse at 10% 50%,rgba(233,69,96,.03) 0%,transparent 40%),radial-gradient(ellipse at 90% 50%,rgba(0,217,255,.03) 0%,transparent 40%)}.game-main{padding:var(--spacing-xs) var(--spacing-sm);animation-duration:.25s}.game-content{padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}}@media(max-height:500px)and (orientation:landscape){.game-main{padding:var(--spacing-xs)}}@media(min-width:768px)and (max-width:1023px)and (orientation:landscape){.game-main{padding:var(--spacing-sm) var(--spacing-md)}}.invite-modal-backdrop{position:fixed;inset:0;background:#00000080;z-index:var(--z-settings-modal-backdrop);display:flex;align-items:center;justify-content:center;padding:var(--spacing-md);padding-top:max(var(--spacing-md),env(safe-area-inset-top,0px));padding-bottom:max(var(--spacing-md),env(safe-area-inset-bottom,0px));padding-left:max(var(--spacing-md),env(safe-area-inset-left,0px));padding-right:max(var(--spacing-md),env(safe-area-inset-right,0px))}.invite-modal{position:relative;width:100%;max-width:380px;background:var(--paper-bg);border:3px solid var(--ink-blue);border-radius:var(--border-wobbly-lg);z-index:var(--z-settings-modal);display:flex;flex-direction:column;align-items:center;padding:var(--spacing-xl) var(--spacing-lg);text-align:center;box-shadow:4px 4px 0 var(--ink-blue)}.invite-modal-close{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:transparent;border:2px solid transparent;border-radius:var(--border-wobbly-sm);color:var(--ink-blue);cursor:pointer;transition:all .2s ease}.invite-modal-close:hover{background:var(--highlighter-pink);border-color:var(--ink-red);color:var(--ink-red)}.invite-modal-mascot{width:100px;height:auto;margin-bottom:var(--spacing-md);filter:drop-shadow(0 4px 12px rgba(0,0,0,.3))}.invite-modal-title{font-family:var(--font-title);font-size:1.75rem;color:var(--ink-blue);margin:0 0 var(--spacing-xs) 0;text-shadow:none}.invite-modal-subtitle{font-family:var(--font-hand);font-size:1rem;color:var(--ink-blue);opacity:.8;margin:0 0 var(--spacing-lg) 0}.invite-modal-error{width:100%;background:var(--highlighter-pink);border:2px solid var(--ink-red);border-radius:var(--border-wobbly-sm);padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-md)}.invite-modal-error p{margin:0;color:var(--ink-red);font-size:.875rem;font-weight:600}.invite-modal-form{width:100%;display:flex;flex-direction:column;gap:var(--spacing-md)}.invite-modal-btn{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-md) var(--spacing-lg);background:var(--ink-blue);border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-sm);color:var(--paper-bg);font-family:var(--font-title);font-size:1.125rem;cursor:pointer;transition:all .15s ease;box-shadow:3px 3px #1a4b8c80;min-height:48px}.invite-modal-btn:hover:not(:disabled){transform:translate(-2px,-2px);box-shadow:5px 5px #1a4b8c80;background:var(--highlighter-yellow);color:var(--ink-blue)}.invite-modal-btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:2px 2px #1a4b8c4d}@media(max-width:480px){.invite-modal{max-width:100%;margin:var(--spacing-md);padding:var(--spacing-lg) var(--spacing-md)}.invite-modal-mascot{width:80px}.invite-modal-title{font-size:1.5rem}}.device-settings-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:var(--z-settings-modal-backdrop);padding:var(--spacing-md);animation:fadeIn .2s ease-out}.device-settings-modal{background:var(--paper-bg);border:3px solid var(--ink-blue);border-radius:var(--border-wobbly-lg);max-width:480px;width:100%;max-height:90vh;overflow-y:auto;z-index:var(--z-settings-modal);animation:slideUp .3s ease-out;box-shadow:6px 6px #1a4b8c66}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.device-settings-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);border-bottom:2px dashed var(--paper-lines)}.device-settings-header h2{font-family:var(--font-title);font-size:1.125rem;font-weight:600;color:var(--ink-blue);margin:0}.device-settings-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--border-wobbly-xs);background:transparent;border:none;color:var(--ink-blue);cursor:pointer;transition:all .15s ease}.device-settings-close:hover{background:var(--highlighter-pink);color:var(--ink-red)}.device-settings-error{background:var(--highlighter-pink);border:2px solid var(--ink-red);color:var(--ink-red);padding:var(--spacing-sm) var(--spacing-md);margin:var(--spacing-md);border-radius:var(--border-wobbly-sm);font-size:.875rem;font-weight:600}.device-settings-preview{position:relative;aspect-ratio:16/9;background:var(--paper-bg);margin:var(--spacing-md);border-radius:var(--border-wobbly-md);overflow:hidden;border:3px solid var(--ink-blue);box-shadow:3px 3px #1a4b8c4d}.device-settings-preview video{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transform:scaleX(-1)}.device-settings-preview video.camera-off{opacity:.3}.camera-off-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-sm);color:var(--ink-blue);background:#fefcf3e6}.camera-off-overlay svg{width:2rem;height:2rem}.camera-off-overlay span{font-size:.875rem}.device-settings-devices{padding:0 var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-md)}.device-setting-row{display:flex;flex-direction:column;gap:var(--spacing-xs)}.device-setting-row label{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.875rem;font-weight:600;color:var(--ink-blue);font-family:var(--font-hand)}.device-setting-row select{width:100%;padding:var(--spacing-sm) var(--spacing-md);background:#1e293b;border:2px solid #475569;border-radius:var(--border-wobbly-sm);color:#e2e8f0;font-size:.875rem;font-family:var(--font-hand);font-weight:500;cursor:pointer;transition:all .15s ease}.device-setting-row select:hover{border-color:var(--ink-blue);background:var(--highlighter-yellow);transform:translate(-1px,-1px);box-shadow:2px 2px #1a4b8c4d}.device-setting-row select:focus{outline:none;border-color:var(--ink-blue);background:var(--highlighter-yellow);box-shadow:3px 3px #1a4b8c66}.device-setting-row select option{background:#1e293b;color:#e2e8f0;font-family:var(--font-hand);padding:8px}.audio-meter-row{margin-top:var(--spacing-sm)}.audio-meter{width:100%;height:8px;background:#fff;border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-xs);overflow:hidden}.audio-meter-fill{height:100%;background:linear-gradient(90deg,var(--ink-green),var(--ink-blue));border-radius:var(--border-wobbly-xs);transition:width .05s ease-out}.audio-meter-bars{display:flex;gap:3px;height:24px;align-items:flex-end;padding:var(--spacing-xs) var(--spacing-sm);background:#fff;border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-sm)}.audio-bar{flex:1;min-height:4px;background:#1a4b8c26;border-radius:2px;transition:all .08s ease-out}.audio-bar.active{min-height:100%}.audio-bar.active.green{background:linear-gradient(to top,#059669,#10b981);box-shadow:0 0 6px #10b98166}.audio-bar.active.yellow{background:linear-gradient(to top,#d97706,#f59e0b);box-shadow:0 0 6px #f59e0b66}.audio-bar.active.red{background:linear-gradient(to top,#dc2626,#ef4444);box-shadow:0 0 6px #ef444480}.device-settings-privacy{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);border-top:2px dashed var(--paper-lines);margin-top:var(--spacing-md)}.privacy-toggle{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.privacy-toggle input[type=checkbox]{position:absolute;opacity:0;width:0;height:0}.toggle-slider{position:relative;width:40px;height:22px;background:#fff;border:2px solid var(--ink-blue);border-radius:11px;transition:all .2s ease;flex-shrink:0}.toggle-slider:before{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;background:var(--ink-blue);opacity:.4;border-radius:50%;transition:all .2s ease}.privacy-toggle input:checked+.toggle-slider{background:var(--ink-green);border-color:var(--ink-green);box-shadow:2px 2px #228b224d}.privacy-toggle input:checked+.toggle-slider:before{transform:translate(18px);background:#fff;opacity:1;box-shadow:1px 1px #0003}.privacy-toggle:hover .toggle-slider{border-color:var(--ink-blue);transform:translate(-1px,-1px);box-shadow:2px 2px #1a4b8c4d}.toggle-label{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.875rem;font-family:var(--font-hand);font-weight:500;color:var(--ink-blue);opacity:.7;transition:all .15s ease}.privacy-toggle input:checked~.toggle-label{color:var(--ink-blue);opacity:1}.privacy-toggle input:checked~.toggle-label svg{color:var(--ink-green)}.device-settings-actions{display:flex;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);border-top:2px dashed var(--paper-lines)}.device-settings-cancel{flex:1;padding:var(--spacing-sm) var(--spacing-md);background:var(--paper-bg);border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-sm);color:var(--ink-blue);font-family:var(--font-hand);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .15s ease;box-shadow:2px 2px #1a4b8c4d}.device-settings-cancel:hover{background:var(--highlighter-pink);transform:translate(-1px,-1px);box-shadow:3px 3px #1a4b8c4d}.device-settings-confirm{flex:2;display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:var(--ink-blue);border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-sm);color:var(--paper-bg);font-family:var(--font-hand);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .15s ease;box-shadow:2px 2px #1a4b8c80}.device-settings-confirm:hover{background:var(--highlighter-yellow);color:var(--ink-blue);transform:translate(-1px,-1px);box-shadow:3px 3px #1a4b8c80}.device-settings-confirm:active{transform:translate(1px,1px);box-shadow:1px 1px #1a4b8c80}@media(max-width:767px){.device-settings-modal-overlay{padding:0}.device-settings-modal{position:fixed;inset:0;max-width:none;max-height:none;border-radius:0;display:flex;flex-direction:column}.device-settings-preview{flex-shrink:0}.device-settings-devices{flex:1;overflow-y:auto;padding-bottom:var(--spacing-md)}.device-settings-actions{flex-shrink:0;padding-bottom:calc(var(--spacing-md) + env(safe-area-inset-bottom))}}.device-settings-tabs{display:flex;gap:var(--spacing-xs);padding:0 var(--spacing-md);border-bottom:2px dashed var(--paper-lines);background:var(--paper-bg)}.device-settings-tab{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:none;border-bottom:2px solid transparent;color:var(--ink-blue);opacity:.6;font-family:var(--font-hand);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .15s ease;margin-bottom:-2px}.device-settings-tab:hover{opacity:1;background:var(--highlighter-yellow)}.device-settings-tab.active{color:var(--ink-blue);opacity:1;border-bottom-color:var(--ink-blue);background:var(--highlighter-yellow)}.device-settings-tab svg{flex-shrink:0}.device-settings-content{flex:1;overflow-y:auto;padding:var(--spacing-md) 0}.virtual-bg-badge{position:absolute;top:var(--spacing-sm);left:var(--spacing-sm);display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:var(--ink-blue);border-radius:var(--border-wobbly-xs);color:#fff;font-size:.75rem;font-family:var(--font-hand);font-weight:600;box-shadow:2px 2px #0003}.virtual-bg-loading{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#fefcf3e6;color:var(--ink-blue);gap:var(--spacing-sm);font-size:.875rem;font-family:var(--font-hand);font-weight:600;z-index:5}.vb-loading-spinner{width:24px;height:24px;border:3px dashed var(--paper-lines);border-top-color:var(--ink-blue);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.feature-toggle{padding:var(--spacing-sm) 0;margin-bottom:var(--spacing-sm)}.background-options{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg)}.background-option{position:relative;aspect-ratio:16/9;border-radius:var(--border-wobbly-sm);overflow:hidden;border:2px solid var(--paper-lines);cursor:pointer;transition:all .15s ease;background:#fff}.background-option:hover{border-color:var(--ink-blue);transform:translate(-1px,-1px);box-shadow:2px 2px #1a4b8c4d}.background-option.active{border-color:var(--ink-blue);border-width:3px;box-shadow:3px 3px #1a4b8c66}.background-option.active:after{content:"✓";position:absolute;top:6px;right:6px;width:20px;height:20px;display:flex;align-items:center;justify-content:center;background:var(--ink-green);border-radius:50%;color:#fff;font-size:.7rem;font-weight:700;box-shadow:2px 2px #0003;z-index:1}.background-option:has(img){background:#f0f0f0}.background-option img{width:100%;height:100%;-o-object-fit:contain;object-fit:contain}.background-option span{position:absolute;bottom:0;left:0;right:0;padding:var(--spacing-xs);background:linear-gradient(transparent,#000c);color:#fff;font-size:.75rem;text-align:center}.blur-option .blur-preview{width:100%;height:100%;background:linear-gradient(135deg,var(--paper-bg) 25%,var(--paper-lines) 25%,var(--paper-lines) 50%,var(--paper-bg) 50%,var(--paper-bg) 75%,var(--paper-lines) 75%);background-size:20px 20px;filter:blur(4px)}.background-info{padding:var(--spacing-sm) var(--spacing-md);margin:var(--spacing-sm) var(--spacing-lg);border-radius:var(--border-wobbly-sm);background:var(--highlighter-yellow);border-left:4px solid var(--ink-blue)}.background-info p{font-size:.8rem;color:var(--ink-blue);font-family:var(--font-hand);line-height:1.5;margin:0}.background-info.info{background:#1a4b8c1a;border-left-color:var(--ink-blue)}.background-info.success{background:#228b2226;border-left-color:var(--ink-green)}.background-info.warning{background:var(--highlighter-yellow);border-left-color:#d97706}.background-info.experimental{background:var(--highlighter-pink);border-left-color:var(--ink-red)}.slider-setting{padding:0 var(--spacing-lg);margin-top:var(--spacing-md)}.slider-setting label{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xs);font-size:.875rem;font-family:var(--font-hand);font-weight:600;color:var(--ink-blue)}.slider-setting .slider-value{font-weight:700;color:var(--ink-blue);background:var(--highlighter-yellow);padding:2px 6px;border-radius:var(--border-wobbly-xs)}.slider-setting input[type=range]{width:100%;height:8px;background:#fff;border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-xs);-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.slider-setting input[type=range]::-webkit-slider-runnable-track{height:4px;border-radius:2px;background:linear-gradient(to right,var(--ink-blue) 0%,var(--ink-blue) var(--value, 30%),var(--paper-lines) var(--value, 30%),var(--paper-lines) 100%)}.slider-setting input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;background:var(--paper-bg);border:3px solid var(--ink-blue);border-radius:50%;cursor:pointer;margin-top:-7px;-webkit-transition:all .15s ease;transition:all .15s ease;box-shadow:2px 2px #1a4b8c4d}.slider-setting input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.15) translate(-1px,-1px);box-shadow:3px 3px #1a4b8c66}.slider-setting input[type=range]:active::-webkit-slider-thumb{transform:scale(1.05)}.slider-setting input[type=range]::-moz-range-track{height:4px;border-radius:2px;background:var(--paper-lines)}.slider-setting input[type=range]::-moz-range-thumb{width:18px;height:18px;background:var(--paper-bg);border:3px solid var(--ink-blue);border-radius:50%;cursor:pointer;box-shadow:2px 2px #1a4b8c4d}.slider-setting input[type=range]::-moz-range-thumb:hover{transform:scale(1.15);box-shadow:3px 3px #1a4b8c66}.slider-setting .slider-labels{display:flex;justify-content:space-between;font-size:.75rem;font-family:var(--font-hand);color:var(--ink-blue);opacity:.7;margin-top:var(--spacing-xs)}.avatar-options{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg)}.avatar-option{position:relative;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-md);background:#fff;border:2px solid var(--paper-lines);border-radius:var(--border-wobbly-sm);cursor:pointer;transition:all .15s ease}.avatar-option:hover:not(.disabled){border-color:var(--ink-blue);transform:translate(-1px,-1px);box-shadow:2px 2px #1a4b8c4d}.avatar-option.active{border-color:var(--ink-blue);border-width:3px;background:var(--highlighter-yellow);box-shadow:3px 3px #1a4b8c66}.avatar-option.disabled{opacity:.5;cursor:not-allowed}.avatar-emoji{font-size:2rem}.avatar-label{font-size:.75rem;font-family:var(--font-hand);font-weight:600;color:var(--ink-blue)}.soon-badge{position:absolute;top:var(--spacing-xs);right:var(--spacing-xs);padding:2px 6px;background:var(--highlighter-pink);border:1px solid var(--ink-red);border-radius:var(--border-wobbly-xs);font-size:.6rem;font-family:var(--font-hand);font-weight:700;color:var(--ink-red);text-transform:uppercase}.device-settings-background,.device-settings-audio,.device-settings-avatar{display:flex;flex-direction:column}.device-settings-background .feature-toggle,.device-settings-audio .feature-toggle,.device-settings-avatar .feature-toggle{padding:var(--spacing-sm) var(--spacing-lg)}@media(max-width:767px){.device-settings-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.device-settings-tabs::-webkit-scrollbar{display:none}.device-settings-tab{white-space:nowrap;padding:var(--spacing-sm)}.device-settings-tab span{display:none}.background-options,.avatar-options{grid-template-columns:repeat(2,1fr)}}.tutorial-overlay{position:fixed;inset:0;z-index:var(--z-modal, 9999);display:flex;align-items:center;justify-content:center;padding:20px;background:#1a4b8c66;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:tutorialFadeIn .2s ease-out}.tutorial-modal{position:relative;width:100%;max-width:420px;padding:2.5rem 2rem 1.5rem;background:var(--paper-bg);background-image:repeating-linear-gradient(transparent 0px,transparent 27px,var(--paper-lines) 27px,var(--paper-lines) 28px);border-radius:var(--border-wobbly-lg);border:3px solid var(--ink-blue);box-shadow:6px 6px #1a4b8c66;animation:tutorialScaleIn .25s ease-out}.tutorial-close{position:absolute;top:12px;right:12px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--paper-bg);border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-xs);color:var(--ink-blue);cursor:pointer;transition:all .2s ease;box-shadow:2px 2px #1a4b8c4d}.tutorial-close:hover{background:var(--highlighter-pink);color:var(--ink-red);border-color:var(--ink-red);transform:translate(-1px,-1px);box-shadow:3px 3px #c41e3a4d}.tutorial-content{text-align:center;min-height:180px;display:flex;flex-direction:column;align-items:center;justify-content:center}.tutorial-icon{font-size:4rem;margin-bottom:1rem;line-height:1;animation:tutorialBounce .4s ease-out}.tutorial-title{font-size:1.5rem;font-weight:700;font-family:var(--font-title);color:var(--ink-blue);margin:0 0 .75rem}.tutorial-description{font-size:1rem;font-family:var(--font-hand);color:var(--ink-blue);line-height:1.6;margin:0;max-width:340px}.tutorial-navigation{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1.5rem;padding-top:1.5rem;border-top:2px dashed var(--paper-lines)}.tutorial-nav-btn{display:flex;align-items:center;justify-content:center;min-width:44px;height:44px;padding:0 1rem;background:var(--paper-bg);border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-sm);color:var(--ink-blue);font-size:.9rem;font-family:var(--font-hand);font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:2px 2px #1a4b8c4d}.tutorial-nav-btn:hover:not(:disabled){background:var(--highlighter-yellow);transform:translate(-1px,-1px);box-shadow:3px 3px #1a4b8c66}.tutorial-nav-btn:disabled{opacity:.3;cursor:not-allowed}.tutorial-dots{display:flex;gap:8px}.tutorial-dot{width:8px;height:8px;padding:0;background:var(--paper-lines);border:2px solid var(--ink-blue);border-radius:50%;cursor:pointer;transition:all .3s ease}.tutorial-dot:hover{background:var(--highlighter-yellow)}.tutorial-dot.active{width:12px;height:12px;background:var(--ink-blue);border-color:var(--ink-blue);box-shadow:2px 2px #1a4b8c66}.tutorial-trigger-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:var(--paper-bg);border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-sm);color:var(--ink-blue);font-size:.85rem;font-family:var(--font-hand);font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:2px 2px #1a4b8c4d}.tutorial-trigger-btn:hover{background:var(--highlighter-yellow);transform:translate(-1px,-1px);box-shadow:3px 3px #1a4b8c66}.tutorial-sidebar{background:var(--paper-bg);background-image:repeating-linear-gradient(transparent 0px,transparent 27px,var(--paper-lines) 27px,var(--paper-lines) 28px);border:3px solid var(--ink-blue);border-radius:var(--border-wobbly-md);padding:1.5rem 1.5rem 1.75rem;box-shadow:4px 4px #1a4b8c66;display:flex;flex-direction:column;width:280px;flex-shrink:0;-webkit-user-select:none;-moz-user-select:none;user-select:none}.tutorial-sidebar-header{font-size:.75rem;font-weight:700;font-family:var(--font-title);text-transform:uppercase;letter-spacing:.1em;color:var(--ink-blue);margin-bottom:1rem}.tutorial-progress{height:6px;background:#fff;border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-xs);margin-bottom:1.25rem;overflow:hidden}.tutorial-progress-bar{height:100%;width:100%;background:linear-gradient(90deg,var(--ink-red),var(--ink-blue));border-radius:var(--border-wobbly-xs);transform-origin:left;animation:progressFill linear forwards}@keyframes progressFill{0%{transform:scaleX(0)}to{transform:scaleX(1)}}.tutorial-sidebar-content{text-align:center;min-height:clamp(180px,30dvh,280px);display:flex;flex-direction:column}.tutorial-sidebar-icon{font-size:3.5rem;line-height:1;margin-bottom:1rem;flex-shrink:0}.tutorial-sidebar-title{font-size:1.1rem;font-weight:700;font-family:var(--font-title);color:var(--ink-blue);margin:0 0 .5rem;flex-shrink:0}.tutorial-sidebar-description{font-size:.9rem;font-family:var(--font-hand);color:var(--ink-blue);line-height:1.5;margin:0;flex:1}.tutorial-sidebar-dots{display:flex;justify-content:center;align-items:center;gap:12px;margin-top:auto;padding-top:1rem;border-top:2px dashed var(--paper-lines)}.tutorial-sidebar-dots button.tutorial-dot-wrapper{position:relative;padding:8px;background:transparent!important;border:none!important;box-shadow:none!important;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:50%;overflow:visible}.tutorial-sidebar-dots button.tutorial-dot-wrapper:before{display:none}.tutorial-sidebar-dots button.tutorial-dot-wrapper .tutorial-dot{width:8px;height:8px;background:var(--paper-lines);border:2px solid var(--ink-blue);border-radius:50%;transition:all .3s cubic-bezier(.34,1.56,.64,1)}.tutorial-sidebar-dots button.tutorial-dot-wrapper:hover .tutorial-dot{background:var(--highlighter-yellow)}.tutorial-sidebar-dots button.tutorial-dot-wrapper.active .tutorial-dot{width:14px;height:14px;background:var(--ink-blue);border-color:var(--ink-blue);animation:dotPop .4s cubic-bezier(.34,1.56,.64,1)}@keyframes dotPop{0%{transform:scale(.6);opacity:.5}50%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}.tutorial-dot-progress{position:absolute;top:50%;left:50%;width:40px;height:40px;transform:translate(-50%,-50%) rotate(-90deg);filter:drop-shadow(0 0 4px rgba(26,75,140,.6))}.tutorial-dot-progress-ring{fill:none;stroke:var(--ink-red);stroke-width:2;stroke-linecap:round;stroke-dasharray:106.81;stroke-dashoffset:106.81;animation:circularProgress 5s linear forwards}@keyframes circularProgress{0%{stroke-dashoffset:106.81}to{stroke-dashoffset:0}}@keyframes tutorialFadeIn{0%{opacity:0}to{opacity:1}}@keyframes tutorialScaleIn{0%{opacity:0;transform:scale(.9) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes tutorialBounce{0%{transform:scale(.8)}50%{transform:scale(1.1)}to{transform:scale(1)}}@media(max-width:480px){.tutorial-modal{padding:2rem 1.5rem 1.25rem;margin:10px;max-width:calc(100% - 20px)}.tutorial-icon{font-size:3rem}.tutorial-title{font-size:1.25rem}.tutorial-description{font-size:.9rem}.tutorial-content{min-height:150px}}@media(prefers-reduced-motion:reduce){.tutorial-overlay,.tutorial-modal,.tutorial-icon{animation:none}.tutorial-nav-btn:hover:not(:disabled){transform:none}}.sidebar-tabs-container{display:flex;flex-direction:column;height:100%;overflow:hidden;background:var(--paper-bg)}.sidebar-tabs{display:flex;border-bottom:3px solid var(--ink-blue);background:var(--paper-bg);flex-shrink:0}.sidebar-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;background:transparent;border:none;color:var(--ink-blue);opacity:.6;font-family:var(--font-hand);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .15s ease;position:relative}.sidebar-tab:hover{opacity:1;background:var(--highlighter-yellow)}.sidebar-tab.active{color:var(--ink-blue);opacity:1;background:var(--highlighter-yellow)}.sidebar-tab.active:after{content:"";position:absolute;bottom:-3px;left:0;right:0;height:3px;background:var(--ink-blue)}.sidebar-tab .tab-icon{font-size:1rem}.sidebar-tab .tab-label{font-weight:600}.sidebar-tab .tab-count{font-size:.75rem;opacity:.7}.sidebar-tab .tab-badge{background:var(--ink-red);color:var(--paper-bg);font-size:.65rem;padding:.125rem .375rem;border-radius:var(--border-wobbly-xs);font-weight:700;animation:badgePulse 2s ease-in-out infinite}@keyframes badgePulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.sidebar-tabs-container .sidebar-content{flex:1;min-height:0;overflow:hidden;background:var(--paper-bg)}@media(min-width:64rem){html.has-filmstrip .app-root.in-room{--zoom-threshold: 200px;--zoom-divisor: 1000px;--zoom-min: .7;--zoom-excess: max(0px, calc(var(--filmstrip-safe-space, 0px) - var(--zoom-threshold)))}html.has-filmstrip .app-root.in-room .lobby-content-wrapper,html.has-filmstrip .app-root.in-room .game-page .main-scroll-area{zoom:clamp(var(--zoom-min),calc(1 - var(--zoom-excess) / var(--zoom-divisor)),1);transition:zoom .15s ease-out}}.language-selector{position:relative;z-index:var(--z-round-start-overlay, 1000)}.language-selector-button{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--paper-bg);border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-sm, 47% 53% 49% 51% / 52% 48% 52% 48%);cursor:pointer;transition:all .2s ease;pointer-events:auto;position:relative;box-shadow:2px 2px #1a4b8c4d}.language-selector-button:hover{background:#1a4b8c0d;transform:translate(-1px,-1px);box-shadow:3px 3px #1a4b8c4d}.language-selector-button:active{transform:translate(1px,1px);box-shadow:1px 1px #1a4b8c4d}.language-selector-button .language-flag{font-size:1.25rem;line-height:1}.language-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:180px;background:var(--paper-bg);border:2px solid var(--ink-blue);border-radius:var(--border-wobbly-md, 48% 52% 50% 50% / 51% 49% 51% 49%);box-shadow:4px 4px #1a4b8c33;z-index:var(--z-mobile-toast, 9999);overflow:hidden;animation:dropdownFadeIn .2s ease;pointer-events:auto}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.language-dropdown-header{padding:.75rem 1rem;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--ink-blue);border-bottom:2px solid var(--paper-lines);background:#1a4b8c0d;font-family:var(--font-hand, inherit)}.language-option{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:transparent;border:none;color:var(--ink-blue);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;text-align:left;font-family:var(--font-hand, inherit);pointer-events:auto}.language-option:hover{background:var(--highlighter-yellow, rgba(255, 255, 0, .3))}.language-option.active{background:var(--highlighter-green, rgba(144, 238, 144, .3));color:var(--ink-green, #228b22)}.language-option .language-flag{font-size:1.2rem;line-height:1}.language-option .language-label{flex:1}.language-option .language-check{color:var(--ink-green, #228b22);font-weight:700}@media(max-width:479px){.language-dropdown{right:0;max-width:250px}}.home-header-controls{display:flex;align-items:center;gap:.5rem}.home-header-menu-language{display:flex;align-items:center;justify-content:space-between}.home-header-menu-language .language-selector{margin-left:auto}.home-header-menu-language .language-selector-button{width:36px;height:36px}.lobby-settings{background:var(--paper-bg, #fefcf3);border:3px solid var(--ink-blue, #1a4b8c);border-radius:4px 12px/12px 4px;padding:var(--spacing-lg);position:relative;box-shadow:4px 4px #1a4b8c26,inset 0 0 40px #1a4b8c08;margin-top:var(--spacing-md)}.lobby-settings:before,.lobby-settings:after{content:"";position:absolute;width:60px;height:24px;background:linear-gradient(135deg,#ffffc8b3,#ffffb480,#ffffc8b3);border:1px solid rgba(200,180,100,.3);transform:rotate(-3deg);box-shadow:0 1px 3px #0000001a;z-index:1}.lobby-settings:before{top:-12px;left:20px}.lobby-settings:after{top:-12px;right:20px;transform:rotate(3deg)}.lobby-settings h3{font-family:var(--font-title, "Gloria Hallelujah", cursive);font-size:1.5rem;color:var(--ink-blue, #1a4b8c);margin:0 0 var(--spacing-lg) 0;padding-bottom:var(--spacing-sm);border-bottom:2px dashed var(--paper-lines, #c4d4e8);text-align:center;position:relative}.lobby-settings h3:after{content:"~";position:absolute;bottom:-8px;left:50%;transform:translate(-50%);font-size:1.2rem;color:var(--paper-lines, #c4d4e8)}.lobby-settings .settings-row{display:flex;flex-direction:row;justify-content:center;gap:var(--spacing-xl);padding:var(--spacing-md) 0;margin-bottom:var(--spacing-md);border-bottom:none;flex-wrap:wrap}.rounds-stepper{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm)}.rounds-stepper .stepper-label{font-family:var(--font-hand, "Patrick Hand", cursive);font-size:1rem;color:var(--ink-blue, #1a4b8c);text-transform:uppercase;letter-spacing:.05em}.rounds-stepper .stepper-controls{display:flex;align-items:center;gap:var(--spacing-sm)}.rounds-stepper .stepper-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;border:2px solid var(--ink-blue, #1a4b8c);border-radius:50%;color:var(--ink-blue, #1a4b8c);cursor:pointer;transition:all .15s ease;font-family:var(--font-hand)}.rounds-stepper .stepper-btn:hover:not(:disabled){background:var(--ink-blue, #1a4b8c);color:var(--paper-bg, #fefcf3);transform:scale(1.1)}.rounds-stepper .stepper-btn:active:not(:disabled){transform:scale(.95)}.rounds-stepper .stepper-btn:disabled{opacity:.3;cursor:not-allowed}.rounds-stepper .stepper-value{font-family:var(--font-title, "Gloria Hallelujah", cursive);font-size:2rem;font-weight:700;color:var(--ink-blue, #1a4b8c);min-width:50px;text-align:center;position:relative}.rounds-stepper .stepper-value:before{content:"";position:absolute;inset:-8px;border:3px solid var(--ink-blue, #1a4b8c);border-radius:50%;opacity:.6}.timer-presets{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm)}.timer-presets .preset-label{font-family:var(--font-hand, "Patrick Hand", cursive);font-size:1rem;color:var(--ink-blue, #1a4b8c);text-transform:uppercase;letter-spacing:.05em}.timer-presets .preset-buttons{display:flex;gap:var(--spacing-xs);flex-wrap:wrap;justify-content:center}.timer-presets .preset-btn{font-family:var(--font-hand, "Patrick Hand", cursive);font-size:.95rem;padding:.4rem .8rem;background:var(--paper-bg, #fefcf3);border:2px solid var(--ink-blue, #1a4b8c);border-radius:3px 8px/8px 3px;color:var(--ink-blue, #1a4b8c);cursor:pointer;transition:all .15s ease;position:relative}.timer-presets .preset-btn:hover:not(:disabled):not(.active){background:#1a4b8c14;transform:translateY(-2px)}.timer-presets .preset-btn.active{background:var(--ink-blue, #1a4b8c);color:var(--paper-bg, #fefcf3);box-shadow:2px 2px #1a4b8c4d}.timer-presets .preset-btn.active:before{content:"✓";position:absolute;top:-8px;right:-8px;font-size:.8rem;background:var(--ink-green, #228b22);color:#fff;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center}.timer-presets .preset-btn:disabled{opacity:.5;cursor:not-allowed}.settings-mode-toggle{display:flex;justify-content:center;gap:0;margin-bottom:var(--spacing-md);border:2px solid var(--ink-blue, #1a4b8c);border-radius:8px;overflow:hidden;background:var(--paper-bg, #fefcf3)}.mode-btn{flex:1;padding:.625rem 1rem;font-family:var(--font-hand, "Patrick Hand", cursive);font-size:.95rem;font-weight:600;color:var(--ink-blue, #1a4b8c);background:var(--paper-bg, #fefcf3);border:none;cursor:pointer;transition:background .15s,color .15s;position:relative}.mode-btn+.mode-btn{border-left:2px solid var(--ink-blue, #1a4b8c)}.mode-btn:hover:not(.active){background:#1a4b8c14}.mode-btn.active{background:var(--ink-blue, #1a4b8c);color:var(--paper-bg, #fefcf3)}.settings-mode-badge{display:inline-block;font-family:var(--font-hand, "Patrick Hand", cursive);font-size:.85rem;font-weight:600;color:var(--paper-bg, #fefcf3);background:var(--ink-blue, #1a4b8c);padding:.25rem .75rem;border-radius:6px;text-align:center;margin-bottom:var(--spacing-sm)}.mode-description{font-family:var(--font-hand, "Patrick Hand", cursive);font-size:.85rem;color:var(--ink-blue, #1a4b8c);opacity:.65;text-align:center;margin:0 0 var(--spacing-md) 0;line-height:1.4}.mode-warning{font-family:var(--font-hand, "Patrick Hand", cursive);font-size:.85rem;font-weight:600;color:var(--ink-red, #c0392b);text-align:center;margin:-.25rem 0 var(--spacing-md) 0}.settings-categories{margin-top:var(--spacing-md)}.settings-categories h4{font-family:var(--font-hand, "Patrick Hand", cursive);font-size:1.1rem;color:var(--ink-blue, #1a4b8c);margin:0 0 var(--spacing-md) 0;display:flex;align-items:center;gap:var(--spacing-sm)}.settings-categories h4:before{content:"📝";font-size:1.2rem}.category-selector{background:transparent}.category-selector.disabled{opacity:.6;pointer-events:none}.category-tabs{display:flex;gap:2px;margin-bottom:-2px;position:relative;z-index:2}.category-tab{font-family:var(--font-hand, "Patrick Hand", cursive);font-size:.9rem;padding:.5rem 1rem;background:var(--paper-lines, #c4d4e8);border:2px solid var(--ink-blue, #1a4b8c);border-bottom:none;border-radius:8px 8px 0 0;color:var(--ink-blue, #1a4b8c);cursor:pointer;transition:all .15s ease;position:relative;top:2px}.category-tab:hover:not(.active){background:#c4d4e8cc;transform:translateY(-2px)}.category-tab.active{background:var(--paper-bg, #fefcf3);border-bottom:2px solid var(--paper-bg, #fefcf3);font-weight:700;z-index:3;top:0}.category-counter{text-align:center;padding:var(--spacing-md);background:var(--paper-bg, #fefcf3);border:2px solid var(--ink-blue, #1a4b8c);border-top:none;font-family:var(--font-hand, "Patrick Hand", cursive);font-size:1rem;color:var(--ink-blue, #1a4b8c)}.category-counter span{padding:.2rem .6rem;border-radius:4px;transition:all .3s ease}.category-counter span.complete{background:linear-gradient(104deg,#90ee9000 .9%,#90ee9066 2.4%,#90ee904d 97.6%,#90ee9000);color:var(--ink-green, #228b22);font-weight:700}.category-chips{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--paper-bg, #fefcf3);border:2px solid var(--ink-blue, #1a4b8c);border-top:none;border-radius:0 0 4px 4px;min-height:100px}.category-chip{font-family:var(--font-hand, "Patrick Hand", cursive);font-size:1rem;padding:.5rem 1rem;background:linear-gradient(145deg,#ffffa5,#fffb8a,#fff876);border:none;border-radius:2px;color:#333;cursor:pointer;transition:all .2s ease;box-shadow:2px 2px 4px #00000026,inset 0 -2px 4px #0000000d;position:relative;transform:rotate(-1deg)}.category-chip:nth-child(2n){transform:rotate(1deg);background:linear-gradient(145deg,#ffb3ba,#ff9aa2,#ff8a93)}.category-chip:nth-child(3n){transform:rotate(-.5deg);background:linear-gradient(145deg,#baffc9,#a5ffb8,#8affab)}.category-chip:nth-child(5n){transform:rotate(1.5deg);background:linear-gradient(145deg,#bae1ff,#a5d4ff,#8ac7ff)}.category-chip:hover:not(:disabled){transform:rotate(0) scale(1.05) translateY(-3px);box-shadow:4px 4px 8px #0003,inset 0 -2px 4px #0000000d;z-index:1}.category-chip:disabled{opacity:.5;cursor:not-allowed}.category-chip.selected{outline:3px solid var(--ink-blue, #1a4b8c);outline-offset:2px;font-weight:700}.category-chip.selected:after{content:"✓";position:absolute;top:-6px;right:-6px;font-size:.7rem;background:var(--ink-blue, #1a4b8c);color:#fff;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center}.category-chip.custom{background:linear-gradient(145deg,#e8d5b7,#d4c4a8,#c9b899);display:flex;align-items:center;gap:var(--spacing-xs)}.category-chip .chip-remove{display:flex;align-items:center;justify-content:center;width:18px;height:18px;background:var(--ink-red, #c41e3a);color:#fff;border-radius:50%;margin-left:var(--spacing-xs);cursor:pointer;transition:transform .15s ease}.category-chip .chip-remove:hover{transform:scale(1.2)}.custom-category-input{display:flex;gap:var(--spacing-xs);align-items:center;width:100%;max-width:280px}.custom-category-input input{flex:1;font-family:var(--font-hand, "Patrick Hand", cursive);font-size:1rem;padding:.5rem .75rem;background:transparent;border:none;border-bottom:2px solid var(--ink-blue, #1a4b8c);border-radius:0;color:var(--ink-blue, #1a4b8c);outline:none;transition:border-color .2s ease}.custom-category-input input:focus{border-bottom-color:var(--ink-green, #228b22);border-bottom-width:3px}.custom-category-input input::-moz-placeholder{color:#1a4b8c66;font-style:italic}.custom-category-input input::placeholder{color:#1a4b8c66;font-style:italic}.custom-category-input .custom-add-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--ink-blue, #1a4b8c);border:none;border-radius:50%;color:var(--paper-bg, #fefcf3);cursor:pointer;transition:all .15s ease}.custom-category-input .custom-add-btn:hover:not(:disabled){background:var(--ink-green, #228b22);transform:scale(1.1)}.custom-category-input .custom-add-btn:disabled{opacity:.3;cursor:not-allowed}.category-empty{font-family:var(--font-hand, "Patrick Hand", cursive);font-size:1rem;color:#1a4b8c80;font-style:italic;text-align:center;padding:var(--spacing-lg);width:100%}.settings-warning{font-family:var(--font-hand, "Patrick Hand", cursive);font-size:1rem;color:var(--ink-red, #c41e3a);text-align:center;padding:var(--spacing-sm) var(--spacing-md);margin-top:var(--spacing-md);background:linear-gradient(104deg,#ffb6c100 .9%,#ffb6c14d 2.4%,#ffb6c133 97.6%,#ffb6c100);border-radius:4px}@media(max-width:767px){.lobby-settings{padding:var(--spacing-md);margin:var(--spacing-sm)}.lobby-settings:before,.lobby-settings:after{width:45px;height:18px}.lobby-settings:before{left:10px}.lobby-settings:after{right:10px}.lobby-settings h3{font-size:1.25rem}.lobby-settings .settings-row{flex-direction:column;gap:var(--spacing-lg);align-items:center}.rounds-stepper .stepper-value{font-size:1.75rem}.category-tabs{flex-wrap:wrap;justify-content:center}.category-tab{font-size:.8rem;padding:.4rem .7rem}.category-chip{font-size:.9rem;padding:.4rem .8rem}.custom-category-input{max-width:100%}}@media(max-width:375px){.timer-presets .preset-buttons{gap:4px}.timer-presets .preset-btn{font-size:.8rem;padding:.3rem .6rem}.category-tab{font-size:.75rem;padding:.35rem .5rem}}.solo-invite-panel{margin:var(--spacing-lg) 0;padding:var(--spacing-lg);background:linear-gradient(135deg,#e9456014,rgba(var(--accent-color-rgb),.08));border:2px solid rgba(var(--accent-color-rgb),.25);border-radius:var(--radius-xl);text-align:center;animation:fadeInUp .4s ease-out}.solo-invite-title{font-family:var(--font-title);font-size:1.2rem;font-weight:700;color:var(--ink-blue);margin-bottom:var(--spacing-md);text-transform:uppercase;letter-spacing:.05em}.solo-invite-code-tiles{display:flex;justify-content:center;gap:var(--spacing-xs);margin-bottom:var(--spacing-lg)}.solo-invite-tile{display:flex;align-items:center;justify-content:center;width:44px;height:52px;background:#e9456026;border:2px solid var(--gb-pink);border-radius:var(--radius-md);font-family:"Orbitron",var(--font-marker),monospace;font-size:1.5rem;font-weight:700;color:var(--gb-pink)}.solo-invite-actions{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.solo-invite-btn{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);min-height:44px;border-radius:var(--radius-md);font-family:var(--font-hand);font-size:.95rem;cursor:pointer;transition:all .2s ease}.solo-invite-btn-copy{background:rgba(var(--accent-color-rgb),.15);border:2px solid rgba(var(--accent-color-rgb),.3);color:var(--accent-color);width:100%}.solo-invite-btn-copy:hover{background:rgba(var(--accent-color-rgb),.25);border-color:var(--accent-color)}.solo-invite-btn-share{background:rgba(var(--accent-color-rgb),.1);border:2px solid rgba(var(--accent-color-rgb),.2);color:var(--accent-color);width:100%}.solo-invite-btn-share:hover{background:rgba(var(--accent-color-rgb),.2);border-color:var(--accent-color)}.solo-invite-hint{font-family:var(--font-hand);font-size:.9rem;color:var(--ink-blue);margin-bottom:var(--spacing-xs)}.solo-invite-subtext{font-family:var(--font-hand);font-size:.8rem;color:#1a4b8c99}@media(max-width:767px){.solo-invite-panel{padding:var(--spacing-sm) var(--spacing-md);margin:var(--spacing-sm) 0}.solo-invite-title{font-size:.9rem;margin-bottom:var(--spacing-xs)}.solo-invite-code-tiles{gap:3px;margin-bottom:var(--spacing-sm)}.solo-invite-tile{width:32px;height:38px;font-size:1.1rem}.solo-invite-actions{flex-direction:row;margin-bottom:var(--spacing-xs)}.solo-invite-btn{padding:var(--spacing-xs) var(--spacing-sm);min-height:36px;font-size:.85rem}.solo-invite-hint{font-size:.8rem;margin-bottom:2px}.solo-invite-subtext{font-size:.75rem}}@media(max-width:374px){.solo-invite-tile{width:28px;height:34px;font-size:1rem}.solo-invite-btn span{display:none}.solo-invite-btn{min-height:32px;padding:var(--spacing-xs)}}@media(prefers-reduced-motion:reduce){.solo-invite-panel{animation:none}}
