@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";.topnav{height:var(--topnav-height);background:var(--bg2);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 20px;gap:32px;flex-shrink:0;z-index:100}.topnav-logo{display:flex;align-items:center;gap:8px;flex-shrink:0}.topnav-logo-mark{display:block;flex-shrink:0}.topnav-logo-text{font-size:16px;font-weight:700;letter-spacing:-.03em;color:var(--text)}.topnav-tabs{display:flex;align-items:center;gap:2px;flex:1}.topnav-tab{background:none;border:none;color:var(--muted);font-size:13px;font-weight:500;padding:6px 14px;border-radius:6px;transition:color .15s,background .15s;font-family:var(--font-ui)}.topnav-tab:hover{color:var(--text);background:#ffffff0a}.topnav-tab.active{color:var(--text);background:var(--bg3)}.topnav-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.topnav-btn-ghost{background:none;border:1px solid var(--border);color:var(--muted);font-size:13px;font-weight:500;padding:6px 12px;border-radius:6px;transition:color .15s,border-color .15s;font-family:var(--font-ui)}.topnav-btn-ghost:hover{color:var(--text);border-color:#ffffff26}.topnav-btn-accent{background:var(--accent);border:none;color:#080809;font-size:13px;font-weight:600;padding:6px 14px;border-radius:6px;transition:opacity .15s;font-family:var(--font-ui)}.topnav-btn-accent:hover{opacity:.88}@media (max-width: 768px){.topnav-btn-ghost,.topnav-tabs{display:none}.topnav{padding:0 16px;gap:0}.topnav-actions{margin-left:auto}.import-library-btn{display:none}}.explore-page{flex:1;display:flex;flex-direction:row}.explore-sidebar{width:220px;flex-shrink:0;display:flex;flex-direction:column;background:var(--bg2);border-right:1px solid var(--border);overflow-y:auto;padding-bottom:12px}.sidebar-search-wrap{padding:12px 12px 8px}.sidebar-search-input{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:7px;padding:7px 10px;color:var(--text);font-size:12px;font-family:var(--font-ui);outline:none;transition:border-color .15s}.sidebar-search-input:focus{border-color:#b8f0504d}.sidebar-search-input::placeholder{color:var(--muted)}.sidebar-section-label{font-size:9px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);padding:12px 14px 4px;font-family:var(--font-mono)}.sidebar-item{display:flex;align-items:center;justify-content:space-between;background:none;border:none;text-align:left;padding:7px 14px;cursor:pointer;width:100%;border-left:2px solid transparent;transition:background .1s,border-color .1s;font-family:var(--font-ui)}.sidebar-item:hover:not(:disabled){background:#ffffff0a}.sidebar-item.active{border-left-color:var(--accent);background:#b8f0500f}.sidebar-item.active .sidebar-item-label{color:var(--accent)}.sidebar-item.disabled,.sidebar-item:disabled{cursor:default}.sidebar-item.muted .sidebar-item-label{color:var(--muted);opacity:.5}.sidebar-item-label{font-size:13px;font-weight:500;color:var(--text)}.sidebar-item-count{font-size:11px;color:var(--muted)}.sidebar-divider{height:1px;background:var(--border);margin:8px 14px}.sidebar-spacer{flex:1}.sidebar-import-btn{margin:8px 12px 4px;background:none;border:1px solid var(--border);color:var(--muted);font-size:11px;font-weight:500;padding:7px 12px;border-radius:7px;cursor:pointer;font-family:var(--font-ui);text-align:center;transition:color .15s,border-color .15s}.sidebar-import-btn:hover{color:var(--text);border-color:#ffffff26}.explore-content-area{display:flex;flex:1;overflow:hidden;min-height:0}.explore-main{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;min-width:0}.explore-center{flex:1;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;min-width:0}.explore-page--has-player .explore-main,.explore-page--has-player .explore-center,.explore-page--has-player .explore-right{padding-bottom:88px}.center-search-area{flex-shrink:0;padding:20px 20px 0;display:flex;flex-direction:column;gap:10px}.mode-pills{display:flex;gap:6px}.mode-pill{background:none;border:1px solid var(--border);color:var(--muted);font-size:11px;font-weight:500;padding:4px 12px;border-radius:20px;cursor:pointer;font-family:var(--font-ui);transition:color .15s,border-color .15s,background .15s}.mode-pill:hover{color:var(--text);border-color:#ffffff26}.mode-pill--active{background:#b8f0501a;border-color:#b8f05059;color:var(--accent)}.mode-pill--muted{opacity:.4;cursor:default;pointer-events:none}.center-results{flex:1;overflow-y:auto;padding:12px 20px 20px;display:flex;flex-direction:column;gap:10px}.center-header{flex-shrink:0;display:flex;align-items:center;gap:10px;padding:16px 20px 12px;border-bottom:1px solid var(--border)}.center-header-title{font-size:15px;font-weight:600;color:var(--text)}.center-header-meta{font-size:12px;color:var(--muted)}.center-header-btn{margin-left:auto;background:none;border:1px solid var(--border);color:var(--muted);font-size:11px;font-weight:500;padding:4px 12px;border-radius:6px;cursor:pointer;font-family:var(--font-ui);transition:color .15s,border-color .15s}.center-header-btn:hover{color:var(--text);border-color:#ffffff26}.explore-table-wrap{flex:1;overflow-y:auto;padding:0 0 20px}.explore-table{width:100%;border-collapse:collapse;font-size:13px}.explore-table thead th{text-align:left;padding:8px 12px;font-size:9px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-family:var(--font-mono);border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg);z-index:1}.explore-table thead th:first-child{padding-left:20px;width:40px}.explore-table thead th:last-child{padding-right:20px}.explore-table tbody tr{cursor:pointer;transition:background .1s;border-bottom:1px solid var(--border)}.explore-table tbody tr:hover{background:#ffffff08}.explore-table tbody tr.active{background:#b8f0500d}.explore-table tbody td{padding:9px 12px;color:var(--text);white-space:nowrap;text-overflow:ellipsis;max-width:200px}.explore-table tbody td:first-child{padding-left:20px;color:var(--muted)}.explore-table tbody td:last-child{padding-right:20px}.explore-table tbody td.muted{color:var(--muted)}.explore-table tbody td.mono{font-family:var(--font-mono);font-size:12px}.explore-right,.right-panel{display:none!important}.explore-right{width:300px;flex-shrink:0;display:flex;flex-direction:column;border-left:1px solid var(--border);background:var(--bg2);overflow-y:auto}.right-panel-header{display:flex;justify-content:flex-end;padding:10px 12px 6px;flex-shrink:0}.right-close-btn{background:none;border:none;color:var(--muted);font-size:18px;cursor:pointer;padding:0 4px;line-height:1;transition:color .15s}.right-close-btn:hover{color:var(--text)}.right-thumb-wrap{flex-shrink:0;padding:0 12px 12px}.right-thumb{width:100%;aspect-ratio:1;object-fit:cover;border-radius:6px;display:block}.right-track-info{padding:0 14px 14px;flex-shrink:0;border-bottom:1px solid var(--border)}.right-artist{font-size:12px;color:var(--muted);margin-bottom:3px}.right-title{font-size:15px;font-weight:600;color:var(--text);line-height:1.3;margin-bottom:5px}.right-meta{font-size:11px;color:var(--muted)}.right-section{padding:12px 14px;border-bottom:1px solid var(--border);flex-shrink:0}.right-section--discovery{flex:1;display:flex;flex-direction:column;min-height:0}.right-section-label{font-size:9px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-family:var(--font-mono);margin-bottom:8px;display:flex;align-items:center;gap:8px}.right-lib-row{padding:6px 0;cursor:pointer;border-bottom:1px solid var(--border);transition:background .1s}.right-lib-row:last-child{border-bottom:none}.right-lib-row:hover{opacity:.75}.right-lib-title{font-size:12px;font-weight:500;color:var(--text)}.right-lib-artist{font-size:11px;color:var(--muted);margin-top:1px}.right-empty{font-size:12px;color:var(--muted);padding:4px 0}.right-discovery-heading{font-size:11px;color:var(--muted);margin-bottom:8px;font-family:var(--font-mono)}.right-skeletons{display:flex;flex-direction:column;gap:6px}.right-sk-row{height:44px;border-radius:6px;background:var(--bg3);animation:skeleton-pulse 1.6s ease-in-out infinite}.right-discovery-list{display:flex;flex-direction:column;overflow-y:auto;flex:1}.disc-row{display:flex;align-items:center;gap:8px;padding:7px 0;border-bottom:1px solid var(--border);flex-shrink:0}.disc-row:last-child{border-bottom:none}.disc-thumb{width:36px;height:36px;border-radius:4px;object-fit:cover;flex-shrink:0}.disc-thumb--placeholder{background:var(--bg3)}.disc-info{flex:1;min-width:0}.disc-title{font-size:12px;font-weight:500;color:var(--text);white-space:nowrap;text-overflow:ellipsis}.disc-artist{font-size:11px;color:var(--muted);margin-top:1px;white-space:nowrap;text-overflow:ellipsis}.disc-score{font-size:10px;color:var(--muted);flex-shrink:0}.disc-actions{display:flex;gap:3px;flex-shrink:0}.disc-btn{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:none;border:1px solid var(--border);border-radius:4px;color:var(--muted);font-size:10px;cursor:pointer;transition:color .15s,border-color .15s,background .15s;padding:0 0 0 1px}.disc-btn:hover{color:var(--text);border-color:#ffffff26}.disc-btn.is-playing,.disc-btn--save.is-saved{color:var(--accent);border-color:#b8f05066}.suggestion-chips{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}.chip{background:var(--bg2);border:1px solid var(--border);color:var(--muted);font-size:12px;font-weight:500;padding:6px 14px;border-radius:20px;cursor:pointer;font-family:var(--font-ui);transition:color .15s,border-color .15s,background .15s}.chip:hover{color:var(--text);border-color:#ffffff26;background:var(--bg3)}.explore-search-bar{display:flex;align-items:center;gap:12px;background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:10px 16px;transition:border-color .15s;flex-shrink:0}.explore-search-bar:focus-within{border-color:#b8f05059}.explore-search-icon{font-size:18px;color:var(--accent);flex-shrink:0;line-height:1}.explore-search-input{flex:1;background:none;border:none;outline:none;color:var(--text);font-size:15px;font-family:var(--font-ui)}.explore-search-input::placeholder{color:var(--muted)}.explore-search-btn{background:var(--accent);border:none;color:#fff;font-size:13px;font-weight:600;padding:7px 16px;border-radius:8px;font-family:var(--font-ui);cursor:pointer;transition:opacity .15s;flex-shrink:0;display:flex;align-items:center;justify-content:center;min-width:68px}.explore-search-btn:hover{opacity:.88}.explore-search-btn:disabled{opacity:.6;cursor:default}.filter-bar{display:flex;align-items:center;gap:16px;flex-shrink:0;padding:0 2px}.filter-group{display:flex;align-items:center;gap:6px}.filter-label{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);flex-shrink:0}.filter-input{width:60px;background:var(--bg2);border:1px solid var(--border);border-radius:6px;padding:5px 8px;color:var(--text);font-size:12px;font-family:var(--font-mono);outline:none;transition:border-color .15s;-moz-appearance:textfield}.filter-input::-webkit-inner-spin-button,.filter-input::-webkit-outer-spin-button{-webkit-appearance:none}.filter-input:focus{border-color:#b8f0504d}.filter-input::placeholder{color:var(--muted)}.filter-sep{font-size:12px;color:var(--muted)}.filter-select{background:var(--bg2);border:1px solid var(--border);border-radius:6px;padding:5px 8px;color:var(--text);font-size:12px;font-family:var(--font-ui);outline:none;cursor:pointer;transition:border-color .15s}.filter-select:focus{border-color:#b8f0504d}.vinyl-toggle-label{display:flex;align-items:center;gap:8px;cursor:pointer}.vinyl-toggle{width:36px;height:20px;background:var(--bg3);border:1px solid var(--border);border-radius:10px;position:relative;cursor:pointer;transition:background .2s,border-color .2s;flex-shrink:0}.vinyl-toggle.active{background:var(--accent);border-color:var(--accent)}.vinyl-toggle-thumb{position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:var(--muted);transition:transform .2s,background .2s}.vinyl-toggle.active .vinyl-toggle-thumb{transform:translate(16px);background:#080809}.vinyl-badge{font-size:9px;font-family:var(--font-mono);color:#d4a017;background:#d4a0171f;border:1px solid rgba(212,160,23,.4);border-radius:3px;padding:1px 4px;flex-shrink:0}.discovery-quick-actions{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px;padding-top:8px;border-top:1px solid var(--border)}.discovery-quick-btn{font-size:11px;font-family:var(--font-mono);color:var(--muted);background:transparent;border:1px solid var(--border);border-radius:4px;padding:3px 8px;cursor:pointer;transition:color .15s,border-color .15s;white-space:nowrap}.discovery-quick-btn:hover{color:var(--fg);border-color:var(--fg)}.filter-count{margin-left:auto;font-size:12px;color:var(--muted);font-family:var(--font-mono)}.explore-error{background:#f5a6231a;border:1px solid rgba(245,166,35,.25);border-radius:8px;padding:11px 16px;font-size:13px;color:#f5c842;flex-shrink:0;margin:10px 20px 0}.explore-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;padding:40px 20px}.vinyl{width:148px;height:148px;border-radius:50%;background:var(--bg3);display:flex;align-items:center;justify-content:center;box-shadow:0 0 0 10px var(--bg2),0 0 0 11px #ffffff0a}.vinyl-groove{width:90px;height:90px;border-radius:50%;background:var(--bg);display:flex;align-items:center;justify-content:center}.vinyl-label{width:46px;height:46px;border-radius:50%;background:var(--bg3);display:flex;align-items:center;justify-content:center}.vinyl-dot{width:10px;height:10px;border-radius:50%;background:var(--accent)}.explore-empty-text{font-size:14px;color:var(--muted);text-align:center}.explore-meta{display:flex;align-items:center;flex-shrink:0}.explore-meta-label{font-size:9px;font-family:var(--font-mono);font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);opacity:.6}.explore-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;align-content:start}.result-card{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:16px;display:flex;flex-direction:column;gap:10px;transition:border-color .15s,background .15s}.result-card:not(.result-card--skeleton):hover{border-color:#ffffff17;background:var(--bg3)}.result-card--playing{border-color:#b8f0504d!important;background:#b8f0500a!important}.card-top-row{display:flex;justify-content:space-between;align-items:center}.card-play-btn{width:32px;height:32px;border-radius:50%;background:var(--accent);border:none;color:#fff;font-size:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:opacity .15s;padding:0 0 0 2px}.card-play-btn:hover{opacity:.85}.card-play-btn.is-playing{background:var(--accent);opacity:1}.btn-spinner{display:block;width:12px;height:12px;border:2px solid rgba(255,255,255,.2);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes eq-bounce{0%,to{height:4px}50%{height:14px}}.eq{display:flex;align-items:flex-end;gap:2px;height:14px}.eq-bar{display:block;width:3px;height:4px;background:var(--accent);border-radius:2px 2px 0 0;animation:eq-bounce .7s ease-in-out infinite}.eq-bar:nth-child(2){animation-delay:.15s}.eq-bar:nth-child(3){animation-delay:.3s}.source-badge{font-family:var(--font-mono);font-size:10px;font-weight:600;padding:2px 6px;border-radius:4px;letter-spacing:.04em}.source-bc{background:#5595d426;color:#5595d4;border:1px solid rgba(85,149,212,.3)}.source-bp{background:#00c8641f;color:#00c864;border:1px solid rgba(0,200,100,.25)}.source-dc{background:#d4555526;color:#d45555;border:1px solid rgba(212,85,85,.3)}.source-yt{background:#ef44441f;color:#ef6060;border:1px solid rgba(239,68,68,.25)}.source-default{background:#ffffff0f;color:var(--muted);border:1px solid var(--border)}.card-body{flex:1;min-width:0}.card-title{font-size:14px;font-weight:600;color:var(--text);white-space:nowrap;text-overflow:ellipsis;line-height:1.3}.card-artist{font-size:12px;color:var(--muted);margin-top:3px;white-space:nowrap;text-overflow:ellipsis}.card-tags{display:flex;gap:4px;margin-top:8px;flex-wrap:wrap}.result-tag{background:var(--bg3);border:1px solid var(--border);color:var(--muted);font-size:10px;font-family:var(--font-mono);padding:2px 6px;border-radius:4px}.alt-version-badge{display:inline-block;margin-left:6px;padding:1px 6px;font-size:9px;font-family:var(--font-mono);font-weight:500;color:var(--muted);background:var(--bg3);border:1px solid var(--border);border-radius:10px;vertical-align:middle;opacity:.75;letter-spacing:.02em}.card-preview-error{margin-top:6px;font-size:11px;color:#f87171}.card-actions{display:flex;gap:6px;margin-top:auto}.card-btn{flex:1;font-size:10px;font-weight:500;font-family:var(--font-ui);padding:6px 8px;border-radius:6px;cursor:pointer;transition:color .15s,border-color .15s,background .15s;white-space:nowrap;text-align:center}.card-btn--save{background:none;border:1px solid var(--border);color:var(--muted)}.card-btn--save:hover{border-color:#b8f05066;color:var(--accent)}.card-btn--save.is-saved{border-color:#b8f05059;color:var(--accent)}.card-btn--similar{background:none;border:1px solid var(--border);color:var(--muted)}.card-btn--similar:hover{color:var(--text);border-color:#ffffff26}@keyframes skeleton-pulse{0%,to{opacity:.5}50%{opacity:1}}.result-card--skeleton{pointer-events:none;animation:skeleton-pulse 1.6s ease-in-out infinite}.sk-top-row{display:flex;justify-content:space-between;align-items:center}.sk-play{width:32px;height:32px;border-radius:50%;background:var(--bg3)}.sk-badge{width:24px;height:16px;border-radius:3px;background:var(--bg3)}.sk-body{display:flex;flex-direction:column;gap:8px;flex:1}.sk-line{height:11px;border-radius:4px;background:var(--bg3)}.sk-line--wide{width:70%}.sk-line--narrow{width:45%}.sk-tags{display:flex;gap:6px}.sk-tag{width:52px;height:18px;border-radius:4px;background:var(--bg3)}.sk-actions{display:flex;gap:6px}.sk-btn{flex:1;height:26px;border-radius:6px;background:var(--bg3)}.player-bar{position:fixed;bottom:16px;left:50%;transform:translate(-50%);width:min(680px,calc(100vw - 48px));background:var(--bg2);border:1px solid var(--border);border-radius:14px;display:flex;flex-direction:column;padding:10px 16px;gap:8px;z-index:200;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 8px 32px #00000080}.player-top-row{display:flex;align-items:center;gap:16px}.player-track-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.player-name{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;text-overflow:ellipsis}.player-artist{font-size:11px;color:var(--muted);white-space:nowrap;text-overflow:ellipsis}.player-controls{display:flex;align-items:center;gap:8px;flex-shrink:0}.player-btn{background:var(--bg3);border:1px solid var(--border);color:var(--text);font-size:13px;width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:background .15s,border-color .15s;padding:0}.player-btn:hover{background:#b8f0501f;border-color:#b8f05066}.player-btn--stop{color:var(--muted);font-size:10px}.player-buffering{display:inline-block;animation:pulse 1s infinite;font-family:var(--font-mono);letter-spacing:2px;font-size:10px;color:var(--accent)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.player-scrubber-row{display:flex;align-items:center;gap:8px}.player-time{font-family:var(--font-mono);font-size:10px;color:var(--muted);flex-shrink:0;min-width:28px;line-height:1}.waveform-scrubber{flex:1;height:32px;display:flex;align-items:center;gap:1.5px;cursor:pointer;padding:4px 0}.waveform-bar{flex:1;min-width:2px;border-radius:2px;transition:background .05s}.player-yt-badge{display:inline-block;margin-left:5px;padding:1px 4px;font-size:9px;font-weight:700;background:red;color:#fff;border-radius:3px;vertical-align:middle;letter-spacing:.3px;line-height:1.4}.player-progress-bar{flex:1;height:4px;background:var(--border);border-radius:2px;overflow:hidden;cursor:default}.player-progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width 1s linear;will-change:width}.discovery-expanded-yt-playing{display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--bg3);border-radius:6px;margin-bottom:10px;font-size:12px;color:var(--accent)}.discovery-expanded-yt-playing-icon{font-size:10px;opacity:.8}.discovery-expanded-yt-playing-label{flex:1;color:var(--muted)}.discovery-expanded-yt-playing-time{font-family:var(--font-mono);font-size:11px;color:var(--muted)}.player-menu-wrap{position:relative;flex-shrink:0}.player-menu-btn{background:none;border:none;color:var(--muted);font-size:18px;cursor:pointer;padding:4px 8px;border-radius:6px;letter-spacing:1px;line-height:1;transition:background .1s,color .1s}.player-menu-btn:hover{background:var(--bg3);color:var(--text)}.player-menu-dropdown{position:absolute;bottom:100%;right:0;margin-bottom:8px;background:var(--bg2);border:1px solid var(--border);border-radius:8px;min-width:200px;z-index:500;padding:4px 0;box-shadow:0 6px 24px #0009}.track-dropdown-item{display:block;width:100%;padding:8px 14px;text-align:left;background:transparent;border:none;color:var(--text);font-size:13px;cursor:pointer}.track-dropdown-item:hover{background:var(--bg3)}.track-dropdown-divider{height:1px;background:var(--border);margin:4px 0}.track-dropdown-submenu-wrap{position:relative}.track-dropdown-arrow{font-size:9px;opacity:.6}.track-dropdown-submenu{position:absolute;right:100%;left:auto;top:0;background:var(--bg2);border:1px solid var(--border);border-radius:8px;min-width:180px;z-index:600;padding:4px 0;box-shadow:0 6px 24px #0009;max-height:280px;overflow-y:auto}.player-queue-badge{background:var(--accent);color:#fff;font-size:10px;font-weight:600;font-family:var(--font-mono);width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.right-panel-section{padding:12px 16px;border-top:1px solid var(--border)}.right-panel-section-label{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin:0 0 10px;font-family:var(--font-mono)}.right-panel-loading{display:flex;align-items:center;padding:8px 0}.discovery-row{display:flex;align-items:center;gap:6px;padding:6px 0;border-bottom:1px solid var(--border);min-width:0}.discovery-row:last-child{border-bottom:none}.discovery-row-thumb{width:32px;height:32px;border-radius:4px;object-fit:cover;flex-shrink:0}.discovery-row-thumb--empty{background:var(--bg3)}.discovery-row-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px;overflow:hidden}.discovery-row-title{font-size:12px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.discovery-row-artist{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.discovery-row-pct{font-size:10px;font-family:var(--font-mono);color:var(--accent);flex-shrink:0;white-space:nowrap}.discovery-row-pct.clap-scored{color:var(--accent);font-weight:600}.discovery-row-btn{flex-shrink:0;background:none;border:1px solid var(--border);color:var(--muted);font-size:10px;width:22px;height:22px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .1s,border-color .1s;padding:0}.discovery-row-btn:hover{color:var(--text);border-color:#fff3}.sidebar-empty-hint{font-size:11px;color:var(--muted);padding:4px 8px;font-style:italic;margin:0}.playlist-view{flex:1;display:flex;flex-direction:column;padding:0 24px}.playlist-header{display:flex;align-items:center;justify-content:space-between;padding:0 0 16px;flex-shrink:0}.playlist-title{font-size:18px;font-weight:500;color:var(--text);margin:0}.playlist-tabs{display:flex;gap:4px}.playlist-tab{background:none;border:1px solid var(--border);color:var(--muted);font-size:12px;padding:5px 12px;border-radius:6px;cursor:pointer;transition:all .15s}.playlist-tab.active{border-color:var(--accent);color:var(--accent)}.library-table-header{display:grid;grid-template-columns:24px 32px 1fr 1fr 60px 60px 100px;gap:8px;padding:6px 8px;font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-family:var(--font-mono);border-bottom:1px solid var(--border);flex-shrink:0}.library-table{flex:1;overflow-y:auto}.library-row{display:grid;grid-template-columns:24px 32px 1fr 1fr 60px 60px 100px;gap:8px;padding:8px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s;align-items:center}.library-row-play{width:24px;height:24px;border-radius:50%;background:var(--accent);border:none;color:#fff;font-size:9px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;padding:0 0 0 1px;transition:opacity .15s}.library-row-play:hover{opacity:.85}.library-row-remove{margin-left:auto;background:none;border:none;color:var(--muted);font-size:16px;cursor:pointer;padding:0 4px;flex-shrink:0;opacity:0;transition:opacity .15s,color .15s}.library-row:hover .library-row-remove{opacity:1}.library-row-remove:hover{color:#ef4444}.playlist-section-header{font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);padding:12px 8px 4px;border-bottom:1px solid var(--border)}.library-row:hover,.library-row.active{background:var(--bg2)}.library-row-num{font-size:11px;color:var(--muted);font-family:var(--font-mono)}.library-row-title{font-size:13px;color:var(--text);white-space:nowrap;text-overflow:ellipsis}.library-row-artist{font-size:12px;color:var(--muted);white-space:nowrap;text-overflow:ellipsis}.library-row-bpm,.library-row-key{font-size:11px;color:var(--muted);font-family:var(--font-mono)}.library-row-genre{font-size:11px;color:var(--muted);white-space:nowrap;text-overflow:ellipsis}.seed-picker{display:flex;flex-direction:column}.seed-picker-section-label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-weight:600;padding:0 4px 8px;font-family:var(--font-mono);margin:0}.seed-picker-row{display:flex;align-items:center;gap:10px;padding:9px 4px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s;border-radius:6px}.seed-picker-row:hover{background:#ffffff0a}.seed-picker-thumb-wrap{position:relative;width:44px;height:44px;flex-shrink:0;cursor:pointer;border-radius:4px;overflow:hidden}.seed-picker-thumb{width:44px;height:44px;object-fit:cover;display:block;border-radius:4px}.seed-picker-thumb--empty{background:var(--bg3);border-radius:4px;display:flex;align-items:center;justify-content:center}.seed-picker-thumb-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;color:#fff;font-size:11px;opacity:0;transition:opacity .15s;border-radius:4px}.seed-picker-thumb-wrap:hover .seed-picker-thumb-overlay,.seed-picker-thumb-overlay.is-playing{opacity:1}.seed-picker-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.seed-picker-title{font-size:13px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.seed-picker-artist{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.seed-picker-source{font-size:9px;font-weight:600;font-family:var(--font-mono);color:#5595d4;background:#5595d426;border:1px solid rgba(85,149,212,.3);padding:2px 5px;border-radius:3px;flex-shrink:0}.seed-picker-arrow{font-size:14px;color:var(--muted);flex-shrink:0;opacity:0;transition:opacity .15s}.seed-picker-row:hover .seed-picker-arrow{opacity:1}.result-card .card-play-btn{opacity:0;transition:opacity .15s}.result-card:hover .card-play-btn,.result-card .card-play-btn.is-playing{opacity:1}.seed-picker-menu-wrap{position:relative;flex-shrink:0}.seed-picker-menu-btn{width:28px;height:28px;border:none;background:transparent;color:var(--muted);font-size:14px;cursor:pointer;border-radius:4px;opacity:0;transition:opacity .15s;letter-spacing:1px}.seed-picker-row:hover .seed-picker-menu-btn{opacity:1}.seed-picker-menu-btn:hover{color:var(--text);background:var(--surface-2)}.seed-picker-find-btn{flex-shrink:0;background:none;border:1px solid var(--accent);color:var(--accent);font-size:11px;font-weight:500;font-family:var(--font-ui);padding:4px 10px;border-radius:4px;cursor:pointer;white-space:nowrap;transition:background .15s,color .15s}.seed-picker-find-btn:hover{background:var(--accent);color:#fff}.track-menu-overlay{display:none}@media (max-width: 768px){.track-menu-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:499}}.track-menu{z-index:9999;background:var(--bg2);border:1px solid var(--border);border-radius:8px;box-shadow:0 8px 32px #00000080;min-width:200px;padding:4px 0}.track-menu-item{display:block;width:100%;padding:8px 14px;text-align:left;background:transparent;border:none;color:var(--text);font-size:13px;cursor:pointer}.track-menu-item:hover{background:var(--surface-2)}.similar-artists-grid{display:flex;flex-wrap:wrap;gap:8px;padding:4px 0}.similar-artist-chip{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg2);border:1px solid var(--border);border-radius:20px;cursor:pointer;transition:background .15s,border-color .15s;max-width:200px}.similar-artist-chip:hover{background:var(--bg3);border-color:#b8f0504d}.similar-artist-thumb{width:24px;height:24px;border-radius:50%;object-fit:cover;flex-shrink:0}.similar-artist-name{font-size:12px;color:var(--text);white-space:nowrap;text-overflow:ellipsis}.similar-artist-match{font-size:10px;color:var(--accent);font-family:var(--font-mono);flex-shrink:0;margin-left:auto}.similar-artist-explore{font-size:10px;color:var(--accent);flex-shrink:0;opacity:.8}.landing-page{display:flex;flex-direction:column;align-items:center;padding:48px 24px 120px;max-width:900px;margin:0 auto;width:100%}.landing-logo{display:flex;align-items:center;gap:10px;margin-bottom:8px}.landing-logo-mark{font-size:28px;color:var(--accent)}.landing-logo-text{font-size:24px;font-weight:700;color:var(--text);letter-spacing:-.02em}.landing-tagline{font-size:16px;color:var(--text);margin-bottom:4px;text-align:center;font-weight:500}.landing-tagline-sub{font-size:13px;color:var(--muted);margin-bottom:32px;text-align:center}.landing-search-wrap{width:100%;max-width:600px;margin-bottom:20px}.landing-search-bar{display:flex;gap:0;border:1.5px solid var(--border);border-radius:4px;overflow:hidden;background:var(--bg2);transition:border-color .2s}.landing-search-bar:focus-within{border-color:var(--accent)}.landing-search-input{flex:1;padding:14px 18px;background:transparent;border:none;color:var(--text);font-size:15px;outline:none}.landing-search-input::placeholder{color:var(--muted)}.landing-search-btn{padding:14px 24px;background:var(--accent);border:none;border-radius:0 4px 4px 0;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .15s;white-space:nowrap}.landing-search-btn:hover{opacity:.85}.landing-search-actions{display:flex;gap:8px;justify-content:center;margin-top:10px;flex-wrap:wrap}.landing-action-chip{font-size:12px;padding:6px 14px;background:none;border:1px solid var(--border);border-radius:20px;color:var(--muted);cursor:pointer;transition:color .15s,border-color .15s}.landing-action-chip:hover{color:var(--text);border-color:#fff3}.landing-filters{margin-bottom:20px}.landing-filter-section-label{display:block;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}.landing-filters-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap;justify-content:flex-start}.landing-filter-group{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.landing-filter-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}.landing-filter-select{background:var(--bg2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:13px;padding:6px 10px;cursor:pointer}.landing-filter-clear{font-size:12px;color:var(--muted);background:none;border:none;cursor:pointer;padding:4px 8px}.landing-filter-clear:hover{color:var(--text)}.landing-how-it-works{font-size:12px;color:var(--muted);text-align:center;margin:-8px 0 20px;opacity:.7;line-height:1.5}.landing-recs-section{width:100%}.landing-recs-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.landing-recs-header-left{display:flex;align-items:center;gap:10px}.landing-recs-header-right{display:flex;align-items:center;gap:6px}.landing-incognito-btn{font-size:11px;font-weight:500;background:none;border:1px solid var(--border);border-radius:6px;color:var(--muted);padding:4px 9px;cursor:pointer;font-family:inherit;transition:color .15s,border-color .15s;white-space:nowrap}.landing-incognito-btn:hover{color:var(--text);border-color:#fff3}.landing-incognito-btn.active{color:var(--accent);border-color:var(--accent)}.landing-recs-title{font-size:13px;font-weight:600;color:var(--text);text-transform:uppercase;letter-spacing:.06em}.landing-recs-refresh{font-size:12px;color:var(--muted);background:none;border:none;cursor:pointer;padding:4px 8px;border-radius:6px;transition:color .15s}.landing-recs-refresh:hover{color:var(--text)}.landing-recs-loading{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:13px;padding:24px 0;justify-content:center}.landing-load-more{margin-top:20px;padding:10px 32px;background:none;border:1px solid var(--border);border-radius:6px;color:var(--muted);font-size:13px;cursor:pointer;transition:color .15s,border-color .15s;width:100%;max-width:300px}.landing-load-more:hover{color:var(--text);border-color:#fff3}.landing-load-more:disabled{opacity:.5;cursor:default}.landing-recs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.landing-rec-card{background:var(--bg2);border:1px solid var(--border);border-radius:6px;overflow:hidden;cursor:pointer;transition:border-color .15s,transform .15s;position:relative}.landing-rec-card:hover{border-color:#ffffff26;transform:translateY(-2px)}.landing-rec-thumb{width:100%;aspect-ratio:1;object-fit:cover;display:block}.landing-rec-thumb--empty{width:100%;aspect-ratio:1;background:var(--bg3);display:flex;align-items:center;justify-content:center}.landing-rec-info{padding:10px 12px 12px}.landing-rec-title{font-size:13px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}.landing-rec-artist{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.landing-rec-genre{font-size:10px;color:var(--muted);margin-top:4px;opacity:.7}.landing-rec-actions{position:absolute;top:8px;right:8px;display:flex;gap:4px;opacity:0;transition:opacity .15s}.landing-rec-card:hover .landing-rec-actions{opacity:1}.landing-rec-play{width:28px;height:28px;border-radius:50%;background:#0009;border:none;color:#fff;font-size:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding-left:2px}.landing-rec-search{width:28px;height:28px;border-radius:50%;background:#0009;border:none;color:#fff;font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center}.landing-import-cta{margin-top:32px;font-size:13px;color:var(--muted);text-align:center}.landing-import-cta button{background:none;border:none;color:var(--accent);cursor:pointer;font-size:13px;text-decoration:underline;padding:0}.discovery-layout{display:flex;flex-direction:column;height:100%;overflow:hidden}.discovery-breadcrumb{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border);flex-shrink:0;flex-wrap:wrap}.discovery-back-btn{background:none;border:1px solid var(--border);color:var(--muted);font-size:12px;padding:5px 12px;border-radius:6px;cursor:pointer;white-space:nowrap;flex-shrink:0}.discovery-back-btn:hover{color:var(--text);border-color:#fff3}.discovery-trail{display:flex;align-items:center;gap:4px;flex:1;overflow:hidden;min-width:0}.discovery-trail-item{background:none;border:none;color:var(--muted);font-size:12px;cursor:pointer;white-space:nowrap;padding:2px 4px;border-radius:4px}.discovery-trail-item.active{color:var(--text);font-weight:500}.discovery-trail-item:hover{color:var(--text)}.discovery-trail-sep{color:var(--muted);font-size:10px}.discovery-trail-type{color:var(--muted);font-size:10px;font-weight:400}.discovery-seed-info{display:flex;align-items:center;gap:8px;margin-left:auto;flex-shrink:0}.discovery-seed-thumb{width:32px;height:32px;border-radius:4px;object-fit:cover}.discovery-seed-title{font-size:12px;font-weight:500;color:var(--text);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.discovery-seed-artist{font-size:11px;color:var(--muted)}.discovery-new-search-btn{background:none;border:1px solid var(--border);color:var(--muted);font-size:11px;padding:4px 10px;border-radius:6px;cursor:pointer;flex-shrink:0}.discovery-new-search-btn:hover{color:var(--text)}.discovery-seed-play-btn{background:none;border:none;color:var(--muted);font-size:13px;padding:2px 4px;cursor:pointer;line-height:1;flex-shrink:0;opacity:.7;transition:opacity .15s}.discovery-seed-play-btn:hover{opacity:1;color:var(--text)}.discovery-filter-bar{display:flex;align-items:center;gap:12px;padding:8px 16px;border-bottom:1px solid var(--border);flex-shrink:0;flex-wrap:wrap;background:var(--bg2)}.discovery-columns{display:flex;flex:1;overflow:hidden;min-height:0}.discovery-results-col{flex:1;overflow-y:auto;padding-bottom:160px;min-width:0}.discovery-result-row{display:flex;align-items:center;gap:10px;padding:8px 16px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .1s}.discovery-result-row:hover,.discovery-result-row.active{background:var(--bg3)}.discovery-result-row--accordion{display:block;padding:0}.discovery-result-row--accordion:hover,.discovery-result-row--accordion.active{background:none}.discovery-result-header{display:flex;align-items:center;gap:10px;padding:8px 16px;transition:background .1s}.discovery-result-row--accordion:hover .discovery-result-header,.discovery-result-row--accordion.active .discovery-result-header,.discovery-result-row--accordion.expanded .discovery-result-header{background:var(--bg3)}.discovery-result-body{max-height:0;overflow:hidden;transition:max-height .2s ease-in-out}.discovery-result-row--accordion.expanded .discovery-result-body{max-height:600px}.discovery-result-expanded{padding:8px 12px 12px}.discovery-expanded-art{width:100%;max-height:180px;object-fit:cover;border-radius:6px;display:block;margin-bottom:10px}.discovery-expanded-art--placeholder{width:100%;height:80px;background:var(--bg3);border-radius:6px;display:flex;align-items:center;justify-content:center;margin-bottom:10px;font-size:28px;font-weight:700;color:var(--accent);opacity:.5}.discovery-expanded-meta{display:flex;align-items:center;flex-wrap:wrap;gap:4px;margin-bottom:10px;font-size:12px;color:var(--muted)}.discovery-expanded-meta-link{background:none;border:none;color:var(--accent);cursor:pointer;font-size:12px;padding:0;text-decoration:underline;text-underline-offset:2px;text-decoration-color:transparent;transition:text-decoration-color .15s}.discovery-expanded-meta-link:hover{text-decoration-color:var(--accent)}.discovery-expanded-meta-sep{color:var(--border);-webkit-user-select:none;user-select:none}.discovery-expanded-meta-text{color:var(--muted)}.discovery-expanded-player{display:flex;align-items:center;gap:10px;margin-bottom:10px;padding:8px 0}.discovery-expanded-play-btn{width:36px;height:36px;border-radius:50%;background:var(--accent);border:none;color:#080809;font-size:14px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:opacity .15s}.discovery-expanded-play-btn:hover{opacity:.85}.discovery-expanded-play-btn.is-loading{background:var(--bg3);color:var(--muted)}.discovery-expanded-play-label{font-size:12px;color:var(--muted)}.discovery-expanded-yt{width:100%;aspect-ratio:16 / 9;margin-bottom:10px;border-radius:6px;overflow:hidden}@media (min-width: 769px){.discovery-expanded-yt{max-height:220px}}.discovery-expanded-yt-frame{width:100%;height:100%;border:none;display:block}.discovery-expanded-no-preview{font-size:12px;color:var(--muted);padding:8px 0 10px;opacity:.6}.discovery-expanded-actions{display:flex;gap:6px;flex-wrap:wrap;position:relative}.discovery-expanded-btn{font-size:12px;padding:5px 10px;background:var(--bg3);border:1px solid var(--border);border-radius:6px;color:var(--text);cursor:pointer;transition:background .1s;white-space:nowrap}.discovery-expanded-btn:hover{background:var(--bg2)}.discovery-expanded-btn.saved{color:var(--accent);border-color:var(--accent)}.discovery-expanded-btn--menu{letter-spacing:2px}.discovery-result-thumb-wrap{position:relative;width:44px;height:44px;flex-shrink:0;border-radius:4px;overflow:hidden;cursor:pointer}.discovery-result-thumb{width:44px;height:44px;object-fit:cover;display:block}.discovery-result-thumb--empty{background:var(--bg3);display:flex;align-items:center;justify-content:center}.disc-result-initial{font-size:16px;font-weight:700;color:var(--accent);opacity:.55;line-height:1;-webkit-user-select:none;user-select:none}.yt-thumb-badge{font-size:9px;font-weight:700;font-family:var(--font-mono);color:#fff;background:#ef4444;border-radius:3px;padding:2px 4px;letter-spacing:.04em}.discovery-result-thumb-overlay.no-preview{opacity:1;background:#00000040}.discovery-result-thumb-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;font-size:13px;opacity:0;transition:opacity .15s;border-radius:4px}.discovery-result-thumb-overlay span{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:var(--accent);color:#fff;font-size:11px}.discovery-result-thumb-wrap:hover .discovery-result-thumb-overlay,.discovery-result-thumb-overlay.playing{opacity:1}@media (max-width: 768px){.discovery-result-thumb-overlay{opacity:1}}.discovery-result-info{flex:1;min-width:0}.discovery-result-title{font-size:13px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.discovery-result-artist{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.discovery-result-tags{display:flex;gap:4px;margin-top:3px;flex-wrap:wrap}.discovery-result-tag{font-size:10px;padding:1px 6px;background:var(--bg3);border-radius:4px;color:var(--muted)}.discovery-result-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.discovery-result-pct{font-family:var(--font-mono);font-size:12px;color:var(--accent);flex-shrink:0;letter-spacing:-.02em;min-width:36px;text-align:right}.discovery-result-pct.clap{color:var(--accent);font-weight:500}.library-row-menu-btn{background:none;border:none;color:var(--muted);font-size:14px;cursor:pointer;padding:4px 8px;border-radius:4px;opacity:0;transition:opacity .15s}.library-row:hover .library-row-menu-btn{opacity:1}.library-row-menu-btn:hover{color:var(--text)}.discovery-result-menu-btn{width:26px;height:26px;border-radius:6px;background:var(--bg3);border:1px solid var(--border);color:var(--muted);font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .1s,border-color .1s}.discovery-result-menu-btn:hover{color:var(--text);border-color:#fff3}.find-similar-btn{padding:3px 8px;border-radius:20px;border:1px solid var(--accent);background:transparent;color:var(--accent);font-size:11px;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:background .15s,color .15s;line-height:1.4}.find-similar-btn:hover{background:var(--accent);color:#080809}.find-similar-btn .find-similar-short{display:none}.find-similar-btn .find-similar-label{display:inline}@media (max-width: 480px){.find-similar-btn{padding:3px 7px}.find-similar-btn .find-similar-label{display:none}.find-similar-btn .find-similar-short{display:inline}}.discovery-result-find-btn,.discovery-result-save-btn{width:26px;height:26px;border-radius:6px;background:var(--bg3);border:1px solid var(--border);color:var(--muted);font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .1s,border-color .1s}.discovery-result-find-btn:hover{color:var(--accent);border-color:var(--accent)}.discovery-result-save-btn:hover{color:var(--text);border-color:#fff3}.discovery-loading{display:flex;align-items:center;gap:10px;padding:32px 16px;color:var(--muted);font-size:13px}.discovery-detail-col{width:260px;flex-shrink:0;border-left:1px solid var(--border);overflow-y:auto;background:var(--bg);display:flex;flex-direction:column;font-size:12px}.dp-header{display:flex;align-items:flex-start;justify-content:space-between;padding:10px 12px 8px;border-bottom:1px solid var(--border);gap:8px;flex-shrink:0}.dp-seed-label{flex:1;min-width:0}.dp-seed-title{display:block;font-size:12px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dp-seed-badge{font-size:9px;font-family:var(--font-mono);color:var(--muted);border:1px solid var(--border);border-radius:3px;padding:1px 5px;margin-top:3px;display:inline-block}.dp-close{background:none;border:none;color:var(--muted);font-size:16px;cursor:pointer;padding:0;flex-shrink:0;line-height:1}.dp-close:hover{color:var(--text)}.dp-section{border-bottom:1px solid var(--border)}.dp-section-header{display:flex;align-items:center;justify-content:space-between;padding:2px 6px}.dp-section-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;background:none;border:none;color:var(--muted);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;cursor:pointer;padding:8px 12px;text-align:left}.dp-section-toggle:hover{color:var(--text)}.dp-section-toggle span{opacity:.6}.dp-lib-row{padding:5px 12px;cursor:pointer;border-top:1px solid var(--border);transition:background .1s}.dp-lib-row:hover{background:var(--bg3)}.dp-lib-title{font-size:11px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.dp-lib-artist{font-size:10px;color:var(--muted)}.dp-actions-row{display:flex;gap:6px;padding:8px 12px 4px}.dp-action-btn{padding:5px 10px;background:none;border:1px solid var(--border);border-radius:5px;color:var(--text);font-size:11px;cursor:pointer;transition:border-color .15s,color .15s;white-space:nowrap}.dp-action-btn:hover{border-color:var(--accent);color:var(--accent)}.dp-action-btn--primary{background:var(--accent);color:#fff;border-color:var(--accent)}.dp-action-btn--primary:hover{opacity:.85;color:#fff}.dp-seed-row{display:flex;align-items:center;justify-content:space-between;padding:4px 12px;gap:8px}.dp-seed-info{font-size:10px;color:var(--muted);flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dp-links-row{display:flex;gap:4px;padding:4px 12px 8px;flex-wrap:wrap}.dp-link-btn{font-size:10px;padding:3px 8px;background:none;border:1px solid var(--border);border-radius:4px;color:var(--muted);cursor:pointer;transition:color .15s,border-color .15s;white-space:nowrap}.dp-link-btn:hover{color:var(--accent);border-color:var(--accent)}.dp-genre-filter{width:calc(100% - 24px);margin:4px 12px 8px;padding:5px 8px;background:var(--bg2);border:1px solid var(--border);border-radius:5px;color:var(--text);font-size:11px;outline:none}.dp-loading{padding:12px;font-size:11px;color:var(--muted);font-family:var(--font-mono)}.dp-result-row{display:flex;align-items:center;gap:6px;padding:6px 12px;border-top:1px solid var(--border);cursor:pointer;transition:background .1s}.dp-result-row:hover{background:var(--bg3)}.dp-result-thumb{width:32px;height:32px;border-radius:3px;object-fit:cover;flex-shrink:0}.dp-result-thumb--empty{background:var(--bg3);width:32px;height:32px;border-radius:3px;flex-shrink:0}.dp-result-info{flex:1;min-width:0}.dp-result-title{font-size:11px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dp-result-artist{font-size:10px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dp-result-pct{font-size:10px;color:var(--muted);font-family:var(--font-mono);flex-shrink:0}.dp-result-pct.clap{color:var(--accent);font-weight:600}.dp-result-btns{display:flex;gap:3px;flex-shrink:0;position:relative}.dp-result-btn{padding:3px 6px;background:none;border:1px solid var(--border);border-radius:3px;color:var(--muted);font-size:10px;cursor:pointer;white-space:nowrap;transition:color .1s,border-color .1s}.dp-result-btn:hover{color:var(--text);border-color:#fff3}.dp-result-btn--menu{padding:3px 5px;letter-spacing:1px}@media (max-width: 768px){.discovery-detail-col{display:none!important}}.right-refresh-btn{padding:4px 10px;background:none;border:1px solid var(--accent);border-radius:6px;color:var(--accent);font-size:11px;cursor:pointer;margin-right:6px;transition:background .15s}.right-refresh-btn:hover{background:rgba(var(--accent-rgb, 120,220,160),.1)}.queue-view{display:flex;flex-direction:column;height:100%;overflow:hidden}.queue-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--border);flex-shrink:0;gap:12px}.queue-header-left{display:flex;align-items:center;gap:10px}.queue-title{font-size:14px;font-weight:600;color:var(--text)}.queue-meta{font-size:11px;color:var(--muted)}.queue-header-right{display:flex;align-items:center;gap:8px}.queue-run-btn{padding:6px 14px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;transition:opacity .15s}.queue-run-btn:hover{opacity:.85}.queue-running-label{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted)}.queue-clear-btn,.queue-close-btn{padding:5px 10px;background:none;border:1px solid var(--border);border-radius:6px;color:var(--muted);font-size:12px;cursor:pointer;transition:color .15s,border-color .15s}.queue-clear-btn:hover,.queue-close-btn:hover{color:var(--text);border-color:#fff3}.queue-cards{flex:1;overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column;gap:12px}.queue-card{border:1px solid var(--border);border-radius:10px;overflow:hidden;background:var(--bg2)}.queue-card--running{border-color:var(--accent)}.queue-card--done{border-color:#ffffff1a}.queue-card--error{border-color:#ef4444}.queue-card-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;gap:12px}.queue-card-seed{display:flex;align-items:center;gap:10px;min-width:0}.queue-card-thumb{width:36px;height:36px;border-radius:4px;object-fit:cover;flex-shrink:0}.queue-card-seed-artist{font-size:12px;font-weight:600;color:var(--text)}.queue-card-seed-title{font-size:11px;color:var(--muted)}.queue-card-status{display:flex;align-items:center;gap:8px;flex-shrink:0}.queue-status-badge{font-size:11px;padding:2px 8px;border-radius:10px;background:var(--bg3);color:var(--muted)}.queue-status-badge--running{background:rgba(var(--accent-rgb, 120,220,160),.15);color:var(--accent);display:flex;align-items:center;gap:4px}.queue-status-badge--done{background:#78dca01a;color:#6ee7b7}.queue-status-badge--error{background:#ef44441a;color:#f87171}.queue-card-remove{background:none;border:none;color:var(--muted);cursor:pointer;font-size:14px;padding:2px 4px;line-height:1;transition:color .15s}.queue-card-remove:hover{color:#f87171}.queue-card-results{padding:0 14px 12px;display:flex;flex-direction:column;gap:4px}.queue-result-row{display:flex;align-items:center;gap:8px;padding:5px 6px;border-radius:6px;transition:background .1s}.queue-result-row:hover{background:var(--hover)}.queue-result-thumb{width:28px;height:28px;border-radius:3px;object-fit:cover;flex-shrink:0}.queue-result-thumb--empty{background:var(--bg3);display:flex;align-items:center;justify-content:center}.queue-result-info{flex:1;min-width:0}.queue-result-title{font-size:12px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.queue-result-artist{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.queue-result-actions{display:flex;gap:4px;flex-shrink:0}.queue-result-btn{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:none;border:1px solid var(--border);border-radius:4px;color:var(--muted);font-size:10px;cursor:pointer;transition:color .15s,border-color .15s}.queue-result-btn:hover{color:var(--text);border-color:#fff3}.queue-result-btn.is-saved{color:var(--accent);border-color:var(--accent)}.queue-card-show-all{margin-top:6px;padding:6px;background:none;border:1px dashed var(--border);border-radius:6px;color:var(--muted);font-size:11px;cursor:pointer;text-align:center;width:100%;transition:color .15s,border-color .15s}.queue-card-show-all:hover{color:var(--text);border-color:#fff3}.queue-card-error{padding:6px 14px 10px;font-size:11px;color:#f87171}.queue-float-btn{position:fixed;bottom:24px;right:24px;padding:10px 18px;background:var(--accent);color:#fff;border:none;border-radius:20px;font-size:13px;font-weight:600;cursor:pointer;box-shadow:0 4px 16px #0006;z-index:200;transition:opacity .15s,transform .1s}.queue-float-btn:hover{opacity:.9;transform:translateY(-1px)}.recent-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;padding:16px}.recent-card{background:var(--bg2);border:1px solid var(--border);border-radius:6px;overflow:hidden;cursor:pointer;transition:border-color .15s,transform .15s;display:flex;flex-direction:column}.recent-card:hover{border-color:#ffffff26;transform:translateY(-2px)}.recent-card-art-wrap{position:relative;width:100%;aspect-ratio:1;flex-shrink:0}.recent-card-art{width:100%;height:100%;object-fit:cover;display:block}.recent-card-art--empty{width:100%;height:100%;background:var(--bg3);display:flex;align-items:center;justify-content:center}.recent-card-initials{font-size:32px;font-weight:700;color:var(--muted);opacity:.4}.recent-card-play{position:absolute;bottom:8px;right:8px;width:32px;height:32px;border-radius:50%;background:var(--accent);border:none;color:#fff;font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s;padding-left:2px;box-shadow:0 2px 8px #0000004d}.recent-card:hover .recent-card-play,.recent-card-play.playing{opacity:1}.recent-card-info{padding:10px 12px 8px;flex:1;min-height:0}.recent-card-title{font-size:13px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}.recent-card-artist{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.recent-card-genre{font-size:10px;color:var(--muted);margin-top:4px;opacity:.7;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.recent-card-actions{display:flex;gap:6px;padding:0 10px 10px}.recent-card-save{width:28px;height:28px;border-radius:6px;background:var(--bg3);border:1px solid var(--border);color:var(--muted);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:color .1s,border-color .1s}.recent-card-save.saved{color:var(--accent);border-color:var(--accent)}.recent-card-save:hover{color:var(--text)}.recent-card-find{flex:1;padding:6px 8px;background:none;border:1px solid var(--border);border-radius:6px;color:var(--muted);font-size:11px;cursor:pointer;white-space:nowrap;transition:color .15s,border-color .15s}.recent-card-find:hover{color:var(--accent);border-color:var(--accent)}.recent-seeds-list{display:flex;flex-direction:column}.recent-seed-row{display:flex;align-items:center;gap:10px;padding:10px 16px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .1s}.recent-seed-row:hover,.recent-seed-row.active{background:var(--bg3)}.recent-seed-art{width:40px;height:40px;border-radius:6px;overflow:hidden;flex-shrink:0}.recent-seed-art img{width:100%;height:100%;object-fit:cover;display:block}.recent-seed-art--empty{width:100%;height:100%;background:var(--bg3);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:var(--muted)}.recent-seed-info{flex:1;min-width:0}.recent-seed-title{font-size:13px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.recent-seed-artist{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.recent-seed-time{font-size:10px;color:var(--muted);opacity:.6;margin-top:1px}.recent-seed-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.recent-seed-play-btn{width:28px;height:28px;background:none;border:1px solid var(--border);border-radius:50%;color:var(--muted);font-size:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:color .15s,border-color .15s;opacity:0}.recent-seed-row:hover .recent-seed-play-btn{opacity:1}.recent-seed-play-btn:hover{color:var(--accent);border-color:var(--accent)}.recent-seed-find-btn{padding:5px 12px;background:none;border:1px solid var(--border);border-radius:6px;color:var(--muted);font-size:11px;cursor:pointer;white-space:nowrap;transition:color .15s,border-color .15s}.recent-seed-find-btn:hover{color:var(--accent);border-color:var(--accent)}.recent-seed-remove-btn{background:none;border:none;color:var(--muted);font-size:16px;cursor:pointer;padding:4px;opacity:0;transition:opacity .15s,color .15s}.recent-seed-row:hover .recent-seed-remove-btn{opacity:1}.recent-seed-remove-btn:hover{color:#ef4444}.library-row-find-btn{padding:3px 8px;background:transparent;border:1px solid var(--accent);border-radius:20px;color:var(--accent);font-size:11px;cursor:pointer;white-space:nowrap;opacity:0;transition:opacity .15s,background .15s,color .15s;flex-shrink:0}.library-row:hover .library-row-find-btn{opacity:1}.library-row-find-btn:hover{background:var(--accent);color:#080809}@media (max-width: 768px){html,body{overscroll-behavior:none}.explore-sidebar{display:none!important}.explore-page{flex-direction:column;height:100vh;height:100dvh;overflow:hidden}.explore-center{overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding-bottom:140px}.explore-right,.discovery-detail-col{display:none!important}.explore-search-bar{border-radius:0;border-left:none;border-right:none}.explore-search-input{font-size:16px}.landing-page{padding:32px 16px 80px}.landing-search-wrap{max-width:100%}.landing-search-bar{border-radius:12px}.landing-filters-row{flex-direction:column;align-items:stretch;gap:12px}.landing-filter-select{font-size:14px}.landing-recs-grid{grid-template-columns:repeat(2,1fr);gap:10px}.seed-picker-row{padding:12px;min-height:60px}.seed-picker-find-btn{padding:6px 10px;font-size:11px}.discovery-layout{padding-bottom:140px}.discovery-results-col{-webkit-overflow-scrolling:touch}.discovery-breadcrumb{flex-wrap:wrap;gap:8px;padding:10px 12px}.discovery-seed-info{display:none}.discovery-result-row,.discovery-result-header{min-height:56px;padding:10px 12px}.recent-grid{grid-template-columns:repeat(2,1fr);gap:10px;padding:12px}.library-table-header span:nth-child(5),.library-table-header span:nth-child(6),.library-table-header span:nth-child(7),.library-row>span:nth-child(5),.library-row>span:nth-child(6),.library-row>span:nth-child(7){display:none}.library-row{min-height:52px}.library-row-play{min-height:44px;min-width:44px}.player-bar{bottom:49px;left:0;right:0;border-radius:0;border-left:none;border-right:none}.player-scrubber-row .waveform-scrubber{height:24px}.track-menu{position:fixed!important;bottom:0!important;left:0!important;right:0!important;top:auto!important;border-radius:16px 16px 0 0!important;min-width:100%!important;max-height:70vh;overflow-y:auto;padding-bottom:env(safe-area-inset-bottom);z-index:500!important}.track-menu:before{content:"";display:block;width:36px;height:4px;background:var(--border);border-radius:2px;margin:10px auto 6px}.track-menu-item{padding:14px 20px;font-size:15px;border-bottom:1px solid var(--border)}.track-dropdown-submenu{position:fixed!important;bottom:0!important;left:0!important;right:0!important;top:auto!important;border-radius:16px 16px 0 0!important;max-height:70vh;overflow-y:auto;padding-bottom:env(safe-area-inset-bottom)}.discovery-result-find-btn,.discovery-result-menu-btn,.find-similar-btn,.recent-card-save,.seed-picker-menu-btn{min-height:36px}.queue-float-btn{bottom:72px;right:12px}}.mobile-tab-bar{display:none}@media (max-width: 768px){.mobile-tab-bar{display:flex;position:fixed;bottom:0;left:0;right:0;height:52px;background:var(--bg2);border-top:1px solid var(--border);z-index:100;padding-bottom:env(safe-area-inset-bottom)}.mobile-tab-btn{flex:1;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--muted);cursor:pointer;font-size:12px;font-weight:500;transition:color .15s;padding:0;-webkit-tap-highlight-color:transparent}.mobile-tab-btn.active{color:var(--accent)}}.mobile-bottom-sheet-overlay,.mobile-bottom-sheet{display:none}@media (max-width: 768px){.mobile-bottom-sheet-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:300;opacity:0;pointer-events:none;transition:opacity .25s}.mobile-bottom-sheet-overlay.open{opacity:1;pointer-events:all}.mobile-bottom-sheet{display:block;position:fixed;bottom:0;left:0;right:0;background:var(--bg2);border-radius:16px 16px 0 0;z-index:301;max-height:85vh;overflow-y:auto;-webkit-overflow-scrolling:touch;transform:translateY(100%);transition:transform .3s cubic-bezier(.32,.72,0,1);padding-bottom:env(safe-area-inset-bottom)}.mobile-bottom-sheet.open{transform:translateY(0)}.mobile-bottom-sheet-handle{width:36px;height:4px;background:var(--border);border-radius:2px;margin:12px auto 8px}}@media (max-width: 768px){.seed-picker-row{flex-wrap:nowrap;align-items:center;padding:10px 12px;gap:8px}.seed-picker-info{flex:1;min-width:0}.seed-picker-find-btn{flex-shrink:0;font-size:12px;padding:6px 10px;white-space:nowrap}.seed-picker-source,.seed-picker-menu-wrap{flex-shrink:0}}@media (max-width: 768px){:root{--nav-height: 49px;--player-height: 80px}.explore-center,.center-results,.discovery-results-col,.recent-seeds-list,.library-table,.playlist-view,.queue-cards,.landing-page{padding-bottom:calc(var(--nav-height) + 8px)}.seed-picker-row:last-child{border-bottom:none}}@media (max-width: 768px){.explore-page--has-player .explore-center,.explore-page--has-player .center-results,.explore-page--has-player .discovery-results-col,.explore-page--has-player .recent-seeds-list,.explore-page--has-player .library-table,.explore-page--has-player .playlist-view,.explore-page--has-player .queue-cards,.explore-page--has-player .landing-page{padding-bottom:calc(var(--player-height, 80px) + var(--nav-height, 49px) + 8px)}}@media (max-width: 768px){.discovery-breadcrumb{padding:8px 12px;gap:6px}.discovery-trail{display:none}.discovery-back-btn{font-size:13px;padding:6px 12px}.discovery-new-search-btn{font-size:12px;padding:6px 10px}.discovery-filter-bar{flex-wrap:wrap;gap:8px;padding:8px 12px}.filter-input{width:50px;font-size:14px}.filter-select{font-size:14px}}@media (max-width: 768px){.discovery-result-row,.discovery-result-header{padding:12px;min-height:60px}.discovery-result-thumb-wrap,.discovery-result-thumb{width:48px;height:48px}.discovery-result-title{font-size:14px}.discovery-result-artist{font-size:12px}.discovery-result-find-btn,.discovery-result-menu-btn{width:36px;height:36px;font-size:16px}.find-similar-btn{font-size:12px}}.library-row-bpm,.library-row-key,.discovery-result-pct,.detail-panel-bpm-key,.filter-input,.player-time,.clap-score{font-family:var(--font-mono);font-size:11px;letter-spacing:-.02em}.seed-picker-row,.discovery-result-row,.library-row,.recent-seed-row{border-radius:0}.landing-rec-art-wrap{position:relative}.landing-rec-art-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:40px;height:40px;border-radius:50%;background:#000000a6;border:none;color:#fff;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding-left:2px;opacity:0;transition:opacity .15s;-webkit-tap-highlight-color:transparent}.landing-rec-card:hover .landing-rec-art-play{opacity:1}@media (max-width: 768px){.landing-rec-art-play{opacity:1}}.player-thumb{width:36px;height:36px;border-radius:4px;object-fit:cover;flex-shrink:0}.player-btn--stop{font-size:10px}@media (max-width: 768px){.player-bar{transform:none;width:100vw;left:0;right:0;bottom:49px;z-index:90;border-radius:0;border-left:none;border-right:none;border-bottom:none;display:flex;flex-direction:column;gap:6px;padding:8px 12px 10px;animation:slideUpPlayer .25s ease}@keyframes slideUpPlayer{0%{transform:translateY(100%)}to{transform:translateY(0)}}.player-thumb{width:40px;height:40px;border-radius:6px}.player-top-row{gap:10px;flex-wrap:nowrap}.player-track-info{min-width:0;flex:1}.player-controls{flex-shrink:0}.player-scrubber-row{display:flex;align-items:center;gap:6px;width:100%}.player-scrubber-row .player-time{flex-shrink:0;min-width:28px}.player-scrubber-row .waveform-scrubber{flex:1;min-width:0}.player-menu-wrap{display:block}.player-btn--stop{display:none}.player-menu-dropdown{position:fixed;bottom:0;left:0;right:0;top:auto;margin:0;border-radius:16px 16px 0 0;border:none;border-top:1px solid var(--border);padding:8px 0 calc(8px + env(safe-area-inset-bottom));z-index:600}.player-menu-dropdown:before{content:"";display:block;width:36px;height:4px;background:var(--border);border-radius:2px;margin:4px auto 8px}.track-dropdown-item{padding:12px 20px;font-size:15px}}.mobile-settings-panel{padding:24px 16px;display:flex;flex-direction:column;gap:24px}.mobile-settings-section{display:flex;flex-direction:column;gap:2px}.mobile-settings-label{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);padding:0 4px 8px}.mobile-settings-row{display:flex;align-items:center;justify-content:space-between;width:100%;padding:14px 16px;background:var(--bg2);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:15px;cursor:pointer;text-align:left;font-family:var(--font-ui);-webkit-tap-highlight-color:transparent}.mobile-settings-row--danger{color:#ef4444}.mobile-settings-arrow{font-size:18px;color:var(--muted);line-height:1}.mobile-settings-note{font-size:12px;color:var(--muted);padding:6px 4px 0}.mbs-content{padding:0 16px 32px;display:flex;flex-direction:column;align-items:center;gap:0}.mbs-art{width:140px;height:140px;border-radius:10px;object-fit:cover;margin-bottom:16px;box-shadow:0 8px 24px #0006}.mbs-info{width:100%;text-align:center;margin-bottom:20px}.mbs-title{font-size:17px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:4px}.mbs-artist{font-size:14px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mbs-meta{font-size:11px;color:var(--muted);margin-top:6px;font-family:var(--font-mono)}.mbs-primary-btns{width:100%;display:flex;flex-direction:column;gap:10px;margin-bottom:12px}.mbs-btn{width:100%;padding:15px;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;font-family:var(--font-ui);-webkit-tap-highlight-color:transparent}.mbs-btn--preview{background:var(--bg3);color:var(--text);border:1px solid var(--border)}.mbs-btn--similar{background:var(--accent);color:#fff}.mbs-secondary-btns{width:100%;display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.mbs-sec-btn{flex:1;min-width:80px;padding:11px 12px;background:none;border:1px solid var(--border);border-radius:10px;color:var(--muted);font-size:13px;cursor:pointer;font-family:var(--font-ui);-webkit-tap-highlight-color:transparent}.mbs-sec-btn--saved{color:var(--accent);border-color:var(--accent)}.mbs-library{width:100%;padding-top:12px;border-top:1px solid var(--border)}.mbs-library-label{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}.mbs-library-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border)}.mbs-library-title{font-size:13px;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.mbs-library-artist{font-size:12px;color:var(--muted);flex-shrink:0;margin-left:8px}.landing-filter-input{background:var(--bg2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:13px;padding:6px 8px;width:62px;-moz-appearance:textfield}.landing-filter-input::-webkit-outer-spin-button,.landing-filter-input::-webkit-inner-spin-button{-webkit-appearance:none}.landing-filter-sep{font-size:12px;color:var(--muted)}.search-prefilters{display:flex;gap:10px;align-items:center;flex-wrap:wrap;justify-content:center;padding:10px 16px;background:var(--bg2);border:1px solid var(--border);border-radius:12px;margin-bottom:12px}.search-prefilter-group{display:flex;align-items:center;gap:5px}.search-prefilter-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;white-space:nowrap}.search-prefilter-select{background:var(--bg3);border:1px solid var(--border);border-radius:7px;color:var(--text);font-size:12px;padding:5px 8px;cursor:pointer}.search-prefilter-input{background:var(--bg3);border:1px solid var(--border);border-radius:7px;color:var(--text);font-size:12px;padding:5px 7px;width:58px;-moz-appearance:textfield}.search-prefilter-input::-webkit-outer-spin-button,.search-prefilter-input::-webkit-inner-spin-button{-webkit-appearance:none}.search-prefilter-sep{font-size:11px;color:var(--muted)}.search-prefilter-harmonic{display:flex;align-items:center;gap:6px;cursor:pointer}.search-prefilter-clear{font-size:11px;color:var(--muted);background:none;border:none;cursor:pointer;padding:4px 6px;margin-left:4px}.search-prefilter-clear:hover{color:var(--text)}@media (max-width: 768px){.search-prefilters{padding:8px 12px;gap:8px}.search-prefilter-input{font-size:16px;width:64px}.search-prefilter-select,.landing-filter-input{font-size:16px}}.landing-filter-select--genre,.dp-genre-filter,.search-prefilter-select{max-width:180px}optgroup{font-size:11px;color:var(--muted)}.format-seg{display:flex;background:var(--bg3);border:1px solid var(--border);border-radius:7px;overflow:hidden;flex-shrink:0}.format-seg-btn{padding:4px 10px;font-size:11px;font-weight:500;background:none;border:none;color:var(--muted);cursor:pointer;transition:background .12s,color .12s;font-family:inherit;white-space:nowrap}.format-seg-btn.active{background:var(--accent);color:var(--bg);font-weight:600}.format-seg-btn:not(.active):hover{background:#ffffff0d;color:var(--text)}.filter-active-indicator{font-size:10px;font-weight:600;font-family:var(--font-mono);color:var(--accent);padding:3px 7px;background:#7fff6e14;border:1px solid rgba(127,255,110,.2);border-radius:10px;white-space:nowrap}.filter-clear-btn{font-size:11px;color:var(--muted);background:none;border:1px solid var(--border);border-radius:5px;padding:3px 8px;cursor:pointer;transition:color .12s,border-color .12s;white-space:nowrap}.filter-clear-btn:hover{color:var(--text);border-color:#fff3}.sidebar-playlist-row{display:flex;align-items:center;gap:6px;padding:7px 14px;cursor:pointer;width:100%;border-left:2px solid transparent;transition:background .1s,border-color .1s;font-family:var(--font-ui);position:relative}.sidebar-playlist-row:hover{background:#ffffff0a}.sidebar-playlist-row.active{border-left-color:var(--accent);background:#b8f0500f}.sidebar-playlist-row.active .sidebar-item-label{color:var(--accent)}.sidebar-playlist-row .sidebar-item-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:500;color:var(--text)}.sidebar-playlist-menu-btn{background:none;border:none;color:var(--muted);font-size:13px;padding:0 4px;cursor:pointer;opacity:0;transition:opacity .12s,color .12s;line-height:1;flex-shrink:0}.sidebar-playlist-row:hover .sidebar-playlist-menu-btn{opacity:1}.sidebar-playlist-menu-btn:hover{color:var(--text)}.sidebar-playlist-menu{position:absolute;right:10px;top:calc(100% + 2px);background:var(--bg2);border:1px solid var(--border);border-radius:8px;box-shadow:0 8px 24px #0006;z-index:100;min-width:120px;overflow:hidden}.sidebar-playlist-menu button{display:block;width:100%;text-align:left;padding:9px 14px;font-size:13px;background:none;border:none;color:var(--text);cursor:pointer;font-family:inherit;transition:background .1s}.sidebar-playlist-menu button:hover{background:#ffffff0f}.sidebar-playlist-menu button.danger{color:#ef4444}.sidebar-playlist-menu button.danger:hover{background:#ef444414}.sidebar-new-playlist-btn{background:none;border:none;color:var(--muted);font-size:15px;padding:0 2px;cursor:pointer;line-height:1;transition:color .12s}.sidebar-new-playlist-btn:hover{color:var(--accent)}.sidebar-new-playlist-input-wrap{padding:4px 10px}.sidebar-inline-input{width:100%;background:var(--bg3);border:1px solid rgba(127,255,110,.3);border-radius:6px;padding:5px 8px;color:var(--text);font-size:12px;font-family:var(--font-ui);outline:none}.landing-genre-multi{position:relative;display:inline-block}.landing-genre-trigger{display:flex;align-items:center;gap:6px;background:var(--bg2);border:1px solid var(--border);border-radius:8px;padding:5px 10px;color:var(--text);font-size:12px;font-family:var(--font-ui);cursor:pointer;white-space:nowrap;transition:border-color .15s}.landing-genre-trigger:hover{border-color:#ffffff26}.landing-genre-caret{font-size:8px;color:var(--muted)}.landing-genre-dropdown{position:absolute;top:calc(100% + 4px);left:0;background:var(--bg2);border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 32px #00000080;z-index:200;max-height:320px;overflow-y:auto;min-width:220px;padding:4px 0 8px}.landing-genre-search{display:block;width:calc(100% - 20px);margin:6px 10px 4px;padding:6px 10px;background:var(--bg3, rgba(255,255,255,.06));border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:12px;outline:none}.landing-genre-search:focus{border-color:var(--accent)}.landing-genre-group-label{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);padding:8px 14px 4px;font-family:var(--font-mono)}.landing-genre-option{display:flex;align-items:center;gap:8px;padding:5px 14px;font-size:12px;color:var(--text);cursor:pointer;transition:background .1s}.landing-genre-option:hover{background:#ffffff0a}.landing-genre-option input[type=checkbox]{accent-color:var(--accent);cursor:pointer}.landing-genre-pills{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px;max-width:300px}.landing-genre-pill{display:flex;align-items:center;gap:4px;background:#7fff6e1a;border:1px solid rgba(127,255,110,.25);border-radius:20px;padding:2px 8px;font-size:11px;color:var(--accent);white-space:nowrap}.landing-genre-pill button{background:none;border:none;color:var(--accent);font-size:13px;padding:0;cursor:pointer;line-height:1;opacity:.7;font-family:inherit}.landing-genre-pill button:hover{opacity:1}@media (max-width: 768px){.landing-genre-dropdown{min-width:180px;max-height:250px}.format-seg-btn{padding:4px 8px;font-size:10px}.landing-filter-select{font-size:16px}}.landing-recs-sparse-notice{font-size:12px;color:var(--muted);padding:8px 0 4px;font-family:var(--font-mono)}.landing-recs-empty{font-size:13px;color:var(--muted);padding:32px 0;text-align:center}.filter-action-btn{font-size:11px;font-family:var(--font-mono);color:var(--muted);background:none;border:1px solid var(--border);border-radius:5px;padding:3px 8px;cursor:pointer;white-space:nowrap;transition:color .12s,border-color .12s}.filter-action-btn:hover{color:var(--text);border-color:#fff3}.player-btn--play{background:var(--accent);color:#080809;border-color:transparent;width:36px;height:36px}.player-btn--play:hover{background:var(--accent);filter:brightness(1.1);border-color:transparent}.player-btn--queue{display:flex;align-items:center;justify-content:center;position:relative}.player-btn--queue.active{color:var(--accent);border-color:#b8f05066}.player-queue-badge{font-size:11px;font-family:var(--font-mono);font-variant-numeric:tabular-nums}.queue-panel{position:fixed;bottom:80px;right:0;width:280px;max-height:360px;background:var(--bg2);border:1px solid var(--border);border-right:none;border-bottom:none;border-radius:8px 0 0;display:flex;flex-direction:column;z-index:200;box-shadow:-4px -4px 20px #0006}.queue-panel-header{display:flex;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid var(--border);flex-shrink:0}.queue-panel-title{font-size:11px;color:var(--muted);flex:1;font-family:var(--font-mono)}.queue-panel-clear,.queue-panel-close{font-size:11px;color:var(--muted);background:none;border:none;cursor:pointer;padding:2px 4px;line-height:1;font-family:inherit}.queue-panel-clear:hover,.queue-panel-close:hover{color:var(--text)}.queue-panel-close{font-size:15px}.queue-panel-list{overflow-y:auto;flex:1}.queue-panel-row{display:flex;align-items:center;gap:8px;padding:6px 12px;border-bottom:1px solid var(--border)}.queue-panel-row:last-child{border-bottom:none}.queue-panel-thumb{width:32px;height:32px;border-radius:3px;background:var(--bg3);flex-shrink:0;overflow:hidden;display:flex;align-items:center;justify-content:center}.queue-panel-info{flex:1;min-width:0}.queue-panel-track{font-size:12px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.queue-panel-artist{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.queue-panel-remove{font-size:14px;color:var(--muted);background:none;border:none;cursor:pointer;padding:0 2px;line-height:1;flex-shrink:0}.queue-panel-remove:hover{color:var(--text)}@media (max-width: 768px){.queue-panel{width:100%;right:0;border-radius:8px 8px 0 0;border-right:1px solid var(--border)}}.sidebar-rb-badge{font-size:9px;font-weight:600;color:var(--muted);background:var(--surface2);border-radius:3px;padding:1px 4px;margin-left:4px;letter-spacing:.05em;flex-shrink:0}.corpus-gap-notice{margin:12px 0 4px;padding:10px 14px;background:var(--surface2);border-left:3px solid var(--accent);border-radius:0 6px 6px 0;font-size:12px;color:var(--muted);line-height:1.5}.corpus-gap-notice strong{color:var(--text)}.ac-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--surface);border:1px solid var(--border, #333);border-radius:8px;max-height:320px;overflow-y:auto;z-index:9999;box-shadow:0 8px 24px #0006}.ac-item{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;cursor:pointer;gap:10px}.ac-item:hover,.ac-item--active{background:var(--surface2, #222)}.ac-label{font-weight:600;font-size:13px;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.ac-type{font-size:11px;color:var(--muted);flex-shrink:0;opacity:.7}.insights-page{flex:1;display:flex;flex-direction:column;overflow-y:auto;padding:24px;gap:20px}.insights-empty{align-items:center;justify-content:center;gap:12px;overflow:hidden}.insights-empty-icon{font-size:28px;color:var(--muted);opacity:.4}.insights-empty-text{font-size:14px;color:var(--muted)}.stat-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;flex-shrink:0}.stat-card{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:18px 20px}.stat-label{font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}.stat-value{font-size:24px;font-weight:500;color:var(--text);line-height:1;margin-bottom:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stat-sub{font-size:11px}.chart-panel{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:20px}.chart-title{font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:20px}.chart-empty{font-size:12px;padding:16px 0}.bar-chart{display:flex;align-items:flex-end;gap:6px;height:180px}.bar-group{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;height:100%}.bar-count{font-size:10px;color:var(--muted);min-height:14px;line-height:14px}.bar-wrap{flex:1;width:100%;display:flex;align-items:flex-end}.bar-fill{width:100%;background:var(--bg3);border:1px solid rgba(255,255,255,.06);border-radius:3px 3px 0 0;transition:opacity .15s;min-height:0}.bar-fill--peak{background:var(--accent);border-color:transparent;opacity:.85}.bar-fill:not(.bar-fill--peak):hover{background:var(--muted);opacity:.5}.bar-fill--peak:hover{opacity:1}.bar-label{font-size:9px;color:var(--muted);white-space:nowrap;font-family:var(--font-mono);text-align:center}.chart-panel--network{min-height:540px}.genre-network-wrap{position:relative;width:100%}.genre-network-svg{display:block;width:100%;background:transparent;border-radius:6px}.genre-node--primary circle{animation:genre-pulse 2.5s ease-in-out infinite}@keyframes genre-pulse{0%,to{opacity:1}50%{opacity:.65}}.genre-network-loading{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted);padding:32px 0;font-family:var(--font-mono)}.genre-network-spinner{display:inline-block;width:14px;height:14px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.genre-network-notice{font-size:10px;color:var(--muted);margin-bottom:6px;opacity:.7}.genre-network-drag-hint{position:absolute;bottom:10px;left:50%;transform:translate(-50%);font-size:10px;color:var(--muted);font-family:var(--font-mono);pointer-events:none;transition:opacity .8s ease}.gaps-panel{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:20px;flex-shrink:0}.gaps-all-clear{font-size:13px;font-weight:500;color:var(--accent);padding:4px 0}.gaps-list{display:flex;flex-direction:column;gap:8px}.gap-card{background:#f5a6231f;border:1px solid rgba(245,166,35,.2);border-radius:7px;padding:10px 14px;font-size:13px;color:#f5c842;line-height:1.4}.gn-controls{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;gap:12px}.gn-mode-toggle{display:flex;background:var(--bg3);border:1px solid var(--border);border-radius:7px;overflow:hidden;flex-shrink:0}.gn-mode-btn{padding:5px 14px;font-size:11px;font-weight:500;background:none;border:none;color:var(--muted);cursor:pointer;transition:background .15s,color .15s;font-family:inherit}.gn-mode-btn.active{background:var(--accent);color:#080809;font-weight:600}.gn-mode-btn:not(.active):hover{background:#ffffff0d;color:var(--text)}.gn-node-count{font-size:11px;font-family:var(--font-mono)}.gn-circle{transition:r .15s}.gn-pulse-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}@keyframes gn-node-pulse{0%{r:attr(r px);opacity:1}50%{opacity:.4}to{opacity:1}}.gn-genre-panel{margin-top:16px;background:var(--bg3);border:1px solid var(--border);border-radius:10px;overflow:hidden;animation:gn-slide-up .25s ease}@keyframes gn-slide-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.gn-genre-panel-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border)}.gn-genre-panel-title{font-size:12px;font-weight:600;color:var(--text);letter-spacing:.02em}.gn-genre-panel-close{background:none;border:none;color:var(--muted);font-size:13px;cursor:pointer;padding:2px 6px;border-radius:4px;line-height:1}.gn-genre-panel-close:hover{color:var(--text)}.gn-genre-panel-loading,.gn-genre-panel-empty{display:flex;align-items:center;gap:8px;padding:20px 16px;font-size:12px;color:var(--muted)}.gn-tracks-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1px;background:var(--border)}.gn-track-card{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--bg3);transition:background .12s}.gn-track-card:hover{background:var(--bg2)}.gn-track-thumb-wrap{position:relative;width:38px;height:38px;flex-shrink:0;cursor:pointer}.gn-track-thumb{width:38px;height:38px;border-radius:4px;object-fit:cover;display:block}.gn-track-thumb--empty{background:var(--bg2);border:1px solid var(--border);border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--muted)}.gn-track-thumb-overlay{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:4px;background:#0000008c;display:flex;align-items:center;justify-content:center;font-size:11px;color:#fff;opacity:0;transition:opacity .15s}.gn-track-thumb-wrap:hover .gn-track-thumb-overlay,.gn-track-thumb-overlay.playing{opacity:1}.gn-track-info{flex:1;min-width:0}.gn-track-title{font-size:12px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gn-track-artist{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gn-find-btn{background:none;border:1px solid var(--border);border-radius:5px;color:var(--muted);font-size:14px;width:26px;height:26px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:color .12s,border-color .12s}.gn-find-btn:hover{color:var(--accent);border-color:var(--accent)}.gn-tooltip{position:absolute;pointer-events:none;background:var(--bg);border:1px solid var(--border);border-radius:7px;padding:7px 11px;z-index:20;min-width:100px;box-shadow:0 4px 16px #0000004d;white-space:nowrap}.gn-tooltip-genre{font-size:12px;font-weight:600;line-height:1.3;margin-bottom:2px}.gn-tooltip-count{font-size:10px;color:var(--muted);font-family:var(--font-mono)}.gn-genre-panel-actions{display:flex;align-items:center;gap:8px}.gn-explore-genre-btn{background:var(--accent);border:none;border-radius:6px;color:#080809;font-size:11px;font-weight:600;padding:5px 12px;cursor:pointer;transition:opacity .15s;font-family:inherit;white-space:nowrap}.gn-explore-genre-btn:hover{opacity:.85}.muted{color:var(--muted)}.mono{font-family:var(--font-mono)}.app-shell{display:flex;flex-direction:column;height:100vh;overflow:hidden}.app-body{display:flex;flex:1;overflow:hidden}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{color-scheme:dark;--bg: #0A0A0C;--bg2: #111116;--bg3: #18181F;--border: rgba(255,255,255,.06);--text: #E8E8EC;--muted: #9898a8;--accent: #4a9eff;--accent2: #60c4ff;--surface: #111116;--surface-2: #18181F;--font-ui: "Space Grotesk", system-ui, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--topnav-height: 56px;--sidebar-width: 240px;--detail-width: 300px}[data-theme=light]{color-scheme:light;--bg: #F2F2EE;--bg2: #FFFFFF;--bg3: #E8E8E4;--border: rgba(0,0,0,.08);--text: #0A0A0C;--muted: #888892;--accent: #1a5cc4;--accent2: #1348a0;--surface: #FFFFFF;--surface-2: #F2F2EE}html,body,#root{height:100%;background:var(--bg);color:var(--text);font-family:var(--font-ui);font-size:14px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none}button{font-family:var(--font-ui);cursor:pointer}input,textarea,select{font-family:var(--font-ui)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--muted);border-radius:3px;opacity:.4}::-webkit-scrollbar-thumb:hover{opacity:.7}
