:root{--red-primary: #dc143c;--red-dark: #8b0000;--red-light: #ff4757;--red-glow: #ff6b6b;--red-deep: #4a0011;--gold: #ffd700;--gold-dark: #b8960f;--bg-darkest: #1a0e14;--bg-dark: #261420;--bg-mid: #341c28;--bg-card: #2c1622;--text-primary: #ffe4e8;--text-dim: #a8809a;--text-bright: #ffffff;--border: #502238;--border-glow: #dc143c44;--font-display: "Press Start 2P", monospace;--font-body: "Silkscreen", "DM Mono", monospace;--font-mono: "DM Mono", monospace}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;overflow:hidden}body{background:var(--bg-darkest);color:var(--text-primary);font-family:var(--font-body);-webkit-font-smoothing:antialiased}.scanlines{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;pointer-events:none;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.08) 2px,rgba(0,0,0,.08) 4px)}.noise-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9998;pointer-events:none;opacity:.04;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='1'/%3E%3C/svg%3E");background-repeat:repeat;background-size:256px}.app{height:100%;position:relative;background:radial-gradient(ellipse at 20% 50%,rgba(220,20,60,.06) 0%,transparent 60%),radial-gradient(ellipse at 80% 20%,rgba(220,20,60,.04) 0%,transparent 50%),radial-gradient(ellipse at 50% 100%,rgba(139,0,0,.08) 0%,transparent 40%),var(--bg-darkest)}.title-glow{position:relative;display:inline-block}.game-title{font-family:var(--font-display);font-size:4rem;line-height:1;display:flex;gap:.3em;align-items:baseline;text-shadow:0 0 20px rgba(220,20,60,.8),0 0 40px rgba(220,20,60,.4),0 0 80px rgba(220,20,60,.2);animation:titlePulse 3s ease-in-out infinite}.game-title.small{font-size:2rem}.title-puzzle{color:var(--red-primary);letter-spacing:.08em}.title-2d{color:var(--gold);font-size:.7em;text-shadow:0 0 15px rgba(255,215,0,.6),0 0 30px rgba(255,215,0,.3)}@keyframes titlePulse{0%,to{filter:brightness(1)}50%{filter:brightness(1.15)}}.subtitle{font-family:var(--font-display);font-size:.7rem;color:var(--text-dim);letter-spacing:.5em;margin-top:.8rem;text-transform:uppercase}.round-badges{display:flex;gap:1rem;margin-top:2rem;justify-content:center}.round-badge{background:linear-gradient(135deg,var(--red-deep),var(--bg-dark));border:2px solid var(--red-primary);border-radius:4px;padding:.5rem 1rem;display:flex;flex-direction:column;align-items:center;gap:.2rem;animation:badgePop .4s ease-out backwards;box-shadow:0 0 15px #dc143c4d,inset 0 0 10px #dc143c1a;transition:transform .2s,box-shadow .2s}.round-badge:hover{transform:scale(1.1) translateY(-2px);box-shadow:0 0 25px #dc143c80,inset 0 0 15px #dc143c33}@keyframes badgePop{0%{opacity:0;transform:scale(.5) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.badge-round{font-family:var(--font-display);font-size:.6rem;color:var(--gold)}.badge-pieces{font-family:var(--font-display);font-size:.9rem;color:var(--text-bright)}.home-container{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2.5rem 2rem;gap:2.5rem;overflow-y:auto}.home-hero{text-align:center;animation:heroSlideIn .8s ease-out}@keyframes heroSlideIn{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}.home-form{width:100%;max-width:540px;display:flex;flex-direction:column;gap:1.8rem;animation:formFadeIn .6s ease-out .3s backwards}@keyframes formFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.form-group{display:flex;flex-direction:column;gap:.6rem}.form-label{font-family:var(--font-display);font-size:.55rem;color:var(--red-light);letter-spacing:.15em}.retro-input{width:100%;background:var(--bg-dark);border:2px solid var(--border);color:var(--text-primary);font-family:var(--font-mono);font-size:.95rem;padding:.75rem 1rem;border-radius:4px;outline:none;transition:border-color .3s,box-shadow .3s}.retro-input::placeholder{color:var(--text-dim)}.retro-input:focus{border-color:var(--red-primary);box-shadow:0 0 15px #dc143c4d,inset 0 0 5px #dc143c1a}.upload-zone{background:var(--bg-dark);border:2px dashed var(--border);border-radius:4px;padding:1.5rem;cursor:pointer;transition:border-color .3s,background .3s;min-height:120px;display:flex;align-items:center;justify-content:center}.upload-zone:hover{border-color:var(--red-primary);background:var(--bg-mid)}.upload-placeholder{display:flex;flex-direction:column;align-items:center;gap:.5rem;color:var(--text-dim);font-size:.85rem}.upload-icon{font-size:2rem;animation:puzzleBob 2s ease-in-out infinite}@keyframes puzzleBob{0%,to{transform:translateY(0) rotate(0)}25%{transform:translateY(-5px) rotate(-5deg)}75%{transform:translateY(-3px) rotate(5deg)}}.upload-hint{font-size:.7rem;color:var(--text-dim);opacity:.6}.preview-grid{display:flex;gap:.75rem;width:100%;justify-content:center}.preview-item{position:relative;width:100px;height:75px;border-radius:4px;overflow:hidden;border:2px solid var(--red-primary);box-shadow:0 0 10px #dc143c4d}.preview-item img{width:100%;height:100%;object-fit:cover}.preview-label{position:absolute;bottom:0;right:0;background:var(--red-primary);color:#fff;font-family:var(--font-display);font-size:.45rem;padding:2px 6px}.retro-btn{display:inline-flex;align-items:center;justify-content:center;gap:.6rem;background:linear-gradient(180deg,var(--bg-mid),var(--bg-dark));border:2px solid var(--border);color:var(--text-primary);font-family:var(--font-display);font-size:.6rem;padding:.75rem 1.5rem;border-radius:4px;cursor:pointer;letter-spacing:.1em;transition:all .2s;position:relative;overflow:hidden}.retro-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(220,20,60,.15),transparent);transition:left .5s}.retro-btn:hover:before{left:100%}.retro-btn:hover{border-color:var(--red-primary);box-shadow:0 0 20px #dc143c4d;transform:translateY(-1px)}.retro-btn:active{transform:translateY(1px);box-shadow:0 0 10px #dc143c33}.retro-btn.primary{background:linear-gradient(180deg,var(--red-primary),var(--red-dark));border-color:var(--red-light);color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.5);box-shadow:0 0 15px #dc143c4d,0 4px 15px #0000004d}.retro-btn.primary:hover{background:linear-gradient(180deg,var(--red-light),var(--red-primary));box-shadow:0 0 30px #dc143c80,0 4px 20px #0000004d}.retro-btn.small{font-size:.5rem;padding:.5rem 1rem}.retro-btn.large{font-size:.75rem;padding:1rem 2rem}.retro-btn.cancel{border-color:#444}.retro-btn.cancel:hover{border-color:var(--red-light);background:linear-gradient(180deg,#2a0a0a,#1a0606)}.retro-btn:disabled{opacity:.5;pointer-events:none}.retro-btn.pulse{animation:btnPulse 1.5s ease-in-out infinite}@keyframes btnPulse{0%,to{box-shadow:0 0 15px #dc143c4d}50%{box-shadow:0 0 35px #dc143c99}}.btn-icon{font-size:1.1em}.btn-loading{animation:blink .8s steps(2,start) infinite}@keyframes blink{to{opacity:0}}.error-msg{background:#dc143c26;border:1px solid var(--red-primary);border-radius:4px;padding:.6rem 1rem;color:var(--red-light);font-size:.75rem;font-family:var(--font-mono);animation:shake .4s ease-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.home-footer{text-align:center;animation:formFadeIn .6s ease-out .6s backwards}.pixel-divider{width:200px;height:2px;margin:0 auto 1rem;background:repeating-linear-gradient(90deg,var(--red-primary) 0px,var(--red-primary) 4px,transparent 4px,transparent 8px);opacity:.4}.footer-text{font-size:.75rem;color:var(--text-dim)}.join-container{height:100%;display:flex;align-items:center;justify-content:center;padding:2rem}.join-card{background:var(--bg-card);border:2px solid var(--border);border-radius:8px;padding:2.5rem;max-width:420px;width:100%;text-align:center;display:flex;flex-direction:column;gap:1.5rem;box-shadow:0 0 40px #dc143c1a,0 20px 60px #00000080;animation:cardSlideUp .5s ease-out;position:relative}.back-btn-inline{align-self:flex-start;padding:.35rem .8rem!important;font-size:.55rem!important;min-width:auto!important}@keyframes cardSlideUp{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.join-invite{display:flex;flex-direction:column;align-items:center;gap:.5rem}.invite-icon{font-size:2.5rem;animation:puzzleBob 2s ease-in-out infinite}.join-invite p{color:var(--text-dim);font-size:.85rem}.lobby-container{height:100%;display:flex;align-items:center;justify-content:center;padding:2rem;overflow-y:auto}.lobby-card{background:var(--bg-card);border:2px solid var(--border);border-radius:8px;padding:2.5rem;max-width:560px;width:100%;display:flex;flex-direction:column;gap:1.5rem;align-items:center;box-shadow:0 0 40px #dc143c1a,0 20px 60px #00000080;animation:cardSlideUp .5s ease-out}.lobby-section{width:100%}.section-title{font-family:var(--font-display);font-size:.55rem;color:var(--red-light);letter-spacing:.2em;margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem}.player-count{background:var(--red-primary);color:#fff;font-size:.5rem;padding:2px 8px;border-radius:10px}.share-row{display:flex;gap:.5rem}.share-input{flex:1;font-size:.7rem}.player-list{display:flex;flex-direction:column;gap:.5rem}.player-row{display:flex;align-items:center;gap:.6rem;background:var(--bg-dark);padding:.6rem .8rem;border-radius:4px;border:1px solid var(--border);animation:playerSlideIn .3s ease-out backwards}@keyframes playerSlideIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.player-icon{font-size:1.1rem}.player-name{font-family:var(--font-mono);font-size:.85rem;flex:1}.player-badge{font-family:var(--font-display);font-size:.4rem;background:var(--gold);color:var(--bg-darkest);padding:2px 8px;border-radius:3px;letter-spacing:.1em}.rounds-preview{display:flex;gap:.75rem}.round-preview-card{flex:1;background:var(--bg-dark);border:1px solid var(--border);border-radius:4px;padding:.6rem;text-align:center;display:flex;flex-direction:column;gap:.2rem}.round-num{font-family:var(--font-display);font-size:.65rem;color:var(--gold)}.round-detail{font-size:.8rem;color:var(--text-primary)}.round-grid{font-size:.7rem;color:var(--text-dim)}.waiting-msg{text-align:center;color:var(--text-dim);font-size:.85rem}.waiting-dots span{animation:dotBounce 1.4s ease-in-out infinite;display:inline-block;font-size:2rem;color:var(--red-primary)}.waiting-dots span:nth-child(2){animation-delay:.2s}.waiting-dots span:nth-child(3){animation-delay:.4s}@keyframes dotBounce{0%,80%,to{transform:translateY(0)}40%{transform:translateY(-8px)}}.game-container{height:100%;display:flex;flex-direction:column;position:relative}.game-hud{display:flex;align-items:center;justify-content:space-between;padding:.6rem 1rem;background:linear-gradient(180deg,var(--bg-mid),var(--bg-darkest));border-bottom:2px solid var(--border);z-index:10;flex-shrink:0}.hud-left,.hud-right{display:flex;align-items:center;gap:1.5rem}.hud-round,.hud-pieces{display:flex;flex-direction:column;gap:.1rem}.hud-label{font-family:var(--font-display);font-size:.4rem;color:var(--text-dim);letter-spacing:.2em}.hud-value{font-family:var(--font-display);font-size:.7rem;color:var(--text-bright)}.pieces-placed{color:var(--gold)}.pieces-sep{color:var(--text-dim);margin:0 2px}.hud-center{display:flex;flex-direction:column;align-items:center;gap:.4rem}.hud-timer{display:flex;align-items:center;gap:.5rem}.timer-icon{font-size:1rem}.timer-value{font-family:var(--font-display);font-size:1rem;color:var(--red-light);text-shadow:0 0 10px rgba(220,20,60,.5);min-width:100px;text-align:center}.progress-bar{width:200px;height:6px;background:var(--bg-dark);border-radius:3px;border:1px solid var(--border);overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--red-dark),var(--red-primary),var(--gold));border-radius:3px;transition:width .3s ease-out;box-shadow:0 0 8px #dc143c80}.opponents-sidebar{position:absolute;right:.5rem;top:65px;z-index:5;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;padding:.6rem;width:180px;opacity:.85;transition:opacity .3s;box-shadow:0 4px 20px #00000080}.opponents-sidebar:hover{opacity:1}.opponents-title{font-family:var(--font-display);font-size:.4rem;color:var(--text-dim);letter-spacing:.2em;margin-bottom:.5rem}.opponent-card{padding:.4rem 0;border-bottom:1px solid var(--border)}.opponent-card:last-child{border-bottom:none}.opponent-name{font-family:var(--font-mono);font-size:.7rem;color:var(--text-primary)}.opponent-progress{display:flex;align-items:center;gap:.4rem;margin-top:.2rem}.opponent-bar{flex:1;height:4px;background:var(--bg-dark);border-radius:2px;overflow:hidden}.opponent-fill{height:100%;background:var(--red-primary);transition:width .5s ease-out;border-radius:2px}.opponent-count{font-size:.55rem;color:var(--text-dim);font-family:var(--font-mono)}.opponent-done{display:block;font-family:var(--font-display);font-size:.4rem;color:var(--gold);margin-top:.2rem}.puzzle-area{flex:1;position:relative;overflow:hidden;background:radial-gradient(circle at 50% 50%,rgba(30,12,20,.9),var(--bg-darkest)),repeating-linear-gradient(0deg,transparent,transparent 39px,rgba(220,20,60,.03) 39px,rgba(220,20,60,.03) 40px),repeating-linear-gradient(90deg,transparent,transparent 39px,rgba(220,20,60,.03) 39px,rgba(220,20,60,.03) 40px)}.puzzle-canvas{display:block;width:100%;height:100%}.loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;background:#0a0406e6;color:var(--text-dim)}.timelapse-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:20;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;padding-bottom:2rem;background:linear-gradient(180deg,rgba(26,14,20,.3) 0%,transparent 30%,transparent 70%,rgba(26,14,20,.4) 100%);animation:timelapseIn .4s ease-out;box-shadow:inset 0 0 120px #0006}@keyframes timelapseIn{0%{opacity:0}to{opacity:1}}.timelapse-badge{display:flex;align-items:center;gap:.5rem;background:#dc143cd9;border:2px solid var(--red-light);color:#fff;font-family:var(--font-display);font-size:.6rem;letter-spacing:.25em;padding:.5rem 1.2rem;border-radius:4px;box-shadow:0 0 20px #dc143c99,0 0 60px #dc143c33;animation:timelapsePulse .8s ease-in-out infinite alternate}.timelapse-icon{animation:timelapseSpin .6s linear infinite}@keyframes timelapseSpin{0%{transform:rotate(0)}to{transform:rotate(-360deg)}}@keyframes timelapsePulse{0%{box-shadow:0 0 20px #dc143c99,0 0 60px #dc143c33;text-shadow:0 0 8px rgba(255,255,255,.5)}to{box-shadow:0 0 30px #dc143ccc,0 0 80px #dc143c4d;text-shadow:0 0 15px rgba(255,255,255,.8)}}.timelapse-progress{margin-top:.75rem;width:180px;height:4px;background:#50223899;border-radius:2px;overflow:hidden}.timelapse-bar{height:100%;width:0%;background:linear-gradient(90deg,var(--red-primary),var(--gold));border-radius:2px;animation:timelapseProgress 5s linear forwards;box-shadow:0 0 8px #ffd70080}@keyframes timelapseProgress{0%{width:0%}to{width:100%}}.preview-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:20;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding-top:1.5rem;background:linear-gradient(180deg,rgba(26,14,20,.45) 0%,transparent 35%,transparent 65%,rgba(26,14,20,.25) 100%);animation:previewIn .3s ease-out;box-shadow:inset 0 0 120px #0000004d}@keyframes previewIn{0%{opacity:0}to{opacity:1}}.preview-badge{display:flex;align-items:center;gap:.5rem;background:#b48c14e6;border:2px solid var(--gold);color:#1a0e14;font-family:var(--font-display);font-size:.6rem;letter-spacing:.25em;padding:.5rem 1.2rem;border-radius:4px;box-shadow:0 0 20px #ffd70080,0 0 60px #ffd70026;animation:previewPulse 1s ease-in-out infinite alternate}.preview-icon{animation:previewBlink 1.2s ease-in-out infinite alternate}@keyframes previewBlink{0%{opacity:.6}to{opacity:1}}@keyframes previewPulse{0%{box-shadow:0 0 20px #ffd70080,0 0 60px #ffd70026}to{box-shadow:0 0 30px #ffd700b3,0 0 80px #ffd70040}}.loading-screen{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem}.loading-spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--red-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{font-family:var(--font-display);font-size:.6rem;color:var(--text-dim);letter-spacing:.3em;animation:blink 1s steps(2) infinite}.error-screen{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem}.error-title{font-family:var(--font-display);font-size:2rem;color:var(--red-primary);text-shadow:0 0 30px rgba(220,20,60,.5)}.error-text{color:var(--text-dim)}.round-complete-container,.game-complete-container{height:100%;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.confetti{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.confetti-piece{position:absolute;width:8px;height:8px;background:var(--color);top:-10px;left:var(--x);animation:confettiFall var(--duration) ease-in var(--delay) infinite;opacity:.8}.confetti-piece:nth-child(odd){border-radius:50%}.confetti-piece:nth-child(3n){width:6px;height:12px}@keyframes confettiFall{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(100vh) rotate(720deg);opacity:0}}.round-complete-content,.complete-content{position:relative;z-index:1;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding:2rem}.round-complete-title{font-family:var(--font-display);font-size:1.2rem;color:var(--gold);text-shadow:0 0 20px rgba(255,215,0,.5);opacity:0;transform:scale(.5);transition:all .6s cubic-bezier(.175,.885,.32,1.275)}.round-complete-title.visible{opacity:1;transform:scale(1)}.round-image-reveal{opacity:0;transform:scale(.8) rotateX(10deg);transition:all .8s cubic-bezier(.175,.885,.32,1.275)}.round-image-reveal.visible{opacity:1;transform:scale(1) rotateX(0)}.image-frame{border:4px solid var(--red-primary);border-radius:8px;overflow:hidden;box-shadow:0 0 30px #dc143c66,0 20px 60px #00000080;max-width:400px}.completed-image{display:block;width:100%;max-height:300px;object-fit:contain}.round-stats{display:flex;gap:1.5rem;opacity:0;transform:translateY(20px);transition:all .5s ease-out}.round-stats.visible{opacity:1;transform:translateY(0)}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:6px;padding:.8rem 1.2rem;display:flex;flex-direction:column;gap:.3rem;align-items:center;box-shadow:0 4px 20px #0000004d}.stat-label{font-family:var(--font-display);font-size:.4rem;color:var(--text-dim);letter-spacing:.2em}.stat-value{font-family:var(--font-display);font-size:.9rem;color:var(--gold);text-shadow:0 0 10px rgba(255,215,0,.3)}.complete-title{font-family:var(--font-display);font-size:2rem;color:var(--gold);text-shadow:0 0 30px rgba(255,215,0,.5);animation:titlePulse 2s ease-in-out infinite}.complete-subtitle{font-family:var(--font-display);font-size:.6rem;color:var(--text-dim);letter-spacing:.3em}.leaderboard{width:100%;max-width:400px;display:flex;flex-direction:column;gap:.5rem}.leaderboard-row{display:flex;align-items:center;gap:.8rem;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;padding:.8rem 1rem;animation:playerSlideIn .4s ease-out backwards}.leaderboard-row.gold{border-color:var(--gold-dark);box-shadow:0 0 20px #ffd70026}.lb-rank{font-size:1.3rem;min-width:30px;text-align:center}.lb-name{flex:1;font-family:var(--font-mono);font-size:.85rem}.lb-rounds{font-size:.7rem;color:var(--text-dim)}.lb-time{font-family:var(--font-display);font-size:.6rem;color:var(--gold)}.no-data{color:var(--text-dim);text-align:center;padding:2rem}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-darkest)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--red-dark)}@media (max-width: 640px){.game-title{font-size:2.5rem}.game-title.small{font-size:1.5rem}.hud-timer .timer-value{font-size:.7rem}.progress-bar{width:120px}.opponents-sidebar{width:140px;font-size:.8em}.form-row{flex-direction:column}.stat-card{padding:.5rem .8rem}.browse-grid{grid-template-columns:1fr}}.volume-control{position:fixed;bottom:1rem;left:1rem;z-index:9000;display:flex;flex-direction:column;align-items:center}.volume-panel{display:flex;gap:0;padding:.6rem .5rem;margin-bottom:.4rem;background:var(--bg-card);border:2px solid var(--border);border-radius:8px;box-shadow:0 4px 24px #0009,0 0 12px #dc143c26;opacity:0;visibility:hidden;transform:translateY(8px) scale(.9);transition:all .25s cubic-bezier(.175,.885,.32,1.275);pointer-events:none}.volume-panel.visible{opacity:1;visibility:visible;transform:translateY(0) scale(1);pointer-events:auto}.vol-channel{display:flex;flex-direction:column;align-items:center;gap:.35rem;padding:0 .35rem}.vol-channel-label{font-family:var(--font-display);font-size:.35rem;color:var(--text-dim);letter-spacing:.2em;white-space:nowrap}.vol-divider{width:1px;align-self:stretch;margin:0 .2rem;background:var(--border)}.vol-channel-btn{background:none;border:1px solid transparent;border-radius:4px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-primary);transition:border-color .2s,color .2s,background .2s}.vol-channel-btn:hover{border-color:var(--red-primary);color:var(--red-light);background:#dc143c1a}.volume-pct{font-family:var(--font-display);font-size:.45rem;color:var(--gold);letter-spacing:.1em;text-shadow:0 0 6px rgba(255,215,0,.3);min-width:30px;text-align:center}.volume-track-wrapper{width:28px;height:90px;display:flex;align-items:center;justify-content:center}.volume-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:90px;height:6px;background:transparent;transform:rotate(-90deg);transform-origin:center center;outline:none;cursor:pointer}.volume-slider::-webkit-slider-runnable-track{height:6px;border-radius:3px;background:linear-gradient(90deg,var(--red-dark),var(--red-primary) 50%,var(--gold));border:1px solid var(--border)}.volume-slider::-moz-range-track{height:6px;border-radius:3px;background:linear-gradient(90deg,var(--red-dark),var(--red-primary) 50%,var(--gold));border:1px solid var(--border)}.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--text-bright);border:2px solid var(--red-primary);margin-top:-4px;box-shadow:0 0 8px #dc143c80,0 2px 4px #0006;cursor:pointer;transition:box-shadow .2s,transform .15s}.volume-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--text-bright);border:2px solid var(--red-primary);box-shadow:0 0 8px #dc143c80,0 2px 4px #0006;cursor:pointer;transition:box-shadow .2s,transform .15s}.volume-slider::-webkit-slider-thumb:hover{box-shadow:0 0 14px #dc143ccc,0 2px 6px #00000080;transform:scale(1.15)}.volume-slider::-moz-range-thumb:hover{box-shadow:0 0 14px #dc143ccc,0 2px 6px #00000080;transform:scale(1.15)}.mute-btn{background:var(--bg-card);border:2px solid var(--border);border-radius:50%;width:36px;height:36px;opacity:.6;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-primary);transition:border-color .3s,box-shadow .3s,transform .2s,opacity .3s;box-shadow:0 2px 12px #00000080}.volume-control:hover .mute-btn{border-color:var(--red-primary);box-shadow:0 0 15px #dc143c4d;transform:scale(1.1);opacity:1}.form-row{display:flex;gap:1rem}.rounds-config{display:flex;flex-direction:column;gap:.5rem}.round-config-row{display:flex;align-items:center;gap:.7rem;background:var(--bg-dark);border:1px solid var(--border);border-radius:4px;padding:.5rem .75rem}.round-config-label{font-family:var(--font-display);font-size:.55rem;color:var(--gold);min-width:24px}.round-input{width:70px;padding:.4rem .5rem;font-size:.85rem;text-align:center}.round-config-grid{font-family:var(--font-mono);font-size:.7rem;color:var(--text-dim);min-width:40px}.round-remove-btn{background:none;border:1px solid var(--border);border-radius:3px;color:var(--text-dim);cursor:pointer;padding:2px 6px;font-size:.7rem;transition:all .2s}.round-remove-btn:hover{border-color:var(--red-primary);color:var(--red-light)}.browse-container{height:100%;padding:2.5rem;overflow-y:auto;max-width:900px;margin:0 auto}.browse-header{text-align:center;margin-bottom:2.5rem;padding-bottom:1.5rem;border-bottom:2px solid var(--border)}.back-link{font-family:var(--font-display);font-size:.5rem;color:var(--text-dim);text-decoration:none;letter-spacing:.1em;transition:color .2s}.back-link:hover{color:var(--red-light)}.browse-title{font-family:var(--font-display);font-size:1.2rem;color:var(--red-primary);margin:1rem 0 .3rem;text-shadow:0 0 15px rgba(220,20,60,.5)}.browse-subtitle{font-size:.8rem;color:var(--text-dim)}.browse-empty{text-align:center;padding:3rem;display:flex;flex-direction:column;align-items:center;gap:1rem}.empty-icon{font-size:3rem;animation:puzzleBob 2s ease-in-out infinite}.browse-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.browse-card{background:linear-gradient(135deg,var(--bg-card),var(--bg-dark));border:2px solid var(--border);border-left:4px solid var(--red-primary);border-radius:6px;padding:1.2rem 1.2rem 1.2rem 1.4rem;cursor:pointer;transition:all .3s;animation:cardSlideUp .4s ease-out backwards}.browse-card:hover{border-color:var(--red-primary);box-shadow:0 0 20px #dc143c33;transform:translateY(-2px)}.browse-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.6rem}.browse-card-name{font-family:var(--font-display);font-size:.6rem;color:var(--text-primary);line-height:1.4}.browse-card-date{font-size:.65rem;color:var(--text-dim);white-space:nowrap}.browse-card-meta{display:flex;gap:1rem;margin-bottom:.6rem}.browse-meta-item{font-size:.7rem;color:var(--text-dim);display:flex;align-items:center;gap:.3rem}.meta-icon{font-size:.85rem}.browse-card-action{font-family:var(--font-display);font-size:.5rem;color:var(--red-light);letter-spacing:.1em;text-align:right;opacity:0;transition:opacity .2s}.browse-card:hover .browse-card-action{opacity:1}.browse-link{display:inline-block;margin-top:1rem;font-family:var(--font-display);font-size:.5rem;color:var(--text-dim);text-decoration:none;letter-spacing:.15em;transition:color .2s;padding:.4rem 0}.browse-link:hover{color:var(--red-light)}.lobby-game-name{font-family:var(--font-display);font-size:.6rem;color:var(--gold);text-align:center;letter-spacing:.1em;margin-top:.5rem}.join-game-name{font-family:var(--font-display);font-size:.55rem;color:var(--gold);margin-top:.4rem}.round-image-picker{width:38px;height:38px;border:2px dashed var(--border);border-radius:4px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .25s;color:var(--text-dim);flex-shrink:0;overflow:hidden}.round-image-picker:hover{border-color:var(--red-primary);color:var(--red-light);background:var(--bg-mid)}.round-image-picker.has-image{border-style:solid;border-color:var(--red-primary);box-shadow:0 0 8px #dc143c4d}.round-image-thumb{width:100%;height:100%;object-fit:cover}.opponent-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.opponent-round{font-family:var(--font-display);font-size:.4rem;color:var(--bg-darkest);background:var(--gold);padding:1px 5px;border-radius:2px;letter-spacing:.05em}.empty-icon-svg{color:var(--text-dim);animation:puzzleBob 2s ease-in-out infinite}.stat-card.highlight{border-color:var(--gold);box-shadow:0 0 15px #ffd7004d,inset 0 0 8px #ffd7001a;background:linear-gradient(135deg,var(--bg-dark),rgba(255,215,0,.05))}.stat-score{color:var(--gold)!important;text-shadow:0 0 10px rgba(255,215,0,.5)}.next-round-area{display:flex;flex-direction:column;align-items:center;gap:.8rem}.wait-opponents-hint{font-size:.7rem;color:var(--text-dim);display:flex;align-items:center}.wait-opponents-hint em{font-style:italic}.lb-score{font-family:var(--font-display);font-size:.55rem;color:var(--gold);display:flex;align-items:center}.nuke-btn{display:flex;align-items:center;gap:.4rem;background:linear-gradient(180deg,#2a1a00,#1a0e00);border:2px solid #554400;color:#860;font-family:var(--font-display);font-size:.5rem;padding:.4rem .8rem;border-radius:4px;cursor:pointer;position:relative;transition:all .3s;overflow:hidden;min-width:80px}.nuke-btn:disabled{opacity:.6;cursor:default}.nuke-btn.ready{background:linear-gradient(180deg,#3a1500,#2a0a00);border-color:#f60;color:#f80;animation:nukeReady 1.2s ease-in-out infinite;box-shadow:0 0 15px #ff640066}.nuke-btn.ready:hover{box-shadow:0 0 25px #ff640099;transform:translateY(-1px)}.nuke-btn.targeting{border-color:#f40;box-shadow:0 0 20px #ff440080}@keyframes nukeReady{0%,to{box-shadow:0 0 15px #ff640066}50%{box-shadow:0 0 30px #ff6400b3}}.nuke-icon{font-size:1rem;line-height:1}.nuke-label{font-size:.5rem;letter-spacing:.1em}.nuke-charge-bar{position:absolute;bottom:2px;left:4px;right:4px;height:3px;background:#0006;border-radius:2px;overflow:hidden}.nuke-charge-fill{height:100%;background:linear-gradient(90deg,#840,#f80);border-radius:2px;transition:width .15s linear;box-shadow:0 0 4px #ff880080}.opponents-sidebar.nuke-select-mode{border-color:#f60;box-shadow:0 0 25px #ff640066;opacity:1}.nuke-select-header{display:flex;align-items:center;gap:.4rem;font-family:var(--font-display);font-size:.45rem;color:#f60;letter-spacing:.2em;margin-bottom:.5rem;padding-bottom:.4rem;border-bottom:1px solid rgba(255,100,0,.3);animation:nukeFlicker .8s ease-in-out infinite alternate}@keyframes nukeFlicker{0%{opacity:.7}to{opacity:1}}.opponent-card.nuke-targetable{cursor:crosshair;border:1px solid transparent;border-radius:4px;padding:.5rem;margin:0 -.1rem;transition:all .2s}.opponent-card.nuke-targetable:hover{border-color:#f60;background:#ff64001a;box-shadow:0 0 10px #ff640033}.nuke-target-label{display:flex;align-items:center;gap:.3rem;font-family:var(--font-display);font-size:.4rem;color:#f60;margin-top:.3rem;letter-spacing:.15em;opacity:0;transition:opacity .2s}.opponent-card.nuke-targetable:hover .nuke-target-label{opacity:1}.nuke-targets-loading{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem 0;color:var(--text-dim);font-family:var(--font-display);font-size:.4rem;letter-spacing:.1em}.nuke-targets-loading .loading-spinner{width:20px;height:20px;border-width:2px}.nuke-targets-empty{text-align:center;padding:.8rem 0;color:var(--text-dim);font-family:var(--font-display);font-size:.4rem;letter-spacing:.1em}.nuke-cancel-btn{width:100%;margin-top:.5rem;background:#6428284d;border:1px solid #664444;border-radius:4px;color:var(--text-dim);font-family:var(--font-display);font-size:.4rem;padding:.4rem;cursor:pointer;letter-spacing:.1em;transition:all .2s}.nuke-cancel-btn:hover{border-color:var(--red-light);color:var(--red-light);background:#dc143c1a}.nuke-target-overlay-wrapper{position:absolute;top:0;right:0;bottom:0;left:0;z-index:15;pointer-events:none}.nuke-target-title{position:absolute;top:.6rem;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:.5rem;font-family:var(--font-display);font-size:.6rem;color:#f60;letter-spacing:.15em;text-shadow:0 0 15px rgba(255,100,0,.6);background:#1a0e14d9;padding:.4rem 1rem;border:1px solid rgba(255,100,0,.5);border-radius:4px;z-index:16;pointer-events:none;animation:nukeFlicker .8s ease-in-out infinite alternate}.nuke-target-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);border:2px solid rgba(255,100,50,.7);box-shadow:0 0 30px #ff64324d,inset 0 0 30px #ff64320d;pointer-events:auto;z-index:15;animation:targetGridIn .3s ease-out}@keyframes targetGridIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.nuke-target-cell{border:1px solid rgba(255,100,50,.3);display:flex;align-items:center;justify-content:center;cursor:crosshair;transition:background .15s,box-shadow .15s;background:#ff321408}.nuke-target-cell:hover{background:#ff321440;box-shadow:inset 0 0 30px #ff643233}.nuke-cell-crosshair{color:#ff643240;transition:color .15s,transform .15s;pointer-events:none}.nuke-target-cell:hover .nuke-cell-crosshair{color:#ff6432e6;transform:scale(1.2)}.nuke-warning-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:25;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;background:#ff00001f;animation:nukeWarningFlash .4s ease-in-out infinite alternate;pointer-events:none}@keyframes nukeWarningFlash{0%{background:#ff000014}to{background:#f003}}.nuke-warning-icon{font-size:4rem;animation:nukeWarnSpin 1s linear infinite;filter:drop-shadow(0 0 20px rgba(255,60,0,.8))}@keyframes nukeWarnSpin{0%{transform:rotate(0) scale(1)}25%{transform:rotate(90deg) scale(1.1)}50%{transform:rotate(180deg) scale(1)}75%{transform:rotate(270deg) scale(1.1)}to{transform:rotate(360deg) scale(1)}}.nuke-warning-text{font-family:var(--font-display);font-size:1.5rem;color:#f44;text-shadow:0 0 20px rgba(255,0,0,.8),0 0 40px rgba(255,0,0,.4),0 0 80px rgba(255,0,0,.2);animation:nukeWarnPulse .3s ease-in-out infinite alternate}@keyframes nukeWarnPulse{0%{transform:scale(1);opacity:.9}to{transform:scale(1.05);opacity:1}}.nuke-warning-from{font-family:var(--font-display);font-size:.55rem;color:var(--text-dim);letter-spacing:.2em}.nuke-launched-toast{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:50;display:flex;align-items:center;gap:.6rem;font-family:var(--font-display);font-size:.8rem;color:#f80;text-shadow:0 0 15px rgba(255,100,0,.8);background:#1a0e14e6;padding:.8rem 1.5rem;border:2px solid #ff6600;border-radius:6px;box-shadow:0 0 30px #ff640066;animation:nukeToastIn .3s ease-out;letter-spacing:.15em;pointer-events:none}.nuke-launched-icon{font-size:1.3rem}@keyframes nukeToastIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.8)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.nuke-result-toast{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:50;display:flex;align-items:center;gap:.7rem;font-family:var(--font-display);background:#1a0e14eb;padding:.8rem 1.5rem;border-radius:6px;animation:nukeToastIn .3s ease-out;pointer-events:none;letter-spacing:.1em}.nuke-result-toast.hit{border:2px solid #00cc66;box-shadow:0 0 30px #0c66}.nuke-result-toast.miss{border:2px solid #666;box-shadow:0 0 15px #6464644d}.nuke-result-icon{font-size:1.5rem;line-height:1}.nuke-result-body{display:flex;flex-direction:column;gap:.15rem}.nuke-result-title{font-size:.7rem}.hit .nuke-result-title{color:#0f8;text-shadow:0 0 12px rgba(0,255,136,.5)}.miss .nuke-result-title{color:#999}.nuke-result-detail{font-size:.45rem;letter-spacing:.05em}.hit .nuke-result-detail{color:#8da}.miss .nuke-result-detail{color:#777}@media (max-width: 640px){.nuke-btn{min-width:60px;padding:.3rem .5rem;font-size:.4rem}.nuke-icon{font-size:.8rem}.nuke-warning-text{font-size:1rem}.nuke-warning-icon{font-size:2.5rem}.nuke-target-title{font-size:.45rem}}.quit-confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;background:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .15s ease-out}.quit-confirm-dialog{background:var(--bg-card);border:2px solid var(--border);border-radius:8px;padding:2rem 2.5rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:.75rem;box-shadow:0 0 40px #dc143c33,0 20px 60px #0009;animation:cardSlideUp .2s ease-out;min-width:280px}.quit-confirm-icon{color:var(--red-primary);opacity:.7}.quit-confirm-title{font-family:var(--font-display);font-size:1rem;letter-spacing:.15em;color:var(--text-primary);margin:0}.quit-confirm-body{font-size:.75rem;color:var(--text-dim);margin:0}.quit-confirm-actions{display:flex;gap:.75rem;margin-top:.5rem}
