*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:100%;-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{min-height:100vh;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit;color:inherit}button{cursor:pointer;border:none;background:none}a{color:inherit;text-decoration:none}ul,ol{list-style:none}h1,h2,h3,h4,h5,h6,p{overflow-wrap:break-word}:root{--color-bg-primary: #0a1628;--color-bg-secondary: #0e1f3d;--color-bg-tertiary: #132847;--color-bg-card: rgba(14, 31, 61, .6);--color-bg-glass: rgba(19, 40, 71, .45);--color-accent-primary: #2dd4bf;--color-accent-secondary: #06b6d4;--color-accent-glow: rgba(45, 212, 191, .3);--color-accent-hover: #5eead4;--color-text-primary: #f1f5f9;--color-text-secondary: #94a3b8;--color-text-muted: #64748b;--color-text-accent: #2dd4bf;--color-border-subtle: rgba(148, 163, 184, .15);--color-border-accent: rgba(45, 212, 191, .4);--color-danger: #f43f5e;--color-warning: #f59e0b;--color-success: #22c55e;--font-primary: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-display: "Outfit", "Inter", sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-md: 1.125rem;--font-size-lg: 1.25rem;--font-size-xl: 1.5rem;--font-size-2xl: 2rem;--font-size-3xl: 2.5rem;--font-size-hero: 4.5rem;--font-weight-light: 300;--font-weight-regular: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--font-weight-extrabold: 800;--line-height-tight: 1.1;--line-height-snug: 1.3;--line-height-normal: 1.5;--line-height-relaxed: 1.7;--letter-spacing-tight: -.02em;--letter-spacing-normal: 0;--letter-spacing-wide: .08em;--letter-spacing-wider: .15em;--letter-spacing-widest: .25em;--spacing-2xs: .25rem;--spacing-xs: .5rem;--spacing-sm: .75rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--spacing-4xl: 6rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl: 24px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-glow: 0 0 20px var(--color-accent-glow);--shadow-glow-lg: 0 0 40px var(--color-accent-glow);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s ease;--transition-spring: .3s cubic-bezier(.34, 1.56, .64, 1);--z-base: 0;--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-modal: 400;--z-toast: 500;--container-max: 1280px;--container-padding: var(--spacing-lg);--color-deck-a: #2dd4bf;--color-deck-b: #a78bfa;--color-deck-a-glow: rgba(45, 212, 191, .25);--color-deck-b-glow: rgba(167, 139, 250, .25);--color-source-local: #22c55e;--color-source-youtube: #ef4444;--color-source-spotify: #1db954;--color-source-soundcloud: #ff7700;--color-source-jamendo: #2ec4b6;--knob-size: 48px;--fader-track-width: 6px;--fader-track-height: 120px;--fader-thumb-size: 20px;--crossfader-track-height: 8px;--crossfader-width: 280px;--waveform-height: 64px;--waveform-bg: rgba(19, 40, 71, .6)}body{font-family:var(--font-primary);font-size:var(--font-size-base);font-weight:var(--font-weight-regular);line-height:var(--line-height-normal);color:var(--color-text-primary);background-color:var(--color-bg-primary);overflow-x:hidden}.container{width:100%;max-width:var(--container-max);margin-inline:auto;padding-inline:var(--container-padding)}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}::selection{background:var(--color-accent-primary);color:var(--color-bg-primary)}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--color-bg-primary)}::-webkit-scrollbar-thumb{background:var(--color-bg-tertiary);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}:focus-visible{outline:2px solid var(--color-accent-primary);outline-offset:2px}.bottom-section{display:flex;gap:var(--spacing-lg);max-width:1200px;margin:var(--spacing-xl) auto var(--spacing-3xl);padding-inline:var(--spacing-lg);align-items:flex-start}@media(max-width:768px){.bottom-section{flex-direction:column;padding-inline:var(--spacing-md)}}.navbar{position:fixed;top:0;left:0;right:0;z-index:var(--z-fixed);background:#0a1628eb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--color-border-subtle)}.navbar__container{display:flex;align-items:center;justify-content:space-between;max-width:var(--container-max);margin-inline:auto;padding:var(--spacing-md) var(--container-padding)}.navbar__menu{display:flex;align-items:center;gap:var(--spacing-xl)}.navbar__link{font-family:var(--font-display);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);letter-spacing:var(--letter-spacing-wider);text-transform:uppercase;transition:color var(--transition-fast);position:relative;display:flex;align-items:center;gap:var(--spacing-2xs);padding:var(--spacing-xs) 0}.navbar__link:hover,.navbar__link--active{color:var(--color-text-primary)}.navbar__link--active:after{content:"";position:absolute;bottom:0;left:0;width:100%;height:2px;background:var(--color-accent-primary);border-radius:var(--radius-full)}.navbar__link-chevron{font-size:var(--font-size-xs);opacity:.6;transition:transform var(--transition-fast)}.navbar__link:hover .navbar__link-chevron{transform:translateY(1px)}.navbar__right{display:flex;align-items:center;gap:var(--spacing-md)}.navbar__login-btn{font-family:var(--font-display);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-wider);text-transform:uppercase;color:var(--color-bg-primary);background:linear-gradient(135deg,var(--color-accent-primary),var(--color-deck-b));border:none;border-radius:var(--radius-md);padding:var(--spacing-xs) var(--spacing-md);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.navbar__login-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #2dd4bf4d}.navbar__user-zone{display:flex;align-items:center;gap:var(--spacing-xs);position:relative}.navbar__action-btn{font-family:var(--font-display);font-size:10px;font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-wide);text-transform:uppercase;padding:var(--spacing-2xs) var(--spacing-sm);border-radius:var(--radius-md);border:1px solid var(--color-border-subtle);background:var(--color-bg-card);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;display:flex;align-items:center;gap:var(--spacing-2xs)}.navbar__action-btn:hover{border-color:var(--color-accent-primary);color:var(--color-accent-primary)}.navbar__action-btn--live{border-color:#f43f5e4d;color:var(--color-danger)}.navbar__action-btn--live:hover{border-color:var(--color-danger);box-shadow:0 0 8px #f43f5e33}.navbar__live-dot{width:6px;height:6px;border-radius:50%;background:var(--color-danger);animation:navLivePulse 1.2s ease-in-out infinite}.navbar__avatar-btn{position:relative;background:transparent;border:none;cursor:pointer;padding:0}.navbar__avatar-circle{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--color-accent-primary),var(--color-deck-b));display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--color-bg-primary);transition:transform var(--transition-spring)}.navbar__avatar-btn:hover .navbar__avatar-circle{transform:scale(1.1)}.navbar__role-badge{position:absolute;bottom:-2px;right:-4px;font-size:10px;line-height:1}.navbar__user-dropdown{position:absolute;top:100%;right:0;margin-top:var(--spacing-xs);background:var(--color-bg-secondary);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);padding:var(--spacing-sm) 0;min-width:200px;box-shadow:0 12px 32px #0006;z-index:100}.navbar__dropdown-header{padding:var(--spacing-xs) var(--spacing-md);display:flex;flex-direction:column;gap:2px}.navbar__dropdown-name{font-family:var(--font-display);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.navbar__dropdown-role{font-family:var(--font-primary);font-size:var(--font-size-xs);color:var(--color-text-muted)}.navbar__dropdown-divider{height:1px;background:var(--color-border-subtle);margin:var(--spacing-2xs) 0}.navbar__dropdown-item{display:block;width:100%;text-align:left;font-family:var(--font-primary);font-size:var(--font-size-sm);color:var(--color-text-secondary);background:transparent;border:none;padding:var(--spacing-xs) var(--spacing-md);cursor:pointer;transition:all var(--transition-fast)}.navbar__dropdown-item:hover{background:var(--color-bg-glass);color:var(--color-text-primary)}.navbar__dropdown-item--danger:hover{color:var(--color-danger)}@keyframes navLivePulse{0%,to{opacity:1}50%{opacity:.3}}.navbar__hamburger{display:none;flex-direction:column;gap:5px;padding:var(--spacing-xs)}.navbar__hamburger-line{width:24px;height:2px;background:var(--color-text-primary);border-radius:var(--radius-full);transition:transform var(--transition-base),opacity var(--transition-fast)}@media(max-width:900px){.navbar__hamburger{display:flex}.navbar__menu{display:none;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:#0a1628f7;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);padding:var(--spacing-lg);gap:var(--spacing-md);border-bottom:1px solid var(--color-border-subtle)}.navbar__menu--open{display:flex}.navbar__social{display:none}.navbar__action-btn{font-size:9px;padding:var(--spacing-2xs) var(--spacing-xs)}}.audio-player{position:fixed;top:60px;left:0;right:0;z-index:var(--z-sticky);background:#0e1f3dd9;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--color-border-subtle);padding:var(--spacing-xs) 0}.audio-player__container{display:flex;align-items:center;gap:var(--spacing-lg);max-width:var(--container-max);margin-inline:auto;padding-inline:var(--container-padding)}.audio-player__volume{display:flex;align-items:center;gap:var(--spacing-xs);flex-shrink:0}.audio-player__volume-icon{color:var(--color-text-secondary);font-size:var(--font-size-lg);transition:color var(--transition-fast)}.audio-player__volume-icon:hover{color:var(--color-text-primary)}.audio-player__slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100px;height:4px;background:var(--color-bg-tertiary);border-radius:var(--radius-full);outline:none;cursor:pointer}.audio-player__slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:12px;height:12px;background:var(--color-accent-primary);border-radius:50%;cursor:pointer;box-shadow:var(--shadow-glow);transition:transform var(--transition-spring)}.audio-player__slider::-webkit-slider-thumb:hover{transform:scale(1.3)}.audio-player__slider::-moz-range-thumb{width:12px;height:12px;background:var(--color-accent-primary);border-radius:50%;border:none;cursor:pointer;box-shadow:var(--shadow-glow)}.audio-player__controls{display:flex;align-items:center;gap:var(--spacing-sm)}.audio-player__btn{color:var(--color-text-secondary);font-size:var(--font-size-md);transition:color var(--transition-fast),transform var(--transition-spring);display:flex;align-items:center;justify-content:center}.audio-player__btn:hover{color:var(--color-text-primary);transform:scale(1.1)}.audio-player__btn--play{width:36px;height:36px;border-radius:50%;border:2px solid var(--color-text-secondary);color:var(--color-text-primary);font-size:var(--font-size-sm);transition:border-color var(--transition-fast),color var(--transition-fast),transform var(--transition-spring)}.audio-player__btn--play:hover{border-color:var(--color-accent-primary);color:var(--color-accent-primary);transform:scale(1.1)}.audio-player__progress{flex:1;height:4px;background:var(--color-bg-tertiary);border-radius:var(--radius-full);cursor:pointer;position:relative;overflow:hidden}.audio-player__progress-fill{height:100%;background:linear-gradient(90deg,var(--color-accent-primary),var(--color-accent-secondary));border-radius:var(--radius-full);transition:width var(--transition-fast);position:relative}.audio-player__progress-fill:after{content:"";position:absolute;right:0;top:50%;transform:translateY(-50%);width:10px;height:10px;background:var(--color-accent-primary);border-radius:50%;box-shadow:var(--shadow-glow)}.audio-player__track{font-family:var(--font-display);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);letter-spacing:var(--letter-spacing-wider);text-transform:uppercase;white-space:nowrap;flex-shrink:0}@media(max-width:640px){.audio-player__slider{width:60px}.audio-player__track{display:none}}.branding{text-align:center;padding:calc(var(--spacing-3xl) + 70px) var(--spacing-lg) var(--spacing-lg);position:relative}.branding__title{font-family:var(--font-display);font-size:clamp(3rem,8vw,5.5rem);font-weight:var(--font-weight-extrabold);letter-spacing:.35em;text-transform:uppercase;line-height:var(--line-height-tight);margin-bottom:var(--spacing-md);display:flex;justify-content:center;gap:.05em}.branding__title-letter{display:inline-block;background:linear-gradient(135deg,var(--color-accent-primary) 0%,var(--color-accent-secondary) 40%,var(--color-deck-b) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:brandingFloat 3s ease-in-out infinite;text-shadow:none}.branding__title-letter:nth-child(1){animation-delay:0s}.branding__title-letter:nth-child(2){animation-delay:.1s}.branding__title-letter:nth-child(3){animation-delay:.2s}.branding__title-letter:nth-child(4){animation-delay:.3s}.branding__title-letter:nth-child(5){animation-delay:.4s}.branding__title-letter:nth-child(6){animation-delay:.5s}.branding__slogan{font-family:var(--font-primary);font-size:var(--font-size-md);font-weight:var(--font-weight-light);color:var(--color-text-secondary);letter-spacing:var(--letter-spacing-wide);margin-bottom:var(--spacing-lg)}.branding__slogan strong{color:var(--color-accent-primary);font-weight:var(--font-weight-bold);-webkit-text-fill-color:var(--color-accent-primary)}.branding__divider{width:120px;height:2px;margin-inline:auto;background:linear-gradient(90deg,transparent 0%,var(--color-accent-primary) 30%,var(--color-deck-b) 70%,transparent 100%);border-radius:var(--radius-full);opacity:.6}.branding:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:500px;height:200px;background:radial-gradient(ellipse at center,var(--color-accent-glow) 0%,transparent 70%);pointer-events:none;opacity:.4}@keyframes brandingFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@media(max-width:640px){.branding{padding:var(--spacing-xl) var(--spacing-md) var(--spacing-md)}.branding__slogan{font-size:var(--font-size-sm)}}.mixer{padding:var(--spacing-xl) var(--spacing-lg);max-width:1400px;margin-inline:auto}.mixer__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-border-subtle)}.mixer__title{font-family:var(--font-display);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-widest);color:var(--color-text-primary);text-transform:uppercase}.mixer__status-indicator{display:flex;align-items:center;gap:var(--spacing-xs)}.mixer__status-dot{width:8px;height:8px;border-radius:50%;background:var(--color-danger);box-shadow:0 0 8px #f43f5e99;animation:mixerPulse 1.5s ease-in-out infinite}.mixer__status-text{font-family:var(--font-display);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-widest);color:var(--color-danger);text-transform:uppercase}.mixer__layout{display:flex;gap:var(--spacing-md);align-items:stretch}.mixer__center-panel{display:flex;flex-direction:column;align-items:center;justify-content:space-between;gap:var(--spacing-md);min-width:200px;padding:var(--spacing-sm) 0}.mixer__eq-row{display:flex;gap:var(--spacing-sm);flex:1}@keyframes mixerPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.85)}}@media(max-width:1024px){.mixer__layout{flex-direction:column;align-items:stretch}.mixer__center-panel{flex-direction:row;min-width:auto;padding:var(--spacing-sm);background:var(--color-bg-card);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg)}.mixer__eq-row{flex-direction:row;gap:var(--spacing-sm)}}@media(max-width:640px){.mixer{padding:var(--spacing-md) var(--spacing-sm)}.mixer__center-panel{flex-direction:column}.mixer__eq-row{width:100%;justify-content:center}}.deck{background:var(--color-bg-card);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-sm);flex:1;min-width:280px;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);transition:box-shadow var(--transition-base),border-color var(--transition-base)}.deck:hover{border-color:var(--color-border-accent)}.deck--a{box-shadow:0 0 24px var(--color-deck-a-glow)}.deck--a:hover{box-shadow:0 0 36px var(--color-deck-a-glow)}.deck--b{box-shadow:0 0 24px var(--color-deck-b-glow)}.deck--b:hover{box-shadow:0 0 36px var(--color-deck-b-glow)}.deck__header{display:flex;align-items:center;justify-content:space-between;padding-bottom:var(--spacing-xs);border-bottom:1px solid var(--color-border-subtle)}.deck__label{font-family:var(--font-display);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-widest);text-transform:uppercase}.deck--a .deck__label{color:var(--color-deck-a)}.deck--b .deck__label{color:var(--color-deck-b)}.deck__source-badge{font-family:var(--font-primary);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);letter-spacing:var(--letter-spacing-wide);padding:2px var(--spacing-xs);border-radius:var(--radius-full);text-transform:uppercase}.deck__source-badge--local{background:#22c55e26;color:var(--color-source-local);border:1px solid rgba(34,197,94,.3)}.deck__source-badge--youtube{background:#ef444426;color:var(--color-source-youtube);border:1px solid rgba(239,68,68,.3)}.deck__source-badge--spotify{background:#1db95426;color:var(--color-source-spotify);border:1px solid rgba(29,185,84,.3)}.deck__source-badge--soundcloud{background:#ff770026;color:var(--color-source-soundcloud);border:1px solid rgba(255,119,0,.3)}.deck__source-badge--jamendo{background:#2ec4b626;color:var(--color-source-jamendo);border:1px solid rgba(46,196,182,.3)}.deck__waveform{position:relative;height:var(--waveform-height);background:var(--waveform-bg);border-radius:var(--radius-md);overflow:hidden;cursor:pointer}.deck__waveform-bars{display:flex;align-items:flex-end;gap:2px;height:100%;padding:4px}.deck__waveform-bar{flex:1;border-radius:1px 1px 0 0;min-height:4px;transition:height var(--transition-fast)}.deck--a .deck__waveform-bar{background:linear-gradient(to top,var(--color-deck-a),rgba(45,212,191,.3))}.deck--b .deck__waveform-bar{background:linear-gradient(to top,var(--color-deck-b),rgba(167,139,250,.3))}.deck__playhead{position:absolute;top:0;bottom:0;width:2px;background:var(--color-text-primary);box-shadow:0 0 6px #ffffff80;transition:left var(--transition-fast);pointer-events:none}.deck__progress-row{display:flex;align-items:center;gap:var(--spacing-xs)}.deck__time{font-family:var(--font-primary);font-size:var(--font-size-xs);color:var(--color-text-muted);font-variant-numeric:tabular-nums;min-width:32px;text-align:center}.deck__progress-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;flex:1;height:4px;background:var(--color-bg-tertiary);border-radius:var(--radius-full);outline:none;cursor:pointer}.deck__progress-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:10px;height:10px;background:var(--color-text-primary);border-radius:50%;cursor:pointer;box-shadow:0 0 4px #ffffff4d}.deck__progress-slider::-moz-range-thumb{width:10px;height:10px;background:var(--color-text-primary);border-radius:50%;border:none;cursor:pointer}.deck__transport{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-xs) 0}.deck__btn{font-family:var(--font-display);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);letter-spacing:var(--letter-spacing-wide);color:var(--color-text-secondary);padding:var(--spacing-2xs) var(--spacing-sm);border-radius:var(--radius-md);border:1px solid var(--color-border-subtle);background:transparent;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.deck__btn:hover{color:var(--color-text-primary);border-color:var(--color-border-accent);background:#2dd4bf0d}.deck__btn--play{width:44px;height:44px;border-radius:50%;font-size:var(--font-size-lg)}.deck--a .deck__btn--play{border-color:var(--color-deck-a);color:var(--color-deck-a)}.deck--a .deck__btn--play:hover{background:#2dd4bf1f;box-shadow:0 0 16px var(--color-deck-a-glow)}.deck--b .deck__btn--play{border-color:var(--color-deck-b);color:var(--color-deck-b)}.deck--b .deck__btn--play:hover{background:#a78bfa1f;box-shadow:0 0 16px var(--color-deck-b-glow)}.deck__footer{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm);padding-top:var(--spacing-xs);border-top:1px solid var(--color-border-subtle)}.deck__track-info{display:flex;flex-direction:column;gap:2px;overflow:hidden;flex:1}.deck__track-title{font-family:var(--font-display);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.deck__track-artist{font-family:var(--font-primary);font-size:var(--font-size-xs);color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.deck__volume{display:flex;align-items:center;gap:var(--spacing-2xs);flex-shrink:0}.deck__volume-label{font-family:var(--font-display);font-size:10px;font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-widest);color:var(--color-text-muted)}.deck__volume-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:70px;height:4px;background:var(--color-bg-tertiary);border-radius:var(--radius-full);outline:none;cursor:pointer}.deck__volume-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:12px;height:12px;background:var(--color-accent-primary);border-radius:50%;cursor:pointer;box-shadow:var(--shadow-glow);transition:transform var(--transition-spring)}.deck__volume-slider::-webkit-slider-thumb:hover{transform:scale(1.3)}.deck__volume-slider::-moz-range-thumb{width:12px;height:12px;background:var(--color-accent-primary);border-radius:50%;border:none;cursor:pointer}.deck__volume-value{font-family:var(--font-primary);font-size:10px;color:var(--color-text-muted);min-width:28px;text-align:right;font-variant-numeric:tabular-nums}.deck__bpm-row{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-xs);padding:var(--spacing-xs) 0;border-top:1px solid var(--color-border-subtle);border-bottom:1px solid var(--color-border-subtle)}.deck__bpm-info,.deck__key-info{display:flex;flex-direction:column;align-items:center;gap:1px;min-width:44px}.deck__bpm-value{font-family:var(--font-display);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text-primary);font-variant-numeric:tabular-nums;line-height:1}.deck--a .deck__bpm-value{color:var(--color-deck-a)}.deck--b .deck__bpm-value{color:var(--color-deck-b)}.deck__bpm-label,.deck__key-label{font-family:var(--font-display);font-size:9px;font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-widest);color:var(--color-text-muted);text-transform:uppercase}.deck__key-value{font-family:var(--font-display);font-size:var(--font-size-md);font-weight:var(--font-weight-bold);color:var(--color-text-secondary);line-height:1}.deck__pitch{display:flex;align-items:center;gap:var(--spacing-2xs);flex:1;justify-content:center}.deck__pitch-label{font-family:var(--font-display);font-size:9px;font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-widest);color:var(--color-text-muted);text-transform:uppercase}.deck__pitch-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:80px;height:4px;background:var(--color-bg-tertiary);border-radius:var(--radius-full);outline:none;cursor:pointer;position:relative}.deck__pitch-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;background:var(--color-text-primary);border-radius:50%;cursor:pointer;box-shadow:0 0 4px #ffffff4d;transition:transform var(--transition-spring)}.deck__pitch-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.deck__pitch-slider::-moz-range-thumb{width:14px;height:14px;background:var(--color-text-primary);border-radius:50%;border:none;cursor:pointer}.deck__pitch-value{font-family:var(--font-primary);font-size:10px;font-weight:var(--font-weight-medium);color:var(--color-text-muted);min-width:36px;text-align:right;font-variant-numeric:tabular-nums}.deck__pitch-value--active{color:var(--color-warning)}.deck--flash{animation:flashDeck .8s ease-out}.deck--a.deck--flash{box-shadow:0 0 40px var(--color-deck-a-glow) inset,0 0 20px var(--color-deck-a-glow)}.deck--b.deck--flash{box-shadow:0 0 40px var(--color-deck-b-glow) inset,0 0 20px var(--color-deck-b-glow)}@keyframes flashDeck{0%{transform:scale(1.02);opacity:.8}50%{transform:scale(1);opacity:1}to{transform:scale(1);box-shadow:none}}@media(max-width:640px){.deck{min-width:0;padding:var(--spacing-sm)}.deck__volume-slider{width:50px}.deck__waveform{height:48px}.deck__pitch-slider{width:50px}.deck__bpm-value{font-size:var(--font-size-base)}}.turntable{position:relative;width:100%;aspect-ratio:1;max-width:220px;margin:var(--spacing-xs) auto;-webkit-user-select:none;user-select:none}.turntable__platter{position:relative;width:100%;height:100%;border-radius:50%;background:radial-gradient(circle at center,#1a1a2e,#16213e 40%,#0f1729);box-shadow:0 0 0 3px #94a3b81f,0 0 0 6px #0a1628cc,0 4px 20px #00000080,inset 0 0 30px #0000004d;display:flex;align-items:center;justify-content:center}.turntable__platter-dots{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%}.turntable__dot{position:absolute;top:50%;left:50%;width:4px;height:4px;margin-left:-2px;border-radius:50%;background:#94a3b840;transform-origin:0 0}.turntable__dot{--dot-radius: calc(50% - 4px) }.turntable__dot:before{content:"";position:absolute;width:4px;height:4px;border-radius:50%;background:#94a3b833;top:calc(var(--dot-radius, 96px) * -1)}.turntable__vinyl{position:relative;width:86%;height:86%;border-radius:50%;background:radial-gradient(circle at center,#0d0d0d,#1a1a1a,#111 40%,#1c1c1c 42%,#0e0e0e 60%,#1a1a1a 62%,#111 80%,#181818);box-shadow:inset 0 0 20px #000c,0 0 10px #0006;display:flex;align-items:center;justify-content:center;cursor:grab;transition:transform .1s linear}.turntable__vinyl:active{cursor:grabbing}.turntable__vinyl--spinning{animation:vinylSpin 1.8s linear infinite}.turntable__groove{position:absolute;border-radius:50%;border:1px solid rgba(255,255,255,.04);pointer-events:none}.turntable__groove--1{top:12%;right:12%;bottom:12%;left:12%;border-color:#ffffff0d}.turntable__groove--2{top:22%;right:22%;bottom:22%;left:22%;border-color:#ffffff08}.turntable__groove--3{top:32%;right:32%;bottom:32%;left:32%;border-color:#ffffff0a}.turntable__groove--4{top:42%;right:42%;bottom:42%;left:42%;border-color:#ffffff08}.turntable__light-reflection{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background:linear-gradient(135deg,rgba(255,255,255,.06) 0%,transparent 40%,transparent 60%,rgba(255,255,255,.03) 100%);pointer-events:none}.turntable__label{position:relative;width:38%;height:38%;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;overflow:hidden;z-index:1}.turntable--a .turntable__label{background:radial-gradient(circle at 40% 35%,#1e5f74,#0e3b4f,#0a2540);box-shadow:0 0 8px #2dd4bf33,inset 0 0 10px #0000004d}.turntable--b .turntable__label{background:radial-gradient(circle at 40% 35%,#4c1d95,#2e1065,#1e0a45);box-shadow:0 0 8px #a78bfa33,inset 0 0 10px #0000004d}.turntable__label-title{font-family:var(--font-display);font-size:8px;font-weight:var(--font-weight-bold);color:var(--color-text-primary);text-align:center;line-height:1.1;max-width:90%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;letter-spacing:.02em}.turntable__label-artist{font-family:var(--font-primary);font-size:6px;color:var(--color-text-muted);text-align:center;max-width:90%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.turntable__label-hole{width:6px;height:6px;border-radius:50%;background:#0a0a0a;margin-top:2px;box-shadow:inset 0 1px 2px #ffffff1a}.turntable__tonearm{position:absolute;top:8%;right:6%;transform-origin:top right;transform:rotate(-25deg);transition:transform var(--transition-slow);z-index:2}.turntable__tonearm--active{transform:rotate(-8deg)}.turntable__tonearm-base{position:absolute;top:0;right:0;width:14px;height:14px;border-radius:50%;background:radial-gradient(circle at 40% 35%,#777,#444);box-shadow:0 1px 4px #00000080,inset 0 1px 1px #fff3;z-index:2}.turntable__tonearm-arm{position:absolute;top:7px;right:5px;width:2px;height:80px;background:linear-gradient(180deg,#888,#555,#666);transform:rotate(15deg);transform-origin:top center;border-radius:1px;box-shadow:1px 1px 3px #0000004d}.turntable__tonearm-head{position:absolute;top:82px;right:-4px;width:10px;height:16px;background:linear-gradient(180deg,#999,#666);border-radius:1px 1px 2px 2px;transform:rotate(15deg);transform-origin:top center;box-shadow:1px 2px 4px #0006}.turntable__tonearm-head:after{content:"";position:absolute;bottom:-2px;left:50%;transform:translate(-50%);width:2px;height:4px;background:#aaa;border-radius:0 0 1px 1px}@keyframes vinylSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:768px){.turntable{max-width:160px}.turntable__tonearm-arm{height:60px}.turntable__tonearm-head{top:62px}}@media(max-width:480px){.turntable{max-width:130px}.turntable__label-title{font-size:7px}.turntable__label-artist{font-size:5px}.turntable__tonearm-arm{height:45px}.turntable__tonearm-head{top:47px}}.eq{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-sm);background:var(--color-bg-card);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:opacity var(--transition-base)}.eq--disabled{opacity:.45;pointer-events:none}.eq__title{font-family:var(--font-display);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-widest);text-transform:uppercase;color:var(--color-text-muted)}.eq--a .eq__title{color:var(--color-deck-a)}.eq--b .eq__title{color:var(--color-deck-b)}.eq__disabled-badge{font-family:var(--font-primary);font-size:9px;font-weight:var(--font-weight-semibold);letter-spacing:var(--letter-spacing-wide);color:var(--color-warning);background:#f59e0b1f;border:1px solid rgba(245,158,11,.25);border-radius:var(--radius-full);padding:2px var(--spacing-xs);text-transform:uppercase}.eq__bands{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md)}.eq__band{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-2xs)}.eq__band-value{font-family:var(--font-primary);font-size:10px;font-weight:var(--font-weight-medium);color:var(--color-text-muted);font-variant-numeric:tabular-nums;min-width:28px;text-align:center}.eq__knob{position:relative;width:var(--knob-size);height:var(--knob-size);border-radius:50%;background:radial-gradient(circle at 40% 35%,var(--color-bg-tertiary),var(--color-bg-secondary));box-shadow:inset 0 2px 4px #0006,0 2px 6px #0000004d,0 0 0 2px var(--color-border-subtle);cursor:pointer;transition:box-shadow var(--transition-fast)}.eq__knob:hover{box-shadow:inset 0 2px 4px #0006,0 2px 6px #0000004d,0 0 0 2px var(--color-border-accent)}.eq--a .eq__knob:hover{box-shadow:inset 0 2px 4px #0006,0 0 12px var(--color-deck-a-glow),0 0 0 2px var(--color-deck-a)}.eq--b .eq__knob:hover{box-shadow:inset 0 2px 4px #0006,0 0 12px var(--color-deck-b-glow),0 0 0 2px var(--color-deck-b)}.eq__knob-indicator{position:absolute;top:6px;left:50%;width:2px;height:14px;margin-left:-1px;border-radius:var(--radius-full);transform-origin:center calc(var(--knob-size) / 2 - 6px);transition:transform var(--transition-fast)}.eq--a .eq__knob-indicator{background:var(--color-deck-a);box-shadow:0 0 6px var(--color-deck-a-glow)}.eq--b .eq__knob-indicator{background:var(--color-deck-b);box-shadow:0 0 6px var(--color-deck-b-glow)}.eq__knob-input{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer;border-radius:50%;margin:0}.eq__band-label{font-family:var(--font-display);font-size:10px;font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-widest);color:var(--color-text-secondary);text-transform:uppercase}@media(max-width:768px){.eq{padding:var(--spacing-sm) var(--spacing-xs)}.eq__bands{flex-direction:row;gap:var(--spacing-sm)}.eq__knob{width:36px;height:36px}.eq__knob-indicator{top:4px;height:10px;transform-origin:center 14px}}.crossfader{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg)}.crossfader__label{font-family:var(--font-display);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-widest);text-transform:uppercase;min-width:20px;text-align:center}.crossfader__label--a{color:var(--color-deck-a)}.crossfader__label--b{color:var(--color-deck-b)}.crossfader__track-wrapper{position:relative;width:var(--crossfader-width);height:32px;display:flex;align-items:center}.crossfader__fill{position:absolute;right:0;bottom:0;left:0;height:var(--crossfader-track-height);top:50%;transform:translateY(-50%);border-radius:var(--radius-full);opacity:.3;pointer-events:none}.crossfader__center-mark{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:2px;height:18px;background:var(--color-text-muted);border-radius:var(--radius-full);opacity:.5;pointer-events:none;z-index:1}.crossfader__slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:var(--crossfader-track-height);background:var(--color-bg-tertiary);border-radius:var(--radius-full);outline:none;cursor:pointer;position:relative;z-index:2}.crossfader__slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:28px;height:22px;background:linear-gradient(180deg,#f1f5f9f2,#94a3b8d9);border-radius:var(--radius-sm);cursor:pointer;box-shadow:0 2px 8px #0006,inset 0 1px #ffffff4d;transition:transform var(--transition-spring)}.crossfader__slider::-webkit-slider-thumb:hover{transform:scale(1.08)}.crossfader__slider::-moz-range-thumb{width:28px;height:22px;background:linear-gradient(180deg,#f1f5f9f2,#94a3b8d9);border-radius:var(--radius-sm);border:none;cursor:pointer;box-shadow:0 2px 8px #0006,inset 0 1px #ffffff4d}@media(max-width:768px){.crossfader{padding:var(--spacing-sm) var(--spacing-md)}.crossfader__track-wrapper{width:200px}}@media(max-width:480px){.crossfader__track-wrapper{width:160px}}.master{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-sm);background:var(--color-bg-card);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);min-width:80px}.master__title{font-family:var(--font-display);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-widest);text-transform:uppercase;color:var(--color-text-primary)}.master__vu-meters{display:flex;gap:6px;flex:1}.master__vu-channel{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-2xs)}.master__vu-label{font-family:var(--font-display);font-size:9px;font-weight:var(--font-weight-bold);color:var(--color-text-muted);letter-spacing:var(--letter-spacing-widest)}.master__vu-track{width:12px;height:120px;background:var(--color-bg-tertiary);border-radius:var(--radius-sm);position:relative;overflow:hidden;border:1px solid var(--color-border-subtle)}.master__vu-fill{position:absolute;bottom:0;left:0;right:0;border-radius:0 0 var(--radius-sm) var(--radius-sm);transition:height var(--transition-fast)}.master__vu-fill--left,.master__vu-fill--right{background:linear-gradient(to top,var(--color-success) 0%,var(--color-success) 60%,var(--color-warning) 80%,var(--color-danger) 95%)}.master__volume-control{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-2xs)}.master__mute-btn{font-size:var(--font-size-md);background:transparent;border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);padding:var(--spacing-2xs) var(--spacing-xs);cursor:pointer;transition:all var(--transition-fast);line-height:1}.master__mute-btn:hover{border-color:var(--color-border-accent);background:#2dd4bf0d}.master__mute-btn--active{border-color:var(--color-danger);background:#f43f5e1a}.master__volume-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;writing-mode:vertical-lr;direction:rtl;width:6px;height:80px;background:var(--color-bg-tertiary);border-radius:var(--radius-full);outline:none;cursor:pointer}.master__volume-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:10px;background:linear-gradient(180deg,#f1f5f9f2,#94a3b8d9);border-radius:var(--radius-sm);cursor:pointer;box-shadow:0 1px 4px #0006,inset 0 1px #ffffff4d}.master__volume-slider::-moz-range-thumb{width:18px;height:10px;background:linear-gradient(180deg,#f1f5f9f2,#94a3b8d9);border-radius:var(--radius-sm);border:none;cursor:pointer}.master__volume-value{font-family:var(--font-display);font-size:10px;font-weight:var(--font-weight-bold);color:var(--color-text-secondary);letter-spacing:var(--letter-spacing-wide);text-transform:uppercase;font-variant-numeric:tabular-nums}.master__db-display{display:flex;align-items:baseline;gap:2px;padding:var(--spacing-2xs) var(--spacing-xs);background:#0000004d;border-radius:var(--radius-sm);border:1px solid var(--color-border-subtle)}.master__db-value{font-family:var(--font-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--color-success);font-variant-numeric:tabular-nums}.master__db-label{font-family:var(--font-primary);font-size:9px;color:var(--color-text-muted)}@media(max-width:1024px){.master{flex-direction:row;min-width:auto;gap:var(--spacing-md)}.master__vu-meters{flex-direction:row}.master__vu-track{width:12px;height:60px}.master__volume-slider{writing-mode:horizontal-tb;direction:ltr;width:80px;height:6px}}.deck-switch{display:inline-flex;align-items:center;background:var(--color-bg-tertiary);border:1px solid var(--color-border-subtle);border-radius:999px;padding:2px;margin-left:var(--spacing-sm);box-shadow:0 2px 4px #0003;position:relative;z-index:10}.deck-switch__btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:transparent;color:var(--color-text-muted);font-family:var(--font-display);font-weight:var(--font-weight-bold);font-size:var(--font-size-xs);padding:4px 12px;border-radius:999px;cursor:pointer;transition:all var(--transition-fast);line-height:1;display:flex;align-items:center;justify-content:center;gap:4px;min-width:40px}.deck-switch__btn:hover:not(:disabled){color:var(--color-text-primary);background:var(--color-bg-hover)}.deck-switch__btn--a.is-active{background:#00f5d426;color:var(--color-deck-a);box-shadow:0 0 8px var(--color-deck-a-glow);cursor:default}.deck-switch__btn--b.is-active{background:#a855f726;color:var(--color-deck-b);box-shadow:0 0 8px var(--color-deck-b-glow);cursor:default}.deck-switch__divider{width:1px;height:14px;background:var(--color-border-subtle);margin:0 2px}.queue{flex:1;min-width:0}.queue__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-border-subtle)}.queue__title{font-family:var(--font-display);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-wider);color:var(--color-text-primary);text-transform:uppercase}.queue__count{font-family:var(--font-primary);font-size:var(--font-size-sm);color:var(--color-text-muted)}.queue__list{display:flex;flex-direction:column;gap:2px}.queue__item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-card);border:1px solid transparent;border-radius:var(--radius-md);transition:all var(--transition-fast);cursor:default}.queue__item:hover{background:var(--color-bg-glass);border-color:var(--color-border-subtle)}.queue__item--playing{background:#2dd4bf14;border-color:var(--color-border-accent);box-shadow:0 0 16px var(--color-deck-a-glow)}.queue__position{font-family:var(--font-display);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--color-text-muted);min-width:28px;text-align:center;flex-shrink:0}.queue__item--playing .queue__position{color:var(--color-accent-primary)}.queue__playing-icon{display:flex;align-items:flex-end;gap:2px;height:14px;justify-content:center}.queue__eq-bar{width:3px;background:var(--color-accent-primary);border-radius:1px;animation:queueEqBounce .8s ease-in-out infinite}.queue__eq-bar:nth-child(1){height:60%;animation-delay:0s}.queue__eq-bar:nth-child(2){height:100%;animation-delay:.2s}.queue__eq-bar:nth-child(3){height:40%;animation-delay:.4s}.queue__info{display:flex;flex-direction:column;gap:2px;flex:1;overflow:hidden}.queue__item-title{font-family:var(--font-display);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.queue__item--playing .queue__item-title{color:var(--color-accent-primary)}.queue__item-meta{font-family:var(--font-primary);font-size:var(--font-size-xs);color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.queue__proposed-by{font-family:var(--font-primary);font-size:var(--font-size-xs);color:var(--color-text-muted);white-space:nowrap;flex-shrink:0;display:none}@media(min-width:640px){.queue__proposed-by{display:block}}.queue__votes{display:flex;align-items:center;gap:var(--spacing-2xs);flex-shrink:0}.queue__vote-btn{font-size:10px;color:var(--color-text-muted);padding:4px;border-radius:var(--radius-sm);background:transparent;border:none;cursor:pointer;transition:all var(--transition-fast);line-height:1}.queue__vote-btn:hover{background:var(--color-bg-tertiary)}.queue__vote-btn--up:hover,.queue__vote-btn--up.queue__vote-btn--active{color:var(--color-success);background:#22c55e1a}.queue__vote-btn--down:hover,.queue__vote-btn--down.queue__vote-btn--active{color:var(--color-danger);background:#ef44441a}.queue__vote-count{font-family:var(--font-display);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--color-text-secondary);min-width:24px;text-align:center;font-variant-numeric:tabular-nums}.queue__vote-count--positive{color:var(--color-success)}.queue__vote-count--negative{color:var(--color-danger)}@keyframes queueEqBounce{0%,to{height:30%}50%{height:100%}}@media(max-width:640px){.queue{padding-inline:var(--spacing-md)}.queue__item{gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm)}}.dj-set-manager{flex:1;min-width:300px;max-height:500px;display:flex;flex-direction:column}.sets-layout{display:flex;gap:var(--spacing-md);flex:1;overflow:hidden;margin-top:var(--spacing-md)}.sets-list{flex:1;display:flex;flex-direction:column;gap:var(--spacing-sm);overflow-y:auto;padding-right:var(--spacing-xs)}.sets-list::-webkit-scrollbar{width:6px}.sets-list::-webkit-scrollbar-track{background:transparent}.sets-list::-webkit-scrollbar-thumb{background:var(--color-bg-tertiary);border-radius:var(--radius-full)}.set-card{background:var(--color-bg-tertiary);border:1px solid transparent;border-radius:var(--radius-md);padding:var(--spacing-sm);text-align:left;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;gap:var(--spacing-xs)}.set-card:hover{background:var(--color-bg-hover);transform:translateY(-2px)}.set-card.active{border-color:var(--color-accent-primary);background:rgba(var(--color-accent-primary-rgb),.1)}.set-card-content h3{font-size:var(--font-size-md);color:var(--color-text-primary);margin:0}.set-card-content p{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.set-badge{display:inline-block;font-size:var(--font-size-xs);background:var(--color-bg-elevated);padding:2px 6px;border-radius:var(--radius-sm);color:var(--color-text-muted);margin-top:var(--spacing-xs);align-self:flex-start}.set-detail{flex:1.5;background:var(--color-bg-elevated);border-radius:var(--radius-md);padding:var(--spacing-md);display:flex;flex-direction:column;overflow:hidden}.set-detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-bg-tertiary)}.set-detail-header h3{font-size:var(--font-size-md);margin:0}.set-tracklist{list-style:none;padding:0;margin:0;overflow-y:auto;display:flex;flex-direction:column;gap:var(--spacing-xs)}.set-tracklist::-webkit-scrollbar{width:6px}.set-tracklist::-webkit-scrollbar-thumb{background:var(--color-bg-tertiary);border-radius:var(--radius-full)}.set-track-item{display:flex;align-items:center;justify-content:space-between;background:var(--color-bg-primary);padding:var(--spacing-sm);border-radius:var(--radius-sm);transition:background .2s ease}.set-track-item:hover{background:var(--color-bg-hover)}.track-info{display:flex;flex-direction:column;flex:1;min-width:0}.track-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-artist{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.track-meta{display:flex;gap:var(--spacing-xs);margin-inline:var(--spacing-sm)}.meta-tag{font-size:.65rem;padding:2px 4px;background:var(--color-bg-tertiary);border-radius:var(--radius-sm);color:var(--color-text-muted);white-space:nowrap}.track-actions{display:flex;gap:var(--spacing-xs)}.btn-icon{background:transparent;border:none;cursor:pointer;padding:var(--spacing-xs);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;transition:all .2s ease}.btn-preview{color:var(--color-text-secondary)}.btn-preview:hover{color:var(--color-text-primary);background:var(--color-bg-tertiary);transform:scale(1.1)}.btn-preview.active{color:var(--color-accent-secondary, #10b981);background:#10b9811a;animation:pulse 2s infinite}.btn-inject{color:var(--color-accent-primary)}.btn-inject:hover{background:rgba(var(--color-accent-primary-rgb),.2);transform:scale(1.1)}@keyframes pulse{0%{box-shadow:0 0 #10b98166}70%{box-shadow:0 0 0 6px #10b98100}to{box-shadow:0 0 #10b98100}}.empty-state{display:flex;align-items:center;justify-content:center;height:100%;color:var(--color-text-muted);text-align:center;font-style:italic}@media(max-width:768px){.sets-layout{flex-direction:column}.set-detail{min-height:250px}}.sample-bank{padding:0;min-width:220px;flex-shrink:0}.sample-bank__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-border-subtle)}.sample-bank__title{font-family:var(--font-display);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-widest);color:var(--color-text-primary);text-transform:uppercase;margin:0}.sample-bank__count{font-family:var(--font-primary);font-size:var(--font-size-xs);color:var(--color-text-muted)}.sample-bank__recorder{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.sample-bank__rec-btn{width:72px;height:72px;border-radius:var(--radius-lg);background:linear-gradient(145deg,#f43f5e14,#f43f5e05);border:2px solid rgba(244,63,94,.3);cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-2xs);transition:all var(--transition-fast);position:relative;overflow:hidden;user-select:none;-webkit-user-select:none;touch-action:none}.sample-bank__rec-btn:hover{background:linear-gradient(145deg,#f43f5e26,#f43f5e0d);border-color:#f43f5e80;box-shadow:0 0 16px #f43f5e26}.sample-bank__rec-btn--active{background:linear-gradient(145deg,#f43f5e40,#f43f5e1f);border-color:var(--color-danger);box-shadow:0 0 24px #f43f5e4d;transform:scale(.96)}.sample-bank__rec-btn--active:after{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;border-radius:var(--radius-lg);border:2px solid var(--color-danger);animation:recPulse .8s ease-in-out infinite;pointer-events:none}.sample-bank__rec-icon{width:20px;height:20px;border-radius:50%;background:var(--color-danger);box-shadow:0 0 8px #f43f5e66;transition:all var(--transition-fast)}.sample-bank__rec-btn--active .sample-bank__rec-icon{animation:recGlow .6s ease-in-out infinite}.sample-bank__rec-label{font-family:var(--font-display);font-size:9px;font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-widest);color:var(--color-danger);text-transform:uppercase}.sample-bank__rec-timer{display:flex;align-items:center;gap:var(--spacing-2xs);font-family:var(--font-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--color-danger);font-variant-numeric:tabular-nums}.sample-bank__rec-dot{width:8px;height:8px;border-radius:50%;background:var(--color-danger);animation:recPulse .8s ease-in-out infinite}.sample-bank__rec-hint{font-family:var(--font-primary);font-size:10px;color:var(--color-text-muted);margin:0;text-align:center}.sample-bank__list{display:flex;flex-direction:column;gap:4px}.sample-bank__empty{font-family:var(--font-primary);font-size:var(--font-size-xs);color:var(--color-text-muted);text-align:center;padding:var(--spacing-lg) 0;margin:0}.sample-bank__item{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-bg-card);border:1px solid transparent;border-radius:var(--radius-md);transition:all var(--transition-fast)}.sample-bank__item:hover{background:var(--color-bg-glass);border-color:var(--color-border-subtle)}.sample-bank__item--playing{border-color:var(--color-border-accent);box-shadow:0 0 8px var(--color-deck-a-glow)}.sample-bank__color-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.sample-bank__item-info{display:flex;flex-direction:column;gap:1px;flex:1;min-width:0}.sample-bank__item-name{font-family:var(--font-display);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sample-bank__item-meta{font-family:var(--font-primary);font-size:10px;color:var(--color-text-muted)}.sample-bank__mini-wave{display:flex;align-items:flex-end;gap:1px;height:20px;flex-shrink:0;width:40px}.sample-bank__mini-bar{flex:1;min-height:2px;border-radius:1px 1px 0 0;opacity:.7}.sample-bank__item--playing .sample-bank__mini-bar{opacity:1;animation:sampleBarPulse .6s ease-in-out infinite alternate}.sample-bank__item-actions{display:flex;gap:2px;flex-shrink:0}.sample-bank__play-btn,.sample-bank__delete-btn{width:24px;height:24px;border-radius:var(--radius-sm);border:none;background:transparent;color:var(--color-text-muted);font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.sample-bank__play-btn:hover{background:#2dd4bf1a;color:var(--color-accent-primary)}.sample-bank__delete-btn:hover{background:#f43f5e1a;color:var(--color-danger)}@keyframes recPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.05)}}@keyframes recGlow{0%,to{box-shadow:0 0 8px #f43f5e66}50%{box-shadow:0 0 20px #f43f5eb3}}@keyframes sampleBarPulse{0%{transform:scaleY(.7)}to{transform:scaleY(1)}}@media(max-width:768px){.sample-bank{min-width:0}.sample-bank__rec-btn{width:60px;height:60px}}.room-members{background:var(--bg-surface, #1a1b21);border-radius:var(--radius-lg, 12px);padding:1.5rem;display:flex;flex-direction:column;gap:1rem;border:1px solid rgba(255,255,255,.05);min-width:250px;height:400px}.room-members__header{display:flex;justify-content:space-between;align-items:center}.room-members__title{font-size:1.2rem;color:var(--text-primary, #ffffff);margin:0;font-weight:600}.room-members__refresh-btn{background:none;border:none;cursor:pointer;font-size:1.2rem;opacity:.7;transition:opacity .2s,transform .2s;padding:.2rem}.room-members__refresh-btn:hover{opacity:1;transform:rotate(45deg)}.room-members__empty{text-align:center;color:var(--text-secondary, #a1a1aa);padding:2rem 0;font-size:.9rem;flex:1;display:flex;align-items:center;justify-content:center}.room-members__list{display:flex;flex-direction:column;gap:.8rem;overflow-y:auto;padding-right:.5rem;flex:1}.room-members__list::-webkit-scrollbar{width:6px}.room-members__list::-webkit-scrollbar-track{background:#ffffff0d;border-radius:4px}.room-members__list::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}.room-members__list::-webkit-scrollbar-thumb:hover{background:#fff6}.room-members__item{display:flex;align-items:center;gap:.8rem;background:#ffffff08;padding:.6rem;border-radius:var(--radius-md, 8px);transition:background .2s,transform .2s}.room-members__item:hover{background:#ffffff14;transform:translateY(-1px)}.room-members__avatar{width:38px;height:38px;border-radius:50%;object-fit:cover;background:var(--bg-body, #0f1014);border:1px solid rgba(255,255,255,.1)}.room-members__info{display:flex;flex-direction:column;gap:.2rem}.room-members__name{font-size:.95rem;color:var(--text-primary, #ffffff);font-weight:500}.room-members__role{font-size:.75rem;text-transform:uppercase;font-weight:700;letter-spacing:.05em}.role-dj{color:var(--brand-primary, #1DB954)}.role-listener{color:var(--text-secondary, #a1a1aa)}.login-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md)}.login-modal{background:var(--color-bg-secondary);border:1px solid var(--color-border-subtle);border-radius:var(--radius-xl);padding:var(--spacing-xl);width:100%;max-width:440px;position:relative;box-shadow:0 24px 48px #0006}.login-modal__close{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);background:transparent;border:none;color:var(--color-text-muted);font-size:var(--font-size-md);cursor:pointer;padding:var(--spacing-2xs);border-radius:var(--radius-md);transition:all var(--transition-fast)}.login-modal__close:hover{color:var(--color-text-primary);background:var(--color-bg-tertiary)}.login-modal__title{font-family:var(--font-display);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);text-align:center;margin-bottom:var(--spacing-2xs);background:linear-gradient(135deg,var(--color-accent-primary),var(--color-deck-b));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.login-modal__subtitle{font-family:var(--font-primary);font-size:var(--font-size-sm);color:var(--color-text-muted);text-align:center;margin-bottom:var(--spacing-lg)}.login-modal__form{display:flex;flex-direction:column;gap:var(--spacing-md)}.login-modal__field{display:flex;flex-direction:column;gap:var(--spacing-2xs)}.login-modal__field label{font-family:var(--font-display);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);letter-spacing:var(--letter-spacing-wide);color:var(--color-text-secondary);text-transform:uppercase}.login-modal__field input{font-family:var(--font-primary);font-size:var(--font-size-sm);color:var(--color-text-primary);background:var(--color-bg-card);border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);outline:none;transition:border-color var(--transition-fast)}.login-modal__field input:focus{border-color:var(--color-accent-primary);box-shadow:0 0 0 3px var(--color-accent-glow)}.login-modal__field input::placeholder{color:var(--color-text-muted)}.login-modal__tabs{display:flex;gap:2px;background:var(--color-bg-card);border-radius:var(--radius-md);padding:3px;margin-bottom:var(--spacing-sm)}.login-modal__tab{flex:1;font-family:var(--font-display);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);letter-spacing:var(--letter-spacing-wide);text-transform:uppercase;color:var(--color-text-muted);background:transparent;border:none;border-radius:var(--radius-sm);padding:var(--spacing-xs) var(--spacing-sm);cursor:pointer;transition:all var(--transition-fast)}.login-modal__tab:hover{color:var(--color-text-secondary)}.login-modal__tab--active{color:var(--color-text-primary);background:var(--color-bg-secondary);box-shadow:0 1px 4px #0003}.login-modal__error{font-family:var(--font-primary);font-size:var(--font-size-xs);color:#f87171;background:#f871711a;border:1px solid rgba(248,113,113,.25);border-radius:var(--radius-md);padding:var(--spacing-xs) var(--spacing-sm);text-align:center;margin-bottom:var(--spacing-xs)}.login-modal__submit{font-family:var(--font-display);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-wider);text-transform:uppercase;color:var(--color-bg-primary);background:linear-gradient(135deg,var(--color-accent-primary),var(--color-deck-b));border:none;border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-lg);cursor:pointer;transition:all var(--transition-fast);margin-top:var(--spacing-xs)}.login-modal__submit:hover{transform:translateY(-1px);box-shadow:0 4px 16px #2dd4bf4d}.login-modal__submit:active{transform:translateY(0)}.login-modal__submit:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.live-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md)}.live-modal{background:var(--color-bg-secondary);border:1px solid var(--color-border-subtle);border-radius:var(--radius-xl);padding:var(--spacing-xl);width:100%;max-width:460px;position:relative;box-shadow:0 24px 48px #0006}.live-modal__close{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);background:transparent;border:none;color:var(--color-text-muted);font-size:var(--font-size-md);cursor:pointer;padding:var(--spacing-2xs);border-radius:var(--radius-md);transition:all var(--transition-fast)}.live-modal__close:hover{color:var(--color-text-primary);background:var(--color-bg-tertiary)}.live-modal__header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.live-modal__live-dot{width:12px;height:12px;border-radius:50%;background:var(--color-danger);box-shadow:0 0 12px #f43f5e80;animation:livePulse 1.5s ease-in-out infinite}.live-modal__title{font-family:var(--font-display);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.live-modal__form{display:flex;flex-direction:column;gap:var(--spacing-md)}.live-modal__field{display:flex;flex-direction:column;gap:var(--spacing-2xs)}.live-modal__field label{font-family:var(--font-display);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);letter-spacing:var(--letter-spacing-wide);color:var(--color-text-secondary);text-transform:uppercase}.live-modal__field input[type=text],.live-modal__field textarea{font-family:var(--font-primary);font-size:var(--font-size-sm);color:var(--color-text-primary);background:var(--color-bg-card);border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);outline:none;resize:none;transition:border-color var(--transition-fast)}.live-modal__field input:focus,.live-modal__field textarea:focus{border-color:var(--color-accent-primary);box-shadow:0 0 0 3px var(--color-accent-glow)}.live-modal__access-row{display:flex;gap:var(--spacing-xs)}.live-modal__access-btn{flex:1;font-family:var(--font-display);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);padding:var(--spacing-sm);border-radius:var(--radius-md);border:2px solid transparent;background:var(--color-bg-card);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);text-align:center}.live-modal__access-btn:hover{border-color:var(--color-border-subtle)}.live-modal__access-btn--active{border-color:var(--color-accent-primary);background:#2dd4bf14;color:var(--color-accent-primary)}.live-modal__range{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:6px;background:var(--color-bg-tertiary);border-radius:var(--radius-full);outline:none}.live-modal__range::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;background:var(--color-accent-primary);border-radius:50%;cursor:pointer;box-shadow:0 0 6px var(--color-accent-glow)}.live-modal__submit{font-family:var(--font-display);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-wider);text-transform:uppercase;color:var(--color-bg-primary);background:linear-gradient(135deg,var(--color-danger),#fb923c);border:none;border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-lg);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);transition:all var(--transition-fast)}.live-modal__submit:hover{transform:translateY(-1px);box-shadow:0 4px 16px #f43f5e4d}.live-modal__submit-dot{width:8px;height:8px;border-radius:50%;background:currentColor;animation:livePulse 1s ease-in-out infinite}.live-modal__success{text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md)}.live-modal__success-icon{font-size:3rem}.live-modal__success-title{font-family:var(--font-display);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-success)}.live-modal__success-name{font-family:var(--font-display);font-size:var(--font-size-md);color:var(--color-text-primary)}.live-modal__code-box{display:flex;flex-direction:column;gap:var(--spacing-2xs);padding:var(--spacing-md);background:var(--color-bg-card);border:1px dashed var(--color-border-accent);border-radius:var(--radius-lg)}.live-modal__code-label{font-family:var(--font-display);font-size:10px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:var(--letter-spacing-widest)}.live-modal__code-value{font-family:var(--font-display);font-size:var(--font-size-2xl);font-weight:var(--font-weight-extrabold);letter-spacing:.3em;color:var(--color-accent-primary)}@keyframes livePulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.9)}}.join-room-modal{max-width:400px;text-align:center}.join-room-modal p{color:var(--color-text-muted);margin-bottom:2rem;font-size:.95rem}.join-room-form{display:flex;flex-direction:column;gap:1.5rem}.codigo-input{width:100%;padding:1rem;font-size:1.5rem;text-align:center;letter-spacing:.5rem;text-transform:uppercase;background-color:var(--color-bg-darker);border:2px solid var(--color-border);color:var(--color-text);border-radius:var(--radius-md);transition:border-color .2s}.codigo-input:focus{outline:none;border-color:var(--color-primary)}.btn-primary{width:100%;padding:1rem;background-color:var(--color-primary);color:var(--color-text);border:none;border-radius:var(--radius-md);font-weight:600;font-size:1rem;cursor:pointer;transition:background-color .2s}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-dark)}.btn-primary:disabled{opacity:.7;cursor:not-allowed}.modal-error{background-color:#dc35451a;color:#ff6b6b;padding:.75rem;border-radius:var(--radius-md);margin-bottom:1.5rem;border:1px solid rgba(220,53,69,.3)}.suggest-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md)}.suggest-modal{background:var(--color-bg-secondary);border:1px solid var(--color-border-subtle);border-radius:var(--radius-xl);padding:var(--spacing-xl);width:100%;max-width:500px;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 24px 48px #0006}.suggest-modal__close{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);background:transparent;border:none;color:var(--color-text-muted);font-size:var(--font-size-md);cursor:pointer;padding:var(--spacing-2xs);border-radius:var(--radius-md);transition:all var(--transition-fast)}.suggest-modal__close:hover{color:var(--color-text-primary);background:var(--color-bg-tertiary)}.suggest-modal__title{font-family:var(--font-display);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text-primary);text-align:center;margin-bottom:var(--spacing-2xs)}.suggest-modal__subtitle{font-family:var(--font-primary);font-size:var(--font-size-sm);color:var(--color-text-muted);text-align:center;margin-bottom:var(--spacing-lg)}.suggest-modal__form{display:flex;flex-direction:column;gap:var(--spacing-md)}.suggest-modal__field{display:flex;flex-direction:column;gap:var(--spacing-2xs)}.suggest-modal__field label{font-family:var(--font-display);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);letter-spacing:var(--letter-spacing-wide);color:var(--color-text-secondary);text-transform:uppercase}.suggest-modal__required{color:var(--color-danger);font-size:9px;text-transform:lowercase;font-weight:var(--font-weight-regular)}.suggest-modal__field input,.suggest-modal__field textarea{font-family:var(--font-primary);font-size:var(--font-size-sm);color:var(--color-text-primary);background:var(--color-bg-card);border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);outline:none;transition:border-color var(--transition-fast)}.suggest-modal__field input:focus{border-color:var(--color-accent-primary);box-shadow:0 0 0 3px var(--color-accent-glow)}.suggest-modal__genre-grid{display:flex;flex-wrap:wrap;gap:var(--spacing-2xs)}.suggest-modal__genre-chip{font-family:var(--font-display);font-size:11px;font-weight:var(--font-weight-semibold);letter-spacing:var(--letter-spacing-wide);padding:var(--spacing-2xs) var(--spacing-sm);border-radius:var(--radius-full);border:1px solid rgba(148,163,184,.2);background:var(--color-bg-card);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.suggest-modal__genre-chip:hover{border-color:var(--genre-color, var(--color-accent-primary));color:var(--genre-color, var(--color-accent-primary))}.suggest-modal__genre-chip--selected{background:var(--genre-color, var(--color-accent-primary));color:#fff;border-color:var(--genre-color, var(--color-accent-primary));box-shadow:0 0 8px color-mix(in srgb,var(--genre-color, #2dd4bf) 40%,transparent)}.suggest-modal__genre-chip--add{border-style:dashed;border-color:var(--color-accent-primary);color:var(--color-accent-primary)}.suggest-modal__genre-chip--add.suggest-modal__genre-chip--selected{background:var(--color-accent-primary);color:#fff;border-style:solid}.suggest-modal__custom-genre{margin-top:var(--spacing-xs);font-family:var(--font-primary);font-size:var(--font-size-sm);color:var(--color-text-primary);background:var(--color-bg-card);border:1px solid var(--color-accent-primary);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);outline:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.suggest-modal__custom-genre:focus{box-shadow:0 0 0 3px var(--color-accent-glow)}.suggest-modal__toggle-optional{font-family:var(--font-display);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);letter-spacing:var(--letter-spacing-wide);color:var(--color-text-muted);background:transparent;border:none;cursor:pointer;text-align:left;padding:var(--spacing-2xs) 0;transition:color var(--transition-fast);text-transform:uppercase}.suggest-modal__toggle-optional:hover{color:var(--color-text-secondary)}.suggest-modal__optional{display:flex;flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-md);background:#00000026;border-radius:var(--radius-md);border:1px solid var(--color-border-subtle)}.suggest-modal__row{display:flex;gap:var(--spacing-md)}.suggest-modal__row .suggest-modal__field{flex:1}.suggest-modal__source-row{display:flex;gap:var(--spacing-2xs)}.suggest-modal__source-btn{border-radius:var(--radius-md);border:1px solid var(--color-border-subtle);background:var(--color-bg-card);font-size:var(--font-size-md);cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;padding:.5rem;flex:1}.suggest-modal__source-btn:hover{border-color:var(--color-accent-primary)}.suggest-modal__source-btn--active{border-color:var(--color-accent-primary);background:#2dd4bf1a;box-shadow:0 0 6px var(--color-accent-glow)}.suggest-modal__submit{font-family:var(--font-display);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-wider);text-transform:uppercase;color:var(--color-bg-primary);background:linear-gradient(135deg,var(--color-accent-primary),var(--color-deck-b));border:none;border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-lg);cursor:pointer;transition:all var(--transition-fast)}.suggest-modal__submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 16px #2dd4bf4d}.suggest-modal__submit--disabled{opacity:.4;cursor:not-allowed}.suggest-modal__search-container{margin-bottom:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-xs)}.suggest-modal__search-box{display:flex;align-items:center;background:var(--color-bg-tertiary);border:1px solid var(--color-border-accent);border-radius:var(--radius-lg);padding:4px;box-shadow:0 4px 12px #2dd4bf1a;transition:all var(--transition-base)}.suggest-modal__search-box:focus-within{border-color:var(--color-accent-primary);box-shadow:0 0 0 3px var(--color-accent-glow),0 8px 24px #0000004d;transform:translateY(-1px)}.suggest-modal__search-icon{padding:0 var(--spacing-sm);font-family:var(--font-display);font-size:10px;font-weight:800;color:var(--color-accent-primary);letter-spacing:1px}.suggest-modal__search-box input{flex:1;background:transparent;border:none;color:var(--color-text-primary);font-family:var(--font-primary);font-size:var(--font-size-sm);padding:var(--spacing-sm);outline:none}.suggest-modal__search-btn{background:var(--color-accent-primary);color:var(--color-bg-primary);border:none;border-radius:var(--radius-md);padding:var(--spacing-sm);cursor:pointer;transition:all var(--transition-fast)}.suggest-modal__search-btn:hover{filter:brightness(1.2);transform:scale(1.05)}.suggest-modal__results{background:var(--color-bg-tertiary);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column;box-shadow:0 8px 24px #0000004d;margin-top:4px}.suggest-modal__result-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:none;border-bottom:1px solid var(--color-border-subtle);cursor:pointer;text-align:left;transition:background var(--transition-fast);width:100%}.suggest-modal__result-item:hover{background:#ffffff0d}.suggest-modal__result-img{width:40px;height:40px;border-radius:var(--radius-sm);object-fit:cover;background:#000}.suggest-modal__result-info{display:flex;flex-direction:column;flex:1;min-width:0}.suggest-modal__result-title{font-family:var(--font-display);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.suggest-modal__result-artist{font-family:var(--font-primary);font-size:var(--font-size-xs);color:var(--color-text-muted)}.suggest-modal__result-source{font-size:var(--font-size-sm);opacity:.7}.suggest-modal__clear-results{background:transparent;border:none;padding:var(--spacing-xs);color:var(--color-text-muted);font-size:10px;font-family:var(--font-display);text-transform:uppercase;letter-spacing:1px;cursor:pointer;transition:color var(--transition-fast)}.suggest-modal__clear-results:hover{color:var(--color-danger)}.profile-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md)}.profile-modal{background:var(--color-bg-secondary);border:1px solid var(--color-border-subtle);border-radius:var(--radius-xl);padding:var(--spacing-xl);width:100%;max-width:460px;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 24px 48px #0006}.profile-modal__close{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);background:transparent;border:none;color:var(--color-text-muted);font-size:var(--font-size-md);cursor:pointer;padding:var(--spacing-2xs);border-radius:var(--radius-md);transition:all var(--transition-fast)}.profile-modal__close:hover{color:var(--color-text-primary);background:var(--color-bg-tertiary)}.profile-modal__header{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.profile-modal__avatar{position:relative;width:90px;height:90px;border-radius:50%;background:linear-gradient(135deg,var(--color-accent-primary),var(--color-deck-b));display:flex;align-items:center;justify-content:center;cursor:pointer;overflow:hidden;transition:transform var(--transition-spring);box-shadow:0 0 20px var(--color-accent-glow)}.profile-modal__avatar:hover{transform:scale(1.05)}.profile-modal__avatar-img{width:100%;height:100%;object-fit:cover;border-radius:50%}.profile-modal__avatar-initial{font-family:var(--font-display);font-size:2rem;font-weight:var(--font-weight-extrabold);color:var(--color-bg-primary)}.profile-modal__avatar-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;font-size:1.5rem;border-radius:50%;opacity:0;transition:opacity var(--transition-fast)}.profile-modal__avatar:hover .profile-modal__avatar-overlay{opacity:1}.profile-modal__name{font-family:var(--font-display);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.profile-modal__role-tag{font-family:var(--font-display);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);letter-spacing:var(--letter-spacing-wide);color:var(--color-accent-primary);background:#2dd4bf1a;padding:2px var(--spacing-sm);border-radius:var(--radius-full);border:1px solid rgba(45,212,191,.2)}.profile-modal__form{display:flex;flex-direction:column;gap:var(--spacing-md)}.profile-modal__field{display:flex;flex-direction:column;gap:var(--spacing-xs)}.profile-modal__field label{font-family:var(--font-display);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary)}.profile-modal__hint{font-family:var(--font-primary);font-size:10px;color:var(--color-text-muted);font-weight:var(--font-weight-regular);margin-left:var(--spacing-2xs)}.profile-modal__field input[type=date],.profile-modal__field textarea{font-family:var(--font-primary);font-size:var(--font-size-sm);color:var(--color-text-primary);background:var(--color-bg-card);border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);outline:none;resize:none;transition:border-color var(--transition-fast);color-scheme:dark}.profile-modal__field input:focus,.profile-modal__field textarea:focus{border-color:var(--color-accent-primary);box-shadow:0 0 0 3px var(--color-accent-glow)}.profile-modal__genre-grid{display:flex;flex-wrap:wrap;gap:var(--spacing-2xs)}.profile-modal__genre-chip{font-family:var(--font-display);font-size:11px;font-weight:var(--font-weight-semibold);letter-spacing:var(--letter-spacing-wide);padding:var(--spacing-2xs) var(--spacing-sm);border-radius:var(--radius-full);border:1px solid rgba(148,163,184,.2);background:var(--color-bg-card);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.profile-modal__genre-chip:hover{border-color:var(--genre-color, var(--color-accent-primary));color:var(--genre-color, var(--color-accent-primary))}.profile-modal__genre-chip--selected{background:var(--genre-color, var(--color-accent-primary));color:#fff;border-color:var(--genre-color, var(--color-accent-primary));box-shadow:0 0 8px color-mix(in srgb,var(--genre-color, #2dd4bf) 40%,transparent)}.profile-modal__submit{font-family:var(--font-display);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-wider);text-transform:uppercase;color:var(--color-bg-primary);background:linear-gradient(135deg,var(--color-accent-primary),var(--color-deck-b));border:none;border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-lg);cursor:pointer;transition:all var(--transition-fast);margin-top:var(--spacing-xs)}.profile-modal__submit:hover{transform:translateY(-1px);box-shadow:0 4px 16px #2dd4bf4d}.profile-modal__success{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);padding:var(--spacing-xl) 0}.profile-modal__success-icon{font-size:3rem}.profile-modal__success-title{font-family:var(--font-display);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-success)}
