@import"https://api.fontshare.com/v2/css?f[]=general-sans@400,500,600,700&display=swap";.cmp-tab{padding:1.5rem;max-width:900px;margin:0 auto}.cmp-intro{margin-bottom:1.5rem}.cmp-title{font-size:1.5rem;font-weight:600;margin:0 0 .25rem}.cmp-subtitle{font-size:.95rem;opacity:.7;margin:0}.cmp-pickers{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}.cmp-picker{display:flex;flex-direction:column;gap:.4rem}.cmp-picker-label{font-size:.85rem;font-weight:500;opacity:.8}.cmp-picker-select{padding:.6rem .75rem;border-radius:6px;border:1px solid rgba(255,255,255,.15);background:#ffffff0d;color:inherit;font-size:.95rem}.cmp-empty{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:3rem 1.5rem;text-align:center;border:1px dashed rgba(255,255,255,.15);border-radius:8px}.ti-card{border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:1.25rem;background:#ffffff05}.ti-empty{padding:2rem;text-align:center;opacity:.6;border:1px dashed rgba(255,255,255,.1);border-radius:10px}.ti-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid rgba(255,255,255,.08)}.ti-tracks{display:flex;align-items:center;gap:.75rem;flex:1;min-width:0}.ti-track{flex:1;min-width:0}.ti-track-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;opacity:.55;margin-bottom:.15rem}.ti-track-title{font-weight:600;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ti-track-artist{font-size:.8rem;opacity:.65;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ti-track-arrow{font-size:1.4rem;opacity:.4;flex-shrink:0}.ti-tier{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:80px;padding:.6rem .75rem;border-radius:8px;flex-shrink:0}.ti-tier-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;font-weight:600}.ti-tier-score{font-size:1.5rem;font-weight:700;line-height:1;margin-top:.2rem}.ti-tier-green{background:#22c55e2e;color:#4ade80}.ti-tier-yellow{background:#eab3082e;color:#facc15}.ti-tier-red{background:#ef44442e;color:#f87171}.ti-summary{font-size:.95rem;line-height:1.5;margin-bottom:1.25rem;opacity:.9}.ti-signals{display:flex;flex-direction:column;gap:1rem}.ti-signal{display:flex;flex-direction:column;gap:.4rem}.ti-signal-header{display:flex;justify-content:space-between;align-items:baseline;font-size:.85rem}.ti-signal-label{font-weight:600;text-transform:uppercase;letter-spacing:.06em;font-size:.75rem;opacity:.7}.ti-signal-flow{display:flex;align-items:center;gap:.4rem;font-variant-numeric:tabular-nums}.ti-from,.ti-to{font-weight:500}.ti-arrow{opacity:.5}.ti-signal-meter{height:6px;background:#ffffff0f;border-radius:3px;overflow:hidden}.ti-signal-bar{height:100%;background:linear-gradient(90deg,#6366f199,#a855f7cc);border-radius:3px;transition:width .25s ease}.ti-signal-desc{font-size:.85rem;opacity:.7}.ti-mixpoints{margin-top:1.25rem;padding-top:1.1rem;border-top:1px solid rgba(255,255,255,.08)}.ti-mixpoints-header{display:flex;align-items:baseline;gap:.75rem;margin-bottom:.85rem;flex-wrap:wrap}.ti-mixpoints-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;opacity:.7}.ti-mixpoints-note{font-size:.72rem;opacity:.45;font-style:italic}.ti-mixpoints-cols{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.ti-mixpoints-col{display:flex;flex-direction:column;gap:.45rem}.ti-mixpoints-col-label{font-size:.78rem;opacity:.6;margin-bottom:.1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ti-timestamp{display:inline-block;font-family:var(--font-mono, monospace);font-size:.9rem;font-weight:600;background:#6366f126;color:#a855f7e6;border:1px solid rgba(99,102,241,.25);border-radius:5px;padding:3px 8px;width:fit-content}.ti-mixpoints-none{font-size:.82rem;opacity:.45;font-style:italic}@media (max-width: 600px){.cmp-pickers{grid-template-columns:1fr}.ti-header{flex-direction:column}.ti-mixpoints-cols{grid-template-columns:1fr}}.landing{--landing-display: "General Sans", -apple-system, BlinkMacSystemFont, sans-serif;--landing-max: 1180px;--landing-gutter: 28px;--landing-section: 112px;--landing-text: #d4d4d4;--landing-soft: #8a8a8a;--landing-hair: #1d1d1d;background:var(--bg);color:var(--landing-text);font-family:var(--landing-display);font-size:16px;line-height:1.55;min-height:100vh;font-feature-settings:"ss01","ss02";letter-spacing:-.005em}.landing *{box-sizing:border-box}.landing ::selection{background:var(--accent);color:#000}.landing-nav{position:sticky;top:0;z-index:50;background:#0a0a0ab3;backdrop-filter:saturate(140%) blur(14px);-webkit-backdrop-filter:saturate(140%) blur(14px);border-bottom:1px solid transparent;transition:border-color .16s ease,background .16s ease}.landing-nav.is-scrolled{background:#0a0a0ae0;border-bottom-color:var(--landing-hair)}.landing-nav-inner{max-width:var(--landing-max);margin:0 auto;padding:18px var(--landing-gutter);display:flex;align-items:center;justify-content:space-between;gap:16px}.landing-logo{font-family:var(--serif);font-style:italic;font-size:26px;color:var(--accent);letter-spacing:-.5px;line-height:1;text-decoration:none;flex-shrink:0}.landing-nav-actions{display:flex;align-items:center;gap:18px}.landing-nav-toggle.mobile{display:none;background:none;border:none;color:var(--landing-text);cursor:pointer;padding:4px}.landing-link{background:none;border:none;color:var(--landing-text);font-family:var(--mono);font-size:13px;cursor:pointer;padding:8px 4px;transition:color .16s ease}.landing-link:hover{color:var(--accent)}.landing-btn-primary{background:var(--accent);color:#000;border:1px solid var(--accent);border-radius:6px;padding:10px 18px;font-family:var(--mono);font-size:13px;font-weight:600;letter-spacing:.2px;cursor:pointer;transition:transform .12s ease,box-shadow .16s ease,background .16s ease}.landing-btn-primary:hover{transform:translateY(-1px);box-shadow:0 8px 24px -10px #00ff888c}.landing-btn-primary.lg{padding:14px 28px;font-size:14px}.landing-btn-primary.block{width:100%}.landing-btn-secondary{background:transparent;color:var(--accent);border:1px solid var(--accent);border-radius:6px;padding:10px 18px;font-family:var(--mono);font-size:13px;font-weight:600;letter-spacing:.2px;cursor:pointer;transition:background .16s ease,color .16s ease}.landing-btn-secondary:hover{background:#00ff8814}.landing-btn-secondary.block{width:100%}.landing-mobile-panel{display:none;flex-direction:column;gap:8px;padding:12px var(--landing-gutter) 18px;border-top:1px solid var(--landing-hair);background:#0a0a0af5}.landing-mobile-panel .landing-link{text-align:left;padding:10px 4px}.landing-eyebrow,.landing-section-eyebrow{display:inline-block;font-family:var(--mono);font-size:11px;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:2px;margin-bottom:18px}.landing-microcopy{font-family:var(--mono);font-size:12px;color:var(--landing-soft);letter-spacing:.3px;margin-top:14px}.landing-hero{position:relative;padding:96px var(--landing-gutter) var(--landing-section);overflow:hidden}.landing-hero:before{content:"";position:absolute;top:-20%;left:50%;width:900px;height:900px;transform:translate(-50%);background:radial-gradient(circle at center,rgba(0,255,136,.08) 0%,transparent 60%);pointer-events:none;z-index:0}.landing-hero-grid{position:relative;z-index:1;max-width:var(--landing-max);margin:0 auto;display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:56px;align-items:center}.landing-hero-copy{max-width:560px}.landing-headline{font-family:var(--landing-display);font-weight:600;font-size:clamp(36px,5vw,60px);line-height:1.04;letter-spacing:-.025em;color:#f5f5f5;margin-bottom:22px}.landing-subhead{font-size:18px;line-height:1.55;color:var(--landing-text);margin-bottom:32px}.landing-cta-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap}.landing-hero-visual{position:relative;aspect-ratio:5 / 4;border:1px solid var(--border);border-radius:12px;background:linear-gradient(180deg,var(--surface) 0%,var(--surface2) 100%);overflow:hidden}.landing-hero-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:2px;color:var(--muted)}.landing-hero-placeholder:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);background-size:32px 32px;background-position:-1px -1px}.landing-wedge{padding:var(--landing-section) var(--landing-gutter);border-top:1px solid var(--landing-hair);background:linear-gradient(180deg,transparent 0%,rgba(255,255,255,.01) 100%)}.landing-wedge-inner{max-width:880px;margin:0 auto;text-align:center}.landing-wedge-headline{font-family:var(--landing-display);font-weight:500;font-size:clamp(28px,3.6vw,44px);line-height:1.15;letter-spacing:-.02em;color:#f5f5f5;margin-bottom:36px}.landing-wedge-headline em{font-family:var(--serif);font-style:italic;color:var(--accent);font-weight:400}.landing-wedge-body{display:flex;flex-direction:column;gap:18px;font-size:17px;line-height:1.65;color:var(--landing-text);text-align:left;max-width:640px;margin:0 auto}.landing-features{padding:var(--landing-section) var(--landing-gutter);border-top:1px solid var(--landing-hair)}.landing-features-inner{max-width:var(--landing-max);margin:0 auto}.landing-feature-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px;margin-top:8px}.landing-feature-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:32px 28px;transition:border-color .2s ease,transform .2s ease}.landing-feature-card:hover{border-color:#00ff8859;transform:translateY(-2px)}.landing-feature-icon{color:var(--accent);margin-bottom:20px}.landing-feature-card h3{font-family:var(--landing-display);font-weight:600;font-size:20px;line-height:1.25;letter-spacing:-.01em;color:#f5f5f5;margin-bottom:12px}.landing-feature-card p{font-size:15px;line-height:1.6;color:var(--landing-text)}.landing-feature-card strong{color:#f5f5f5;font-weight:600}.landing-who{padding:var(--landing-section) var(--landing-gutter);border-top:1px solid var(--landing-hair)}.landing-who-inner{max-width:720px;margin:0 auto;text-align:center}.landing-who-headline{font-family:var(--landing-display);font-weight:500;font-size:clamp(26px,3.2vw,38px);line-height:1.2;letter-spacing:-.02em;color:#f5f5f5;margin-bottom:24px}.landing-who-body{font-size:17px;line-height:1.65;color:var(--landing-text);text-align:left}.landing-pricing{padding:var(--landing-section) var(--landing-gutter);border-top:1px solid var(--landing-hair)}.landing-pricing-inner{max-width:var(--landing-max);margin:0 auto;text-align:center}.landing-pricing-headline{font-family:var(--landing-display);font-weight:500;font-size:clamp(28px,3.6vw,40px);line-height:1.15;letter-spacing:-.02em;color:#f5f5f5;margin-bottom:48px}.landing-price-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:24px;max-width:840px;margin:0 auto;text-align:left}.landing-price-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:36px 32px;display:flex;flex-direction:column}.landing-price-card.pro{border-color:#00ff8859;background:linear-gradient(180deg,rgba(0,255,136,.04) 0%,transparent 60%),var(--surface);position:relative}.landing-price-head{margin-bottom:24px}.landing-price-title-row{display:flex;align-items:center;gap:10px;margin-bottom:8px}.landing-price-card h3{font-family:var(--landing-display);font-weight:600;font-size:20px;color:#f5f5f5;letter-spacing:-.01em}.landing-price-tag{font-family:var(--mono);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;color:var(--accent);border:1px solid var(--accent);border-radius:3px;padding:3px 7px}.landing-price-amount{display:flex;align-items:baseline;gap:10px;margin-top:4px}.landing-price-num{font-family:var(--landing-display);font-weight:600;font-size:48px;line-height:1;letter-spacing:-.03em;color:#f5f5f5}.landing-price-unit{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:1.5px;color:var(--landing-soft)}.landing-price-banner{display:inline-block;margin-top:14px;padding:6px 10px;background:#00ff881a;border:1px solid rgba(0,255,136,.4);border-radius:4px;font-family:var(--mono);font-size:11px;font-weight:600;letter-spacing:1.5px;color:var(--accent)}.landing-price-list{list-style:none;padding:0;margin:0 0 28px;display:flex;flex-direction:column;gap:10px;font-size:14px;color:var(--landing-text)}.landing-price-list li{padding-left:18px;position:relative}.landing-price-list li:before{content:"→";position:absolute;left:0;color:var(--accent);font-family:var(--mono)}.landing-price-footnote{margin-top:12px;font-family:var(--mono);font-size:11px;color:var(--landing-soft);letter-spacing:.3px}.landing-final{padding:var(--landing-section) var(--landing-gutter);border-top:1px solid var(--landing-hair);text-align:center}.landing-final-inner{max-width:640px;margin:0 auto}.landing-final-headline{font-family:var(--landing-display);font-weight:500;font-size:clamp(28px,3.6vw,44px);line-height:1.15;letter-spacing:-.02em;color:#f5f5f5;margin-bottom:28px}.landing-footer{border-top:1px solid var(--landing-hair);padding:32px var(--landing-gutter)}.landing-footer-inner{max-width:var(--landing-max);margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.landing-footer-mark{font-family:var(--serif);font-style:italic;font-size:18px;color:var(--accent)}.landing-footer-line{font-family:var(--mono);font-size:11px;color:var(--landing-soft);letter-spacing:.3px}@media (max-width: 900px){.landing{--landing-section: 80px}.landing-hero{padding-top:64px}.landing-hero-grid{grid-template-columns:minmax(0,1fr);gap:40px}.landing-hero-visual{max-width:520px}.landing-feature-grid,.landing-price-grid{grid-template-columns:1fr}}@media (max-width: 640px){.landing{font-size:15px}.landing-nav-actions.desktop{display:none}.landing-nav-toggle.mobile{display:inline-flex}.landing-mobile-panel{display:flex}.landing-nav-inner{padding:14px var(--landing-gutter)}.landing-logo{font-size:22px}.landing-hero{padding-top:48px}.landing-headline{font-size:clamp(32px,8vw,42px)}.landing-subhead,.landing-wedge-body,.landing-who-body{font-size:16px}.landing-feature-card,.landing-price-card{padding:28px 24px}.landing-price-num{font-size:40px}.landing-footer-inner{flex-direction:column;align-items:flex-start}}@media (max-width: 380px){.landing{--landing-gutter: 20px}.landing-btn-primary.lg{width:100%}}@media (prefers-reduced-motion: reduce){.landing-nav,.landing-btn-primary,.landing-btn-secondary,.landing-feature-card,.landing-link{transition:none}.landing-btn-primary:hover,.landing-feature-card:hover{transform:none}}:root{--bg: #0a0a0a;--surface: #141414;--surface2: #1e1e1e;--accent: #00ff88;--accent-dim: #003322;--text: #e0e0e0;--muted: #505050;--border: #242424;--mono: "SF Mono", "Fira Code", "Consolas", monospace;--serif: Georgia, "Times New Roman", serif;--spotify: #1DB954;--soundcloud: #FF5500;--youtube: #FF0000;--local: #FFB800}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:var(--mono);font-size:14px;min-height:100vh;-webkit-font-smoothing:antialiased}.app{max-width:1440px;margin:0 auto;padding:28px 32px}header{display:flex;align-items:baseline;gap:16px;margin-bottom:28px;padding-bottom:16px;border-bottom:1px solid var(--border)}.logo{font-family:var(--serif);font-style:italic;font-weight:400;font-size:38px;color:var(--accent);letter-spacing:-1px;line-height:1}.tagline{font-size:12px;color:var(--muted);letter-spacing:.5px}.url-input-section{margin-bottom:28px}.url-form{display:flex;gap:8px;margin-bottom:10px}.url-input{flex:1;background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:10px 14px;color:var(--text);font-family:var(--mono);font-size:13px;outline:none;transition:border-color .15s}.url-input:focus{border-color:var(--accent)}.url-input::placeholder{color:var(--muted)}.url-input:disabled{opacity:.5}.btn-add{display:flex;align-items:center;gap:6px;background:var(--accent);color:#000;border:none;border-radius:6px;padding:10px 18px;font-family:var(--mono);font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;transition:opacity .15s}.btn-add:hover:not(:disabled){opacity:.82}.btn-add:disabled{opacity:.45;cursor:not-allowed}.file-drop-zone{display:flex;align-items:center;justify-content:center;border:1px dashed var(--border);border-radius:6px;padding:13px;color:var(--muted);font-size:12px;cursor:pointer;transition:border-color .15s,background .15s;-webkit-user-select:none;user-select:none}.file-drop-zone:hover,.file-drop-zone.drag-over{border-color:var(--accent);background:#00ff8808;color:var(--accent)}.file-drop-zone input{display:none}.error-msg{margin-top:8px;font-size:12px;color:#f55}.main-grid{display:grid;grid-template-columns:1fr 380px;gap:24px;align-items:start}.track-list{background:var(--surface);border:1px solid var(--border);border-radius:8px;overflow:hidden}.tier-badge{display:inline-flex;align-items:center;font-family:var(--mono);font-size:11px;color:var(--muted);border:1px solid var(--border);border-radius:4px;padding:3px 8px;margin-right:4px}.tier-badge.pro{color:var(--accent);border-color:var(--accent)}.app-loading{padding:80px 24px;text-align:center;color:var(--muted);font-size:13px}.track-list-search{display:flex;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid var(--border)}.track-list-search-icon{color:var(--muted);flex-shrink:0}.track-list-search-input{flex:1;background:transparent;border:none;outline:none;color:inherit;font-family:inherit;font-size:12px;padding:2px 0}.track-list-search-input::placeholder{color:var(--muted)}.track-list-search-clear{background:none;border:none;color:var(--muted);cursor:pointer;padding:2px;display:flex;align-items:center;border-radius:3px;transition:color .12s}.track-list-search-clear:hover{color:#f55}.track-list-header{display:flex;align-items:center;justify-content:space-between;padding:11px 16px;border-bottom:1px solid var(--border)}.track-list-header h2{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:1.5px}.track-list-header-right{display:flex;align-items:center;gap:12px}.track-count{font-size:11px;color:var(--muted)}.btn-clear{display:flex;align-items:center;gap:5px;background:none;border:1px solid var(--border);border-radius:4px;color:var(--muted);font-family:var(--mono);font-size:11px;padding:3px 8px;cursor:pointer;transition:border-color .15s,color .15s}.btn-clear:hover{border-color:#f55;color:#f55}.btn-save-playlist{display:flex;align-items:center;gap:5px;background:none;border:1px solid var(--border);border-radius:4px;color:var(--muted);font-family:var(--mono);font-size:11px;padding:3px 8px;cursor:pointer;transition:border-color .15s,color .15s}.btn-save-playlist:hover{border-color:var(--accent);color:var(--accent)}.empty-crate{padding:52px 24px;text-align:center;color:var(--muted);font-size:13px}.track-item{display:grid;grid-template-columns:8px 1fr 42px 72px 80px 28px 28px;gap:12px;align-items:center;padding:11px 16px;border-bottom:1px solid var(--border);cursor:pointer;position:relative;transition:background .12s}.track-item:last-child{border-bottom:none}.track-item:hover{background:var(--surface2)}.track-item.selected{background:#00ff880a;border-left:2px solid var(--accent);padding-left:14px}.track-item.compatible{background:#00ff8806}.track-item.compatible:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border:1px solid rgba(0,255,136,.18);pointer-events:none;border-radius:0}.source-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.source-dot.spotify{background:var(--spotify)}.source-dot.soundcloud{background:var(--soundcloud)}.source-dot.youtube{background:var(--youtube)}.source-dot.local{background:var(--local)}.track-info{min-width:0}.track-title{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-artist{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.track-key{font-family:var(--serif);font-style:italic;font-size:16px;font-weight:700;color:var(--accent);text-align:center}.track-item.compatible .track-key{color:var(--accent)}.track-bpm{font-size:11px;color:var(--muted);text-align:right}.energy-bar{display:flex;gap:2px;align-items:center}.energy-pip{width:4px;height:13px;border-radius:2px;background:var(--border);transition:background .15s}.energy-pip.active{background:var(--accent)}.btn-remove{background:none;border:none;color:var(--muted);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;opacity:0;transition:opacity .12s,color .12s}.track-item:hover .btn-remove{opacity:1}.btn-remove:hover{color:#f55}.btn-reanalyze{background:none;border:none;color:var(--muted);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;opacity:0;transition:opacity .12s,color .12s}.track-item:hover .btn-reanalyze{opacity:1}.btn-reanalyze:hover{color:var(--accent)}.btn-reanalyze:disabled{cursor:not-allowed;opacity:.5}.btn-reanalyze .spinning{animation:spin .8s linear infinite}.camelot-wheel-container{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:20px 20px 16px;display:flex;flex-direction:column;align-items:center}.camelot-wheel-container h3{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:12px;align-self:flex-start;font-weight:600}.camelot-legend{display:flex;gap:20px;margin-top:14px;font-size:11px;color:var(--muted)}.legend-item{display:flex;align-items:center;gap:6px}.legend-dot{width:10px;height:10px;border-radius:2px;flex-shrink:0}.crate-controls{background:var(--surface);border:1px solid var(--border);border-radius:8px;margin-bottom:16px;overflow:visible}.controls-row{display:flex;align-items:center;gap:12px;padding:10px 14px;flex-wrap:wrap}.controls-top{border-bottom:1px solid var(--border);justify-content:space-between}.controls-filters{gap:16px;align-items:flex-start}.view-toggle{display:flex;gap:2px}.view-btn{display:flex;align-items:center;gap:5px;background:none;border:1px solid transparent;border-radius:5px;color:var(--muted);font-family:var(--mono);font-size:12px;padding:5px 10px;cursor:pointer;transition:color .12s,border-color .12s,background .12s}.view-btn:hover{color:var(--text);border-color:var(--border)}.view-btn.active{background:#00ff8814;border-color:var(--accent);color:var(--accent)}.controls-right{display:flex;align-items:center;gap:10px}.sort-select{background:var(--surface2);border:1px solid var(--border);border-radius:5px;color:var(--text);font-family:var(--mono);font-size:12px;padding:5px 8px;cursor:pointer;outline:none}.sort-select:focus{border-color:var(--accent)}.energy-preset-select{background:var(--surface2);border:1px solid var(--border);border-radius:5px;color:var(--text-muted);font-family:var(--mono);font-size:12px;padding:5px 8px;cursor:pointer;outline:none}.energy-preset-select:focus{border-color:var(--accent)}.energy-preset-select.has-value{color:var(--accent);border-color:var(--accent)}.filter-badge{font-size:11px;color:var(--accent);background:#00ff881a;border:1px solid rgba(0,255,136,.25);border-radius:10px;padding:2px 8px}.filter-group{position:relative}.key-filter-btn{display:flex;align-items:center;gap:5px;background:var(--surface2);border:1px solid var(--border);border-radius:5px;color:var(--muted);font-family:var(--mono);font-size:12px;padding:5px 10px;cursor:pointer;white-space:nowrap;transition:border-color .12s,color .12s}.key-filter-btn:hover,.key-filter-btn.open{border-color:var(--accent);color:var(--text)}.key-filter-btn.has-value{color:var(--accent);border-color:var(--accent)}.key-dropdown{position:absolute;top:calc(100% + 6px);left:0;z-index:100;background:var(--surface2);border:1px solid var(--border);border-radius:7px;padding:10px;box-shadow:0 8px 32px #00000080}.key-grid{display:grid;grid-template-columns:repeat(6,auto);gap:4px;margin-bottom:8px}.key-pair{display:contents}.key-chip{background:var(--surface);border:1px solid var(--border);border-radius:4px;color:var(--muted);font-family:Georgia,serif;font-style:italic;font-size:12px;padding:4px 7px;cursor:pointer;transition:background .1s,border-color .1s,color .1s;white-space:nowrap}.key-chip:hover{border-color:var(--accent);color:var(--text)}.key-chip.selected{background:#00ff881f;border-color:var(--accent);color:var(--accent)}.key-clear-all{display:block;width:100%;background:none;border:1px solid var(--border);border-radius:4px;color:var(--muted);font-family:var(--mono);font-size:11px;padding:4px;cursor:pointer;text-align:center;transition:color .12s,border-color .12s}.key-clear-all:hover{border-color:#f55;color:#f55}.sources-group{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.source-checkbox{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--muted);cursor:pointer;padding:4px 8px;border:1px solid var(--border);border-radius:5px;-webkit-user-select:none;user-select:none;transition:color .12s,border-color .12s}.source-checkbox:hover{border-color:var(--text);color:var(--text)}.source-checkbox.checked{color:var(--text);border-color:var(--surface2)}.source-checkbox input{display:none}.source-dot-sm{width:7px;height:7px;border-radius:50%;flex-shrink:0}.btn-reset-filters{display:flex;align-items:center;gap:4px;background:none;border:1px solid var(--border);border-radius:5px;color:var(--muted);font-family:var(--mono);font-size:11px;padding:5px 10px;cursor:pointer;white-space:nowrap;align-self:center;transition:color .12s,border-color .12s}.btn-reset-filters:hover{color:#f55;border-color:#f55}.dual-range{display:flex;flex-direction:column;gap:2px;min-width:130px}.dual-range-header{display:flex;justify-content:space-between;gap:8px;font-size:11px}.dr-label{color:var(--muted)}.dr-value{color:var(--text);font-size:11px}.dual-range-track{position:relative;height:4px;border-radius:2px;margin-top:10px;margin-bottom:6px}.dr-input{position:absolute;width:100%;top:50%;transform:translateY(-50%);height:4px;-moz-appearance:none;appearance:none;-webkit-appearance:none;background:transparent;pointer-events:none;margin:0}.dr-input::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent);border:2px solid var(--bg);cursor:pointer;pointer-events:auto}.dr-input::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--accent);border:2px solid var(--bg);cursor:pointer;pointer-events:auto}.wheel-view-wrap{background:var(--surface);border:1px solid var(--border);border-radius:8px;overflow:hidden}.wheel-view-header{display:flex;align-items:center;gap:10px;padding:10px 16px;border-bottom:1px solid var(--border);flex-wrap:wrap}.wheel-view-hint{font-size:11px;color:var(--muted)}.wheel-filter-tags{display:flex;gap:6px;flex-wrap:wrap}.wheel-filter-tag{background:#00ff881a;border:1px solid rgba(0,255,136,.3);border-radius:4px;color:var(--accent);font-family:Georgia,serif;font-style:italic;font-size:12px;padding:2px 7px;cursor:pointer;transition:background .1s}.wheel-filter-tag:hover{background:#0f83}.wheel-view-svg-wrap{display:flex;justify-content:center;padding:20px 16px 8px}.wheel-view-tracks{border-top:1px solid var(--border)}.wheel-tracks-header{padding:8px 16px;font-size:11px;color:var(--muted);border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:1px}.energy-ladder{background:var(--surface);border:1px solid var(--border);border-radius:8px;overflow:hidden}.ladder-group{border-bottom:1px solid var(--border)}.ladder-group:last-child{border-bottom:none}.ladder-group-header{display:flex;align-items:center;gap:12px;padding:8px 16px;background:#ffffff04;border-bottom:1px solid var(--border)}.ladder-level-bar{height:3px;border-radius:2px;background:var(--accent);flex-shrink:0;max-width:80px;transition:width .3s}.ladder-level-label{font-size:11px;color:var(--muted);white-space:nowrap}.ladder-group .track-item{grid-template-columns:8px 1fr 72px 42px 28px}.btn-stack{background:none;border:none;color:var(--muted);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;opacity:0;transition:opacity .12s,color .12s}.track-item:hover .btn-stack{opacity:1}.btn-stack:hover{color:var(--accent)}.btn-stack.in-stack{color:var(--accent);opacity:.4;cursor:default}.input-row{display:flex;gap:10px;align-items:flex-start;margin-bottom:16px}.input-row-main{flex:1;min-width:0}.input-row-main .url-input-section{margin-bottom:0}.btn-import-toggle{display:flex;align-items:center;gap:6px;background:var(--surface);border:1px solid var(--border);border-radius:6px;color:var(--muted);font-family:var(--mono);font-size:13px;padding:10px 14px;cursor:pointer;white-space:nowrap;align-self:flex-start;transition:border-color .15s,color .15s}.btn-import-toggle:hover,.btn-import-toggle.active{border-color:var(--accent);color:var(--accent)}.import-panel{background:var(--surface);border:1px solid var(--border);border-radius:8px;margin-bottom:16px;overflow:hidden}.import-tabs{display:flex;border-bottom:1px solid var(--border)}.import-tab{background:none;border:none;border-bottom:2px solid transparent;color:var(--muted);font-family:var(--mono);font-size:12px;padding:9px 16px;cursor:pointer;transition:color .12s,border-color .12s}.import-tab:hover{color:var(--text)}.import-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.import-section{padding:14px 16px}.import-hint{font-size:11px;color:var(--muted);margin-bottom:10px;line-height:1.5}.import-hint code{background:var(--surface2);border-radius:3px;padding:1px 5px;font-size:11px;color:var(--text)}.import-textarea{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:5px;color:var(--text);font-family:var(--mono);font-size:12px;padding:10px 12px;resize:vertical;outline:none;transition:border-color .15s}.import-textarea:focus{border-color:var(--accent)}.import-drop{margin-top:0}.btn-parse{margin-top:10px;background:none;border:1px solid var(--border);border-radius:5px;color:var(--text);font-family:var(--mono);font-size:12px;padding:6px 14px;cursor:pointer;transition:border-color .15s,color .15s}.btn-parse:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.btn-parse:disabled{opacity:.4;cursor:not-allowed}.import-preview{border-top:1px solid var(--border);padding:12px 16px}.import-preview-header{font-size:11px;color:var(--muted);margin-bottom:8px}.import-preview-list{margin-bottom:10px}.import-preview-row{display:grid;grid-template-columns:36px 1fr auto auto auto;gap:8px;align-items:center;padding:4px 0;border-bottom:1px solid var(--border);font-size:12px}.import-preview-row:last-child{border-bottom:none}.import-preview-key{font-family:var(--serif);font-style:italic;font-size:13px;color:var(--accent)}.import-preview-title{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.import-preview-artist{color:var(--muted);font-size:11px}.import-preview-bpm,.import-preview-energy{color:var(--muted);font-size:11px;white-space:nowrap}.import-preview-more{font-size:11px;color:var(--muted);padding:4px 0;text-align:center}.import-no-tracks{font-size:12px;color:var(--muted);text-align:center;padding:12px 0}.btn-import-confirm{background:var(--accent);border:none;border-radius:5px;color:#000;font-family:var(--mono);font-size:12px;font-weight:600;padding:7px 16px;cursor:pointer;transition:opacity .15s}.btn-import-confirm:hover:not(:disabled){opacity:.82}.btn-import-confirm:disabled{opacity:.45;cursor:not-allowed}.import-status{padding:8px 16px;font-size:12px;border-top:1px solid var(--border)}.import-status.ok{color:var(--accent)}.import-status.error{color:#f55}.queue-list{margin-top:12px;border:1px solid var(--border);border-radius:6px;overflow:hidden}.queue-summary{display:flex;align-items:center;padding:6px 10px;font-size:11px;color:var(--text-muted);background:var(--surface2);border-bottom:1px solid var(--border)}.queue-item{display:flex;align-items:flex-start;gap:8px;padding:6px 10px;font-size:12px;border-bottom:1px solid var(--border)}.queue-item:last-child{border-bottom:none}.queue-icon{flex-shrink:0;margin-top:1px}.queue-label{flex:1;color:var(--text-muted);word-break:break-all;font-family:var(--mono);font-size:11px}.queue-error{font-size:11px;color:#f55;margin-top:2px}.queue-item-done .queue-label{color:var(--text)}.queue-item-failed .queue-label{color:#f55;opacity:.7}.q-done{color:var(--accent)}.q-failed{color:#f55}.q-pending{color:var(--text-muted)}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:spin 1s linear infinite;display:inline-block}.tab-bar{display:flex;gap:2px;margin-bottom:16px;border-bottom:1px solid var(--border);padding-bottom:0}.tab-btn{display:flex;align-items:center;gap:7px;background:none;border:none;border-bottom:2px solid transparent;color:var(--muted);font-family:var(--mono);font-size:13px;padding:10px 16px;cursor:pointer;margin-bottom:-1px;transition:color .12s,border-color .12s}.tab-btn:hover{color:var(--text)}.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}.tab-badge{background:#00ff881f;border:1px solid rgba(0,255,136,.25);border-radius:10px;color:var(--accent);font-size:10px;padding:1px 7px}.stack-tab{display:flex;flex-direction:column;gap:16px}.stack-builder{background:var(--surface);border:1px solid var(--border);border-radius:8px;overflow:hidden}.stack-header{display:flex;align-items:center;justify-content:space-between;padding:11px 16px;border-bottom:1px solid var(--border)}.stack-title{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:1.5px}.stack-header-right{display:flex;align-items:center;gap:10px}.stack-count{font-size:11px;color:var(--muted)}.stack-hint{font-size:11px;color:var(--muted);font-style:italic}.btn-auto-build{display:flex;align-items:center;gap:5px;background:#00ff8814;border:1px solid rgba(0,255,136,.3);border-radius:5px;color:var(--accent);font-family:var(--mono);font-size:11px;padding:4px 10px;cursor:pointer;transition:background .15s,border-color .15s}.btn-auto-build:hover{background:#00ff8829;border-color:var(--accent)}.stack-empty{padding:52px 24px;text-align:center;color:var(--muted);font-size:13px;border:2px dashed transparent;transition:border-color .15s,background .15s}.stack-empty.drag-over{border-color:var(--accent);background:#00ff8808;color:var(--accent)}.stack-empty-text strong{color:var(--text)}.stack-slots{padding:4px 0}.stack-slot{border:2px solid transparent;border-radius:4px;margin:0 8px;transition:border-color .15s}.stack-slot.drag-over{border-color:var(--accent);background:#00ff8808}.stack-track-card{display:grid;grid-template-columns:16px 8px 1fr auto 28px;gap:10px;align-items:center;padding:10px 12px;cursor:grab;-webkit-user-select:none;user-select:none;transition:background .12s;border-radius:4px}.stack-track-card:hover{background:var(--surface2)}.stack-track-card:active{cursor:grabbing}.stack-grip{color:var(--muted);opacity:.4;flex-shrink:0}.stack-track-info{min-width:0}.stack-track-title{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stack-track-artist{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.stack-track-meta{display:flex;align-items:center;gap:8px;flex-shrink:0}.stack-track-key{font-family:var(--serif);font-style:italic;font-size:15px;font-weight:700;color:var(--accent)}.stack-track-bpm,.stack-track-energy{font-size:11px;color:var(--muted)}.stack-drop-end{margin:4px 8px 8px;padding:10px;text-align:center;font-size:11px;color:var(--muted);border:1px dashed var(--border);border-radius:4px;transition:border-color .15s,color .15s,background .15s}.stack-drop-end.drag-over{border-color:var(--accent);color:var(--accent);background:#00ff8808}.transition-card{display:flex;align-items:center;gap:10px;padding:6px 24px;background:var(--bg);position:relative}.transition-card.risky{border-left:2px solid #ffaa00}.tc-arrow{font-size:16px;color:var(--muted);flex-shrink:0}.tc-body{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.tc-score{font-size:20px;font-weight:700;font-family:var(--serif);font-style:italic;min-width:32px;text-align:center}.tc-score--green{color:var(--accent)}.tc-score--yellow{color:#fc0}.tc-score--red{color:#f55}.tc-breakdown{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--muted)}.tc-sep{color:var(--border)}.tc-deltas{display:flex;gap:8px;font-size:11px;color:var(--muted)}.tc-risky-badge{color:#fa0;font-size:11px}.intent-panel{border-top:1px solid var(--border);padding:14px 16px}.intent-header{display:flex;align-items:baseline;gap:10px;margin-bottom:12px}.intent-title{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:1.5px}.intent-ref{font-size:11px;color:var(--muted)}.intent-ref-key{font-family:var(--serif);font-style:italic;color:var(--accent)}.intent-axes{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}.intent-axis{display:flex;align-items:center;gap:10px}.intent-axis-label{font-size:11px;color:var(--muted);width:42px;flex-shrink:0}.intent-buttons{display:flex;gap:4px;flex-wrap:wrap}.intent-btn{background:var(--surface2);border:1px solid var(--border);border-radius:4px;color:var(--muted);font-family:var(--mono);font-size:11px;padding:4px 10px;cursor:pointer;transition:border-color .12s,color .12s,background .12s}.intent-btn:hover{border-color:var(--accent);color:var(--text)}.intent-btn.active{background:#00ff881a;border-color:var(--accent);color:var(--accent)}.intent-recs{display:flex;flex-direction:column;gap:4px}.intent-rec-row{display:grid;grid-template-columns:32px 8px 1fr auto auto auto 24px;gap:8px;align-items:center;padding:5px 8px;border-radius:5px;background:var(--surface2)}.intent-rec-row.bridge{border-left:2px dashed var(--muted)}.intent-rec-delta{font-size:10px;color:var(--muted);white-space:nowrap}.intent-rec-score{font-family:var(--serif);font-style:italic;font-size:15px;font-weight:700;text-align:center}.intent-rec-score--green{color:var(--accent)}.intent-rec-score--yellow{color:#fc0}.intent-rec-score--red{color:#f55}.intent-rec-info{min-width:0}.intent-rec-title{display:block;font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.intent-rec-meta{font-size:11px;color:var(--muted)}.intent-rec-key{font-family:var(--serif);font-style:italic;color:var(--accent);font-size:13px}.intent-rec-bpm{font-size:11px;color:var(--muted)}.intent-no-match{font-size:12px;color:var(--muted);padding:8px 0}.btn-add-stack-sm{background:none;border:1px solid var(--border);border-radius:4px;color:var(--muted);cursor:pointer;padding:3px;display:flex;align-items:center;transition:border-color .12s,color .12s}.btn-add-stack-sm:hover{border-color:var(--accent);color:var(--accent)}.export-bar{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--surface);border:1px solid var(--border);border-radius:8px}.export-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-right:4px}.btn-export{display:flex;align-items:center;gap:5px;background:var(--surface2);border:1px solid var(--border);border-radius:5px;color:var(--muted);font-family:var(--mono);font-size:12px;padding:5px 12px;cursor:pointer;transition:border-color .12s,color .12s}.btn-export:hover{border-color:var(--accent);color:var(--accent)}.set-builder-tab{padding:0}.set-builder{display:flex;flex-direction:column;gap:10px}.sb-section{background:var(--surface);border:1px solid var(--border);border-radius:6px;overflow:hidden}.sb-section-header{display:flex;align-items:center;justify-content:space-between;padding:9px 14px;border-bottom:1px solid var(--border)}.sb-section-title{font-size:10px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--muted);font-family:var(--mono)}.sb-section-count{font-size:10px;color:var(--muted);font-family:var(--mono)}.sb-now-playing-card{display:flex;align-items:center;gap:16px;margin:12px;padding:12px 14px;background:var(--surface2);border-radius:4px;border-left:3px solid var(--accent)}.sb-np-info{flex:1;min-width:0}.sb-np-title{font-size:15px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sb-np-artist{font-size:12px;color:var(--muted);margin-top:3px}.sb-np-meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0}.sb-np-key{font-family:var(--serif);font-style:italic;font-size:24px;font-weight:700;color:var(--accent);line-height:1}.sb-np-detail{font-size:11px;color:var(--muted);font-family:var(--mono)}.sb-np-empty{padding:28px 16px;text-align:center;color:var(--muted);font-size:12px;line-height:1.6}.sb-np-empty strong{display:block;color:var(--text);font-size:13px;margin-bottom:4px}.sb-filters{display:flex;align-items:center;gap:6px;padding:8px 14px;border-bottom:1px solid var(--border);flex-wrap:wrap}.sb-filter-sep{width:1px;height:14px;background:var(--border);flex-shrink:0}.sb-filter-btn{font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:3px 10px;border-radius:3px;border:1px solid var(--border);background:transparent;color:var(--muted);cursor:pointer;font-family:var(--mono);transition:border-color .1s,color .1s,background .1s}.sb-filter-btn:hover{border-color:var(--accent);color:var(--accent)}.sb-filter-btn.active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.sb-suggestion-list{display:flex;flex-direction:column}.sb-suggestion-row{display:grid;grid-template-columns:60px 1fr auto;grid-template-rows:auto auto;column-gap:10px;padding:8px 14px;cursor:pointer;transition:background .1s;border-bottom:1px solid var(--border)}.sb-suggestion-row:last-child{border-bottom:none}.sb-suggestion-row:hover{background:var(--surface2)}.sb-sug-stars{grid-column:1;grid-row:1 / 3;display:flex;align-items:center}.sb-stars{display:flex;gap:1px}.sb-star{font-size:13px;line-height:1}.sb-star.filled{color:var(--accent)}.sb-star{color:#2a2a2a}.sb-sug-main{grid-column:2;grid-row:1;min-width:0}.sb-sug-meta{grid-column:3;grid-row:1;display:flex;flex-direction:column;align-items:flex-end;gap:2px;flex-shrink:0}.sb-sug-reason{grid-column:2;grid-row:2;font-size:10px;color:var(--muted);font-style:italic;padding-top:2px}.sb-sug-title{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sb-sug-artist{font-size:11px;color:var(--muted);margin-top:1px}.sb-sug-key{font-family:var(--serif);font-style:italic;font-size:14px;font-weight:700;color:var(--accent);line-height:1}.sb-sug-bpm{font-size:10px;color:var(--muted);font-family:var(--mono)}.sb-empty-msg{padding:20px 14px;color:var(--muted);font-size:12px;text-align:center}.sb-discovery-section{background:#0b1410;border-color:#1c2e22}.sb-discovery-section .sb-section-title{color:#395240}.sb-discovery-section .sb-section-header{border-bottom-color:#1c2e22}.sb-discovery-section .sb-filter-btn{border-color:#1c2e22;color:#395240}.sb-discovery-section .sb-filter-btn:hover{border-color:#3a7a50;color:#3a7a50}.sb-discovery-empty{padding:14px;color:#395240;font-size:12px;font-style:italic}.sb-discovery-card{display:grid;grid-template-columns:20px 1fr auto;gap:10px;align-items:start;padding:9px 14px;border-bottom:1px solid #1c2e22}.sb-disc-diamond{color:#395240;font-size:13px;margin-top:1px}.sb-disc-info{min-width:0}.sb-ext-link{font-size:12px;color:#395240;text-decoration:none;padding:2px}.sb-ext-link:hover{color:#3a7a50}.sb-mix-body{padding:12px 14px}.sb-mix-empty{font-size:12px;color:var(--muted);font-style:italic;padding:4px 0}.sb-mix-chips{display:flex;flex-wrap:wrap;align-items:center;gap:4px;min-height:30px}.sb-mix-chip{background:var(--surface2);border:1px solid var(--border);border-radius:4px;padding:4px 10px;font-size:11px;font-family:var(--mono);color:var(--text);cursor:pointer;max-width:150px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:border-color .1s,color .1s}.sb-mix-chip:hover{border-color:#f55;color:#f55}.sb-mix-arrow{color:var(--muted);font-size:11px;flex-shrink:0;-webkit-user-select:none;user-select:none}.sb-mix-actions{display:flex;gap:7px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border);flex-wrap:wrap}.sb-action-btn{display:flex;align-items:center;gap:5px;font-size:10px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;padding:5px 11px;border-radius:4px;border:1px solid var(--border);background:transparent;color:var(--muted);font-family:var(--mono);cursor:pointer;transition:border-color .1s,color .1s}.sb-action-btn:hover{border-color:var(--text);color:var(--text)}.sb-action-btn.sb-action-danger:hover{border-color:#f55;color:#f55}.sb-action-btn:disabled{opacity:.3;cursor:not-allowed;pointer-events:none}.sb-top-grid,.sb-top-left{display:flex;flex-direction:column;gap:10px}@media (min-width: 1024px){.sb-top-grid{display:grid;grid-template-columns:1fr auto;align-items:start;gap:10px}}@media (max-width: 767px){.sb-wheel-panel:not(.sb-wheel-panel--visible){display:none}}.sb-wheel-body{display:flex;flex-direction:column;align-items:center;padding:14px 12px 10px}.sb-wheel-svg{width:320px;height:320px;display:block}@media (max-width: 1023px){.sb-wheel-svg{width:280px;height:280px}}@media (max-width: 767px){.sb-wheel-svg{width:240px;height:240px}}.sb-wheel-hint{font-size:11px;color:var(--muted);font-family:var(--mono);margin-top:8px;text-align:center;letter-spacing:.05em}.sw-node{transform-box:fill-box;transform-origin:center;transition:transform .1s ease}.sw-node:not(.sw-node--disabled){cursor:pointer}.sw-node:not(.sw-node--disabled):hover{transform:scale(1.1)}.sw-node--active{filter:drop-shadow(0 0 7px #00ff8860)}.sb-wheel-toggle{display:none}@media (max-width: 767px){.sb-wheel-toggle{display:flex;align-items:center;justify-content:center;width:100%;padding:9px 14px;background:var(--surface);border:1px solid var(--border);border-radius:6px;color:var(--muted);font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:border-color .15s,color .15s}.sb-wheel-toggle:hover{border-color:var(--accent);color:var(--accent)}}.sb-wheel-filter-badge{display:flex;align-items:center;gap:10px;padding:7px 14px;background:#001810;border-bottom:1px solid #00ff8828;font-family:var(--mono);font-size:11px;color:var(--accent);letter-spacing:.07em;text-transform:uppercase}.sb-wheel-filter-badge strong{font-weight:700}.sb-wheel-filter-clear{background:none;border:none;padding:0;font-family:var(--mono);font-size:11px;color:var(--muted);cursor:pointer;text-decoration:underline;letter-spacing:.05em;transition:color .15s}.sb-wheel-filter-clear:hover{color:var(--accent)}header{flex-wrap:wrap;justify-content:space-between;align-items:center}.header-main{display:flex;align-items:baseline;gap:16px}.header-auth{display:flex;align-items:center;gap:12px;margin-left:auto}.auth-email{font-family:var(--mono);font-size:11px;color:var(--muted)}.btn-auth{background:none;border:1px solid var(--border);color:var(--text);font-family:var(--mono);font-size:11px;padding:4px 10px;border-radius:4px;cursor:pointer;letter-spacing:.05em;transition:border-color .15s,color .15s}.btn-auth:hover{border-color:var(--accent);color:var(--accent)}.auth-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.auth-modal{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:32px;width:100%;max-width:360px}.auth-modal h2{font-family:var(--mono);font-size:14px;font-weight:400;color:var(--accent);letter-spacing:.1em;text-transform:uppercase;margin-bottom:24px}.auth-close{position:absolute;top:12px;right:16px;background:none;border:none;color:var(--muted);font-size:20px;cursor:pointer;line-height:1}.auth-close:hover{color:var(--text)}.auth-modal form{display:flex;flex-direction:column;gap:16px}.auth-modal label{display:flex;flex-direction:column;gap:6px;font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.05em}.auth-modal input{background:var(--surface2);border:1px solid var(--border);border-radius:4px;color:var(--text);font-family:var(--mono);font-size:13px;padding:8px 10px;outline:none;transition:border-color .15s}.auth-modal input:focus{border-color:var(--accent)}.auth-modal button[type=submit]{background:var(--accent);border:none;border-radius:4px;color:#000;font-family:var(--mono);font-size:12px;font-weight:700;letter-spacing:.08em;padding:10px;cursor:pointer;margin-top:4px;transition:opacity .15s}.auth-modal button[type=submit]:disabled{opacity:.5;cursor:default}.auth-modal button[type=submit]:not(:disabled):hover{opacity:.85}.auth-error{font-family:var(--mono);font-size:11px;color:#f44}.auth-message{font-family:var(--mono);font-size:11px;color:var(--accent);line-height:1.5}.auth-switch{margin-top:20px;font-family:var(--mono);font-size:11px;color:var(--muted);text-align:center}.auth-switch button{background:none;border:none;color:var(--accent);font-family:var(--mono);font-size:11px;cursor:pointer;text-decoration:underline;padding:0}.playlists-tab{display:flex;flex-direction:column;gap:16px}.playlists-panel{background:var(--surface);border:1px solid var(--border);border-radius:8px;overflow:hidden;max-width:680px}.playlists-header{display:flex;align-items:center;justify-content:space-between;padding:11px 16px;border-bottom:1px solid var(--border)}.playlists-header h2{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:1.5px}.playlists-header-actions{display:flex;align-items:center;gap:8px}.playlist-item{display:grid;grid-template-columns:1fr auto auto;gap:12px;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .12s}.playlist-item:last-child{border-bottom:none}.playlist-item:hover{background:var(--surface2)}.playlist-item .btn-remove{opacity:0}.playlist-item:hover .btn-remove{opacity:1}.playlist-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.playlist-count{font-size:11px;color:var(--muted);white-space:nowrap}.playlist-detail-header{display:flex;align-items:center;gap:10px;padding:11px 16px;border-bottom:1px solid var(--border)}.btn-back{display:flex;align-items:center;gap:4px;background:none;border:1px solid var(--border);border-radius:4px;color:var(--muted);font-family:var(--mono);font-size:11px;padding:4px 8px;cursor:pointer;white-space:nowrap;transition:color .12s,border-color .12s}.btn-back:hover{color:var(--text);border-color:var(--text)}.playlist-detail-name{font-size:14px;font-weight:600;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.playlist-detail-count{font-size:11px;color:var(--muted);white-space:nowrap}.playlist-track-item{display:grid;grid-template-columns:8px 1fr 42px 72px;gap:12px;align-items:center;padding:10px 16px;border-bottom:1px solid var(--border)}.playlist-track-item:last-child{border-bottom:none}.empty-playlists{padding:52px 24px;text-align:center;color:var(--muted);font-size:13px}.mp-low-conf{opacity:.55}
