@import"https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@400;500;600;700&family=Barlow:wght@400;500;600&family=JetBrains+Mono:wght@400;500&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #000000;--surface: #0c0c0d;--surface-hi: #111113;--surface-soft: color-mix(in srgb, var(--surface) 58%, var(--bg));--border: #282829;--border-hi: #3c3c40;--text: #f0f0f2;--text-muted: #888891;--text-dim: #52525a;--accent: #dd1533;--accent-lo: rgba(221,21,51,.13);--accent-hi: #ff3558;--accent-text: #fff;--chrome: #b4b4ba;--chrome-lo: rgba(180,180,186,.08);--green: #4ade80;--green-lo: rgba(74,222,128,.15);--red: #f87171;--yellow: #fbbf24;--blue: #60a5fa;--mauve: #a78bfa;--peach: #fb923c;--base: #0c0c0d;--overlay: #070708;--radius: 3px;--ff: "Barlow Condensed", sans-serif;--fb: "Barlow", sans-serif;--fm: "JetBrains Mono", monospace;--shadow: 0 20px 54px rgba(0, 0, 0, .6)}html,body,#root{height:100%}body{background:var(--bg);color:var(--text);font-family:var(--fb);-webkit-font-smoothing:antialiased;font-size:14px;letter-spacing:.01em}.app{display:flex;flex-direction:column;height:100%;max-width:720px;margin:0 auto}.app-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px 0;border-bottom:1px solid var(--border);flex-shrink:0}.app-title{display:flex;align-items:center;gap:10px}.app-logo{color:var(--accent);flex-shrink:0}.app-title-text{display:flex;flex-direction:column;line-height:1;letter-spacing:.18em}.app-title-main{font-family:var(--ff);font-size:20px;font-weight:700;color:var(--text);letter-spacing:.22em;text-transform:uppercase}.app-title-sub{font-family:var(--ff);font-size:9px;font-weight:500;color:var(--accent);letter-spacing:.35em;margin-top:3px;text-transform:uppercase}.tab-nav{display:flex;gap:2px}.tab-btn{background:none;border:none;border-bottom:2px solid transparent;color:var(--text-muted);cursor:pointer;font-family:var(--ff);font-size:12px;font-weight:600;letter-spacing:.18em;padding:10px 14px 12px;text-transform:uppercase;transition:color .15s,border-color .15s}.tab-btn:hover{color:var(--text)}.tab-btn--active{color:var(--accent);border-bottom-color:var(--accent)}.app-main{flex:1;overflow-y:auto;padding:0 0 40px}.app-main::-webkit-scrollbar{width:4px}.app-main::-webkit-scrollbar-track{background:transparent}.app-main::-webkit-scrollbar-thumb{background:var(--border-hi);border-radius:2px}.panel{padding:0}.panel-section{padding:18px 20px;border-bottom:1px solid var(--border)}.panel-section--meta{padding:12px 20px}.panel-error{display:flex;align-items:center;gap:8px;padding:12px 20px;font-size:12px;color:var(--text-muted);border-bottom:1px solid var(--border)}.panel-empty{padding:32px 20px;font-size:12px;color:var(--text-muted);text-align:center;letter-spacing:.06em}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.section-label{font-size:10px;font-weight:600;letter-spacing:.2em;color:var(--text-muted)}.section-value{font-size:13px;color:var(--text)}.icon-btn{display:inline-flex;align-items:center;justify-content:center;background:none;border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);cursor:pointer;font-family:var(--ff);line-height:1;transition:background .1s,border-color .1s,color .1s,opacity .1s}.icon-btn:hover:not(:disabled){background:var(--surface-hi);border-color:var(--border-hi);color:var(--text)}.icon-btn:disabled{cursor:default;opacity:.35}.action-toast{position:fixed;left:50%;bottom:18px;z-index:40;transform:translate(-50%);background:#11111beb;border:1px solid var(--border-hi);border-radius:var(--radius);color:var(--text);font-size:12px;padding:8px 12px;box-shadow:0 10px 30px #00000052}.dot{display:inline-block;width:6px;height:6px;border-radius:50%;flex-shrink:0}.dot-green{background:var(--green);box-shadow:0 0 6px var(--green)}.dot-red{background:var(--red)}.dot-dim{background:var(--text-dim)}.mono{font-family:var(--fm);font-size:12px}.vol-slider{position:relative;height:36px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.vol-fill{position:absolute;top:0;left:0;bottom:0;background:var(--accent-lo);border-right:1px solid var(--accent);pointer-events:none;transition:width .05s}.vol-slider input[type=range]{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer;margin:0}.param-list{display:flex;flex-direction:column;gap:10px}.param-row{display:flex;align-items:center;gap:12px}.param-label{flex:0 0 140px;font-size:11px;color:var(--text-muted);letter-spacing:.05em;text-transform:capitalize}.param-control{flex:1;display:flex;align-items:center;gap:10px}.param-value{font-family:var(--fm);font-size:11px;color:var(--accent);flex:0 0 40px;text-align:right}.slider-track{flex:1;position:relative;height:24px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.slider-fill{position:absolute;top:0;left:0;bottom:0;background:var(--accent-lo);border-right:1px solid var(--accent);pointer-events:none}.slider-track input[type=range]{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer;margin:0}.dsp-response-section{padding-bottom:10px}.dsp-response{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.dsp-response svg{display:block;width:100%;height:150px}.dsp-grid{stroke:#cdd6f41f;stroke-width:.35;vector-effect:non-scaling-stroke}.dsp-grid--freq{stroke:#cdd6f414}.dsp-axis{stroke:#cdd6f447;stroke-width:.55;vector-effect:non-scaling-stroke}.dsp-response-fill{fill:#89b4fa1f;stroke:none}.dsp-response-line{fill:none;stroke:var(--accent);stroke-width:1.6;stroke-linejoin:round;stroke-linecap:round;vector-effect:non-scaling-stroke}.dsp-filter-dot{fill:var(--peach);stroke:var(--base);stroke-width:.7;vector-effect:non-scaling-stroke}.dsp-response-labels{display:flex;justify-content:space-between;border-top:1px solid var(--border);color:var(--text-muted);font-size:10px;padding:5px 8px 6px}.dsp-response-legend{display:flex;align-items:center;gap:14px;color:var(--text-muted);font-size:11px;margin-top:8px}.dsp-response-legend span{display:inline-flex;align-items:center;gap:6px}.legend-line{display:inline-block;width:18px;height:2px;border-radius:2px;background:var(--accent)}.legend-dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--peach)}.select{width:100%;background:var(--surface);border:1px solid var(--border-hi);border-radius:var(--radius);color:var(--text);font-family:var(--ff);font-size:13px;padding:8px 28px 8px 12px;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23a6adc8'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.select--sm{width:auto;font-size:11px;padding:4px 24px 4px 8px}.select:focus{outline:1px solid var(--accent)}.meta-row{display:flex;justify-content:space-between;padding:3px 0;border-bottom:1px solid var(--border);font-size:11px}.meta-key{color:var(--text-muted)}.meta-val{color:var(--text)}.now-playing{display:flex;align-items:center;gap:12px;padding:4px 0 12px}.now-playing--empty .track-title{color:var(--text-muted)}.now-cover{display:flex;align-items:center;justify-content:center;width:64px;height:64px;background:var(--overlay);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-dim);flex:0 0 64px;font-family:var(--fm);font-size:12px;overflow:hidden;position:relative}.now-cover img{width:100%;height:100%;object-fit:cover;display:block}.now-text{min-width:0}.track-title{font-size:16px;font-weight:600;margin-bottom:4px;line-height:1.3}.track-sub{font-size:12px;color:var(--text-muted)}.progress-bar{height:3px;background:var(--surface-hi);border-radius:2px;cursor:pointer;margin-bottom:6px;position:relative;overflow:visible}.progress-fill{height:100%;background:var(--accent);border-radius:2px;pointer-events:none;transition:width .5s linear}.progress-times{display:flex;justify-content:space-between;font-family:var(--fm);font-size:11px;color:var(--text-muted)}.transport-panel{display:flex;flex-direction:column;gap:10px}.transport-main{display:flex;align-items:center;gap:12px}.transport{flex:1;min-width:0;display:flex;align-items:center;justify-content:flex-start;gap:8px;margin-bottom:0}.transport-btn{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);cursor:pointer;font-size:18px;width:48px;height:42px;transition:border-color .1s,background .1s}.transport-btn:hover{border-color:var(--border-hi);background:var(--surface-hi)}.transport-btn--play{font-size:22px;width:72px;height:48px;border-color:var(--border-hi)}.transport-btn--play.transport-btn--active{background:var(--accent-lo);border-color:var(--accent);color:var(--accent)}.transport-btn--stop{font-size:14px;color:var(--text-muted)}.transport-btn--queue{color:var(--text-muted);font-family:var(--fm);font-size:12px;width:auto;min-width:54px;gap:6px;white-space:nowrap}.queue-count{color:var(--accent);font-size:11px}.transport-btn--active{background:var(--surface-hi);border-color:var(--border-hi);color:var(--chrome)}.transport-volume{flex:0 0 150px;display:flex;align-items:center;gap:8px}.transport-volume-label{flex:0 0 28px;color:var(--text-muted);text-align:right}.vol-slider--sm{flex:1;height:28px;min-width:92px}.transport-toggles{display:flex;gap:6px;justify-content:flex-start}.toggle-btn{background:none;border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);cursor:pointer;font-family:var(--fm);font-size:14px;width:32px;height:28px;letter-spacing:.1em;transition:all .1s}.toggle-btn--on{background:var(--accent-lo);border-color:var(--accent);color:var(--accent)}.section-toggle{background:none;border:none;border-bottom:1px solid var(--border);color:var(--text-muted);cursor:pointer;font-family:var(--ff);font-size:10px;font-weight:600;letter-spacing:.2em;padding:6px 0;width:100%;text-align:left;transition:color .1s}.section-toggle:hover{color:var(--text)}.playlist-list{display:flex;flex-direction:column;margin-top:8px;gap:2px}.playlist-item{background:none;border:none;border-left:2px solid var(--border);color:var(--text);cursor:pointer;font-family:var(--ff);font-size:13px;padding:6px 12px;text-align:left;transition:border-color .1s,background .1s}.playlist-item:hover{border-left-color:var(--accent);background:var(--accent-lo)}.track-thumb,.search-thumb{display:inline-flex;align-items:center;justify-content:center;background:var(--overlay);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-dim);font-family:var(--fm);font-size:8px;overflow:hidden}.track-thumb img,.search-thumb img{width:100%;height:100%;object-fit:cover;display:block}.queue-shell{position:fixed;top:0;right:0;bottom:0;left:0;z-index:30;pointer-events:none}.queue-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#11111b85;border:none;cursor:pointer;pointer-events:auto}.queue-drawer{position:absolute;left:50%;bottom:0;width:min(720px,100%);max-height:min(78vh,680px);transform:translate(-50%);display:flex;flex-direction:column;background:var(--bg);border:1px solid var(--border-hi);border-bottom:none;border-radius:var(--radius) var(--radius) 0 0;box-shadow:0 -20px 44px #00000057;padding:14px 16px 18px;pointer-events:auto}.queue-heading{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}.queue-heading-actions{display:flex;align-items:center;gap:8px}.queue-subtitle{color:var(--text-dim);font-size:10px;margin-top:3px}.queue-close{width:30px;height:30px;font-size:18px}.queue-list{display:flex;flex-direction:column;gap:3px;overflow-y:auto;padding-right:2px}.queue-item{display:flex;align-items:center;gap:8px;padding:7px 8px;border-left:2px solid transparent;border-radius:var(--radius);transition:background .1s}.queue-item:hover{background:var(--surface-hi)}.queue-item--active{border-left-color:var(--accent);background:var(--accent-lo)}.queue-thumb{width:34px;height:34px;flex:0 0 34px}.queue-info{flex:1;min-width:0}.queue-title{display:block;font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.queue-artist{font-size:11px;color:var(--text-muted)}.queue-dur{color:var(--text-muted);flex-shrink:0}.queue-play{width:28px;height:28px;font-size:10px;flex:0 0 28px}.queue-remove{width:28px;height:28px;color:var(--text-dim);font-size:16px;flex:0 0 28px}.queue-remove:hover{color:var(--red);border-color:var(--red)}.danger-btn{background:none;border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);cursor:pointer;font-family:var(--ff);font-size:11px;margin-top:10px;padding:6px 12px;transition:border-color .1s,color .1s}.danger-btn:hover{border-color:var(--red);color:var(--red)}.danger-btn--inline{margin-top:0;padding:4px 10px}.browser-search-row{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid var(--border)}.browser-input{flex:1;background:var(--surface);border:1px solid var(--border-hi);border-radius:var(--radius);color:var(--text);font-family:var(--fm);font-size:12px;padding:6px 10px;outline:none}.browser-input:focus{border-color:var(--accent)}.browser-icon-btn{background:none;border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);cursor:pointer;font-size:14px;padding:4px 8px;transition:color .1s,border-color .1s;flex-shrink:0}.browser-icon-btn:hover{color:var(--text);border-color:var(--border-hi)}.browser-nav{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid var(--border)}.browser-mode-row{display:flex;gap:6px;padding:8px 0 6px;border-bottom:1px solid var(--border)}.browser-mode-btn{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);cursor:pointer;flex:1;font-family:var(--ff);font-size:10px;font-weight:600;letter-spacing:.12em;padding:7px 10px;text-transform:uppercase;transition:background .1s,border-color .1s,color .1s}.browser-mode-btn:hover{color:var(--text);border-color:var(--border-hi)}.browser-mode-btn--active{background:var(--accent-lo);border-color:var(--accent);color:var(--accent)}.browser-mode-btn--search{flex:0 0 92px}.browser-back-btn{width:30px;height:28px;font-size:14px;flex-shrink:0}.browser-back-btn:hover:not(:disabled){color:var(--text);border-color:var(--border-hi)}.browser-back-btn:disabled{opacity:.25;cursor:default}.browser-crumbs{flex:1;display:flex;align-items:center;min-width:0;font-size:10px;color:var(--text-muted);overflow:hidden;white-space:nowrap}.browser-crumb{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.browser-crumb:last-child{color:var(--text)}.browser-crumb-sep{color:var(--text-dim);margin:0 5px}.browser-add-all-btn{font-family:var(--fm);font-size:10px;height:28px;padding:0 9px;white-space:nowrap;flex-shrink:0}.browser-add-all-btn:hover{color:var(--accent);border-color:var(--accent)}.browser-list{min-height:920px;max-height:920px;overflow-y:auto}.browser-list::-webkit-scrollbar{width:4px}.browser-list::-webkit-scrollbar-track{background:transparent}.browser-list::-webkit-scrollbar-thumb{background:var(--border-hi);border-radius:2px}.browser-msg{padding:16px 0;font-size:12px;color:var(--text-muted);text-align:center}.browser-row{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid var(--border)}.browser-row--search{padding:7px 0}.browser-row--dir{cursor:pointer}.browser-row--dir:hover .browser-name{color:var(--accent)}.browser-row--dir:hover{background:var(--surface-hi)}.browser-type{flex:0 0 28px;font-size:8px;color:var(--text-dim);letter-spacing:.05em}.browser-name{flex:1;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.browser-name-col{flex:1;display:flex;flex-direction:column;min-width:0}.browser-sub{font-size:10px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.browser-arrow{color:var(--text-muted);font-size:14px;flex-shrink:0}.browser-add-btn{font-size:13px;font-weight:600;width:28px;height:26px;flex-shrink:0}.browser-add-btn:hover{color:var(--accent);border-color:var(--accent)}.search-thumb{width:36px;height:36px;flex:0 0 36px}.cover-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(118px,1fr));gap:12px;padding:12px 0}.cover-card{min-width:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);cursor:pointer;font-family:var(--ff);overflow:hidden;text-align:left;transition:background .1s,border-color .1s,transform .1s}.cover-card:hover{background:var(--surface-hi);border-color:var(--accent);transform:translateY(-1px)}.cover-art{display:flex;align-items:center;justify-content:center;aspect-ratio:1;background:var(--overlay);border-bottom:1px solid var(--border);color:var(--text-dim);font-family:var(--fm);font-size:20px;overflow:hidden}.cover-art img{width:100%;height:100%;object-fit:cover;display:block}.cover-title{display:block;min-height:36px;padding:8px;font-size:12px;line-height:1.25;overflow:hidden}@keyframes vinyl-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.snap-now{display:flex;flex-direction:column;align-items:center;gap:0;padding:4px 0 0}.vinyl-scene{position:relative;width:min(100%,520px);aspect-ratio:1;filter:drop-shadow(0 18px 42px rgba(0,0,0,.75))}.vinyl-wrap{width:100%;aspect-ratio:1}.vinyl-svg{width:100%;height:100%;display:block}.vinyl-spinning{animation:vinyl-spin 1.8s linear infinite}.vinyl-arm{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none}.snap-info{text-align:center;padding:18px 12px 10px;width:100%}.snap-info .snap-title{font-size:18px}.snap-info .snap-artist{margin-top:5px}.snap-info .snap-album,.snap-info .snap-extra{margin-top:3px}.snap-cava{position:relative;width:min(100%,520px);height:52px;margin-top:6px}.snap-cava .cava-overlay{height:100%;padding:0 6px 6px}.group-vol{display:flex;align-items:center;gap:10px;padding:8px 12px;border-bottom:1px solid var(--border);background:var(--surface)}.group-vol-label{flex:0 0 28px;font-size:8px;color:var(--text-dim);letter-spacing:.05em}.snap-art{position:relative;display:flex;align-items:center;justify-content:center;width:100%;aspect-ratio:1;background:var(--overlay);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-dim);flex:none;font-family:var(--fm);font-size:34px;overflow:hidden}.snap-art img{width:100%;height:100%;object-fit:cover;display:block}.cava-overlay{position:absolute;left:0;right:0;bottom:0;display:flex;align-items:flex-end;gap:2px;pointer-events:none;background:transparent}.cava-overlay--cover{height:56%;padding:0 7px 7px}.cava-overlay--snapcast{height:50%;padding:0 10px 10px}.cava-overlay span{flex:1;min-width:2px;height:var(--bar-height);background:var(--accent-lo, rgba(205, 214, 244, .18));border-radius:2px 2px 0 0;transform-origin:bottom;will-change:height;animation:snap-cava-pulse 1.2s ease-in-out infinite alternate;animation-delay:var(--bar-delay)}.cava-overlay--live span{animation:none;transition:height .07s ease-out}@keyframes snap-cava-pulse{0%{opacity:.12;transform:scaleY(.35)}to{opacity:.34;transform:scaleY(1)}}.snap-meta{position:absolute;left:0;right:0;top:0;min-width:0;max-height:50%;padding:12px;background:linear-gradient(to bottom,#11111bad,#11111b47,#11111b00);pointer-events:none;z-index:1}.snap-title{font-size:18px;font-weight:600;line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.snap-artist{color:var(--text);font-size:14px;margin-top:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.snap-album,.snap-extra,.snap-source{color:var(--text-muted);font-size:12px;margin-top:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.section-header .snap-source{color:var(--text-dim);font-size:10px;margin-top:4px}.snap-error{color:var(--red);font-size:11px;margin-top:6px}.recognize-btn{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);cursor:pointer;font-family:var(--ff);font-size:10px;font-weight:600;letter-spacing:.12em;padding:5px 9px;text-transform:uppercase;transition:border-color .1s,color .1s,background .1s}.recognize-btn:hover:not(:disabled){background:var(--accent-lo);border-color:var(--accent);color:var(--accent)}.recognize-btn:disabled{cursor:default;opacity:.55}.stream-list{display:flex;flex-direction:column;gap:8px}.stream-row{display:flex;align-items:center;gap:10px;font-size:12px}.stream-id{flex:1;color:var(--text)}.stream-status,.stream-name{font-size:11px;color:var(--text-muted)}.group-section{margin-bottom:16px;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.group-header{display:flex;align-items:center;justify-content:space-between;background:var(--surface);padding:8px 12px;border-bottom:1px solid var(--border)}.group-name{font-size:10px;font-weight:600;letter-spacing:.2em;color:var(--text-muted)}.group-controls{display:flex;align-items:center;gap:8px}.client-row{padding:10px 12px;border-bottom:1px solid var(--border);transition:background .1s}.client-row:last-child{border-bottom:none}.client-row--offline{opacity:.45}.client-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.client-name-block{display:flex;align-items:center;gap:8px}.client-name{font-size:13px;font-weight:500}.client-host{font-size:10px;color:var(--text-muted)}.client-actions{display:flex;align-items:center;gap:8px}.client-stream{font-size:10px;color:var(--text-muted);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:2px 6px}.client-vol-row{display:flex;align-items:center;gap:10px}.mute-btn{background:none;border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;font-size:13px;padding:3px 8px;transition:border-color .1s}.mute-btn--muted{border-color:var(--accent);background:var(--accent-lo)}.mute-btn:hover{border-color:var(--border-hi)}.delete-btn{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:12px;padding:2px 6px;border-radius:var(--radius);transition:color .1s}.delete-btn:hover{color:var(--red)}@media (max-width: 560px){.app-header,.panel-section{padding-left:14px;padding-right:14px}.transport-main{flex-wrap:wrap}.transport{justify-content:center;overflow-x:auto;padding-bottom:2px}.transport-btn{width:42px;height:40px}.transport-btn--play{width:64px;height:48px}.transport-btn--queue{min-width:48px}.transport-volume{flex:1 0 100%}.browser-mode-row{flex-wrap:wrap}.browser-mode-btn,.browser-mode-btn--search{flex:1 1 calc(50% - 6px)}.queue-drawer{max-height:84vh;padding-left:12px;padding-right:12px}.queue-dur{display:none}.track-row .browser-add-btn{opacity:1}}.album-detail{position:relative}.album-header{display:flex;align-items:center;gap:8px;padding:4px 0;margin-bottom:8px}.album-back-btn{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:13px;padding:4px 8px;border-radius:var(--radius);transition:color .1s,background .1s}.album-back-btn:hover{color:var(--text);background:var(--surface-hi)}.album-type{font-size:11px;color:var(--text-dim);margin-left:auto}.album-play-menu{display:flex;gap:6px}.album-play-btn{display:inline-flex;align-items:center;gap:4px;background:var(--accent);border:1px solid var(--accent);border-radius:var(--radius);color:var(--accent-text);cursor:pointer;font-size:12px;font-weight:700;padding:4px 10px;transition:background .15s,transform .1s}.album-play-btn:hover{transform:scale(1.05)}.album-play-btn:disabled{cursor:default;opacity:.65;transform:none}.album-add-btn{display:inline-flex;align-items:center;gap:4px;background:none;border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);cursor:pointer;font-size:12px;font-weight:600;padding:4px 10px;transition:color .15s,border-color .15s,transform .1s}.album-add-btn:hover{color:var(--accent);border-color:var(--accent);transform:scale(1.05)}.album-add-btn:disabled{cursor:default;opacity:.55;transform:none}.browser-play-btn{font-size:10px;width:26px;height:26px;flex-shrink:0;color:var(--text-muted)}.browser-play-btn:hover{color:var(--accent);border-color:var(--accent)}.album-info{display:flex;align-items:center;gap:16px;padding:8px 0 12px}.album-cover{width:64px;height:64px;min-width:64px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;display:flex;align-items:center;justify-content:center;color:var(--text-dim);font-weight:700;font-size:11px;flex-shrink:0}.album-cover img{width:100%;height:100%;object-fit:cover}.album-meta{flex:1;min-width:0}.album-name{font-weight:700;font-size:14px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.album-count{font-size:12px;color:var(--text-dim);margin-top:2px}.track-list{max-height:400px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.disc-heading{position:sticky;top:0;z-index:1;background:var(--bg);border-bottom:1px solid var(--border);color:var(--accent);font-size:10px;padding:8px 8px 5px;text-transform:uppercase}.track-row{display:grid;grid-template-columns:32px 1fr 48px 32px;align-items:center;gap:8px;padding:4px 8px;border-radius:var(--radius);transition:background .1s}.track-row:hover{background:var(--surface-hi)}.track-num{font-size:11px;color:var(--text-dim)}.track-name{font-size:13px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.track-duration{font-size:12px;color:var(--text-dim);text-align:right}.track-row .browser-add-btn{justify-self:end;opacity:0;transition:opacity .15s}.track-row:hover .browser-add-btn{opacity:1}.settings-service-list{display:flex;flex-direction:column;gap:12px}.settings-service-row{display:flex;align-items:center;gap:10px}.settings-service-label{font-size:13px;color:var(--text)}.settings-service-desc{font-size:11px;color:var(--text-muted);margin-top:1px}.settings-service-badge{font-family:var(--fm);font-size:10px;padding:2px 8px;border-radius:var(--radius);letter-spacing:.06em;white-space:nowrap}.settings-service-badge--ok{color:var(--green);background:var(--green-lo)}.settings-service-badge--error{color:var(--red);background:#f38ba829}.settings-service-badge--checking{color:var(--text-dim);background:var(--surface)}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 0;border-bottom:1px solid var(--border)}.settings-row:last-child{border-bottom:none}.settings-row-left{flex:1;min-width:0}.settings-row-label{font-size:13px;color:var(--text)}.settings-row-hint{font-size:11px;color:var(--text-muted);margin-top:2px}.settings-action-btn{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);cursor:pointer;font-family:var(--ff);font-size:11px;font-weight:600;letter-spacing:.1em;padding:6px 14px;text-transform:uppercase;transition:border-color .1s,color .1s,background .1s;white-space:nowrap}.settings-action-btn:hover:not(:disabled){background:var(--accent-lo);border-color:var(--accent);color:var(--accent)}.settings-action-btn:disabled{cursor:default;opacity:.55}.settings-feedback{font-size:11px;font-family:var(--fm);margin-top:8px}.settings-feedback--ok{color:var(--green)}.settings-feedback--error{color:var(--red)}.settings-feedback--warn{color:var(--yellow)}.settings-feedback--warn code{font-family:var(--fm);background:var(--surface);padding:1px 5px;border-radius:var(--radius)}.settings-input{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--fm);font-size:12px;min-width:0;padding:5px 8px;width:260px;transition:border-color .15s}.settings-input:focus{border-color:var(--accent);outline:none}.settings-input--sm{width:70px}body{background:var(--bg)}.app{width:min(100%,980px);max-width:980px;min-height:100%;height:auto;padding:0 16px}.app-header{position:sticky;top:0;z-index:20;gap:22px;padding:16px 0 12px;border-bottom:1px solid color-mix(in srgb,var(--chrome) 18%,transparent);background:var(--bg);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:0 1px #b4b4ba0f inset}.app-title{min-width:132px;letter-spacing:.08em}.app-title-main{color:var(--text);font-size:20px}.app-title-sub{color:var(--accent);font-size:9px}.tab-nav{flex:1;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:5px;max-width:560px}.tab-btn{border:1px solid transparent;border-radius:var(--radius);color:var(--text-muted);font-size:11px;font-family:var(--ff);font-weight:600;letter-spacing:.18em;padding:9px 10px;text-transform:uppercase}.tab-btn:hover{background:#ffffff08;border-color:var(--border-hi);color:var(--chrome)}.tab-btn--active{background:var(--accent-lo);border-color:color-mix(in srgb,var(--accent) 60%,transparent);color:var(--accent-hi)}.app-main{padding:16px 0 48px}.panel{display:flex;flex-direction:column;gap:12px}.panel-section{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);padding:18px;box-shadow:0 1px #b4b4ba0a inset}.panel-section--meta{padding:12px 18px}.panel-error,.panel-empty{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-soft)}.section-header{margin-bottom:16px}.section-label{font-family:var(--ff);font-weight:600;color:var(--text-dim);font-size:11px;letter-spacing:.22em;text-transform:uppercase}.section-value{color:var(--text-muted)}.icon-btn,.browser-icon-btn,.browser-back-btn,.settings-action-btn,.recognize-btn,.danger-btn,.mute-btn,.toggle-btn,.transport-btn{min-height:32px}.icon-btn,.browser-icon-btn,.browser-back-btn,.settings-action-btn,.recognize-btn,.danger-btn,.mute-btn,.delete-btn,.toggle-btn,.transport-btn,.playlist-item,.cover-card,.browser-mode-btn,.album-back-btn,.album-play-btn,.album-add-btn{-webkit-tap-highlight-color:transparent}.icon-btn:focus-visible,.tab-btn:focus-visible,.select:focus-visible,.settings-input:focus-visible,.browser-input:focus-visible,.transport-btn:focus-visible,.toggle-btn:focus-visible,.browser-mode-btn:focus-visible,.settings-action-btn:focus-visible{outline:2px solid color-mix(in srgb,var(--accent) 75%,transparent);outline-offset:2px}.vol-slider,.slider-track,.browser-input,.settings-input,.select{background:var(--surface-soft);border-color:var(--border)}.vol-slider{height:38px}.vol-fill,.slider-fill,.progress-fill{background:linear-gradient(90deg,#3a3a42,#606068,#808088)}.now-playing{gap:16px;padding:2px 0 16px}.now-cover{width:92px;height:92px;flex-basis:92px;border-color:var(--border-hi);box-shadow:var(--shadow)}.now-cover--empty{box-shadow:none}.track-title{color:var(--text);font-size:22px;line-height:1.15;margin-bottom:8px}.track-sub{color:var(--text-muted);line-height:1.45}.progress-bar{height:8px;background:color-mix(in srgb,var(--overlay) 78%,var(--bg));border:1px solid var(--border);border-radius:999px;margin-bottom:8px}.progress-fill{border-radius:999px}.transport-panel{gap:14px}.transport{gap:10px}.transport-btn{background:linear-gradient(180deg,#525258,#3a3a40 55%,#2e2e34);border-color:#606068;border-radius:var(--radius);color:#d0d0d8;font-size:17px;box-shadow:0 1px #ffffff1f inset,0 -1px #0006 inset,0 2px 5px #00000080}.transport-btn:hover:not(:disabled){transform:translateY(-1px);background:linear-gradient(180deg,#686870,#4c4c54 55%,#3c3c44);border-color:#84848e;color:var(--text);box-shadow:0 1px #ffffff2e inset,0 -1px #00000059 inset,0 3px 7px #00000080}.transport-btn--play{width:76px;background:linear-gradient(180deg,#585862,#3e3e46 55%,#32323a);border-color:color-mix(in srgb,var(--accent) 65%,#606068);color:var(--accent-hi);box-shadow:0 0 8px #dd15331f,0 1px #ffffff1f inset,0 2px 5px #00000080}.transport-btn--play.transport-btn--active{background:linear-gradient(180deg,#dd153347,#dd15331f);border-color:color-mix(in srgb,var(--accent) 80%,transparent);box-shadow:0 0 16px #dd15334d,0 1px #ffffff0f inset}.transport-volume{flex-basis:190px}.toggle-btn{width:38px;background:var(--surface-soft)}.toggle-btn--on,.browser-mode-btn--active{box-shadow:0 0 0 1px #b4b4ba38 inset}.transport-btn--active:not(.transport-btn--play){background:linear-gradient(180deg,#484852,#323238 55%,#28282e);border-color:#787880;color:var(--chrome);box-shadow:0 0 0 1px #b4b4ba2e inset,0 1px 3px #00000080}.section-toggle{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-soft);color:var(--text-muted);padding:10px 12px}.playlist-list,.browser{margin-top:10px}.browser-mode-row{gap:8px;padding:0 0 10px}.browser-mode-btn{background:var(--surface-soft);padding:9px 10px;letter-spacing:.08em}.browser-search-row,.browser-nav{padding:10px 0}.browser-input{min-height:36px}.browser-list{min-height:min(66vh,720px);max-height:min(66vh,720px);padding-right:4px}.browser-row{min-height:42px;padding:7px 8px;border-radius:var(--radius)}.browser-row:hover{background:#ffffff09}.cover-grid{grid-template-columns:repeat(auto-fill,minmax(142px,1fr));gap:14px}.cover-card{background:var(--surface-soft)}.cover-title{min-height:48px;padding:10px}.queue-backdrop{background:#05070aad;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.queue-drawer{width:min(820px,calc(100% - 24px));background:color-mix(in srgb,var(--surface-soft) 80%,var(--overlay));border-color:var(--border-hi);border-radius:10px 10px 0 0}.queue-item{min-height:48px}.dsp-response{background:color-mix(in srgb,var(--overlay) 78%,var(--bg))}.dsp-response svg{height:190px}.dsp-response-fill{fill:color-mix(in srgb,var(--accent) 12%,transparent)}.group-section{background:var(--surface-soft);border-color:var(--border)}.group-header,.group-vol{background:color-mix(in srgb,var(--surface-hi) 78%,transparent)}.client-row:hover{background:#ffffff06}.stream-row,.settings-service-row,.settings-row,.meta-row{min-height:36px}.stream-row,.settings-service-row{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-soft);padding:9px 10px}.snap-art{border-color:var(--border-hi);box-shadow:var(--shadow)}.snap-meta{background:linear-gradient(to bottom,rgba(5,7,10,.78),rgba(5,7,10,.34),transparent)}.snap-title{font-size:20px}.album-header{padding:8px 0}.album-play-btn{color:var(--accent-text)}.album-play-btn:hover{transform:translateY(-1px)}.track-list{max-height:min(54vh,520px)}.disc-heading{background:color-mix(in srgb,var(--surface-soft) 80%,var(--overlay))}.track-row{min-height:38px}.settings-input{min-height:34px}@media (min-width: 760px){.app-main>.panel{display:grid;grid-template-columns:minmax(0,1fr)}.panel-section:first-child .now-playing{align-items:flex-start}.panel-section:first-child .now-cover{width:124px;height:124px;flex-basis:124px}}@media (max-width: 640px){.app{padding:0 10px}.app-header{align-items:stretch;flex-direction:column;gap:12px;padding-top:14px}.app-title{min-width:0}.tab-nav{max-width:none}.tab-btn{font-size:11px;padding:9px 6px}.app-main{padding-top:10px}.panel{gap:10px}.panel-section{padding:14px 12px}.now-cover{width:76px;height:76px;flex-basis:76px}.track-title{font-size:18px}.transport-volume{flex-basis:100%}.browser-list{min-height:560px;max-height:560px}.cover-grid{grid-template-columns:repeat(auto-fill,minmax(118px,1fr))}.settings-row{align-items:stretch;flex-direction:column}.settings-input,.settings-input--sm{width:100%}}html,body,#root{height:100%;overflow:hidden}.app{display:flex;flex-direction:column;height:100%;width:100%;max-width:100%;min-height:0;padding:0;margin:0 auto}.app-header{padding-left:24px;padding-right:24px;flex-shrink:0}.app-body{display:flex;flex:1;min-height:0;overflow:hidden}.player-sidebar{width:300px;flex-shrink:0;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;border-right:1px solid var(--border);padding:20px}.player-sidebar::-webkit-scrollbar{width:4px}.player-sidebar::-webkit-scrollbar-track{background:transparent}.player-sidebar::-webkit-scrollbar-thumb{background:var(--border-hi);border-radius:2px}@media (min-width: 1100px){.player-sidebar{width:340px}}@media (min-width: 1400px){.player-sidebar{width:380px}}.app-main{flex:1;overflow-y:auto;overflow-x:hidden;padding:16px 20px 48px;min-width:0}.sidebar-player{display:flex;flex-direction:column;gap:14px;flex:1}.sidebar-conn-error{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-muted)}.sidebar-art{width:100%;aspect-ratio:1;background:var(--overlay);border:1px solid var(--border-hi);border-radius:calc(var(--radius) + 4px);overflow:hidden;position:relative;box-shadow:var(--shadow);flex-shrink:0}.sidebar-art img{width:100%;height:100%;object-fit:cover;display:block}.sidebar-art--empty{display:flex;align-items:center;justify-content:center;color:var(--text-dim);font-size:40px}.sidebar-track{min-width:0}.sidebar-title{font-size:17px;font-weight:600;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text)}.sidebar-sub{font-size:12px;color:var(--text-muted);margin-top:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-progress{display:flex;flex-direction:column;gap:6px}.sidebar-controls{display:flex;flex-direction:column;gap:10px}.sidebar-volume{display:flex;align-items:center;gap:8px}.sidebar-volume .vol-slider--sm{flex:1}.sidebar-clients{margin-top:20px;padding-top:16px;border-top:1px solid var(--border)}.sidebar-client-group+.sidebar-client-group{margin-top:6px}.sidebar-client-row{display:flex;align-items:center;gap:6px;padding:4px 0}.sidebar-client-name{font-size:11px;color:var(--text-muted);width:72px;flex-shrink:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mute-btn--sm{font-size:11px;min-height:24px;padding:2px 5px}@media (max-width: 759px){html,body,#root{height:auto;overflow:visible}.app{height:auto;min-height:100dvh}.app-body{flex-direction:column;overflow:visible;min-height:0}.player-sidebar{width:100%;border-right:none;border-bottom:1px solid var(--border);padding:14px;overflow:visible}.sidebar-art{max-width:260px;margin:0 auto}.app-main{overflow-y:visible;padding:10px 14px 48px}}.vol-slider,.vol-slider--sm,.slider-track{background:transparent;border:none;border-radius:0;overflow:visible;display:flex;align-items:center}.vol-slider{height:44px}.vol-slider--sm{height:38px}.slider-track{height:40px}.vol-slider:before,.vol-slider--sm:before,.slider-track:before{content:"";position:absolute;left:0;right:0;height:3px;top:50%;transform:translateY(-50%);background:var(--overlay);box-shadow:inset 0 1px 2px #000000b3,0 1px #ffffff0a;border-radius:1px;pointer-events:none}.vol-slider:after,.vol-slider--sm:after,.slider-track:after{content:"";position:absolute;left:50%;top:calc(50% - 9px);width:1px;height:18px;background:var(--accent);transform:translate(-50%);opacity:.38;pointer-events:none;z-index:1}.vol-fill,.slider-fill{position:absolute;left:0;top:50%;height:3px;transform:translateY(-50%);background:linear-gradient(90deg,#dd153338,#dd153394);border-right:none;pointer-events:none;transition:width .05s;border-radius:1px 0 0 1px;z-index:0}.vol-slider input[type=range],.vol-slider--sm input[type=range],.slider-track input[type=range]{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;opacity:1;cursor:pointer;margin:0;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;z-index:2}.vol-slider input[type=range]::-webkit-slider-runnable-track,.vol-slider--sm input[type=range]::-webkit-slider-runnable-track,.slider-track input[type=range]::-webkit-slider-runnable-track{-webkit-appearance:none;background:transparent;height:3px}.vol-slider input[type=range]::-webkit-slider-thumb,.slider-track input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:13px;height:32px;margin-top:-15px;background:linear-gradient(to right,#707078,#b8b8be 16%,#e2e2e6 40%,#f0f0f4,#e0e0e4 60%,#b4b4ba 84%,#707078);border-radius:2px;border:1px solid rgba(0,0,0,.55);box-shadow:0 3px 12px #000000bf,inset 0 1px #ffffff80;cursor:grab}.vol-slider--sm input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:11px;height:26px;margin-top:-12px;background:linear-gradient(to right,#707078,#b8b8be 16%,#e2e2e6 40%,#f0f0f4,#e0e0e4 60%,#b4b4ba 84%,#707078);border-radius:2px;border:1px solid rgba(0,0,0,.55);box-shadow:0 2px 8px #000000b3,inset 0 1px #ffffff73;cursor:grab}.vol-slider input[type=range]:active::-webkit-slider-thumb,.vol-slider--sm input[type=range]:active::-webkit-slider-thumb,.slider-track input[type=range]:active::-webkit-slider-thumb{cursor:grabbing;box-shadow:0 1px 16px #000000e6,inset 0 1px #ffffff80}.vol-slider input[type=range]::-moz-range-track,.vol-slider--sm input[type=range]::-moz-range-track,.slider-track input[type=range]::-moz-range-track{background:transparent;height:3px}.vol-slider input[type=range]::-moz-range-thumb,.slider-track input[type=range]::-moz-range-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:13px;height:32px;background:linear-gradient(to right,#707078,#b8b8be,#f0f0f4,#b4b4ba,#707078);border-radius:2px;border:1px solid rgba(0,0,0,.55);box-shadow:0 3px 12px #000000bf;cursor:grab}.vol-slider--sm input[type=range]::-moz-range-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:11px;height:26px;background:linear-gradient(to right,#707078,#b8b8be,#f0f0f4,#b4b4ba,#707078);border-radius:2px;border:1px solid rgba(0,0,0,.55);cursor:grab}.tab-btn{position:relative;background:linear-gradient(180deg,#222224,#181819);border:1px solid #0d0d0f;border-bottom-color:#080809;border-radius:2px;color:#b4b4ba8c;font-family:var(--ff);font-size:11px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;padding:18px 10px 9px;box-shadow:inset 0 1px #ffffff0b,0 2px 6px #000000b3;transition:color .1s,border-color .1s,background .1s}.tab-btn:before{content:"";position:absolute;top:9px;left:50%;transform:translate(-50%);width:18px;height:4px;border-radius:2px;background:#0a0a0c;box-shadow:inset 0 1px 2px #000000e6;transition:background .15s,box-shadow .15s}.tab-btn:hover{background:linear-gradient(180deg,#272729,#1d1d1f);border-color:#1a1a1c;color:#b4b4bacc}.tab-btn--active{background:linear-gradient(180deg,#1e1e20,#161618);border-color:#0d0d0f;color:var(--chrome)}.tab-btn--active:before{background:var(--accent);box-shadow:0 0 5px var(--accent),0 0 10px #dd153373}.toggle-btn{position:relative;background:linear-gradient(180deg,#222224,#181819);border:1px solid #0d0d0f;border-bottom-color:#080809;border-radius:2px;color:#b4b4ba80;font-family:var(--fm);font-size:12px;width:38px;height:38px;padding-top:14px;box-shadow:inset 0 1px #ffffff0a,0 2px 5px #000000a6;transition:color .1s}.toggle-btn:before{content:"";position:absolute;top:7px;left:50%;transform:translate(-50%);width:14px;height:3.5px;border-radius:2px;background:#0a0a0c;box-shadow:inset 0 1px 2px #000000e6;transition:background .15s,box-shadow .15s}.toggle-btn--on{background:linear-gradient(180deg,#1e1e20,#161618);border-color:#0d0d0f;color:var(--chrome);box-shadow:inset 0 1px #ffffff0a,0 2px 5px #000000a6}.toggle-btn--on:before{background:var(--accent);box-shadow:0 0 5px var(--accent),0 0 9px #dd153366}
