:root{--bg-0: oklch(.13 .012 280);--bg-1: oklch(.165 .014 280);--bg-2: oklch(.205 .016 280);--bg-3: oklch(.255 .018 280);--line: oklch(.28 .018 280);--line-soft: oklch(.23 .015 280);--fg: oklch(.97 .005 280);--fg-2: oklch(.78 .01 280);--fg-3: oklch(.58 .012 280);--fg-4: oklch(.44 .012 280);--acc-h: 280;--acc-c: .02;--acc-l: .7;--acc: oklch(var(--acc-l) var(--acc-c) var(--acc-h));--acc-fg: oklch(.18 .02 var(--acc-h));--acc-soft: oklch(.3 .08 var(--acc-h));--acc-bg: oklch(.2 .05 var(--acc-h) / .5);--bg: var(--bg-0);--surface: var(--bg-1);--text: var(--fg);--muted: var(--fg-3);--accent: var(--acc);--accent-hover: oklch(calc(var(--acc-l) + .06) var(--acc-c) var(--acc-h));--border: var(--line-soft)}*{box-sizing:border-box}body{margin:0;font-family:Geist,system-ui,sans-serif;font-size:14px;background:var(--bg-0);color:var(--fg);overflow:hidden}.display{font-family:"Instrument Serif",Georgia,serif}.mono{font-family:Geist Mono,Fira Code,monospace}.upper{text-transform:uppercase;letter-spacing:.08em;font-size:.7rem;font-weight:600}.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.row-between{display:flex;align-items:center;justify-content:space-between}.app{display:grid;grid-template-columns:248px 1fr 360px;height:100vh;overflow:hidden;position:relative}.app-main-column{display:contents}.ambient{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;background:radial-gradient(ellipse 60% 50% at 30% 0%,oklch(.35 .1 var(--acc-h) / .18) 0%,transparent 70%);transition:background .6s ease}.sidebar{position:relative;z-index:10;display:flex;flex-direction:column;gap:0;background:var(--bg-1);border-right:1px solid var(--line-soft);height:100vh;overflow-y:auto;overflow-x:hidden;padding:20px 0 0}.brand{padding:8px 20px 20px;border-bottom:1px solid var(--line-soft);margin-bottom:8px;display:flex;align-items:center;gap:10px}.brand-mark{width:22px;height:22px;border-radius:6px;flex-shrink:0;background:linear-gradient(135deg,var(--acc) 0%,oklch(.5 .18 calc(var(--acc-h) + 60)) 100%);box-shadow:0 0 0 1px #ffffff14 inset}.brand-text{font-size:1.2rem;font-weight:400;color:var(--fg);letter-spacing:-.02em;font-family:var(--font-display, "Instrument Serif", serif)}.nav-section{display:flex;flex-direction:column;gap:2px;padding:8px 12px}.nav-section-label{color:var(--fg-4);padding:4px 8px 2px;font-size:.65rem}.nav-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:6px;border:none;background:transparent;color:var(--fg-2, var(--muted));font-size:13.5px;font-family:inherit;font-weight:400;cursor:pointer;text-align:left;transition:background .12s,color .12s;width:100%}.nav-item:hover{background:var(--bg-2);color:var(--fg)}.nav-item.active{background:var(--bg-2);color:var(--fg);font-weight:500}.nav-item-ico{width:16px;height:16px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;color:var(--fg-3)}.nav-item.active .nav-item-ico{color:var(--acc, var(--accent))}.nav-item-label{flex:1}.spaces-section{margin-top:8px;border-top:1px solid var(--line-soft);padding-top:12px;flex:1;min-height:0;overflow-y:auto}.space-list{display:flex;flex-direction:column;gap:1px}.space-row{display:grid;grid-template-columns:20px 1fr 20px;align-items:center;padding:7px 10px;border-radius:6px;border:none;background:transparent;color:var(--fg-2, var(--muted));font-size:13.5px;font-family:inherit;cursor:pointer;width:100%;transition:background .12s,color .12s}.space-row:hover{background:var(--bg-2);color:var(--fg)}.space-row.active{background:var(--acc-bg);color:var(--fg);font-weight:500}.space-row-name{text-align:center;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.swatch{width:10px;height:10px;border-radius:3px;justify-self:start;align-self:center;background:var(--swatch, var(--fg-4));box-shadow:0 0 0 1px #ffffff12 inset}.space-row.active .swatch{box-shadow:0 0 0 2px #ffffff0f,0 0 10px var(--swatch, var(--acc))}.swatch-globe{background:transparent;color:var(--fg-3);width:14px;height:14px;display:inline-flex;align-items:center;justify-content:center;box-shadow:none!important;border-radius:0;justify-self:start;align-self:center}.sidebar-divider{height:1px;background:var(--line-soft);margin:4px 8px}.sidebar-bottom{margin-top:auto;padding:8px 12px 16px;border-top:1px solid var(--line-soft)}.sidebar-bug-btn{color:var(--fg-4, var(--muted));font-size:.8rem;width:100%}.sidebar-bug-btn:hover{color:var(--fg-2, var(--text))}.main{position:relative;z-index:5;overflow-y:auto;overflow-x:hidden;padding:24px 32px 120px;height:100vh}.hero{position:relative;background:linear-gradient(180deg,transparent 0%,oklch(0 0 0 / .35) 100%),linear-gradient(135deg,oklch(var(--acc-l, .72) var(--acc-c, .18) var(--acc-h, 280) / .38),oklch(.28 .1 calc(var(--acc-h, 280) + 40) / .55));border:1px solid oklch(1 0 0 / .07);border-radius:20px;padding:32px 32px 28px;margin-bottom:32px;overflow:hidden;isolation:isolate}.hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:-1;background:radial-gradient(80% 60% at 90% 10%,oklch(var(--acc-l, .72) var(--acc-c, .18) var(--acc-h, 280) / .45),transparent 60%),radial-gradient(60% 80% at 0% 100%,oklch(var(--acc-l, .72) .12 calc(var(--acc-h, 280) - 40) / .35),transparent 60%)}.hero .eyebrow{color:#ffffffb3;margin-bottom:6px;font-size:.68rem;letter-spacing:.14em}.hero-h1{margin:0 0 8px;font-size:3.5rem;font-weight:400;color:var(--fg);line-height:1;letter-spacing:-.02em}.hero-desc{color:#ffffffc7;font-size:.95rem;margin-bottom:16px;max-width:52ch}.hero-meta{display:flex;gap:18px;flex-wrap:wrap;font-size:.72rem;color:#ffffffa6;font-family:var(--font-mono, "Geist Mono", monospace);letter-spacing:.04em;text-transform:uppercase;margin-bottom:22px}.hero-meta b{color:var(--fg);font-weight:500;font-style:normal}.hero-actions{display:flex;gap:10px;flex-wrap:wrap}.hero-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border-radius:10px;font-size:.875rem;font-weight:600;cursor:pointer;border:none;font-family:inherit;transition:filter .12s,transform .12s}.hero-btn:active{transform:translateY(1px)}.hero-btn-primary{background:var(--acc);color:var(--acc-fg, #0a1a1a)}.hero-btn-primary:hover{filter:brightness(1.1)}.hero-btn-outline{background:#ffffff14;color:var(--fg);border:1px solid oklch(1 0 0 / .2)}.hero-btn-outline:hover{background:#ffffff24}.hero-btn-ghost{background:transparent;color:#ffffffbf;border:none}.hero-btn-ghost:hover{color:var(--fg)}.section{margin-bottom:32px}.section-h2{margin:0 0 14px;font-size:1.6rem;font-weight:400;color:var(--fg);letter-spacing:-.01em;line-height:1.1}.presets{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.preset{position:relative;display:flex;flex-direction:column;justify-content:space-between;gap:12px;padding:18px 18px 16px;background:var(--bg-1);border:1px solid var(--line-soft);border-radius:14px;cursor:pointer;text-align:left;overflow:hidden;transition:background .15s,border-color .15s,transform .12s;font-family:inherit;color:var(--fg);min-height:130px}.preset:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(120% 80% at 100% 0%,oklch(.7 .18 var(--preset-h, var(--acc-h, 280)) / .2),transparent 60%)}.preset:hover{background:var(--bg-2);border-color:var(--line);transform:translateY(-1px)}.preset-name{font-family:var(--font-display, "Instrument Serif", serif);font-size:1.4rem;font-weight:400;color:var(--fg);line-height:1.1;letter-spacing:-.01em;margin-bottom:4px}.preset-why{font-size:.75rem;color:var(--fg-3);line-height:1.4}.preset-foot{display:flex;align-items:center;justify-content:space-between}.preset-dur{font-family:var(--font-mono, "Geist Mono", monospace);font-size:.68rem;color:var(--fg-4);letter-spacing:.04em;text-transform:uppercase}.preset-play{width:28px;height:28px;border-radius:999px;background:#ffffff14;display:flex;align-items:center;justify-content:center;font-size:.65rem;color:var(--fg-3);transition:background .12s,color .12s}.preset:hover .preset-play{background:var(--acc);color:var(--acc-fg, #0a1a1a)}.header{display:flex;flex-direction:column;gap:.5rem;margin-bottom:2rem}.header-row{display:flex;flex-wrap:wrap;align-items:center;gap:1rem}.header h1{margin:0;font-size:1.75rem;font-weight:600;letter-spacing:-.02em}.active-space-bar{display:flex;align-items:center;gap:.4rem;padding:.25rem .6rem;background:#7c6bee1f;border:1px solid rgba(124,107,238,.25);border-radius:6px;font-size:.85rem;align-self:flex-start;transition:background .15s,border-color .15s}.active-space-bar-none{background:#ffffff0a;border-color:#ffffff1a}.active-space-bar-none .active-space-icon{color:var(--muted)}.active-space-icon{color:var(--accent);font-size:.8rem;flex-shrink:0}.active-space-select{background:transparent;border:none;color:var(--accent);font-size:.85rem;font-weight:500;cursor:pointer;padding:0;outline:none;font-family:inherit}.active-space-bar-none .active-space-select{color:var(--muted)}.active-space-select option{background:var(--surface);color:var(--text)}.nav{display:flex;align-items:center;gap:.5rem;font-size:.9rem}.nav-link{cursor:pointer;color:var(--muted)}.nav-link:hover,.nav-link.active{color:var(--accent)}.nav-sep{color:var(--muted);margin:0 .25rem}.auth{margin-left:auto}.api-base-hint{font-size:.75rem;color:var(--muted, #666);margin-left:.5rem}.btn-login,.btn-logout{padding:.4rem .75rem;font-size:.9rem;border:1px solid var(--surface);border-radius:6px;background:var(--surface);color:var(--text);cursor:pointer}.btn-login:hover,.btn-logout:hover{border-color:var(--accent)}.subtitle{margin:.25rem 0 0;color:var(--muted);font-size:.9rem}.search-bar{display:flex;gap:.5rem;margin-bottom:1.5rem;flex-wrap:wrap}.search-bar input{flex:1;min-width:140px;padding:.6rem .75rem;font-size:1rem;border:1px solid var(--surface);border-radius:8px;background:var(--surface);color:var(--text)}.search-bar input::placeholder{color:var(--muted)}.search-bar input:focus{outline:none;border-color:var(--accent)}.search-bar select{padding:.6rem .75rem;font-size:.95rem;border:1px solid var(--surface);border-radius:8px;background:var(--surface);color:var(--text);cursor:pointer}.search-bar button{padding:.6rem 1.25rem;font-size:1rem;font-weight:500;border:none;border-radius:8px;background:var(--accent);color:#fff;cursor:pointer}.search-bar button:hover{background:var(--accent-hover)}.search-in-library{display:inline-flex;align-items:center;gap:.4rem;font-size:.95rem;color:var(--text);cursor:pointer}.search-in-library input[type=checkbox]{width:1rem;height:1rem;accent-color:var(--accent);cursor:pointer}.search-options-row{display:flex;align-items:center;gap:1.25rem;margin-bottom:1rem;flex-wrap:wrap}.search-options-checkbox{display:inline-flex;align-items:center;gap:.4rem;font-size:.95rem;color:var(--text);cursor:pointer}.search-options-checkbox input[type=checkbox]{width:1rem;height:1rem;accent-color:var(--accent);cursor:pointer}.page-heading{margin:0 0 1rem;font-size:1.5rem;font-weight:600;color:var(--text)}.library-section{margin-bottom:2rem}.library-section-heading{margin:0 0 .75rem;font-size:1.1rem;font-weight:600;color:var(--muted)}.login-prompt-btn{padding:.6rem 1.25rem;font-size:1rem;font-weight:500;border:none;border-radius:8px;background:var(--accent);color:#fff;cursor:pointer;margin-top:.5rem}.login-prompt-btn:hover{background:var(--accent-hover)}.discover-bar{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.discover-row{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}.discover-row-actions{margin-top:.25rem}.discover-select{padding:.6rem .75rem;font-size:.95rem;border:1px solid var(--surface);border-radius:8px;background:var(--surface);color:var(--text);cursor:pointer;min-width:8rem}.discover-input{flex:1;min-width:140px;padding:.6rem .75rem;font-size:1rem;border:1px solid var(--surface);border-radius:8px;background:var(--surface);color:var(--text)}.discover-input::placeholder{color:var(--muted)}.discover-input:focus,.discover-select:focus{outline:none;border-color:var(--accent)}.discover-shuffle{display:inline-flex;align-items:center;gap:.4rem;font-size:.95rem;color:var(--text);cursor:pointer;padding:.5rem 0}.discover-shuffle input[type=checkbox]{width:1rem;height:1rem;accent-color:var(--accent);cursor:pointer}.discover-btn{padding:.6rem 1.25rem;font-size:1rem;font-weight:500;border:none;border-radius:8px;background:var(--accent);color:#fff;cursor:pointer}.discover-btn:hover{background:var(--accent-hover)}.results{min-height:120px}.hint,.loading,.error{color:var(--muted);margin:0}.error{color:#e07070}.error-details{margin-top:.75rem;font-size:.85rem}.error-details summary{cursor:pointer;color:var(--muted)}.error-detail-text{margin:.5rem 0 0;padding:.75rem;background:var(--surface);border-radius:6px;overflow:auto;max-height:12rem;font-size:.8rem;white-space:pre-wrap;word-break:break-all}.retry-btn{margin-top:.75rem;padding:.5rem 1rem;font-size:.95rem;border:1px solid var(--accent);border-radius:8px;background:var(--surface);color:var(--accent);cursor:pointer}.retry-btn:hover{background:var(--accent);color:#fff}.result-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .25rem;border-bottom:1px solid var(--surface)}.result-actions{display:flex;align-items:center;margin-left:auto;flex-shrink:0;opacity:0;transition:opacity .12s}.result-item:hover .result-actions,.result-item:focus-within .result-actions{opacity:1}.result-item .kind{font-size:.75rem;text-transform:uppercase;color:var(--accent);min-width:4rem}.result-item .name{font-weight:500}.result-item .subtitle{font-size:.9rem;color:var(--muted)}.result-item-song,.result-item-album,.result-item-playlist,.result-item-artist{cursor:pointer}.result-item-song:hover,.result-item-album:hover,.result-item-playlist:hover,.result-item-artist:hover{background:var(--surface)}.player-panel{width:auto;min-width:auto;background:var(--bg-1);border-left:1px solid var(--line-soft);display:flex;flex-direction:column;height:100vh;position:relative;z-index:10;overflow:hidden}.player-panel-top{flex-shrink:0;padding:1rem}.player-panel-empty{color:var(--muted);font-size:.9rem;padding:.5rem 0}.player-panel-now-playing{display:flex;flex-direction:column;gap:14px;margin-bottom:14px}.np-art{width:100%;aspect-ratio:1 / 1;border-radius:12px;overflow:hidden;box-shadow:0 16px 48px -16px #000000b3;flex-shrink:0}.np-art-img{width:100%;height:100%;object-fit:cover;display:block}.player-panel-artwork{width:64px;height:64px;border-radius:8px;object-fit:cover;flex-shrink:0}.player-panel-info{display:flex;flex-direction:column;min-width:0;gap:.2rem}.player-panel-title{font-weight:500;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-panel-artist{font-size:.85rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-panel-progress{font-size:.8rem;color:var(--muted)}.player-panel-controls{display:flex;align-items:center;justify-content:center;gap:4px}.player-panel-scrub{padding:0 4px;display:flex;flex-direction:column;gap:4px}.scrub-slider{width:100%;cursor:pointer}.scrub-times{display:flex;justify-content:space-between;font-size:11px;font-family:var(--font-mono, monospace);color:var(--fg-3, var(--muted));padding:0 2px}.player-panel-volume{margin-top:8px;width:100%;display:flex;align-items:center;gap:8px}.vol-icon{display:inline-flex;align-items:center;flex-shrink:0;color:var(--fg-3, var(--muted))}.vol-slider{flex:1;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:4px;border-radius:2px;background:linear-gradient(to right,var(--acc, var(--accent)) var(--vol, 100%),oklch(1 0 0 / .15) var(--vol, 100%));outline:none;cursor:pointer}.vol-slider::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;border-radius:50%;background:#fff;box-shadow:0 1px 4px #0006;cursor:pointer;transition:transform .1s}.vol-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.vol-slider::-moz-range-thumb{width:12px;height:12px;border-radius:50%;background:#fff;border:none;box-shadow:0 1px 4px #0006;cursor:pointer}.vol-slider::-moz-range-track{height:4px;border-radius:2px;background:#ffffff26}.player-panel-btn{padding:.4rem .6rem;font-size:.85rem;border:1px solid var(--accent);border-radius:6px;background:var(--accent);color:#fff;cursor:pointer}.player-panel-btn:disabled{opacity:.5;cursor:not-allowed}.player-panel-btn:hover:not(:disabled){background:var(--accent-hover)}.player-ctl-btn{width:36px;height:36px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--fg-2, var(--muted));cursor:pointer;transition:background .12s,color .12s;flex-shrink:0}.player-ctl-btn:hover:not(:disabled){background:var(--bg-2, rgba(255,255,255,.08));color:var(--fg, #fff)}.player-ctl-btn:disabled{opacity:.35;cursor:not-allowed}.player-ctl-btn.player-ctl-btn-primary{width:44px;height:44px;background:var(--acc, var(--accent));color:var(--acc-fg, #18181b);border-radius:50%}.player-ctl-btn.player-ctl-btn-primary:hover:not(:disabled){filter:brightness(1.1)}.player-ctl-btn.active{color:var(--acc, var(--accent))}.player-panel-queue-title-link:hover{color:var(--acc, var(--accent));text-decoration:underline;cursor:pointer}.player-panel-artwork-link{cursor:pointer}.player-panel-artwork-link:hover{opacity:.85;transition:opacity .12s}.player-panel-artist-link{cursor:pointer}.player-panel-artist-link:hover{color:var(--fg, #fff);text-decoration:underline}.player-panel-queue-window{flex:1;min-height:0;display:flex;flex-direction:column;padding:.75rem 1rem 1rem;border-top:1px solid rgba(255,255,255,.06)}.player-panel-queue-heading-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.player-panel-queue-heading{margin:0;font-size:.95rem}.player-panel-queue-clear-btn{padding:.15rem .5rem;font-size:.75rem;border:1px solid rgba(255,255,255,.2);border-radius:4px;background:transparent;color:var(--muted);cursor:pointer}.player-panel-queue-clear-btn:hover{background:#ff505026;border-color:#ff505066;color:#ff6b6b}.player-panel-play-next{margin-bottom:.5rem;padding:.35rem .6rem;font-size:.85rem;border:1px solid var(--accent);border-radius:6px;background:transparent;color:var(--accent);cursor:pointer}.player-panel-play-next:hover{background:#7c6bee26}.player-panel-queue-list{list-style:none;margin:0;padding:0;overflow-y:auto;flex:1;min-height:100px}.player-panel-queue-item{display:flex;align-items:center;gap:.5rem;padding:.4rem 0;font-size:.85rem;cursor:pointer;border-radius:4px}.player-panel-queue-item:hover{background:#ffffff0d}.player-panel-queue-item.current{background:#7c6bee33;color:var(--accent)}.player-panel-queue-right{flex-shrink:0;display:flex;align-items:center;justify-content:flex-end;min-width:3.5rem}.player-panel-queue-duration{font-size:.8rem;color:var(--muted)}.player-panel-queue-item:not(.player-panel-queue-track):hover .player-panel-queue-duration{display:none}.player-panel-queue-actions{display:none;gap:.15rem;align-items:center}.player-panel-queue-item:hover .player-panel-queue-actions{display:flex}.player-panel-queue-btn{padding:.15rem .35rem;font-size:.75rem;line-height:1;border:1px solid rgba(255,255,255,.2);border-radius:4px;background:transparent;color:var(--muted);cursor:pointer}.player-panel-queue-btn-stacked{display:inline-flex;flex-direction:column;line-height:.55;padding-top:.1rem;padding-bottom:.1rem;border:none;border-radius:0;background:transparent}.player-panel-queue-btn:hover{background:#ffffff14;color:var(--accent)}.player-panel-queue-btn-remove:hover{background:#ff505026;border-color:#ff505066;color:#ff6b6b}.player-panel-btn-autoplay{font-size:1rem;opacity:.35}.player-panel-btn-autoplay.active{opacity:1;color:#fff}.player-panel-queue-autoplay-divider{display:flex;align-items:center;gap:.5rem;padding:.3rem .25rem;margin-top:.2rem;list-style:none;border-top:1px solid rgba(255,255,255,.08)}.player-panel-queue-autoplay-label{flex:1;font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);opacity:.65}.player-panel-dancers{flex-shrink:0;border-top:1px solid rgba(255,255,255,.06);background:#00000026}.player-panel-dancers-header{display:flex;align-items:center;justify-content:space-between;padding:.4rem 1rem;cursor:pointer;font-size:.9rem;color:var(--muted)}.player-panel-dancers-header:hover{color:var(--text)}.player-panel-dancers-title{font-weight:500}.player-panel-dancers-chevron{font-size:.7rem;opacity:.8}.player-panel-dancers-body{padding:.5rem 1rem;max-height:130px;display:flex;align-items:center;justify-content:center}.player-panel-dancers-body svg{max-width:100%;max-height:110px;display:block}.player-panel-dancers-controls{display:flex;flex-direction:column;gap:.5rem;padding:0 1rem .75rem}.player-panel-dancers-controls select{flex:1;background:#ffffff12;border:1px solid rgba(255,255,255,.15);border-radius:4px;color:var(--text);font-size:.78rem;padding:.25rem .4rem;cursor:pointer}.player-panel-dancers-controls button{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:4px;color:var(--text);font-size:.78rem;padding:.25rem .6rem;cursor:pointer;white-space:nowrap}.player-panel-dancers-controls button:hover{background:#ffffff2e}.player-panel-dancers-controls-row{display:flex;gap:.4rem;align-items:center}.player-panel-dancers-speed{display:flex;align-items:center;gap:.5rem;color:#ffffffb3;font-size:.75rem;white-space:nowrap;width:100%}.player-panel-dancers-speed input[type=range]{flex:1;accent-color:rgba(255,255,255,.6)}.player-panel-queue-num{flex-shrink:0;width:1.5rem;color:var(--muted)}.player-panel-queue-title{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-panel-queue-chevron{flex-shrink:0;width:1rem;font-size:.7rem;color:var(--muted)}.player-panel-queue-album-header{font-weight:500;padding-left:0;gap:.25rem}.player-panel-queue-album-header .player-panel-queue-num{width:0;min-width:0;overflow:hidden}.player-panel-queue-playlist-header{font-weight:500;padding-left:0;gap:.25rem}.player-panel-queue-playlist-header .player-panel-queue-num{width:0;min-width:0;overflow:hidden}.player-panel-queue-track{padding-left:1.75rem;font-size:.8rem}.player-panel-queue-track .player-panel-queue-num{width:0;min-width:0;overflow:hidden}.player-panel-queue-empty{color:var(--muted);font-size:.85rem;margin:.5rem 0}.back-btn,.add-to-queue-btn{margin-bottom:1rem;padding:.4rem .75rem;font-size:.9rem;border:1px solid var(--accent);border-radius:6px;cursor:pointer}.back-btn{background:transparent;color:var(--accent)}.back-btn:hover{background:#7c6bee26}.add-to-queue-btn{background:var(--accent);color:#fff}.add-to-queue-btn:hover{background:var(--accent-hover)}@media(max-width:960px){.app{grid-template-columns:200px 1fr 300px}}@media(max-width:768px){.app{grid-template-columns:1fr;grid-template-rows:auto 1fr auto}.sidebar{height:auto;border-right:none;border-bottom:1px solid var(--line-soft)}.player-panel{height:auto;max-height:50vh;border-left:none;border-top:1px solid var(--line-soft)}}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:10px;font-size:13.5px;font-weight:500;font-family:inherit;background:var(--bg-2, rgba(255,255,255,.07));color:var(--fg, #fff);border:1px solid var(--line, rgba(255,255,255,.14));cursor:pointer;transition:background .12s,transform .12s}.btn:hover{background:var(--bg-3, rgba(255,255,255,.14))}.btn:active{transform:translateY(1px)}.btn.primary{background:var(--acc, var(--accent));color:var(--acc-fg, #18181b);border-color:transparent;font-weight:600}.btn.primary:hover{filter:brightness(1.08)}.btn.ghost{background:transparent;border-color:transparent;color:var(--fg-2, var(--muted))}.btn.ghost:hover{background:var(--bg-2, rgba(255,255,255,.07));color:var(--fg, #fff)}.player-page-top{display:flex;gap:1.5rem;align-items:flex-end;margin-bottom:1.5rem;flex-wrap:wrap}.player-page-artwork{width:200px;height:200px;border-radius:12px;object-fit:cover;flex-shrink:0;box-shadow:0 20px 60px -20px #000000b3}.player-page-center{display:flex;flex-direction:column;gap:.35rem;min-width:0;flex:1}.player-page-kind{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--fg-3, var(--muted));font-weight:500}.player-page-title{font-weight:600;font-size:1.8rem;line-height:1.1;margin:2px 0}.player-page-artist{color:var(--muted);font-size:1rem}.player-page-action-row{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin-top:14px}.player-page-taste-row{display:flex;align-items:center;flex-wrap:wrap;gap:.4rem;margin-top:.4rem}.player-page-artist-header{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin-bottom:.5rem}.player-page-artist-header .player-page-heading{margin:0}.track-action-btns{display:flex;align-items:center;gap:.2rem;flex-shrink:0;min-width:5.2rem;justify-content:flex-end}.track-action-btns .taste-btn,.track-action-btns .space-picker-btn{width:1.6rem;height:1.6rem;padding:0;margin:0;display:flex;align-items:center;justify-content:center;font-size:.85rem;line-height:1}.player-page-controls{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-top:.5rem}.player-page-links{display:flex;align-items:center;flex-wrap:wrap;gap:.35rem;font-size:.9rem}.player-page-links-label{color:var(--muted)}.player-page-links-sep{color:var(--muted);margin:0 .15rem}.player-page-link{color:var(--accent);text-decoration:none}.player-page-link:hover{text-decoration:underline}.player-page-progress{font-size:.9rem;color:var(--muted);margin-top:.25rem}.player-page-album{margin-top:1rem}.player-page-album h3{margin:0 0 .5rem;font-size:1.1rem}.player-page-album-artist{color:var(--muted);font-size:.95rem;margin:0 0 .5rem}.player-page-album-artwork{width:160px;height:160px;border-radius:8px;object-fit:cover;margin-bottom:.75rem}.player-page-tracks{list-style:none;padding:0;margin:0}.player-page-track-item{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.4rem 0;border-bottom:1px solid rgba(255,255,255,.06);font-size:.95rem}.player-page-track-title{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.player-page-track-duration{flex-shrink:0;font-variant-numeric:tabular-nums;color:var(--muted);font-size:.9rem}.player-page-track-item.clickable{cursor:pointer}.player-page-track-item.clickable:hover{background:#ffffff0a}.player-page-heading{margin:0 0 1rem;font-size:1.25rem}.player-page-artist-albums{list-style:none;padding:0;margin:0}.player-page-album-row{display:flex;align-items:center;gap:1rem;padding:.75rem 0;border-bottom:1px solid rgba(255,255,255,.06);cursor:pointer}.player-page-album-row:hover{background:#ffffff0a}.player-page-album-row-artwork{width:56px;height:56px;border-radius:6px;object-fit:cover;flex-shrink:0}.player-page-album-row-info{display:flex;flex-direction:column;gap:.2rem;min-width:0}.player-page-album-row-name{font-weight:500}.player-page-album-row-subtitle{font-size:.9rem;color:var(--muted)}.now-playing-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:20;display:flex;align-items:center;justify-content:center;padding:1rem}.now-playing-panel{background:var(--surface);border-radius:12px;max-width:420px;width:100%;max-height:90vh;overflow-y:auto;padding:1.25rem;position:relative}.now-playing-close{position:absolute;top:.75rem;right:1rem;font-size:1.5rem;cursor:pointer;color:var(--muted);line-height:1}.now-playing-close:hover{color:var(--text)}.now-playing-track{display:flex;gap:1rem;margin-bottom:1.25rem}.now-playing-artwork{width:80px;height:80px;border-radius:8px;object-fit:cover}.now-playing-track-info{display:flex;flex-direction:column;gap:.25rem;min-width:0}.now-playing-title{font-weight:600;font-size:1.1rem}.now-playing-artist{color:var(--muted);font-size:.95rem}.now-playing-play{margin-top:.5rem;padding:.35rem .65rem;font-size:.85rem;border:1px solid var(--accent);border-radius:6px;background:var(--accent);color:#fff;cursor:pointer;align-self:flex-start}.now-playing-progress{font-size:.85rem;color:var(--muted);margin-top:.25rem}.now-playing-no-preview{margin:.5rem 0 0;font-size:.85rem;color:var(--muted)}.now-playing-no-preview a{color:var(--accent);text-decoration:none}.now-playing-no-preview a:hover{text-decoration:underline}.now-playing-album-loading{color:var(--muted);font-size:.9rem;margin:0 0 1rem}.now-playing-album{margin-bottom:1.25rem}.now-playing-album h3{margin:0 0 .5rem;font-size:1rem}.now-playing-album-artist{color:var(--muted);font-size:.9rem;margin:0 0 .5rem}.now-playing-album-artwork{width:120px;height:120px;border-radius:8px;object-fit:cover;margin-bottom:.75rem}.now-playing-tracks{list-style:none;padding:0;margin:0}.now-playing-track-item{padding:.35rem 0;border-bottom:1px solid rgba(255,255,255,.06);font-size:.9rem}.now-playing-track-item.clickable{cursor:pointer}.now-playing-track-item.clickable:hover{background:#ffffff0a}.now-playing-links h3{margin:0 0 .5rem;font-size:1rem}.now-playing-links-official,.now-playing-links-more{font-size:.85rem;color:var(--muted);margin:.25rem 0 0}.now-playing-links-list{list-style:none;padding:0;margin:.25rem 0 0}.now-playing-links-list a{color:var(--accent);text-decoration:none}.now-playing-links-list a:hover{text-decoration:underline}.home-section{margin-bottom:2rem}.home-section-heading{font-size:.85rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin:0 0 .75rem}.home-login-nudge{display:flex;align-items:center;gap:1rem}.quick-discover-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:8px}.quick-discover-tile{position:relative;background:var(--bg-1, var(--surface));border:1px solid var(--line-soft, rgba(255,255,255,.07));border-radius:10px;color:var(--fg, var(--text));font-size:.88rem;font-weight:500;padding:14px 10px;cursor:pointer;text-align:left;overflow:hidden;transition:background .15s,transform .12s;font-family:var(--font-display, "Instrument Serif", serif);font-size:1rem}.quick-discover-tile:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(135deg,oklch(.7 .18 var(--tile-h, 280) / .35),transparent 65%)}.quick-discover-tile:hover{background:var(--bg-2, var(--surface));transform:translateY(-1px)}.quick-discover-tile-space{border-color:var(--acc-soft, rgba(124,107,238,.35));color:var(--acc, var(--accent))}.home-space-bar{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.55rem .75rem;margin-bottom:1.25rem;background:color-mix(in srgb,var(--accent) 10%,var(--surface));border:1px solid color-mix(in srgb,var(--accent) 30%,transparent);border-radius:8px}.home-space-bar-name{font-weight:600;font-size:.9rem;color:var(--accent)}.home-space-bar-actions{display:flex;gap:.5rem}.space-btn-muted{opacity:.6;border-color:#ffffff26;color:var(--muted)}.space-btn-muted:hover{opacity:1;color:var(--text)}.home-results-divider{width:100%;display:flex;align-items:center;gap:.5rem;margin:.75rem 0 .5rem;color:var(--muted);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em}.home-results-divider:before,.home-results-divider:after{content:"";flex:1;height:1px;background:var(--border)}.recent-searches-chips{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.5rem}.recent-search-chip{display:inline-flex;align-items:center;gap:.3rem;background:var(--surface);border:1px solid rgba(255,255,255,.1);border-radius:999px;font-size:.8rem;padding:.2rem .55rem;cursor:pointer;-webkit-user-select:none;user-select:none}.recent-search-chip:hover{border-color:var(--accent)}.recent-search-chip-label:hover{color:var(--accent)}.recent-search-chip-remove{font-size:.65rem;color:var(--muted);line-height:1}.recent-search-chip-remove:hover{color:#e06060}.exclusions-banner{margin-top:.5rem;font-size:.8rem;color:var(--muted)}.exclusions-banner-link{color:var(--accent);cursor:pointer;text-decoration:underline}.spaces-panel{margin-bottom:1.5rem;border:1px solid var(--surface);border-radius:10px;overflow:hidden}.spaces-panel-header{display:flex;align-items:center;gap:.5rem;padding:.6rem 1rem;background:var(--surface);cursor:default}.spaces-panel-title{font-weight:600;font-size:.9rem;flex:1}.spaces-panel-toggle,.spaces-panel-new{background:none;border:none;color:var(--muted);cursor:pointer;font-size:.8rem;padding:.25rem .5rem;border-radius:5px}.spaces-panel-new{color:var(--accent);font-weight:600}.spaces-panel-toggle:hover,.spaces-panel-new:hover{background:#7c6bee1a}.space-card{padding:.75rem 1rem;border-bottom:1px solid rgba(255,255,255,.05);transition:background .15s}.space-card:last-child{border-bottom:none}.space-card:hover{background:#ffffff05}.space-card-active{background:#7c6bee12;border-left:3px solid var(--accent)}.space-card-suggested{background:#7c6bee0a}.space-card-top{display:flex;align-items:center;gap:.75rem}.space-card-name{font-weight:500;flex:1;font-size:.95rem}.space-suggested-icon{color:var(--accent);font-size:.85rem}.space-card-actions{display:flex;gap:.35rem;flex-wrap:wrap}.space-btn{background:#ffffff0f;border:none;border-radius:5px;color:var(--text);cursor:pointer;font-size:.78rem;padding:.25rem .55rem;transition:background .15s}.space-btn:hover{background:#ffffff1f}.space-btn-primary{background:#7c6bee33;color:var(--accent)}.space-btn-primary:hover{background:#7c6bee59}.space-btn-danger:hover{background:#e0606040;color:#e06060}.space-card-desc{margin:.25rem 0 0;font-size:.8rem;color:var(--muted)}.space-card-pills{display:flex;flex-wrap:wrap;gap:.3rem;margin-top:.4rem}.space-pill{background:#ffffff12;border-radius:4px;font-size:.72rem;padding:.15rem .45rem;color:var(--muted)}.space-pill-time{color:var(--accent);background:#7c6bee1f}.taste-btns-group{display:inline-flex;align-items:center;gap:.15rem;margin-left:.4rem}.taste-btn{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;min-width:30px;min-height:30px;background:transparent;border:none;border-radius:8px;color:var(--fg-3, var(--muted));cursor:pointer;padding:0;font-size:14px;font-weight:500;line-height:1;font-family:var(--font-ui, inherit);transition:background .12s,color .12s;flex-shrink:0;align-self:center}.taste-btn:hover{background:var(--bg-2, rgba(255,255,255,.08));color:var(--fg, var(--text))}.taste-btn-liked{color:#e07070;background:#e0707014}.taste-btn-disliked{color:#888;background:#88888814}.taste-label{font-size:.65rem;color:var(--muted);opacity:.6}.space-picker-btn{background:transparent;border:1px solid rgba(255,255,255,.1);border-radius:4px;color:var(--muted);cursor:pointer;font-size:.72rem;padding:.1rem .3rem;line-height:1;margin-left:.4rem;transition:background .12s,color .12s}.space-picker-btn:hover{background:#ffffff1a;color:var(--text)}.space-picker-btn-in-space{color:var(--accent);border-color:#7c6bee59;background:#7c6bee14}.space-picker-btn-in-space:hover{background:#7c6bee2e;color:var(--accent)}.space-picker-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:500;display:flex;align-items:center;justify-content:center}.space-picker-panel{background:var(--surface);border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:1.25rem 1.5rem;min-width:280px;max-width:420px;width:100%;box-shadow:0 8px 32px #00000080}.space-picker-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.6rem}.space-picker-title{font-weight:600;font-size:1rem}.space-picker-close{background:transparent;border:none;color:var(--muted);cursor:pointer;font-size:1.2rem;padding:0 .3rem;line-height:1}.space-picker-close:hover{color:var(--text)}.space-picker-item-name{font-size:.85rem;color:var(--muted);margin:0 0 1rem}.space-picker-kind{font-size:.75rem;text-transform:uppercase;opacity:.6;margin-right:.2rem}.space-picker-empty{font-size:.85rem;color:var(--muted);margin:.5rem 0 0}.space-picker-spaces{display:flex;flex-direction:column;gap:.4rem}.space-picker-row{display:flex;align-items:center;gap:.4rem}.space-picker-space-name{flex:1;font-size:.9rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.space-tastes-section{border-left:3px solid var(--accent);padding-left:1rem}.space-tastes-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.space-tastes-header .home-section-heading{flex:1;margin:0}.space-tastes-group{margin-top:.5rem}.space-tastes-group-label{font-size:.72rem;text-transform:uppercase;color:var(--accent);letter-spacing:.05em;margin-right:.5rem}.space-tastes-tags{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.3rem}.taste-tag{display:inline-flex;align-items:center;gap:.3rem;background:#ffffff12;border-radius:5px;padding:.2rem .5rem;font-size:.8rem}.taste-tag-remove{background:transparent;border:none;color:var(--muted);cursor:pointer;font-size:.7rem;padding:0;line-height:1}.taste-tag-remove:hover{color:#e06060}.space-form{padding:1rem;border-top:1px solid rgba(255,255,255,.07);background:#ffffff05}.space-form h4{margin:0 0 .75rem;font-size:.9rem;color:var(--muted)}.space-form-row{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.65rem}.space-form-row label{font-size:.75rem;color:var(--muted)}.space-form-row input[type=text],.space-form-row select{background:var(--surface);border:1px solid rgba(255,255,255,.1);border-radius:6px;color:var(--text);font-size:.9rem;padding:.45rem .6rem}.space-form-row-inline{flex-direction:row;flex-wrap:wrap;gap:.75rem;align-items:flex-end}.space-form-row-inline>div{display:flex;flex-direction:column;gap:.25rem;min-width:100px}.space-form-check{display:flex;align-items:center;gap:.35rem;font-size:.85rem;cursor:pointer}.space-form-buttons{display:flex;gap:.5rem;margin-top:.75rem}.spaces-page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.spaces-page-header .page-heading{margin:0}.space-list{display:flex;flex-direction:column;gap:.25rem;margin-bottom:1.5rem}.space-list-row{border:1px solid rgba(255,255,255,.08);border-radius:6px;overflow:hidden}.space-list-row-active{border-color:var(--accent)}.space-list-row-selected{border-color:#fff3}.space-list-row-top{display:flex;align-items:center;padding:.5rem .75rem;cursor:pointer;-webkit-user-select:none;user-select:none}.space-list-row-top:hover{background:var(--surface)}.space-list-row-name{flex:1;font-weight:500;font-size:.95rem}.space-list-active-badge{font-size:.65rem;text-transform:uppercase;color:var(--accent);font-weight:600;margin-left:.4rem;opacity:.85}.space-list-row-chevron{font-size:.7rem;color:var(--muted);margin-left:.5rem}.space-detail-panel{padding:.75rem 1rem 1rem;border-top:1px solid rgba(255,255,255,.08);background:#ffffff05}.space-detail-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem}.space-detail-name{font-size:1rem;font-weight:600;margin:0}.space-detail-actions{display:flex;gap:.4rem;flex-wrap:wrap}.space-detail-desc{font-size:.85rem;color:var(--muted);margin:0 0 .5rem}.space-detail-hint{margin-top:.5rem}.space-detail-tastes{display:flex;flex-direction:column;gap:1rem;margin-top:.75rem}.space-detail-taste-section{display:flex;flex-direction:column;gap:.5rem}.space-detail-taste-section-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:600}.space-detail-taste-group{display:flex;flex-direction:column;gap:.3rem}.space-detail-taste-group-label{font-size:.7rem;color:var(--muted);opacity:.7;text-transform:uppercase}.curate-header{margin-bottom:.25rem}.curate-subhead{color:var(--muted);font-size:.85rem;margin:.25rem 0 .75rem}.curate-filter{width:100%;box-sizing:border-box;padding:.5rem .75rem;border-radius:6px;border:1px solid var(--border);background:var(--input-bg, var(--surface));color:var(--text);font-size:.9rem;margin-bottom:.75rem}.curate-artist-list{display:flex;flex-direction:column;gap:0}.curate-artist-row{display:flex;align-items:center;gap:.5rem;padding:.45rem .25rem;border-bottom:1px solid var(--border)}.curate-artist-row:last-child{border-bottom:none}.curate-artist-name{flex:0 0 auto;min-width:140px;max-width:220px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.curate-badges{flex:1;display:flex;flex-wrap:wrap;gap:.35rem}.curate-space-btns{display:flex;gap:.2rem;flex-shrink:0}.curate-space-btn{background:transparent;border:1px solid rgba(255,255,255,.12);border-radius:4px;color:var(--muted);cursor:pointer;font-size:.8rem;width:1.8rem;height:1.8rem;display:flex;align-items:center;justify-content:center;padding:0;transition:background .12s,border-color .12s,color .12s}.curate-space-btn:hover{background:#ffffff14;color:var(--text)}.curate-space-btn-include{color:#6dba7e;border-color:#6dba7e66;background:#6dba7e1a}.curate-space-btn-include:hover{background:#6dba7e2e}.curate-space-btn-exclude{color:#e07070;border-color:#e0707066;background:#e070701a}.curate-space-btn-exclude:hover{background:#e070702e}.curate-status-icon{font-size:.8rem;flex-shrink:0}.curate-status-liked{color:#e07070}.curate-status-disliked{color:#888}.curate-space-badge{display:inline-flex;align-items:center;gap:.2rem;padding:.15rem .45rem;border-radius:999px;font-size:.75rem;font-weight:500;line-height:1.4}.curate-badge-liked{background:color-mix(in srgb,var(--liked, #e05c7a) 15%,transparent);border:1px solid color-mix(in srgb,var(--liked, #e05c7a) 45%,transparent);color:var(--liked, #e05c7a)}.curate-badge-disliked{background:color-mix(in srgb,var(--muted) 12%,transparent);border:1px solid var(--border);color:var(--muted)}.curate-badge-icon{font-size:.7rem}.curate-badge-remove{background:none;border:none;cursor:pointer;color:inherit;padding:0 0 0 .1rem;font-size:.8rem;line-height:1;opacity:.6}.curate-badge-remove:hover{opacity:1}.row-actions-sep{width:1px;height:16px;background:#ffffff1f;margin:0 4px;align-self:center;flex-shrink:0}.ico-btn{width:30px;height:30px;min-width:30px;min-height:30px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;color:var(--fg-3, var(--muted));background:transparent;border:none;cursor:pointer;font-size:14px;font-weight:500;line-height:1;transition:background .12s,color .12s;flex-shrink:0;align-self:center}.ico-btn:hover{background:var(--bg-2, rgba(255,255,255,.08));color:var(--fg, var(--text))}.play-now-btn{color:var(--acc, var(--accent))}.play-now-btn:hover{background:var(--acc, var(--accent));color:var(--acc-fg, #18181b)}.ico-btn.active{color:var(--acc, var(--accent));background:var(--acc-bg, rgba(124,107,238,.15))}.ico-btn.danger.active{color:#fa6863;background:#fa68631f}.section{margin-top:28px}.section-h2{font-size:22px;font-weight:400;letter-spacing:-.01em;margin:0 0 12px}.insights-section{margin-top:32px;margin-bottom:32px}.insights-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.insights-header .section-h2{margin-bottom:0}.insights-columns{display:grid;grid-template-columns:1fr 1fr;gap:24px}.insights-col{min-width:0}.insights-col-heading{font-size:11px;letter-spacing:.12em;color:var(--acc, var(--accent));padding-bottom:8px;border-bottom:1px solid var(--line-soft, rgba(255,255,255,.08));margin-bottom:8px}.insights-group{margin-bottom:16px}.insights-group-label{font-size:10.5px;letter-spacing:.1em;color:var(--fg-4, var(--muted));margin-bottom:2px}.insights-row{gap:6px}.insights-row-name{font-weight:500;flex:1;min-width:0}.insights-row-count{font-family:var(--font-mono, monospace);font-size:11px;white-space:nowrap;flex-shrink:0}
