@import"https://fonts.googleapis.com/css2?family=Syne:wght@400;500;600;700;800&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;1,9..40,300&display=swap";*,*:before,*:after{box-sizing:border-box}html{overflow-x:hidden}:root{--bg: #0a0a0f;--bg-1: #111118;--bg-2: #18181f;--bg-3: #1e1e28;--surface: #222230;--surface-2: #2a2a3a;--border: rgba(255,255,255,.07);--border-2: rgba(255,255,255,.12);--accent: #7c6aff;--accent-2: #a78bfa;--accent-glow: rgba(124,106,255,.3);--accent-dim: rgba(124,106,255,.15);--pink: #f472b6;--pink-dim: rgba(244,114,182,.15);--cyan: #22d3ee;--cyan-dim: rgba(34,211,238,.12);--green: #4ade80;--green-dim: rgba(74,222,128,.12);--amber: #fbbf24;--red: #f87171;--text: #f0f0f8;--text-2: #a0a0c0;--text-3: #60607a;--host-color: #a78bfa;--cohost-color: #67e8f9;--radius: 12px;--radius-sm: 8px;--radius-lg: 16px;--radius-full: 9999px;--shadow: 0 4px 24px rgba(0,0,0,.4);--shadow-lg: 0 8px 48px rgba(0,0,0,.6);--transition: .2s cubic-bezier(.4, 0, .2, 1)}body{margin:0;font-family:DM Sans,system-ui,sans-serif;font-size:14px;background:var(--bg);color:var(--text);overflow-x:hidden;-webkit-font-smoothing:antialiased}.app{min-height:100vh;overflow-x:hidden;background:var(--bg)}.login-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:24px;background:radial-gradient(ellipse 80% 60% at 50% -10%,rgba(124,106,255,.18) 0%,transparent 60%),radial-gradient(ellipse 50% 40% at 85% 80%,rgba(244,114,182,.1) 0%,transparent 50%),var(--bg)}.login-container{width:100%;max-width:400px;background:var(--bg-2);border:1px solid var(--border-2);border-radius:var(--radius-lg);padding:40px 36px;box-shadow:var(--shadow-lg),0 0 80px #7c6aff14;animation:fadeUp .4s cubic-bezier(.4,0,.2,1)}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.login-container h1{margin:0 0 4px;font-family:Syne,sans-serif;font-size:28px;font-weight:800;color:var(--text);letter-spacing:-.5px}.login-subtitle{font-size:13px;color:var(--text-3);margin-bottom:28px;font-weight:400}.login-container .win98-titlebar{display:none}.login-container .win98-body{padding:0}.auth-tabs{display:flex;gap:4px;margin-bottom:20px;background:var(--bg-3);border-radius:var(--radius-sm);padding:4px}.auth-tab{flex:1;padding:8px 16px;border:none;border-radius:6px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:500;cursor:pointer;color:var(--text-3);background:transparent;transition:var(--transition)}.auth-tab:hover{color:var(--text-2)}.auth-tab.active{background:var(--surface);color:var(--text);box-shadow:0 1px 4px #0000004d}.form-row{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.form-row label{font-size:12px;font-weight:500;color:var(--text-2);text-transform:uppercase;letter-spacing:.5px}.win98-input{background:var(--bg-3);border:1px solid var(--border-2);border-radius:var(--radius-sm);padding:10px 14px;font-family:DM Sans,sans-serif;font-size:14px;color:var(--text);outline:none;transition:var(--transition);width:100%}.win98-input::placeholder{color:var(--text-3)}.win98-input:focus{border-color:var(--accent);background:var(--bg-2);box-shadow:0 0 0 3px var(--accent-dim)}.win98-input:disabled{opacity:.5;cursor:not-allowed}.form-actions{display:flex;gap:8px;margin-top:20px;flex-wrap:wrap}.win98-btn{background:var(--accent);border:none;border-radius:var(--radius-sm);padding:10px 20px;font-family:DM Sans,sans-serif;font-size:14px;font-weight:500;cursor:pointer;color:#fff;transition:var(--transition);min-width:unset;max-width:100%;text-align:center;letter-spacing:.1px}.win98-btn:hover{background:var(--accent-2);transform:translateY(-1px);box-shadow:0 4px 16px var(--accent-glow)}.win98-btn:active{transform:translateY(0);box-shadow:none;padding:10px 20px}.win98-btn:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}.win98-btn:focus{outline:2px solid var(--accent);outline-offset:2px}.browse-back-btn,.logout-btn,.leave-room-btn,.upload-clear-btn,.upload-refresh-btn{background:var(--surface);color:var(--text-2);border:1px solid var(--border-2)}.browse-back-btn:hover,.logout-btn:hover,.leave-room-btn:hover,.upload-clear-btn:hover,.upload-refresh-btn:hover{background:var(--surface-2);color:var(--text);transform:translateY(-1px);box-shadow:none}.leave-room-btn{font-size:13px;padding:7px 16px}.error{background:#f871711a;border:1px solid rgba(248,113,113,.3);border-radius:var(--radius-sm);padding:10px 14px;color:var(--red);font-size:13px;margin-top:12px}.success{background:#4ade801a;border:1px solid rgba(74,222,128,.3);border-radius:var(--radius-sm);padding:10px 14px;color:var(--green);font-size:13px;margin-top:12px}.warning{background:#fbbf241a;border:1px solid rgba(251,191,36,.3);border-radius:var(--radius-sm);padding:10px 14px;color:var(--amber);font-size:13px;margin-top:12px}.geocities-footer{margin-top:32px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px}.under-construction,.visitor-counter{display:none}.github-badge{font-size:12px;color:var(--text-3);text-decoration:none;transition:var(--transition)}.github-badge:hover{color:var(--accent-2)}.server-info{margin-top:20px;font-size:12px;color:var(--text-3)}.waitlist-header{font-family:Syne,sans-serif;font-weight:700;font-size:16px;margin-bottom:16px;color:var(--text)}.waitlist-link{margin-top:16px;font-size:13px;color:var(--text-3);text-align:center}.link-btn{background:none;border:none;color:var(--accent-2);cursor:pointer;font-size:13px;padding:0;font-family:DM Sans,sans-serif;text-decoration:underline;text-decoration-color:transparent;transition:var(--transition)}.link-btn:hover{text-decoration-color:var(--accent-2)}.waitlist-confirmed{text-align:center}.retro-divider{border:none;border-top:1px solid var(--border);margin:20px 0}.room-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:24px;background:radial-gradient(ellipse 80% 60% at 50% -10%,rgba(124,106,255,.15) 0%,transparent 60%),radial-gradient(ellipse 40% 30% at 10% 90%,rgba(34,211,238,.08) 0%,transparent 50%),var(--bg)}.room-card{width:100%;max-width:440px;background:var(--bg-2);border:1px solid var(--border-2);border-radius:var(--radius-lg);padding:36px 32px 28px;box-shadow:var(--shadow-lg);animation:fadeUp .4s cubic-bezier(.4,0,.2,1)}.room-card-header{margin-bottom:28px}.room-card-header h1{margin:0 0 4px;font-family:Syne,sans-serif;font-size:26px;font-weight:800;color:var(--text);letter-spacing:-.5px}.room-card-header p{margin:0;color:var(--text-3);font-size:14px}.room-card-header p strong{color:var(--text-2);font-weight:500}.room-section{margin-bottom:4px}.room-section-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.7px;color:var(--text-3);margin-bottom:8px}.room-join-row{display:flex;gap:8px;align-items:center}.room-code-input{flex:1;min-width:0;background:var(--bg-3);border:1px solid var(--border-2);border-radius:var(--radius-sm);padding:11px 10px;font-family:Syne,sans-serif;font-size:18px;font-weight:700;letter-spacing:3px;text-align:center;text-transform:uppercase;color:var(--text);outline:none;transition:var(--transition)}.room-code-input::placeholder{color:var(--text-3);letter-spacing:2px;font-size:14px}.room-code-input:focus{border-color:var(--accent);background:var(--bg-1);box-shadow:0 0 0 3px var(--accent-dim)}.room-code-input:disabled{opacity:.45;cursor:not-allowed}.room-join-btn{flex:0 0 auto;background:var(--accent);border:none;border-radius:var(--radius-sm);padding:11px 20px;font-family:DM Sans,sans-serif;font-size:14px;font-weight:600;color:#fff;cursor:pointer;white-space:nowrap;transition:var(--transition)}.room-join-btn:hover{background:var(--accent-2);transform:translateY(-1px);box-shadow:0 4px 16px var(--accent-glow)}.room-join-btn:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}.room-join-btn--sm{padding:7px 14px;font-size:13px}.room-divider-row{display:flex;align-items:center;gap:12px;margin:20px 0}.room-divider-line{flex:1;height:1px;background:var(--border-2)}.room-divider-text{font-size:12px;color:var(--text-3);text-transform:uppercase;letter-spacing:.5px}.room-create-btn{width:100%;background:var(--bg-3);border:1px solid var(--border-2);border-radius:var(--radius-sm);padding:12px 20px;font-family:DM Sans,sans-serif;font-size:14px;font-weight:500;color:var(--text-2);cursor:pointer;transition:var(--transition);text-align:center}.room-create-btn:hover{background:var(--surface);color:var(--text);border-color:var(--accent)}.room-create-btn:disabled{opacity:.4;cursor:not-allowed}.active-rooms-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.active-room-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius-sm);transition:var(--transition)}.active-room-item:hover{border-color:var(--border-2);background:var(--surface)}.active-room-info{display:flex;flex-direction:column;gap:2px;min-width:0}.active-room-code{font-family:Syne,sans-serif;font-size:15px;font-weight:700;letter-spacing:2px;color:var(--accent-2)}.active-room-meta{font-size:12px;color:var(--text-3)}.active-room-track{font-size:12px;color:var(--text-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:220px}.room-card-footer{margin-top:24px;padding-top:20px;border-top:1px solid var(--border);display:flex;justify-content:flex-end}.room-logout-btn{background:none;border:none;color:var(--text-3);font-family:DM Sans,sans-serif;font-size:13px;cursor:pointer;padding:4px 0;transition:var(--transition)}.room-logout-btn:hover{color:var(--text-2)}.marquee-container{display:none}.jam-screen{display:grid;grid-template-rows:60px 1fr 36px;height:100vh;overflow:hidden}header{display:flex;align-items:center;gap:16px;padding:0 20px;background:var(--bg-1);border-bottom:1px solid var(--border);z-index:20}header h1{font-family:Syne,sans-serif;font-size:18px;font-weight:800;margin:0;color:var(--text);letter-spacing:-.3px;white-space:nowrap}.header-info{display:flex;align-items:center;gap:8px;flex:1;overflow:hidden}.header-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:var(--radius-full);border:1px solid var(--border-2);background:var(--bg-3);font-size:12px;white-space:nowrap;line-height:1}.header-chip-label{color:var(--text-3);font-size:10px;text-transform:uppercase;letter-spacing:.6px;font-weight:500}.header-chip-value{color:var(--text);font-weight:600;font-family:Syne,sans-serif;font-size:13px;letter-spacing:.5px}.header-chip--room{background:var(--accent-dim);border-color:#7c6aff40}.header-chip--room .header-chip-value{color:var(--accent-2)}.header-chip--role{font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.8px}.header-chip--role-host{background:#a78bfa26;border-color:#a78bfa4d;color:var(--host-color)}.header-chip--role-cohost{background:#67e8f91a;border-color:#67e8f940;color:var(--cohost-color)}.header-chip--role-listener{background:var(--bg-3);border-color:var(--border-2);color:var(--text-3)}.header-chip--user{background:var(--bg-3);border-color:var(--border)}.header-community-select,.mobile-community-select{background:var(--bg-3);border:1px solid var(--border-2);border-radius:var(--radius-sm);color:var(--text-2);font-size:13px;padding:4px 8px;font-family:DM Sans,sans-serif;cursor:pointer}.main-content{display:grid;grid-template-columns:180px 1fr 220px;overflow:hidden}.panel-titlebar{font-family:Syne,sans-serif;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-3);padding:12px 16px 8px;border-bottom:1px solid var(--border)}.panel-body{flex:1;overflow-y:auto;padding:0;scrollbar-width:thin;scrollbar-color:var(--surface-2) transparent}.panel-body::-webkit-scrollbar{width:4px}.panel-body::-webkit-scrollbar-track{background:transparent}.panel-body::-webkit-scrollbar-thumb{background:var(--surface-2);border-radius:4px}.users-panel{display:flex;flex-direction:column;background:var(--bg-1);border-right:1px solid var(--border);overflow:hidden}.users-list{list-style:none;margin:0;padding:8px}.users-list li{display:flex;align-items:center;justify-content:space-between;gap:6px;padding:8px 10px;border-radius:var(--radius-sm);transition:var(--transition)}.users-list li:hover{background:var(--surface)}.user-name{font-size:13px;font-weight:500;color:var(--text-2);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.users-list li.host .user-name{color:var(--host-color)}.users-list li.cohost .user-name{color:var(--cohost-color)}.user-badges{display:flex;align-items:center;gap:4px;flex-shrink:0}.badge{font-size:9px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;padding:2px 5px;border-radius:var(--radius-full)}.badge-host{background:var(--pink-dim);color:var(--pink)}.badge-cohost{background:var(--cyan-dim);color:var(--cyan)}.user-action-btn{width:20px;height:20px;border:1px solid var(--border-2);border-radius:var(--radius-full);background:var(--surface);color:var(--text-2);font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;padding:0;transition:var(--transition)}.promote-btn:hover{background:var(--accent-dim);border-color:var(--accent);color:var(--accent-2)}.demote-btn:hover{background:#f871711a;border-color:var(--red);color:var(--red)}.player-panel{display:flex;flex-direction:column;overflow:hidden;background:var(--bg)}.player-panel .panel-titlebar{display:none}.player-panel .panel-body{flex:1;overflow-y:auto;display:flex;flex-direction:column}.now-playing{display:flex;align-items:center;gap:16px;padding:16px 20px;background:linear-gradient(to bottom,var(--bg-1),var(--bg));border-bottom:1px solid var(--border);min-height:88px}.cover-art{width:56px;height:56px;border-radius:8px;object-fit:cover;flex-shrink:0;box-shadow:0 2px 12px #0006}.track-info{min-width:0;flex:1}.track-info h2{margin:0 0 2px;font-family:Syne,sans-serif;font-size:16px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-info p{margin:0;font-size:13px;color:var(--text-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-info .album{font-size:12px;color:var(--text-3)}.loading-track{padding:20px;color:var(--text-3);font-size:13px}.synced-audio-player{padding:12px 20px;background:var(--bg-1);border-bottom:1px solid var(--border)}.playback-info{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.playback-info .time{font-size:12px;color:var(--text-3);font-variant-numeric:tabular-nums;font-family:Syne,monospace}.playback-info .status{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-3)}.seek-bar{-webkit-appearance:none;width:100%;height:4px;border-radius:2px;background:var(--surface-2);outline:none;cursor:pointer;margin-bottom:10px;transition:height var(--transition)}.seek-bar:hover{height:6px}.seek-bar::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent);cursor:pointer;transition:transform var(--transition),box-shadow var(--transition)}.seek-bar::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 0 0 6px var(--accent-glow)}.seek-bar::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--accent);cursor:pointer;border:none}.seek-bar:disabled{cursor:default;opacity:.5}.volume-control{display:flex;align-items:center;gap:10px}.volume-control label{font-size:11px;color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;font-weight:500;white-space:nowrap;min-width:44px}.volume-slider{-webkit-appearance:none;flex:1;height:3px;border-radius:2px;background:var(--surface-2);outline:none;cursor:pointer}.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;border-radius:50%;background:var(--text-2);cursor:pointer;transition:transform var(--transition)}.volume-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.volume-slider::-moz-range-thumb{width:12px;height:12px;border-radius:50%;background:var(--text-2);cursor:pointer;border:none}.transport-controls{display:flex;align-items:center;gap:4px;padding:10px 20px;border-bottom:1px solid var(--border);background:var(--bg-1)}.transport-separator{flex:1}.transport-btn{width:36px;height:36px;border:none;border-radius:var(--radius-full);background:transparent;color:var(--text-2);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition);padding:0;flex-shrink:0}.transport-btn:hover{background:var(--surface);color:var(--text)}.transport-btn:disabled{opacity:.3;cursor:not-allowed}.transport-play-btn{width:44px;height:44px;background:var(--accent);color:#fff;box-shadow:0 2px 12px var(--accent-glow)}.transport-play-btn:hover{background:var(--accent-2);color:#fff;transform:scale(1.05);box-shadow:0 4px 20px var(--accent-glow)}.like-btn.active,.like-btn.active:hover{color:var(--pink)}.repeat-btn.repeat-active{color:var(--accent-2)}.transport-icon{display:inline-block;width:16px;height:16px;position:relative}.play-icon:before{content:"";display:block;width:0;height:0;border-top:8px solid transparent;border-bottom:8px solid transparent;border-left:14px solid currentColor;position:absolute;top:50%;left:52%;transform:translate(-50%,-50%)}.pause-icon:before,.pause-icon:after{content:"";display:block;position:absolute;width:4px;height:14px;background:currentColor;border-radius:2px;top:50%;transform:translateY(-50%)}.pause-icon:before{left:2px}.pause-icon:after{left:10px}.next-icon:before{content:"";display:block;width:0;height:0;border-top:7px solid transparent;border-bottom:7px solid transparent;border-left:10px solid currentColor;position:absolute;top:50%;left:1px;transform:translateY(-50%)}.next-icon:after{content:"";position:absolute;right:0;top:50%;transform:translateY(-50%);width:3px;height:14px;background:currentColor;border-radius:1px}.prev-icon:before{content:"";display:block;width:0;height:0;border-top:7px solid transparent;border-bottom:7px solid transparent;border-right:10px solid currentColor;position:absolute;top:50%;right:1px;transform:translateY(-50%)}.prev-icon:after{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:14px;background:currentColor;border-radius:1px}.repeat-icon:before{content:"↻";font-size:20px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);line-height:1}.music-tabs{display:flex;padding:0 20px;gap:0;background:var(--bg-1);border-bottom:1px solid var(--border);overflow-x:auto;scrollbar-width:none}.music-tabs::-webkit-scrollbar{display:none}.music-tabs .auth-tab{flex:none;border-radius:0;background:transparent;border-bottom:2px solid transparent;padding:10px 16px;font-size:13px;font-weight:500;color:var(--text-3);white-space:nowrap}.music-tabs .auth-tab:hover{color:var(--text-2);background:transparent;box-shadow:none}.music-tabs .auth-tab.active{background:transparent;color:var(--accent-2);border-bottom-color:var(--accent);box-shadow:none}.music-tab-content{flex:1;overflow:hidden;display:flex;flex-direction:column}.mobile-tab{display:none}.desktop-tab{display:flex}.search-panel{padding:16px;display:flex;flex-direction:column;gap:12px;flex:1;overflow-y:auto}.search-panel form{display:flex;gap:8px}.search-panel .win98-input{flex:1}.search-panel .win98-btn{flex-shrink:0;padding:10px 16px}.search-results{display:flex;flex-direction:column;gap:8px}.results-section h4{font-family:Syne,sans-serif;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-3);margin:0 0 8px}.results-section ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}.song-item{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 10px;border-radius:var(--radius-sm);transition:var(--transition)}.song-item:hover{background:var(--surface)}.song-info{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.song-info strong{font-weight:500;font-size:13px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.song-info span{font-size:12px;color:var(--text-3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-num{color:var(--text-3);margin-right:6px;font-variant-numeric:tabular-nums;font-size:11px}.song-artist-name{color:var(--text-3)}.song-actions{display:flex;gap:4px;flex-shrink:0;opacity:0;transition:var(--transition)}.song-item:hover .song-actions{opacity:1}.song-actions button{padding:4px 10px;font-size:11px;font-family:DM Sans,sans-serif;font-weight:500;border:1px solid var(--border-2);border-radius:var(--radius-full);background:var(--surface);color:var(--text-2);cursor:pointer;transition:var(--transition);white-space:nowrap}.song-actions button:hover{background:var(--accent);border-color:var(--accent);color:#fff}.browse-panel{display:flex;flex-direction:column;flex:1;overflow:hidden}.browse-toolbar{padding:12px 16px 0;flex-shrink:0}.browse-mode-select{width:100%;background:var(--bg-3);border:1px solid var(--border-2);border-radius:var(--radius-sm);color:var(--text-2);font-size:13px;font-family:DM Sans,sans-serif;padding:8px 12px;cursor:pointer;outline:none;transition:var(--transition)}.browse-mode-select:focus{border-color:var(--accent)}.browse-breadcrumb{display:flex;align-items:center;gap:6px;padding:8px 16px;font-size:12px;color:var(--text-3);flex-shrink:0;border-bottom:1px solid var(--border)}.browse-breadcrumb .current{color:var(--text-2)}.browse-breadcrumb .clickable{cursor:pointer;color:var(--accent-2);text-decoration:underline;text-decoration-color:transparent;transition:var(--transition)}.browse-breadcrumb .clickable:hover{text-decoration-color:var(--accent-2)}.browse-breadcrumb .separator{color:var(--text-3)}.browse-loading{padding:24px 16px;text-align:center;color:var(--text-3);font-size:13px}.browse-empty{padding:32px 16px;text-align:center;color:var(--text-3);font-size:13px}.browse-list{flex:1;overflow-y:auto;padding:8px;scrollbar-width:thin;scrollbar-color:var(--surface-2) transparent}.browse-list::-webkit-scrollbar{width:4px}.browse-list::-webkit-scrollbar-thumb{background:var(--surface-2);border-radius:4px}.browse-list ul{list-style:none;margin:0;padding:0}.browse-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition)}.browse-item:hover{background:var(--surface)}.browse-icon{width:32px;height:32px;border-radius:6px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:16px;background:var(--surface-2);overflow:hidden}.folder-icon:before{content:"📁"}.cd-icon:before{content:"💿"}.browse-thumb{width:32px;height:32px;object-fit:cover;border-radius:6px;flex-shrink:0}.browse-item-info{display:flex;flex-direction:column;gap:2px;min-width:0}.browse-item-info strong{font-weight:500;font-size:13px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.browse-item-info span{font-size:12px;color:var(--text-3)}.browse-back-btn{background:transparent;border:none;color:var(--accent-2);font-size:12px;padding:8px 0;margin:0 10px 8px;cursor:pointer;display:flex;align-items:center;gap:4px;font-family:DM Sans,sans-serif;font-weight:500;transition:var(--transition)}.browse-back-btn:hover{color:var(--text);background:transparent;transform:none;box-shadow:none}.browse-album-header{display:flex;align-items:flex-start;gap:12px;padding:12px 10px 16px;border-bottom:1px solid var(--border);margin-bottom:4px;flex-wrap:wrap}.browse-album-art{width:64px;height:64px;border-radius:8px;object-fit:cover;box-shadow:0 2px 12px #0006}.browse-album-meta{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.browse-album-meta strong{font-family:Syne,sans-serif;font-size:15px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.browse-album-meta span{font-size:13px;color:var(--text-3)}.browse-queue-all-btn{padding:6px 14px;font-size:12px}.favorites-header{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:10px;border-bottom:1px solid var(--border);margin-bottom:4px;flex-wrap:wrap}.favorites-count{font-size:12px;color:var(--text-3);font-weight:500}.favorites-empty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:40px 16px}.favorites-empty-star{font-size:32px;opacity:.3}.favorites-empty p{margin:0;color:var(--text-3);font-size:14px}.favorites-hint{font-size:12px;color:var(--text-3);opacity:.7}.queue-panel{display:flex;flex-direction:column;background:var(--bg-1);border-left:1px solid var(--border);overflow:hidden}.queue-list{list-style:none;margin:0;padding:8px;display:flex;flex-direction:column;gap:2px}.queue-list li{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 10px;border-radius:var(--radius-sm);transition:var(--transition)}.queue-list li:hover{background:var(--surface)}.queue-list li.empty{padding:24px 10px;text-align:center;color:var(--text-3);font-size:13px}.queue-track{display:flex;align-items:center;gap:8px;min-width:0;flex:1}.queue-num{font-size:11px;color:var(--text-3);font-variant-numeric:tabular-nums;flex-shrink:0;min-width:16px;font-family:Syne,monospace}.queue-track-info{display:flex;flex-direction:column;gap:1px;min-width:0}.queue-track-info strong{font-size:12px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.queue-track-info span{font-size:11px;color:var(--text-3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.queue-controls{display:flex;gap:2px;flex-shrink:0;opacity:0;transition:var(--transition)}.queue-list li:hover .queue-controls{opacity:1}.queue-ctrl-btn{width:20px;height:20px;border:none;border-radius:4px;background:transparent;color:var(--text-3);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:10px;padding:0;transition:var(--transition)}.queue-ctrl-btn:hover{background:var(--surface-2);color:var(--text)}.queue-ctrl-btn:disabled{opacity:.3;cursor:not-allowed}.queue-remove-btn:hover{background:#f871711a;color:var(--red)}.upload-panel{padding:16px;display:flex;flex-direction:column;gap:16px;flex:1;overflow-y:auto}.upload-zone-section{display:flex;flex-direction:column;gap:12px}.upload-dropzone{border:2px dashed var(--border-2);border-radius:var(--radius);padding:32px 16px;text-align:center;transition:var(--transition);background:var(--bg-3);display:flex;flex-direction:column;align-items:center;gap:12px}.upload-dropzone.dragover{border-color:var(--accent);background:var(--accent-dim)}.upload-dropzone-text{font-size:14px;color:var(--text-2);font-weight:500}.upload-or{font-size:12px;color:var(--text-3)}.upload-browse-btn{cursor:pointer;padding:8px 20px;font-size:13px}.upload-formats{font-size:11px;color:var(--text-3)}.upload-queue-section{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius);padding:12px}.upload-queue-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;font-size:13px;color:var(--text-2)}.upload-clear-btn{padding:4px 12px;font-size:12px}.upload-queue-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.upload-queue-item{display:flex;align-items:center;gap:8px;font-size:12px}.upload-queue-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-2)}.upload-queue-status{flex-shrink:0;font-size:11px;font-weight:500}.upload-queue-done .upload-queue-status{color:var(--green)}.upload-queue-error .upload-queue-status,.upload-queue-error{color:var(--red)}.upload-queue-progress{flex:1;flex-shrink:0;max-width:80px}.upload-progress-track{background:var(--surface-2);border-radius:2px;height:4px;overflow:hidden}.upload-progress-fill{background:var(--accent);height:100%;border-radius:2px;transition:width .3s ease}.upload-success{margin-top:8px;font-size:11px;color:var(--text-3)}.my-uploads-section{display:flex;flex-direction:column;gap:10px}.my-uploads-header{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-2);font-weight:500}.upload-quota{flex:1;font-size:12px;color:var(--text-3);text-align:right}.upload-refresh-btn{padding:4px 12px;font-size:12px}.my-uploads-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}.upload-item{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 10px;background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius-sm)}.upload-item-info{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.upload-item-info strong{font-size:12px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.upload-item-info span{font-size:11px;color:var(--text-3)}.upload-permanent-toggle{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-3);cursor:pointer;flex-shrink:0}.upload-permanent-toggle input[type=checkbox]{accent-color:var(--accent);width:14px;height:14px;cursor:pointer}.status-bar{display:flex;align-items:center;gap:0;background:var(--bg-1);border-top:1px solid var(--border);padding:0 16px;height:36px;overflow:hidden}.status-bar-section{font-size:11px;color:var(--text-3);padding:0 12px 0 0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.status-bar-section:first-child{flex:1}.status-bar-section:not(:first-child){border-left:1px solid var(--border);padding-left:12px;flex-shrink:0}.mobile-queue-panel,.mobile-users-panel{flex:1;overflow-y:auto;padding:8px}.mobile-community-bar{display:none}@media(max-width:900px){.main-content{grid-template-columns:1fr}.users-panel,.queue-panel{display:none}.mobile-tab,.desktop-tab{display:flex}.jam-screen{grid-template-rows:56px 1fr 36px}.mobile-community-bar{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--bg-1);border-top:1px solid var(--border);font-size:13px;color:var(--text-3)}.mobile-community-select{flex:1}}@media(max-width:600px){.login-container,.room-container{padding:28px 20px}.now-playing{padding:12px 16px}.transport-controls{padding:8px 16px}.music-tabs{padding:0 12px}.header-info{display:none}}
