:root{--bg:#172031;--bg-card:#1e2940;--bg-card-hover:#243050;--bg-inset:#142038;--bg-input:#11192a;--ink:#eee9df;--ink-secondary:#c4bfb4;--muted:#7b8da0;--line:#2b3d55;--line-soft:#233350;--gold:#d4a843;--gold-dim:#d4a8431f;--gold-glow:#d4a8432e;--pine:#4d7a5e;--pine-dim:#4d7a5e24;--rock:#b85c4a;--rock-dim:#b85c4a1f;--sky:#5a8ab5;--sky-dim:#5a8ab51f;--radius:10px;--radius-lg:16px;--radius-sm:7px;--shadow:0 12px 40px #080c1480;--shadow-sm:0 2px 10px #080c144d;--font-display:"Outfit", system-ui, sans-serif;--font-body:"Plus Jakarta Sans", system-ui, sans-serif;--ease:cubic-bezier(.16, 1, .3, 1);--ease-bounce:cubic-bezier(.34, 1.56, .64, 1)}*,:before,:after{box-sizing:border-box}html,body{background:var(--bg);min-height:100%;color:var(--ink);font-family:var(--font-body);-webkit-font-smoothing:antialiased;margin:0;font-size:15px;line-height:1.55}button,input,select{font:inherit;color:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.4}.shell{min-height:100vh;padding:36px 24px 80px;position:relative;overflow:hidden}.shell:before{content:"";pointer-events:none;z-index:0;opacity:.035;background-image:repeating-radial-gradient(circle at 30% 20%,#0000 0 38px,#d4a84380 39px,#0000 40px),repeating-radial-gradient(circle at 70% 60%,#0000 0 55px,#4d7a5e66 56px,#0000 57px),repeating-radial-gradient(circle at 50% 80%,#0000 0 72px,#5a8ab54d 73px,#0000 74px);position:fixed;inset:0}.shell:after{content:"";pointer-events:none;z-index:0;background:radial-gradient(#d4a84308,#0000 70%);width:50%;height:50%;position:fixed;bottom:-20%;right:-10%}.topbar{z-index:1;justify-content:space-between;align-items:center;gap:16px;max-width:880px;margin:0 auto 32px;display:flex;position:relative}.brand{align-items:center;gap:14px;min-width:0;display:flex}.brand-icon{background:var(--gold);border-radius:var(--radius-sm);color:var(--bg);width:44px;height:44px;box-shadow:0 0 24px var(--gold-glow);place-items:center;display:grid}.brand h1{font-family:var(--font-display);letter-spacing:-.01em;margin:0;font-size:1.55rem;font-weight:800;line-height:1.1}.brand p{color:var(--muted);margin:3px 0 0;font-size:.82rem;font-weight:500}.topbar-actions{align-items:center;gap:10px;display:flex}.scan-note{color:var(--muted);white-space:nowrap;font-size:.78rem;font-weight:600}.refresh-btn{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);color:var(--ink-secondary);height:40px;transition:all .2s var(--ease);align-items:center;gap:8px;padding:0 16px;font-size:.84rem;font-weight:600;display:inline-flex}.refresh-btn:hover{border-color:var(--gold);color:var(--gold);box-shadow:0 0 14px var(--gold-dim)}.refresh-btn svg{transition:transform .5s var(--ease)}.refresh-btn:hover svg{transform:rotate(120deg)}.content{z-index:1;gap:20px;max-width:880px;margin:0 auto;display:grid;position:relative}.panel{background:var(--bg-card);border:1px solid var(--line-soft);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:26px}.panel-header{justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:20px;display:flex}.panel-title-area{flex-direction:column;gap:2px;display:flex}.panel-title-row{align-items:center;gap:10px;display:flex}.panel-title-row svg{color:var(--gold);flex-shrink:0}.panel-title-row h2{font-family:var(--font-display);letter-spacing:.04em;text-transform:uppercase;margin:0;font-size:1.2rem;font-weight:800}.panel-subtitle{color:var(--muted);margin:0;padding-left:30px;font-size:.8rem;font-weight:500}.status-pill{font-family:var(--font-display);letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;border:1px solid #0000;border-radius:999px;flex:none;align-items:center;gap:5px;min-height:26px;padding:0 11px;font-size:.7rem;font-weight:700;display:inline-flex}.status-pill.good{background:var(--pine-dim);color:var(--pine);border-color:#4d7a5e40}.status-pill.warn{background:var(--gold-dim);color:var(--gold);border-color:#d4a84333}.status-pill.bad{background:var(--rock-dim);color:var(--rock);border-color:#b85c4a33}.sensor-strip{z-index:1;flex-wrap:wrap;gap:8px;max-width:880px;margin:0 auto 20px;display:flex;position:relative}.sensor-chip{background:var(--bg-card);border:1px solid var(--line-soft);border-radius:999px;align-items:center;gap:8px;padding:6px 14px;display:inline-flex}.sensor-chip-label{color:var(--muted);font-size:.74rem;font-weight:600}.sensor-chip-value{color:var(--ink);font-family:var(--font-display);font-size:.88rem;font-weight:700}.device-grid-2col{z-index:1;grid-template-columns:repeat(2,1fr);align-items:start;gap:14px;max-width:880px;margin:0 auto 20px;display:grid;position:relative}.device-card{background:var(--bg-card);border:1px solid var(--line-soft);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:border-color .2s,box-shadow .2s;overflow:hidden}.device-card:hover{border-color:var(--line);box-shadow:var(--shadow)}.card-glance{cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;gap:12px;padding:16px 18px;transition:background .15s;display:flex}.card-glance:hover{background:var(--bg-card-hover)}.card-glance-left{align-items:center;gap:12px;min-width:0;display:flex}.card-glance-icon{color:var(--gold);flex-shrink:0}.card-glance-left h3{font-family:var(--font-display);margin:0;font-size:1rem;font-weight:700;line-height:1.2}.card-glance-sub{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;max-width:180px;margin:1px 0 0;font-size:.76rem;overflow:hidden}.card-glance-right{flex-shrink:0;align-items:center;gap:10px;display:flex}.glance-stat{text-align:center}.glance-value{font-family:var(--font-display);white-space:nowrap;font-size:.95rem;font-weight:700;line-height:1.1;display:block}.glance-mode{text-transform:capitalize;font-size:.82rem}.glance-playing{color:var(--pine)}.glance-label{color:var(--muted);font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;margin-top:2px;font-size:.58rem;font-weight:700;display:block}.glance-divider{background:var(--line);width:1px;height:24px}.glance-transport-btn{background:var(--bg-input);border:1px solid var(--line);border-radius:var(--radius-sm);color:var(--ink-secondary);width:30px;height:30px;transition:all .15s var(--ease);place-items:center;display:grid}.glance-transport-btn:hover{border-color:var(--pine);color:var(--pine)}.expand-chevron{color:var(--muted);transition:transform .2s var(--ease);flex-shrink:0}.expand-chevron.open{transform:rotate(180deg)}.card-expand{animation:slideDown .25s var(--ease);border-top:1px solid var(--line-soft);gap:14px;padding:18px;display:grid}.threshold-row,.eq-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.card-controls-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;display:flex}.card-detail-footer{border-top:1px solid var(--line-soft);justify-content:space-between;align-items:center;padding-top:10px;display:flex}.card-detail-footer .muted-text{color:var(--muted);font-size:.78rem}.discovery-bar{background:var(--bg-card);border:1px solid var(--line-soft);border-radius:var(--radius);z-index:1;max-width:880px;margin:0 auto;position:relative;overflow:hidden}.discovery-bar-toggle{color:var(--muted);text-align:left;background:0 0;border:none;align-items:center;gap:8px;width:100%;padding:14px 18px;font-size:.82rem;font-weight:600;transition:color .15s;display:flex}.discovery-bar-toggle:hover,.discovery-bar-toggle svg:first-child{color:var(--gold)}.controls-section{gap:16px;display:grid}.control-row{gap:7px;display:grid}.control-label{color:var(--muted);font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;font-size:.7rem;font-weight:700}.mode-selector{background:var(--bg-input);border:1px solid var(--line-soft);border-radius:var(--radius);gap:3px;padding:3px;display:flex}.mode-btn{border-radius:var(--radius-sm);color:var(--muted);font-family:var(--font-display);height:38px;transition:all .18s var(--ease);background:0 0;border:none;flex:1;justify-content:center;align-items:center;gap:6px;padding:0 8px;font-size:.84rem;font-weight:600;display:inline-flex}.mode-btn:hover{color:var(--ink-secondary);background:var(--line-soft)}.mode-btn.active{background:var(--gold);color:var(--bg);box-shadow:0 2px 12px var(--gold-glow)}.stepper{grid-template-columns:40px 1fr 40px;align-items:center;gap:6px;display:grid}.stepper-btn{background:var(--bg-input);border:1px solid var(--line);border-radius:var(--radius-sm);color:var(--ink-secondary);width:40px;height:40px;transition:all .15s var(--ease);place-items:center;display:grid}.stepper-btn:hover{border-color:var(--gold);color:var(--gold);box-shadow:0 0 10px var(--gold-dim)}.stepper-btn:active{transform:scale(.9)}.stepper-display{background:var(--bg-input);border:1px solid var(--line-soft);border-radius:var(--radius-sm);font-family:var(--font-display);letter-spacing:-.01em;justify-content:center;align-items:center;height:40px;font-size:1.2rem;font-weight:600;display:flex}.slider-row{gap:10px;display:grid}.slider-header{color:var(--muted);font-family:var(--font-display);text-transform:uppercase;letter-spacing:.06em;justify-content:space-between;align-items:center;font-size:.72rem;font-weight:700;display:flex}.slider-header strong{color:var(--ink);font-family:var(--font-display);text-transform:none;letter-spacing:-.01em;font-size:1rem;font-weight:700}.slider-track{appearance:none;background:var(--line);border:none;border-radius:999px;outline:none;width:100%;height:4px}.slider-track::-webkit-slider-thumb{appearance:none;background:var(--gold);border:2px solid var(--bg-card);box-shadow:0 0 10px var(--gold-glow);cursor:pointer;width:18px;height:18px;transition:transform .15s var(--ease-bounce), box-shadow .15s;border-radius:50%}.slider-track::-webkit-slider-thumb:hover{box-shadow:0 0 18px var(--gold-glow);transform:scale(1.2)}.slider-track::-moz-range-thumb{background:var(--gold);border:2px solid var(--bg-card);box-shadow:0 0 10px var(--gold-glow);cursor:pointer;border-radius:50%;width:14px;height:14px}.toggle-group{flex-wrap:wrap;gap:8px;display:flex}.toggle-btn{background:var(--bg-input);border:1px solid var(--line);border-radius:var(--radius-sm);color:var(--muted);height:36px;transition:all .18s var(--ease);align-items:center;gap:6px;padding:0 14px;font-size:.82rem;font-weight:600;display:inline-flex}.toggle-btn:hover{border-color:var(--gold);color:var(--gold)}.toggle-btn.active{background:var(--gold-dim);border-color:var(--gold);color:var(--gold)}.transport-controls{align-items:center;gap:6px;display:flex}.transport-btn{background:var(--bg-input);border:1px solid var(--line);border-radius:var(--radius-sm);color:var(--ink-secondary);height:36px;transition:all .15s var(--ease);justify-content:center;align-items:center;gap:6px;padding:0 14px;font-size:.82rem;font-weight:600;display:inline-flex}.transport-btn:hover{border-color:var(--pine);color:var(--pine)}.transport-btn.active{background:var(--pine-dim);border-color:var(--pine);color:var(--pine)}.speaker-group{background:var(--bg-card);border:1px solid var(--line-soft);border-left:3px solid var(--sky);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);grid-column:1/-1;transition:border-color .2s,box-shadow .2s;overflow:hidden}.speaker-group:hover{border-color:var(--line);border-left-color:var(--sky);box-shadow:var(--shadow)}.group-header{gap:12px;padding:16px 18px;display:grid}.group-header-top{justify-content:space-between;align-items:center;gap:10px;display:flex}.group-header-left{align-items:center;gap:10px;min-width:0;display:flex}.group-header-left svg{color:var(--sky);flex-shrink:0}.group-header-left h3{font-family:var(--font-display);margin:0;font-size:1rem;font-weight:700}.group-header-left .group-member-names{color:var(--muted);margin:0;font-size:.76rem}.group-volume-row{gap:10px;display:grid}.group-volume-header{font-family:var(--font-display);letter-spacing:.06em;text-transform:uppercase;justify-content:space-between;align-items:center;font-size:.68rem;font-weight:700;display:flex}.group-volume-header span{color:var(--sky)}.group-volume-header strong{color:var(--ink);letter-spacing:-.01em;text-transform:none;font-size:1rem}.group-volume-track{appearance:none;background:var(--line);border:none;border-radius:999px;outline:none;width:100%;height:5px}.group-volume-track::-webkit-slider-thumb{appearance:none;background:var(--sky);border:2px solid var(--bg-card);box-shadow:0 0 10px var(--sky-dim);cursor:pointer;width:20px;height:20px;transition:transform .15s var(--ease-bounce), box-shadow .15s;border-radius:50%}.group-volume-track::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 0 18px #5a8ab54d}.group-volume-track::-moz-range-thumb{background:var(--sky);border:2px solid var(--bg-card);box-shadow:0 0 10px var(--sky-dim);cursor:pointer;border-radius:50%;width:16px;height:16px}.group-members-grid{background:var(--line-soft);gap:1px;display:grid}.group-members-grid>.device-card{box-shadow:none;border:none;border-radius:0}.group-members-grid>.device-card:hover{box-shadow:none}.group-footer{border-top:1px solid var(--line-soft);padding:12px 18px}.group-section{background:var(--bg-inset);border:1px solid var(--line-soft);border-radius:var(--radius);padding:12px}.group-section-label{color:var(--muted);font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;margin-bottom:8px;font-size:.65rem;font-weight:700}.group-chips{flex-wrap:wrap;gap:6px;display:flex}.group-chip{background:var(--bg-input);border:1px solid var(--line);color:var(--ink-secondary);height:32px;transition:all .15s var(--ease);border-radius:999px;align-items:center;gap:6px;padding:0 12px;font-size:.78rem;font-weight:600;display:inline-flex}.group-chip.joinable{cursor:pointer}.group-chip.joinable:hover{border-color:var(--sky);color:var(--sky);background:var(--sky-dim)}.group-chip.member{background:var(--sky-dim);color:var(--sky);border-color:#5a8ab540}.group-chip.self{background:var(--gold-dim);color:var(--gold);border-color:#d4a84340}.group-chip-x{color:inherit;opacity:.6;background:0 0;border:none;align-items:center;margin:0 -4px 0 0;padding:0;transition:opacity .15s;display:inline-flex}.group-chip-x:hover{opacity:1}.group-empty{color:var(--muted);font-size:.78rem;font-style:italic}.sensor-chip-edit{color:var(--muted);cursor:pointer;font:inherit;background:0 0;border:none;align-items:center;gap:4px;margin:0;padding:0;font-size:.74rem;font-weight:600;display:inline-flex}.sensor-chip-pencil{color:var(--muted);opacity:0;transition:opacity .15s}.sensor-chip:hover .sensor-chip-pencil{opacity:.6}.sensor-chip-edit:hover .sensor-chip-pencil{opacity:1;color:var(--gold)}.editable-name{border:none;border-bottom:1px solid var(--gold);color:var(--ink);font:inherit;background:0 0;outline:none;min-width:40px;margin:0;padding:0 0 1px}.now-playing{background:var(--bg-inset);border:1px solid var(--line-soft);border-radius:var(--radius);color:var(--ink-secondary);align-items:center;gap:10px;min-height:42px;margin-bottom:16px;padding:0 14px;font-size:.84rem;display:flex}.now-playing svg{color:var(--gold);flex-shrink:0}.now-playing span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.card-footer{border-top:1px solid var(--line-soft);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-top:18px;padding-top:14px;display:flex}.card-footer .muted-text{color:var(--muted);font-size:.8rem}.details-toggle{color:var(--muted);font-family:var(--font-display);letter-spacing:.06em;text-transform:uppercase;background:0 0;border:none;align-items:center;gap:5px;padding:4px 0;font-size:.72rem;font-weight:700;transition:color .15s;display:inline-flex}.details-toggle:hover{color:var(--gold)}.details-toggle svg{transition:transform .2s var(--ease)}.details-toggle[aria-expanded=true] svg{transform:rotate(180deg)}.details-content{animation:slideDown .25s var(--ease);margin-top:12px}@keyframes slideDown{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.specs-grid{gap:4px;display:grid}.spec-row{color:var(--muted);justify-content:space-between;align-items:center;gap:8px;padding:4px 0;font-size:.76rem;display:flex}.spec-row code{background:var(--bg-input);border:1px solid var(--line-soft);color:var(--ink-secondary);border-radius:4px;padding:2px 8px;font-family:JetBrains Mono,SF Mono,Fira Code,monospace;font-size:.72rem}.toast-container{z-index:1000;pointer-events:none;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:28px;left:50%;transform:translate(-50%)}.toast{animation:toastIn .3s var(--ease-bounce), toastOut .28s 2.2s var(--ease) forwards;border-radius:var(--radius);color:#fff;pointer-events:auto;white-space:nowrap;align-items:center;gap:8px;padding:12px 20px;font-size:.84rem;font-weight:600;display:flex;box-shadow:0 8px 28px #00000080}.toast.success{background:var(--pine)}.toast.error{background:var(--rock)}@keyframes toastIn{0%{opacity:0;transform:translateY(10px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes toastOut{0%{opacity:1}to{opacity:0;transform:translateY(-6px)scale(.95)}}.save-indicator{color:#0000;justify-content:center;align-items:center;width:16px;height:16px;transition:color .3s,opacity .3s;display:inline-flex}.save-indicator.idle{color:#0000}.save-indicator.saving{color:var(--muted)}.save-indicator.saved{color:var(--pine)}.save-indicator.failed{color:var(--rock)}.pair-form{gap:14px;margin-top:16px;display:grid}.pair-form-row{grid-template-columns:1fr 1fr auto;align-items:end;gap:12px;display:grid}.form-field{gap:6px;display:grid}.form-field label{color:var(--muted);font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;font-size:.68rem;font-weight:700}.form-input,.form-select{background:var(--bg-input);border:1px solid var(--line);border-radius:var(--radius-sm);color:var(--ink);width:100%;height:40px;padding:0 12px;transition:border-color .15s,box-shadow .15s}.form-input:focus,.form-select:focus{border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-dim);outline:none}.form-select option{background:var(--bg-card);color:var(--ink)}.pair-btn{background:var(--gold);border-radius:var(--radius-sm);box-shadow:0 0 18px var(--gold-glow);color:var(--bg);font-family:var(--font-display);letter-spacing:.02em;height:40px;transition:all .18s var(--ease);white-space:nowrap;border:none;align-items:center;gap:8px;padding:0 18px;font-size:.88rem;font-weight:700;display:inline-flex}.pair-btn:hover{box-shadow:0 0 28px var(--gold-glow);transform:translateY(-1px)}.pair-hint{color:var(--muted);margin:0;font-size:.78rem}.sensor-grid{grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:8px;margin-top:14px;display:grid}.sensor-card{background:var(--bg-inset);border:1px solid var(--line-soft);border-radius:var(--radius);text-align:center;padding:14px}.sensor-card h4{color:var(--muted);font-family:var(--font-display);letter-spacing:.06em;text-transform:uppercase;margin:0 0 8px;font-size:.65rem;font-weight:700}.sensor-value{font-family:var(--font-display);font-size:1.25rem;font-weight:700}.sensor-kind{color:var(--muted);font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;margin-top:4px;font-size:.6rem;font-weight:700}.discovery-grid{gap:8px;margin-top:4px;display:grid}.discovery-item{background:var(--bg-card-hover);border:1px solid var(--line-soft);border-radius:var(--radius);padding:14px 16px;transition:border-color .15s}.discovery-item:hover{border-color:var(--line)}.discovery-item-header{align-items:center;gap:10px;display:flex}.discovery-item-header svg{color:var(--gold);flex-shrink:0}.discovery-item-header h4{font-family:var(--font-display);margin:0;font-size:.92rem;font-weight:700}.alert{background:var(--gold-dim);border-radius:var(--radius);color:var(--gold);border:1px solid #d4a84333;margin-top:12px;padding:14px 16px;font-size:.86rem;font-weight:500}.error-banner{background:var(--rock-dim);border-radius:var(--radius);color:var(--rock);border:1px solid #b85c4a33;margin-top:12px;padding:14px 16px;font-size:.86rem;font-weight:500}.empty-state{color:var(--muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:8px;min-height:80px;padding:20px;font-size:.88rem;display:flex}.empty-state svg{color:var(--line)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinning{animation:1s linear infinite spin}@media (max-width:880px){.device-grid-2col{grid-template-columns:1fr}}@media (max-width:768px){.shell{padding:20px 14px 48px}.topbar{flex-direction:column;align-items:stretch;gap:10px}.topbar-actions{justify-content:flex-start}.panel{border-radius:var(--radius);padding:18px}.sensor-strip{gap:6px}.sensor-chip{padding:5px 10px}.sensor-chip-label{font-size:.68rem}.sensor-chip-value{font-size:.82rem}.card-glance{flex-wrap:wrap;gap:8px;padding:14px}.card-glance-right{gap:8px}.card-glance-sub{max-width:120px}.glance-value{font-size:.85rem}.card-expand{gap:12px;padding:14px}.threshold-row,.eq-row{grid-template-columns:1fr}.mode-selector{flex-wrap:wrap}.mode-btn{flex:0 auto;min-width:0;padding:0 10px;font-size:.78rem}.pair-form-row{grid-template-columns:1fr}.card-controls-row{flex-direction:column;align-items:stretch;gap:8px}.toggle-group,.transport-controls{justify-content:flex-start}.group-chips{gap:5px}}@media (max-width:480px){.card-glance-right .glance-stat:nth-child(n+3),.card-glance-right .glance-divider:nth-child(n+4){display:none}.stepper{grid-template-columns:36px 1fr 36px}.stepper-btn{width:36px;height:36px}.stepper-display{height:36px;font-size:1rem}}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeUp .35s var(--ease) both}.fade-in:first-child{animation-delay:0s}.fade-in:nth-child(2){animation-delay:50ms}.fade-in:nth-child(3){animation-delay:.1s}.fade-in:nth-child(4){animation-delay:.15s}.fade-in:nth-child(5){animation-delay:.2s}.fade-in:nth-child(6){animation-delay:.25s}
