:root{--bg: #0a0a0a;--surface: #111;--surface-2: #1a1a1a;--surface-3: #222;--border: #2a2a2a;--text: #e8e8e8;--muted: #888;--accent: #c8ff00;--accent-dim: #4a5f00;--warn: #ff9800;--bad: #f44;--good: #4caf50;--cyan: #00bcd4;--mono: "JetBrains Mono", monospace;--sans: "Inter", system-ui, sans-serif;--radius: 10px}*{box-sizing:border-box;margin:0;padding:0}body{min-height:100dvh;background:var(--bg);color:var(--text);font-family:var(--sans);-webkit-font-smoothing:antialiased}#app{min-height:100dvh}.page{min-height:100dvh;display:flex;flex-direction:column}.header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border);background:var(--surface);position:sticky;top:0;z-index:100}.header-left{display:flex;align-items:center;gap:10px}.logo{font-family:var(--mono);font-weight:800;color:var(--accent);font-size:15px;letter-spacing:-.03em}.tag{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.12em}.pill{font-family:var(--mono);font-size:11px;padding:4px 10px;border-radius:999px;border:1px solid var(--border);color:var(--muted)}.pill.ok{border-color:var(--accent);color:var(--accent)}.pill.warn{border-color:var(--warn);color:var(--warn)}.pill.bad{border-color:var(--bad);color:var(--bad)}.pill.live{border-color:var(--bad);color:var(--bad);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.btn{font-family:var(--sans);font-weight:600;font-size:13px;padding:10px 14px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface-2);color:var(--text);cursor:pointer;transition:background .15s,border-color .15s;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.btn:active{transform:scale(.97)}.btn.primary{background:var(--accent);color:#0a0a0a;border-color:var(--accent);font-weight:700}.btn.primary:active{background:#b0e000}.btn.danger{background:var(--bad);color:#fff;border-color:var(--bad)}.btn.danger:active{background:#d00}.btn.warn{border-color:var(--warn);color:var(--warn)}.btn.ghost{background:transparent;border:none;padding:8px;color:var(--muted)}.btn.sm{padding:6px 10px;font-size:12px}.btn.lg{padding:14px 20px;font-size:15px;min-height:52px}.btn.full{width:100%}.btn:disabled{opacity:.4;cursor:not-allowed}.input{font-family:var(--mono);font-size:14px;padding:10px 12px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg);color:var(--text);width:100%}.input:focus{outline:none;border-color:var(--accent)}.card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px}.card h3{font-family:var(--mono);font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:12px}.main{flex:1;padding:16px;max-width:480px;margin:0 auto;width:100%}.gap-12{display:flex;flex-direction:column;gap:12px}.gap-8{display:flex;flex-direction:column;gap:8px}.row{display:flex;gap:8px;align-items:center}.row.between{justify-content:space-between}.flex-1{flex:1}.text-center{text-align:center}.home .main{display:flex;flex-direction:column;justify-content:center}.home h1{font-size:1.3rem;font-weight:700;margin-bottom:6px}.home .lede{color:var(--muted);margin-bottom:20px;line-height:1.5;font-size:14px}.hint{color:var(--bad);font-size:13px;min-height:1.2em}.pairing-overlay{flex:1;display:flex;align-items:center;justify-content:center;padding:24px;min-height:calc(100dvh - 60px)}.pairing-center{text-align:center;max-width:400px;width:100%}.pairing-center h2{font-size:1.3rem;font-weight:700;margin-bottom:8px}.pairing-center .muted{font-size:13px;line-height:1.5;margin-bottom:16px}.qr-wrap-big{margin:20px 0;display:flex;justify-content:center}.qr-wrap-big canvas{border-radius:12px}.mono{font-family:var(--mono);font-size:10px;word-break:break-all;white-space:pre-wrap}.deep{background:var(--bg);padding:10px;border-radius:8px;border:1px solid var(--border);max-height:60px;overflow:auto;font-size:10px;text-align:left}.dashboard{padding:0;max-width:100%}.dash-grid{display:flex;flex-direction:column;gap:12px;padding:12px}.status-bar{display:flex;flex-wrap:wrap;gap:8px;padding:10px 16px;background:var(--surface);border-bottom:1px solid var(--border);font-family:var(--mono);font-size:11px;color:var(--muted)}.status-bar .stat{display:flex;align-items:center;gap:4px}.status-bar .stat-value{color:var(--text);font-weight:600}.status-bar .stat-label{color:var(--muted)}.stream-control{display:flex;gap:8px}.stream-control .btn{flex:1;min-height:48px;font-size:14px}.scene-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:8px}.scene-btn{padding:10px 8px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface-2);color:var(--text);text-align:center;font-size:12px;font-family:var(--mono);cursor:pointer;transition:all .15s;touch-action:manipulation}.scene-btn.active{border-color:var(--accent);background:var(--accent-dim);color:var(--accent)}.scene-btn:active{transform:scale(.95)}.zoom-strip{display:flex;gap:6px;overflow-x:auto;padding:2px 0}.zoom-chip{padding:8px 14px;border-radius:20px;border:1px solid var(--border);background:var(--surface-2);color:var(--muted);font-family:var(--mono);font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .15s;touch-action:manipulation}.zoom-chip.active{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.zoom-chip:active{transform:scale(.93)}.audio-row{display:flex;align-items:center;gap:10px}.gain-slider{flex:1;height:6px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--border);border-radius:3px;outline:none}.gain-slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;background:var(--accent);border-radius:50%;cursor:pointer}.gain-value{font-family:var(--mono);font-size:12px;color:var(--accent);min-width:36px;text-align:right}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:4px 0}.toggle-label{font-size:13px}.toggle-sub{font-size:11px;color:var(--muted)}.log{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:10px;min-height:120px;max-height:200px;overflow:auto;font-family:var(--mono);font-size:10px;white-space:pre-wrap;word-break:break-all}.raw-row{display:flex;gap:6px}.raw-row .input{flex:1;font-size:12px;padding:8px 10px}.section-toggle{display:flex;align-items:center;justify-content:space-between;cursor:pointer;padding:2px 0;-webkit-user-select:none;user-select:none}.section-toggle h3{margin:0;cursor:pointer}.section-toggle .arrow{color:var(--muted);font-size:12px;transition:transform .2s}.section-toggle .arrow.open{transform:rotate(90deg)}.section-body{overflow:hidden}.section-body.collapsed{display:none}.quick-actions{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:12px}.action-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 6px;font-size:11px;border-radius:var(--radius)}.action-btn .action-icon{font-size:18px}.action-btn .action-label{font-size:10px;font-weight:600}.action-btn.active{border-color:var(--warn);color:var(--warn);background:#ff98001a}.audio-label{font-size:12px;color:var(--muted);min-width:32px}.toast{position:fixed;bottom:20px;left:50%;transform:translate(-50%) translateY(20px);padding:10px 20px;border-radius:8px;font-family:var(--mono);font-size:12px;font-weight:600;z-index:1000;opacity:0;transition:all .3s ease;pointer-events:none}.toast.show{opacity:1;transform:translate(-50%) translateY(0)}.toast-ok{background:var(--good);color:#fff}.toast-warn{background:var(--warn);color:#000}.toast-bad{background:var(--bad);color:#fff}@media(min-width:768px){.main{max-width:600px}.dashboard{max-width:100%}.dashboard .dash-grid{max-width:900px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:24px}.dashboard .dash-grid .card.full-width,.card-stream{grid-column:1 / -1}.stream-control{gap:12px}.stream-control .btn{min-height:56px;font-size:15px}.quick-actions{grid-template-columns:repeat(4,1fr);gap:10px}.action-btn{padding:14px 8px}.action-btn .action-icon{font-size:22px}.action-btn .action-label{font-size:12px}.scene-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}.card{padding:20px}.card h3{margin-bottom:14px}.pairing-center h2{font-size:1.6rem}}@media(min-width:1100px){.dashboard .dash-grid{max-width:1100px;grid-template-columns:2fr 1fr 1fr;gap:20px;padding:28px}.card-stream{grid-column:1;grid-row:1 / 3}.card-scenes{grid-column:2 / 4}.card{padding:24px}}
