:root{--bg: #0a0a0a;--surface: #0f1117;--surface-2: #161921;--surface-3: #1c2029;--border: #1e2230;--border-hover: #2a3040;--text: #e8eaf0;--muted: #6b7280;--accent: #c8ff00;--accent-dim: rgba(200, 255, 0, .08);--accent-border: rgba(200, 255, 0, .25);--warn: #ff9800;--bad: #ef4444;--good: #22c55e;--cyan: #06b6d4;--purple: #a855f7;--mono: "JetBrains Mono", monospace;--sans: "Inter", system-ui, sans-serif;--radius: 10px;--radius-lg: 14px}*{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}.ico{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;line-height:1}.ico svg{width:100%;height:100%}.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;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.header-left{display:flex;align-items:center;gap:10px}.header-right{display:flex;align-items:center;gap:8px}.logo{font-family:var(--mono);font-weight:800;color:var(--accent);font-size:14px;letter-spacing:-.03em}.tag{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.15em;font-weight:600}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--muted);flex-shrink:0}.status-dot.ok{background:var(--good);box-shadow:0 0 6px #22c55e66}.status-dot.warn{background:var(--warn);box-shadow:0 0 6px #ff980066}.status-dot.bad{background:var(--bad);box-shadow:0 0 6px #ef444466}.status-dot.live{background:var(--bad);animation:pulse-dot 2s infinite}@keyframes pulse-dot{0%,to{opacity:1;box-shadow:0 0 6px #ef444466}50%{opacity:.5;box-shadow:0 0 12px #ef444499}}.conn-label{font-family:var(--mono);font-size:11px;color:var(--muted);font-weight:600}.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:all .15s ease;display:inline-flex;align-items:center;gap:6px;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.btn:hover{border-color:var(--border-hover);background:var(--surface-3)}.btn:active{transform:scale(.97)}.btn.primary{background:var(--accent);color:#0a0a0a;border-color:var(--accent);font-weight:700}.btn.primary:hover{background:#b8ee00}.btn.primary:active{background:#a0d000}.btn.danger{background:var(--bad);color:#fff;border-color:var(--bad)}.btn.danger:active{background:#dc2626}.btn.ghost{background:transparent;border:none;padding:8px;color:var(--muted)}.btn.ghost:hover{color:var(--text)}.btn.sm{padding:6px 10px;font-size:12px}.btn.lg{padding:14px 20px;font-size:15px;min-height:50px;justify-content:center}.btn.full{width:100%}.btn.btn-icon{padding:6px}.btn:disabled{opacity:.35;cursor:not-allowed;pointer-events:none}.input{font-family:var(--sans);font-size:14px;padding:10px 12px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg);color:var(--text);width:100%;transition:border-color .15s}.input:focus{outline:none;border-color:var(--accent)}.input.mono{font-family:var(--mono);font-size:12px}.select{-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%236b7280' viewBox='0 0 16 16'%3E%3Cpath d='M4 6l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:32px;cursor:pointer}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px;transition:border-color .15s}.card:hover{border-color:var(--border-hover)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.card-header h3{font-family:var(--mono);font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:1.2px;display:flex;align-items:center;gap:6px;margin:0}.card-footer{margin-top:16px;padding-top:14px;border-top:1px solid var(--border);display:flex;justify-content:flex-end}.row{display:flex;gap:8px;align-items:center}.flex-1{flex:1}.tab-bar{display:flex;gap:0;border-bottom:1px solid var(--border);background:var(--surface);position:sticky;top:49px;z-index:90;overflow-x:auto;-webkit-overflow-scrolling:touch}.tab{font-family:var(--mono);font-size:11px;font-weight:600;padding:12px 18px;color:var(--muted);cursor:pointer;border:none;background:none;border-bottom:2px solid transparent;display:flex;align-items:center;gap:6px;white-space:nowrap;transition:all .15s;text-transform:uppercase;letter-spacing:.5px;touch-action:manipulation}.tab:hover{color:var(--text);background:var(--surface-2)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.home-main{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:24px 16px;max-width:420px;margin:0 auto;width:100%}.home-hero{text-align:center;margin-bottom:32px}.home-icon{color:var(--accent);margin-bottom:16px;opacity:.8}.home-hero h1{font-size:1.4rem;font-weight:700;margin-bottom:8px}.home-hero .lede{color:var(--muted);line-height:1.6;font-size:14px}.home-actions{width:100%;display:flex;flex-direction:column;gap:12px}.divider-text{display:flex;align-items:center;gap:12px;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em}.divider-text:before,.divider-text:after{content:"";flex:1;height:1px;background:var(--border)}.hint{color:var(--bad);font-size:13px;min-height:1.2em;text-align:center}.home-footer{padding:16px;text-align:center;border-top:1px solid var(--border)}.footer-text{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.05em}.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-icon{color:var(--accent);margin-bottom:16px;opacity:.7}.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;color:var(--muted)}.qr-wrap-big{margin:20px 0;display:flex;justify-content:center}.qr-wrap-big canvas{border-radius:12px}.deep-link-wrap{margin-top:12px}.deep{font-family:var(--mono);font-size:10px;word-break:break-all;white-space:pre-wrap;background:var(--bg);padding:10px;border-radius:8px;border:1px solid var(--border);max-height:50px;overflow:auto;text-align:left;margin-bottom:8px}.btn-copy{width:100%;justify-content:center}.waiting-bar{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:24px;font-size:12px;color:var(--muted)}.waiting-dot{width:6px;height:6px;border-radius:50%;background:var(--warn);animation:pulse-dot 2s infinite}.dash-wrap{display:flex;flex-direction:column;flex:1}.dash-content{display:flex;flex-direction:column;gap:12px;padding:12px;flex:1}.status-bar{display:flex;flex-wrap:wrap;gap:4px 16px;padding:10px 16px;background:var(--surface);border-bottom:1px solid var(--border)}.stat{display:flex;align-items:center;gap:5px}.stat-label{font-family:var(--mono);font-size:10px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:center;gap:3px}.stat-value{font-family:var(--mono);font-size:12px;color:var(--text);font-weight:600}.stat-value.live{color:var(--bad);font-weight:800}.live-badge{font-family:var(--mono);font-size:10px;font-weight:800;color:#fff;background:var(--bad);padding:3px 8px;border-radius:4px;letter-spacing:1px;animation:pulse-dot 2s infinite}.stream-btns{display:flex;gap:8px}.stream-btn{flex:1;min-height:48px;font-size:14px;font-weight:700;justify-content:center;border-radius:var(--radius)}.stream-btn.go-live{background:var(--good);color:#fff;border-color:var(--good)}.stream-btn.go-live:hover{background:#16a34a}.stream-btn.stop-btn{background:transparent;color:var(--bad);border-color:var(--bad)}.stream-btn.stop-btn:hover:not(:disabled){background:#ef44441a}.action-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.action-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 8px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface-2);color:var(--muted);cursor:pointer;transition:all .15s;touch-action:manipulation;font-family:var(--sans)}.action-btn:hover{border-color:var(--border-hover);color:var(--text);background:var(--surface-3)}.action-btn:active{transform:scale(.95)}.action-btn .action-ico{display:flex}.action-btn .action-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.action-btn.active{border-color:var(--accent-border);color:var(--accent);background:var(--accent-dim)}.scene-count{font-family:var(--mono);font-size:10px;color:var(--muted)}.scene-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.scene-btn{position:relative;display:flex;align-items:center;gap:8px;padding:12px 14px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface-2);color:var(--text);cursor:pointer;font-size:13px;font-family:var(--sans);font-weight:500;transition:all .15s;touch-action:manipulation}.scene-btn:hover{border-color:var(--border-hover);background:var(--surface-3)}.scene-btn:active{transform:scale(.97)}.scene-btn.active{border-color:var(--good);background:#22c55e14;color:var(--good)}.scene-btn .scene-ico{display:flex;opacity:.6}.scene-btn.active .scene-ico{opacity:1}.scene-btn .scene-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.scene-dot{position:absolute;top:6px;right:6px;width:6px;height:6px;border-radius:50%;background:var(--good);box-shadow:0 0 6px #22c55e80}.scene-empty{color:var(--muted);font-size:12px;padding:8px 0;grid-column:1 / -1}.current-scene{display:flex;align-items:center;gap:6px;margin-top:12px;padding:10px 14px;background:var(--surface-2);border-radius:var(--radius);font-size:12px;color:var(--muted)}.current-scene strong{color:var(--text)}.cs-dot{width:6px;height:6px;border-radius:50%;background:var(--good);box-shadow:0 0 6px #22c55e66;flex-shrink:0}.zoom-strip{display:flex;gap:6px;overflow-x:auto;padding:2px 0}.zoom-chip{padding:8px 16px;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:hover{border-color:var(--border-hover);color:var(--text)}.zoom-chip.active{border-color:var(--accent-border);color:var(--accent);background:var(--accent-dim)}.zoom-chip:active{transform:scale(.93)}.audio-row{display:flex;align-items:center;gap:10px}.audio-label{font-size:12px;color:var(--muted);min-width:32px;font-weight:600}.gain-slider{flex:1;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--border);border-radius:2px;outline:none}.gain-slider::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;background:var(--accent);border-radius:50%;cursor:pointer;box-shadow:0 0 6px #c8ff004d}.gain-value{font-family:var(--mono);font-size:12px;color:var(--accent);min-width:40px;text-align:right;font-weight:600}.section-toggle{display:flex;align-items:center;justify-content:space-between;cursor:pointer;-webkit-user-select:none;user-select:none}.section-toggle h3{font-family:var(--mono);font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:1.2px;display:flex;align-items:center;gap:6px;margin:0;cursor:pointer}.toggle-arrow{color:var(--muted);transition:transform .2s;display:flex}.toggle-arrow.open{transform:rotate(90deg)}.section-body{overflow:hidden;margin-top:14px}.section-body.collapsed{display:none;margin-top:0}.raw-row{display:flex;gap:6px;margin-bottom:8px}.raw-row .input{flex:1;font-size:12px;padding:8px 10px}.log{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:10px;min-height:100px;max-height:200px;overflow:auto;font-family:var(--mono);font-size:10px;white-space:pre-wrap;word-break:break-all;color:var(--muted)}.settings-content{display:flex;flex-direction:column;gap:12px;padding:12px;flex:1}.settings-grid{display:flex;flex-direction:column;gap:14px}.setting-row{display:flex;flex-direction:column;gap:6px}.setting-label{font-family:var(--mono);font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.setting-control{display:flex;flex-direction:column;gap:4px}.slider-control{display:flex;align-items:center;gap:10px;flex-direction:row}.cfg-slider{flex:1;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--border);border-radius:2px;outline:none}.cfg-slider::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;background:var(--accent);border-radius:50%;cursor:pointer;box-shadow:0 0 6px #c8ff004d}.cfg-slider-value{font-family:var(--mono);font-size:12px;color:var(--accent);min-width:90px;text-align:right;font-weight:600;white-space:nowrap}.cfg-readonly{font-family:var(--mono);font-size:13px;color:var(--text);padding:8px 0;font-weight:500}.toggle-btn{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface-2);color:var(--muted);cursor:pointer;font-family:var(--sans);font-size:13px;font-weight:600;transition:all .15s;touch-action:manipulation}.toggle-btn:hover{border-color:var(--border-hover)}.toggle-btn .toggle-ico{display:flex}.toggle-btn .toggle-text{font-size:12px}.toggle-btn.active{border-color:var(--accent-border);color:var(--accent);background:var(--accent-dim)}.system-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.sys-stat{display:flex;align-items:center;gap:8px;padding:12px;background:var(--surface-2);border-radius:var(--radius);border:1px solid var(--border)}.sys-label{font-family:var(--mono);font-size:10px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:center;gap:4px;min-width:60px}.sys-value{font-family:var(--mono);font-size:14px;color:var(--text);font-weight:700}.profiles-content{display:flex;flex-direction:column;gap:12px;padding:12px;flex:1}.profiles-hint{font-size:12px;color:var(--muted);line-height:1.5;margin-bottom:8px}.profile-list{display:flex;flex-direction:column;gap:8px}.profile-card{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:14px;transition:border-color .15s}.profile-card:hover{border-color:var(--border-hover)}.profile-card.enabled{border-color:#22c55e4d}.profile-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.profile-info{flex:1;min-width:0}.profile-name{font-weight:600;font-size:14px;margin-bottom:4px;display:flex;align-items:center;gap:8px}.profile-dot{width:8px;height:8px;border-radius:50%;background:var(--muted);flex-shrink:0}.profile-dot.on{background:var(--good);box-shadow:0 0 6px #22c55e66}.profile-dest{font-family:var(--mono);font-size:11px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-actions{display:flex;gap:2px;flex-shrink:0}.profile-meta{display:flex;gap:12px;margin-top:8px;padding-top:8px;border-top:1px solid var(--border);font-size:11px;color:var(--muted);font-family:var(--mono)}.profile-empty{color:var(--muted);font-size:13px;text-align:center;padding:24px 16px;background:var(--surface-2);border:1px dashed var(--border);border-radius:var(--radius)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:16px}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:500px;max-height:90dvh;overflow-y:auto}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 18px 0}.modal-header h3{font-family:var(--mono);font-size:13px;font-weight:700;color:var(--text);display:flex;align-items:center;gap:8px;margin:0}.modal-body{padding:18px;display:flex;flex-direction:column;gap:14px}.modal-footer{padding:14px 18px 18px;display:flex;justify-content:flex-end;gap:8px;border-top:1px solid var(--border);margin-top:4px}.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;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.toast.show{opacity:1;transform:translate(-50%) translateY(0)}.toast-ok{background:#22c55ee6;color:#fff}.toast-warn{background:#ff9800e6;color:#000}.toast-bad{background:#ef4444e6;color:#fff}@media(min-width:768px){.home-main{max-width:420px}.dash-content{max-width:900px;margin:0 auto;width:100%;display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:20px}.card-stream,.card-actions{grid-column:1 / -1}.action-grid{grid-template-columns:repeat(6,1fr)}.card-debug{grid-column:1 / -1}.scene-grid{grid-template-columns:repeat(3,1fr)}.card{padding:20px}.stream-btn{min-height:52px;font-size:15px}.settings-content{max-width:700px;margin:0 auto;width:100%;padding:20px}.setting-row{flex-direction:row;align-items:center;gap:16px}.setting-label{min-width:140px;flex-shrink:0}.setting-control{flex:1}.profiles-content{max-width:700px;margin:0 auto;width:100%;padding:20px}.system-stats{grid-template-columns:repeat(4,1fr)}}@media(min-width:1100px){.dash-content{max-width:1100px;grid-template-columns:1fr 1fr 1fr;gap:16px;padding:24px}.card-stream,.card-actions{grid-column:1 / -1}.card-scenes{grid-column:1 / 3}.scene-grid{grid-template-columns:repeat(4,1fr)}.card-debug{grid-column:1 / -1}.card{padding:24px}.stream-btns{max-width:500px}.settings-content,.profiles-content{max-width:900px;padding:24px}}
