@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg: #07070a;--bg-gradient: radial-gradient(ellipse 80% 60% at 50% -20%, rgba(249,115,22,.06), transparent);--surface: rgba(255,255,255,.03);--surface-hover: rgba(255,255,255,.06);--surface-elevated: rgba(255,255,255,.08);--surface-glass: rgba(14,14,18,.72);--border: rgba(255,255,255,.06);--border-subtle: rgba(255,255,255,.04);--border-hover: rgba(255,255,255,.1);--txt: #f0f0f2;--txt-secondary: #a1a1aa;--txt-tertiary: #63636e;--txt-faint: #3f3f46;--accent: #f97316;--accent-hover: #fb923c;--accent-muted: rgba(249,115,22,.15);--accent-glow: rgba(249,115,22,.25);--accent-glow-lg: rgba(249,115,22,.12);--green: #22c55e;--green-muted: rgba(34,197,94,.15);--red: #ef4444;--red-muted: rgba(239,68,68,.12);--blue: #3b82f6;--r: 8px;--r-md: 12px;--r-lg: 16px;--r-xl: 20px;--shadow-sm: 0 1px 2px rgba(0,0,0,.3), 0 1px 3px rgba(0,0,0,.15);--shadow-md: 0 4px 12px rgba(0,0,0,.35), 0 2px 4px rgba(0,0,0,.2);--shadow-lg: 0 12px 40px rgba(0,0,0,.5), 0 4px 12px rgba(0,0,0,.3);--shadow-xl: 0 24px 64px rgba(0,0,0,.6), 0 8px 24px rgba(0,0,0,.35);--ease-out: cubic-bezier(.16,1,.3,1);--ease-spring: cubic-bezier(.34,1.56,.64,1);--dur-fast: .15s;--dur: .2s;--dur-slow: .35s}body{font-family:Inter,-apple-system,BlinkMacSystemFont,system-ui,sans-serif;background:var(--bg);background-image:var(--bg-gradient);background-attachment:fixed;color:var(--txt);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5;overflow-x:hidden}::selection{background:var(--accent-muted);color:var(--accent-hover)}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);background-image:var(--bg-gradient)}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:48px 40px;text-align:center;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:var(--shadow-xl);min-width:320px;animation:login-in .4s var(--ease-out)}@keyframes login-in{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.login-logo{font-size:28px;font-weight:800;letter-spacing:-.5px;background:linear-gradient(135deg,var(--accent) 0%,#fbbf24 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:4px}.login-sub{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:2px;color:var(--txt-faint);margin-bottom:32px}.login-form{display:flex;flex-direction:column;gap:12px}.login-input{padding:14px 18px;border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface);color:var(--txt);font-size:15px;font-family:inherit;text-align:center;outline:none;transition:all var(--dur) var(--ease-out)}.login-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.login-btn{padding:14px!important;font-size:14px!important;width:100%}.login-error{color:var(--red);font-size:13px;font-weight:500}.app{max-width:1200px;margin:0 auto;padding:20px 24px 120px;overflow-x:hidden}.main-layout{display:flex;gap:20px;align-items:flex-start;max-width:100%}.main-content{flex:1;min-width:0;max-width:100%}.header{display:flex;align-items:center;justify-content:space-between;padding-bottom:20px;border-bottom:1px solid var(--border);margin-bottom:24px}.header-left{display:flex;align-items:center;gap:14px;min-width:0}.logo{font-size:22px;font-weight:800;letter-spacing:-.5px;background:linear-gradient(135deg,var(--accent) 0%,#fbbf24 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-dot.online{background:var(--green);box-shadow:0 0 6px var(--green),0 0 12px #22c55e4d;animation:pulse-green 2s ease-in-out infinite}.status-dot.offline{background:var(--red);box-shadow:0 0 6px var(--red)}@keyframes pulse-green{0%,to{box-shadow:0 0 6px var(--green),0 0 12px #22c55e4d}50%{box-shadow:0 0 8px var(--green),0 0 20px #22c55e66}}.logo-sub{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;color:var(--txt-faint)}.bot-name{font-size:13px;color:var(--txt-tertiary);font-weight:500}.header-voice{display:flex;align-items:center;gap:10px}.channel-select{padding:8px 12px;border-radius:var(--r);border:1px solid var(--border);background:var(--surface);color:var(--txt);font-size:13px;font-family:inherit;cursor:pointer;min-width:180px;transition:border-color var(--dur) var(--ease-out)}.channel-select:hover{border-color:var(--border-hover)}.channel-select:focus{border-color:var(--accent);outline:none}.channel-select option{background:#1a1a2e;color:var(--txt)}.voice-status{font-size:13px;font-weight:600;padding:6px 12px;border-radius:var(--r)}.voice-status.connected{color:var(--green);background:var(--green-muted)}.btn{padding:9px 18px;border:none;border-radius:var(--r);cursor:pointer;font-size:13px;font-weight:600;font-family:inherit;transition:all var(--dur) var(--ease-out)}.btn:active{transform:scale(.96)}.btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.btn-accent{background:linear-gradient(135deg,var(--accent) 0%,#ea580c 100%);color:#fff;box-shadow:0 2px 8px var(--accent-glow),inset 0 1px #ffffff26}.btn-accent:hover{background:linear-gradient(135deg,var(--accent-hover) 0%,var(--accent) 100%);box-shadow:0 4px 16px var(--accent-glow);transform:translateY(-1px)}.btn-danger{padding:9px 18px;border:none;border-radius:var(--r);cursor:pointer;font-size:13px;font-weight:600;font-family:inherit;background:linear-gradient(135deg,var(--red) 0%,#dc2626 100%);color:#fff;box-shadow:0 2px 8px var(--red-muted);transition:all var(--dur) var(--ease-out)}.btn-danger:hover{background:linear-gradient(135deg,#f87171 0%,var(--red) 100%);transform:translateY(-1px)}.btn-ghost{background:var(--surface);color:var(--txt-secondary);border:1px solid var(--border)}.btn-ghost:hover{color:var(--txt);background:var(--surface-hover);border-color:var(--border-hover)}.btn-sm{padding:6px 14px!important;font-size:12px!important}.btn-xs{padding:5px 12px;border:none;border-radius:var(--r);cursor:pointer;font-size:11px;font-weight:600;font-family:inherit;color:#fff;transition:all var(--dur-fast)}.btn-xs:active{transform:scale(.93)}.btn-play{background:linear-gradient(135deg,var(--accent),#ea580c);box-shadow:0 1px 4px var(--accent-glow)}.btn-play:hover{box-shadow:0 2px 8px var(--accent-glow)}.btn-pin{background:var(--surface-elevated);color:var(--txt-secondary);border:1px solid var(--border)}.btn-pin:hover{color:var(--accent);border-color:var(--accent)}.search-container{position:relative;margin-bottom:24px}.search-input{width:100%;padding:14px 18px 14px 44px;border-radius:var(--r-lg);border:1px solid var(--border);background:var(--surface);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:var(--txt);font-size:14px;font-family:inherit;font-weight:500;outline:none;transition:all var(--dur) var(--ease-out)}.search-input:hover{border-color:var(--border-hover);background:var(--surface-hover)}.search-input:focus{border-color:var(--accent);background:var(--surface-hover);box-shadow:0 0 0 3px var(--accent-glow)}.search-input::placeholder{color:var(--txt-faint);font-weight:400}.search-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--txt-faint);font-size:15px;pointer-events:none}.search-container:focus-within .search-icon{color:var(--accent)}.search-dropdown{position:absolute;top:calc(100% + 8px);left:0;right:0;z-index:50;background:var(--surface-glass);-webkit-backdrop-filter:blur(24px) saturate(1.4);backdrop-filter:blur(24px) saturate(1.4);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-xl);max-height:440px;overflow-y:auto;overflow-x:hidden;padding:6px;animation:dropdown-in .2s var(--ease-out)}@keyframes dropdown-in{0%{opacity:0;transform:translateY(-6px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.search-item{display:flex;align-items:center;padding:10px 12px;gap:12px;cursor:pointer;border-radius:var(--r);transition:all var(--dur-fast);min-width:0;max-width:100%}.search-item:hover{background:var(--surface-hover)}.search-item-info{flex:1;min-width:0}.search-item-title{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-item-meta{font-size:11px;color:var(--txt-tertiary);margin-top:1px}.search-item-actions{display:flex;gap:6px;flex-shrink:0;opacity:0;transition:opacity var(--dur-fast)}.search-item:hover .search-item-actions{opacity:1}.cat-picker{position:fixed;z-index:200;background:var(--surface-glass);-webkit-backdrop-filter:blur(24px) saturate(1.4);backdrop-filter:blur(24px) saturate(1.4);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-xl);padding:10px;animation:dropdown-in .15s var(--ease-out);min-width:280px}.cat-picker-title{font-size:11px;font-weight:600;color:var(--txt-tertiary);padding:4px 8px 8px;text-transform:uppercase;letter-spacing:1px}.cat-picker-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px}.cat-picker-item{display:flex;align-items:center;gap:6px;padding:7px 10px;border-radius:var(--r);border:1px solid transparent;background:transparent;color:var(--txt-secondary);font-size:12px;font-weight:500;font-family:inherit;cursor:pointer;transition:all var(--dur-fast);text-align:left}.cat-picker-item:hover{background:color-mix(in srgb,var(--picker-color, #888) 12%,transparent);color:var(--picker-color, #888);border-color:color-mix(in srgb,var(--picker-color, #888) 25%,transparent)}.cat-picker-divider{height:1px;background:var(--border);margin:6px 8px}.cat-picker-lib{font-style:italic;opacity:.8}.section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--txt-faint);margin-bottom:14px;padding-left:2px}.scene-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-bottom:24px;max-width:100%}.scene-card{position:relative;padding:0;border-radius:var(--r-lg);cursor:pointer;color:#fff;border:1px solid rgba(255,255,255,.08);transition:all var(--dur-slow) var(--ease-out);overflow:hidden;-webkit-user-select:none;user-select:none;isolation:isolate}.scene-card-inner{padding:18px 10px 14px;text-align:center;position:relative;z-index:2}.scene-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,rgba(255,255,255,.08) 0%,transparent 40%,rgba(0,0,0,.35) 100%);pointer-events:none;z-index:1}.scene-card:hover{transform:translateY(-4px) scale(1.03);box-shadow:var(--shadow-lg),0 0 0 1px #ffffff1f;border-color:#ffffff26}.scene-card:active{transform:translateY(-1px) scale(.99);transition-duration:.1s}.scene-card.active{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),0 0 30px var(--accent-glow-lg),0 12px 40px #00000080}.scene-card.active:before{background:linear-gradient(180deg,rgba(249,115,22,.12) 0%,transparent 60%,rgba(0,0,0,.3) 100%)}.scene-card.dim{opacity:.3;filter:saturate(.4)}.scene-card.dim:hover{opacity:.6;filter:saturate(.7)}.scene-emoji{font-size:28px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.4));transition:transform var(--dur-slow) var(--ease-spring)}.scene-card:hover .scene-emoji{transform:scale(1.15)}.scene-label{font-size:13px;font-weight:700;margin-top:6px;letter-spacing:-.01em;text-shadow:0 1px 3px rgba(0,0,0,.5)}.scene-hint{font-size:9px;color:#ffffff80;margin-top:3px;line-height:1.3;text-shadow:0 1px 2px rgba(0,0,0,.5)}.scene-moods{display:flex;gap:3px;flex-wrap:wrap;justify-content:center;margin-top:6px}.mood-pill{font-size:8px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;padding:1px 5px;border-radius:6px;background:#ffffff1a;color:#ffffffa6}.scene-count{font-size:9px;opacity:.5;margin-top:4px;font-weight:500;letter-spacing:.3px}.scene-eq{position:absolute;top:6px;right:6px;display:flex;align-items:flex-end;gap:2px;height:12px;z-index:5}.scene-eq span{width:2.5px;background:var(--accent);border-radius:1px;animation:eq-bar .8s ease-in-out infinite}.scene-eq span:nth-child(1){animation-delay:0s}.scene-eq span:nth-child(2){animation-delay:.15s}.scene-eq span:nth-child(3){animation-delay:.3s}@keyframes eq-bar{0%,to{height:30%}50%{height:100%}}.tracklist-card{background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--scene-color, var(--border));border-radius:var(--r-lg);padding:6px;margin-bottom:20px;animation:tracklist-in .3s var(--ease-out);min-width:0;max-width:100%;overflow:hidden}@keyframes tracklist-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.tracklist-header{display:flex;justify-content:space-between;align-items:flex-start;padding:14px 16px 10px}.tracklist-header-left{display:flex;flex-direction:column;gap:2px}.tracklist-title{font-size:14px;font-weight:700;color:var(--accent)}.tracklist-hint{font-size:11px;color:var(--txt-faint);font-style:italic}.tracklist-sub{font-size:11px;color:var(--txt-tertiary);font-weight:500;flex-shrink:0}.track-row{display:flex;align-items:center;gap:10px;padding:8px 14px;border-radius:var(--r);cursor:pointer;transition:all var(--dur-fast);min-width:0;max-width:100%}.track-row:hover{background:var(--surface-hover)}.track-row.now-playing{background:var(--accent-muted)}.track-row.now-playing .track-num{color:var(--accent);font-weight:700}.track-row.now-playing .track-name{color:var(--accent)}.track-num{width:22px;text-align:center;font-size:12px;color:var(--txt-faint);flex-shrink:0;font-variant-numeric:tabular-nums}.track-row:hover .track-num{color:var(--accent)}.track-info{flex:1;min-width:0}.track-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-artist{font-size:11px;color:var(--txt-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}.track-add-btn{background:none;border:1px solid var(--border);color:var(--txt-faint);font-size:14px;font-weight:600;width:28px;height:28px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:0;transition:all var(--dur-fast);font-family:inherit}.track-row:hover .track-add-btn{opacity:1}.track-add-btn:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-muted)}.track-add-btn:active{transform:scale(.9)}.track-add-btn.added{opacity:.7;color:var(--green);border-color:var(--green-muted);cursor:default}.track-row.in-playlist{border-left:2px solid var(--green)}.track-eq-mini{display:flex;align-items:flex-end;gap:1px;height:12px;justify-content:center}.track-eq-mini span{width:2px;background:var(--blue);border-radius:1px;animation:eq-bar .8s ease-in-out infinite}.track-eq-mini span:nth-child(1){animation-delay:0s}.track-eq-mini span:nth-child(2){animation-delay:.15s}.track-eq-mini span:nth-child(3){animation-delay:.3s}.track-row[draggable]:active,.search-item[draggable]:active{opacity:.5;cursor:grabbing}.cat-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:12px;font-size:10px;font-weight:600;white-space:nowrap;flex-shrink:0;background:color-mix(in srgb,var(--badge-color, #888) 15%,transparent);color:var(--badge-color, #888)}.cat-badge-sm{font-size:9px;padding:1px 6px;gap:2px}.cat-badge-icon{font-size:9px}.cat-badge-label{letter-spacing:.2px}.playlist-panel{width:340px;flex-shrink:0;position:sticky;top:20px;max-height:calc(100vh - 200px);display:flex;flex-direction:column;animation:pl-in .25s var(--ease-out)}@keyframes pl-in{0%{opacity:0;transform:translate(10px)}to{opacity:1;transform:translate(0)}}.playlist-header{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg) var(--r-lg) 0 0;padding:14px 14px 10px}.playlist-header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.playlist-title{font-size:15px;font-weight:700}.playlist-meta{font-size:11px;color:var(--txt-tertiary);font-variant-numeric:tabular-nums}.playlist-filters{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:10px}.filter-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:16px;border:1px solid var(--border);background:transparent;color:var(--txt-tertiary);font-size:11px;font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--dur-fast)}.filter-chip:hover{border-color:var(--border-hover);color:var(--txt-secondary)}.filter-chip.active{border-color:var(--chip-color, var(--accent));background:color-mix(in srgb,var(--chip-color, var(--accent)) 12%,transparent);color:var(--chip-color, var(--accent))}.filter-chip-count{font-size:9px;opacity:.6}.repeat-control{display:flex;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;margin-bottom:8px}.repeat-btn{flex:1;padding:5px 8px;border:none;background:transparent;color:var(--txt-faint);font-size:11px;font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--dur-fast);white-space:nowrap}.repeat-btn:hover{color:var(--txt-secondary);background:var(--surface-hover)}.repeat-btn.active{color:var(--accent);background:var(--accent-muted);box-shadow:inset 0 0 0 1px #f9731633}.repeat-btn+.repeat-btn{border-left:1px solid var(--border)}.playlist-actions{display:flex;gap:6px;align-items:center}.playlist-panel.drop-hover{border-color:var(--accent)!important;box-shadow:inset 0 0 20px var(--accent-glow-lg),0 0 0 2px var(--accent-muted)}.playlist-empty{background:var(--surface);border:1px solid var(--border);border-top:none;border-radius:0 0 var(--r-lg) var(--r-lg);padding:40px 20px;text-align:center;color:var(--txt-faint);font-size:13px}.playlist-empty-icon{font-size:32px;margin-bottom:10px;opacity:.3}.playlist-empty-hint{font-size:11px;margin-top:6px;color:var(--txt-faint);line-height:1.5}.playlist-list{background:var(--surface);border:1px solid var(--border);border-top:none;border-radius:0 0 var(--r-lg) var(--r-lg);padding:4px;overflow-y:auto;overflow-x:hidden;flex:1;min-height:100px;min-width:0}.pl-item{display:flex;align-items:center;gap:6px;padding:7px 8px;border-radius:var(--r);cursor:grab;transition:all var(--dur-fast);border-left:3px solid var(--item-color, transparent);margin:1px 0;min-width:0;max-width:100%}.pl-item:hover{background:var(--surface-hover)}.pl-item.now-playing{background:color-mix(in srgb,var(--item-color, var(--accent)) 10%,transparent)}.pl-item.now-playing .pl-name{color:var(--item-color, var(--accent));font-weight:600}.pl-item.dragging{opacity:.3}.pl-item.drag-over{border-color:var(--accent);background:var(--accent-muted)}.pl-grip{color:var(--txt-faint);font-size:10px;cursor:grab;flex-shrink:0;width:14px;text-align:center}.pl-item:hover .pl-grip{color:var(--txt-tertiary)}.pl-play-btn{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;color:var(--txt-faint);cursor:pointer;flex-shrink:0;transition:all var(--dur-fast);background:transparent;border:1px solid var(--border)}.pl-play-btn:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-muted)}.pl-item.now-playing .pl-play-btn{color:var(--item-color, var(--accent));border-color:var(--item-color, var(--accent))}.pl-eq{display:flex;align-items:flex-end;gap:1.5px;height:10px}.pl-eq span{width:2px;background:var(--item-color, var(--accent));border-radius:1px;animation:eq-bar .8s ease-in-out infinite}.pl-eq span:nth-child(1){animation-delay:0s}.pl-eq span:nth-child(2){animation-delay:.15s}.pl-eq span:nth-child(3){animation-delay:.3s}.pl-play-icon{display:block;width:0;height:0;border-style:solid;border-width:5px 0 5px 9px;border-color:transparent transparent transparent currentColor}.pl-info{flex:1;min-width:0}.pl-name{font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pl-meta{font-size:10px;color:var(--txt-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pl-remove{background:none;border:none;color:var(--txt-faint);font-size:11px;cursor:pointer;padding:2px 4px;border-radius:4px;opacity:0;transition:all var(--dur-fast);flex-shrink:0}.pl-item:hover .pl-remove{opacity:1}.pl-remove:hover{color:var(--red);background:var(--red-muted)}.pl-cached{color:var(--green);font-size:10px;margin-left:2px}.pl-startat-btn{background:none;border:1px solid var(--border);color:var(--txt-faint);font-size:10px;font-weight:600;font-family:inherit;font-variant-numeric:tabular-nums;padding:2px 6px;border-radius:4px;cursor:pointer;opacity:0;transition:all var(--dur-fast);flex-shrink:0;white-space:nowrap}.pl-item:hover .pl-startat-btn{opacity:1}.pl-startat-btn:hover{color:var(--accent);border-color:var(--accent)}.pl-startat-btn.has-time{opacity:1!important;color:var(--accent);border-color:var(--accent-muted);background:var(--accent-muted)}.pl-startat-editor{display:flex;align-items:center;gap:3px;flex-shrink:0}.pl-startat-input{width:46px;padding:2px 4px;border:1px solid var(--accent);border-radius:4px;background:var(--surface);color:var(--txt);font-size:11px;font-family:inherit;font-variant-numeric:tabular-nums;text-align:center;outline:none}.pl-startat-ok{background:none;border:none;color:var(--green);font-size:14px;cursor:pointer;padding:0 2px}.pl-startat-group{display:flex;align-items:center;gap:2px;flex-shrink:0}.pl-startat-clear{background:none;border:none;color:var(--txt-faint);font-size:9px;cursor:pointer;padding:1px 3px;border-radius:3px;opacity:0;transition:all var(--dur-fast)}.pl-item:hover .pl-startat-clear{opacity:1}.pl-startat-clear:hover{color:var(--red);background:var(--red-muted)}.player-bar{position:fixed;bottom:12px;left:50%;transform:translate(-50%);z-index:100;width:min(720px,calc(100% - 24px));background:var(--surface-glass);border:1px solid var(--border-hover);border-radius:var(--r-xl);-webkit-backdrop-filter:blur(32px) saturate(1.5);backdrop-filter:blur(32px) saturate(1.5);box-shadow:0 8px 40px #00000080,0 0 0 1px #ffffff0a;overflow:visible}.player-bar:before{content:"";position:absolute;top:-1px;left:20px;right:20px;height:1px;border-radius:1px;background:linear-gradient(90deg,transparent 0%,var(--accent-glow) 30%,var(--accent-muted) 50%,var(--accent-glow) 70%,transparent 100%)}.player-inner{display:flex;align-items:center;padding:8px 16px 10px;gap:12px;overflow:hidden}.player-track-info{width:160px;flex:0 1 160px;min-width:0;overflow:hidden}.player-track-title{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}.player-track-artist{font-size:11px;color:var(--txt-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px;line-height:1.3}.player-no-track{font-size:13px;color:var(--txt-faint);font-style:italic}.player-controls{display:flex;align-items:center;gap:4px;flex:0 0 auto}.ctrl-btn{width:36px;height:36px;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--dur) var(--ease-out);background:transparent;color:var(--txt-secondary);font-size:15px;font-family:inherit;flex-shrink:0}.ctrl-btn:hover{color:var(--txt);background:var(--surface-hover)}.ctrl-btn:active{transform:scale(.88);transition-duration:.08s}.ctrl-btn.play-btn{width:42px;height:42px;background:linear-gradient(135deg,var(--accent) 0%,#ea580c 100%);color:#fff;font-size:18px;box-shadow:0 2px 12px var(--accent-glow),inset 0 1px #ffffff26}.ctrl-btn.play-btn:hover{background:linear-gradient(135deg,var(--accent-hover) 0%,var(--accent) 100%);box-shadow:0 4px 20px var(--accent-glow);transform:scale(1.06)}.ctrl-btn.stop-btn{color:var(--txt-tertiary);font-size:10px;font-weight:800;letter-spacing:.8px;border-radius:var(--r);width:auto;padding:0 12px;height:30px;border:1px solid var(--border);flex-shrink:0}.ctrl-btn.stop-btn:hover{color:var(--red);background:var(--red-muted);border-color:#ef444433}.loop-btn{font-size:14px!important;width:32px!important;height:32px!important}.loop-btn.active{color:var(--accent)!important}.volume-wrap{display:flex;align-items:center;gap:6px;flex:1 1 120px;min-width:60px;max-width:140px;justify-content:flex-end}.volume-icon{color:var(--txt-tertiary);font-size:15px;cursor:pointer;flex-shrink:0}.volume-icon:hover{color:var(--txt)}.volume-slider{flex:1;min-width:0;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:2px;outline:none;cursor:pointer;background:var(--surface-elevated)}.volume-wrap:hover .volume-slider{height:5px}.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:#fff;cursor:pointer;box-shadow:0 1px 4px #0006;margin-top:-5px}.volume-slider::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 1px 8px #00000080,0 0 0 3px var(--accent-glow)}.volume-slider:active::-webkit-slider-thumb{background:var(--accent)}.volume-slider::-moz-range-track{height:4px;border-radius:2px;background:var(--surface-elevated);border:none}.volume-slider::-moz-range-progress{height:4px;border-radius:2px;background:var(--accent)}.volume-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:#fff;border:none}.volume-val{font-size:10px;color:var(--txt-faint);min-width:20px;text-align:right;font-variant-numeric:tabular-nums;flex-shrink:0}.status-badge{font-size:10px;padding:4px 10px;border-radius:20px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;flex-shrink:0}.status-badge.playing{background:var(--green-muted);color:var(--green)}.status-badge.paused{background:var(--accent-muted);color:var(--accent)}.status-badge.idle{background:var(--surface-hover);color:var(--txt-faint)}.progress-track{position:relative;cursor:pointer;-webkit-user-select:none;user-select:none}.progress-track:hover .progress-fill,.progress-track:hover .progress-bg{height:4px}.progress-bg{position:absolute;left:0;right:0;top:0;height:3px;background:#ffffff14;border-radius:0;transition:height var(--dur-fast)}.progress-fill{position:absolute;left:0;top:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--accent-hover));border-radius:0;transition:height var(--dur-fast)}.progress-fill:after{content:"";position:absolute;right:-5px;top:50%;transform:translateY(-50%);width:10px;height:10px;border-radius:50%;background:#fff;box-shadow:0 0 8px var(--accent-glow),0 1px 4px #00000080;opacity:0;transition:opacity var(--dur-fast)}.progress-track:hover .progress-fill:after{opacity:1}.progress-times{display:flex;justify-content:space-between;padding:6px 16px 2px;font-size:10px;color:var(--txt-faint);font-variant-numeric:tabular-nums;font-weight:500}.seek-tooltip{position:absolute;top:-28px;transform:translate(-50%);background:var(--surface-glass);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:6px;padding:2px 8px;font-size:11px;font-weight:600;font-variant-numeric:tabular-nums;color:var(--accent);pointer-events:none;white-space:nowrap;box-shadow:var(--shadow-md);z-index:110}.toast{position:fixed;top:16px;left:50%;transform:translate(-50%);z-index:200;background:var(--surface-glass);-webkit-backdrop-filter:blur(20px) saturate(1.3);backdrop-filter:blur(20px) saturate(1.3);border:1px solid var(--border);border-radius:var(--r-lg);padding:10px 24px;font-size:13px;font-weight:500;color:var(--txt-secondary);box-shadow:var(--shadow-lg);animation:toast-in .3s var(--ease-out)}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(-12px) scale(.95)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}.track-row.previewing{background:#3b82f614}.track-row.previewing .track-num,.track-row.previewing .track-name{color:var(--blue)}.search-item.previewing{background:#3b82f60f}.track-row.expanded,.search-item.expanded,.pl-item.expanded{flex-wrap:wrap;background:#3b82f60f;border:1px solid rgba(59,130,246,.12);padding-bottom:4px;max-width:100%}.inline-preview{width:100%;display:flex;align-items:center;gap:8px;padding:4px 4px 2px 36px;animation:ip-in .15s var(--ease-out);min-width:0;box-sizing:border-box}@keyframes ip-in{0%{opacity:0;height:0}to{opacity:1;height:auto}}.ip-btn{background:none;border:1px solid rgba(59,130,246,.25);color:var(--blue);width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:10px;flex-shrink:0;transition:all var(--dur-fast)}.ip-btn:hover{background:#3b82f626}.ip-progress{flex:1;height:4px;background:#ffffff14;border-radius:2px;cursor:pointer;position:relative;min-width:60px}.ip-progress:hover{height:6px}.ip-fill{height:100%;background:var(--blue);border-radius:2px;position:relative}.ip-fill:after{content:"";position:absolute;right:-4px;top:50%;transform:translateY(-50%);width:8px;height:8px;border-radius:50%;background:#fff;box-shadow:0 0 4px #3b82f680;opacity:0;transition:opacity var(--dur-fast)}.ip-progress:hover .ip-fill:after{opacity:1}.ip-time{font-size:10px;color:#3b82f699;font-variant-numeric:tabular-nums;flex-shrink:0;min-width:24px;white-space:nowrap}.ip-vol{width:50px;height:3px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#ffffff1a;border-radius:2px;outline:none;cursor:pointer;flex-shrink:0}.ip-vol::-webkit-slider-thumb{-webkit-appearance:none;width:8px;height:8px;border-radius:50%;background:var(--blue);cursor:pointer}.ip-close{background:none;border:none;color:#ffffff4d;font-size:11px;cursor:pointer;padding:1px 3px;flex-shrink:0;transition:color var(--dur-fast)}.ip-close:hover{color:#fff}.kbd-hints{position:fixed;bottom:120px;right:16px;display:flex;gap:6px;font-size:9px;color:var(--txt-faint);opacity:.2;transition:opacity .3s;z-index:50}.kbd-hints:hover{opacity:.6}.kbd-hints span{padding:2px 6px;background:var(--surface);border:1px solid var(--border);border-radius:4px;font-family:monospace}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--surface-elevated);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ffffff1f}.spinner{width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite;position:absolute;right:16px;top:50%;margin-top:-9px}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:900px){.scene-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.app{max-width:100%;padding:12px 12px 180px}.header{flex-wrap:wrap;gap:10px;padding-bottom:12px;margin-bottom:16px}.header-left{width:100%;min-width:0;overflow:hidden}.header-voice{width:100%;min-width:0}.channel-select{min-width:0;flex:1}.logo{font-size:18px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.logo-sub{font-size:8px;letter-spacing:1px}.bot-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:120px}.main-layout{flex-direction:column;gap:16px}.main-content{min-width:0;width:100%}.playlist-panel{width:100%;min-width:0;max-height:none;position:static}.kbd-hints{display:none}.scene-grid{grid-template-columns:repeat(3,1fr);gap:8px;overflow:hidden}.scene-card-inner{padding:14px 8px 10px}.scene-card{transform:none!important}.scene-card:hover{transform:none;box-shadow:none}.scene-card:active{transform:scale(.97)!important}.scene-emoji{font-size:24px}.search-input{min-height:48px;font-size:16px;padding:14px 16px 14px 42px}.search-container{margin-bottom:16px}.tracklist-card{padding:4px}.track-row{min-height:48px;padding:10px 8px;gap:8px;max-width:100%}.track-row.expanded{padding-bottom:4px}.track-info{min-width:0;flex:1}.track-add-btn{opacity:1}.track-add-btn.added{opacity:.7}.track-action-btn{opacity:1}.tracklist-header{flex-direction:column;gap:4px;align-items:flex-start;padding:10px 8px 8px}.tracklist-title{font-size:13px}.tracklist-sub{font-size:10px}.pl-item{min-height:48px;padding:8px 6px;gap:5px;max-width:100%}.pl-item.expanded{padding-bottom:4px}.pl-remove{opacity:1;font-size:14px;padding:4px 8px}.pl-startat-btn{opacity:1}.pl-grip{display:none}.pl-play-btn{width:28px;height:28px}.pl-info{min-width:0;flex:1}.playlist-filters{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:6px;gap:6px}.filter-chip{white-space:nowrap;flex-shrink:0}.repeat-control{margin-bottom:6px}.player-bar{bottom:0;left:0;right:0;transform:none;width:100%;border-radius:var(--r-lg) var(--r-lg) 0 0;border-bottom:none}.player-inner{padding:6px 12px 8px;gap:8px}.player-track-info{flex:0 1 120px;min-width:0}.player-track-title{font-size:12px}.player-track-artist{font-size:10px}.player-controls{gap:3px}.volume-wrap{flex:1 1 80px;min-width:50px;max-width:100px}.volume-val{display:none}.ctrl-btn{width:32px;height:32px;font-size:13px}.ctrl-btn.play-btn{width:38px;height:38px;font-size:15px}.ctrl-btn.stop-btn{padding:0 8px;font-size:9px;height:28px}.status-badge{font-size:9px;padding:3px 6px}.progress-times{font-size:9px;padding:4px 12px 2px}.inline-preview{padding:6px 4px 4px;gap:6px}.ip-vol{display:none}.ip-btn{width:28px;height:28px;flex-shrink:0}.ip-progress{min-width:40px;flex:1}.ip-time{font-size:10px;max-width:80px;overflow:hidden}.ip-close{flex-shrink:0}.search-dropdown{max-height:60vh;left:0;right:0}.search-item{padding:12px 10px;max-width:100%}.search-item.expanded{padding-bottom:4px}.search-item-info{min-width:0;flex:1}.search-item-actions{opacity:1;gap:8px;flex-shrink:0}.btn-xs{padding:8px 14px;font-size:12px}.cat-picker{position:fixed!important;left:0!important;right:0!important;bottom:0!important;top:auto!important;min-width:unset;width:100%;border-radius:var(--r-xl) var(--r-xl) 0 0;max-height:70vh;overflow-y:auto;padding:16px 12px;animation:sheet-up .25s var(--ease-out)}.cat-picker-grid{grid-template-columns:1fr 1fr;gap:6px}.cat-picker-item{padding:10px 12px;font-size:13px}.login-card{padding:32px 20px;min-width:unset;max-width:calc(100vw - 24px)}.login-logo{font-size:22px}.login-input{font-size:16px;min-height:48px}.playlist-header{padding:12px 10px 8px}.playlist-title{font-size:14px}.playlist-actions{flex-wrap:wrap}.playlist-actions .btn{flex:1;min-width:0;text-align:center}.playlist-list{overflow-x:hidden}.playlist-empty{padding:24px 16px}.cat-badge{flex-shrink:1;min-width:0;overflow:hidden}.cat-badge-label{overflow:hidden;text-overflow:ellipsis}.toast{max-width:calc(100vw - 32px)}}@keyframes sheet-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}@media(max-width:480px){.app{padding:8px 8px 180px}.scene-grid{grid-template-columns:repeat(2,1fr);gap:6px}.scene-card-inner{padding:10px 6px 8px}.scene-emoji{font-size:20px}.scene-label{font-size:10px}.scene-hint,.scene-moods{display:none}.scene-count{font-size:7px}.scene-eq{top:4px;right:4px;height:10px}.section-title{font-size:10px;margin-bottom:10px}.logo{font-size:16px}.bot-name{font-size:11px;max-width:90px}.voice-status{font-size:11px;padding:5px 8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}.header-voice .btn{padding:8px 14px;font-size:12px;flex-shrink:0}.track-name{font-size:12px}.track-artist{font-size:10px}.track-row{padding:8px 6px;gap:6px}.track-num{width:18px;font-size:11px}.pl-name{font-size:11px}.pl-meta{font-size:9px}.pl-item{padding:8px 4px;gap:4px}.pl-play-btn{width:26px;height:26px;flex-shrink:0}.pl-startat-btn:not(.has-time){display:none}.cat-badge-sm{font-size:8px;padding:1px 4px}.cat-badge-sm .cat-badge-label{max-width:50px}.player-inner{padding:4px 8px 6px;gap:4px}.ctrl-btn{width:28px;height:28px;font-size:12px}.ctrl-btn.play-btn{width:34px;height:34px;font-size:14px}.ctrl-btn.stop-btn{padding:0 6px;font-size:8px;height:24px}.volume-wrap{flex:0 1 50px;min-width:40px;max-width:60px}.player-track-info{flex:0 1 80px;min-width:0}.player-track-title{font-size:11px}.player-track-artist{display:none}.player-no-track{font-size:11px}.search-item{padding:10px 8px;gap:8px}.search-item-title{font-size:12px}.search-item-meta{font-size:10px}.inline-preview{gap:4px;padding:4px 2px 2px}.ip-btn{width:24px;height:24px;font-size:9px}.ip-time{font-size:9px}.playlist-header{padding:10px 8px 6px}.playlist-header-top{flex-direction:column;gap:2px;align-items:flex-start}.playlist-meta,.repeat-control{font-size:10px}.repeat-btn{padding:4px 6px;font-size:10px}.playlist-actions .btn{font-size:11px!important;padding:7px 10px!important}.progress-times{padding:4px 8px 2px;font-size:9px}}
