*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg-deep: #0a0a1a;--bg-mid: #12122a;--bg-card: rgba(255, 255, 255, .04);--bg-card-hover: rgba(255, 255, 255, .07);--glass-border: rgba(255, 255, 255, .08);--glass-blur: 20px;--cyan: #00f0ff;--magenta: #ff006e;--violet: #8b5cf6;--violet-soft: #a78bfa;--green: #22c55e;--text-primary: #f0f0f8;--text-secondary: rgba(240, 240, 248, .55);--text-muted: rgba(240, 240, 248, .3);--font-body: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-heading: "Outfit", "Inter", sans-serif;--radius-sm: 8px;--radius-md: 14px;--radius-lg: 20px;--radius-xl: 28px;--transition-fast: .15s ease;--transition-med: .3s cubic-bezier(.4, 0, .2, 1);--transition-slow: .5s cubic-bezier(.4, 0, .2, 1)}html,body{height:100%;font-family:var(--font-body);background:linear-gradient(145deg,var(--bg-deep) 0%,#1a0a2e 50%,#0d1b2a 100%);color:var(--text-primary);overflow-x:hidden;-webkit-font-smoothing:antialiased}#visualizer-canvas{position:fixed;top:0;left:0;width:100%;height:100%;z-index:0;opacity:.4;pointer-events:none}.particles{position:fixed;top:0;left:0;width:100%;height:100%;z-index:0;pointer-events:none;overflow:hidden}.particle{position:absolute;width:3px;height:3px;border-radius:50%;background:var(--cyan);opacity:0;animation:particleFloat 8s infinite}@keyframes particleFloat{0%{transform:translateY(100vh) scale(0);opacity:0}10%{opacity:.6}90%{opacity:.2}to{transform:translateY(-10vh) scale(1);opacity:0}}.app-container{position:relative;z-index:1;min-height:100vh;display:flex;flex-direction:column;max-width:1200px;margin:0 auto;padding:20px}.header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:var(--bg-card);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-lg);margin-bottom:20px;position:relative;z-index:100}.logo{display:flex;align-items:center;gap:12px}.logo-icon{width:40px;height:40px;animation:logoPulse 3s ease-in-out infinite}@keyframes logoPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.logo h1{font-family:var(--font-heading);font-size:1.8rem;font-weight:800;background:linear-gradient(135deg,var(--cyan),var(--violet));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.5px}.logo h1 span{font-weight:500}.header-right{display:flex;align-items:center;gap:16px}.live-listeners{display:flex;align-items:center;gap:5px;padding:5px 12px;border-radius:20px;background:#ffffff0d;border:1px solid var(--glass-border);color:var(--text-secondary);font-size:.72rem;font-weight:500;font-family:var(--font-body)}.live-listeners span{color:var(--cyan);font-weight:700;font-variant-numeric:tabular-nums}.dj-sidebar{position:fixed;left:0;top:0;bottom:0;width:200px;padding-top:80px;background:#0c0c1ef7;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-right:1px solid var(--glass-border);z-index:90;display:flex;flex-direction:column;overflow:hidden;transition:transform .3s cubic-bezier(.4,0,.2,1)}.dj-sidebar.collapsed{transform:translate(-100%)}.sidebar-toggle{position:fixed;left:0;top:86px;width:40px;height:56px;background:#0c0c1ef7;border:2px solid var(--cyan);border-left:none;border-radius:0 12px 12px 0;color:var(--cyan);font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:92;box-shadow:4px 0 16px #00f0ff26}.sidebar-toggle:hover{background:#00f0ff26;color:#fff;box-shadow:4px 0 20px #00f0ff4d}.dj-sidebar:not(.collapsed)~.sidebar-toggle,.has-sidebar:not(.sidebar-collapsed) .sidebar-toggle{left:200px}.sidebar-tabs{display:flex;border-bottom:1px solid var(--glass-border);padding:0;flex-shrink:0}.sidebar-tab{flex:1;padding:10px 4px;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-muted);font-family:var(--font-body);font-size:.72rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.sidebar-tab:hover{color:var(--text-secondary);background:#ffffff08}.sidebar-tab.active{color:var(--cyan);border-bottom-color:var(--cyan)}.sidebar-feed{flex:1;overflow-y:auto;position:relative}.feed-panel{display:none;flex-direction:column;height:100%;overflow-y:auto;padding:8px;gap:6px}.feed-panel.active{display:flex}.feed-empty{color:var(--text-muted);font-size:.8rem;text-align:center;padding:32px 16px;opacity:.6}.feed-item{padding:8px 10px;border-radius:var(--radius-sm);background:#ffffff08;border:1px solid rgba(255,255,255,.04);font-size:.78rem;color:var(--text-secondary);animation:feedSlideIn .3s ease}.feed-item .feed-time{font-size:.65rem;color:var(--text-muted);float:right}.feed-item.hype{border-left:3px solid #f97316}.feed-item.request{border-left:3px solid var(--cyan)}.feed-item.chat{border-left:3px solid #8b5cf6}.feed-item .feed-song{font-weight:600;color:var(--text-primary)}@keyframes feedSlideIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.app-container.has-sidebar .main-content{margin-left:200px;transition:margin-left .3s ease}.app-container.has-sidebar.sidebar-collapsed .main-content{margin-left:0}@media(max-width:900px){.dj-sidebar{width:200px}.dj-sidebar.collapsed{transform:translate(-200px)}.app-container.has-sidebar .main-content{margin-left:0}}.dj-login-btn{padding:8px 16px;background:#ffffff0d;border:1px solid var(--glass-border);color:var(--text-secondary);font-family:var(--font-body);font-size:.85rem;font-weight:600;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition-med)}.dj-login-btn:hover{background:#00f0ff1a;border-color:var(--cyan);color:var(--cyan)}.dj-login-btn.hidden{display:none}.dj-logout-btn{padding:8px 16px;background:#ff006e14;border:1px solid rgba(255,0,110,.3);color:var(--magenta);font-family:var(--font-body);font-size:.85rem;font-weight:600;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition-med);align-items:center;gap:6px}.dj-logout-btn:hover{background:#ff006e2e;border-color:var(--magenta);box-shadow:0 0 16px #ff006e40}.on-air{display:flex;align-items:center;gap:6px;padding:6px 14px;background:#ff3c7814;border:1px solid rgba(255,60,120,.2);border-radius:100px;opacity:0;transform:scale(.9);transition:var(--transition-med)}.on-air.active{opacity:1;transform:scale(1)}.on-air-dot{width:6px;height:6px;border-radius:50%;background:#ff3c78;box-shadow:0 0 6px #ff3c78;animation:onAirPulse 2s ease-in-out infinite}@keyframes onAirPulse{0%,to{box-shadow:0 0 4px #ff3c78}50%{box-shadow:0 0 12px #ff3c78,0 0 20px #ff3c784d}}.on-air-text{font-family:var(--font-heading);font-size:.65rem;font-weight:700;color:#ff3c78;letter-spacing:2.5px;text-transform:uppercase}.main-content{display:grid;grid-template-columns:1fr 340px;gap:20px;flex:1}.player-section{display:flex;flex-direction:column}.upload-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:60px 40px;background:var(--bg-card);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:2px dashed rgba(255,255,255,.12);border-radius:var(--radius-xl);cursor:pointer;transition:var(--transition-med);text-align:center;min-height:350px}.upload-zone:hover,.upload-zone.drag-over{border-color:var(--cyan);background:#00f0ff0a;transform:scale(1.01)}.upload-zone.drag-over{box-shadow:0 0 40px #00f0ff26}.upload-icon{width:64px;height:64px;color:var(--text-secondary);transition:var(--transition-med)}.upload-zone:hover .upload-icon{color:var(--cyan);transform:translateY(-4px)}.upload-zone h2{font-family:var(--font-heading);font-size:1.4rem;font-weight:600;color:var(--text-primary)}.upload-zone p{color:var(--text-secondary);font-size:.9rem}.upload-zone input[type=file]{display:none}.upload-progress-overlay{position:fixed;bottom:28px;right:28px;z-index:9999;width:280px;padding:16px 20px;background:#0c0c1eeb;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(0,240,255,.25);border-radius:var(--radius-md);box-shadow:0 8px 32px #00000080,0 0 24px #00f0ff14;display:flex;flex-direction:column;gap:10px;animation:slideUpFade .3s ease}@keyframes slideUpFade{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.upload-progress-header{display:flex;align-items:center;gap:8px}.upload-progress-header span{font-size:.82rem;font-weight:600;color:var(--cyan);font-variant-numeric:tabular-nums;letter-spacing:.3px}.upload-progress-bar-wrap{width:100%;height:6px;background:#ffffff14;border-radius:100px;overflow:hidden}.upload-progress-fill{height:100%;width:0%;background:linear-gradient(90deg,var(--cyan),var(--violet));border-radius:100px;transition:width .25s ease;position:relative}.upload-progress-fill:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.35),transparent);animation:shimmer 1.2s infinite}.upload-progress-fill:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 1.2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(200%)}}.upload-progress-label{font-size:.8rem;color:var(--cyan);font-weight:600;font-variant-numeric:tabular-nums;letter-spacing:.5px}.now-playing{display:flex;flex-direction:column;align-items:center;gap:24px;padding:40px 32px 32px;background:var(--bg-card);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-xl)}.album-art{position:relative;width:200px;height:200px;border-radius:50%;background:linear-gradient(135deg,#00f0ff1a,#8b5cf61a);display:flex;align-items:center;justify-content:center;overflow:hidden}.album-art-placeholder{width:80px;height:80px;color:var(--text-muted)}.vinyl-spin{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;border:2px solid rgba(255,255,255,.05);border-top-color:var(--cyan);border-right-color:var(--violet);animation:none}.vinyl-spin.spinning{animation:vinylRotate 3s linear infinite}@keyframes vinylRotate{to{transform:rotate(360deg)}}.track-info{text-align:center}.track-title{font-family:var(--font-heading);font-size:1.3rem;font-weight:600;margin-bottom:8px;max-width:400px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.track-meta{display:flex;align-items:center;justify-content:center;gap:12px;font-size:.75rem}.deck-indicator{padding:3px 10px;border-radius:100px;background:#00f0ff26;color:var(--cyan);font-weight:600;letter-spacing:1px;font-size:.65rem}.crossfade-status{color:var(--violet-soft);font-weight:500}.progress-container{display:flex;align-items:center;gap:12px;width:100%;padding:0 8px}.time-display{font-size:.75rem;color:var(--text-secondary);font-variant-numeric:tabular-nums;min-width:36px;text-align:center}.progress-bar{flex:1;height:5px;background:#ffffff14;border-radius:100px;cursor:pointer;position:relative;transition:height var(--transition-fast)}.progress-bar:hover{height:8px}.progress-fill{height:100%;background:linear-gradient(90deg,var(--cyan),var(--violet));border-radius:100px;width:0%;transition:width .1s linear;position:relative}.progress-handle{position:absolute;top:50%;right:-6px;width:12px;height:12px;border-radius:50%;background:var(--text-primary);transform:translateY(-50%) scale(0);transition:transform var(--transition-fast);box-shadow:0 0 10px #00f0ff80}.progress-bar:hover .progress-handle{transform:translateY(-50%) scale(1)}.controls{display:flex;align-items:center;justify-content:center;gap:16px}.control-btn{width:44px;height:44px;border:none;background:#ffffff0f;color:var(--text-secondary);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition-med)}.control-btn svg{width:18px;height:18px}.control-btn:hover{background:#ffffff1f;color:var(--text-primary);transform:scale(1.08)}.control-btn.active{color:var(--cyan);background:#00f0ff1f}.control-btn.play-btn{width:60px;height:60px;background:linear-gradient(135deg,var(--cyan),var(--violet));color:#fff;box-shadow:0 4px 24px #00f0ff40}.control-btn.play-btn svg{width:24px;height:24px}.control-btn.play-btn:hover{transform:scale(1.1);box-shadow:0 6px 32px #00f0ff59}.dj-controls{display:flex;gap:24px;width:100%;padding:0 8px}.slider-group{flex:1;display:flex;flex-direction:column;gap:8px}.slider-group label{display:flex;align-items:center;gap:6px;font-size:.75rem;color:var(--text-secondary);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.slider-group label svg{opacity:.6}.slider-group span{font-size:.7rem;color:var(--text-muted);text-align:right}input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:5px;background:#ffffff14;border-radius:100px;outline:none;cursor:pointer}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--text-primary);box-shadow:0 0 8px #00f0ff66;cursor:pointer;transition:transform var(--transition-fast)}input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.2)}input[type=range]::-moz-range-thumb{width:16px;height:16px;border:none;border-radius:50%;background:var(--text-primary);box-shadow:0 0 8px #00f0ff66;cursor:pointer}.mix-now-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;border:1px solid rgba(255,0,110,.3);background:#ff006e1a;color:var(--magenta);font-family:var(--font-body);font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-med)}.mix-now-btn:hover{background:#ff006e33;border-color:var(--magenta);box-shadow:0 4px 16px #ff006e33;transform:translateY(-2px)}.mix-now-btn svg{transition:var(--transition-fast)}.mix-now-btn:active svg{transform:scale(.9)}.add-music-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px;border:1px dashed rgba(255,255,255,.12);background:transparent;color:var(--text-secondary);font-family:var(--font-body);font-size:.85rem;font-weight:500;border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-med)}.add-music-btn:hover{border-color:var(--cyan);color:var(--cyan);background:#00f0ff0a}.playlist-section{display:flex;flex-direction:column;background:var(--bg-card);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-xl);overflow:hidden;max-height:calc(100vh - 120px)}.playlist-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--glass-border)}.playlist-header h2{font-family:var(--font-heading);font-size:1.1rem;font-weight:600}.track-count{font-size:.75rem;color:var(--text-secondary);padding:4px 12px;background:#ffffff0f;border-radius:100px}.playlist{list-style:none;overflow-y:auto;flex:1;padding:8px}.playlist::-webkit-scrollbar{width:4px}.playlist::-webkit-scrollbar-track{background:transparent}.playlist::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:100px}.playlist-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-med);position:relative;overflow:hidden}.playlist-item:hover{background:var(--bg-card-hover)}.playlist-item.active{background:#00f0ff14;border:1px solid rgba(0,240,255,.15)}.playlist-item.dragging{opacity:.5;background:#ffffff1a;border:1px dashed var(--cyan)}.playlist-item.drag-over-item{border-top:2px solid var(--magenta)}.playlist-item.active .playlist-item-title{color:var(--cyan)}.playlist-item-number{font-size:.75rem;color:var(--text-muted);min-width:20px;text-align:center;font-variant-numeric:tabular-nums}.playlist-item.active .playlist-item-number{position:relative}.playlist-item.active .playlist-item-number:after{content:"";display:none}.playing-bars{display:flex;align-items:flex-end;gap:2px;height:14px}.playing-bars span{width:3px;background:var(--cyan);border-radius:2px;animation:playingBar .8s ease-in-out infinite}.playing-bars span:nth-child(1){animation-delay:0s;height:60%}.playing-bars span:nth-child(2){animation-delay:.2s;height:100%}.playing-bars span:nth-child(3){animation-delay:.4s;height:40%}@keyframes playingBar{0%,to{transform:scaleY(.4)}50%{transform:scaleY(1)}}.playlist-item-info{flex:1;overflow:hidden}.playlist-item-title{font-size:.85rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color var(--transition-fast)}.playlist-item-duration{font-size:.7rem;color:var(--text-muted);margin-top:2px}.playlist-item-remove{width:28px;height:28px;border:none;background:transparent;color:var(--text-muted);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:var(--transition-fast)}.playlist-item:hover .playlist-item-remove{opacity:1}.playlist-item-remove:hover{background:#ff006e26;color:var(--magenta)}.playlist-item-remove svg{width:14px;height:14px}.playlist-empty{display:flex;align-items:center;justify-content:center;flex:1;padding:40px}.playlist-empty p{color:var(--text-muted);font-size:.85rem}@media(max-width:900px){.main-content{grid-template-columns:1fr}.playlist-section{max-height:350px}}@media(max-width:600px){.app-container{padding:12px}.header{padding:12px 16px}.logo h1{font-size:1.4rem}.now-playing{padding:24px 16px 20px;gap:18px}.album-art{width:150px;height:150px}.controls{gap:12px}.control-btn.play-btn{width:52px;height:52px}.dj-controls{flex-direction:column;gap:16px}.upload-zone{padding:40px 20px;min-height:260px}}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0a1ad9;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px}.role-card{background:var(--bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-xl);padding:40px;max-width:500px;width:100%;display:flex;flex-direction:column;align-items:center;gap:24px;text-align:center;box-shadow:0 20px 60px #00000080;animation:fadeIn .4s ease-out}.role-card h2{font-family:var(--font-heading);font-size:1.8rem;font-weight:700}.role-card p{color:var(--text-secondary)}.logo-icon.large{width:80px;height:80px}.role-buttons{display:flex;flex-direction:column;gap:16px;width:100%}.role-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:20px;border:1px solid var(--glass-border);border-radius:var(--radius-lg);background:#ffffff08;color:var(--text-primary);font-family:var(--font-body);font-size:1.1rem;font-weight:600;cursor:pointer;transition:var(--transition-med)}.role-btn span{font-size:2rem;margin-bottom:8px}.role-btn small{font-size:.8rem;color:var(--text-muted);font-weight:400}.role-btn:hover{transform:translateY(-4px);background:#ffffff14}.role-btn.dj:hover{border-color:var(--cyan);box-shadow:0 10px 30px #00f0ff26}.role-btn.listener:hover{border-color:var(--violet);box-shadow:0 10px 30px #8b5cf626}.text-center{text-align:center}.tune-in-btn{font-size:1.1rem;padding:16px 32px;background:linear-gradient(135deg,var(--cyan),var(--violet));border:none;color:#fff;margin-top:16px;width:auto}.tune-in-btn:hover{transform:scale(1.05);box-shadow:0 10px 30px #00f0ff4d}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .4s ease-out forwards}.sets-bar{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid var(--glass-border);margin-bottom:8px}.sets-chips{display:flex;gap:6px;overflow-x:auto;flex:1;scrollbar-width:none}.sets-chips::-webkit-scrollbar{display:none}.set-chip{flex-shrink:0;padding:5px 14px;border-radius:20px;border:1px solid var(--glass-border);background:#ffffff0a;color:var(--text-secondary);font-family:var(--font-body);font-size:.72rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.set-chip:hover{background:#ffffff14;color:var(--text-primary)}.set-chip.active{background:linear-gradient(135deg,#00f0ff33,#8b5cf633);border-color:var(--cyan);color:var(--cyan);font-weight:600}.set-chip .set-delete{margin-left:6px;opacity:0;transition:opacity var(--transition-fast);cursor:pointer;font-size:.65rem}.set-chip:hover .set-delete{opacity:.7}.set-chip .set-delete:hover{opacity:1;color:var(--magenta)}.set-add-btn{width:28px;height:28px;border-radius:50%;border:1px dashed var(--glass-border);background:transparent;color:var(--text-secondary);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);flex-shrink:0}.set-add-btn:hover{border-color:var(--cyan);color:var(--cyan);background:#00f0ff14}.advanced-toggle-btn{width:100%;padding:10px 16px;border-radius:var(--radius-sm);border:1px solid var(--glass-border);background:#ffffff08;color:var(--text-secondary);font-family:var(--font-body);font-size:.78rem;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all var(--transition-fast);margin-top:8px}.advanced-toggle-btn:hover{background:#ffffff0f;color:var(--cyan);border-color:#00f0ff4d}.advanced-toggle-btn.open{color:var(--cyan);border-color:#00f0ff4d;background:#00f0ff0d}.advanced-toggle-btn .chevron-icon{transition:transform var(--transition-fast)}.advanced-toggle-btn.open .chevron-icon{transform:rotate(180deg)}.advanced-tools{background:#0000004d;border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:16px;margin-top:8px;animation:slideDown .25s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.adv-tool-row{display:flex;gap:12px;align-items:center}.adv-tool-row+.adv-tool-row{margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,.04)}.bpm-display{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:72px;padding:8px 12px;border-radius:var(--radius-sm);background:#00f0ff0f;border:1px solid rgba(0,240,255,.15)}.bpm-label{font-size:.6rem;font-weight:600;color:var(--cyan);letter-spacing:1.5px;text-transform:uppercase}.bpm-value{font-size:1.4rem;font-weight:700;font-family:var(--font-heading);color:var(--text-primary);line-height:1}.adv-slider{flex:1;display:flex;flex-direction:column;gap:3px}.adv-slider-wide{flex:2}.adv-slider label{font-size:.65rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;font-weight:600;display:flex;justify-content:space-between}.adv-slider span{font-size:.65rem;color:var(--text-secondary);text-align:right;font-variant-numeric:tabular-nums}.adv-slider input[type=range]{width:100%;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#ffffff1a;border-radius:2px;outline:none}.adv-slider input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;border-radius:50%;background:var(--cyan);cursor:pointer;box-shadow:0 0 8px #00f0ff66}.bpm-badge{font-size:.6rem;padding:1px 6px;border-radius:8px;background:#00f0ff26;color:var(--cyan);font-weight:600;margin-left:4px;letter-spacing:.3px}.playlist-item .bpm-badge{font-size:.58rem;opacity:.7}.autopilot-badge{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border-radius:100px;background:#22c55e14;border:1px solid rgba(34,197,94,.2);color:var(--green);font-size:.65rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.smart-mix-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius-sm);border:1px solid rgba(139,92,246,.4);background:linear-gradient(135deg,#8b5cf626,#00f0ff1a);color:var(--violet-soft);font-family:var(--font-body);font-size:.78rem;font-weight:600;cursor:pointer;transition:all var(--transition-med);white-space:nowrap}.smart-mix-btn:hover{background:linear-gradient(135deg,#8b5cf64d,#00f0ff33);border-color:var(--violet);box-shadow:0 0 20px #8b5cf640;transform:translateY(-1px)}.smart-mix-btn:active{transform:translateY(0)}.listener-tip-section{position:fixed;bottom:24px;left:50%;transform:translate(-50%);display:flex;align-items:center;justify-content:center;gap:10px;padding:10px 20px;border-radius:100px;background:#0a0a1ecc;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.08);z-index:100;box-shadow:0 8px 32px #0006}.reaction-btn{width:44px;height:44px;border-radius:50%;border:1px solid rgba(255,255,255,.1);background:#ffffff0d;font-size:1.3rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;padding:0;line-height:1;flex-shrink:0}.reaction-btn:hover{background:#ffffff26;border-color:#00f0ff4d;transform:scale(1.18);box-shadow:0 0 16px #00f0ff26}.reaction-btn:active{transform:scale(.88)}.footer-divider{width:1px;height:24px;background:#ffffff1a;flex-shrink:0}.tip-dj-btn,.tip-count{display:none}.request-btn{padding:8px 16px;border-radius:100px;border:1px solid rgba(255,255,255,.08);background:#ffffff0a;color:var(--text-secondary);font-family:var(--font-body);font-size:.78rem;font-weight:500;cursor:pointer;transition:all var(--transition-med);white-space:nowrap}.request-btn:hover{background:#ffffff1a;border-color:var(--cyan);color:var(--text-primary)}@media(max-width:480px){.listener-tip-section{bottom:12px;padding:8px 14px;gap:6px}.reaction-btn{width:38px;height:38px;font-size:1.1rem}.request-btn{padding:6px 12px;font-size:.72rem}}.reaction-float{position:fixed;font-size:2.5rem;pointer-events:none;z-index:9999;animation:reactionFloat 1.8s ease-out forwards;filter:drop-shadow(0 0 8px rgba(255,255,255,.3))}@keyframes reactionFloat{0%{opacity:1;transform:translateY(0) scale(.5) rotate(0)}20%{opacity:1;transform:translateY(-40px) scale(1.3) rotate(-10deg)}50%{opacity:.9;transform:translateY(-120px) scale(1.1) rotate(5deg)}to{opacity:0;transform:translateY(-280px) scale(.6) rotate(-15deg)}}.reaction-spray{position:fixed;font-size:1.6rem;pointer-events:none;z-index:9999;animation:reactionSpray var(--spray-duration, 1.5s) ease-out forwards}@keyframes reactionSpray{0%{opacity:1;transform:translate(0) scale(.3) rotate(0)}30%{opacity:1;transform:translate(var(--spray-x, 20px),var(--spray-y, -60px)) scale(1.2) rotate(var(--spray-rot, 15deg))}to{opacity:0;transform:translate(calc(var(--spray-x, 20px) * 2),calc(var(--spray-y, -60px) * 2.5)) scale(.4) rotate(calc(var(--spray-rot, 15deg) * 2))}}.dual-deck{display:grid;grid-template-columns:1fr auto 1fr;gap:12px;width:100%;align-items:stretch;min-width:600px}.deck-panel{background:var(--bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-md);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));padding:16px;display:flex;flex-direction:column;gap:10px;min-width:240px}.deck-header{display:flex;justify-content:space-between;align-items:center}.deck-label{font-family:var(--font-heading);font-weight:700;font-size:.85rem;letter-spacing:1px}.deck-a-label{color:var(--cyan)}.deck-b-label{color:var(--magenta)}.deck-bpm{font-size:.7rem;color:var(--text-muted);font-variant-numeric:tabular-nums}.deck-track-name{font-size:.85rem;color:var(--text-primary);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-height:1.2em}.deck-progress{display:flex;align-items:center;gap:6px}.deck-time{font-size:.65rem;color:var(--text-muted);font-variant-numeric:tabular-nums;min-width:28px}.deck-progress-bar{flex:1;height:6px;background:#ffffff0f;border-radius:3px;position:relative;cursor:pointer}.deck-progress-fill{height:100%;border-radius:3px;width:0%;transition:width .1s linear}#deck-a-panel .deck-progress-fill{background:linear-gradient(90deg,var(--cyan),var(--violet))}#deck-b-panel .deck-progress-fill{background:linear-gradient(90deg,var(--magenta),var(--violet))}.deck-progress-handle{position:absolute;top:50%;width:10px;height:10px;background:#fff;border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 0 6px #0006;left:0%}.deck-controls{display:flex;align-items:center;gap:10px}.deck-play-btn{width:40px;height:40px;border-radius:50%;border:2px solid var(--glass-border);background:#ffffff0f;color:var(--text-primary);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);flex-shrink:0}.deck-play-btn:hover{background:#ffffff1f;border-color:var(--cyan)}.deck-play-btn.playing{background:linear-gradient(135deg,var(--cyan),var(--violet));border-color:transparent}.deck-slider{display:flex;align-items:center;gap:4px;flex:1}.deck-slider label{font-size:.6rem;color:var(--text-muted);min-width:24px;text-transform:uppercase;letter-spacing:.5px}.deck-slider input[type=range]{flex:1;height:4px}.deck-speed-val{font-size:.6rem;color:var(--text-secondary);font-variant-numeric:tabular-nums;min-width:30px}.deck-eq{display:flex;justify-content:center;gap:16px;padding:4px 0}.eq-knob{display:flex;flex-direction:column;align-items:center;gap:4px}.eq-knob label{font-size:.6rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.eq-knob input[type=range]{writing-mode:vertical-lr;direction:rtl;height:50px;width:4px}.deck-load-btn{padding:6px 12px;border-radius:var(--radius-sm);border:1px dashed var(--glass-border);background:none;color:var(--text-secondary);font-family:var(--font-body);font-size:.72rem;cursor:pointer;text-align:center;transition:all var(--transition-fast)}.deck-load-btn:hover{border-color:var(--cyan);color:var(--cyan);background:#00f0ff0d}.crossfader-section{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:12px 8px;min-width:80px}.crossfader-label{font-family:var(--font-heading);font-weight:700;font-size:.75rem;color:var(--text-muted)}.crossfader-wrapper{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:12px}.crossfader-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#ffffff26;border-radius:8px;width:140px;height:6px;cursor:pointer;outline:none}.crossfader-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:28px;border-radius:4px;background:#fff;box-shadow:0 0 12px #00f0ff99;cursor:pointer;border:2px solid var(--cyan)}.crossfader-slider::-moz-range-thumb{width:18px;height:28px;border-radius:4px;background:#fff;box-shadow:0 0 12px #00f0ff99;cursor:pointer;border:2px solid var(--cyan)}.crossfader-actions{display:flex;flex-direction:row;justify-content:center;gap:8px;margin-top:12px}.crossfader-actions .mix-now-btn,.crossfader-actions .smart-mix-btn{padding:6px 8px;font-size:.65rem;min-width:unset}.shared-controls{display:flex;gap:10px;margin-top:12px;justify-content:center}.listener-view{max-width:500px;margin:0 auto}.header-share-btn{padding:6px 14px;border-radius:var(--radius-lg);border:1px solid var(--glass-border);background:#ffffff0f;color:var(--text-primary);font-family:var(--font-body);font-size:.8rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.header-share-btn:hover{background:#ffffff1f;border-color:var(--cyan)}.deck-load-btns{display:flex;gap:3px;margin-left:auto;flex-shrink:0}.load-to-deck{width:22px;height:22px;border-radius:4px;border:1px solid var(--glass-border);background:#ffffff0a;color:var(--text-muted);font-family:var(--font-heading);font-size:.6rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.load-to-deck[data-deck=A]:hover{background:#00f0ff26;border-color:var(--cyan);color:var(--cyan)}.load-to-deck[data-deck=B]:hover{background:#ff00aa26;border-color:var(--magenta);color:var(--magenta)}
