:root{--header-height: 40px;--topbar-height: 56px;--player-bar-height: 64px;--font-family: "Nunito", system-ui, sans-serif;--color-surface: #fbfaf8;--color-surface-alt: #f6f4f1;--color-surface-sunken: #f1efe9;--color-surface-hover: #eae7e0;--color-surface-active: #ddd9d0;--color-border: #dad6cd;--color-border-strong: #c5c0b5;--color-text-strong: #262320;--color-text: #383530;--color-text-secondary: #625d55;--color-text-muted: #88837a;--color-text-faint: #aca69d;--color-text-inverse: #ffffff;--color-accent: #8b3a2e;--color-accent-strong: #6e2c22;--color-accent-deep: #4a2018;--color-accent-soft: #d9b3a8;--color-accent-tint: #f0e0da;--color-danger: #e74c3c;--color-danger-strong: #dc2626;--color-danger-soft: #f87171;--color-danger-tint: #fef2f2;--color-success: #16a34a;--color-success-soft: #4ade80;--color-success-tint: #e8f5e9;--color-warning: #f59e0b;--color-warning-strong: #ca8a04;--color-warning-text: #856404;--color-warning-soft: #ffe58f;--color-warning-tint: #fffbeb;--color-spotify: #1db954;--color-spotify-bright: #1ed760;--color-spotlight: #f5c842;--color-spotlight-strong: #e6b830}:root[data-theme=dark]{--color-surface: #1c1c1e;--color-surface-alt: #232326;--color-surface-sunken: #2a2a2e;--color-surface-hover: #333338;--color-surface-active: #3d3d44;--color-border: #3a3a40;--color-border-strong: #4a4a52;--color-text-strong: #f2f2f5;--color-text: #e0e0e4;--color-text-secondary: #a8a8b0;--color-text-muted: #808088;--color-text-faint: #5c5c64;--color-accent: #60a5fa;--color-accent-strong: #3b82f6;--color-accent-deep: #a5b4fc;--color-accent-soft: #1e3a8a;--color-accent-tint: #1e2942;--color-danger-tint: #3a2024;--color-success-tint: #1d3324;--color-warning-tint: #332b14;--color-warning-text: #d4b14a}:root[data-theme=paper]{--font-family: "Iowan Old Style", "Palatino Linotype", Palatino, Georgia, serif;--color-spotlight: #c9a227}*{box-sizing:border-box}html,body{overscroll-behavior:none}body{margin:0;font-family:var(--font-family);font-size:15px;background:var(--color-surface);color:var(--color-text-strong)}#root{min-height:100vh}.skeleton-container{position:absolute;top:0;right:0;bottom:0;left:0;top:var(--topbar-height);bottom:var(--player-bar-height);background:var(--color-surface);z-index:5;overflow:hidden;padding:20px}.skeleton-shimmer{background:linear-gradient(90deg,var(--color-surface-hover) 25%,var(--color-surface-active) 50%,var(--color-surface-hover) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-headers{display:flex;gap:2px;margin-bottom:20px;padding-left:90px}.skeleton-header{width:240px;flex-shrink:0}.skeleton-header-bar{height:44px;border-radius:0}.skeleton-grid{display:flex;flex-direction:column;gap:8px}.skeleton-row{display:flex;gap:2px;align-items:flex-start}.skeleton-year{width:80px;height:28px;flex-shrink:0;display:flex;align-items:center;padding-left:10px;font-size:14px;color:var(--color-border-strong);background:var(--color-surface-alt)}.skeleton-cell{width:240px;flex-shrink:0;display:flex;flex-direction:column;gap:6px;padding:4px}.skeleton-card{height:70px;border-radius:0}.skeleton-chart{display:flex;flex-direction:column}.skeleton-chart-headers{display:flex;gap:4px;margin-bottom:16px}.skeleton-chart-header{width:60px;height:24px;flex-shrink:0}.skeleton-chart-bars{display:flex;gap:4px;align-items:flex-end;height:300px}.skeleton-chart-column{display:flex;flex-direction:column;gap:2px;width:60px}.skeleton-chart-bar{width:100%;border-radius:0}.timeline{position:relative;min-height:100vh}.topbar{position:fixed;top:0;left:0;right:0;height:var(--topbar-height);display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:0 20px;background:var(--color-surface);border-bottom:1px solid var(--color-surface-active);z-index:10}.topbar-left{display:flex;align-items:center;gap:12px;justify-self:start}.topbar-center{justify-self:center;display:flex;align-items:center;gap:8px}.filter-nav-arrows{display:flex;align-items:center;gap:2px;margin-left:4px}.filter-nav-arrows.is-pending{opacity:.7}.filter-nav-arrows.is-pending .filter-nav-count{animation:filter-pending-pulse 1s ease-in-out infinite}@keyframes filter-pending-pulse{0%,to{opacity:.5}50%{opacity:1}}.filter-nav-btn{background:none;border:none;padding:2px 4px;cursor:pointer;color:var(--color-text-secondary);font-size:11px;line-height:1}.filter-nav-btn:hover{color:var(--color-text)}.filter-nav-btn:active{color:var(--color-text-strong)}.filter-nav-count{font-size:11px;color:var(--color-text-secondary);min-width:36px;text-align:center;font-variant-numeric:tabular-nums}.filter-mode-btn{background:transparent;border:none;padding:4px 6px;cursor:pointer;color:var(--color-text-muted);font-size:14px;transition:color .15s}.filter-mode-btn:hover{color:var(--color-text-secondary)}.filter-mode-btn.is-active{color:var(--color-text-strong)}.topbar-controls{display:flex;align-items:center;gap:2px;justify-self:end}.hamburger-button{display:none;background:none;border:none;padding:8px;cursor:pointer;color:var(--color-text);font-size:18px;transition:background .15s,color .15s}.hamburger-button:hover{background:var(--color-surface-hover);color:var(--color-text-strong)}.topbar-controls-collapsible{display:contents}@media (max-width: 1100px){.hamburger-button{display:flex;align-items:center;justify-content:center}.topbar-controls-collapsible{display:none;position:absolute;right:100%;top:50%;transform:translateY(-50%);background:var(--color-surface);border:1px solid var(--color-surface-active);padding:6px;gap:2px;align-items:center;z-index:20}.topbar-controls-collapsible.is-expanded{display:flex}.topbar-controls{position:relative}}.topbar-title{font-size:1.1rem;font-weight:600}.url-toast{position:fixed;top:calc(var(--topbar-height) + 12px);left:50%;transform:translate(-50%);background:var(--color-warning-tint);border:1px solid var(--color-warning);color:var(--color-warning-text);padding:10px 16px;border-radius:6px;display:flex;align-items:center;gap:12px;z-index:100;box-shadow:0 4px 12px #00000026;cursor:pointer;max-width:calc(100vw - 40px);animation:toast-slide-in .3s ease}@keyframes toast-slide-in{0%{opacity:0;transform:translate(-50%) translateY(-10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.url-toast-message{font-size:.9rem;line-height:1.4}.url-toast-close{background:none;border:none;padding:4px;cursor:pointer;color:var(--color-warning-text);opacity:.7;transition:opacity .15s ease}.url-toast-close:hover{opacity:1}.login-toast{position:fixed;top:calc(var(--topbar-height) + 12px);left:50%;transform:translate(-50%);background:var(--color-accent-tint);border:1px solid var(--color-accent);color:var(--color-accent-strong);padding:10px 16px;border-radius:6px;display:flex;align-items:center;gap:10px;z-index:100;box-shadow:0 4px 12px #3b82f633;cursor:pointer;max-width:calc(100vw - 40px);animation:toast-slide-in .3s ease}.login-toast-icon{font-size:.9rem;opacity:.8}.login-toast-message{font-size:.9rem;line-height:1.4;font-weight:500}.login-toast-close{background:none;border:none;padding:4px;cursor:pointer;color:var(--color-accent-strong);opacity:.7;transition:opacity .15s ease}.login-toast-close:hover{opacity:1}.player-toast{position:fixed;top:calc(var(--topbar-height) + 12px);left:50%;transform:translate(-50%);background:var(--color-warning-tint);border:1px solid var(--color-warning-strong);color:var(--color-warning-text);padding:10px 16px;border-radius:6px;display:flex;align-items:center;gap:10px;z-index:100;box-shadow:0 4px 12px #ca8a0433;cursor:pointer;max-width:calc(100vw - 40px);animation:toast-slide-in .3s ease}.player-toast-icon{font-size:.9rem;opacity:.8}.player-toast-message{font-size:.9rem;line-height:1.4;font-weight:500}.player-toast-close{background:none;border:none;padding:4px;cursor:pointer;color:var(--color-warning-text);opacity:.7;transition:opacity .15s ease}.player-toast-close:hover{opacity:1}.view-tabs{display:flex;gap:4px;position:relative}.view-tab{border:none;background:none;padding:6px 10px;font:inherit;font-size:.85rem;color:var(--color-text-secondary);cursor:pointer;transition:background .15s ease,color .15s ease;display:flex;align-items:center;justify-content:center}.view-tab svg{display:block}.view-tab:hover{background:var(--color-surface-hover);color:var(--color-text)}.view-tab.is-active{background:var(--color-text);color:var(--color-text-inverse)}.view-tab.zoom-out-tab{position:absolute;display:flex;align-items:center;justify-content:center;gap:6px;background:none;border:none;color:var(--color-text);font-size:18px;white-space:nowrap;padding:8px;transition:background .15s,color .15s}.view-tab.zoom-out-tab:hover{background:var(--color-surface-hover);color:var(--color-text-strong)}.zoom-out-text{display:none}@media (min-width: 1100px){.view-tab.zoom-out-tab{left:100%;top:50%;transform:translateY(-50%);margin-left:8px;padding:6px 10px;font-size:inherit}.zoom-out-text{display:inline}}@media (max-width: 1099px){.view-tab.zoom-out-tab{position:fixed;top:calc(var(--topbar-height) / 2);right:52px;transform:translateY(-50%);z-index:15}}.search-container{position:relative;display:flex;align-items:center;flex-wrap:nowrap;gap:4px;border:1px solid var(--color-border);padding:4px 8px;background:var(--color-surface);min-height:36px;transition:border-color .15s,box-shadow .15s;overflow-x:auto;overflow-y:hidden;scrollbar-width:none;-ms-overflow-style:none}.search-container::-webkit-scrollbar{display:none}.search-container:focus-within{border-color:var(--color-accent-deep);box-shadow:0 0 0 3px #3730a31a}.search-container.has-tags{padding-right:32px}.search-play-btn{position:absolute;right:6px;top:50%;transform:translateY(-50%);width:22px;height:22px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:4px;color:var(--color-text-muted);opacity:.5;cursor:pointer;transition:opacity .15s,color .15s,background .15s;font-size:10px}.search-play-btn:hover{opacity:1;color:var(--color-accent-deep);background:var(--color-surface-hover)}.search-play-btn:active{background:var(--color-border)}.search-tag{display:inline-flex;align-items:center;gap:6px;background:var(--color-surface-alt);border-radius:4px;padding:4px 8px;flex-shrink:0;font-size:13px;white-space:nowrap;position:relative}.search-tag-field{background:var(--color-accent-tint);color:var(--color-accent-deep);padding:3px 10px;border-radius:12px;font-size:11px;font-weight:600}.search-tag-op{color:var(--color-text-muted);font-size:12px}.search-tag-value{color:var(--color-text);font-weight:500}.search-tag-actions{position:absolute;right:4px;top:50%;transform:translateY(-50%);display:flex;align-items:center;gap:2px;background:var(--color-surface-alt);padding:0 2px;opacity:0;transition:opacity .15s}.search-tag:hover .search-tag-actions{opacity:1}.search-tag-remove{background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:2px 4px;font-size:13px;line-height:1}.search-tag-remove:hover{color:var(--color-danger)}.search-tag-promote{background:var(--color-success);border:none;color:var(--color-text-inverse);cursor:pointer;padding:2px 6px;font-size:11px;font-weight:600;line-height:1;border-radius:3px}.search-tag-promote:hover{background:var(--color-success)}.search-tag-favorites{background:var(--color-danger-tint);border:1px solid var(--color-danger-tint)}.search-tag-favorites .search-tag-icon{color:var(--color-danger)}.search-tag-favorites .search-tag-label{color:var(--color-danger-strong)}.search-tag-history{background:#f3e8ff;border:1px solid #d8b4fe}.search-tag-history .search-tag-icon{color:#9333ea}.search-tag-history .search-tag-label{color:#6b21a8}.search-tag-popular{background:var(--color-accent-tint);border:1px solid var(--color-accent-soft)}.search-tag-popular .search-tag-icon{color:var(--color-accent)}.search-tag-popular .search-tag-label{color:var(--color-accent-strong)}.search-tag-text{background:var(--color-accent-tint);border:1px solid var(--color-accent-soft)}.search-tag-text .search-tag-field{color:var(--color-accent)}.search-tag-text .search-tag-value{color:var(--color-accent-strong)}.search-tag-icon{font-size:12px}.search-tag-label{font-weight:500;font-size:13px}.search{font:inherit;font-size:14px;border:none;background:transparent;padding:4px 0;flex:0 0 auto;width:180px;min-width:180px}.search-container:not(.has-tags) .search{flex:1;width:auto}.search:focus{outline:none}.search-box{position:relative;width:520px;min-width:180px;flex:1 1 520px;max-width:845px}.search-suggestions{position:absolute;top:calc(100% + 4px);left:-60px;right:-60px;min-width:340px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;box-shadow:0 4px 20px #00000026;z-index:300;max-height:540px;overflow-y:auto}.search-suggestions-header{padding:10px 14px 8px;font-size:11px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;font-weight:500}.search-suggestion{display:flex;align-items:center;gap:8px;width:100%;padding:10px 14px;border:none;background:transparent;text-align:left;cursor:pointer;font:inherit;font-size:13px;transition:background .1s}.search-suggestion:hover,.search-suggestion.is-selected{background:var(--color-surface-alt)}.search-suggestion-field{background:var(--color-accent-tint);color:var(--color-accent-deep);padding:3px 10px;border-radius:12px;font-size:11px;font-weight:600;white-space:nowrap}.search-suggestion-op{color:var(--color-text-muted);font-size:12px}.search-suggestion-value{color:var(--color-text);font-weight:500;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-suggestion-count{color:var(--color-text-muted);font-size:11px}.search-suggestion-icon{color:var(--color-text-secondary);font-size:14px;width:16px;text-align:center}.search-suggestion-label{font-weight:500;color:var(--color-text)}.search-suggestion-composition{flex-direction:column;align-items:flex-start;gap:2px;padding:8px 14px}.search-suggestion-title{font-weight:500;color:var(--color-text-strong);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.search-suggestion-meta{font-size:11px;color:var(--color-text-secondary)}.search-suggestion-combo{display:flex;align-items:center;gap:6px}.search-suggestion-combo-pills{display:flex;flex-wrap:wrap;gap:4px;flex:1;min-width:0}.search-suggestion-combo-pill{display:inline-flex;align-items:center;gap:2px;background:var(--color-surface-sunken);border:1px solid var(--color-border);border-radius:4px;padding:2px 8px;font-size:12px}.search-suggestion-combo-pill-field{color:var(--color-text-secondary);font-weight:500}.search-suggestion-combo-pill-op{color:var(--color-text-muted);font-size:11px}.search-suggestion-combo-pill-value{color:var(--color-text)}.menu{position:relative}.icon-button{position:relative;font:inherit;border:none;background:transparent;padding:6px 10px;cursor:pointer;transition:background .15s ease,color .15s ease}.icon-button:hover{background:var(--color-surface-hover)}.icon-button.is-active{background:var(--color-surface-alt)}.icon-button.has-indicator{position:relative}.icon-button.has-indicator:after{content:"";position:absolute;top:4px;right:4px;width:6px;height:6px;background:var(--color-accent);border-radius:50%}@keyframes player-pulse{0%,to{background:var(--color-success-tint);border-color:var(--color-success-soft)}50%{background:var(--color-success-tint);border-color:var(--color-success)}}.icon-button.is-playing{animation:player-pulse 2s ease-in-out infinite;color:var(--color-success)}.icon-button.queue-added{animation:queue-flash .4s ease-out}@keyframes queue-flash{0%{transform:scale(1);background:transparent}50%{transform:scale(1.3);background:#16a34a33}to{transform:scale(1);background:transparent}}.queue-fly-animation{position:fixed;z-index:9999;pointer-events:none;font-size:16px;color:var(--color-success);transition:transform .35s cubic-bezier(.4,0,.2,1),opacity .35s ease-out}.queue-badge{position:absolute;top:-4px;right:-4px;min-width:16px;height:16px;padding:0 4px;font-size:10px;font-weight:600;line-height:16px;text-align:center;color:var(--color-text-inverse);background:var(--color-accent);border-radius:8px}@keyframes filter-flash{0%{background:var(--color-surface);border-color:var(--color-border-strong);transform:scale(1)}25%{background:var(--color-success);border-color:var(--color-success);transform:scale(1.15);color:var(--color-text-inverse)}to{background:var(--color-surface);border-color:var(--color-border-strong);transform:scale(1)}}.icon-button.is-flashing{animation:filter-flash .5s ease-out}.icon-button.is-flashing i{color:var(--color-text-inverse)}.menu-panel{position:absolute;top:calc(100% + 6px);right:0;min-width:160px;border:1px solid var(--color-border);background:var(--color-surface);display:grid;gap:4px;padding:8px;z-index:11}.menu-panel button{font:inherit;text-align:left;background:none;border:none;padding:4px 2px;cursor:pointer}.menu-panel button.is-active{font-weight:600}.font-panel{width:180px}.font-panel button{font-size:.95rem;padding:6px 8px}.menu-option{display:flex;align-items:center;gap:8px;font-size:.9rem;cursor:pointer}.menu-option input{margin:0}.fields-panel{width:280px;padding:0;gap:0}.fields-search{padding:8px 12px;border-bottom:1px solid var(--color-surface-active)}.fields-search input{width:100%;border:1px solid var(--color-border-strong);border-radius:4px;padding:6px 10px;font:inherit;font-size:13px}.fields-search input:focus{outline:none;border-color:var(--color-text-faint)}.fields-list{display:flex;flex-direction:column;max-height:300px;overflow-y:auto;padding:8px}.field-item{display:flex;align-items:center;gap:10px;padding:8px 12px;cursor:pointer;transition:background .1s ease;border:none;background:none;width:100%;text-align:left;font:inherit}.field-item:hover{background:var(--color-surface-sunken)}.field-name{flex:1;font-size:13px;color:var(--color-text)}.field-toggle{width:36px;height:20px;border-radius:10px;background:var(--color-border-strong);position:relative;transition:background .15s ease;flex-shrink:0}.field-toggle:after{content:"";position:absolute;width:16px;height:16px;border-radius:50%;background:var(--color-surface);top:2px;left:2px;transition:transform .15s ease;box-shadow:0 1px 2px #00000026}.field-toggle.is-active{background:var(--color-text-secondary)}.field-toggle.is-active:after{transform:translate(16px)}.title-format-builder{padding:12px;border-bottom:1px solid var(--color-surface-active)}.title-format-label{font-size:.75rem;letter-spacing:.05em;text-transform:uppercase;color:var(--color-text-secondary);margin-bottom:8px}.title-format-preview{font-size:13px;color:var(--color-text-muted);margin-bottom:10px;padding:6px 8px;background:var(--color-surface-alt);border-radius:4px;font-family:monospace;word-break:break-word}.title-format-chips{display:flex;flex-wrap:wrap;gap:6px;min-height:32px;padding:8px;background:var(--color-surface-alt);border:1px dashed var(--color-border-strong);border-radius:4px;margin-bottom:10px}.title-format-chip{display:flex;align-items:center;gap:4px;padding:4px 6px;background:var(--color-surface);border:1px solid var(--color-border-strong);border-radius:4px;font-size:13px;cursor:grab;-webkit-user-select:none;user-select:none;transition:border-color .15s ease,box-shadow .15s ease}.title-format-chip:hover{border-color:var(--color-text-faint)}.title-format-chip.is-dragging{opacity:.5}.title-format-chip.is-drop-target{border-color:var(--color-danger);box-shadow:0 0 0 2px #e0404033}.title-format-chip-grip{color:var(--color-text-faint);font-size:10px;cursor:grab}.title-format-chip-label{color:var(--color-text)}.title-format-chip-remove{border:none;background:none;color:var(--color-text-muted);font-size:14px;line-height:1;padding:0 2px;cursor:pointer;transition:color .1s ease}.title-format-chip-remove:hover{color:var(--color-danger)}.title-format-empty{font-size:13px;color:var(--color-text-faint);font-style:italic}.title-format-add{margin-top:4px}.title-format-add-label{font-size:12px;color:var(--color-text-muted);margin-bottom:6px}.title-format-add-options{display:flex;flex-wrap:wrap;gap:4px}.title-format-add-button{border:1px solid var(--color-border);background:var(--color-surface);padding:4px 10px;font-size:13px;color:var(--color-text-secondary);border-radius:3px;cursor:pointer;transition:border-color .1s ease,color .1s ease}.title-format-add-button:hover{border-color:var(--color-text-faint);color:var(--color-text)}.title-format-more{font-size:12px;color:var(--color-text-faint);padding:4px 6px}.fields-section-divider{height:1px;background:var(--color-surface-active)}.fields-section-label{font-size:.75rem;letter-spacing:.05em;text-transform:uppercase;color:var(--color-text-secondary);padding:10px 12px 6px}.fields-spacing-toggle{display:flex;margin:0 12px 8px;border:1px solid var(--color-border);border-radius:6px;overflow:hidden}.fields-spacing-btn{flex:1;padding:8px 16px;border:none;background:var(--color-surface);font-size:13px;font-weight:500;color:var(--color-text-secondary);cursor:pointer;transition:background .15s,color .15s;display:flex;justify-content:center;align-items:center}.fields-spacing-btn:first-child{border-right:1px solid var(--color-border)}.fields-spacing-btn:hover:not(.is-active){background:var(--color-surface-sunken)}.fields-spacing-btn.is-active{background:var(--color-text-secondary);color:var(--color-text-inverse)}.mode-toggle{display:flex;gap:6px}.filter-panel{width:480px;max-height:420px;overflow:auto;gap:14px;border-radius:8px;box-shadow:0 4px 20px #00000026;border:1px solid var(--color-border);padding:14px}.filter-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.filter-title{font-weight:600;font-size:14px;color:var(--color-text)}.filter-header-controls{display:flex;align-items:center;gap:10px}.filter-clear-all{font:inherit;font-size:12px;background:none;border:none;color:var(--color-danger);cursor:pointer;padding:4px 8px;border-radius:4px;transition:background .15s}.filter-clear-all:hover{background:var(--color-danger-tint)}.filter-mode-toggle{display:flex;gap:2px;background:var(--color-surface-hover);border-radius:6px;padding:3px}.filter-mode-toggle button{font:inherit;font-size:12px;border:none;background:transparent;padding:6px 14px;cursor:pointer;border-radius:4px;color:var(--color-text-secondary);transition:all .15s}.filter-mode-toggle button:hover{color:var(--color-text)}.filter-mode-toggle button.is-active{background:var(--color-surface);color:var(--color-text);box-shadow:0 1px 3px #0000001a}.filter-empty{font-size:13px;color:var(--color-text-muted);padding:8px 0}.filter-list{display:grid;gap:10px}.filter-row{display:grid;grid-template-columns:auto 1fr 1.5fr auto;gap:8px;align-items:center}.filter-row input,.filter-row select{font:inherit;font-size:13px;border:1px solid var(--color-border);border-radius:4px;padding:6px 8px;background:var(--color-surface);transition:border-color .15s}.filter-row input:focus,.filter-row select:focus{outline:none;border-color:var(--color-accent-deep)}.filter-field-pill{background:var(--color-accent-tint);color:var(--color-accent-deep);border:none;border-radius:14px;padding:6px 26px 6px 12px;font:inherit;font-size:12px;font-weight:600;cursor:pointer;-moz-appearance:none;appearance:none;-webkit-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='%233730a3' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;min-width:100px}.filter-field-pill:focus{outline:none;box-shadow:0 0 0 2px #3730a333}.filter-range{display:grid;grid-template-columns:1fr 1fr;gap:6px}.filter-add{font:inherit;font-size:13px;border:1px dashed var(--color-border-strong);background:var(--color-surface-alt);padding:8px 14px;cursor:pointer;justify-self:start;border-radius:6px;color:var(--color-text-secondary);transition:all .15s}.filter-add:hover{border-color:var(--color-accent-deep);background:var(--color-surface-alt);color:var(--color-accent-deep)}.filter-remove{border:1px solid var(--color-border);background:var(--color-surface);width:28px;height:28px;line-height:1;cursor:pointer;border-radius:4px;color:var(--color-text-muted);transition:all .15s}.filter-remove:hover{border-color:var(--color-danger);background:var(--color-danger-tint);color:var(--color-danger)}.color-panel{width:280px;padding:0;gap:0}.color-field-item{display:flex;align-items:center;gap:10px;padding:8px 12px;cursor:pointer;transition:background .1s ease;border:none;background:none;width:100%;text-align:left;font:inherit}.color-field-item:hover{background:var(--color-surface-sunken)}.color-field-item.is-selected{background:var(--color-surface-hover)}.color-field-item.is-selected .field-name{font-weight:600;color:var(--color-text)}.color-field-check{color:var(--color-text);font-weight:600;font-size:14px}.fields-empty{padding:12px;text-align:center;color:var(--color-text-muted);font-size:13px}.color-scheme-section{border-top:1px solid var(--color-surface-hover);padding-top:2px}.color-scheme-options{display:flex;justify-content:center;gap:2px;padding:2px 4px 4px}.color-scheme-option{flex:1;display:flex;align-items:center;justify-content:center;padding:8px 0;border:none;background:none;font:inherit;font-size:13px;color:var(--color-text-muted);cursor:pointer;text-align:center;transition:background .1s ease,color .1s ease}.color-scheme-option:hover{background:var(--color-surface-sunken);color:var(--color-text)}.color-scheme-option.is-selected{background:var(--color-surface-hover);color:var(--color-text);font-weight:600}.card.has-color{background:color-mix(in srgb,var(--card-color) 9%,var(--color-surface))}.card-color-bar{position:absolute;top:0;left:0;bottom:0;width:4px;border-radius:3px 0 0 3px}.player-panel{width:240px;gap:8px;z-index:250}.menu:has(.player-panel){z-index:201}.player-now-playing{display:flex;align-items:center;gap:8px}.player-info{flex:1;min-width:0}.player-title{font-weight:600}.player-meta{font-size:.85rem;color:var(--color-text-secondary)}.player-like-btn{flex-shrink:0;width:26px;height:26px;border:1px solid var(--color-border-strong);border-radius:999px;background:var(--color-surface);color:var(--color-text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .15s ease,color .15s ease;font-size:.8rem}.player-like-btn:hover,.player-like-btn.is-liked{color:var(--color-accent)}.player-favorite-btn{flex-shrink:0;width:26px;height:26px;border:1px solid var(--color-border-strong);border-radius:999px;background:var(--color-surface);color:var(--color-text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .15s ease,color .15s ease;font-size:.8rem}.player-favorite-btn:hover,.player-favorite-btn.is-favorite{color:var(--color-danger)}.player-goto-btn{flex-shrink:0;width:26px;height:26px;border:1px solid var(--color-border-strong);border-radius:999px;background:var(--color-surface);color:var(--color-text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .15s ease,color .15s ease;font-size:.7rem}.player-goto-btn:hover{color:var(--color-text)}.player-status{font-size:.85rem;color:var(--color-text-muted)}.player-error{color:var(--color-danger)}.player-error-link{color:var(--color-text-muted);text-decoration:underline}.player-error-link:hover{color:var(--color-text-faint)}.player-video-title{font-size:.8rem;color:var(--color-text-secondary);margin-bottom:8px;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.player-controls{display:flex;justify-content:center;gap:8px;margin-bottom:8px}.player-control-btn{font:inherit;font-size:.85rem;border:1px solid var(--color-border);background:var(--color-surface);padding:6px 10px;cursor:pointer;border-radius:4px}.player-control-btn:hover{background:var(--color-surface-sunken)}.player-control-main{font-weight:600;display:flex;align-items:center;justify-content:center}.player-links{display:flex;align-items:center;justify-content:space-between;gap:12px}.player-link{font-size:.8rem;color:var(--color-text-strong);text-decoration:underline}button.player-report-btn{font-size:.8rem;color:var(--color-text-strong);text-decoration:underline;background:none;border:none;cursor:pointer;padding:0;transition:color .15s ease}.player-report-btn:hover{color:var(--color-danger-strong)}.player-adblock-tip{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:8px;padding:6px 8px;background:var(--color-warning-tint);border:1px solid var(--color-warning-soft);border-radius:4px;font-size:.75rem;color:var(--color-warning-text)}.player-adblock-dismiss{background:none;border:none;color:var(--color-warning-text);cursor:pointer;padding:2px 4px;font-size:.8rem;opacity:.7}.player-adblock-dismiss:hover{opacity:1}.player-progress{display:flex;align-items:center;gap:8px;margin-bottom:8px}.player-time{font-size:.7rem;color:var(--color-text-secondary);width:28px;text-align:center;font-variant-numeric:tabular-nums;flex-shrink:0}.player-progress-bar{flex:1;height:6px;background:var(--color-border);border-radius:3px;cursor:pointer;position:relative;overflow:hidden}.player-progress-bar:hover{background:var(--color-border-strong)}.player-progress-fill{position:absolute;top:0;left:0;height:100%;background:var(--color-text);border-radius:3px;transition:width .1s linear}.player-progress-bar:hover .player-progress-fill{background:var(--color-text-secondary)}.player-volume{display:flex;align-items:center;gap:8px;margin-bottom:8px}.player-volume-icon{font-size:.75rem;color:var(--color-text-secondary);width:28px;text-align:center;flex-shrink:0}.player-volume-slider{flex:1;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--color-border);border-radius:2px;cursor:pointer}.player-volume-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;background:var(--color-text);border-radius:50%;cursor:pointer}.player-volume-slider::-moz-range-thumb{width:14px;height:14px;background:var(--color-text);border-radius:50%;cursor:pointer;border:none}.board{margin-top:var(--topbar-height);height:calc(100vh - var(--topbar-height) - var(--player-bar-height));overflow:auto;overscroll-behavior:contain;border-top:1px solid var(--color-surface-hover)}.board-inner{position:relative;min-width:max-content}.year-sticky-indicator{position:sticky;top:0;left:0;width:90px;height:var(--header-height);display:flex;align-items:center;justify-content:center;background:var(--color-surface);border-bottom:1px solid var(--color-border);border-right:1px solid var(--color-border);font-size:1.4rem;font-weight:600;color:var(--color-text-strong);z-index:8;pointer-events:none;margin-bottom:calc(-1 * var(--header-height))}.grid{display:grid;grid-auto-rows:minmax(80px,auto)}.row{display:grid;grid-column:1 / -1;min-height:80px;border-top:1px solid var(--color-surface-sunken)}.header-overlay{position:sticky;top:0;height:0;z-index:4;pointer-events:none}.composer-floating{position:absolute;top:0;height:40px;display:flex;align-items:center;justify-content:center;background:var(--color-surface-hover);border:1px solid var(--color-border);color:var(--color-text);font-size:1rem;font-weight:600;pointer-events:auto;white-space:nowrap;padding:0 12px;z-index:10}.composer-floating.is-spotlight{background:var(--color-spotlight);border-color:var(--color-spotlight-strong);box-shadow:0 2px 8px #f5c84266}.composer-floating.is-muted{filter:saturate(.3)}.composer-name{text-align:center}.spotlight-button{position:absolute;right:8px;top:55%;transform:translateY(-50%);opacity:0;border:1px solid rgba(0,0,0,.15);background:#ffffffe6;border-radius:50%;width:26px;height:26px;font-size:.75rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .15s ease,background .15s ease,color .15s ease,transform .15s ease;color:var(--color-text-secondary);box-shadow:0 1px 3px #0000001a}.composer-floating:hover .spotlight-button,.spotlight-button.is-active{opacity:.4}.spotlight-button:hover{opacity:1;background:var(--color-surface);color:var(--color-text);box-shadow:0 2px 5px #00000026}.spotlight-button.is-active{background:var(--color-text);border-color:var(--color-text);color:var(--color-text-inverse)}.spotlight-button.is-active:hover{background:var(--color-text-secondary);border-color:var(--color-text-secondary)}.header-row{display:grid;grid-column:1 / -1}.header-spacer{height:var(--header-height);background:var(--color-surface);border-bottom:1px solid var(--color-surface-hover);border-right:1px solid var(--color-surface-sunken)}.year{display:flex;align-items:flex-start;justify-content:center;padding:6px 0 0;border-right:1px solid var(--color-surface-hover);background:var(--color-surface);font-size:1.4rem;font-weight:600;color:var(--color-text-strong);transform:translateY(-10px)}.cell{padding:12px;border-right:1px solid var(--color-surface-sunken);border-bottom:1px solid var(--color-surface-sunken)}.cell.is-outside-life{background:var(--color-surface-hover)}.cell.is-muted{filter:saturate(.25)}.cell.is-spotlight-column{background:linear-gradient(to bottom,var(--color-warning-tint),var(--color-warning-tint));box-shadow:inset 0 0 0 1px #f5c84233}.cell.is-constrained{position:relative}.cell.is-constrained:after{content:"";position:absolute;bottom:0;left:0;right:0;height:60px;background:linear-gradient(to bottom,transparent,rgba(255,255,255,.95));pointer-events:none}.cell-expand-button{position:absolute;bottom:8px;left:50%;transform:translate(-50%);background:var(--color-text);color:var(--color-text-inverse);font:inherit;font-size:.8rem;font-weight:500;padding:6px 14px;border:none;border-radius:16px;cursor:pointer;z-index:5;box-shadow:0 2px 6px #0003;white-space:nowrap;transition:background .15s ease}.cell-expand-button:hover{background:var(--color-text-strong)}.sticky-left{position:sticky;left:0;z-index:6}.card{display:block;width:100%;text-align:left;border:none;border-bottom:1px solid var(--color-border);background:transparent;padding:11px 8px 11px 20px;margin-bottom:0;cursor:pointer;font:inherit;border-radius:0;position:relative}.cell .card:last-child{border-bottom:none}.card-title{font-weight:600;font-size:.95rem;margin-bottom:6px;position:relative}.card-title:before{content:"";position:absolute;left:-13px;top:.5em;width:7px;height:7px;background:var(--card-color, var(--color-border-strong))}.card-subtitle{font-size:.85rem;color:var(--color-text-secondary);margin-bottom:4px}.card-title-row{display:flex;align-items:baseline;margin-bottom:6px}.card-title-row .card-title{flex:0 0 50%;min-width:0;margin-bottom:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding-right:12px}.card-composer{flex:0 0 50%;font-size:.85rem;color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-play{position:absolute;top:8px;right:8px;border:1px solid var(--color-border-strong);background:var(--color-surface);border-radius:999px;width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;font-size:.8rem;opacity:0;transition:opacity .15s ease;cursor:pointer;overflow:hidden;z-index:1}.card:hover .card-play,.card-play:focus-visible{opacity:1}.card-play.is-playing{background:var(--color-text-strong);color:var(--color-text-inverse);border-color:var(--color-text-strong)}.card-play-icon{position:relative;z-index:2}.card-play:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--color-text-strong);transform:translate(-110%);z-index:1}.card-play.is-starting:before{animation:play-swipe .5s ease forwards}.card-play.is-starting{color:var(--color-text-inverse);border-color:var(--color-text-strong)}@keyframes play-swipe{0%{transform:translate(-110%)}to{transform:translate(0)}}.card-favorite{position:absolute;top:-6px;left:-8px;border:1px solid var(--color-border);background:var(--color-surface);border-radius:999px;width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;font-size:.85rem;opacity:0;transition:opacity .15s ease,color .15s ease,transform .15s ease,border-color .15s ease;cursor:pointer;z-index:1;color:var(--color-text-faint);transform:rotate(-15deg)}.card:hover .card-favorite:not(.is-active){opacity:1}.card-favorite:hover{opacity:1;color:var(--color-danger);border-color:var(--color-danger);transform:rotate(-15deg) scale(1.1)}.card-favorite.is-active{color:var(--color-danger);opacity:1;z-index:2}.card-favorite-icon{line-height:1}.card-link{position:absolute;top:8px;right:68px;border:1px solid var(--color-border-strong);background:var(--color-surface);border-radius:999px;width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;font-size:.7rem;opacity:0;transition:opacity .15s ease,color .15s ease,background-color .15s ease;cursor:pointer;z-index:1;color:var(--color-text-secondary)}.card:hover .card-link,.card-link:focus-visible{opacity:1}.card-link:hover{background-color:var(--color-surface-hover);color:var(--color-accent)}.card-link-icon{font-size:.75rem}.card-link:hover .card-link-icon{color:var(--color-accent)}.card-queue{position:absolute;top:8px;right:38px;border:1px solid var(--color-border-strong);background:var(--color-surface);border-radius:999px;width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;font-size:.7rem;opacity:0;transition:opacity .15s ease,color .15s ease,background-color .15s ease;cursor:pointer;z-index:1;color:var(--color-text-secondary)}.card:hover .card-queue,.card-queue:focus-visible{opacity:1}.card-queue:hover{color:var(--color-text);background-color:var(--color-surface-hover);border-color:var(--color-border-strong)}.card-queue-icon{line-height:1}.card-playlist{position:absolute;top:8px;right:68px;border:1px solid var(--color-border-strong);background:var(--color-surface);border-radius:999px;width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;font-size:.7rem;opacity:0;transition:opacity .15s ease,color .15s ease,background-color .15s ease;cursor:pointer;z-index:1;color:var(--color-text-secondary)}.card:hover .card-playlist,.card-playlist:focus-visible{opacity:1}.card-playlist:hover{color:var(--color-text);background-color:var(--color-surface-hover);border-color:var(--color-border-strong)}.card-playlist-icon{line-height:1}.card-goto{position:absolute;top:8px;right:98px;border:1px solid var(--color-border-strong);background:var(--color-surface);border-radius:999px;width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;font-size:.7rem;opacity:0;transition:opacity .15s ease,color .15s ease,background-color .15s ease;cursor:pointer;z-index:1;color:var(--color-text-secondary)}.card:hover .card-goto,.card-goto:focus-visible{opacity:1}.card-goto:hover{color:var(--color-accent);background-color:var(--color-surface-hover);border-color:var(--color-border-strong)}.card-goto-icon{line-height:1}.card.is-favorite .card-title:before{background:var(--color-danger)}.card.is-favorite-colored .card-title:before{background:var(--color-danger)}.card.is-favorite-colored .card-field{color:var(--color-text-muted)}.card.is-favorite-colored .card-play{background:#ffffffe6;border-color:transparent}.card.is-favorite-colored .card-favorite{background:#ffffffe6;border-color:transparent;color:#c8c8c8cc}.card.is-favorite-colored .card-favorite.is-active{color:var(--color-danger)}.card.is-filtered-out{opacity:.35!important;filter:grayscale(.7)!important}.card.is-now-playing{outline:3px solid var(--color-success);outline-offset:1px;z-index:4;position:relative}.card.is-selected{outline:3px solid var(--color-warning);outline-offset:1px;z-index:5;position:relative}.card-fields{display:flex;flex-wrap:wrap;gap:0}.card-field{display:inline-flex;align-items:center;padding:0;border-radius:0;border:none;background:none;font-size:.8rem;color:var(--color-text-muted);line-height:1.4;position:relative}.card-field+.card-field:before{content:"·";margin:0 7px;color:var(--color-text-faint)}.card-field.is-clickable{cursor:pointer;transition:color .15s ease}.card-field.is-clickable:hover{color:var(--color-text);text-decoration:underline;text-underline-offset:2px}.card-field.is-colored{padding:1px 7px;color:var(--color-text-inverse)}.card-field.is-colored.is-clickable:hover{color:var(--color-text-inverse);text-decoration:none}.card-field+.card-field.is-colored:before{content:none}.card-field-tooltip{position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);background:var(--color-text);color:var(--color-text-inverse);font-size:.75rem;padding:4px 8px;border-radius:4px;white-space:nowrap;z-index:10;pointer-events:auto}.card-field-tooltip.is-clickable{cursor:pointer}.card-field-tooltip.is-clickable:hover{background:var(--color-text)}.card-field-tooltip-icon{margin-left:6px;font-size:.7rem;opacity:.8}.card-field-tooltip.is-clickable:hover .card-field-tooltip-icon{opacity:1}.card-field-tooltip:before{content:"";position:absolute;top:100%;left:0;right:0;height:10px}.card-field-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:5px solid transparent;border-top-color:var(--color-text)}.card-properties{display:flex;flex-direction:column;gap:4px;margin-top:8px}.card-property{font-size:.85rem;line-height:1.4;color:var(--color-text)}.card-property-label{color:var(--color-text-muted)}.card-property-value{color:var(--color-text-strong)}.details{position:fixed;right:20px;top:calc(var(--topbar-height) + 12px);bottom:calc(var(--player-bar-height) + 16px);width:320px;border:1px solid var(--color-border);background:var(--color-surface);z-index:200;display:flex;flex-direction:column;overflow:hidden}.details.is-left{right:auto;left:20px}.details-sticky-header{flex-shrink:0;padding:16px 16px 12px;background:var(--color-surface);border-bottom:1px solid var(--color-surface-hover);position:relative;z-index:1}.details-scrollable{flex:1;overflow-y:auto;overscroll-behavior:contain;padding:16px}.details-header{position:relative}.details-header-actions{display:flex;gap:4px;opacity:0;transition:opacity .15s ease;position:absolute;top:0;right:0;z-index:2;background:linear-gradient(to right,transparent 0%,var(--color-surface) 20%);padding-left:24px}.details-header:hover .details-header-actions{opacity:1}.details-header-action{width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--color-border-strong);background:var(--color-surface);border-radius:999px;font-size:.75rem;color:var(--color-text-muted);cursor:pointer;transition:opacity .15s ease,color .15s ease}.details-header-action:hover{color:var(--color-text)}.details-title{font-size:1rem;font-weight:600;margin-bottom:6px;width:100%;padding-right:8px}.details-meta{font-size:.85rem;color:var(--color-text-secondary);margin-bottom:0}.details-empty{font-size:.85rem;color:var(--color-text-muted);margin-bottom:16px}.details-section{border-top:1px solid var(--color-surface-hover);padding-top:12px;margin-bottom:16px}.details-section:first-child{border-top:none;padding-top:16px}.details-section-title{font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-secondary);margin-bottom:8px}.details-muted{font-size:.85rem;color:var(--color-text-muted)}.details-wiki-title{font-size:.9rem;font-weight:600;margin-bottom:6px}.details-wiki-text{font-size:.9rem;color:var(--color-text);line-height:1.5;margin-bottom:8px}.details-link{font-size:.85rem;color:var(--color-text-strong);text-decoration:underline}.details-external-links{display:flex;flex-wrap:wrap;gap:8px}.details-external-link{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:var(--color-surface-sunken);border:1px solid var(--color-border);border-radius:4px;font-size:.8rem;color:var(--color-text);text-decoration:none;transition:background-color .15s,border-color .15s}.details-external-link:hover{background:var(--color-surface-active);border-color:var(--color-border-strong)}.details-external-link.is-icon-only{width:28px;height:28px;padding:0;justify-content:center;font-size:.9rem;color:var(--color-text-secondary)}.details-external-link.is-icon-only:hover{color:var(--color-text-strong)}.details-external-icon{font-size:.9rem}.details-external-label{font-weight:500}.details-properties{display:flex;flex-direction:column;gap:6px}.details-property{font-size:.9rem;line-height:1.4}.details-property-label{color:var(--color-text-secondary);border-bottom:1px dotted var(--color-text-muted);margin-right:8px}.details-property-label:after{content:":"}.details-property-label:hover{color:var(--color-text)}.details-property-value{color:var(--color-text-strong);display:inline-flex;align-items:center;gap:6px}.details-property-value.has-actions{position:relative}.details-property-actions{display:inline-flex;gap:2px;opacity:0;transition:opacity .15s}.details-property:hover .details-property-actions{opacity:1}.details-property-action{background:none;border:none;padding:2px 4px;cursor:pointer;color:var(--color-text-secondary);font-size:11px;border-radius:3px;transition:color .15s,background .15s}.details-property-action:hover{color:var(--color-text);background:var(--color-surface-hover)}.fa-filter-plus{position:relative;display:inline-block;width:1em;height:1em;font-size:inherit}.fa-filter-plus .fa-filter{position:absolute;top:1px;left:0;font-size:.9em}.fa-filter-plus .fa-plus{position:absolute;bottom:-4px;right:-3px;font-size:.55em;background:var(--color-surface);border-radius:2px}.details-close{border:1px solid var(--color-border);background:var(--color-surface);font:inherit;padding:6px 10px;cursor:pointer}@media (max-width: 800px){.details{left:12px;top:calc(var(--topbar-height) + 8px);bottom:calc(var(--player-bar-height) + 12px);width:240px}}.favorites-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;z-index:299}.favorites-panel{position:fixed;top:0;left:0;bottom:0;width:270px;max-width:90vw;background:var(--color-surface);box-shadow:4px 0 20px #00000026;z-index:300;display:flex;flex-direction:column;transform:translate(-100%);transition:transform .3s ease}.favorites-panel.is-open{transform:translate(0)}.favorites-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--color-surface-active);background:var(--color-surface-alt);flex-shrink:0}.favorites-tabs{display:flex;gap:4px}.favorites-tab{display:flex;align-items:center;gap:6px;padding:8px 12px;border:none;background:transparent;border-radius:6px;font-size:.9rem;color:var(--color-text-secondary);cursor:pointer;transition:background-color .15s ease,color .15s ease}.favorites-tab:hover{background:var(--color-surface-active)}.favorites-tab.is-active{background:var(--color-text);color:var(--color-text-inverse)}.favorites-tab i{font-size:.85rem}.favorites-tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;background:#0000001a;border-radius:10px;font-size:.75rem;font-weight:600}.favorites-tab.is-active .favorites-tab-count{background:#fff3}.favorites-title{margin:0;font-size:1.25rem;font-weight:600;color:var(--color-text);display:flex;align-items:center;gap:10px}.favorites-count{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 8px;background:var(--color-danger);color:var(--color-text-inverse);border-radius:12px;font-size:.8rem;font-weight:600}.favorites-close{border:none;background:none;font-size:1.5rem;color:var(--color-text-secondary);cursor:pointer;padding:4px 8px;line-height:1}.favorites-close:hover{color:var(--color-text)}.favorites-sort{display:flex;align-items:center;gap:8px;padding:10px 20px;border-bottom:1px solid var(--color-surface-active);background:var(--color-surface-sunken);flex-shrink:0}.favorites-sort label{font-size:13px;color:var(--color-text-secondary)}.favorites-sort select{flex:1;padding:6px 10px;border:1px solid var(--color-border-strong);border-radius:6px;background:var(--color-surface);font-size:13px;color:var(--color-text);cursor:pointer}.favorites-sort select:hover{border-color:var(--color-text-faint)}.favorites-sort select:focus{outline:none;border-color:var(--color-text-secondary)}.favorites-list-flat{display:flex;flex-direction:column;gap:8px}.favorites-content{flex:1;overflow-y:auto;padding:16px}.favorites-empty{text-align:center;padding:40px 20px;color:var(--color-text-secondary)}.favorites-empty p{margin:0 0 8px}.favorites-empty-hint{font-size:.85rem;color:var(--color-text-muted)}.favorites-group{margin-bottom:24px}.favorites-composer{margin:0 0 12px;font-size:.9rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.03em;padding-bottom:8px;border-bottom:1px solid var(--color-surface-active)}.favorites-list{display:flex;flex-direction:column;gap:8px}.favorites-item{position:relative}.favorites-item .card{margin:0}.favorites-goto{position:absolute;top:8px;right:72px;width:26px;height:26px;border:1px solid var(--color-border-strong);background:var(--color-surface);border-radius:999px;display:flex;align-items:center;justify-content:center;font-size:.75rem;color:var(--color-text-muted);cursor:pointer;opacity:0;transition:opacity .15s ease,background-color .15s ease,color .15s ease;z-index:15}.favorites-queue{position:absolute;top:8px;right:40px;width:26px;height:26px;border:1px solid var(--color-border-strong);background:var(--color-surface);border-radius:999px;display:flex;align-items:center;justify-content:center;font-size:.75rem;color:var(--color-text-muted);cursor:pointer;opacity:0;transition:opacity .15s ease,background-color .15s ease,color .15s ease;z-index:15}.favorites-item:hover .favorites-goto,.favorites-item:hover .favorites-queue,.favorites-goto:focus-visible,.favorites-queue:focus-visible{opacity:1}.favorites-goto:hover,.favorites-queue:hover{background:var(--color-text);border-color:var(--color-text);color:var(--color-text-inverse)}.favorites-toggle{position:fixed;bottom:24px;right:24px;width:56px;height:56px;border-radius:50%;border:none;background:var(--color-danger);color:var(--color-text-inverse);font-size:1.5rem;cursor:pointer;box-shadow:0 4px 12px #e74c3c66;z-index:50;display:flex;align-items:center;justify-content:center;transition:transform .2s ease,box-shadow .2s ease}.favorites-toggle:hover{transform:scale(1.05);box-shadow:0 6px 16px #e74c3c80}.favorites-toggle-count{position:absolute;top:-4px;right:-4px;min-width:20px;height:20px;padding:0 6px;background:var(--color-text);color:var(--color-text-inverse);border-radius:10px;font-size:.7rem;font-weight:600;display:flex;align-items:center;justify-content:center}.qh-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;z-index:299}.qh-panel{position:fixed;top:0;right:0;bottom:0;width:320px;max-width:90vw;background:var(--color-surface);box-shadow:-4px 0 20px #00000026;z-index:300;display:flex;flex-direction:column;transform:translate(100%);transition:transform .3s ease}.qh-panel.is-open{transform:translate(0)}.qh-header{display:flex;align-items:center;padding:12px 16px;border-bottom:1px solid var(--color-surface-active);background:var(--color-surface-alt);flex-shrink:0;gap:8px}.qh-tabs{display:flex;gap:4px;flex:1}.qh-tab{padding:8px 12px;border:none;background:none;font-size:.9rem;font-weight:500;color:var(--color-text-secondary);cursor:pointer;border-radius:6px;display:flex;align-items:center;gap:6px;transition:background-color .15s ease,color .15s ease}.qh-tab:hover{background:var(--color-surface-active)}.qh-tab.is-active{background:var(--color-text);color:var(--color-text-inverse)}.qh-tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;background:#00000026;border-radius:9px;font-size:.7rem;font-weight:600}.qh-tab.is-active .qh-tab-count{background:#fff3}.qh-close{border:none;background:none;font-size:1.5rem;color:var(--color-text-secondary);cursor:pointer;padding:4px 8px;line-height:1}.qh-close:hover{color:var(--color-text)}.qh-content{flex:1;overflow-y:auto;padding:16px}.qh-empty{text-align:center;padding:40px 20px;color:var(--color-text-secondary)}.qh-empty p{margin:0 0 8px}.qh-empty-hint{font-size:.85rem;color:var(--color-text-muted)}.qh-list{display:flex;flex-direction:column;gap:4px}.qh-item{position:relative;display:flex;gap:4px;align-items:center}.qh-item .card{flex:1;margin:0}.qh-item .card-fields{margin-top:4px}.qh-item .card-play,.qh-item .card-favorite,.qh-item .card-queue,.qh-item .card-playlist{display:none}.qh-item-controls{position:absolute;right:8px;top:8px;display:flex;flex-direction:row;gap:4px;opacity:0;transition:opacity .15s ease}.qh-item:hover .qh-item-controls{opacity:1}.qh-item.is-dragging{opacity:.5}.qh-item.drag-over{border-top:2px solid var(--color-accent);margin-top:-2px}.qh-drag-handle{cursor:grab;color:var(--color-text-muted);padding:4px;display:flex;align-items:center;justify-content:center}.qh-drag-handle:active{cursor:grabbing}.qh-item:hover .qh-drag-handle{color:var(--color-text-secondary)}.qh-control{width:26px;height:26px;border:1px solid var(--color-border-strong);background:var(--color-surface);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;line-height:1;color:var(--color-text-secondary);cursor:pointer;transition:background-color .15s ease,color .15s ease,border-color .15s ease}.qh-control span{display:block;margin-top:-1px}.qh-control:hover{background:var(--color-text);border-color:var(--color-text);color:var(--color-text-inverse)}.qh-control.qh-play i{font-size:.7rem;margin-left:2px}.qh-history-item{display:flex;align-items:flex-start;gap:8px}.qh-history-item .qh-item{flex:1}.qh-timestamp{font-size:.75rem;color:var(--color-text-muted);white-space:nowrap;padding-top:10px}.qh-group{margin-bottom:20px}.qh-group-label{margin:0 0 10px;font-size:.8rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.03em}.qh-footer{padding:12px 16px;border-top:1px solid var(--color-surface-active);background:var(--color-surface-alt)}.qh-clear{width:100%;padding:10px 16px;border:1px solid var(--color-border-strong);background:var(--color-surface);border-radius:6px;font-size:.9rem;color:var(--color-text-secondary);cursor:pointer;transition:background-color .15s ease,color .15s ease,border-color .15s ease}.qh-clear:hover{background:var(--color-surface-sunken);border-color:var(--color-border-strong)}.player-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.player-header-buttons{display:flex;align-items:center;gap:8px}.player-retry-btn,.player-radio-btn,.player-queue-btn{position:relative;width:32px;height:32px;border:1px solid var(--color-border-strong);background:var(--color-surface);border-radius:50%;padding:0;font-size:.85rem;color:var(--color-text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .15s ease,color .15s ease,border-color .15s ease}.player-retry-btn:hover,.player-radio-btn:hover,.player-queue-btn:hover{background:var(--color-surface-sunken);border-color:var(--color-border-strong)}.player-radio-btn.is-active{background:var(--color-success-tint);border-color:var(--color-success);color:var(--color-success)}.player-radio-btn.is-active:hover{background:var(--color-success-tint)}.player-radio-wrapper{position:relative}.radio-mode-panel{position:absolute;bottom:calc(100% + 8px);right:0;width:220px;padding:0;gap:0;z-index:50}.radio-mode-panel .fields-section-label{padding:10px 12px 6px;font-size:.75rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.radio-mode-panel .fields-list{padding:0 0 4px}.radio-mode-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:8px 12px!important;text-align:left;gap:10px}.radio-mode-item:hover{background:var(--color-surface-sunken)}.radio-mode-item.is-selected{background:var(--color-success-tint)}.radio-mode-item.is-disabled{opacity:.5;cursor:not-allowed}.radio-mode-item.is-disabled:hover{background:transparent}.radio-mode-content{display:flex;flex-direction:column;gap:2px}.radio-mode-label{font-size:.875rem;font-weight:500;color:var(--color-text)}.radio-mode-description{font-size:.75rem;color:var(--color-text-muted)}.radio-mode-check{color:var(--color-success);font-weight:600}.radio-mode-header{display:flex;align-items:center;justify-content:space-between}.radio-source-icons{display:flex;gap:2px;margin-left:auto}.radio-source-icon{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border:none;background:none;color:var(--color-text-muted);font-size:13px;cursor:pointer;padding:0}.radio-source-icon:hover{color:var(--color-text-secondary)}.radio-source-icon.is-active{color:var(--color-text)}.radio-source-icon.is-active .fa-youtube{color:var(--color-danger)}.radio-source-icon.is-active .fa-spotify{color:var(--color-spotify)}.player-queue-count{position:absolute;top:-4px;right:-4px;display:inline-flex;align-items:center;justify-content:center;min-width:16px;height:16px;padding:0 4px;background:var(--color-accent);color:var(--color-text-inverse);border-radius:8px;font-size:.6rem;font-weight:600}.stacked-chart-view{position:fixed;top:var(--topbar-height);left:0;right:0;bottom:var(--player-bar-height);display:flex;flex-direction:column;background:var(--color-surface)}.stacked-chart-legend{display:flex;flex-wrap:wrap;gap:8px 16px;padding:12px 20px;background:var(--color-surface-alt);border-bottom:1px solid var(--color-surface-active);max-height:80px;overflow-y:auto}.stacked-chart-legend-item{display:flex;align-items:center;gap:6px;font-size:.75rem;color:var(--color-text)}.stacked-chart-legend-color{width:12px;height:12px;border-radius:2px;flex-shrink:0}.stacked-chart-legend-label{white-space:nowrap}.stacked-chart-container{flex:1;overflow:auto;padding:20px}.stacked-chart-svg{display:block}.stacked-chart-axis-label{font-size:9px;fill:var(--color-text-secondary)}.stacked-chart-grid-line{stroke:var(--color-border);stroke-width:1}.stacked-chart-block{transition:opacity .1s ease}.stacked-chart-block:hover{opacity:.8}.stacked-chart-block.is-playing{filter:drop-shadow(0 0 6px var(--color-spotlight)) drop-shadow(0 0 12px var(--color-spotlight)) drop-shadow(0 0 20px var(--color-spotlight));stroke:var(--color-text-inverse);stroke-width:1}.stacked-chart-toolbar{display:flex;align-items:center;gap:16px;padding:10px 20px;background:var(--color-surface);border-bottom:1px solid var(--color-surface-active)}.zoom-range-label{font-size:.9rem;color:var(--color-text-secondary);font-weight:500}.zoomed-chart-container{flex:1;overflow:auto;padding:0 16px 16px}.zoomed-chart-grid{display:flex;gap:12px;align-items:stretch}.zoomed-year-column{flex:0 0 240px;width:240px;min-width:240px;max-width:240px;display:flex;flex-direction:column;background:var(--color-surface-alt)}.zoomed-year-header{padding:10px 12px;font-size:1rem;font-weight:600;color:var(--color-text);background:var(--color-surface-hover);text-align:center;border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:10}.zoomed-year-content{flex:1;padding:0;display:flex;flex-direction:column}.zoomed-year-empty{flex:1;min-height:40px;padding:8px}.zoomed-composer-group{border-left:3px solid;background:var(--color-surface)}.zoomed-composer-group.is-muted{opacity:.4}.zoomed-composer-header{padding:8px 10px;font-size:.75rem;font-weight:600;color:var(--color-text-inverse);text-transform:uppercase;letter-spacing:.03em;position:sticky;top:41px;z-index:5}.zoomed-composer-works{padding:8px 6px 6px;display:flex;flex-direction:column;gap:6px;position:relative;z-index:0}.zoomed-composer-works .card{margin:0;min-width:0}.timeline-overview{position:fixed;top:var(--topbar-height);left:0;right:0;bottom:var(--player-bar-height);display:flex;flex-direction:column;background:var(--color-surface);overflow:hidden}.timeline-overview-legend{display:flex;flex-wrap:wrap;gap:8px 16px;padding:12px 20px;background:var(--color-surface-alt);border-bottom:1px solid var(--color-surface-active);max-height:80px;overflow-y:auto}.timeline-overview-legend-item{display:flex;align-items:center;gap:6px;font-size:.75rem;color:var(--color-text)}.timeline-overview-legend-color{width:12px;height:12px;border-radius:2px;flex-shrink:0}.timeline-overview-legend-label{white-space:nowrap}.timeline-overview-container{flex:1;overflow:auto;padding:0 20px 20px}.timeline-overview-headers{position:sticky;top:0;z-index:5;display:flex;gap:2px;padding:10px 0;background:var(--color-surface)}.timeline-overview-header-bar{position:relative;height:180px;display:flex;align-items:flex-end;justify-content:flex-start;flex-shrink:0;padding:0 0 8px 8px}.timeline-overview-header-bar.is-muted{opacity:.4}.timeline-overview-header-name{writing-mode:vertical-rl;text-orientation:mixed;transform:rotate(180deg);color:var(--color-text-inverse);font-size:18px;font-weight:600;text-shadow:0 1px 3px rgba(0,0,0,.4);white-space:nowrap;flex:1;margin-left:4px}.timeline-overview-header-focus{position:absolute;top:6px;left:50%;transform:translate(-50%);border:1px solid rgba(255,255,255,.5);background:#fff3;border-radius:50%;width:24px;height:24px;font-size:12px;color:var(--color-text-inverse);cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s ease,background .15s ease}.timeline-overview-header-bar:hover .timeline-overview-header-focus{opacity:1}.timeline-overview-header-focus:hover{background:#fff6}.timeline-overview-svg{display:block}.timeline-overview-composer-label{font-size:8px;font-weight:500}.timeline-overview-composer-bar-label{font-size:9px;font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.3)}.timeline-overview-year-label{font-size:9px;fill:var(--color-text-secondary)}.timeline-overview-grid-line{stroke:var(--color-border);stroke-width:1}.timeline-overview-cell{transition:opacity .1s ease}.timeline-overview-cell:hover{opacity:.7}.timeline-overview-cell.is-playing{filter:drop-shadow(0 0 6px var(--color-spotlight)) drop-shadow(0 0 12px var(--color-spotlight)) drop-shadow(0 0 20px var(--color-spotlight));stroke:var(--color-text-inverse);stroke-width:1}.timeline-overview-overflow{font-size:8px;fill:var(--color-text-secondary);font-weight:600}.auth-panel{width:280px;padding:16px}.auth-tabs{display:flex;gap:4px;margin-bottom:16px}.auth-tabs button{flex:1;padding:8px 12px;border:1px solid var(--color-border);background:var(--color-surface-sunken);font:inherit;font-size:.85rem;cursor:pointer;transition:all .15s ease}.auth-tabs button:first-child{border-radius:4px 0 0 4px}.auth-tabs button:last-child{border-radius:0 4px 4px 0}.auth-tabs button.is-active{background:var(--color-text);border-color:var(--color-text);color:var(--color-text-inverse)}.auth-form{display:flex;flex-direction:column;gap:10px}.auth-form input{font:inherit;padding:10px 12px;border:1px solid var(--color-border-strong);border-radius:4px;font-size:.9rem}.auth-form input:focus{outline:none;border-color:var(--color-text-secondary)}.auth-form button{padding:10px 16px;border:none;background:var(--color-text);color:var(--color-text-inverse);font:inherit;font-size:.9rem;font-weight:500;border-radius:4px;cursor:pointer;transition:background .15s ease}.auth-form button:hover:not(:disabled){background:var(--color-text-secondary)}.auth-form button:disabled{opacity:.6;cursor:not-allowed}.auth-google-button{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:10px 16px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:4px;font-size:.9rem;font-weight:500;color:var(--color-text);cursor:pointer;transition:background-color .2s,box-shadow .2s}.auth-google-button:hover{background:var(--color-surface-alt);box-shadow:0 1px 3px #0000001a}.auth-google-button svg{flex-shrink:0}.auth-divider{display:flex;align-items:center;margin:16px 0;color:var(--color-text-muted);font-size:.8rem}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.auth-divider span{padding:0 12px}.auth-error{margin-top:12px;padding:8px 10px;background:var(--color-danger-tint);color:var(--color-danger-strong);font-size:.85rem;border-radius:4px}.auth-message{margin-top:12px;padding:8px 10px;background:var(--color-success-tint);color:var(--color-success);font-size:.85rem;border-radius:4px}.auth-hint{margin:12px 0 0;font-size:.8rem;color:var(--color-text-muted);text-align:center}.auth-user{text-align:center}.auth-user-email{font-weight:500;font-size:.95rem;word-break:break-all}.auth-user-hint{margin:8px 0 16px;font-size:.8rem;color:var(--color-text-muted)}.auth-signout-button{padding:8px 20px;border:1px solid var(--color-border-strong);background:var(--color-surface);font:inherit;font-size:.85rem;border-radius:4px;cursor:pointer;transition:all .15s ease}.auth-signout-button:hover{background:var(--color-surface-sunken);border-color:var(--color-border-strong)}.auth-spotify{border-top:1px solid var(--color-surface-hover);padding-top:12px;margin-top:12px}.auth-spotify-connected{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--color-text-secondary)}.auth-spotify-connected i{font-size:16px}.auth-spotify-disconnect{margin-left:auto;background:none;border:none;color:var(--color-text-muted);font-size:12px;cursor:pointer;padding:2px 0}.auth-spotify-disconnect:hover{color:var(--color-danger-strong)}.menu-panel button.auth-spotify-button{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:8px 12px;background:var(--color-spotify);color:var(--color-text-inverse);border:none;font-size:13px;font-weight:500;cursor:pointer}.menu-panel button.auth-spotify-button:hover{background:var(--color-spotify-bright)}.auth-spotify-button i{font-size:16px}.auth-offline{text-align:center;padding:8px 0}.auth-offline-icon{font-size:2rem;margin-bottom:8px}.auth-offline p{margin:4px 0;font-size:.9rem}.auth-offline-hint{color:var(--color-text-muted);font-size:.8rem!important}.auth-loading{text-align:center;padding:20px;color:var(--color-text-muted)}.spotify-panel{width:300px;padding:16px}.spotify-offline,.spotify-connect{text-align:center;padding:8px 0}.spotify-icon{font-size:2.5rem;color:var(--color-spotify);margin-bottom:12px}.spotify-connect-text{font-size:.9rem;color:var(--color-text-secondary);margin:0 0 16px;line-height:1.5}.spotify-hint{color:var(--color-text-muted);font-size:.8rem;margin-top:8px}.spotify-button{padding:10px 20px;border:none;font:inherit;font-size:.9rem;font-weight:500;border-radius:20px;cursor:pointer;transition:all .15s ease}.spotify-connect-button{background:var(--color-spotify);color:var(--color-text-inverse);display:inline-flex;align-items:center;gap:8px}.spotify-connect-button:hover{background:var(--color-spotify-bright)}.spotify-connected{display:flex;align-items:center;gap:12px;margin-bottom:16px}.spotify-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover}.spotify-avatar-placeholder{background:var(--color-spotify);color:var(--color-text-inverse);display:flex;align-items:center;justify-content:center;font-size:1.5rem}.spotify-user{display:flex;flex-direction:column;gap:2px;overflow:hidden}.spotify-name{font-weight:500;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.spotify-email{font-size:.8rem;color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.spotify-stats{display:flex;gap:16px;margin-bottom:12px}.spotify-stat{display:flex;flex-direction:column;gap:2px}.spotify-stat-value{font-size:1.5rem;font-weight:600;color:var(--color-spotify)}.spotify-stat-label{font-size:.75rem;color:var(--color-text-muted)}.spotify-synced{font-size:.8rem;color:var(--color-text-muted);margin-bottom:12px}.spotify-progress{background:var(--color-surface-sunken);padding:12px;border-radius:8px;margin-bottom:12px}.spotify-progress-text{font-size:.85rem;margin-bottom:8px}.spotify-progress-bar{height:4px;background:var(--color-border);border-radius:2px;overflow:hidden;margin-bottom:4px}.spotify-progress-fill{height:100%;background:var(--color-spotify);transition:width .2s ease}.spotify-progress-count{font-size:.75rem;color:var(--color-text-muted);text-align:right}.spotify-error{margin-bottom:12px;padding:8px 10px;background:var(--color-danger-tint);color:var(--color-danger-strong);font-size:.85rem;border-radius:4px}.spotify-actions{display:flex;gap:8px}.spotify-sync-button{flex:1;background:var(--color-surface-sunken);color:var(--color-text);border:1px solid var(--color-border)}.spotify-sync-button:hover:not(:disabled){background:var(--color-surface-hover)}.spotify-sync-button:disabled{opacity:.6;cursor:not-allowed}.spotify-disconnect-button{background:transparent;color:var(--color-text-muted);border:1px solid var(--color-border)}.spotify-disconnect-button:hover{background:var(--color-surface-sunken);color:var(--color-text-secondary)}.spotify-loading{text-align:center;padding:20px;color:var(--color-text-muted)}.spotify-import-playlist-button{background:transparent;border:1px solid var(--color-spotify);color:var(--color-spotify)}.spotify-import-playlist-button:hover{background:var(--color-spotify);color:var(--color-text-inverse)}.spotify-import-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px}.spotify-import-modal{background:var(--color-surface);width:100%;max-width:560px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 8px 32px #0000004d}.spotify-import-header{display:flex;align-items:center;gap:8px;padding:12px 16px;border-bottom:1px solid var(--color-border)}.spotify-import-title{flex:1;font-size:16px;font-weight:600;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.spotify-import-title .fa-spotify{color:var(--color-spotify)}.spotify-import-back,.spotify-import-close{background:none;border:none;cursor:pointer;padding:4px 8px;color:var(--color-text-secondary);font-size:14px}.spotify-import-back:hover,.spotify-import-close:hover{color:var(--color-text-strong)}.spotify-import-error{padding:8px 16px;color:var(--color-danger-strong);font-size:13px;background:var(--color-danger-tint)}.spotify-import-loading{padding:32px 16px;text-align:center;color:var(--color-text-muted);font-size:14px}.spotify-import-list{overflow-y:auto;flex:1}.spotify-import-empty{padding:32px 16px;text-align:center}.spotify-import-playlist-row{display:flex;align-items:center;gap:12px;padding:10px 16px;width:100%;border:none;background:none;cursor:pointer;text-align:left}.spotify-import-playlist-row:hover{background:var(--color-surface-sunken)}.spotify-import-playlist-img{width:44px;height:44px;object-fit:cover;flex-shrink:0}.spotify-import-playlist-img-placeholder{background:var(--color-border);display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);font-size:18px}.spotify-import-playlist-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.spotify-import-playlist-name{font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.spotify-import-playlist-meta{font-size:12px;color:var(--color-text-muted)}.spotify-import-playlist-arrow{color:var(--color-border-strong);font-size:12px}.spotify-import-stats{padding:12px 16px;border-bottom:1px solid var(--color-border)}.spotify-import-stats-bar{height:4px;background:var(--color-border);margin-bottom:6px}.spotify-import-stats-fill{height:100%;background:var(--color-spotify);transition:width .3s}.spotify-import-stats-text{font-size:13px;color:var(--color-text-secondary)}.spotify-import-tracks{overflow-y:auto;flex:1;min-height:0}.spotify-import-track{display:flex;align-items:center;gap:8px;padding:8px 16px;border-bottom:1px solid var(--color-surface-hover)}.spotify-import-track.is-unmatched{opacity:.4;cursor:pointer;-webkit-user-select:none;user-select:none}.spotify-import-track-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.spotify-import-track-title{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.spotify-import-track-artist{font-size:12px;color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.spotify-import-track-badge{font-size:11px;padding:2px 6px;background:var(--color-success-tint);color:var(--color-spotify);white-space:nowrap}.spotify-import-footer{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--color-border)}.spotify-import-name-input{flex:1;padding:6px 10px;border:1px solid var(--color-border);font-size:14px;outline:none}.spotify-import-name-input:focus{border-color:var(--color-spotify)}.spotify-import-button{background:var(--color-spotify);color:var(--color-text-inverse);white-space:nowrap}.spotify-import-button:disabled{opacity:.5;cursor:not-allowed}.spotify-import-track.is-unmatched:hover{background:var(--color-surface-alt);opacity:.7}.spotify-import-track.is-unmatched.is-selected{background:var(--color-accent-tint);opacity:1}.spotify-import-track-checkbox{font-size:14px;color:var(--color-text-faint);width:18px;flex-shrink:0}.spotify-import-track.is-selected .spotify-import-track-checkbox{color:var(--color-accent)}.spotify-import-manual-bar{position:sticky;top:0;z-index:2;display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--color-accent-tint);border-bottom:1px solid var(--color-accent-soft)}.spotify-import-manual-bar-count{font-size:13px;color:var(--color-accent-strong);font-weight:500}.spotify-import-manual-bar-btn{font-size:13px;padding:4px 10px;background:var(--color-accent);color:var(--color-text-inverse);border:none;cursor:pointer;display:flex;align-items:center;gap:4px}.spotify-import-manual-bar-btn:hover{background:var(--color-accent-strong)}.spotify-import-manual-search{flex:1;position:relative}.spotify-import-manual-search-input-row{display:flex;align-items:center;gap:6px;background:var(--color-surface);border:1px solid var(--color-accent-soft);padding:0 8px}.spotify-import-manual-search-input-row:focus-within{border-color:var(--color-accent)}.spotify-import-manual-search-icon{font-size:12px;color:var(--color-text-muted)}.spotify-import-manual-search-input{flex:1;border:none;outline:none;font-size:13px;padding:6px 0;background:transparent}.spotify-import-manual-search-close{background:none;border:none;cursor:pointer;color:var(--color-text-muted);padding:2px;font-size:12px}.spotify-import-manual-search-close:hover{color:var(--color-text)}.spotify-import-manual-search-results{position:absolute;top:100%;left:0;right:0;background:var(--color-surface);border:1px solid var(--color-border);border-top:none;max-height:200px;overflow-y:auto;z-index:10;box-shadow:0 4px 12px #0000001a}.spotify-import-manual-search-result{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;border:none;border-bottom:1px solid var(--color-surface-sunken);background:var(--color-surface);cursor:pointer;text-align:left;font-size:13px}.spotify-import-manual-search-result:last-child{border-bottom:none}.spotify-import-manual-search-result:hover,.spotify-import-manual-search-result.is-selected{background:var(--color-surface-sunken)}.spotify-import-manual-search-result-title{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}.spotify-import-manual-search-result-meta{font-size:12px;color:var(--color-text-muted);white-space:nowrap}.spotify-import-manual-search-empty{padding:12px;text-align:center;color:var(--color-text-muted);font-size:13px}.player-bar-source-toggle.is-spotify{color:var(--color-spotify)}.player-bar-source-toggle.is-youtube{color:var(--color-danger)}.player-bar-spotify-label .fa-spotify{color:var(--color-spotify);margin-right:4px}.radio-source-list{margin-bottom:4px}.radio-import-btn{border-top:1px solid var(--color-border);margin-bottom:8px}.radio-import-btn .fa-download{color:var(--color-spotify)}.library-spotify-badge{color:var(--color-spotify);font-size:11px;margin-right:-2px}.library-sync-btn{background:none;border:none;cursor:pointer;padding:4px 6px;color:var(--color-text-muted);font-size:13px}.library-sync-btn:hover{color:var(--color-spotify)}.library-sync-btn.is-syncing{color:var(--color-spotify);cursor:default}.library-sync-result{font-size:12px;color:var(--color-text-secondary);padding:2px 0 4px;display:flex;gap:8px}.library-sync-result span{color:var(--color-spotify)}.docs-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px}.docs-modal{background:var(--color-surface);border-radius:16px;width:min(900px,90vw);height:min(700px,85vh);display:flex;flex-direction:column;position:relative;box-shadow:0 20px 60px #0000004d}.docs-modal-close{position:absolute;top:16px;right:16px;width:32px;height:32px;border:none;background:#0000000d;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);font-size:14px;z-index:1;transition:background .15s,color .15s}.docs-modal-close:hover{background:#0000001a;color:var(--color-text)}.docs-modal-content{flex:1;overflow-y:auto;padding:24px 32px}.docs-image-container{background:var(--color-surface-alt);border-radius:12px;padding:16px;margin-bottom:20px;display:flex;align-items:center;justify-content:center}.docs-image{max-width:100%;max-height:300px;border-radius:8px;box-shadow:0 4px 20px #0000001a}.docs-image-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.docs-image-grid .docs-image{max-height:140px;width:100%;object-fit:contain}.docs-video-container{margin-bottom:20px;overflow:hidden}.docs-video{width:100%;height:auto;display:block}.docs-icon-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 16px;margin-bottom:20px}.docs-icon{width:100px;height:100px;border-radius:50%;background:var(--color-surface-hover);display:flex;align-items:center;justify-content:center;font-size:42px;color:var(--color-text-secondary)}.docs-icon-coming-soon{background:linear-gradient(135deg,var(--color-spotify) 0%,var(--color-spotify-bright) 100%);color:var(--color-text-inverse)}.docs-coming-soon-badge{margin-top:16px;padding:6px 16px;background:var(--color-surface-hover);border-radius:20px;font-size:13px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.docs-text{text-align:center}.docs-text h2{margin:0 0 12px;font-size:22px;font-weight:600;color:var(--color-text-strong)}.docs-text p{margin:0;font-size:15px;line-height:1.6;color:var(--color-text-secondary)}.docs-modal-nav{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-top:1px solid var(--color-surface-hover);gap:16px}.docs-nav-btn{width:40px;height:40px;border:1px solid var(--color-border);background:var(--color-surface);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);font-size:14px;transition:all .15s}.docs-nav-btn:hover:not(:disabled){background:var(--color-surface-sunken);border-color:var(--color-border-strong);color:var(--color-text)}.docs-nav-btn:disabled{opacity:.3;cursor:not-allowed}.docs-dots{display:flex;align-items:center;gap:8px}.docs-dot{width:10px;height:10px;border-radius:50%;border:none;background:var(--color-border);cursor:pointer;padding:0;transition:background .15s,transform .15s}.docs-dot:hover{background:var(--color-text-faint);transform:scale(1.2)}.docs-dot.is-active{background:var(--color-text-secondary)}.docs-dot-icon{width:24px;height:24px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--color-text-muted);margin-left:4px}.docs-dot-icon:first-of-type{margin-left:8px}.docs-dot-icon:hover{background:var(--color-surface-hover);color:var(--color-text-secondary)}.docs-dot-icon.is-active{background:var(--color-text-secondary);color:var(--color-text-inverse)}.docs-tips{padding:20px 0}.docs-tips h2{margin:0 0 24px;font-size:22px;font-weight:600;color:var(--color-text-strong);text-align:center}.docs-tips-grid{display:flex;flex-direction:column;align-items:center;gap:100px;max-height:450px;overflow-y:auto;padding-right:8px}.docs-tip-card{background:var(--color-surface-alt);border-radius:12px;overflow:hidden;max-width:400px;width:100%;flex-shrink:0}.docs-tip-image{width:100%;height:auto;display:block}.docs-tip-text{margin:0;padding:12px 14px;font-size:13px;line-height:1.4;color:var(--color-text)}.random-tip-popup{position:fixed;bottom:24px;right:24px;width:320px;background:var(--color-surface);border-radius:12px;box-shadow:0 8px 32px #00000026;overflow:hidden;z-index:1000;animation:slideInTip .3s ease-out}@keyframes slideInTip{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.random-tip-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--color-surface-sunken);border-bottom:1px solid var(--color-border)}.random-tip-title{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--color-text-secondary)}.random-tip-title i{color:var(--color-spotlight)}.random-tip-close{width:24px;height:24px;border:none;background:none;border-radius:4px;cursor:pointer;color:var(--color-text-muted);display:flex;align-items:center;justify-content:center}.random-tip-close:hover{background:var(--color-border);color:var(--color-text-secondary)}.random-tip-image{width:100%;height:auto;display:block}.random-tip-text{margin:0;padding:12px 14px;font-size:14px;line-height:1.5;color:var(--color-text)}.random-tip-more{display:block;width:calc(100% - 28px);margin:0 14px 14px;padding:8px 12px;background:var(--color-surface-hover);border:1px solid var(--color-border);border-radius:6px;font-size:13px;color:var(--color-text);cursor:pointer;transition:background .15s,border-color .15s}.random-tip-more:hover{background:var(--color-border);border-color:var(--color-border)}.docs-shortcuts{padding:20px 0}.docs-shortcuts h2{margin:0 0 24px;font-size:22px;font-weight:600;color:var(--color-text-strong);text-align:center}.docs-shortcuts-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}.docs-shortcut-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--color-surface-alt);border-radius:8px}.docs-shortcut-item kbd{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:28px;padding:0 8px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:6px;font-family:inherit;font-size:12px;font-weight:600;color:var(--color-text);box-shadow:0 1px 2px #0000000d}.docs-shortcut-item span{font-size:14px;color:var(--color-text-secondary)}.docs-contact{display:flex;flex-direction:column;align-items:center;padding:20px 0}.docs-contact-email{display:inline-flex;align-items:center;gap:8px;margin-top:16px;padding:12px 20px;background:var(--color-surface-hover);border-radius:8px;color:var(--color-text);text-decoration:none;font-size:15px;transition:background .15s,color .15s}.docs-contact-email:hover{background:var(--color-border);color:var(--color-text-strong)}.docs-contact-email i{font-size:14px;color:var(--color-text-secondary)}.spotify-coming-soon{width:280px;padding:24px;text-align:center}.spotify-coming-soon-icon{width:64px;height:64px;margin:0 auto 16px;border-radius:50%;background:linear-gradient(135deg,var(--color-spotify) 0%,var(--color-spotify-bright) 100%);display:flex;align-items:center;justify-content:center;font-size:32px;color:var(--color-text-inverse)}.spotify-coming-soon h3{margin:0 0 8px;font-size:16px;font-weight:600;color:var(--color-text-strong)}.spotify-coming-soon p{margin:0 0 16px;font-size:13px;line-height:1.5;color:var(--color-text-secondary)}.spotify-coming-soon-badge{display:inline-block;padding:6px 16px;background:var(--color-surface-hover);border-radius:20px;font-size:11px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.info-button-wrapper{position:relative}.first-visit-tooltip{position:absolute;top:calc(100% + 12px);right:0;background:var(--color-text);color:var(--color-text-inverse);padding:10px 14px;border-radius:8px;font-size:13px;font-weight:500;white-space:nowrap;cursor:pointer;display:flex;align-items:center;gap:8px;box-shadow:0 4px 12px #0003;animation:tooltip-bounce 2s ease-in-out infinite;z-index:100}.first-visit-tooltip:before{content:"";position:absolute;top:-6px;right:14px;width:12px;height:12px;background:var(--color-text);transform:rotate(45deg)}.first-visit-tooltip i{font-size:12px;animation:arrow-bounce 1s ease-in-out infinite}@keyframes tooltip-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(4px)}}@keyframes arrow-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}.subscription-panel{width:280px;padding:16px}.subscription-loading{text-align:center;padding:20px;color:var(--color-text-muted)}.subscription-upsell{text-align:center}.subscription-icon{font-size:32px;color:var(--color-spotlight);margin-bottom:8px}.subscription-upsell h3{margin:0 0 12px;font-size:18px}.subscription-signin-prompt{font-size:.9rem;color:var(--color-text-secondary)}.subscription-price{margin-bottom:16px}.price-amount{font-size:36px;font-weight:700}.price-period{font-size:14px;color:var(--color-text-secondary)}.subscription-hidden-matches{background:#f5c8421a;border:1px solid rgba(245,200,66,.3);border-radius:4px;padding:8px 12px;margin-bottom:16px;font-size:13px;color:var(--color-warning-strong)}.subscription-features{list-style:none;padding:0;margin:0 0 16px;text-align:left}.subscription-features li{padding:6px 0;font-size:14px}.subscription-features i{color:var(--color-spotify);margin-right:8px}.subscription-upgrade-button{width:100%;padding:12px 16px;background:linear-gradient(135deg,var(--color-spotlight) 0%,var(--color-spotlight-strong) 100%);border:none;border-radius:6px;color:var(--color-text-strong);font-weight:600;cursor:pointer;transition:transform .15s,box-shadow .15s}.subscription-upgrade-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #f5c84266}.subscription-upgrade-button:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.subscription-active{text-align:center}.subscription-badge{display:inline-flex;align-items:center;gap:6px;background:linear-gradient(135deg,var(--color-spotlight) 0%,var(--color-spotlight-strong) 100%);color:var(--color-text-strong);padding:8px 16px;border-radius:20px;font-weight:600;margin-bottom:12px}.subscription-trial,.subscription-period{font-size:13px;color:var(--color-text-secondary);margin-bottom:12px}.subscription-feature{font-size:14px;color:var(--color-text);margin-bottom:16px}.subscription-feature i{color:var(--color-spotify);margin-right:6px}.subscription-manage-button{padding:10px 16px;background:var(--color-surface-hover);border:none;border-radius:6px;cursor:pointer;font:inherit;font-size:.9rem}.subscription-manage-button:hover{background:var(--color-border)}.subscription-error{color:var(--color-danger);font-size:13px;margin-bottom:12px;cursor:pointer}.icon-button.is-pro{color:var(--color-spotlight)}.spotify-upgrade-prompt{display:flex;align-items:center;justify-content:space-between;background:#f5c8421a;border:1px solid rgba(245,200,66,.3);border-radius:6px;padding:10px 12px;margin-top:12px}.spotify-hidden-count{font-size:13px;color:var(--color-warning-strong)}.spotify-upgrade-button{padding:6px 12px;background:linear-gradient(135deg,var(--color-spotlight) 0%,var(--color-spotlight-strong) 100%);border:none;border-radius:4px;color:var(--color-text-strong);font-size:12px;font-weight:600;cursor:pointer}.spotify-upgrade-button:hover{filter:brightness(1.05)}.player-bar{position:fixed;bottom:0;left:0;right:0;height:64px;background:var(--color-surface);border-top:1px solid var(--color-border);display:flex;align-items:center;gap:16px;padding:0 16px;z-index:400;box-shadow:0 -2px 10px #0000000d}.player-bar-info{flex:0 0 180px;min-width:0;overflow:hidden}.player-bar-title{font-size:14px;font-weight:600;color:var(--color-text-strong);white-space:nowrap;overflow:hidden}.player-bar-title.is-live{color:var(--color-danger);animation:live-pulse 2s ease-in-out infinite}@keyframes live-pulse{0%,to{opacity:1}50%{opacity:.7}}.scrolling-text-container{position:relative;overflow:hidden}.scrolling-text{display:inline-block;white-space:nowrap}.scrolling-text-container:hover .scrolling-text{animation:scroll-text 10s linear infinite;animation-delay:.5s}@keyframes scroll-text{0%,10%{transform:translate(0)}45%,55%{transform:translate(var(--scroll-distance, -50px))}90%,to{transform:translate(0)}}.player-bar-artist{font-size:12px;color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-bar-no-match{color:var(--color-text-muted);font-style:italic}.player-bar-video{flex:0 0 160px;min-width:0;overflow:hidden}.player-bar-video-wrapper{position:relative;display:flex;align-items:center;min-width:0;flex:1}.player-bar-video-title{font-size:11px;color:var(--color-text-muted);white-space:nowrap;overflow:hidden;flex:1;min-width:0}.player-bar-video-actions{position:absolute;right:0;top:50%;transform:translateY(-50%);display:flex;gap:2px;opacity:0;background:linear-gradient(to right,transparent,var(--color-surface) 8px,var(--color-surface));padding-left:16px;transition:opacity .15s ease}.player-bar-video-wrapper:hover .player-bar-video-actions{opacity:1}.player-bar-video-action{width:20px;height:20px;border:none;background:transparent;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);font-size:11px;text-decoration:none;transition:background .15s ease,color .15s ease}.player-bar-video-action:hover{background:var(--color-surface-hover);color:var(--color-text-strong)}.player-bar-video-action .fa-youtube{color:var(--color-danger)}.player-bar-video-action .fa-flag{color:var(--color-text-muted)}.player-bar-video-action:hover .fa-flag{color:var(--color-danger)}.player-bar-status{font-size:11px;color:var(--color-text-muted)}.player-bar-error{font-size:11px;color:var(--color-danger)}.player-bar-ad-notice{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--color-warning);background:var(--color-warning-tint);padding:4px 8px;border-radius:4px}.player-bar-ad-notice .fa-ad{font-size:12px}.player-bar-live-info{display:flex;flex-direction:column;gap:2px}.player-bar-live-link{font-size:11px;color:var(--color-text-muted);text-decoration:none;transition:color .15s ease}.player-bar-live-link:hover{color:var(--color-accent-strong);text-decoration:underline}.player-bar-nothing{font-size:12px;color:var(--color-text-muted)}.player-bar-start-radio-link{border:none;background:transparent;cursor:pointer;font-size:12px;color:var(--color-text-muted);text-decoration:none;transition:color .15s ease;padding:0;font-family:inherit}.player-bar-start-radio-link:hover{color:var(--color-accent-strong);text-decoration:underline}.player-bar-controls{display:flex;align-items:center;gap:4px}.player-bar-controls .player-bar-btn{border-radius:50%}.player-bar-btn{width:32px;height:32px;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--color-text);transition:background .15s ease,color .15s ease;position:relative}.player-bar-btn:hover:not(:disabled){background:var(--color-surface-hover);color:var(--color-text-strong)}.player-bar-btn:disabled{color:var(--color-border-strong);cursor:default}.player-bar-btn.is-inactive{color:var(--color-border-strong)}.player-bar-btn.is-disabled{opacity:.3;cursor:not-allowed}.player-bar-btn.is-active{color:var(--color-accent-strong)}.player-bar-btn.is-active:hover:not(:disabled){background:var(--color-accent-tint)}.player-bar-btn-main{width:34px;height:34px;background:var(--color-text-strong);color:var(--color-text-inverse)}.player-bar-btn-main:hover:not(:disabled){background:var(--color-text);color:var(--color-text-inverse)}.player-bar-btn-main:disabled{background:var(--color-border-strong)}.player-bar-badge{position:absolute;top:0;right:0;background:var(--color-accent-strong);color:var(--color-text-inverse);font-size:9px;font-weight:600;min-width:14px;height:14px;border-radius:7px;display:flex;align-items:center;justify-content:center;padding:0 3px}.player-bar-progress{flex:1;display:flex;align-items:center;gap:8px;min-width:120px}.player-bar-time{font-size:11px;color:var(--color-text-muted);font-variant-numeric:tabular-nums;min-width:36px}.player-bar-time:last-child{text-align:right}.player-bar-progress-track{flex:1;height:4px;background:var(--color-border);border-radius:2px;cursor:pointer;position:relative}.player-bar-progress-track:hover{height:6px;margin:-1px 0}.player-bar-progress-fill{position:absolute;top:0;left:0;height:100%;background:var(--color-text-strong);border-radius:2px;transition:width .1s linear}.player-bar-progress.is-disabled{opacity:.3;pointer-events:none}.player-bar-progress.is-disabled .player-bar-progress-track{cursor:default}.player-bar-volume{display:flex;align-items:center;gap:6px;color:var(--color-text-muted);font-size:12px}.player-bar-volume-btn{background:none;border:none;color:inherit;cursor:pointer;padding:2px;display:flex;align-items:center;justify-content:center}.player-bar-volume-btn:hover{color:var(--color-text)}.player-bar-volume-slider{width:80px;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--color-border);border-radius:2px;cursor:pointer}.player-bar-volume-slider::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;background:var(--color-text);border-radius:50%;cursor:pointer}.player-bar-volume-slider::-moz-range-thumb{width:12px;height:12px;background:var(--color-text);border-radius:50%;border:none;cursor:pointer}.player-bar-actions{display:flex;align-items:center;gap:2px;position:relative}.player-bar-hamburger{display:none;width:32px;height:32px;border:none;background:transparent;cursor:pointer;align-items:center;justify-content:center;color:var(--color-text);transition:background .15s ease,color .15s ease}.player-bar-hamburger:hover{background:var(--color-surface-hover);color:var(--color-text-strong)}.player-bar-actions-collapsible{display:contents}.player-bar-radio-wrapper{position:relative}.player-bar-radio-wrapper .radio-mode-panel{top:auto;bottom:calc(100% + 8px)}@media (max-width: 1050px){.player-bar-hamburger{display:flex}.player-bar-actions-collapsible{display:none;position:absolute;right:100%;bottom:50%;transform:translateY(50%);background:var(--color-surface);border:1px solid var(--color-border);padding:6px;gap:2px;align-items:center;z-index:10}.player-bar-actions-collapsible.is-expanded{display:flex}.player-bar-actions-collapsible .player-bar-radio-wrapper .radio-mode-panel{bottom:calc(100% + 4px);right:0;left:auto}}@media (max-width: 950px){.player-bar-video{flex:0 0 120px}}@media (max-width: 850px){.player-bar-video{display:none}}@media (max-width: 750px){.player-bar-volume{display:none}.player-bar-info{flex:0 0 140px}}@media (max-width: 600px){.player-bar-info{flex:0 0 110px}}@media (max-width: 500px){.player-bar-info{flex:0 0 90px}.player-bar{gap:10px;padding:0 10px}.player-bar-progress{min-width:80px}}.library-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:200;display:flex;align-items:center;justify-content:center;padding:40px;animation:library-fade-in .2s ease}@keyframes library-fade-in{0%{opacity:0}to{opacity:1}}.library-modal{background:var(--color-surface);box-shadow:0 20px 60px #0000004d;display:flex;width:100%;max-width:900px;height:80vh;max-height:700px;overflow:hidden;animation:library-slide-up .25s ease}.library-modal.is-add-mode{max-width:280px;height:auto;max-height:500px}.library-modal.is-add-mode .library-sidebar{width:100%;border-right:none}.library-modal.is-add-mode .library-content{display:none}@keyframes library-slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.library-sidebar{width:220px;flex-shrink:0;background:var(--color-surface-alt);border-right:1px solid var(--color-border);display:flex;flex-direction:column;overflow-y:auto}.library-section{padding:12px 8px}.library-divider{height:1px;background:var(--color-border);margin:0 12px}.library-playlists{flex:1;overflow-y:auto;min-height:0}.library-sidebar-playlist{position:relative}.library-sidebar-playlist.is-dragging{opacity:.4}.library-sidebar-playlist.is-drag-over{border-top:2px solid var(--color-accent);margin-top:-2px}.library-sidebar-playlist .library-collection-btn{cursor:grab}.library-sidebar-playlist .library-collection-btn:active{cursor:grabbing}.library-sidebar-footer{flex-shrink:0;border-top:1px solid var(--color-border);background:var(--color-surface-alt)}.library-collection-btn{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border:none;background:transparent;cursor:pointer;text-align:left;font:inherit;font-size:.9rem;color:var(--color-text);transition:background .15s}.library-collection-btn:hover{background:var(--color-border)}.library-collection-btn.is-selected{background:var(--color-accent-tint);color:var(--color-accent-strong)}.library-collection-btn i{width:16px;text-align:center;font-size:.85rem;opacity:.7}.library-collection-btn.is-selected i{opacity:1}.library-collection-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.library-collection-count{font-size:.75rem;color:var(--color-text-muted);background:var(--color-border);padding:2px 6px;min-width:20px;text-align:center}.library-collection-btn.is-selected .library-collection-count{background:var(--color-accent-soft);color:var(--color-accent-strong)}.library-new-playlist-btn{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border:none;background:transparent;cursor:pointer;text-align:left;font:inherit;font-size:.9rem;color:var(--color-text-secondary);transition:background .15s,color .15s}.library-new-playlist-btn:hover{background:var(--color-border);color:var(--color-text)}.library-new-playlist-btn i{width:16px;text-align:center;font-size:.85rem}.library-new-playlist-form{display:flex;align-items:center;gap:6px;padding:8px 12px}.library-new-playlist-form input{flex:1;padding:8px 10px;border:1px solid var(--color-border);background:var(--color-surface);font:inherit;font-size:.85rem;min-width:0}.library-new-playlist-form input:focus{outline:none;border-color:var(--color-accent)}.library-new-playlist-save{width:32px;height:32px;border:none;background:var(--color-success);color:var(--color-text-inverse);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.85rem;flex-shrink:0;transition:background .15s}.library-new-playlist-save:hover:not(:disabled){background:var(--color-success)}.library-new-playlist-save:disabled{background:var(--color-border);cursor:default}.library-new-playlist-cancel{background:var(--color-surface-hover);color:var(--color-text-secondary)}.library-new-playlist-cancel:hover{background:var(--color-border)}.library-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.library-header{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--color-border);flex-shrink:0}.library-title{flex:1;font-size:1.25rem;font-weight:600;margin:0;color:var(--color-text-strong)}.library-title-empty{color:var(--color-text-muted);font-weight:400}.library-title-section{display:flex;align-items:center;gap:12px;flex:1}.library-play-buttons{display:flex;gap:4px}.library-play-btn,.library-shuffle-btn{width:28px;height:28px;border-radius:4px;border:none;background:transparent;color:var(--color-text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.85rem;transition:background-color .15s,color .15s}.library-play-btn:hover,.library-shuffle-btn:hover{background:var(--color-border);color:var(--color-text)}.library-header-controls{display:flex;align-items:center;gap:8px}.library-sort-select{padding:6px 10px;border:1px solid var(--color-border);font:inherit;font-size:.85rem;background:var(--color-surface);cursor:pointer}.library-sort-select:focus{outline:none;border-color:var(--color-accent)}.library-clear-btn{padding:6px 12px;border:1px solid var(--color-border);background:var(--color-surface);font:inherit;font-size:.85rem;cursor:pointer;color:var(--color-text-secondary)}.library-clear-btn:hover{background:var(--color-surface-hover);color:var(--color-text)}.library-delete-btn{width:32px;height:32px;border:1px solid var(--color-border);background:transparent;color:var(--color-border);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.library-delete-btn:hover{border-color:var(--color-text-muted);color:var(--color-text-secondary)}.library-delete-btn.is-confirming{background:var(--color-danger-tint);border-color:var(--color-danger-soft);color:var(--color-danger-strong);width:auto;padding:0 12px;font-size:.8rem;font-weight:500}.library-delete-btn.is-confirming:hover{background:var(--color-danger-tint);border-color:var(--color-danger-soft);color:var(--color-danger-strong)}.library-close-btn{width:32px;height:32px;border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.1rem;margin-left:8px}.library-close-btn:hover{background:var(--color-surface-hover);color:var(--color-text)}.library-items{flex:1;overflow-y:auto;padding:0}.library-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:16px 20px;color:var(--color-text-muted);text-align:center}.library-empty p{margin:0}.library-empty-playlist{justify-content:flex-start}.library-empty-search{margin-top:0;align-self:stretch}.library-table-header{display:flex;align-items:center;padding:0 12px 0 4px;border-bottom:1px solid var(--color-border);background:var(--color-surface-alt);position:sticky;top:0;z-index:5;flex-shrink:0}.library-th{padding:6px 8px;font-size:.7rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.library-th-checkbox{width:28px;flex-shrink:0}.library-th-handle{width:20px;flex-shrink:0}.library-th-title{width:40%;flex-shrink:0;min-width:0}.library-th-composer{width:120px;flex-shrink:0}.library-th-year{width:55px;flex-shrink:0;text-align:right}.library-th-type,.library-th-genre,.library-th-key,.library-th-opus,.library-th-catalogNumbers,.library-th-forces{width:100px;flex-shrink:0}.library-th-add{width:32px;flex-shrink:0;position:relative;display:flex;align-items:center;justify-content:center}.library-column-add-btn{width:20px;height:20px;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.6rem;transition:all .15s}.library-column-add-btn:hover{border-color:var(--color-text-muted);color:var(--color-text);background:var(--color-surface-hover)}.library-column-picker{position:absolute;top:100%;right:0;margin-top:4px;min-width:160px;background:var(--color-surface);border:1px solid var(--color-border);box-shadow:0 4px 12px #00000026;z-index:20}.library-column-picker-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;border:none;background:transparent;text-align:left;font-size:.85rem;color:var(--color-text);cursor:pointer;transition:background .1s}.library-column-picker-item:hover{background:var(--color-surface-hover)}.library-column-picker-item.is-active{color:var(--color-accent-strong)}.library-column-picker-check{width:16px;display:flex;align-items:center;justify-content:center;font-size:.7rem}.library-table-footer{padding:0}.library-list{display:flex;flex-direction:column}.library-row{position:relative;display:flex;align-items:center;padding:0 12px 0 4px;border-left:2px solid transparent;border-bottom:1px solid var(--color-surface-hover);min-height:34px;transition:background-color .1s;content-visibility:auto;contain-intrinsic-size:auto 35px}.library-row:hover{background-color:var(--color-surface-alt)}.library-row.is-now-playing{border-left-color:var(--color-success)}.library-row.is-dragging{opacity:.5}.library-row.is-drag-over{border-top:2px solid var(--color-accent);margin-top:-2px}.library-row.is-selected{background:var(--color-accent-tint)}.library-row-handle{width:20px;flex-shrink:0;display:flex;align-items:center;justify-content:center;cursor:grab;color:var(--color-border);opacity:0;transition:opacity .15s;font-size:.65rem}.library-row:hover .library-row-handle{opacity:1}.library-row-handle:active{cursor:grabbing;color:var(--color-text-muted)}.library-row-cell{padding:6px 8px;font-size:.85rem;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.library-row-title{width:40%;flex-shrink:0;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.library-row-composer{width:120px;flex-shrink:0;color:var(--color-text-secondary)}.library-row-year{width:55px;flex-shrink:0;text-align:right;color:var(--color-text-secondary);font-variant-numeric:tabular-nums}.library-row-type,.library-row-genre,.library-row-key,.library-row-opus,.library-row-catalogNumbers,.library-row-forces{width:100px;flex-shrink:0;color:var(--color-text-secondary)}.library-row-actions{display:flex;align-items:center;gap:3px;opacity:0;flex-shrink:0;margin-left:auto;padding-left:8px;transition:opacity .1s}.library-row:hover .library-row-actions{opacity:1}.library-row-action{width:26px;height:26px;border:1px solid var(--color-border-strong);background:var(--color-surface);border-radius:999px;color:var(--color-text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.65rem;transition:color .1s,background-color .1s,border-color .1s}.library-row-action:hover{color:var(--color-text);background:var(--color-surface-hover);border-color:var(--color-text-muted)}.library-row-action.is-playing{color:var(--color-success);border-color:var(--color-success-soft)}.library-row-action.is-starting{animation:pulse-green .5s ease}.library-row-action.is-fav-active{color:var(--color-danger);border-color:var(--color-danger-soft)}.library-row-action.is-fav-active:hover,.library-row-action-remove:hover{color:var(--color-danger-strong);background:var(--color-danger-tint);border-color:var(--color-danger-soft)}@keyframes pulse-green{0%{transform:scale(1)}50%{transform:scale(1.3)}to{transform:scale(1)}}.library-row-checkbox{display:flex;align-items:center;justify-content:center;width:28px;flex-shrink:0;cursor:pointer}.library-row-checkbox input{position:absolute;opacity:0;width:0;height:0}.library-add-mode-header{padding:12px 16px;border-bottom:1px solid var(--color-border);background:var(--color-surface-alt)}.library-add-mode-title{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);margin:0 0 4px}.library-add-mode-item{font-size:.9rem;font-weight:500;color:var(--color-text-strong);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0}.library-close-btn-add-mode{position:absolute;top:8px;right:8px;width:24px;height:24px;border:none;background:transparent;color:var(--color-text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.9rem}.library-close-btn-add-mode:hover{color:var(--color-text)}.library-collection-btn.is-just-added{animation:flash-green .4s ease}.library-collection-btn.is-already-added{animation:flash-yellow .4s ease}@keyframes flash-green{0%{background:var(--color-success-tint)}to{background:transparent}}@keyframes flash-yellow{0%{background:var(--color-warning-tint)}to{background:transparent}}.library-edit-btn{width:28px;height:28px;border:none;background:transparent;color:var(--color-text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.8rem;transition:background-color .15s,color .15s}.library-edit-btn:hover{background:var(--color-border);color:var(--color-text)}.library-edit-btn.is-active{background:var(--color-accent);color:var(--color-text-inverse)}.library-edit-btn.is-active:hover{background:var(--color-accent-strong)}.library-title.is-editable{cursor:pointer}.library-title.is-editable:hover{text-decoration:underline;text-decoration-style:dotted;text-underline-offset:3px}.library-title-input{flex:1;font-size:1.25rem;font-weight:600;color:var(--color-text-strong);padding:4px 8px;border:1px solid var(--color-accent);background:var(--color-surface);margin:-4px 0;box-shadow:0 0 0 2px #3b82f633}.library-title-input:focus{outline:none}.playlist-search-add-btn{display:flex;align-items:center;gap:8px;padding:6px 20px 6px 32px;background:transparent;border:none;border-bottom:1px solid var(--color-surface-hover);color:var(--color-text-muted);font-size:.85rem;cursor:pointer;transition:background-color .1s,color .1s;width:100%;min-height:34px}.playlist-search-add-btn:hover{background:var(--color-surface-alt);color:var(--color-text-secondary)}.playlist-search-add-btn i{font-size:.65rem}.playlist-search{position:relative}.playlist-search-input-container{display:flex;align-items:center;gap:8px;padding:4px 12px 4px 28px;background:var(--color-surface);border:none;border-bottom:1px solid var(--color-border);min-height:34px}.playlist-search-input-container:focus-within{background:var(--color-surface-alt)}.playlist-search-icon{color:var(--color-text-muted);font-size:14px}.playlist-search-input{flex:1;border:none;background:transparent;font-size:14px;outline:none;min-width:0}.playlist-search-input::placeholder{color:var(--color-text-muted)}.playlist-search-close{display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;background:transparent;border:none;border-radius:4px;color:var(--color-text-muted);cursor:pointer;transition:all .1s ease}.playlist-search-close:hover{background:#00000014;color:var(--color-text-secondary)}.playlist-search-results{position:absolute;top:100%;left:0;right:0;margin-top:0;background:var(--color-surface);border:1px solid var(--color-border);box-shadow:0 4px 12px #00000026;z-index:10;max-height:320px;overflow-y:auto}.playlist-search-result{display:flex;align-items:center;gap:8px;width:100%;padding:10px 12px;background:transparent;border:none;border-bottom:1px solid var(--color-surface-hover);text-align:left;cursor:pointer;transition:background .1s ease}.playlist-search-result:last-child{border-bottom:none}.playlist-search-result:hover,.playlist-search-result.is-selected{background:var(--color-surface-sunken)}.playlist-search-result.is-added{background:var(--color-success-tint)}.playlist-search-result-title{flex:1;font-size:14px;font-weight:500;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.playlist-search-result-meta{font-size:12px;color:var(--color-text-muted);white-space:nowrap}.playlist-search-result-check{color:var(--color-success);font-size:14px}.playlist-search-empty{padding:16px 12px;text-align:center;color:var(--color-text-muted);font-size:14px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;margin-top:4px;box-shadow:0 4px 12px #00000026}.library-item-checkbox{display:flex;align-items:center;justify-content:center;width:28px;height:100%;min-height:48px;flex-shrink:0;cursor:pointer;align-self:stretch}.library-item-checkbox input{position:absolute;opacity:0;width:0;height:0}.library-item-checkbox-mark{width:18px;height:18px;border:2px solid var(--color-border);border-radius:4px;background:var(--color-surface);display:flex;align-items:center;justify-content:center;transition:all .15s ease}.library-item-checkbox input:checked+.library-item-checkbox-mark{background:var(--color-accent);border-color:var(--color-accent)}.library-item-checkbox input:checked+.library-item-checkbox-mark:after{content:"";width:5px;height:9px;border:solid var(--color-surface);border-width:0 2px 2px 0;transform:rotate(45deg);margin-bottom:2px}.library-item-checkbox:hover .library-item-checkbox-mark{border-color:var(--color-text-muted)}.library-item.is-selected{background:var(--color-accent-tint)}.library-bulk-bar{position:sticky;bottom:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--color-surface-hover);border:1px solid var(--color-border);border-radius:8px;margin-top:16px;gap:16px}.library-bulk-info{display:flex;align-items:center;gap:12px}.library-bulk-count{color:var(--color-text);font-size:14px;font-weight:500}.library-bulk-select-all{background:transparent;border:none;color:var(--color-accent);font-size:13px;cursor:pointer;padding:0}.library-bulk-select-all:hover{text-decoration:underline}.library-bulk-actions{display:flex;align-items:center;gap:8px}.library-bulk-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:6px;color:var(--color-text);font-size:13px;cursor:pointer;transition:all .15s ease}.library-bulk-btn:hover{background:var(--color-surface-alt);border-color:var(--color-text-muted)}.library-bulk-btn-danger{color:var(--color-danger-strong);border-color:var(--color-danger-tint)}.library-bulk-btn-danger:hover{background:var(--color-danger-tint);border-color:var(--color-danger-soft)}.library-bulk-btn-confirming{background:var(--color-danger-tint);border-color:var(--color-danger-soft);color:var(--color-danger-strong)}.library-bulk-btn-confirming:hover{background:var(--color-danger-tint);border-color:var(--color-danger-soft)}.library-bulk-btn i{font-size:12px}.library-bulk-dropdown{position:relative}.library-bulk-dropdown-menu{position:absolute;bottom:100%;left:0;margin-bottom:4px;min-width:180px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;box-shadow:0 4px 12px #00000026;overflow:hidden;z-index:20}.library-bulk-dropdown-item{display:block;width:100%;padding:10px 12px;background:transparent;border:none;text-align:left;font-size:14px;color:var(--color-text);cursor:pointer;transition:background .1s ease}.library-bulk-dropdown-item:hover{background:var(--color-surface-hover)}.library-bulk-dropdown-item:not(:last-child){border-bottom:1px solid var(--color-border)}.library-playlist-picker-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:60}.library-playlist-picker{background:var(--color-surface);width:300px;max-height:400px;display:flex;flex-direction:column;box-shadow:0 8px 32px #0003}.library-playlist-picker-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--color-border);font-weight:600}.library-playlist-picker-header button{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:6px;color:var(--color-text-secondary);cursor:pointer}.library-playlist-picker-header button:hover{background:var(--color-surface-hover)}.library-playlist-picker-item-name{padding:12px 16px;font-size:13px;color:var(--color-text-secondary);background:var(--color-surface-alt);border-bottom:1px solid var(--color-border);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.library-playlist-picker-list{flex:1;overflow-y:auto;padding:8px}.library-playlist-picker-btn{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;background:transparent;border:none;border-radius:6px;text-align:left;font-size:14px;color:var(--color-text);cursor:pointer;transition:background .1s ease}.library-playlist-picker-btn:hover{background:var(--color-surface-hover)}.library-playlist-picker-btn i{color:var(--color-text-muted);font-size:12px}.library-playlist-picker-empty{padding:24px 16px;text-align:center;color:var(--color-text-muted);font-size:13px}.library-playlist-picker-footer{border-top:1px solid var(--color-border);padding:8px}.library-playlist-picker-create-btn,.library-playlist-picker-create-btn i{color:var(--color-text-secondary)}.library-playlist-picker-create{display:flex;gap:6px}.library-playlist-picker-create input{flex:1;padding:8px 10px;border:1px solid var(--color-border);font-size:13px}.library-playlist-picker-create input:focus{outline:none;border-color:var(--color-accent)}.library-playlist-picker-confirm{width:34px;height:34px;display:flex;align-items:center;justify-content:center;background:none;color:var(--color-text-muted);border:none;cursor:pointer;transition:color .15s ease}.library-playlist-picker-confirm:hover{color:var(--color-accent)}.library-playlist-picker-confirm:disabled{color:var(--color-border);cursor:not-allowed}@media (max-width: 700px){.library-modal-overlay{padding:0}.library-modal{border-radius:0;height:100vh;max-height:none}.library-sidebar{width:180px}}.playlist-picker{background:var(--color-surface);border-radius:8px;box-shadow:0 4px 20px #00000026,0 0 0 1px #0000000d;width:200px;max-height:280px;display:flex;flex-direction:column;overflow:hidden;animation:playlist-picker-in .15s ease-out}@keyframes playlist-picker-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.playlist-picker-header{padding:10px 12px;font-size:.75rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--color-border)}.playlist-picker-list{flex:1;overflow-y:auto;padding:4px 0}.playlist-picker-empty{padding:16px 12px;text-align:center;color:var(--color-text-muted);font-size:.85rem}.playlist-picker-item{width:100%;padding:8px 12px;display:flex;align-items:center;gap:8px;background:none;border:none;text-align:left;cursor:pointer;font-size:.9rem;color:var(--color-text)}.playlist-picker-item:hover{background:var(--color-surface-hover)}.playlist-picker-item i{color:var(--color-text-muted);font-size:.8rem}.playlist-picker-new{width:100%;padding:10px 12px;display:flex;align-items:center;gap:8px;background:none;border:none;border-top:1px solid var(--color-border);text-align:left;cursor:pointer;font-size:.85rem;color:var(--color-text-secondary)}.playlist-picker-new:hover{background:var(--color-surface-hover);color:var(--color-text)}.playlist-picker-new i{font-size:.75rem}.playlist-picker-create-form{display:flex;padding:8px;gap:6px;border-top:1px solid var(--color-border)}.playlist-picker-create-form input{flex:1;padding:6px 10px;border:1px solid var(--color-border);border-radius:4px;font-size:.85rem}.playlist-picker-create-form input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 2px #3b82f626}.playlist-picker-create-btn{width:28px;height:28px;border:none;border-radius:4px;background:var(--color-accent);color:var(--color-text-inverse);cursor:pointer;display:flex;align-items:center;justify-content:center}.playlist-picker-create-btn:hover:not(:disabled){background:var(--color-accent-strong)}.playlist-picker-create-btn:disabled{opacity:.5;cursor:not-allowed}
