:root{font-family:Segoe UI,system-ui,-apple-system,sans-serif;font-size:15px;line-height:1.4;color:#e8e8e8;background:#0d0d0d}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:#0d0d0d}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.shell{min-height:100vh;display:flex;flex-direction:column;max-width:1360px;margin:0 auto}.titlebar{display:flex;align-items:center;gap:18px;padding:10px 18px;border-bottom:1px solid #1f1f1f;background:#111;flex-shrink:0}.brand{display:flex;align-items:baseline;gap:6px;flex-shrink:0}.brand-name{font-weight:600;letter-spacing:-.02em}.brand-sub{font-size:12px;color:#6a6a6a;text-transform:uppercase;letter-spacing:.06em}.search-inline{flex:1;display:flex;gap:0;min-width:0;border:1px solid #2a2a2a;border-radius:6px;overflow:hidden;background:#161616}.search-input{flex:1;border:none;background:transparent;color:#eee;padding:9px 12px;font-size:15px;outline:none;min-width:0}.search-input::placeholder{color:#555}.search-submit{border:none;border-left:1px solid #2a2a2a;background:#1c1c1c;color:#ccc;padding:9px 16px;font-size:13px;cursor:pointer}.search-submit:disabled{opacity:.45;cursor:not-allowed}.search-submit:not(:disabled):hover{background:#252525;color:#fff}.pane-quiet{min-height:12px}.banner-error{margin:0 14px;padding:6px 10px;background:#2a1515;border-bottom:1px solid #442222;color:#f0b0b0;font-size:12px}.workspace{flex:1;display:grid;grid-template-columns:1fr minmax(460px,680px);gap:0;min-height:0}@media(max-width:960px){.workspace{grid-template-columns:1fr}.titlebar{flex-wrap:wrap}.brand{order:-1;width:100%}}.pane{display:flex;flex-direction:column;min-height:0;border-right:1px solid #1f1f1f;background:#0d0d0d}.pane-side{border-right:none;background:#101010;display:flex;flex-direction:column;min-height:0}.pane-head{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;border-bottom:1px solid #1f1f1f;flex-shrink:0}.pane-head-spaced{margin-top:4px}.pane-title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:#8e8e8e}.pane-hint{font-size:12px;color:#5c5c5c}.track-list{flex:1;overflow-y:auto;padding:2px 0 12px}.track-list-tight{flex:0 1 auto;max-height:480px}.taste-split{flex:1;display:flex;flex-direction:row;min-height:0;min-width:0}.taste-main-column{flex:1;min-width:0;display:flex;flex-direction:column;min-height:0}.pick-list{max-height:220px;overflow-y:auto;border-bottom:1px solid #1f1f1f;flex-shrink:0}.taste-focus-rail{width:258px;flex-shrink:0;border-left:1px solid #1f1f1f;background:#0c0c0c;padding:12px 14px 14px;overflow-y:auto;display:flex;flex-direction:column}.taste-focus-rail--empty{width:0;padding:0;margin:0;overflow:hidden;border:none}.taste-focus-meta.subtle{color:#5a5a5a}.taste-focus-dl{margin:10px 0 0;font-size:12px;color:#9a9a9a}.taste-focus-dl dt{margin:6px 0 0;font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:#5c6565}.taste-focus-dl dd{margin:2px 0 0;color:#b5b5b5;line-height:1.35}.taste-focus-tracklist-wrap{margin-top:12px}.taste-focus-tracklist-title{font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:#5c6565;margin-bottom:6px}.taste-focus-tracklist{margin:0;padding:0 0 0 1.1rem;max-height:220px;overflow-y:auto;font-size:11px;color:#a8a8a8;line-height:1.35}.taste-focus-tracklist li{display:grid;grid-template-columns:auto 1fr auto;gap:8px;padding:2px 0;border-bottom:1px solid #1a1a1a}.taste-focus-tracklist .ti-pos{color:#5a5a5a;font-variant-numeric:tabular-nums}.taste-focus-tracklist .ti-title{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.taste-focus-tracklist .ti-dur{color:#606060;font-variant-numeric:tabular-nums}.taste-focus-blurb.taste-focus-blurb--full{display:block;overflow:visible;-webkit-line-clamp:unset;-webkit-box-orient:unset}.profile-deezer-muted{color:#5c6565}.taste-focus-fade{animation:tasteFocusIn .42s ease}@keyframes tasteFocusIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.taste-focus-loading{font-size:12px;color:#666;padding:20px 4px;text-align:center}.taste-focus-cover-wrap{border-radius:6px;overflow:hidden;margin-bottom:10px;box-shadow:0 6px 20px #00000073}.taste-focus-cover{width:100%;aspect-ratio:1;object-fit:cover;display:block;background:#1a1a1a}.taste-focus-album{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#7a7a7a;line-height:1.3}.taste-focus-track{font-size:14px;font-weight:600;color:#eee;margin-top:4px;line-height:1.25}.taste-focus-artist{font-size:12px;color:#9a9a9a;margin-top:2px}.taste-focus-meta{font-size:11px;color:#6b6b6b;margin-top:4px}.taste-focus-tags{font-size:11px;color:#5c7a5c;margin-top:8px;line-height:1.35}.taste-focus-enrichment{font-size:11px;color:#7a8f9e;margin-top:8px;line-height:1.4}.taste-focus-blurb{font-size:11px;color:#777;margin:10px 0 0;line-height:1.45;display:-webkit-box;-webkit-line-clamp:5;-webkit-box-orient:vertical;overflow:hidden}.taste-focus-link{display:inline-block;margin-top:10px;font-size:11px;color:#8ab4d4;text-decoration:none}.taste-focus-link:hover{text-decoration:underline}@media(max-width:960px){.taste-split{flex-direction:column-reverse}.taste-focus-rail{width:100%;border-left:none;border-bottom:1px solid #1f1f1f;max-height:320px;flex-direction:row;flex-wrap:wrap;gap:12px}.taste-focus-rail--empty{display:none}.taste-focus-cover-wrap{width:128px;margin-bottom:0}}.track-row{display:grid;grid-template-columns:34px 48px 1fr auto;align-items:center;gap:10px;padding:6px 12px;min-height:56px;border-bottom:1px solid #181818}.track-row--rec{grid-template-columns:34px 48px 1fr}.track-row:hover{background:#141414}.track-row.is-selected{background:#151a15}.track-row.is-pick-interactive{cursor:pointer}.track-row.is-focus-target{box-shadow:inset 3px 0 #5a8a5a;background:#141c14}.row-play{width:34px;height:34px;padding:0;border:none;border-radius:5px;background:#222;color:#ddd;font-size:12px;cursor:pointer;line-height:1}.row-play:hover:not(:disabled){background:#2e2e2e;color:#fff}.row-play.is-disabled{opacity:.35;cursor:default}.row-art{width:48px;height:48px;object-fit:cover;border-radius:5px;background:#222}.row-meta{min-width:0}.row-title-line{overflow:hidden}.row-title{font-weight:500;color:#f0f0f0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.row-sub{display:flex;flex-wrap:wrap;gap:6px;align-items:baseline;margin-top:1px}.row-artist{font-size:13px;color:#9a9a9a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.row-tags{font-size:12px;color:#6b6b6b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.row-enrichment{font-size:11px;color:#7a8f9e;margin-top:4px;line-height:1.35;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.row-reasons{font-size:12px;color:#6d8a6d;margin-top:3px;line-height:1.3}.row-action{font-size:12px;padding:6px 12px;border:1px solid #333;border-radius:4px;background:#1a1a1a;color:#bbb;cursor:pointer;flex-shrink:0}.row-action:hover{border-color:#444;color:#fff}.row-action.is-on{background:#242424;border-color:#3d5c3d;color:#a8d4a8}.primary-btn{margin:12px 14px;padding:10px 14px;border:1px solid #3d5c3d;border-radius:8px;background:#1a2a1a;color:#a8d4a8;font-size:14px;font-weight:600;cursor:pointer}.primary-btn:hover:not(:disabled){background:#223822;border-color:#4a7a4a;color:#c4e8c4}.primary-btn:disabled{opacity:.4;cursor:not-allowed}.profile-block{padding:10px 14px 6px;font-size:12px;color:#888;border-bottom:1px solid #1f1f1f}.profile-loading{margin:0 0 8px;color:#666}.profile-row{margin-bottom:6px}.profile-label{display:block;color:#555;text-transform:uppercase;letter-spacing:.05em;font-size:11px;margin-bottom:2px}.profile-value{color:#a3a3a3;line-height:1.35}.empty-hint{padding:18px 14px;margin:0;color:#555;font-size:14px}.empty-hint.subtle{color:#4a4a4a}.list-skeleton .skeleton-row{grid-template-columns:34px 48px 1fr 72px}.skel-play,.skel-art,.skel-btn{background:#1e1e1e;border-radius:5px;animation:skel 1s ease-in-out infinite}.skel-play{width:34px;height:34px}.skel-art{width:48px;height:48px}.skel-meta{display:flex;flex-direction:column;gap:6px}.skel-line{height:10px;border-radius:3px;background:#1e1e1e;animation:skel 1s ease-in-out infinite}.skel-line-long{width:72%}.skel-line-short{width:40%}.skel-btn{width:58px;height:30px;justify-self:end}@keyframes skel{0%,to{opacity:.45}50%{opacity:.85}}
