:root{--color-bg-primary: #0a0a0f;--color-bg-secondary: #12121a;--color-bg-tertiary: #1a1a25;--color-bg-elevated: #22222f;--color-bg-hover: #2a2a3a;--color-border: #2a2a3a;--color-border-light: #3a3a4a;--color-text-primary: #ffffff;--color-text-secondary: #a0a0b0;--color-text-tertiary: #6a6a7a;--color-primary: #8b5cf6;--color-primary-hover: #7c3aed;--color-primary-subtle: rgba(139, 92, 246, .15);--color-secondary: #06b6d4;--color-secondary-hover: #0891b2;--color-accent: #f43f5e;--color-accent-hover: #e11d48;--color-success: #10b981;--color-warning: #f59e0b;--color-error: #ef4444;--gradient-primary: linear-gradient(135deg, #8b5cf6 0%, #06b6d4 100%);--gradient-dark: linear-gradient(180deg, var(--color-bg-secondary) 0%, var(--color-bg-primary) 100%);--gradient-glow: radial-gradient(ellipse at 50% 0%, rgba(139, 92, 246, .15) 0%, transparent 50%);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 25px rgba(0, 0, 0, .5);--shadow-glow: 0 0 30px rgba(139, 92, 246, .3);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--sidebar-width: 260px;--sidebar-width-collapsed: 72px;--header-height: 60px;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);background:var(--color-bg-primary);color:var(--color-text-primary);line-height:1.6;min-height:100vh}*{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.12) transparent}*::-webkit-scrollbar{width:6px;height:6px}*::-webkit-scrollbar-track{background:transparent}*::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:3px}*::-webkit-scrollbar-thumb:hover{background:#ffffff40}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.3;letter-spacing:-.02em}h1{font-size:1.875rem}h2{font-size:1.25rem}h3{font-size:1.125rem}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-hover)}.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);height:100vh;position:fixed;left:0;top:0;background:var(--color-bg-secondary);border-right:1px solid var(--color-border);display:flex;flex-direction:column;z-index:100;transition:width var(--transition-base),transform var(--transition-base)}.sidebar-header{padding:var(--spacing-lg);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between}.sidebar-collapse-btn{background:none;border:none;color:var(--color-text-tertiary);cursor:pointer;padding:var(--spacing-xs);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);flex-shrink:0}.sidebar-collapse-btn:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.logo{display:flex;align-items:center;gap:var(--spacing-sm);font-size:1.25rem;font-weight:700;color:var(--color-text-primary)}.logo svg{color:var(--color-primary)}.logo-text{display:flex;flex-direction:column;line-height:1.2}.logo-tagline{font-size:.6rem;font-weight:400;color:var(--color-text-secondary);letter-spacing:.02em}.sidebar-nav{flex:1;padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-xs)}.nav-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:.9375rem;font-weight:500;transition:all var(--transition-fast)}.nav-item:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.nav-item.active{background:var(--color-primary-subtle);color:var(--color-primary)}.nav-section{display:flex;flex-direction:column;gap:var(--spacing-xs)}.nav-section:not(:first-child){margin-top:var(--spacing-md)}.nav-section-label{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);padding:var(--spacing-xs) var(--spacing-md);margin-bottom:var(--spacing-xs)}.nav-section-bottom{margin-top:auto;padding-top:var(--spacing-md);border-top:1px solid var(--color-border)}.sidebar-footer{padding:var(--spacing-md);border-top:1px solid var(--color-border);display:flex;align-items:center;gap:var(--spacing-sm)}.user-info{flex:1;display:flex;align-items:center;gap:var(--spacing-sm);min-width:0}.user-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;flex-shrink:0}.user-details{flex:1;min-width:0;display:flex;flex-direction:column}.user-name{font-weight:500;font-size:.875rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-email{font-size:.75rem;color:var(--color-text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:var(--header-height);background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border);padding:0 var(--spacing-md);align-items:center;gap:var(--spacing-md);z-index:101}.mobile-logo{display:flex;align-items:center;gap:var(--spacing-sm);font-weight:700}.mobile-logo svg{color:var(--color-primary)}.menu-toggle{background:none;border:none;color:var(--color-text-primary);cursor:pointer;padding:var(--spacing-sm);margin:calc(var(--spacing-sm) * -1)}.sidebar-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:99}.sidebar-bottom-actions{padding:var(--spacing-md);border-top:1px solid var(--color-border);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs)}.sidebar-collapse-btn-bottom{background:none;border:none;color:var(--color-text-tertiary);cursor:pointer;padding:var(--spacing-sm);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);width:100%}.sidebar-collapse-btn-bottom:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.sidebar.collapsed{width:var(--sidebar-width-collapsed)}.sidebar.collapsed .sidebar-header{padding:var(--spacing-md);justify-content:center}.sidebar.collapsed .logo{justify-content:center}.sidebar.collapsed .sidebar-nav{padding:var(--spacing-sm)}.sidebar.collapsed .nav-item{justify-content:center;padding:var(--spacing-sm)}.sidebar.collapsed .nav-section{margin-top:var(--spacing-sm)}.sidebar.collapsed .nav-section-label{display:none}.sidebar.collapsed .nav-section-bottom{border-top:1px solid var(--color-border);padding-top:var(--spacing-sm)}.sidebar.collapsed .sidebar-footer{flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-sm);border-bottom:1px solid var(--color-border)}.sidebar.collapsed .user-info{justify-content:center}.sidebar.collapsed .sidebar-bottom-actions{padding:var(--spacing-sm)}.main-content{flex:1;margin-left:var(--sidebar-width);min-height:100vh;background:var(--gradient-glow),var(--color-bg-primary);transition:margin-left var(--transition-base)}.main-content.sidebar-collapsed{margin-left:var(--sidebar-width-collapsed)}.page{padding:var(--spacing-xl);max-width:1400px;overflow-x:hidden}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-xl);gap:var(--spacing-md)}.page-header h1{margin-bottom:var(--spacing-xs)}.page-subtitle{color:var(--color-text-secondary);font-size:.9375rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-size:.875rem;font-weight:500;border:none;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-hover);box-shadow:var(--shadow-glow)}.btn-secondary{background:var(--color-bg-tertiary);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-bg-hover);border-color:var(--color-border-light)}.btn-full{width:100%}.btn-sm{padding:var(--spacing-xs) var(--spacing-sm);font-size:.8125rem}.btn-icon{background:none;border:none;color:var(--color-text-secondary);cursor:pointer;padding:var(--spacing-xs);border-radius:var(--radius-sm);transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.btn-icon:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.btn-icon.danger:hover{background:#ef44441a;color:var(--color-error)}input,select,textarea{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);font-size:.9375rem;color:var(--color-text-primary);font-family:inherit;transition:all var(--transition-fast);width:100%}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-subtle)}input::placeholder{color:var(--color-text-tertiary)}input:disabled{opacity:.6;cursor:not-allowed}.form-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.form-group label{font-size:.875rem;font-weight:500;color:var(--color-text-secondary)}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--spacing-md)}.input-with-icon{position:relative;display:flex;align-items:center}.input-with-icon svg{position:absolute;left:var(--spacing-md);color:var(--color-text-tertiary);pointer-events:none}.input-with-icon input{padding-left:calc(var(--spacing-md) * 2 + 20px)}.search-bar{display:flex;align-items:center;gap:var(--spacing-sm);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:0 var(--spacing-md);flex:1;max-width:400px}.search-bar svg{color:var(--color-text-tertiary);flex-shrink:0}.search-bar input{background:none;border:none;padding:var(--spacing-sm) 0;flex:1}.search-bar input:focus{box-shadow:none}.toolbar{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);flex-wrap:wrap}.stat-card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);display:flex;align-items:center;gap:var(--spacing-md)}.stat-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}.stat-content{display:flex;flex-direction:column}.stat-value{font-size:1.5rem;font-weight:700}.stat-label{font-size:.875rem;color:var(--color-text-secondary)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.quick-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-md)}.action-card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);display:flex;align-items:flex-start;gap:var(--spacing-md);transition:all var(--transition-base);color:inherit}.action-card:hover{border-color:var(--color-primary);background:var(--color-bg-tertiary);transform:translateY(-2px);color:inherit}.action-icon{width:44px;height:44px;border-radius:var(--radius-md);background:var(--color-primary-subtle);color:var(--color-primary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.action-content h3{margin-bottom:var(--spacing-xs)}.action-content p{font-size:.875rem;color:var(--color-text-secondary)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);text-align:center;background:var(--color-bg-secondary);border:1px dashed var(--color-border);border-radius:var(--radius-lg)}.empty-state svg{color:var(--color-text-tertiary);margin-bottom:var(--spacing-md)}.empty-state h3{margin-bottom:var(--spacing-xs)}.empty-state p{color:var(--color-text-secondary);margin-bottom:var(--spacing-lg);max-width:300px}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);color:var(--color-text-secondary)}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;color:var(--color-text-secondary);gap:var(--spacing-md)}.spinner{animation:spin 1s linear infinite}.songs-list{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.songs-header{display:grid;grid-template-columns:var(--grid-cols, 2fr 70px 60px 140px 80px 80px 90px 70px);gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid var(--color-border);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-tertiary)}.songs-header .sortable{cursor:pointer;user-select:none;transition:color var(--transition-fast);display:flex;align-items:center}.songs-header .sortable:hover{color:var(--color-text-primary)}.song-row{display:grid;grid-template-columns:var(--grid-cols, 2fr 70px 60px 140px 80px 80px 90px 70px);gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);align-items:center;border-bottom:1px solid var(--color-border);transition:background var(--transition-fast);cursor:pointer}.song-row:last-child{border-bottom:none}.song-row:hover{background:var(--color-bg-hover)}.song-row.selected{background:var(--color-primary-subtle)}.song-row.playing{background:#a855f71a;border-left:3px solid #a855f7}.song-row.playing .song-title{color:#a855f7}.col-title{display:flex;align-items:center;gap:var(--spacing-sm);min-width:0}.song-artwork{width:40px;height:40px;border-radius:var(--radius-sm);background:var(--color-bg-tertiary);display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;overflow:hidden}.song-artwork img{width:100%;height:100%;object-fit:cover}.song-artwork svg{color:var(--color-text-tertiary)}.play-overlay{position:absolute;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition-fast);border:none;cursor:pointer;color:#fff}.song-artwork:hover .play-overlay,.song-row:hover .play-overlay{opacity:1}.song-info{display:flex;flex-direction:column;min-width:0}.song-title{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.song-artist{font-size:.8125rem;color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.col-bpm,.col-key,.col-genre,.col-arousal,.col-duration,.col-date-added{font-size:.875rem;color:var(--color-text-secondary)}.col-extra{font-size:.875rem;color:var(--color-text-secondary);display:flex;align-items:center}.energy-segments{display:flex;gap:2px;align-items:center}.energy-seg{width:3px;height:10px;border-radius:1px;background:#ffffff1a}.songs-list.compact .songs-header{padding:2px var(--spacing-md);font-size:.7rem}.songs-list.compact .song-artwork{width:24px;height:24px}.songs-list.compact .song-title{font-size:.8125rem}.song-artist-inline{font-weight:400;color:var(--color-text-secondary)}.songs-list.compact .song-row{height:48px;padding:2px var(--spacing-md)}.songs-list.compact .song-info{justify-content:center}.song-tags-row{display:flex;flex-wrap:nowrap;gap:3px;margin-top:1px;overflow:hidden;max-height:18px}.song-tags-row .tag-pill,.song-tags-row .custom-tag-pill{font-size:.6rem;padding:1px 5px;border-radius:3px;white-space:nowrap;flex-shrink:0}.tag-pill.tag-situation{background:#f9731633;color:#f97316}.tag-pill.tag-mood{background:#a855f733;color:#a855f7}.tag-pill.tag-instrument{background:#22c55e33;color:#22c55e}.tag-pill.tag-mytag{background:#fbbf2426;color:#fbbf24;border:1px solid rgba(251,191,36,.3);font-family:monospace}.songs-list.compact .col-bpm,.songs-list.compact .col-key,.songs-list.compact .col-genre,.songs-list.compact .col-arousal,.songs-list.compact .col-duration,.songs-list.compact .col-date-added{font-size:.75rem}.energy-bar{display:flex;align-items:center;gap:var(--spacing-xs)}.energy-bar svg{color:var(--color-warning)}.energy-level{height:4px;background:var(--color-warning);border-radius:var(--radius-full);max-width:60px}.rating{display:flex;gap:2px}.rating svg{color:var(--color-text-tertiary)}.rating svg.filled{color:var(--color-warning);fill:var(--color-warning)}.sources-section{margin-bottom:var(--spacing-xl)}.sources-section h2{margin-bottom:var(--spacing-md);color:var(--color-text-secondary);font-weight:500}.sources-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--spacing-md)}.source-card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);display:flex;gap:var(--spacing-md);align-items:flex-start;transition:all var(--transition-base)}.source-card.connected{flex-wrap:wrap}.source-card.available{align-items:center}.source-card.available:not(.coming-soon):hover{border-color:var(--color-primary);background:var(--color-bg-tertiary)}.source-card.coming-soon{opacity:.6}.source-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.source-content{flex:1;min-width:0}.source-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs)}.source-header h3{font-size:1rem}.source-status{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.75rem;padding:2px 8px;border-radius:var(--radius-full);text-transform:capitalize}.source-status.connected{background:#10b98126;color:var(--color-success)}.source-status.error{background:#ef444426;color:var(--color-error)}.source-meta{font-size:.8125rem;color:var(--color-text-secondary)}.source-actions{display:flex;gap:var(--spacing-xs);width:100%;justify-content:flex-end;margin-top:var(--spacing-sm)}.badge{font-size:.75rem;padding:4px 10px;border-radius:var(--radius-full);font-weight:500}.badge.coming-soon{background:var(--color-bg-tertiary);color:var(--color-text-secondary)}.info-card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.info-card h3{margin-bottom:var(--spacing-md)}.info-card ul{list-style:none;display:flex;flex-direction:column;gap:var(--spacing-sm)}.info-card li{color:var(--color-text-secondary);font-size:.9375rem;padding-left:var(--spacing-md);position:relative}.info-card li:before{content:"→";position:absolute;left:0;color:var(--color-primary)}.sources-info,.sets-tips{margin-top:var(--spacing-xl)}.sets-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-md)}.set-card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-md);display:flex;gap:var(--spacing-md);align-items:flex-start;color:inherit;transition:all var(--transition-base);position:relative}.set-card:hover{border-color:var(--color-primary);background:var(--color-bg-tertiary);color:inherit}.set-artwork{width:64px;height:64px;border-radius:var(--radius-md);background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;color:#fff}.set-content{flex:1;min-width:0}.set-content h3{margin-bottom:var(--spacing-xs)}.set-description{font-size:.875rem;color:var(--color-text-secondary);margin-bottom:var(--spacing-sm);display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.set-meta{display:flex;gap:var(--spacing-md);font-size:.8125rem;color:var(--color-text-tertiary)}.set-meta span{display:flex;align-items:center;gap:var(--spacing-xs)}.set-menu{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm)}.settings-grid{display:grid;gap:var(--spacing-lg)}.settings-section{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.settings-header{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--color-border);background:var(--color-bg-tertiary)}.settings-header svg{color:var(--color-primary)}.settings-header h2{font-size:1rem;color:var(--color-text-primary)}.settings-content{padding:var(--spacing-md)}.setting-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);gap:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.setting-item:last-child{border-bottom:none}.setting-info{flex:1}.setting-info label{display:block;font-weight:500;margin-bottom:2px}.setting-description{font-size:.8125rem;color:var(--color-text-secondary)}.setting-value{color:var(--color-text-secondary);font-size:.875rem}.setting-item input,.setting-item select{max-width:200px}.toggle{position:relative;display:inline-block;width:44px;height:24px}.toggle input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-full);transition:var(--transition-base)}.toggle-slider:before{content:"";position:absolute;height:18px;width:18px;left:2px;bottom:2px;background:var(--color-text-secondary);border-radius:var(--radius-full);transition:var(--transition-base)}.toggle input:checked+.toggle-slider{background:var(--color-primary);border-color:var(--color-primary)}.toggle input:checked+.toggle-slider:before{transform:translate(20px);background:#fff}.color-options{display:flex;gap:var(--spacing-sm)}.color-option{width:28px;height:28px;border-radius:var(--radius-full);border:2px solid transparent;cursor:pointer;transition:all var(--transition-fast)}.color-option:hover{transform:scale(1.1)}.color-option.active{border-color:#fff;box-shadow:0 0 0 2px var(--color-bg-primary)}.sources-settings{grid-column:1 / -1}.sources-settings .settings-content{padding:0}.sources-list{display:flex;flex-direction:column}.source-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--color-border)}.source-item:last-child{border-bottom:none}.source-icon-small{width:36px;height:36px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.source-info{flex:1;min-width:0}.source-name{display:block;font-weight:500;color:var(--color-text-primary)}.source-status-text{display:block;font-size:.8125rem;color:var(--color-text-secondary)}.source-badge.connected{color:var(--color-success)}.source-actions-inline{display:flex;gap:var(--spacing-xs)}.source-item.available{background:var(--color-bg-tertiary)}.page.dj-copilot{height:100%;display:flex;flex-direction:column;padding:0}.copilot-visualization{flex:1;min-height:0}.modal-overlay{position:fixed;inset:0;background:#000000b3;backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:200;padding:var(--spacing-md)}.modal{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;max-width:500px;max-height:90vh;overflow:auto;animation:modalIn .2s ease}@keyframes modalIn{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.modal-header h2{font-size:1.125rem}.modal-body{padding:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-md)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-sm);padding-top:var(--spacing-md);border-top:1px solid var(--color-border);margin-top:var(--spacing-md)}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--gradient-glow),var(--color-bg-primary);padding:var(--spacing-md)}.auth-container{width:100%;max-width:400px;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-xl)}.auth-header{text-align:center;margin-bottom:var(--spacing-xl)}.auth-logo{width:72px;height:72px;margin:0 auto var(--spacing-md);background:var(--gradient-primary);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:#fff}.auth-header h1{margin-bottom:var(--spacing-xs)}.auth-header p{color:var(--color-text-secondary)}.auth-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.auth-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:var(--color-error);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-size:.875rem}.auth-footer{margin-top:var(--spacing-lg);text-align:center;font-size:.875rem;color:var(--color-text-secondary)}@media(max-width:768px){.mobile-header{display:flex}.sidebar{transform:translate(-100%);width:var(--sidebar-width)}.sidebar.open{transform:translate(0)}.sidebar.collapsed{width:var(--sidebar-width)}.sidebar-collapse-btn,.sidebar-collapse-btn-bottom,.sidebar-bottom-actions{display:none}.sidebar-overlay{display:block}.main-content{margin-left:0;padding-top:var(--header-height)}.main-content.sidebar-collapsed{margin-left:0}.page{padding:var(--spacing-md)}.page-header{flex-direction:column;align-items:stretch}.songs-header{display:none}.song-row{grid-template-columns:1fr auto}.col-bpm,.col-key,.col-genre,.col-arousal,.col-duration,.col-date-added{display:none}}.discovery .page-header h1{display:flex;align-items:center;gap:var(--spacing-sm)}.discovery .header-icon{color:var(--color-primary)}.discovery-layout{display:grid;grid-template-columns:320px 1fr;gap:var(--spacing-lg);min-height:calc(100vh - 200px)}.discovery-sources{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);display:flex;flex-direction:column;overflow:hidden}.sources-header{padding:var(--spacing-md);border-bottom:1px solid var(--color-border)}.sources-header h2{margin-bottom:var(--spacing-sm);font-size:.875rem;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.search-bar.compact{max-width:none}.search-bar.compact input{font-size:.875rem;padding:var(--spacing-xs) 0}.sources-list{flex:1;overflow-y:auto}.source-group{border-bottom:1px solid var(--color-border)}.source-group:last-child{border-bottom:none}.source-group.disconnected{opacity:.6}.source-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--spacing-md);background:none;border:none;color:var(--color-text-primary);cursor:pointer;transition:background var(--transition-fast)}.source-header:hover{background:var(--color-bg-hover)}.source-info{display:flex;align-items:center;gap:var(--spacing-sm);font-weight:500}.playlist-count{background:var(--color-bg-tertiary);padding:2px 8px;border-radius:var(--radius-full);font-size:.75rem;color:var(--color-text-secondary)}.chevron{color:var(--color-text-tertiary);transition:transform var(--transition-fast)}.chevron.expanded{transform:rotate(180deg)}.connect-badge{font-size:.75rem;padding:4px 10px;border-radius:var(--radius-full);background:var(--color-primary-subtle);color:var(--color-primary)}.playlists-list{padding:0 var(--spacing-sm) var(--spacing-sm)}.playlist-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--spacing-sm) var(--spacing-md);background:none;border:none;border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);text-align:left}.playlist-item:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.playlist-item.active{background:var(--color-primary-subtle);color:var(--color-primary)}.playlist-name{flex:1;font-size:.875rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-count{font-size:.75rem;color:var(--color-text-tertiary)}.discovery-tracks{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);display:flex;flex-direction:column;overflow:hidden}.tracks-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--color-border);gap:var(--spacing-md)}.playlist-info{display:flex;align-items:center;gap:var(--spacing-md)}.playlist-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}.playlist-info h2{font-size:1.125rem;margin-bottom:2px}.playlist-info p{font-size:.8125rem;color:var(--color-text-secondary)}.tracks-actions{display:flex;gap:var(--spacing-sm)}.tracks-list{flex:1;overflow-y:auto}.track-row{display:grid;grid-template-columns:36px 1fr 60px 50px 60px auto;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-lg);align-items:center;border-bottom:1px solid var(--color-border);transition:background var(--transition-fast)}.track-row:last-child{border-bottom:none}.track-row:hover{background:var(--color-bg-hover)}.track-row.added{opacity:.6}.track-artwork{width:36px;height:36px;border-radius:var(--radius-sm);background:var(--color-bg-tertiary);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.track-artwork img{width:100%;height:100%;object-fit:cover}.track-artwork svg{color:var(--color-text-tertiary)}.track-info{display:flex;flex-direction:column;min-width:0}.track-title{font-weight:500;font-size:.9375rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-artist{font-size:.8125rem;color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-bpm,.track-key,.track-duration{font-size:.8125rem;color:var(--color-text-secondary)}.track-actions{display:flex;align-items:center;gap:var(--spacing-sm)}.added-badge{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.75rem;color:var(--color-success);background:#10b9811a;padding:4px 10px;border-radius:var(--radius-full)}.existing-badge{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.75rem;color:var(--color-warning, #f59e0b);background:#f59e0b1a;padding:4px 10px;border-radius:var(--radius-full);white-space:nowrap}.empty-tracks{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);text-align:center;color:var(--color-text-secondary)}.empty-tracks svg{color:var(--color-text-tertiary);margin-bottom:var(--spacing-md)}.empty-tracks h3{margin-bottom:var(--spacing-xs)}.discovery-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);text-align:center;height:100%}.discovery-empty svg{color:var(--color-primary);margin-bottom:var(--spacing-lg);opacity:.5}.discovery-empty h2{font-size:1.5rem;margin-bottom:var(--spacing-sm)}.discovery-empty>p{color:var(--color-text-secondary);margin-bottom:var(--spacing-xl);max-width:400px}.discovery-tips{display:flex;flex-direction:column;gap:var(--spacing-md);text-align:left}.tip{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-bg-tertiary);border-radius:var(--radius-md);color:var(--color-text-secondary)}.tip-number{width:28px;height:28px;border-radius:var(--radius-full);background:var(--color-primary-subtle);color:var(--color-primary);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;flex-shrink:0}@media(max-width:1024px){.discovery-layout{grid-template-columns:1fr}.discovery-sources{max-height:300px}}@media(max-width:768px){.track-row{grid-template-columns:36px 1fr auto}.track-bpm,.track-key,.track-duration{display:none}.tracks-header{flex-direction:column;align-items:stretch}.tracks-actions{justify-content:flex-end}}.upload-zone{background:var(--color-bg-secondary);border:2px dashed var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-2xl) var(--spacing-xl);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;cursor:pointer;transition:all var(--transition-base);min-height:300px}.upload-zone:hover{border-color:var(--color-primary);background:var(--color-bg-tertiary)}.upload-zone.dragging{border-color:var(--color-primary);background:var(--color-primary-subtle);box-shadow:var(--shadow-glow)}.upload-zone.error{border-color:var(--color-error)}.upload-icon{width:80px;height:80px;border-radius:var(--radius-full);background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;margin-bottom:var(--spacing-lg);color:#fff}.upload-zone h3{margin-bottom:var(--spacing-xs);font-size:1.25rem}.upload-zone p{color:var(--color-text-secondary);margin-bottom:var(--spacing-md)}.upload-formats{font-size:.75rem;color:var(--color-text-tertiary);padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-bg-tertiary);border-radius:var(--radius-full)}.analysis-error{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-lg);color:var(--color-error)}.analysis-error svg{flex-shrink:0}.analysis-error div{flex:1}.analysis-error strong{display:block;margin-bottom:var(--spacing-xs)}.analysis-error p{font-size:.875rem;opacity:.9}.analysis-progress{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-2xl);display:flex;justify-content:center}.progress-content{display:flex;flex-direction:column;align-items:center;text-align:center;max-width:400px}.progress-content svg.pulse{color:var(--color-primary);margin-bottom:var(--spacing-lg);animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.05)}}.progress-content h3{margin-bottom:var(--spacing-sm);word-break:break-word}.progress-content p{color:var(--color-text-secondary);margin-bottom:var(--spacing-lg)}.progress-bar{width:100%;height:8px;background:var(--color-bg-tertiary);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--spacing-sm)}.progress-fill{height:100%;background:var(--gradient-primary);border-radius:var(--radius-full);transition:width .3s ease}.progress-percent{font-size:.875rem;color:var(--color-text-tertiary)}.analysis-results{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);overflow:hidden}.result-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--color-border);gap:var(--spacing-md);flex-wrap:wrap}.result-file-info{display:flex;align-items:center;gap:var(--spacing-md)}.result-file-info h3{font-size:1rem;word-break:break-word}.result-file-info span{font-size:.8125rem;color:var(--color-text-secondary)}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md);padding:var(--spacing-lg)}.feature-card{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-md);display:flex;align-items:flex-start;gap:var(--spacing-md)}.feature-icon{width:44px;height:44px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.bpm-card .feature-icon{background:#fb923c33;color:#fb923c}.key-card .feature-icon{background:#8b5cf633;color:#8b5cf6}.energy-card .feature-icon{background:#22c55e33;color:#22c55e}.dance-card .feature-icon{background:#ec489933;color:#ec4899}.loudness-card .feature-icon{background:#06b6d433;color:#06b6d4}.feature-content{display:flex;flex-direction:column;flex:1;min-width:0}.feature-label{font-size:.75rem;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--spacing-xs)}.feature-value{font-size:1.75rem;font-weight:700;line-height:1;margin-bottom:var(--spacing-xs)}.feature-sublabel{font-size:.8125rem;color:var(--color-text-secondary);text-transform:capitalize}.feature-percent{font-size:.875rem;color:var(--color-text-secondary)}.confidence-bar,.energy-meter{width:100%;height:6px;background:var(--color-bg-primary);border-radius:var(--radius-full);overflow:hidden;margin:var(--spacing-xs) 0}.confidence-fill{height:100%;background:var(--color-primary);border-radius:var(--radius-full);transition:width .5s ease}.energy-fill{height:100%;background:linear-gradient(90deg,#22c55e,#84cc16);border-radius:var(--radius-full);transition:width .5s ease}.energy-fill.dance{background:linear-gradient(90deg,#ec4899,#f472b6)}.confidence-label{font-size:.6875rem;color:var(--color-text-tertiary)}.analysis-section{padding:var(--spacing-lg);border-top:1px solid var(--color-border)}.analysis-section h3{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);color:var(--color-text-secondary);font-weight:500}.genre-predictions{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.genre-tag{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-full)}.genre-name{font-weight:500}.genre-confidence{font-size:.75rem;color:var(--color-primary);background:var(--color-primary-subtle);padding:2px 8px;border-radius:var(--radius-full)}.chord-timeline{display:flex;gap:2px;overflow-x:auto;padding-bottom:var(--spacing-sm)}.chord-segment{min-width:60px;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex;flex-direction:column;align-items:center;gap:2px;flex-shrink:0}.chord-name{font-weight:600;font-size:1rem}.chord-time{font-size:.6875rem;color:var(--color-text-tertiary)}.chord-more{display:flex;align-items:center;justify-content:center;padding:var(--spacing-sm) var(--spacing-md);color:var(--color-text-tertiary);font-size:.75rem;white-space:nowrap}.analysis-complete{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:#10b9811a;color:var(--color-success);font-size:.875rem;font-weight:500}.mood-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.mood-item{display:flex;align-items:center;gap:var(--spacing-sm);background:var(--color-bg-tertiary);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);border:1px solid var(--color-border)}.mood-icon{width:32px;height:32px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.mood-icon.happy{background:#fbbf2433;color:#fbbf24}.mood-icon.sad{background:#6366f133;color:#6366f1}.mood-icon.aggressive{background:#ef444433;color:#ef4444}.mood-icon.relaxed{background:#22c55e33;color:#22c55e}.mood-icon.party{background:#ec489933;color:#ec4899}.mood-label{font-size:.8125rem;color:var(--color-text-secondary);min-width:70px}.mood-bar{flex:1;height:8px;background:var(--color-bg-primary);border-radius:4px;overflow:hidden}.mood-fill{height:100%;border-radius:4px;transition:width .3s ease}.mood-fill.relaxed{background:linear-gradient(90deg,#22c55e,#16a34a)}.mood-value{font-size:.75rem;font-weight:600;min-width:36px;text-align:right}.emotional-metrics{display:flex;align-items:center;gap:var(--spacing-lg);padding:var(--spacing-md);background:var(--color-bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--color-border)}.emotional-metrics .metric{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs)}.emotional-metrics .metric-label{font-size:.6875rem;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em}.emotional-metrics .metric-value{font-size:1.25rem;font-weight:700;font-family:var(--font-mono)}.emotional-quadrant{margin-left:auto;padding:var(--spacing-sm) var(--spacing-md);background:#8b5cf626;border:1px solid rgba(139,92,246,.3);border-radius:var(--radius-full);font-size:.875rem;font-weight:600}@media(max-width:768px){.features-grid{grid-template-columns:1fr}.result-header{flex-direction:column;align-items:flex-start}.chord-timeline{gap:var(--spacing-xs)}.chord-segment{min-width:50px;padding:var(--spacing-xs) var(--spacing-sm)}.mood-grid{grid-template-columns:1fr}.emotional-metrics{flex-direction:column;align-items:stretch}.emotional-metrics .metric{flex-direction:row;justify-content:space-between}.emotional-quadrant{margin-left:0;text-align:center}}.song-analysis{max-width:1200px;margin:0 auto}.upload-zone{border:2px dashed var(--color-border);border-radius:var(--radius-xl);padding:4rem 2rem;text-align:center;background:var(--color-bg-secondary);transition:all var(--transition-base);cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md)}.upload-zone:hover,.upload-zone.dragging{border-color:var(--color-primary);background:var(--color-bg-elevated);box-shadow:var(--shadow-glow)}.upload-zone.error{border-color:var(--color-error);background:#ef44440d}.upload-icon{width:96px;height:96px;border-radius:50%;background:var(--color-bg-tertiary);display:flex;align-items:center;justify-content:center;margin-bottom:var(--spacing-md);color:var(--color-primary);transition:all var(--transition-base)}.upload-zone:hover .upload-icon{transform:scale(1.1);background:var(--color-primary-subtle)}.upload-formats{font-size:.875rem;color:var(--color-text-tertiary);margin-top:var(--spacing-sm)}.analysis-results{display:flex;flex-direction:column;gap:var(--spacing-xl);animation:fadeIn .5s ease-out}.result-header{display:flex;justify-content:space-between;align-items:center;background:var(--color-bg-secondary);padding:var(--spacing-lg);border-radius:var(--radius-lg);border:1px solid var(--color-border)}.result-file-info{display:flex;align-items:center;gap:var(--spacing-lg)}.result-file-info svg{color:var(--color-primary)}.hero-stats{display:flex;justify-content:center;gap:4rem;padding:2rem;background:linear-gradient(180deg,rgba(139,92,246,.1) 0%,transparent 100%);border-radius:var(--radius-xl);border:1px solid var(--color-primary-subtle);margin-bottom:var(--spacing-lg)}.stat-item{display:flex;flex-direction:column;align-items:center;gap:.5rem}.stat-item .stat-value{font-size:3.5rem;font-weight:800;line-height:1;background:linear-gradient(135deg,#fff,#a5b4fc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;text-shadow:0 4px 12px rgba(139,92,246,.3)}.stat-item .stat-label{font-size:.875rem;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-secondary);font-weight:600}.camelot-badge{background:var(--color-primary);color:#fff;padding:.25rem .75rem;border-radius:var(--radius-full);font-weight:700;font-size:1rem;margin-top:-.5rem;box-shadow:0 0 15px var(--color-primary-subtle)}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--spacing-lg)}.feature-card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);transition:transform .2s ease,border-color .2s ease}.feature-card:hover{transform:translateY(-2px);border-color:var(--color-border-light)}.section-title{font-size:1.125rem;font-weight:600;margin-bottom:var(--spacing-lg);display:flex;align-items:center;gap:.5rem;color:var(--color-text-primary)}.genre-pills{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center}.genre-pill{background:var(--color-bg-tertiary);border:1px solid var(--color-border);padding:.5rem 1rem;border-radius:var(--radius-full);display:flex;align-items:center;gap:.5rem;font-size:.9375rem;transition:all .2s ease}.genre-pill.primary{background:#8b5cf633;border-color:var(--color-primary);color:#fff;box-shadow:0 0 15px #8b5cf633}.genre-pill.secondary{background:#06b6d426;border-color:var(--color-secondary);color:#fff}.genre-pill.tertiary{background:#10b9811a;border-color:var(--color-success)}.genre-probability{font-size:.75rem;opacity:.7;font-weight:600}.energy-meters-card{display:flex;flex-direction:column;gap:1.5rem}.energy-meter-container{display:flex;flex-direction:column;gap:.5rem}.energy-header{display:flex;justify-content:space-between;align-items:center;font-size:.9375rem}.energy-label{display:flex;align-items:center;gap:.5rem;color:var(--color-text-secondary)}.energy-value{font-weight:700}.energy-bar-bg{height:8px;background:var(--color-bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.energy-bar{height:100%;border-radius:var(--radius-full);transition:width 1s cubic-bezier(.4,0,.2,1)}.energy-bar.danceability{background:linear-gradient(90deg,#22c55e,#4ade80)}.energy-bar.energy{background:linear-gradient(90deg,#ea580c,#fb923c)}.energy-bar.positivity{background:linear-gradient(90deg,#4f46e5,#818cf8)}.analysis-progress{display:flex;justify-content:center;align-items:center;padding:4rem 0}.progress-content{text-align:center;max-width:400px;width:100%}.progress-bar{height:6px;background:var(--color-bg-tertiary);border-radius:var(--radius-full);margin:var(--spacing-md) 0;overflow:hidden;position:relative}.progress-fill{height:100%;background:var(--gradient-primary);border-radius:var(--radius-full);transition:width .3s ease;box-shadow:0 0 10px #8b5cf680}.pulse{animation:pulse 2s infinite}@keyframes pulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}to{transform:scale(1);opacity:1}}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.waveform-player-container{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-md)}.waveform-wrapper{width:100%;min-height:120px;position:relative;border-radius:var(--radius-md);overflow:hidden;background:#0003}.controls-timeline-wrapper{display:flex;flex-direction:column;gap:var(--spacing-md);padding-top:var(--spacing-sm)}.player-controls{display:flex;align-items:center;gap:var(--spacing-md)}.btn-icon.circle{width:48px;height:48px;border-radius:50%;background:var(--color-bg-tertiary);border:1px solid var(--color-border);display:flex;align-items:center;justify-content:center;color:var(--color-text-primary);transition:all var(--transition-base)}.btn-icon.circle:hover{background:var(--color-bg-hover);transform:scale(1.05)}.btn-icon.circle.primary{background:var(--color-primary);color:#fff;border:none;box-shadow:0 0 15px var(--color-primary-subtle)}.btn-icon.circle.primary:hover{background:var(--color-primary-hover)}.time-display{font-family:var(--font-mono);font-size:.875rem;color:var(--color-text-secondary);display:flex;gap:.25rem}.time-display .current-time{color:var(--color-text-primary);font-weight:600}.timeline-wrapper{position:relative;margin-top:var(--spacing-xs)}.segmentation-timeline-container{display:flex;flex-direction:column;gap:4px}.timeline-labels{position:relative;height:20px;width:100%}.timeline-segment-label{position:absolute;top:0;height:100%;color:var(--color-text-secondary);font-size:.7rem;font-weight:600;text-transform:uppercase;display:flex;align-items:center;justify-content:center;overflow:hidden;white-space:nowrap;cursor:pointer;transition:color .2s}.timeline-segment-label.active{color:var(--color-text-primary);text-shadow:0 0 5px rgba(255,255,255,.3)}.timeline-bar{position:relative;width:100%;height:8px;background:var(--color-bg-tertiary);border-radius:var(--radius-full);cursor:pointer;overflow:hidden}.timeline-segment{position:absolute;top:0;bottom:0;opacity:.6;transition:opacity .2s}.timeline-segment:hover{opacity:.9}.timeline-segment.active{opacity:1;box-shadow:0 0 8px currentColor;z-index:1}.timeline-playhead{position:absolute;top:-2px;bottom:-2px;width:2px;background:#fff;box-shadow:0 0 4px #00000080;z-index:10;pointer-events:none;transition:left .1s linear}.player-controls-row{display:flex;justify-content:space-between;align-items:center;width:100%}.current-chord-display{display:flex;flex-direction:column;align-items:center;background:#0006;padding:.5rem 1rem;border-radius:var(--radius-md);border:1px solid var(--color-border);min-width:80px}.current-chord-display .label{font-size:.65rem;text-transform:uppercase;color:var(--color-text-tertiary);letter-spacing:.05em;font-weight:600}.current-chord-display .value{font-size:1.25rem;font-weight:700;color:#f59e0b;line-height:1.2}.timeline-stack{display:flex;flex-direction:column;gap:var(--spacing-sm)}.chord-labels{height:16px}.chord-label{font-size:.65rem;color:var(--color-text-tertiary)}.chord-label.active{color:#f59e0b}.chord-bar{height:6px;background:#ffffff0d}.chord-segment{background-color:#f59e0b}.chord-segment.active{background-color:#fbbf24;box-shadow:0 0 8px #fbbf2466;z-index:2;opacity:1!important}.waveform-display{position:relative;width:100%;min-height:120px;border-radius:var(--radius-md);overflow:hidden;background:#0000004d}.three-band-waveform{width:100%;border-radius:var(--radius-md);overflow:hidden}.three-band-waveform canvas{display:block}.waveform-mode-toggle{display:flex;gap:2px;background:var(--color-bg-tertiary);border-radius:var(--radius-md);padding:2px;width:fit-content;margin-top:var(--spacing-sm)}.waveform-mode-toggle .mode-btn{display:flex;align-items:center;justify-content:center;width:32px;height:28px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--color-text-tertiary);cursor:pointer;transition:all var(--transition-fast)}.waveform-mode-toggle .mode-btn:hover{color:var(--color-text-secondary);background:var(--color-bg-hover)}.waveform-mode-toggle .mode-btn.active{background:var(--color-primary);color:#fff;box-shadow:0 0 8px var(--color-primary-subtle)}.band-legend{display:flex;gap:var(--spacing-md);font-size:.6875rem;color:var(--color-text-tertiary);padding:var(--spacing-xs) 0}.band-legend-item{display:flex;align-items:center;gap:var(--spacing-xs)}.band-legend-dot{width:8px;height:8px;border-radius:50%}.band-legend-dot.bass{background:#3b82f6}.band-legend-dot.mids{background:#f59e0b}.band-legend-dot.highs{background:#fafafa}.umap-container{position:relative;width:100%;height:600px;background:var(--bg-secondary);border-radius:var(--border-radius-lg);border:1px solid var(--border-color);overflow:hidden;display:flex;flex-direction:column}.umap-container.fullscreen{position:fixed;inset:0;width:100vw;height:100vh;z-index:100000;border-radius:0;background:var(--color-bg-primary);isolation:isolate}.umap-container.loading,.umap-container.error{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);color:var(--text-secondary)}.umap-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--border-color);background:var(--bg-tertiary)}.umap-header h3{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.umap-subtitle{margin:4px 0 0;font-size:.875rem;color:var(--text-secondary)}.umap-main-content{display:flex;flex:1;overflow:hidden;position:relative}.umap-settings{width:360px;padding:var(--spacing-lg);background:linear-gradient(180deg,#141414fa,#0f0f0ffa);border-right:1px solid var(--border-color);overflow-y:auto;display:flex;flex-direction:column;gap:var(--spacing-lg);animation:slideInLeft .25s ease-out;box-shadow:4px 0 12px #0000004d;flex-shrink:0}.umap-viewport{flex:1;position:relative;display:flex;flex-direction:column}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.btn-icon.active{background:#60a5fa33;color:#60a5fa}.umap-settings h4{margin:0;font-size:.875rem;font-weight:600;color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px;opacity:.8}.setting-value{font-family:SF Mono,Monaco,Courier New,monospace;color:#60a5fa;background:#60a5fa26;padding:3px 8px;border-radius:4px;font-size:.75rem;font-weight:600}.setting-hint{margin:var(--spacing-xs) 0 0 0;font-size:.75rem;color:var(--text-tertiary);font-style:italic}.feature-checkboxes{display:flex;flex-direction:column;gap:var(--spacing-sm)}.feature-checkbox{display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-sm);background:#ffffff05;border-radius:var(--border-radius-sm);cursor:pointer;transition:background .2s}.feature-checkbox:hover{background:#ffffff0d}.feature-checkbox input[type=checkbox]{margin-top:2px;width:16px;height:16px;cursor:pointer;accent-color:#60a5fa}.feature-checkbox span{flex:1;font-size:.875rem;color:var(--text-secondary);line-height:1.4}.feature-checkbox strong{color:var(--text-primary);font-weight:600}.playlist-picker-list{overflow-y:auto;max-height:40vh;display:flex;flex-direction:column;gap:var(--spacing-xs)}.mode-selector{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.mode-btn{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:#ffffff08;border:2px solid transparent;border-radius:var(--border-radius-md);cursor:pointer;transition:all .2s;color:var(--text-secondary)}.mode-btn:hover{background:#ffffff0d;border-color:#60a5fa4d}.mode-btn.active{background:#60a5fa26;border-color:#60a5fa;color:var(--text-primary)}.mode-icon{font-size:1.5rem;line-height:1}.mode-info{display:flex;flex-direction:column;align-items:flex-start;gap:2px}.mode-title{font-weight:600;font-size:.875rem}.mode-desc{font-size:.75rem;opacity:.7}.flamingo-section{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md);background:linear-gradient(135deg,#ec489914,#a855f714);border-radius:var(--border-radius-md);border:1px solid rgba(236,72,153,.2)}.flamingo-status{display:flex;align-items:center}.flamingo-status .status-info{display:flex;align-items:center;gap:var(--spacing-sm);font-size:.875rem;color:var(--text-secondary)}.flamingo-status .status-indicator{width:8px;height:8px;border-radius:50%;background:#ef4444}.flamingo-status .status-indicator.active{background:#22c55e;box-shadow:0 0 8px #22c55e80}.flamingo-extract-controls{display:flex;flex-direction:column;gap:var(--spacing-sm)}.force-refresh-checkbox{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.75rem;color:var(--text-secondary);cursor:pointer}.force-refresh-checkbox input[type=checkbox]{width:14px;height:14px;cursor:pointer;accent-color:#ec4899}.force-refresh-checkbox:hover{color:var(--text-primary)}.extract-flamingo-btn{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:linear-gradient(135deg,#ec48994d,#a855f74d);border:1px solid rgba(236,72,153,.4);border-radius:var(--border-radius-md);color:#f9a8d4;font-weight:500;font-size:.875rem;cursor:pointer;transition:all .2s}.extract-flamingo-btn:hover:not(:disabled){background:linear-gradient(135deg,#ec489966,#a855f766);border-color:#ec489999;color:#fbcfe8}.extract-flamingo-btn:disabled{opacity:.6;cursor:not-allowed}.flamingo-progress{font-size:.75rem;color:var(--text-tertiary);text-align:center;padding:var(--spacing-xs);background:#0003;border-radius:var(--border-radius-sm)}.spin{animation:spin 1s linear infinite}.genre-filter-section{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md);background:#ffffff05;border-radius:var(--border-radius-md)}.genre-filter-header{display:flex;justify-content:space-between;align-items:center}.genre-filter-header h4{display:flex;align-items:center}.clear-filter-btn{font-size:.75rem;padding:4px 10px;background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:12px;color:#f87171;cursor:pointer;transition:all .2s}.clear-filter-btn:hover{background:#ef444440;border-color:#ef444480}.selected-genres{display:flex;flex-wrap:wrap;gap:6px;padding:8px;background:#60a5fa0d;border-radius:8px;border:1px solid rgba(96,165,250,.2)}.genre-tag{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:#60a5fa33;border-radius:14px;font-size:.75rem;color:#60a5fa;font-weight:500}.genre-tag .remove-genre{display:flex;align-items:center;justify-content:center;width:16px;height:16px;padding:0;background:#0000004d;border:none;border-radius:50%;color:inherit;cursor:pointer;transition:all .2s}.genre-tag .remove-genre:hover{background:#ef444480;color:#fff}.genre-search{position:relative}.genre-search input{width:100%;padding:10px 32px 10px 12px;background:#0000004d;border:1px solid #333;border-radius:8px;color:var(--text-primary);font-size:.875rem}.genre-search input:focus{outline:none;border-color:#60a5fa;background:#0006}.genre-search input::placeholder{color:var(--text-tertiary)}.genre-search .clear-search{position:absolute;right:8px;top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;width:20px;height:20px;padding:0;background:#ffffff1a;border:none;border-radius:50%;color:var(--text-secondary);cursor:pointer}.genre-search .clear-search:hover{background:#fff3;color:var(--text-primary)}.genre-list{display:flex;flex-direction:column;gap:2px;max-height:200px;overflow-y:auto;padding:4px;background:#0003;border-radius:8px}.genre-list::-webkit-scrollbar{width:6px}.genre-list::-webkit-scrollbar-track{background:transparent}.genre-list::-webkit-scrollbar-thumb{background:#60a5fa4d;border-radius:3px}.genre-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:transparent;border:none;border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:all .15s;text-align:left;font-size:.8125rem}.genre-item:hover{background:#ffffff0d;color:var(--text-primary)}.genre-item.selected{background:#60a5fa26;color:#60a5fa}.genre-item .genre-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.genre-item .genre-category{opacity:.5;font-size:.75rem}.genre-item .genre-count{font-size:.7rem;padding:2px 6px;background:#ffffff1a;border-radius:10px;font-family:monospace;color:var(--text-tertiary);flex-shrink:0}.genre-item.selected .genre-count{background:#60a5fa4d;color:#60a5fa}.no-genres,.genre-overflow,.filter-hint{font-size:.75rem;color:var(--text-tertiary);text-align:center;padding:8px;margin:0}.filter-hint{font-style:italic;opacity:.7}.filter-badge{color:#60a5fa;font-weight:500}.features-section{display:flex;flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-md);background:#ffffff05;border-radius:var(--border-radius-md)}.features-header{display:flex;justify-content:space-between;align-items:center}.dim-counter{font-size:.75rem;padding:4px 10px;background:#60a5fa33;border-radius:12px;color:#60a5fa;font-weight:600;font-family:monospace}.preset-pills{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-xs)}.preset-pill{padding:10px 14px;background:#ffffff0d;border:1px solid #333;border-radius:8px;font-size:.8125rem;cursor:pointer;transition:all .2s;color:var(--text-secondary);font-weight:500;text-align:center}.preset-pill:hover{background:#60a5fa1a;border-color:#60a5fa;color:var(--text-primary);transform:translateY(-1px)}.feature-chips{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-xs)}.feature-chip{display:flex;align-items:center;justify-content:space-between;gap:6px;padding:8px 12px;background:#ffffff08;border:1px solid #333;border-radius:6px;cursor:pointer;transition:all .2s;font-size:.8125rem}.feature-chip:hover{background:#ffffff0d;border-color:#555}.feature-chip.active{background:#60a5fa26;border-color:#60a5fa}.feature-chip .chip-name{color:var(--text-secondary);font-weight:500}.feature-chip.active .chip-name{color:var(--text-primary)}.feature-chip .chip-dims{font-size:.7rem;padding:2px 6px;background:#0000004d;border-radius:4px;font-family:monospace;color:var(--text-tertiary)}.feature-chip.active .chip-dims{background:#60a5fa4d;color:#60a5fa}.algorithm-section{display:flex;flex-direction:column;gap:var(--spacing-md)}.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.setting-compact{display:flex;flex-direction:column;gap:6px}.setting-compact label{display:flex;justify-content:space-between;align-items:center;font-size:.8125rem;font-weight:500;color:var(--text-primary)}.setting-compact input[type=range]{width:100%;height:4px;background:#ffffff1a;border-radius:2px;outline:none;-webkit-appearance:none}.setting-compact input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;background:#60a5fa;border-radius:50%;cursor:pointer;transition:all .2s}.setting-compact input[type=range]::-webkit-slider-thumb:hover{background:#93c5fd;transform:scale(1.15)}.setting-compact input[type=range]::-moz-range-thumb{width:14px;height:14px;background:#60a5fa;border-radius:50%;cursor:pointer;border:none;transition:all .2s}.setting-compact input[type=range]::-moz-range-thumb:hover{background:#93c5fd;transform:scale(1.15)}.range-labels{display:flex;justify-content:space-between;font-size:.7rem;color:var(--text-tertiary)}.algorithm-selector{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.algorithm-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:12px;background:#ffffff08;border:1px solid #333;border-radius:8px;cursor:pointer;transition:all .2s;text-align:center}.algorithm-btn:hover{background:#ffffff0f;border-color:#555}.algorithm-btn.active{background:#60a5fa26;border-color:#60a5fa}.algorithm-btn .algo-name{font-size:.9rem;font-weight:600;color:var(--text-secondary)}.algorithm-btn.active .algo-name{color:#60a5fa}.algorithm-btn .algo-desc{font-size:.7rem;color:var(--text-tertiary)}.algorithm-btn.active .algo-desc{color:#60a5fab3}.metric-buttons{display:flex;align-items:center;gap:var(--spacing-xs);flex-wrap:wrap}.metric-label{font-size:.8125rem;color:var(--text-secondary);font-weight:500}.metric-btn{padding:6px 12px;background:#ffffff08;border:1px solid #333;border-radius:6px;font-size:.75rem;cursor:pointer;transition:all .2s;color:var(--text-secondary)}.metric-btn:hover{background:#ffffff0d;border-color:#555}.metric-btn.active{background:#60a5fa26;border-color:#60a5fa;color:var(--text-primary);font-weight:600}.color-mode-section{padding:var(--spacing-md);border-bottom:1px solid rgba(255,255,255,.05)}.color-mode-section h4{margin:0 0 var(--spacing-sm) 0;font-size:.9rem;color:var(--text-primary)}.color-mode-selector{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-xs)}.color-mode-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:10px;background:#ffffff08;border:1px solid #333;border-radius:8px;cursor:pointer;transition:all .2s}.color-mode-btn:hover{background:#ffffff0f;border-color:#555}.color-mode-btn.active{background:#60a5fa26;border-color:#60a5fa}.color-mode-btn .color-icon{font-size:1rem}.color-mode-btn .color-label{font-size:.8rem;font-weight:500;color:var(--text-secondary)}.color-mode-btn.active .color-label{color:#60a5fa}.cluster-info{display:flex;justify-content:space-between;align-items:center;margin-top:var(--spacing-sm);padding:8px 10px;background:#ffffff05;border-radius:6px;font-size:.75rem;color:var(--text-tertiary)}.cluster-info .noise-indicator{color:#666}.apply-button{width:100%;padding:12px;background:linear-gradient(135deg,#60a5fa,#3b82f6);border:none;border-radius:var(--border-radius-md);color:#fff;font-weight:600;font-size:.9375rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);box-shadow:0 2px 8px #60a5fa4d}.apply-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #60a5fa66}.apply-button:disabled{opacity:.6;cursor:not-allowed}.umap-settings>div:not(:first-child){position:relative;padding-top:var(--spacing-lg);border-top:1px solid rgba(96,165,250,.15)}.umap-settings::-webkit-scrollbar{width:6px}.umap-settings::-webkit-scrollbar-track{background:#0003;border-radius:3px}.umap-settings::-webkit-scrollbar-thumb{background:#60a5fa4d;border-radius:3px}.umap-settings::-webkit-scrollbar-thumb:hover{background:#60a5fa80}.umap-canvas-wrapper{flex:1;position:relative;width:100%;height:100%}.umap-legend{position:absolute;bottom:80px;right:var(--spacing-lg);background:#0a0a0ae6;backdrop-filter:blur(10px);padding:var(--spacing-md);border-radius:var(--border-radius-md);border:1px solid var(--border-color);z-index:10}.umap-legend h4{margin:0 0 var(--spacing-sm) 0;font-size:.875rem;font-weight:600;color:var(--text-primary)}.legend-item{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs);font-size:.75rem;color:var(--text-secondary)}.legend-color{width:12px;height:12px;border-radius:50%;border:1px solid rgba(255,255,255,.2)}.umap-legend.bpm-legend{min-width:120px}.bpm-gradient-bar{width:100%;height:12px;border-radius:6px;overflow:hidden;border:1px solid rgba(255,255,255,.2);margin-bottom:var(--spacing-xs)}.bpm-gradient-bar .gradient-fill{width:100%;height:100%}.bpm-labels{display:flex;justify-content:space-between;font-size:.75rem;color:var(--text-secondary)}.umap-search-bar{position:absolute;top:var(--spacing-lg);left:50%;transform:translate(-50%);z-index:20;min-width:280px;max-width:400px}.search-input-wrapper{display:flex;align-items:center;background:#141419f2;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.15);border-radius:8px;padding:8px 12px;gap:8px}.search-input-wrapper:focus-within{border-color:#6366f1;box-shadow:0 0 0 2px #6366f133}.search-input-wrapper .search-icon{color:#888;flex-shrink:0}.search-input{flex:1;background:transparent;border:none;outline:none;color:#f0f0f0;font-size:.875rem}.search-input::placeholder{color:#666}.search-clear{background:transparent;border:none;color:#888;cursor:pointer;padding:2px;display:flex;align-items:center;justify-content:center;border-radius:4px}.search-clear:hover{color:#f0f0f0;background:#ffffff1a}.search-results{margin-top:4px;background:#141419f2;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.15);border-radius:8px;overflow:hidden;max-height:300px;overflow-y:auto}.search-result-item{display:flex;flex-direction:column;align-items:flex-start;width:100%;padding:8px 12px;background:transparent;border:none;border-bottom:1px solid rgba(255,255,255,.1);cursor:pointer;text-align:left;transition:background-color .15s}.search-result-item:last-child{border-bottom:none}.search-result-item:hover,.search-result-item.selected{background:#6366f133}.search-result-item .result-title{color:#f0f0f0;font-size:.875rem;font-weight:500}.search-result-item .result-artist{color:#888;font-size:.75rem}.umap-instructions{position:absolute;bottom:var(--spacing-lg);left:var(--spacing-lg);background:#0a0a0ae6;backdrop-filter:blur(10px);padding:var(--spacing-md);border-radius:var(--border-radius-md);border:1px solid var(--border-color);z-index:10;font-size:.75rem;color:var(--text-secondary)}.umap-instructions p{margin:0 0 4px}.umap-instructions p:last-child{margin-bottom:0}.umap-instructions strong{color:var(--text-primary);display:block;margin-bottom:var(--spacing-xs)}.umap-tooltip{background:#0a0a0af2;backdrop-filter:blur(10px);padding:var(--spacing-md);border-radius:var(--border-radius-md);border:1px solid var(--border-color);pointer-events:none;box-shadow:0 4px 12px #00000080;max-width:280px}.tooltip-title{font-weight:600;color:var(--text-primary);margin-bottom:4px}.tooltip-artist{font-size:.875rem;color:var(--text-secondary);margin-bottom:8px}.tooltip-details{font-size:.75rem;color:var(--text-tertiary);display:flex;gap:var(--spacing-md);flex-wrap:wrap}.tooltip-details span{display:inline-block}.tooltip-moods{margin-top:12px;padding-top:12px;border-top:1px solid rgba(96,165,250,.2);min-width:220px}.mood-label{font-size:.75rem;font-weight:600;color:var(--text-secondary);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.mood-grid{display:flex;flex-direction:column;gap:6px}.mood-item{display:grid;grid-template-columns:70px 1fr 35px;align-items:center;gap:8px;font-size:.75rem}.mood-name{color:var(--text-secondary);font-weight:500}.mood-bar{height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden;position:relative}.mood-fill{position:absolute;left:0;top:0;height:100%;background:#60a5fa;border-radius:3px;transition:width .3s ease}.mood-fill.aggressive{background:linear-gradient(90deg,#ef4444,#dc2626)}.mood-fill.happy{background:linear-gradient(90deg,#fbbf24,#f59e0b)}.mood-fill.party{background:linear-gradient(90deg,#ec4899,#db2777)}.mood-fill.relaxed{background:linear-gradient(90deg,#10b981,#059669)}.mood-fill.sad{background:linear-gradient(90deg,#6366f1,#4f46e5)}.mood-value{color:var(--text-tertiary);font-family:SF Mono,Monaco,Courier New,monospace;font-size:.7rem;text-align:right}.umap-hover-label{background:#0a0a0ae6;backdrop-filter:blur(8px);padding:8px 12px;border-radius:8px;border:1px solid rgba(96,165,250,.3);pointer-events:none;white-space:nowrap;display:flex;flex-direction:column;gap:2px}.umap-hover-label .hover-title{font-weight:600;font-size:.875rem;color:var(--text-primary)}.umap-hover-label .hover-artist{font-size:.75rem;color:var(--text-secondary)}.song-detail-panel{position:absolute;top:16px;right:16px;width:280px;background:#0f0f0ff2;backdrop-filter:blur(12px);border-radius:12px;border:1px solid rgba(96,165,250,.2);box-shadow:0 8px 32px #00000080;overflow:hidden;animation:slideIn .2s ease-out;z-index:100}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.song-detail-panel .close-panel{position:absolute;top:12px;right:12px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border:none;border-radius:50%;color:var(--text-secondary);cursor:pointer;transition:all .2s;z-index:1}.song-detail-panel .close-panel:hover{background:#ef44444d;color:#f87171}.song-detail-panel .panel-header{padding:20px 20px 16px;background:linear-gradient(180deg,rgba(96,165,250,.1) 0%,transparent 100%);border-bottom:1px solid rgba(96,165,250,.1)}.song-detail-panel .panel-title{margin:0;font-size:1.125rem;font-weight:600;color:var(--text-primary);padding-right:32px;line-height:1.3}.song-detail-panel .panel-artist{margin:6px 0 0;font-size:.875rem;color:var(--text-secondary)}.song-detail-panel .panel-play-btn{width:32px;height:32px;border-radius:50%;border:none;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0}.song-detail-panel .panel-play-btn:hover:not(:disabled){background:var(--color-primary-hover);transform:scale(1.05)}.song-detail-panel .panel-play-btn:disabled{opacity:.4;cursor:not-allowed}.song-detail-panel .panel-play-btn svg{margin-left:2px}.song-detail-panel .panel-play-btn svg:has(+*){margin-left:0}.song-detail-panel .panel-stats{display:flex;gap:16px;padding:16px 20px;background:#0003;flex-wrap:wrap}.song-detail-panel .stat-item{display:flex;flex-direction:column;gap:2px}.song-detail-panel .stat-label{font-size:.625rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.song-detail-panel .stat-value{font-size:.9375rem;font-weight:600;color:var(--text-primary)}.song-detail-panel .stat-value.genre-value{font-size:.8125rem;color:#60a5fa}.song-detail-panel .panel-moods{padding:16px 20px 20px}.song-detail-panel .panel-moods h5{margin:0 0 12px;font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.song-detail-panel .mood-bars{display:flex;flex-direction:column;gap:10px}.song-detail-panel .mood-row{display:grid;grid-template-columns:70px 1fr 36px;align-items:center;gap:10px}.song-detail-panel .mood-row .mood-name{font-size:.75rem;color:var(--text-secondary);font-weight:500}.song-detail-panel .mood-bar-container{height:8px;background:#ffffff14;border-radius:4px;overflow:hidden}.song-detail-panel .mood-bar-fill{height:100%;border-radius:4px;transition:width .3s ease}.song-detail-panel .mood-percent{font-size:.75rem;font-family:SF Mono,Monaco,Courier New,monospace;color:var(--text-tertiary);text-align:right}.view-toggle{display:flex;gap:var(--spacing-sm);padding:var(--spacing-sm);background:var(--bg-tertiary);border-radius:var(--border-radius-md);border:1px solid var(--border-color)}.view-toggle-btn{padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:none;border-radius:var(--border-radius-sm);color:var(--text-secondary);cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:var(--spacing-xs)}.view-toggle-btn:hover{color:var(--text-primary);background:var(--bg-hover)}.view-toggle-btn.active{color:var(--text-primary);background:var(--bg-primary)}@media(max-width:1024px){.umap-settings{width:280px}.settings-grid{grid-template-columns:1fr}}@media(max-width:768px){.umap-main-content{flex-direction:column}.umap-settings{width:100%;max-height:50vh;border-right:none;border-bottom:1px solid var(--border-color);animation:slideDown .25s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.umap-viewport{min-height:50vh}.umap-legend,.umap-instructions{font-size:.625rem;padding:var(--spacing-sm)}.umap-legend{right:var(--spacing-sm);bottom:60px}.umap-instructions{left:var(--spacing-sm);bottom:var(--spacing-sm)}.mode-selector{grid-template-columns:1fr}.feature-chips{gap:6px}.feature-chip{flex:1;min-width:calc(50% - 3px);justify-content:center}}.dropzone{transition:all .2s ease}.dropzone:hover{border-color:#60a5fa!important;background:#60a5fa0d!important}.dropzone.dragging{border-color:#60a5fa!important;background:#60a5fa1a!important;transform:scale(1.02)}.generate-set-container{display:flex;align-items:center;gap:2px;position:relative}.btn-generate-set{display:flex;align-items:center;gap:6px;padding:8px 14px;background:linear-gradient(135deg,#059669,#10b981);border:none;border-radius:6px 0 0 6px;color:#fff;font-size:.8125rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-generate-set:hover:not(:disabled){background:linear-gradient(135deg,#047857,#059669);transform:translateY(-1px)}.btn-generate-set:disabled{opacity:.5;cursor:not-allowed}.btn-generate-set.active{background:linear-gradient(135deg,#dc2626,#ef4444)}.btn-generate-set.active:hover:not(:disabled){background:linear-gradient(135deg,#b91c1c,#dc2626)}.btn-generate-set .spinner{animation:spin 1s linear infinite}.btn-set-settings{display:flex;align-items:center;justify-content:center;padding:8px 10px;background:#10b98133;border:none;border-radius:0 6px 6px 0;color:#10b981;cursor:pointer;transition:all .2s}.btn-set-settings:hover{background:#10b9814d}.traversal-settings-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:260px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:10px;padding:16px;z-index:100;box-shadow:0 10px 40px #0006}.traversal-settings-dropdown h5{margin:0 0 12px;font-size:.8125rem;font-weight:600;color:var(--text-primary)}.traversal-setting{margin-bottom:14px}.traversal-setting:last-child{margin-bottom:0}.traversal-setting label{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;font-size:.75rem;color:var(--text-secondary)}.traversal-setting .setting-value{color:#10b981;font-weight:600;font-family:SF Mono,Monaco,monospace}.traversal-setting input[type=range]{width:100%;height:4px;background:#ffffff1a;border-radius:2px;-webkit-appearance:none;appearance:none}.traversal-setting input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;background:#10b981;border-radius:50%;cursor:pointer;transition:transform .15s}.traversal-setting input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.2)}.starting-song-setting{border-bottom:1px solid var(--border-color);padding-bottom:14px;margin-bottom:14px}.starting-song-setting label{margin-bottom:8px}.starting-song-display{display:flex;align-items:center;gap:8px;background:#10b9811a;border:1px solid rgba(16,185,129,.2);border-radius:8px;padding:8px 10px}.starting-song-info{display:flex;flex-direction:column;flex:1;min-width:0}.starting-song-info strong{font-size:.8125rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.starting-song-info .artist{font-size:.6875rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.clear-starting-song{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:#ffffff1a;border:none;color:var(--text-secondary);cursor:pointer;transition:all .15s;flex-shrink:0}.clear-starting-song:hover{background:#ef444433;color:#ef4444}.starting-song-placeholder{display:flex;align-items:center;gap:6px;min-height:36px}.starting-song-placeholder .hint{font-size:.75rem;color:var(--text-muted);font-style:italic}.set-starting-song-btn{background:#10b98126;border:1px solid rgba(16,185,129,.3);color:#10b981;font-size:.75rem;font-weight:500;padding:6px 12px;border-radius:6px;cursor:pointer;transition:all .15s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.set-starting-song-btn:hover{background:#10b98140;border-color:#10b98180}.traversal-setting .setting-hint{display:block;font-size:.6875rem;color:var(--text-muted);margin-top:6px}.set-position-badge{background:linear-gradient(135deg,#059669,#10b981);color:#fff;font-size:10px;font-weight:700;padding:2px 6px;border-radius:10px;white-space:nowrap;box-shadow:0 2px 8px #0006;pointer-events:none}.set-list-panel{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);margin-top:var(--spacing-lg);display:flex;flex-direction:column;overflow:hidden}.set-list-header{display:flex;justify-content:space-between;align-items:center;padding:12px 20px;background:linear-gradient(135deg,#10b9811a,#0596690d);border-bottom:1px solid rgba(16,185,129,.15);flex-shrink:0}.set-list-header h4{display:flex;align-items:center;gap:8px;margin:0;font-size:.9375rem;font-weight:600;color:#10b981}.set-list-header .close-panel{background:transparent;border:none;padding:6px;color:var(--text-tertiary);cursor:pointer;border-radius:6px;transition:all .15s}.set-list-header .close-panel:hover{background:#ffffff1a;color:var(--text-primary)}.set-list-stats{display:flex;align-items:center;gap:12px;padding:8px 20px;font-size:.8125rem;color:var(--text-secondary);background:#00000026;border-bottom:1px solid rgba(255,255,255,.05);flex-shrink:0}.set-list-stats .separator{color:var(--text-tertiary)}.set-warnings{padding:8px 20px;background:#f59e0b1a;border-bottom:1px solid rgba(245,158,11,.2);flex-shrink:0}.set-warnings .warning-header{display:flex;align-items:center;gap:6px;font-size:.8125rem;color:#f59e0b;font-weight:500}.set-list-songs{display:flex;overflow-x:auto;padding:12px 16px;gap:8px;scrollbar-width:thin;scrollbar-color:rgba(16,185,129,.3) transparent}.set-list-songs::-webkit-scrollbar{height:6px}.set-list-songs::-webkit-scrollbar-track{background:#ffffff0d;border-radius:3px}.set-list-songs::-webkit-scrollbar-thumb{background:#10b9814d;border-radius:3px}.set-list-songs::-webkit-scrollbar-thumb:hover{background:#10b98180}.set-song-item{display:flex;flex-direction:column;min-width:140px;max-width:160px;padding:12px;background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:10px;cursor:pointer;transition:all .15s;position:relative;flex-shrink:0}.set-song-item:hover{background:#ffffff0f;border-color:#10b9814d;transform:translateY(-2px)}.set-song-item .song-position{position:absolute;top:-8px;left:-8px;display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:linear-gradient(135deg,#059669,#10b981);border-radius:50%;font-size:.75rem;font-weight:700;color:#fff;box-shadow:0 2px 8px #0000004d}.set-song-item .song-info{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}.set-song-item .song-title{font-size:.8125rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}.set-song-item .song-artist{font-size:.6875rem;color:var(--text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.set-song-item .song-meta{display:flex;justify-content:space-between;align-items:center;padding-top:8px;border-top:1px solid rgba(255,255,255,.08)}.set-song-item .song-bpm{font-size:.8125rem;font-weight:700;color:var(--text-secondary);font-family:SF Mono,Monaco,monospace}.set-song-item .song-key{font-size:.75rem;color:#60a5fa;font-weight:600;background:#60a5fa1a;padding:2px 6px;border-radius:4px}.set-song-item .transition-info{position:absolute;top:50%;right:-20px;transform:translateY(-50%);display:flex;flex-direction:column;align-items:center;gap:2px;z-index:1}.set-song-item .bpm-diff{font-size:.625rem;font-family:SF Mono,Monaco,monospace;color:#10b981;background:var(--bg-secondary);padding:1px 4px;border-radius:3px}.set-song-item .bpm-diff.warning{color:#f59e0b}.set-song-item .key-warning{color:#ef4444;background:#ef44441a;padding:2px;border-radius:3px}.set-song-item .chevron{display:none}.set-song-item:not(:last-child):after{content:"";position:absolute;right:-12px;top:50%;transform:translateY(-50%);width:0;height:0;border-top:6px solid transparent;border-bottom:6px solid transparent;border-left:8px solid rgba(16,185,129,.4)}@media(max-width:768px){.set-list-panel{border-top:1px solid var(--border-color)}.set-list-songs{padding:10px 12px;gap:6px}.set-song-item{min-width:120px;max-width:140px;padding:10px}.set-song-item .song-position{width:20px;height:20px;font-size:.6875rem;top:-6px;left:-6px}.generate-set-container{flex-shrink:0}.btn-generate-set span{display:none}.traversal-settings-dropdown{width:240px;right:-40px}}.page.identity{padding:var(--spacing-xl);max-width:1400px;margin:0 auto}.identity-loading,.identity-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:var(--spacing-lg);color:var(--color-text-secondary)}.identity-error h2{color:var(--color-text-primary)}.identity-header{margin-bottom:var(--spacing-xl);text-align:center}.identity-title h1{font-size:2.5rem;font-weight:700;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--spacing-xs)}.identity-subtitle{color:var(--color-text-secondary);font-size:1.1rem}.identity-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.identity-stats .stat-card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);display:flex;align-items:center;gap:var(--spacing-md);transition:border-color var(--transition-base)}.identity-stats .stat-card:hover{border-color:var(--color-primary)}.identity-stats .stat-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.identity-stats .stat-content{display:flex;flex-direction:column}.identity-stats .stat-value{font-size:1.5rem;font-weight:700;color:var(--color-text-primary);line-height:1.2}.identity-stats .stat-label{font-size:.875rem;color:var(--color-text-secondary)}.identity-section{margin-bottom:var(--spacing-xl)}.identity-section h2{font-size:1.25rem;font-weight:600;margin-bottom:var(--spacing-lg);color:var(--color-text-primary)}.suited-section{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.identity-visualizations{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.viz-card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.viz-card h3{font-size:1rem;font-weight:600;margin-bottom:var(--spacing-md);color:var(--color-text-primary)}.genre-universe{position:relative}.genre-view-toggle{display:flex;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.genre-view-toggle .toggle-btn{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-xs) var(--spacing-md);color:var(--color-text-secondary);cursor:pointer;font-size:.8125rem;transition:all var(--transition-fast)}.genre-view-toggle .toggle-btn:hover{border-color:var(--color-primary);color:var(--color-text-primary)}.genre-view-toggle .toggle-btn.active{background:var(--color-primary-subtle);border-color:var(--color-primary);color:var(--color-primary)}.genre-bubbles-svg{display:block;width:100%;max-width:100%}.genre-tooltip{position:absolute;bottom:var(--spacing-md);left:50%;transform:translate(-50%);background:#000000e6;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);display:flex;flex-direction:column;align-items:center;gap:2px;pointer-events:none;z-index:10}.genre-tooltip .tooltip-name{font-weight:600;color:var(--color-text-primary)}.genre-tooltip .tooltip-count,.genre-tooltip .tooltip-percent{font-size:.8125rem;color:var(--color-text-secondary)}.genre-list-view{display:flex;flex-direction:column;gap:var(--spacing-sm);max-height:350px;overflow-y:auto}.genre-list-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);border-radius:var(--radius-sm);transition:background-color var(--transition-fast)}.genre-list-item:hover{background:var(--color-bg-hover)}.genre-list-item .genre-rank{font-size:.75rem;color:var(--color-text-tertiary);width:28px}.genre-list-item .genre-color-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.genre-list-item .genre-name{flex:1;font-weight:500;color:var(--color-text-primary);font-size:.875rem}.genre-list-item .genre-bar-container{width:100px;height:6px;background:var(--color-bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.genre-list-item .genre-bar-fill{height:100%;border-radius:var(--radius-full);transition:width var(--transition-base)}.genre-list-item .genre-stats{font-size:.75rem;color:var(--color-text-secondary);text-align:right;min-width:90px}.bpm-histogram{position:relative}.bpm-stats-row{display:flex;flex-wrap:wrap;gap:var(--spacing-lg);margin-bottom:var(--spacing-lg);justify-content:center}.bpm-stat{display:flex;flex-direction:column;align-items:center;gap:2px}.bpm-stat-label{font-size:.75rem;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em}.bpm-stat-value{font-size:1.25rem;font-weight:700;color:var(--color-text-primary);font-variant-numeric:tabular-nums}.bpm-stat-value.highlight-green{color:#22c55e}.bpm-stat-value.highlight-orange{color:#f59e0b}.bpm-chart-container{display:flex;justify-content:center}.bpm-chart-container canvas{max-width:100%;height:auto}.bpm-tooltip{background:#000000e6;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);display:flex;flex-direction:column;gap:2px;pointer-events:none;z-index:1000;box-shadow:var(--shadow-lg)}.bpm-tooltip .tooltip-range{font-weight:600;color:var(--color-text-primary)}.bpm-tooltip .tooltip-count,.bpm-tooltip .tooltip-percent{font-size:.8125rem;color:var(--color-text-secondary)}.bpm-section .bpm-card{max-width:100%}.suited-badges{display:flex;flex-direction:column;gap:var(--spacing-lg)}.suited-badges.empty{text-align:center;color:var(--color-text-secondary);padding:var(--spacing-lg)}.badge-category{display:flex;flex-direction:column;gap:var(--spacing-sm)}.badge-category .category-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-tertiary)}.badge-group{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.suited-badge{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-full);border:1px solid;transition:transform var(--transition-fast)}.suited-badge:hover{transform:scale(1.05)}.suited-badge .badge-label{font-weight:600;font-size:.875rem}.suited-badge .badge-score{font-size:.6875rem;font-weight:600;color:#fff;padding:2px 6px;border-radius:var(--radius-full);min-width:36px;text-align:center}.mood-card{display:flex;flex-direction:column;align-items:center}.mood-card h3{align-self:flex-start}@media(max-width:900px){.identity-visualizations{grid-template-columns:1fr}.identity-title h1{font-size:2rem}}@media(max-width:600px){.page.identity{padding:var(--spacing-md)}.identity-stats{grid-template-columns:repeat(2,1fr)}.identity-title h1{font-size:1.75rem}.bpm-stats-row{gap:var(--spacing-md)}.bpm-stat-value{font-size:1rem}}.hidden{display:none!important}.performance-panel{position:absolute;top:20px;right:20px;width:320px;background:#0a0a0ff2;backdrop-filter:blur(20px);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-md);z-index:100;max-height:calc(100% - 40px);overflow-y:auto;box-shadow:0 8px 32px #00000080}.umap-container.fullscreen .performance-panel{top:70px;right:20px;max-height:calc(100vh - 100px)}.performance-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)}.performance-header h4{display:flex;align-items:center;gap:var(--spacing-sm);font-size:1rem;font-weight:600;color:var(--color-text-primary);margin:0}.performance-header .pulse-icon{color:#f0f;animation:pulse-glow 2s ease-in-out infinite}@keyframes pulse-glow{0%,to{opacity:1;filter:drop-shadow(0 0 2px #ff00ff)}50%{opacity:.7;filter:drop-shadow(0 0 8px #ff00ff)}}.btn-end-performance{display:flex;align-items:center;gap:6px;padding:6px 12px;background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);color:#ef4444;font-size:.8125rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.btn-end-performance:hover{background:#ef444440;border-color:#ef4444}.performance-progress{margin-bottom:var(--spacing-md)}.progress-bar{height:6px;background:var(--color-bg-tertiary);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--spacing-xs)}.progress-fill{height:100%;background:linear-gradient(90deg,#8b5cf6,#0f8);border-radius:var(--radius-full);transition:width .3s ease}.progress-text{display:flex;justify-content:space-between;font-size:.75rem;color:var(--color-text-tertiary)}.embedding-type-selector{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-sm);background:#ffffff08;border-radius:var(--radius-md);margin-bottom:var(--spacing-md)}.embedding-type-selector .selector-label{font-size:.75rem;color:var(--color-text-tertiary);white-space:nowrap}.embedding-buttons{display:flex;gap:4px;flex:1}.embedding-btn{flex:1;padding:6px 10px;border:none;border-radius:var(--radius-sm);background:#ffffff0f;color:var(--color-text-secondary);cursor:pointer;font-size:.75rem;font-weight:500;transition:all var(--transition-fast)}.embedding-btn:hover:not(:disabled){background:#ffffff1a;color:var(--color-text-primary)}.embedding-btn.active{background:linear-gradient(135deg,#0f83,#8b5cf633);color:#0f8;border:1px solid rgba(0,255,136,.3)}.embedding-btn:disabled{opacity:.5;cursor:not-allowed}.embedding-type-selector .loading-indicator{display:flex;align-items:center;color:var(--color-text-tertiary)}.embedding-type-selector .loading-indicator .spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.journey-complete{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl) var(--spacing-md);text-align:center}.journey-complete svg{color:#0f8;margin-bottom:var(--spacing-md);animation:success-bounce .6s ease}@keyframes success-bounce{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.journey-complete h3{font-size:1.25rem;font-weight:700;color:var(--color-text-primary);margin-bottom:var(--spacing-xs);background:linear-gradient(135deg,#0f8,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.journey-complete p{color:var(--color-text-secondary);font-size:.875rem}.section-label{display:flex;align-items:center;gap:6px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-tertiary);margin-bottom:var(--spacing-sm)}.now-playing-section{margin-bottom:var(--spacing-md)}.now-playing-card{background:#ff00ff1a;border:1px solid rgba(255,0,255,.3);border-radius:var(--radius-md);padding:var(--spacing-md)}.now-playing-card .song-info{display:flex;flex-direction:column;margin-bottom:var(--spacing-sm)}.now-playing-card .song-title{font-weight:600;color:var(--color-text-primary);font-size:.9375rem}.now-playing-card .song-artist{font-size:.8125rem;color:var(--color-text-secondary)}.now-playing-card .song-meta{display:flex;gap:var(--spacing-md);font-size:.8125rem}.now-playing-card .song-bpm{color:var(--color-primary);font-weight:500}.now-playing-card .song-key{color:var(--color-secondary);font-weight:500}.toggle-moods-btn{display:flex;align-items:center;gap:var(--spacing-xs);margin-top:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);font-size:.75rem;cursor:pointer;transition:all var(--transition-fast)}.toggle-moods-btn:hover{background:var(--color-bg-tertiary);color:var(--color-text-primary)}.toggle-moods-btn svg{transition:transform var(--transition-fast)}.toggle-moods-btn svg.expanded{transform:rotate(180deg)}.now-playing-moods{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid rgba(255,0,255,.2);display:flex;flex-direction:column;gap:var(--spacing-xs)}.mood-bar-row{display:grid;grid-template-columns:80px 1fr 40px;align-items:center;gap:var(--spacing-sm)}.mood-label{font-size:.6875rem;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.mood-bar-track{height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden}.mood-bar-value{height:100%;border-radius:3px;transition:width var(--transition-normal)}.mood-percent{font-size:.6875rem;color:var(--color-text-primary);font-weight:500;text-align:right;font-variant-numeric:tabular-nums}.suggestions-section{margin-bottom:var(--spacing-md)}.suggestions-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.suggestion-card{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-left:3px solid;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-align:left;width:100%}.suggestion-card:hover{background:var(--color-bg-hover);transform:translate(4px)}.suggestion-rank{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:#000;flex-shrink:0}.suggestion-info{flex:1;min-width:0;display:flex;flex-direction:column}.suggestion-title-row{display:flex;align-items:center;gap:var(--spacing-sm)}.suggestion-title{font-weight:500;font-size:.8125rem;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.similarity-score{flex-shrink:0;font-size:.6875rem;font-weight:600;color:#0f8;padding:2px 6px;background:#00ff881a;border-radius:var(--radius-sm);font-variant-numeric:tabular-nums}.suggestion-artist{font-size:.75rem;color:var(--color-text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.suggestion-meta{display:flex;flex-direction:column;align-items:flex-end;font-size:.75rem;gap:2px}.suggestion-bpm{color:var(--color-text-secondary);font-variant-numeric:tabular-nums}.suggestion-key{color:var(--color-text-tertiary)}.suggestion-mood-changes{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.mood-change{display:inline-flex;align-items:center;gap:2px;padding:1px 5px;border-radius:var(--radius-sm);font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.02em}.mood-change.increase{background:#10b98126;color:#10b981;border:1px solid rgba(16,185,129,.3)}.mood-change.decrease{background:#ef444426;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.mood-change.increase{background:color-mix(in srgb,var(--mood-color) 15%,transparent);color:var(--mood-color);border-color:color-mix(in srgb,var(--mood-color) 40%,transparent)}.mood-change.decrease{background:#64646426;color:var(--color-text-secondary);border-color:#6464644d}.load-more-suggestions{display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);margin-top:var(--spacing-xs);background:linear-gradient(135deg,#8b5cf626,#06b6d426);border:1px dashed rgba(139,92,246,.4);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:.8125rem;cursor:pointer;transition:all var(--transition-fast);width:100%}.load-more-suggestions:hover{background:linear-gradient(135deg,#8b5cf640,#06b6d440);border-color:#8b5cf699;color:var(--color-text-primary);transform:translateY(-1px)}.load-more-suggestions:active{transform:translateY(0)}.load-more-suggestions svg{color:#8b5cf6}.waiting-for-selection{text-align:center;padding:var(--spacing-lg);color:var(--color-text-secondary);font-size:.875rem}.past-songs-section{margin-top:var(--spacing-md);border-top:1px solid var(--color-border);padding-top:var(--spacing-md)}.past-songs-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--spacing-sm) var(--spacing-sm);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);color:var(--color-text-secondary)}.past-songs-toggle:hover{background:var(--color-bg-hover);color:var(--color-text-primary);border-color:var(--color-border-light)}.past-songs-toggle .toggle-label{display:flex;align-items:center;gap:6px;font-size:.8125rem;font-weight:500}.past-songs-toggle .toggle-chevron{transition:transform var(--transition-fast)}.past-songs-toggle .toggle-chevron.expanded{transform:rotate(180deg)}.past-songs-list{margin-top:var(--spacing-sm);display:flex;flex-direction:column;gap:4px;max-height:200px;overflow-y:auto;padding-right:4px}.past-songs-list::-webkit-scrollbar{width:4px}.past-songs-list::-webkit-scrollbar-track{background:var(--color-bg-tertiary);border-radius:2px}.past-songs-list::-webkit-scrollbar-thumb{background:var(--color-border-light);border-radius:2px}.past-songs-list::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}.past-song-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:6px var(--spacing-sm);background:var(--color-bg-secondary);border-radius:var(--radius-sm);opacity:.7;transition:opacity var(--transition-fast)}.past-song-item:hover{opacity:1}.past-song-number{width:20px;height:20px;border-radius:50%;background:var(--color-bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:.6875rem;font-weight:600;color:var(--color-text-tertiary);flex-shrink:0}.past-song-info{flex:1;min-width:0;display:flex;flex-direction:column}.past-song-title{font-size:.75rem;font-weight:500;color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.past-song-artist{font-size:.6875rem;color:var(--color-text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.past-song-meta{display:flex;flex-direction:column;align-items:flex-end;font-size:.6875rem;color:var(--color-text-tertiary);gap:1px}.now-playing-badge{background:#f5f0e6e6;color:#1a1a1a;padding:3px 6px;border-radius:var(--radius-sm);font-size:.75rem;font-weight:500;box-shadow:0 2px 8px #0000004d;animation:badge-breathe 2s ease-in-out infinite}@keyframes badge-breathe{0%,to{opacity:.85}50%{opacity:1}}.suggestion-rank-badge{width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.625rem;font-weight:600;color:#fff;background:#646464b3;backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.2)}.btn-start-performance{display:flex;align-items:center;gap:8px;padding:8px 16px;background:linear-gradient(135deg,#8b5cf6,#f0f);border:none;border-radius:var(--radius-md);color:#fff;font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.btn-start-performance:hover{transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf666}.btn-start-performance:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.btn-start-performance.active{background:#f0f3;border:1px solid rgba(255,0,255,.5)}.performance-mode-indicator{display:flex;align-items:center;gap:6px;padding:4px 10px;background:#ff00ff26;border:1px solid rgba(255,0,255,.3);border-radius:var(--radius-full);font-size:.75rem;font-weight:600;color:#f0f}.performance-mode-indicator .live-dot{width:6px;height:6px;border-radius:50%;background:#f0f;animation:live-pulse 1s ease-in-out infinite}@keyframes live-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.btn-beat-grid{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);margin-left:var(--spacing-sm)}.btn-beat-grid:hover{background:var(--color-bg-hover);color:var(--color-text-primary);border-color:var(--color-border-light)}.btn-beat-grid.active{background:var(--color-primary-subtle);color:var(--color-primary);border-color:var(--color-primary)}.beat-grid-section{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border);animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.beat-grid-verifier{display:flex;flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);background:transparent}.beat-grid-controls{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--spacing-md)}.beat-grid-zoom-buttons{display:flex;align-items:center;gap:var(--spacing-sm)}.beat-grid-zoom-buttons .zoom-label{font-size:.8125rem;color:var(--color-text-secondary);margin-right:var(--spacing-xs)}.beat-grid-zoom-buttons .zoom-btn{padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);min-width:36px;text-align:center}.beat-grid-zoom-buttons .zoom-btn:hover{background:var(--color-bg-hover);color:var(--color-text-primary);border-color:var(--color-border-light)}.beat-grid-zoom-buttons .zoom-btn.active{background:var(--color-primary-subtle);color:var(--color-primary);border-color:var(--color-primary)}.beat-grid-nav-buttons{display:flex;gap:var(--spacing-sm)}.beat-grid-nav-buttons .nav-btn{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);font-size:.75rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.beat-grid-nav-buttons .nav-btn:hover:not(:disabled){background:var(--color-bg-hover);color:var(--color-text-primary);border-color:var(--color-border-light)}.beat-grid-nav-buttons .nav-btn:disabled{opacity:.4;cursor:not-allowed}.beat-grid-canvas-container{width:100%;border-radius:var(--radius-md);overflow:hidden}.beat-grid-canvas-container canvas{display:block;width:100%}.beat-grid-playback{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) 0}.beat-grid-playback .playback-left{display:flex;align-items:center;gap:var(--spacing-md)}.beat-grid-playback .btn-icon{background:var(--color-bg-elevated);border:1px solid var(--color-border);color:var(--color-text-secondary);padding:var(--spacing-sm);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.beat-grid-playback .btn-icon:hover{background:var(--color-bg-hover);color:var(--color-text-primary);border-color:var(--color-border-light)}.beat-grid-playback .btn-icon.circle{border-radius:var(--radius-full);width:36px;height:36px}.beat-grid-playback .btn-icon.circle.primary{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.beat-grid-playback .btn-icon.circle.primary:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover)}.beat-grid-playback .btn-icon.active{background:var(--color-primary-subtle);color:var(--color-primary);border-color:var(--color-primary)}.beat-grid-playback .time-range{font-size:.8125rem;color:var(--color-text-secondary);font-family:var(--font-mono)}.beat-grid-playback .bpm-display{font-size:.8125rem;color:var(--color-text-tertiary);font-family:var(--font-mono)}.beat-grid-overview{position:relative;height:24px;background:var(--color-bg-elevated);border-radius:var(--radius-sm);border:1px solid var(--color-border);cursor:pointer;overflow:hidden}.beat-grid-overview:hover{border-color:var(--color-border-light)}.beat-grid-overview-viewport{position:absolute;top:0;height:100%;background:#8b5cf64d;border-left:2px solid var(--color-primary);border-right:2px solid var(--color-primary);pointer-events:none;min-width:4px}.beat-grid-legend{display:flex;gap:var(--spacing-lg);justify-content:center;padding-top:var(--spacing-sm);border-top:1px solid var(--color-border)}.beat-grid-legend .legend-item{display:flex;align-items:center;gap:var(--spacing-sm);font-size:.75rem;color:var(--color-text-tertiary)}.beat-grid-legend .legend-line{display:inline-block;width:16px;height:3px;border-radius:1px}.beat-grid-legend .legend-line.downbeat{background:#f43f5e;height:4px}.beat-grid-legend .legend-line.beat{background:#06b6d4}.beat-grid-legend .legend-line.extrapolated{background:repeating-linear-gradient(90deg,#4b5563 0px,#4b5563 3px,transparent 3px,transparent 6px)}.nav-badge{margin-left:auto;font-size:.6875rem;font-weight:600;line-height:1;padding:2px 6px;border-radius:var(--radius-full);background:var(--color-primary-subtle);color:var(--color-primary)}.acquire .page-header h1{display:flex;align-items:center;gap:var(--spacing-sm)}.acquire .header-icon{color:var(--color-primary)}.acquire .songs-header,.acquire .song-row{grid-template-columns:2fr 110px 1fr 110px}.acquire .song-row{cursor:default}.acquire .col-checkbox{display:inline-flex;align-items:center;flex-shrink:0}.acquire .col-checkbox input[type=checkbox]{appearance:none;-webkit-appearance:none;width:14px;height:14px;min-width:14px;min-height:14px;max-width:14px;max-height:14px;border:1.5px solid var(--color-border-light);border-radius:3px;background:transparent;cursor:pointer;transition:all var(--transition-fast);position:relative;margin:0;padding:0}.acquire .col-checkbox input[type=checkbox]:hover{border-color:var(--color-primary);background:var(--color-primary-subtle)}.acquire .col-checkbox input[type=checkbox]:checked{background:var(--color-primary);border-color:var(--color-primary)}.acquire .col-checkbox input[type=checkbox]:checked:after{content:"";position:absolute;left:3.5px;top:.5px;width:4px;height:8px;border:solid white;border-width:0 1.5px 1.5px 0;transform:rotate(45deg)}.acquire .col-source{font-size:.875rem}.acquire .col-providers{display:flex;gap:4px;align-items:center;flex-wrap:wrap}.acquire-provider-link{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:var(--radius-sm);text-decoration:none;background:#ffffff0f;transition:all var(--transition-fast);opacity:.7}.acquire-provider-link:hover{background:#ffffff26;opacity:1}.acquire-provider-link img{width:16px;height:16px;object-fit:contain}.acquire-provider-link{position:relative}.acquire-provider-link.provider-has-listing{opacity:1;background:#10b98126;border:1px solid rgba(16,185,129,.3)}.acquire-provider-link.provider-unavailable{opacity:.25;pointer-events:none;filter:grayscale(1)}.provider-price-badge{position:absolute;bottom:-6px;right:-6px;font-size:.5625rem;font-weight:600;line-height:1;padding:1px 3px;border-radius:3px;background:var(--color-success);color:#fff;white-space:nowrap;pointer-events:none}.provider-loading-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#0a0a0f99;border-radius:var(--radius-sm)}.provider-loading-overlay .spinner{width:10px;height:10px}.acquire-check-prices-btn{color:var(--color-success)!important}.acquire-provider-btn-icon{width:14px;height:14px;object-fit:contain}.acquire-bulk-bar{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-primary-subtle);border:1px solid var(--color-primary);border-radius:var(--radius-md);margin-bottom:var(--spacing-sm);font-size:.875rem;font-weight:500;color:var(--color-primary);flex-wrap:wrap}.acquire-bulk-actions{display:flex;align-items:center;gap:6px}.acquire-provider-btn{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-full);border:1px solid currentColor;background:transparent;font-size:.75rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;opacity:.85}.acquire-provider-btn:hover{opacity:1;background:#ffffff0f}.acquire-bulk-warning{display:flex;align-items:center;gap:4px;color:var(--color-warning);font-size:.8125rem;font-weight:400}.acquire-filters{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) 0}.acquire-search{display:flex;align-items:center;gap:var(--spacing-sm);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:0 var(--spacing-md);width:240px;min-width:0}.acquire-search svg{color:var(--color-text-tertiary);flex-shrink:0}.acquire-search input{background:none;border:none;padding:var(--spacing-sm) 0;flex:1;font-size:.875rem;color:var(--color-text-primary);min-width:0}.acquire-search input::placeholder{color:var(--color-text-tertiary)}.acquire-search input:focus{outline:none;box-shadow:none}.acquire-filter-divider{width:1px;height:20px;background:var(--color-border);flex-shrink:0}.acquire-filter-pill{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border-radius:var(--radius-full);border:1px solid var(--color-border);background:transparent;color:var(--color-text-secondary);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.acquire-filter-pill:hover{border-color:var(--color-border-light);background:var(--color-bg-hover)}.acquire-filter-pill.active{background:var(--color-primary-subtle);border-color:var(--color-primary);color:var(--color-primary)}.acquire-filter-pill .pill-count{font-size:.6875rem;opacity:.7}.acquire-status-select{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:6px 28px 6px 12px;color:var(--color-text-secondary);font-size:.8125rem;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236a6a7a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;width:auto;max-width:220px}.acquire-status-select:focus{outline:none;border-color:var(--color-primary)}.acquire-clear-filters{display:inline-flex;align-items:center;gap:4px;padding:5px 10px;border-radius:var(--radius-full);border:none;background:transparent;color:var(--color-text-tertiary);font-size:.8125rem;cursor:pointer;transition:color var(--transition-fast);white-space:nowrap}.acquire-clear-filters:hover{color:var(--color-text-primary)}.acquire-filter-summary{color:var(--color-text-secondary);font-size:.875rem;padding:var(--spacing-xs) 0}.source-pill{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:var(--radius-full);font-size:.75rem;font-weight:500;white-space:nowrap}.acquire-upload-btn{color:var(--color-text-tertiary)}.acquire-upload-btn:hover{color:var(--color-primary);background:var(--color-primary-subtle)}.acquire-upload-progress{width:32px;height:4px;background:var(--color-bg-tertiary);border-radius:2px;overflow:hidden}.acquire-upload-progress-bar{height:100%;background:var(--color-primary);border-radius:2px;transition:width .15s ease}.acquire-upload-error{color:var(--color-error)}.acquire-upload-error:hover{background:#ef44441a;color:var(--color-error)}.acquire-uploaded-check{color:#22c55e;cursor:default}.acquire-bulk-divider{width:1px;height:16px;background:var(--color-border);margin:0 var(--spacing-xs)}.acquire-delete-btn{color:var(--color-error)!important}.acquire-delete-btn:hover{background:#ef44441a}@media(max-width:768px){.acquire .songs-header{display:none}.acquire .song-row{grid-template-columns:1fr auto}.acquire .col-source,.acquire .col-providers{display:none}.acquire-bulk-actions,.acquire-filters{flex-wrap:wrap}.acquire-search{width:100%;flex-shrink:0}.acquire-filter-divider{display:none}}.bulk-upload-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-2xl) var(--spacing-lg);border:2px dashed var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);text-align:center;color:var(--color-text-secondary);font-size:.875rem}.bulk-upload-dropzone:hover{border-color:var(--color-primary);background:var(--color-primary-subtle)}.bulk-upload-dropzone.drag-over{border-color:var(--color-primary);background:var(--color-primary-subtle);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb, 99, 102, 241),.15)}.bulk-upload-file-list{display:flex;flex-direction:column;gap:2px;max-height:320px;overflow-y:auto}.bulk-upload-file-row{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-sm);background:var(--color-bg-tertiary);min-height:40px}.bulk-upload-file-row.has-error{background:#ef44440f}.bulk-upload-file-row.matched{background:#22c55e0f}.bulk-upload-file-row.skipped{opacity:.5}.bulk-upload-file-info{display:flex;align-items:center;gap:var(--spacing-sm);min-width:0;flex:1}.bulk-upload-file-name{font-size:.8125rem;font-weight:500;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bulk-upload-file-size{font-size:.75rem;color:var(--color-text-tertiary)}.bulk-upload-file-error{font-size:.75rem;color:var(--color-error)}.bulk-upload-match-target{font-size:.75rem;color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bulk-upload-section-header{display:flex;align-items:center;gap:6px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);padding:var(--spacing-sm) 0 var(--spacing-xs) 0;margin-top:var(--spacing-sm)}.bulk-upload-section-header:first-child{margin-top:0}.bulk-upload-candidates{display:flex;flex-direction:column;gap:4px;margin-top:var(--spacing-xs);padding-left:24px}.bulk-upload-candidate-row{display:flex;align-items:center;gap:var(--spacing-sm);font-size:.8125rem}.bulk-upload-confidence{display:inline-block;padding:1px 8px;border-radius:var(--radius-full);font-size:.6875rem;font-weight:600;white-space:nowrap}.bulk-upload-confidence.green{background:#22c55e26;color:#22c55e}.bulk-upload-confidence.emerald{background:#10b98126;color:#10b981}.bulk-upload-confidence.yellow{background:#eab30826;color:#eab308}.bulk-upload-confidence.orange{background:#f9731626;color:#f97316}.bulk-upload-confidence.red{background:#ef444426;color:#ef4444}.bulk-upload-progress{width:60px;height:4px;background:var(--color-bg-tertiary);border-radius:2px;overflow:hidden;flex-shrink:0}.bulk-upload-progress-bar{height:100%;background:var(--color-primary);border-radius:2px;transition:width .15s ease}.bulk-upload-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.bulk-upload-summary{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);padding:var(--spacing-xl);text-align:center}.bulk-upload-summary h3{font-size:1.125rem;margin:0}.bulk-upload-summary-stats{display:flex;gap:var(--spacing-lg);justify-content:center}.bulk-upload-stat{display:flex;flex-direction:column;align-items:center;gap:2px}.bulk-upload-stat-value{font-size:1.5rem;font-weight:700;color:var(--color-text-primary)}.bulk-upload-stat.error .bulk-upload-stat-value{color:var(--color-error)}.bulk-upload-stat-label{font-size:.75rem;color:var(--color-text-secondary)}.btn-xs{padding:2px 8px;font-size:.6875rem;border-radius:var(--radius-sm)}.custom-tag-pill{display:inline-flex;align-items:center;gap:3px;font-size:.65rem;padding:2px 6px;border-radius:3px;white-space:nowrap;font-weight:500}.filter-panel{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:12px 16px;margin-bottom:8px}.filter-panel-row{display:flex;align-items:flex-end;gap:20px;flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:4px}.filter-label{font-size:.75rem;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em;font-weight:500}.filter-range-inputs{display:flex;align-items:center;gap:6px}.filter-number-input{width:68px;padding:5px 8px;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:.875rem;-moz-appearance:textfield}.filter-number-input::-webkit-inner-spin-button,.filter-number-input::-webkit-outer-spin-button{-webkit-appearance:none}.filter-number-input:focus{outline:none;border-color:var(--color-primary)}.filter-range-sep{color:var(--color-text-tertiary);font-size:.875rem}.filter-select{padding:5px 8px;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:.875rem;min-width:130px;cursor:pointer}.filter-select:focus{outline:none;border-color:var(--color-primary)}.filter-date-presets{display:flex;gap:4px}.filter-date-preset{padding:4px 10px;font-size:.8rem;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.filter-date-preset:hover{border-color:var(--color-primary);color:var(--color-text-primary)}.filter-date-preset.active{background:var(--color-primary-subtle);border-color:var(--color-primary);color:var(--color-primary)}.filter-date-custom{position:relative;cursor:pointer}.filter-date-custom-input{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}.filter-clear-btn{padding:5px 10px;font-size:.8125rem;display:flex;align-items:center;gap:4px;color:var(--color-text-tertiary);align-self:flex-end}.filter-clear-btn:hover{color:var(--color-text-primary)}.tag-management-bar{display:flex;align-items:center;gap:8px;padding:8px 0;flex-wrap:wrap}.tag-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;background:var(--color-bg-tertiary);border:1px solid var(--color-border);cursor:pointer;font-size:.8125rem;color:var(--color-text-secondary);transition:border-color var(--transition-fast),background var(--transition-fast)}.tag-chip:hover{border-color:var(--color-border-light);background:var(--color-bg-hover)}.tag-chip.active{border-color:var(--color-primary);background:var(--color-primary-subtle);color:var(--color-text-primary)}.tag-chip-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.tag-chip-count{font-size:.6875rem;color:var(--color-text-tertiary)}.tag-review-panel{position:fixed;top:0;right:0;width:400px;height:100vh;background:var(--color-bg-secondary);border-left:1px solid var(--color-border);box-shadow:-4px 0 24px #0006;z-index:200;display:flex;flex-direction:column;animation:slideInRight .2s ease-out}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.vibe-badge{font-size:.6875rem;padding:2px 6px;border-radius:10px;background:var(--color-primary);color:#fff;font-weight:600;white-space:nowrap}.vibe-count{font-size:.75rem;color:var(--color-text-tertiary);padding:4px var(--spacing-md) 0}.relevance-dot{display:inline-block;width:6px;height:6px;border-radius:50%;margin-right:6px;flex-shrink:0;vertical-align:middle}.song-row.vibe-dim{opacity:.35}.vibe-search-btn{color:var(--color-primary)}.set-new{max-width:1100px;margin:0 auto;padding:var(--spacing-2xl) var(--spacing-lg)}.set-new-header{text-align:center;margin-bottom:var(--spacing-2xl)}.set-new-badge{display:inline-flex;align-items:center;gap:var(--spacing-sm);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:999px;padding:6px 16px;font-size:.6875rem;letter-spacing:3px;text-transform:uppercase;color:var(--color-text-tertiary);margin-bottom:var(--spacing-lg)}.set-new-badge:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--color-primary);display:inline-block}.set-new-header h1{font-size:3rem;font-weight:600;letter-spacing:-1px;margin-bottom:var(--spacing-md)}.set-new-header p{color:var(--color-text-tertiary);font-size:1.125rem;max-width:560px;margin:0 auto;line-height:1.7}.set-new-quote{text-align:center;color:var(--color-text-tertiary);font-size:.8125rem;font-style:italic;margin-bottom:var(--spacing-2xl)}.shape-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:var(--spacing-md)}.shape-card{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-lg);text-align:left;cursor:pointer;transition:all var(--transition-slow);color:inherit}.shape-card:hover,.shape-card--hovered{background:var(--color-bg-hover);border-color:var(--color-border-light);box-shadow:0 0 40px #8b5cf60f;transform:scale(1.02)}.shape-card:disabled{opacity:.5;cursor:wait}.shape-card-preview{margin-bottom:var(--spacing-md);border-radius:var(--radius-md);background:#00000059;padding:var(--spacing-md)}.shape-card-preview svg{width:100%;height:80px}.shape-card-info{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.shape-card-icon{font-size:1.25rem}.shape-card-name{font-weight:500;font-size:1.0625rem}.shape-card-desc{color:var(--color-text-tertiary);font-size:.8125rem;line-height:1.6}.duration-picker{display:flex;justify-content:center;margin-top:var(--spacing-2xl)}.duration-picker>*{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-md) var(--spacing-lg);display:flex;align-items:center;gap:var(--spacing-lg)}.duration-picker-label{color:var(--color-text-tertiary);font-size:.8125rem}.duration-picker-options{display:flex;gap:var(--spacing-sm)}.duration-btn{padding:6px 16px;border-radius:var(--radius-md);font-size:.8125rem;cursor:pointer;transition:all var(--transition-base);border:1px solid transparent;background:transparent;color:var(--color-text-tertiary);font-family:var(--font-mono)}.duration-btn--active{border-color:#8b5cf64d;background:var(--color-primary-subtle);color:var(--color-primary)}.set-new-creating{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);margin-top:var(--spacing-lg);color:var(--color-text-secondary)}.set-card{display:flex;flex-direction:column;position:relative;overflow:hidden}.set-card-curve{padding:12px 16px 4px}.set-card-curve svg{width:100%;height:50px}.set-card-content{padding:8px 16px 16px}.set-card-title-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}.set-card-icon{font-size:1.125rem}.set-delete{position:absolute;top:8px;right:8px;opacity:0;transition:opacity var(--transition-fast)}.set-card:hover .set-delete{opacity:1}.set-canvas{max-width:1200px;margin:0 auto;padding:var(--spacing-lg) var(--spacing-md)}.set-canvas-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:80px 0;color:var(--color-text-secondary)}.set-canvas-topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-lg)}.set-canvas-topbar-left{display:flex;align-items:center;gap:var(--spacing-md)}.set-canvas-title{font-size:1.25rem;font-weight:500;cursor:pointer}.set-canvas-title:hover{color:var(--color-primary)}.set-name-input{background:var(--color-bg-tertiary);border:1px solid rgba(139,92,246,.3);border-radius:var(--radius-md);padding:var(--spacing-xs) var(--spacing-sm);color:var(--color-text-primary);font-size:1.25rem;font-weight:500;font-family:var(--font-sans);outline:none}.set-canvas-meta{color:var(--color-text-tertiary);font-size:.75rem;font-family:var(--font-mono)}.set-canvas-topbar-right{display:flex;align-items:center;gap:var(--spacing-md)}.set-canvas-progress-text{font-size:.75rem;color:var(--color-text-tertiary);font-family:var(--font-mono)}.text-cyan{color:var(--color-primary);font-weight:600}.set-canvas-progress-bar{width:120px;height:6px;background:var(--color-bg-hover);border-radius:var(--radius-full);overflow:hidden}.set-canvas-progress-fill{height:100%;background:var(--gradient-primary);border-radius:var(--radius-full);transition:width var(--transition-slow)}.set-canvas-curve-panel{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-lg);margin-bottom:var(--spacing-md)}.set-canvas-curve-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.set-canvas-curve-legends{display:flex;align-items:center;gap:var(--spacing-lg)}.curve-label{color:var(--color-text-tertiary);font-size:.625rem;letter-spacing:2px;text-transform:uppercase;font-family:var(--font-mono)}.curve-legend{display:inline-flex;align-items:center;gap:var(--spacing-xs);font-size:.6875rem;color:var(--color-text-tertiary)}.curve-legend-line{display:inline-block;width:20px;height:2px;border-radius:2px}.curve-legend-line--intended{background:#22d3ee}.curve-legend-line--actual{background-image:repeating-linear-gradient(90deg,#fbbf24 0,#fbbf24 4px,transparent 4px,transparent 8px)}.curve-hint{color:var(--color-text-tertiary);font-size:.6875rem}.set-canvas-curve-area{position:relative;user-select:none}.curve-y-labels{position:absolute;left:0;top:0;width:32px;display:flex;flex-direction:column;justify-content:space-between;font-size:.625rem;color:var(--color-text-tertiary);font-family:var(--font-mono)}.curve-svg-container{position:absolute;left:40px;right:0;top:0}.curve-svg-container svg{width:100%;height:100%}.set-canvas-slots{position:absolute;left:40px;right:0;bottom:0;display:flex}.slot-wrapper{display:flex;flex-direction:column;align-items:center;position:relative}.transition-dot{position:absolute;left:-2px;top:4px;width:7px;height:7px;border-radius:50%;z-index:1}.slot-box{width:88%;max-width:38px;height:36px;display:flex;align-items:center;justify-content:center;font-size:.6875rem;cursor:pointer;transition:all var(--transition-base);border-radius:var(--radius-md);background:var(--color-bg-secondary);border:1px dashed var(--color-border)}.slot-box:hover{background:var(--color-primary-subtle);border-color:#8b5cf64d}.slot-box--filled{background:var(--color-bg-tertiary);border:1px solid var(--color-border-light)}.slot-box--selected{background:var(--color-primary-subtle);border:1px solid rgba(139,92,246,.5);transform:scale(1.12)}.slot-filled{width:100%;height:100%;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;overflow:hidden}.slot-energy-bg{position:absolute;inset:0;opacity:.25}.slot-energy-val{position:relative;color:#ffffffd9;font-weight:600;font-size:.6875rem;font-family:var(--font-mono)}.slot-key-val{position:relative;color:#ffffffe6;font-weight:600;font-size:.6875rem;font-family:var(--font-mono)}.slot-remove{position:absolute;top:1px;right:1px;background:none;border:none;color:var(--color-text-tertiary);cursor:pointer;padding:2px;opacity:0;transition:opacity var(--transition-fast)}.slot-box:hover .slot-remove{opacity:1}.slot-remove:hover{color:var(--color-error)}.slot-target{color:var(--color-text-tertiary)}.slot-time{font-size:.625rem;color:var(--color-text-tertiary);margin-top:var(--spacing-xs);font-family:var(--font-mono)}.transition-legend{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-md);padding-left:var(--spacing-sm);font-size:.6875rem;color:var(--color-text-tertiary)}.transition-legend-item{display:flex;align-items:center;gap:5px}.transition-legend-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.vibe-fit-panel{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:var(--spacing-md);overflow:hidden}.vibe-fit-panel-toggle{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:10px 14px;background:none;border:none;color:var(--color-text-secondary);cursor:pointer;font-size:.75rem;font-family:var(--font-mono)}.vibe-fit-panel-toggle:hover{background:var(--color-bg-tertiary)}.vibe-fit-panel-title{font-weight:600;color:var(--color-text-primary)}.vibe-fit-panel-summary{color:var(--color-text-tertiary);font-size:.6875rem;margin-left:auto;margin-right:var(--spacing-xs)}.mixer-strip-rack{display:flex;gap:2px;padding:6px 10px 12px;background:linear-gradient(180deg,var(--color-bg-primary) 0%,var(--color-bg-secondary) 100%);border-top:1px solid var(--color-border)}.mixer-channel{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;min-width:0}.mixer-channel-label{font-size:.5625rem;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;color:var(--color-text-tertiary);font-family:var(--font-mono);white-space:nowrap}.mixer-channel-strip{display:flex;flex-direction:column;gap:3px;width:100%;padding:4px 6px;background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-sm)}.mixer-led{display:flex;align-items:center;gap:6px;padding:3px 4px;border:none;background:none;cursor:pointer;border-radius:2px;transition:background var(--transition-fast)}.mixer-led:hover{background:#ffffff0a}.mixer-led-bar{width:4px;height:10px;border-radius:1px;flex-shrink:0;transition:background var(--transition-fast),box-shadow var(--transition-fast)}.mixer-led-label{font-size:.5625rem;font-family:var(--font-mono);color:var(--color-text-tertiary);transition:color var(--transition-fast);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mixer-led--off .mixer-led-bar{background:var(--color-bg-hover)}.mixer-led--cool .mixer-led-bar{background:#22c55e;box-shadow:0 0 6px #22c55e80}.mixer-led--warm .mixer-led-bar{background:#f59e0b;box-shadow:0 0 6px #f59e0b66}.mixer-led--hot .mixer-led-bar{background:#ef4444;box-shadow:0 0 6px #ef444466}.mixer-led--active .mixer-led-label{color:var(--color-text-primary);font-weight:600}.mixer-led--cool .mixer-led-label,.mixer-led--warm .mixer-led-label,.mixer-led--hot .mixer-led-label{color:var(--color-text-secondary)}.mixer-led--spacer{visibility:hidden;pointer-events:none}.set-canvas-library{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-lg)}.set-canvas-library-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md)}.set-canvas-library-header-left{display:flex;align-items:center;gap:var(--spacing-md)}.library-count{color:var(--color-text-tertiary);font-size:.75rem;font-family:var(--font-mono)}.library-hint{color:var(--color-primary);font-size:.75rem}.genre-filter{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);outline:none;font-size:.8125rem;padding:6px 12px;font-family:var(--font-mono);flex-shrink:0;width:140px}.genre-filter option{background:var(--color-bg-secondary)}.set-library-controls{display:flex;align-items:center;gap:8px;flex:1;margin-left:16px}.set-vibe-search{display:flex;align-items:center;gap:6px;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);border-radius:8px;padding:4px 10px;flex:1}.set-vibe-search:focus-within{border-color:#a855f780}.set-vibe-input{background:transparent;border:none;outline:none;color:var(--color-text-secondary);font-size:.8125rem;font-family:var(--font-mono);flex:1;min-width:0}.set-vibe-input::placeholder{color:var(--color-text-tertiary)}.set-vibe-btn{background:none;border:none;color:var(--color-primary);cursor:pointer;padding:2px;display:flex;align-items:center}.set-vibe-btn:hover{color:#c084fc}.set-vibe-btn:disabled{color:var(--color-text-tertiary);cursor:default}.set-vibe-badge{font-size:.5625rem;font-weight:700;text-transform:uppercase;color:var(--color-primary);letter-spacing:1px}.set-vibe-clear{background:none;border:none;color:var(--color-text-tertiary);cursor:pointer;padding:2px;display:flex;align-items:center}.set-vibe-clear:hover{color:var(--color-text-secondary)}.library-table-header{display:grid;grid-template-columns:28px 60px 2fr 1.5fr 50px 50px 1fr 50px;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-sm);font-size:.625rem;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:1.5px;border-bottom:1px solid var(--color-border);margin-bottom:var(--spacing-xs)}.library-table-body{max-height:360px;overflow-y:auto}.library-row{display:grid;grid-template-columns:28px 60px 2fr 1.5fr 50px 50px 1fr 50px;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-sm);border-radius:var(--radius-md);transition:background var(--transition-fast);align-items:center;border:1px solid transparent}.library-row--clickable{cursor:pointer}.library-row--clickable:hover{background:var(--color-bg-tertiary)}.lib-col{font-size:.8125rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lib-col--sortable{cursor:pointer;user-select:none;display:flex;align-items:center;gap:2px}.lib-col--sortable:hover{color:var(--color-text-secondary)}.lib-col--energy{display:flex;align-items:center;gap:4px}.lib-col--bpm,.lib-col--key,.lib-col--fit{text-align:center;font-family:var(--font-mono);font-size:.75rem}.lib-col--artist,.lib-col--genre{color:var(--color-text-tertiary)}.lib-col--genre{font-size:.6875rem;color:var(--color-text-tertiary)}.energy-bar-bg{flex:1;height:6px;background:var(--color-bg-tertiary);border-radius:3px;overflow:hidden}.energy-bar-fill{height:100%;border-radius:3px}.energy-val{font-size:.6875rem;color:var(--color-text-tertiary);width:22px;text-align:right;font-family:var(--font-mono)}.key-badge{background:var(--color-bg-tertiary);border-radius:var(--radius-sm);padding:2px 6px;font-size:.6875rem;color:var(--color-text-tertiary);font-family:var(--font-mono)}.fit-badge{font-size:.6875rem;font-weight:600;padding:2px 8px;border-radius:10px}.fit-badge--great{background:#22c55e26;color:#4ade80}.fit-badge--ok{background:#f59e0b26;color:#fbbf24}.fit-badge--poor{background:#ef44441a;color:#f87171}.fit-placeholder{color:var(--color-text-tertiary);font-size:.6875rem}.muq-affinity-badge{font-size:.5625rem;font-weight:600;letter-spacing:.02em;padding:1px 5px;border-radius:var(--radius-sm);background:var(--color-primary-subtle);color:var(--color-primary);margin-left:4px;vertical-align:middle;cursor:default}.set-canvas-summary{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);margin-top:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);display:flex;align-items:center;gap:var(--spacing-lg);font-size:.8125rem;color:var(--color-text-tertiary)}.lib-col--play{width:28px;min-width:28px;flex:0 0 28px;display:flex;align-items:center;justify-content:center}.lib-play-btn{background:none;border:none;color:var(--color-text-tertiary);cursor:pointer;padding:4px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:color .15s,background .15s}.lib-play-btn:hover{color:var(--color-text-primary);background:var(--color-primary-subtle)}.library-row--playing{background:var(--color-primary-subtle)!important}.library-row--playing .lib-play-btn{color:var(--color-primary)}.slot-play-btn{position:absolute;bottom:1px;left:1px;background:#00000080;border:none;color:#fffc;cursor:pointer;padding:2px;border-radius:3px;display:flex;align-items:center;justify-content:center;transition:color .15s,background .15s;z-index:2}.slot-play-btn:hover{color:var(--color-text-primary);background:var(--color-primary-hover)}.set-mini-player{position:fixed;bottom:0;left:0;right:0;height:72px;background:linear-gradient(to top,var(--color-bg-primary) 0%,var(--color-bg-secondary) 100%);border-top:1px solid var(--color-border);display:flex;align-items:center;padding:0 24px;gap:16px;z-index:1000}.set-mini-player-info{display:flex;align-items:center;gap:10px;min-width:180px}.set-mini-player-art{width:42px;height:42px;border-radius:4px;background:var(--color-bg-elevated);display:flex;align-items:center;justify-content:center;flex-shrink:0}.set-mini-player-text{overflow:hidden}.set-mini-player-title{font-weight:600;font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px}.set-mini-player-artist{font-size:.75rem;color:var(--color-text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px}.set-mini-player-controls{display:flex;align-items:center;gap:8px}.set-mini-player-btn{background:none;border:none;color:var(--color-text-tertiary);cursor:pointer;padding:6px;display:flex;align-items:center;justify-content:center;transition:color .15s}.set-mini-player-btn:hover{color:#fff}.set-mini-player-btn--play{background:var(--color-primary);border-radius:50%;width:36px;height:36px;color:#fff;padding:0}.set-mini-player-btn--play:hover{background:var(--color-primary-hover)}.set-mini-player-progress{flex:1;display:flex;align-items:center;gap:10px}.set-mini-player-time{font-size:.7rem;color:var(--color-text-tertiary);min-width:36px;text-align:center}.set-mini-player-bar{flex:1;height:4px;background:var(--color-bg-elevated);border-radius:2px;cursor:pointer;position:relative}.set-mini-player-bar-fill{position:absolute;left:0;top:0;height:100%;background:var(--color-primary);border-radius:2px;transition:width .1s linear}.set-mini-player-actions{display:flex;align-items:center;gap:10px}.btn-text{display:inline-flex;align-items:center;gap:4px;background:none;border:none;color:#fff3;cursor:pointer;font-size:.8125rem;font-family:var(--font-mono);padding:0}.btn-text:hover{color:var(--color-text-secondary)}.btn-export{display:inline-flex;align-items:center;gap:6px;background:#8b5cf626;border:1px solid rgba(139,92,246,.4);color:var(--color-primary);cursor:pointer;font-size:.75rem;font-weight:600;font-family:var(--font-mono);padding:6px 12px;border-radius:var(--radius-sm);letter-spacing:.03em;text-transform:uppercase;transition:background .15s,border-color .15s}.btn-export:hover{background:#8b5cf640;border-color:#8b5cf699}.path-choice-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-xl);max-width:1000px;margin:0 auto}.path-card{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-xl);text-align:left;cursor:pointer;transition:all var(--transition-slow);color:inherit;display:flex;flex-direction:column;gap:var(--spacing-sm)}.path-card:hover{background:var(--color-bg-hover);border-color:var(--color-border-light);box-shadow:0 0 40px #8b5cf60f;transform:translateY(-2px)}.path-card-icon{width:56px;height:56px;border-radius:14px;background:var(--color-primary-subtle);border:1px solid rgba(139,92,246,.15);display:flex;align-items:center;justify-content:center;color:var(--color-primary)}.path-card h3{font-size:1.25rem;font-weight:500}.path-card p{color:var(--color-text-tertiary);font-size:.875rem;line-height:1.6}.path-card-cta{display:inline-flex;align-items:center;gap:var(--spacing-xs);color:var(--color-primary);font-size:.8125rem;margin-top:var(--spacing-xs)}.set-new-back{position:absolute;top:0;left:0}.set-new-header{position:relative}.anchor-section{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-lg);margin-bottom:var(--spacing-md)}.anchor-section-title{font-size:1rem;font-weight:500;margin-bottom:var(--spacing-xs)}.anchor-section-desc{color:var(--color-text-tertiary);font-size:.8125rem;margin-bottom:var(--spacing-md)}.optional-tag{font-size:.6875rem;color:var(--color-text-tertiary);font-weight:400;margin-left:var(--spacing-xs)}.peak-count-options{display:flex;gap:var(--spacing-sm)}.peak-count-btn{flex:1;padding:var(--spacing-md);border-radius:var(--radius-lg);border:1px solid var(--color-border);background:var(--color-bg-secondary);cursor:pointer;transition:all var(--transition-base);color:inherit;text-align:center}.peak-count-btn:hover{background:var(--color-bg-hover);border-color:var(--color-border-light)}.peak-count-btn--active{border-color:#8b5cf666;background:var(--color-primary-subtle)}.peak-count-num{display:block;font-size:1.75rem;font-weight:600;color:var(--color-primary);margin-bottom:var(--spacing-xs)}.peak-count-label{font-size:.75rem;color:var(--color-text-tertiary)}.anchor-slots{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.anchor-pick-btn{padding:var(--spacing-sm) var(--spacing-xl);border-radius:var(--radius-lg);border:1px dashed rgba(139,92,246,.3);background:#8b5cf60a;color:var(--color-primary);cursor:pointer;font-size:.8125rem;transition:all var(--transition-base);font-family:var(--font-mono)}.anchor-pick-btn:hover{background:#8b5cf61a;border-color:#8b5cf680}.anchor-badge{display:flex;align-items:center;gap:var(--spacing-sm);padding:10px 14px;border-radius:var(--radius-lg);background:var(--color-bg-tertiary);border:1px solid var(--color-border)}.anchor-badge-energy{width:36px;height:36px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:.6875rem;font-weight:600;color:#fff}.anchor-badge-info{display:flex;flex-direction:column;gap:1px}.anchor-badge-label{font-size:.625rem;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:1px}.anchor-badge-title{font-size:.8125rem;font-weight:500}.anchor-badge-artist{font-size:.75rem;color:var(--color-text-tertiary)}.anchor-badge-remove{background:none;border:none;color:var(--color-text-tertiary);cursor:pointer;padding:var(--spacing-xs);margin-left:auto}.anchor-badge-remove:hover{color:var(--color-error)}.anchor-create-bar{display:flex;justify-content:center;margin-top:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.btn-lg{padding:var(--spacing-sm) var(--spacing-xl);font-size:.9375rem;gap:var(--spacing-sm)}.song-picker-overlay{position:fixed;inset:0;background:#000000b3;z-index:100;display:flex;align-items:center;justify-content:center}.song-picker{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:16px;width:560px;max-height:70vh;display:flex;flex-direction:column;overflow:hidden}.song-picker-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--color-border)}.song-picker-header h3{font-size:1rem;font-weight:500}.song-picker-search{display:flex;align-items:center;gap:8px;padding:10px 20px;border-bottom:1px solid var(--color-border);color:var(--color-text-tertiary)}.song-picker-search input{flex:1;background:none;border:none;color:var(--color-text-primary);font-size:.875rem;outline:none;font-family:var(--font-mono)}.song-picker-list{overflow-y:auto;max-height:50vh}.song-picker-row{display:flex;align-items:center;gap:12px;padding:10px 20px;border:none;background:none;width:100%;cursor:pointer;color:inherit;text-align:left;transition:background .15s}.song-picker-row:hover{background:#ffffff0a}.song-picker-energy{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:.6875rem;font-weight:600;color:#fff;flex-shrink:0}.song-picker-info{flex:1;min-width:0}.song-picker-title{display:block;font-size:.8125rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.song-picker-artist{display:block;font-size:.75rem;color:var(--color-text-tertiary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.song-picker-meta{font-size:.6875rem;color:var(--color-text-tertiary);white-space:nowrap;font-family:var(--font-mono)}.song-picker-empty{padding:40px 20px;text-align:center;color:var(--color-text-tertiary)}.set-new-bottom-bar{margin-top:var(--spacing-2xl);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xl)}.set-new-filters{width:100%;max-width:760px;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-xl) var(--spacing-lg)}.set-new-filters-row{display:flex;gap:var(--spacing-lg);align-items:flex-start}.filter-group{flex:1}.filter-group--bpm{flex:0 0 200px}.filter-label{display:block;font-size:.6875rem;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:1px;margin-bottom:var(--spacing-sm)}.filter-empty{font-size:.75rem;color:var(--color-text-tertiary)}.genre-chips{display:flex;flex-wrap:wrap;gap:6px}.genre-chip{padding:var(--spacing-xs) 10px;border-radius:var(--radius-sm);font-size:.6875rem;border:1px solid var(--color-border);background:var(--color-bg-secondary);color:var(--color-text-tertiary);cursor:pointer;transition:all var(--transition-fast);display:inline-flex;align-items:center;gap:var(--spacing-xs);font-family:var(--font-mono)}.genre-chip:hover{border-color:var(--color-border-light);background:var(--color-bg-hover)}.genre-chip--active{border-color:#8b5cf64d;background:var(--color-primary-subtle);color:var(--color-primary)}.bpm-range-inputs{display:flex;align-items:center;gap:var(--spacing-sm)}.bpm-input{width:70px;padding:6px 10px;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-bg-tertiary);color:var(--color-text-primary);font-size:.8125rem;font-family:var(--font-mono);outline:none;text-align:center}.bpm-input:focus{border-color:#8b5cf64d}.bpm-input::placeholder{color:var(--color-text-tertiary)}.bpm-dash{color:var(--color-text-tertiary)}.energy-range-bar{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-lg);margin-bottom:var(--spacing-md);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.energy-range-label{font-size:.625rem;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:1.5px;white-space:nowrap;font-family:var(--font-mono)}.energy-range-dual{display:flex;align-items:center;gap:var(--spacing-sm);flex:1}.energy-range-val{font-size:.8125rem;color:var(--color-primary);font-family:var(--font-mono);min-width:28px;text-align:center;font-weight:600}.energy-range-track-wrapper{position:relative;flex:1;height:24px;display:flex;align-items:center}.energy-range-track{position:absolute;left:0;right:0;height:4px;background:var(--color-bg-hover);border-radius:2px}.energy-range-fill{position:absolute;top:0;height:100%;background:var(--gradient-primary);border-radius:2px}.energy-range-input{position:absolute;left:0;width:100%;height:24px;-webkit-appearance:none;appearance:none;background:transparent;pointer-events:none;outline:none;margin:0}.energy-range-input::-webkit-slider-runnable-track{height:4px;background:transparent}.energy-range-input::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--color-primary);cursor:pointer;pointer-events:all;border:2px solid var(--color-bg-primary);margin-top:-6px;box-shadow:0 0 8px #8b5cf666;transition:box-shadow var(--transition-fast),transform var(--transition-fast)}.energy-range-input::-webkit-slider-thumb:hover{box-shadow:0 0 14px #8b5cf699;transform:scale(1.15)}.energy-range-input::-moz-range-track{height:4px;background:transparent;border:none}.energy-range-input::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--color-primary);cursor:pointer;pointer-events:all;border:2px solid var(--color-bg-primary);box-shadow:0 0 8px #8b5cf666}.energy-range-input--floor{z-index:1}.energy-range-input--ceiling{z-index:2}.slot-box--anchor{border:1px solid rgba(251,191,36,.4)!important;background:#fbbf240f!important}.slot-anchor-icon{position:absolute;top:1px;right:1px;color:#fbbf24;display:flex;align-items:center}.library-filter-active{font-size:.625rem;padding:2px var(--spacing-sm);border-radius:var(--radius-sm);background:var(--color-primary-subtle);color:var(--color-primary);text-transform:uppercase;letter-spacing:1px}.group-canvas{display:flex;flex-direction:column;height:100%;overflow:hidden}.group-canvas-topbar{display:flex;align-items:center;gap:16px;padding:14px 24px;border-bottom:1px solid var(--color-border);background:var(--color-bg-secondary);flex-shrink:0}.group-canvas-title{flex:1;display:flex;align-items:baseline;gap:12px;min-width:0}.group-canvas-name{font-size:1.125rem;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.group-canvas-name:hover .group-canvas-name-edit-icon{opacity:1}.group-canvas-name-edit-icon{opacity:0;color:var(--color-text-tertiary);transition:opacity .15s}.group-canvas-name-input{font-size:1.125rem;font-weight:500;background:var(--color-bg-tertiary);border:1px solid var(--color-border-light);border-radius:var(--radius-sm);color:var(--color-text-primary);padding:4px 10px;outline:none;min-width:200px}.group-canvas-track-count{font-size:.75rem;color:var(--color-text-tertiary);white-space:nowrap;font-family:var(--font-mono)}.group-canvas-topbar-actions{display:flex;align-items:center;gap:8px}.btn-success{background:#10b98126;border-color:#10b9814d;color:#34d399}.group-canvas-columns{display:flex;gap:0;flex:1;overflow:hidden}.group-column{flex:1;display:flex;flex-direction:column;border-right:1px solid var(--color-border);overflow:hidden;cursor:pointer;transition:background var(--transition-fast);min-width:200px}.group-column:last-child{border-right:none}.group-column--active{background:#8b5cf60a;border-color:#8b5cf633}.group-column--dragover{background:var(--color-primary-subtle);outline:2px solid rgba(139,92,246,.3);outline-offset:-2px}.group-header{padding:14px 14px 8px;border-bottom:1px solid var(--color-border);flex-shrink:0}.group-header-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.group-header-name{font-size:.875rem;font-weight:600;letter-spacing:.02em}.group-header-name-input{font-size:.875rem;font-weight:600;background:var(--color-bg-tertiary);border:1px solid var(--color-border-light);border-radius:var(--radius-sm);color:var(--color-text-primary);padding:2px 6px;outline:none;width:100%}.group-meta-toggle{flex-shrink:0;color:var(--color-text-tertiary)}.group-meta-tags{display:flex;flex-wrap:wrap;gap:4px}.group-meta-tag{font-size:.6875rem;padding:2px 7px;border-radius:var(--radius-sm);background:var(--color-bg-tertiary);border:1px solid var(--color-border);color:var(--color-text-secondary);font-family:var(--font-mono)}.group-meta-tag--genre{background:var(--color-primary-subtle);border-color:#8b5cf640;color:var(--color-primary)}.group-edit-form{padding:12px 14px;background:#ffffff05;border-bottom:1px solid var(--color-border);display:flex;flex-direction:column;gap:10px;flex-shrink:0}.group-edit-form-row{display:flex;flex-direction:column;gap:6px}.group-stats-row{display:flex;gap:var(--spacing-sm);padding:6px 14px;border-bottom:1px solid var(--color-border);flex-shrink:0;font-size:.6875rem;color:var(--color-text-tertiary);font-family:var(--font-mono)}.group-track-list{flex:1;overflow-y:auto;padding:8px 0}.group-track-card{display:flex;align-items:center;gap:6px;padding:7px 10px 7px 8px;cursor:grab;transition:background var(--transition-fast);border-bottom:1px solid var(--color-border)}.group-track-card:hover{background:var(--color-bg-tertiary)}.group-track-card:active{cursor:grabbing}.group-track-drag-handle{color:var(--color-text-tertiary);flex-shrink:0;opacity:.4}.group-track-energy-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.group-track-info{flex:1;min-width:0;display:flex;flex-direction:column}.group-track-title{font-size:.75rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.group-track-artist{font-size:.6875rem;color:var(--color-text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.group-track-meta{font-size:.6875rem;color:var(--color-text-tertiary);font-family:var(--font-mono);flex-shrink:0;white-space:nowrap}.group-track-remove{flex-shrink:0;color:var(--color-text-tertiary);opacity:0;transition:opacity .12s}.group-track-card:hover .group-track-remove{opacity:1}.group-dropzone{padding:10px 14px;font-size:.6875rem;color:var(--color-text-tertiary);text-align:center;border-top:1px dashed var(--color-border);flex-shrink:0;transition:all var(--transition-fast)}.group-dropzone--over{background:var(--color-primary-subtle);color:var(--color-primary);border-color:#8b5cf64d}.group-library-panel{border-top:1px solid var(--color-border);background:var(--color-bg-secondary);flex-shrink:0;display:flex;flex-direction:column}.group-library-header{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;cursor:pointer;user-select:none}.group-library-title{font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;font-family:var(--font-mono);color:var(--color-text-secondary);display:flex;align-items:center;gap:8px}.group-library-body{display:flex;flex-direction:column;max-height:280px}.group-library-body .set-library-controls{margin-left:0;padding:8px 16px;border-bottom:1px solid var(--color-border);flex:none}.group-library-list{overflow-y:auto;flex:1}.group-library-row{display:flex;align-items:center;gap:10px;padding:8px 16px;width:100%;text-align:left;cursor:pointer;border:none;background:none;color:inherit;border-bottom:1px solid rgba(255,255,255,.03);transition:background .12s}.group-library-row:hover:not(:disabled){background:#ffffff0a}.group-library-row:disabled{cursor:default}.group-library-row--in-set{opacity:.4}.group-library-energy-bar{width:4px;height:28px;border-radius:2px;background:#ffffff0f;flex-shrink:0;position:relative;overflow:hidden;display:flex;align-items:flex-end}.group-library-energy-fill{width:100%;border-radius:2px}.group-library-info{flex:1;min-width:0;display:flex;flex-direction:column}.group-library-title{font-size:.8125rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.group-library-artist{font-size:.6875rem;color:var(--color-text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.group-library-meta{font-size:.6875rem;color:var(--color-text-tertiary);font-family:var(--font-mono);flex-shrink:0}.group-library-in-set-badge{font-size:.625rem;padding:1px 6px;border-radius:4px;background:#ffffff0f;color:var(--color-text-tertiary);flex-shrink:0}.group-library-vibe-score{font-size:.6875rem;color:#a78bfa;font-family:var(--font-mono);flex-shrink:0}.group-library-empty{padding:24px;text-align:center;color:var(--color-text-tertiary);font-size:.8125rem}.groups-setup-list{display:flex;flex-direction:column;gap:10px;max-width:640px;margin:0 auto;width:100%}.group-setup-item{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:12px;overflow:hidden}.group-setup-header{display:flex;align-items:center;gap:12px;padding:14px 16px}.group-setup-name-input{flex:1;font-size:.9375rem;font-weight:500;background:transparent;border:none;border-bottom:1px solid rgba(255,255,255,.08);color:var(--color-text-primary);padding:4px 0;outline:none;transition:border-color .15s}.group-setup-name-input:focus{border-color:#8b5cf666}.group-setup-expand{flex-shrink:0;display:flex;align-items:center;gap:4px;color:var(--color-text-tertiary);font-size:.75rem;padding:4px 8px;border-radius:6px;border:1px solid transparent;background:none;cursor:pointer;transition:all .15s}.group-setup-expand:hover{border-color:#ffffff1a;background:#ffffff0a}.group-setup-form{padding:14px 16px 16px;display:flex;flex-direction:column;gap:12px;border-top:1px solid rgba(255,255,255,.05)}.group-setup-row{display:flex;flex-direction:column;gap:6px}.group-setup-notes{width:100%;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:8px;color:var(--color-text-primary);padding:8px 12px;font-size:.8125rem;font-family:var(--font-sans);resize:vertical;outline:none;line-height:1.5}.group-setup-notes:focus{border-color:#8b5cf64d}.set-card-groups-preview{display:flex;align-items:center;gap:10px;padding:14px 20px 0}.set-card-group-chips{display:flex;flex-wrap:wrap;gap:5px}.set-card-group-chip{font-size:.6875rem;padding:2px 8px;border-radius:5px;background:#a78bfa1a;border:1px solid rgba(167,139,250,.2);color:#c4b5fd;font-family:var(--font-mono)}.rekordbox-import{padding:var(--spacing-xl);max-width:800px}.import-step{display:flex;flex-direction:column;gap:var(--spacing-lg)}.import-step h2{font-size:1.25rem;margin:0}.import-step-desc{color:var(--color-text-secondary);font-size:.875rem;margin:0}.import-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-2xl) var(--spacing-lg);border:2px dashed var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);text-align:center;color:var(--color-text-secondary);font-size:.875rem}.import-dropzone:hover{border-color:var(--color-primary);background:var(--color-primary-subtle)}.import-dropzone.drag-over{border-color:var(--color-primary);background:var(--color-primary-subtle);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb, 99, 102, 241),.15)}.import-dropzone-hint{font-size:.75rem;color:var(--color-text-tertiary)}.import-error-banner{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-md);color:var(--color-error);font-size:.875rem;margin-bottom:var(--spacing-md)}.import-error-banner .btn-icon{margin-left:auto}.import-summary-card{display:flex;flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-lg);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.import-summary-stats{display:flex;gap:var(--spacing-xl);justify-content:center}.import-stat{display:flex;flex-direction:column;align-items:center;gap:2px}.import-stat-value{font-size:1.5rem;font-weight:700;color:var(--color-text-primary)}.import-stat-label{font-size:.75rem;color:var(--color-text-secondary)}.import-notice{display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-size:.8125rem}.import-notice.warning{background:#f59e0b14;border:1px solid rgba(245,158,11,.2);color:var(--color-warning)}.import-option-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.import-option-group h3{font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;margin:0 0 4px;color:var(--color-text-secondary)}.rekordbox-import .import-radio{all:unset;box-sizing:border-box;display:flex!important;flex-direction:row!important;align-items:center!important;gap:12px;width:100%;padding:12px 16px;border-radius:8px;cursor:pointer;font-size:.875rem;color:var(--color-text-primary);background:var(--color-bg-secondary);border:1px solid var(--color-border);transition:background .15s,border-color .15s}.rekordbox-import .import-radio:hover{background:var(--color-bg-tertiary);border-color:var(--color-text-tertiary)}.rekordbox-import .import-radio:has(input:checked){border-color:var(--color-primary);background:#7c3aed14}.rekordbox-import .import-radio input[type=radio]{appearance:auto;-webkit-appearance:auto;width:16px;height:16px;min-width:16px;margin:0;flex-shrink:0;accent-color:var(--color-primary);cursor:pointer}.rekordbox-import .import-radio span{font-weight:500;line-height:1.3}.rekordbox-import .import-radio>div{display:flex;align-items:baseline;gap:8px}.import-radio-hint{font-size:.75rem;color:var(--color-primary);font-weight:400;opacity:.8}.import-actions{display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-sm);padding-top:var(--spacing-md);border-top:1px solid var(--color-border)}.playlist-tree{display:flex;flex-direction:column;gap:1px;padding:var(--spacing-sm);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:8px;max-height:360px;overflow-y:auto}.playlist-tree-item{display:flex;flex-direction:column}.playlist-tree-folder{display:flex;flex-direction:row;align-items:center;gap:6px;padding:6px 8px;cursor:pointer;font-size:.8125rem;font-weight:500;color:var(--color-text-primary);border-radius:4px;transition:background .15s}.playlist-tree-folder:hover{background:var(--color-bg-tertiary)}.playlist-tree-children{padding-left:20px}.rekordbox-import .playlist-tree-playlist{all:unset;box-sizing:border-box;display:flex!important;flex-direction:row!important;align-items:center!important;gap:8px;width:100%;padding:5px 8px;font-size:.8125rem;color:var(--color-text-primary);cursor:pointer;border-radius:4px;transition:background .15s}.rekordbox-import .playlist-tree-playlist:hover{background:var(--color-bg-tertiary)}.rekordbox-import .playlist-tree-playlist input[type=checkbox]{appearance:auto;-webkit-appearance:auto;width:14px;height:14px;min-width:14px;margin:0;flex-shrink:0;accent-color:var(--color-primary);cursor:pointer}.rekordbox-import .playlist-tree-playlist span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.playlist-track-count{margin-left:auto;flex-shrink:0;font-size:.6875rem;color:var(--color-text-tertiary);background:var(--color-bg-tertiary);padding:1px 6px;border-radius:999px}.playlist-select-all{border-bottom:1px solid var(--color-border);padding-bottom:6px!important;margin-bottom:4px;font-weight:600}.playlist-tree-total{font-size:.8125rem;font-weight:500;color:var(--color-text-secondary);padding:var(--spacing-sm);border-top:1px solid var(--color-border);margin-top:var(--spacing-xs);text-align:right}.folder-hints{display:flex;flex-direction:column;gap:var(--spacing-xs);padding:var(--spacing-md);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md)}.folder-hints h4{font-size:.8125rem;font-weight:500;margin:0;color:var(--color-text-secondary)}button.folder-hint-row{all:unset;box-sizing:border-box;display:flex;align-items:center;gap:8px;width:100%;padding:6px 10px;font-size:.75rem;font-family:var(--font-mono, monospace);color:var(--color-text-primary);background:var(--color-bg-tertiary);border-radius:var(--radius-sm);cursor:pointer;transition:background .15s}button.folder-hint-row:hover{background:#7c3aed1f}button.folder-hint-row>svg{flex-shrink:0;color:var(--color-text-tertiary)}.folder-hint-path{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.folder-hint-copy-icon{color:var(--color-text-tertiary);opacity:0;transition:opacity .15s}button.folder-hint-row:hover .folder-hint-copy-icon{opacity:1}.folder-hint-copied{color:var(--color-success);font-family:var(--font-sans, sans-serif);font-size:.6875rem;font-weight:500}.file-match-counter{display:flex;align-items:center;gap:var(--spacing-sm);font-size:.875rem;color:var(--color-success)}.file-sections{display:flex;flex-direction:column;border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.file-section-header{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-secondary);border:none;border-bottom:1px solid var(--color-border);color:var(--color-text-primary);font-size:.8125rem;font-weight:600;cursor:pointer;width:100%;text-align:left}.file-section-header:hover{background:var(--color-bg-tertiary)}.file-section-list{display:flex;flex-direction:column;max-height:240px;overflow-y:auto}.file-section-row{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-md);font-size:.8125rem;border-bottom:1px solid var(--color-border)}.file-section-row:last-child{border-bottom:none}.file-section-row.matched{color:var(--color-success)}.file-section-row.unmatched{color:var(--color-warning)}.file-section-row.extra{color:var(--color-text-tertiary)}.file-section-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--color-text-primary)}.file-section-file{font-size:.75rem;color:var(--color-text-tertiary);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.import-progress{display:flex;align-items:center;gap:var(--spacing-md)}.import-progress-bar{flex:1;height:8px;background:var(--color-bg-tertiary);border-radius:4px;overflow:hidden}.import-progress-fill{height:100%;background:var(--color-primary);border-radius:4px;transition:width .3s ease}.import-progress-text{font-size:.875rem;color:var(--color-text-secondary);white-space:nowrap}.import-current-track{display:flex;align-items:center;gap:var(--spacing-sm);font-size:.8125rem;color:var(--color-text-secondary);margin:0}.import-complete{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-lg);padding:var(--spacing-2xl) var(--spacing-lg);text-align:center;color:var(--color-success)}.import-complete h2{color:var(--color-text-primary)}.electron-app .sidebar-header{padding-top:calc(var(--spacing-lg) + 28px)}.electron-app .page-header{padding-top:28px}.electron-app .sidebar{-webkit-app-region:drag}.electron-app .sidebar-nav,.electron-app .sidebar-header,.electron-app .sidebar-footer,.electron-app .sidebar-bottom-actions{-webkit-app-region:no-drag}
