: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%}}.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}
