:root{--bg:#0a0a0a;--surface:#141414;--surface2:#1e1e1e;--border:#2a2a2a;--accent:#1db954;--accent2:#ff6b35;--text:#f0f0f0;--text-dim:#888;--danger:#e74c3c;--gold:#f5c842}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}body{background:var(--bg);color:var(--text);overscroll-behavior-y:contain;min-height:100vh;font-family:DM Sans,sans-serif;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:0;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='0.03'/%3E%3C/svg%3E");position:fixed;inset:0}.screen{z-index:1;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:24px 20px;display:none;position:relative}.screen.active{display:flex}.logo{letter-spacing:4px;background:linear-gradient(135deg, var(--accent) 0%, #17a349 50%, var(--accent2) 100%);-webkit-text-fill-color:transparent;text-align:center;-webkit-background-clip:text;background-clip:text;font-family:Bebas Neue,sans-serif;font-size:64px;line-height:1}.logo-sub{letter-spacing:6px;text-transform:uppercase;color:var(--text-dim);text-align:center;margin-top:4px;margin-bottom:40px;font-size:12px}.home-bug-btn{background:var(--surface2);border:1px solid var(--border);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;transition:color .15s;display:flex;position:absolute;bottom:20px;right:20px}.home-friends-btn{background:var(--surface2);border:1px solid var(--border);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;transition:color .15s;display:flex;position:absolute;top:20px;right:20px}.home-icon-badge{background:var(--danger);color:#fff;text-align:center;border-radius:10px;min-width:18px;padding:2px 6px;font-size:10px;font-weight:700}.home-friends-btn .home-icon-badge{min-width:14px;padding:1px 4px;font-size:9px;position:absolute;top:-2px;right:-2px}.home-hero-btn{color:#000;text-align:center;cursor:pointer;border:none;border-radius:16px;width:100%;padding:24px;font-family:DM Sans,sans-serif;position:relative;overflow:hidden}.home-hero-btn:active:after{content:"";background:#0000001a;position:absolute;inset:0}.home-hero-green{background:linear-gradient(135deg, var(--accent), #17a349)}.home-hero-orange{background:linear-gradient(135deg,#f07535,#d45a20)}.home-hero-label{letter-spacing:3px;text-transform:uppercase;opacity:.7;margin-bottom:4px;font-size:10px}.home-hero-title{letter-spacing:2px;text-shadow:0 1px 2px #0003;font-family:Bebas Neue,sans-serif;font-size:30px}.home-hero-desc{opacity:.8;margin-top:4px;font-size:12px}.home-divider{align-items:center;gap:12px;padding:8px 0;display:flex}.home-divider-line{background:var(--border);flex:1;height:1px}.home-divider-text{letter-spacing:2px;text-transform:uppercase;color:var(--text-dim);font-size:10px}.home-secondary-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.home-secondary-btn{background:var(--surface);border:1px solid var(--border);cursor:pointer;text-align:center;color:var(--text);border-radius:12px;padding:24px 16px;font-family:DM Sans,sans-serif;transition:border-color .2s}.home-secondary-btn:hover{border-color:var(--text-dim)}.home-signin-link{width:100%;color:var(--accent);cursor:pointer;background:0 0;border:none;padding:12px;font-family:DM Sans,sans-serif;font-size:14px}.home-signin-link:hover{text-decoration:underline}.card{background:var(--surface);border:1px solid var(--border);border-radius:16px;width:100%;max-width:380px;padding:24px}.card-title{letter-spacing:2px;color:var(--text-dim);margin-bottom:16px;font-family:Bebas Neue,sans-serif;font-size:22px}input[type=number]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}input[type=number]::-webkit-inner-spin-button{opacity:1;cursor:pointer;border-left:1px solid var(--border);background:0 0}input[type=number]::-webkit-outer-spin-button{opacity:1;cursor:pointer;border-left:1px solid var(--border);background:0 0}input[type=checkbox]{appearance:none;border:1.5px solid var(--border);background:var(--surface2);cursor:pointer;border-radius:3px;width:16px;min-width:16px;height:16px;transition:background .15s,border-color .15s;position:relative}input[type=checkbox]:checked{background:#666;border-color:#666}input[type=checkbox]:checked:after{content:"";border:2px solid #f0f0f0;border-top:none;border-left:none;width:5px;height:9px;position:absolute;top:1px;left:4px;transform:rotate(45deg)}input[type=text],input[type=password]{background:var(--surface2);border:1px solid var(--border);width:100%;color:var(--text);-webkit-appearance:none;border-radius:10px;outline:none;padding:14px 16px;font-family:DM Sans,sans-serif;font-size:16px;transition:border-color .2s}input:focus{border-color:var(--accent)}.password-wrap{position:relative}.password-wrap input{padding-right:48px}.password-toggle{cursor:pointer;color:var(--text-dim);background:0 0;border:none;padding:0;font-size:18px;line-height:1;position:absolute;top:50%;right:14px;transform:translateY(-50%)}.btn{letter-spacing:2px;cursor:pointer;-webkit-appearance:none;border:none;border-radius:12px;width:100%;padding:16px;font-family:Bebas Neue,sans-serif;font-size:20px;transition:all .15s}.btn:active{transform:scale(.97)}.btn-primary{background:var(--accent);color:#000}.btn-primary:hover{background:#1ed760}.btn-secondary{color:var(--text);border:1px solid var(--border);background:0 0}.btn-secondary:hover{border-color:var(--text-dim)}.playlist-tab.active{background:var(--surface2);border-color:var(--accent);color:var(--accent)}.browse-container{scrollbar-width:thin;scrollbar-color:var(--border) transparent;max-height:400px;padding:2px;overflow-y:auto}.browse-container::-webkit-scrollbar{width:4px}.browse-container::-webkit-scrollbar-track{background:0 0}.browse-container::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.browse-section-title{letter-spacing:2px;text-transform:uppercase;color:var(--text-dim);margin:14px 0 8px;padding:0 2px;font-size:11px}.browse-section-title:first-child{margin-top:0}.browse-pills{grid-template-columns:1fr 1fr;gap:10px;width:100%;display:grid}.browse-pill{color:#fff;cursor:pointer;text-align:left;border:none;border-radius:12px;align-items:center;padding:22px 14px;font-size:17px;font-weight:600;transition:transform .12s,opacity .12s;display:flex}.browse-pill:hover{opacity:.9;transform:scale(1.03)}.browse-pill.selected{outline-offset:2px;opacity:1;outline:3px solid #fff}.browse-category-grid{grid-template-columns:1fr 1fr;gap:10px;width:100%;display:grid}.browse-category-tile{aspect-ratio:1;cursor:pointer;border:none;border-radius:12px;align-items:flex-start;padding:14px;transition:transform .12s,opacity .12s;display:flex;position:relative;overflow:hidden}.browse-category-tile:hover{opacity:.9;transform:scale(1.03)}.browse-category-tile-name{letter-spacing:1px;color:#fff;text-shadow:0 2px 8px #0000004d;font-family:Bebas Neue,sans-serif;font-size:27px;line-height:1.1}.browse-category-tile-count{color:#ffffffb3;margin-top:3px;font-size:12px}.playlist-tabs{background:var(--surface2);border-radius:10px;gap:0;width:100%;margin-bottom:4px;padding:3px;display:flex}.playlist-tab{color:var(--text-dim);cursor:pointer;background:0 0;border:none;border-radius:8px;flex:1;padding:10px 8px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:600;transition:all .15s}.playlist-tab.active{background:var(--accent);color:#000}.user-playlist-item{background:var(--surface2);cursor:pointer;border:2px solid #0000;border-radius:10px;align-items:center;gap:10px;padding:10px 12px;transition:transform .1s,outline .1s;display:flex}.user-playlist-item:hover{transform:scale(1.01)}.user-playlist-item.selected{border-color:var(--accent)}.user-playlist-item-thumb{object-fit:cover;background:var(--bg);border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:20px;display:flex}.user-playlist-item-info{flex:1;min-width:0}.user-playlist-item-name{white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.user-playlist-item-meta{color:var(--text-dim);margin-top:2px;font-size:11px}.user-playlist-item-actions{flex-shrink:0;gap:4px;display:flex}.user-playlist-item-actions button{color:var(--text-dim);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px;font-size:14px}.user-playlist-item-actions button:hover{color:var(--danger)}.btn-danger{background:var(--danger);color:#fff}.btn-text-link{color:var(--text-dim);cursor:pointer;opacity:.6;text-underline-offset:3px;background:0 0;border:none;margin:0 auto;padding:8px 0;font-family:DM Sans,sans-serif;font-size:13px;text-decoration:underline;transition:opacity .15s;display:block}.btn-text-link:hover{opacity:1}.btn-orange{color:#000;background:linear-gradient(135deg,#f07535,#d45a20)}.btn-gold{background:var(--gold);color:#000}.btn:disabled{opacity:.4;cursor:not-allowed}.stack{flex-direction:column;gap:12px;width:100%;max-width:380px;display:flex}.divider{color:var(--text-dim);letter-spacing:2px;text-transform:uppercase;align-items:center;gap:12px;width:100%;max-width:380px;font-size:12px;display:flex}.divider:before,.divider:after{content:"";background:var(--border);flex:1;height:1px}.room-code-display{letter-spacing:12px;color:var(--accent);text-align:center;text-shadow:0 0 40px #1db9544d;font-family:Bebas Neue,sans-serif;font-size:72px;line-height:1}.room-code-label{letter-spacing:4px;text-transform:uppercase;color:var(--text-dim);text-align:center;margin-bottom:8px;font-size:11px}.players-list{flex-direction:column;gap:8px;width:100%;max-width:380px;display:flex}.player-item{background:var(--surface2);border:1px solid var(--border);border-radius:10px;justify-content:space-between;align-items:center;padding:12px 16px;animation:.3s slideIn;display:flex}.player-name{font-weight:500}.player-score{color:var(--accent);letter-spacing:1px;font-family:Bebas Neue,sans-serif;font-size:22px}.host-badge{letter-spacing:2px;text-transform:uppercase;color:var(--accent);background:#1db95426;border:1px solid #1db9544d;border-radius:20px;padding:3px 8px;font-size:10px}@keyframes slideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.album-art{object-fit:cover;background:var(--surface2);border-radius:12px;width:160px;height:160px;margin:0 auto 20px;display:block;box-shadow:0 20px 60px #0009}.album-art.blurred{filter:blur(24px)}.album-art-placeholder{background:var(--surface2);border:1px solid var(--border);border-radius:12px;justify-content:center;align-items:center;width:160px;height:160px;margin:0 auto 20px;font-size:48px;display:flex}.now-playing-label{letter-spacing:4px;text-transform:uppercase;color:var(--text-dim);text-align:center;margin-bottom:4px;font-size:11px}.answer-section{gap:8px;width:100%;max-width:380px;display:flex}.answer-input{background:var(--surface2);border:2px solid var(--border);color:var(--text);-webkit-appearance:none;border-radius:12px;outline:none;flex:1;padding:14px 16px;font-family:DM Sans,sans-serif;font-size:16px;transition:border-color .2s}.answer-input:focus{border-color:var(--accent)}.answer-input.correct{border-color:var(--accent);background:#1db9541a}.answer-input.wrong{border-color:var(--danger);animation:.3s shake}.submit-btn{background:var(--accent);color:#000;letter-spacing:1px;cursor:pointer;white-space:nowrap;border:none;border-radius:12px;padding:14px 20px;font-family:Bebas Neue,sans-serif;font-size:18px;transition:all .15s}.submit-btn:active{transform:scale(.95)}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-6px)}75%{transform:translate(6px)}}.winner-banner{text-align:center;background:linear-gradient(135deg,#1db95433,#1db9540d);border:1px solid #1db95466;border-radius:14px;width:100%;max-width:380px;padding:16px 20px;animation:.4s cubic-bezier(.34,1.56,.64,1) popIn}.winner-name{letter-spacing:2px;color:var(--accent);font-family:Bebas Neue,sans-serif;font-size:32px}.winner-answer{color:var(--text-dim);margin-top:2px;font-size:14px}@keyframes popIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.song-reveal{text-align:center;background:var(--surface);border:1px solid var(--border);border-radius:14px;width:100%;max-width:380px;padding:16px}.reveal-track{font-size:18px;font-weight:600}.reveal-artist{color:var(--text-dim);margin-top:4px;font-size:14px}.round-pill{letter-spacing:3px;text-transform:uppercase;background:var(--surface2);border:1px solid var(--border);color:var(--text-dim);border-radius:20px;margin-bottom:16px;padding:6px 14px;font-size:11px}.playlist-item{background:var(--surface2);border:1px solid var(--border);cursor:pointer;border-radius:10px;align-items:center;gap:12px;padding:12px;transition:border-color .2s;display:flex}.playlist-item:hover,.playlist-item.selected{border-color:var(--accent)}.playlist-thumb{object-fit:cover;background:var(--surface);border-radius:6px;flex-shrink:0;width:48px;height:48px}.playlist-info{flex:1;min-width:0}.playlist-name{white-space:nowrap;text-overflow:ellipsis;font-size:15px;font-weight:500;overflow:hidden}.playlist-count{color:var(--text-dim);margin-top:2px;font-size:12px}.scroll-list{flex-direction:column;gap:8px;min-height:280px;max-height:280px;padding:6px;display:flex;overflow-y:auto}.scroll-list::-webkit-scrollbar{width:4px}.scroll-list::-webkit-scrollbar-track{background:0 0}.scroll-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.score-row{border-radius:12px;align-items:center;gap:14px;margin-bottom:8px;padding:14px 16px;display:flex}.score-rank{text-align:center;width:32px;color:var(--text-dim);font-family:Bebas Neue,sans-serif;font-size:28px}.score-rank.first{color:var(--gold)}.score-row.first-place{background:#f5c84214;border:1px solid #f5c84233}.score-row.other{background:var(--surface2);border:1px solid var(--border)}.score-name{flex:1;font-size:16px;font-weight:500}.score-pts{color:var(--accent);font-family:Bebas Neue,sans-serif;font-size:28px}.status-msg{color:var(--text-dim);text-align:center;min-height:20px;font-size:13px}.status-msg.success{color:var(--accent)}.status-msg.error{color:var(--danger)}.spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:24px;height:24px;margin:0 auto;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.section-gap{height:16px}.small-text{color:var(--text-dim);text-align:center;font-size:13px}.mode-toggle{gap:8px;display:flex}.mode-btn{border:1px solid var(--border);color:var(--text-dim);cursor:pointer;text-align:center;background:0 0;border-radius:8px;flex:1;padding:8px;font-family:DM Sans,sans-serif;font-size:13px;transition:all .15s}.mode-btn.active{background:var(--accent);color:#000;border-color:var(--accent)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.pulsing{animation:1.8s ease-in-out infinite pulse}.chat-fab{background:var(--accent);color:#000;cursor:pointer;z-index:100;border:none;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;font-size:22px;transition:transform .15s;display:none;position:fixed;bottom:20px;right:20px;box-shadow:0 4px 20px #1db95466}.chat-fab:active{transform:scale(.9)}.chat-fab .chat-badge{background:var(--danger);color:#fff;border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 4px;font-size:11px;font-weight:700;display:none;position:absolute;top:-4px;right:-4px}.chat-panel{background:var(--surface);border:1px solid var(--border);z-index:100;border-radius:14px;flex-direction:column;width:300px;max-height:360px;animation:.2s chatSlideUp;display:none;position:fixed;bottom:80px;right:20px;overflow:hidden;box-shadow:0 8px 40px #00000080}@keyframes chatSlideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.chat-header{border-bottom:1px solid var(--border);letter-spacing:2px;text-transform:uppercase;color:var(--text-dim);justify-content:space-between;align-items:center;padding:10px 14px;font-size:12px;display:flex}.chat-header button{color:var(--text-dim);cursor:pointer;background:0 0;border:none;padding:0;font-size:18px;line-height:1}.chat-messages{flex-direction:column;flex:1;gap:4px;min-height:80px;max-height:240px;padding:8px 12px;display:flex;overflow-y:auto}.chat-messages::-webkit-scrollbar{width:3px}.chat-messages::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.chat-msg{font-size:13px;line-height:1.4;animation:.2s slideIn}.chat-msg .chat-author{color:var(--accent);margin-right:6px;font-size:12px;font-weight:600}.chat-msg .chat-text{color:var(--text)}.chat-msg.chat-system{color:var(--text-dim);text-align:center;padding:2px 0;font-size:11px;font-style:italic}.chat-input-row{border-top:1px solid var(--border);background:var(--surface2);gap:6px;padding:8px 10px;display:flex}.chat-input-row input{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:8px;outline:none;flex:1;padding:8px 10px;font-family:DM Sans,sans-serif;font-size:13px}.chat-input-row input:focus{border-color:var(--accent)}.chat-input-row button{background:var(--accent);color:#000;letter-spacing:1px;cursor:pointer;border:none;border-radius:8px;padding:8px 14px;font-family:Bebas Neue,sans-serif;font-size:14px;transition:transform .1s}.chat-input-row button:active{transform:scale(.95)}@media (width<=400px){.chat-panel{width:auto;bottom:76px;left:12px;right:12px}}.sound-bars{align-items:flex-end;gap:3px;height:20px;margin:0 auto 12px;display:flex}.bar{background:var(--accent);border-radius:2px;width:4px;animation:1.2s ease-in-out infinite barAnim}.bar:first-child{animation-delay:0s}.bar:nth-child(2){animation-delay:.2s}.bar:nth-child(3){animation-delay:.4s}.bar:nth-child(4){animation-delay:.6s}.bar:nth-child(5){animation-delay:.8s}@keyframes barAnim{0%,to{height:4px}50%{height:20px}}#feedback-input::placeholder,#feedback-name::placeholder{color:#555}.card input::placeholder,.card textarea::placeholder{color:#444}.feedback-info-btn{border:1px solid var(--text-dim);width:18px;height:18px;color:var(--text-dim);cursor:pointer;background:0 0;border-radius:50%;flex-shrink:0;font-size:11px;font-weight:600;line-height:1;transition:border-color .2s,color .2s}.feedback-info-btn:hover{border-color:var(--text);color:var(--text)}.screen-title{margin-bottom:4px;font-size:40px}.screen-title-lg{margin-bottom:4px;font-size:48px}.screen-title-sm{margin-bottom:4px;font-size:36px}.section-label{letter-spacing:3px;text-transform:uppercase;color:var(--text-dim);margin-bottom:8px;font-size:11px}.bebas{font-family:Bebas Neue,sans-serif}.container{width:100%;max-width:380px}.text-secondary{color:var(--text-dim);font-size:13px}.text-hint{color:var(--text-dim);font-size:12px}.text-hint-sm{color:var(--text-dim);font-size:11px}.text-center{text-align:center}.text-bold{font-weight:600}.flex-row{gap:8px;display:flex}.flex-list{flex-direction:column;gap:6px;display:flex}.spacer-sm{height:8px}.spacer-md{height:12px}.spacer-lg{height:16px}.spacer-xl{height:24px}.btn-action{background:var(--accent);color:#000;cursor:pointer;white-space:nowrap;border:none;border-radius:10px;flex-shrink:0;padding:8px 14px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:600}.btn-action-secondary{background:var(--surface2);color:var(--text);border:1px solid var(--border);cursor:pointer;white-space:nowrap;border-radius:10px;flex-shrink:0;padding:8px 14px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:600}.modal-overlay{z-index:200;box-sizing:border-box;background:#000000bf;padding:20px;position:fixed;inset:0}.modal-card{background:var(--surface);border-radius:16px;width:100%;max-width:400px;margin:0 auto;padding:20px}
