:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:16px/145% var(--sans);--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial;--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}.badge-success{color:#4ade80}.alert-error{color:#f87171}.alert-success{color:#4ade80}}*,:before,:after{box-sizing:border-box}body{margin:0}#root{min-height:100svh}h1,h2,h3,h4{font-family:var(--heading);color:var(--text-h);font-weight:500}p{margin:0}a{color:var(--accent)}.app-layout{text-align:left;min-height:100svh;display:flex}.sidebar{background:var(--code-bg);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:240px;padding:1.25rem 0;display:flex}.sidebar-brand{border-bottom:1px solid var(--border);align-items:center;gap:.5rem;margin-bottom:1rem;padding:0 1.25rem 1.5rem;display:flex}.brand-icon{font-size:1.5rem}.brand-name{color:var(--text-h);font-size:1.1rem;font-weight:600}.sidebar-nav{flex-direction:column;flex:1;gap:.25rem;padding:0 .75rem;display:flex}.nav-link{color:var(--text);border-radius:6px;padding:.6rem .75rem;font-size:.95rem;text-decoration:none;transition:background .15s,color .15s;display:block}.nav-link:hover{background:var(--accent-bg);color:var(--text-h)}.nav-link.active{background:var(--accent-bg);color:var(--accent);font-weight:500}.sidebar-footer{border-top:1px solid var(--border);flex-direction:column;gap:.5rem;padding:1rem 1.25rem 0;display:flex}.user-email{color:var(--text);word-break:break-all;font-size:.8rem}.main-content{flex-direction:column;flex:1;min-width:0;padding:2rem;display:flex;overflow:auto}.db-status{color:var(--text);border-top:1px solid var(--border);margin-top:auto;padding-top:2rem;font-size:.85rem}.db-status-connected{color:#16a34a}.db-status-disconnected{color:#dc2626}.db-status-label{font-weight:600}.db-status-error-msg{font-weight:400}.db-status-stack{background:var(--code-bg);border:1px solid var(--border);white-space:pre-wrap;word-break:break-word;color:var(--text);border-radius:6px;margin:.75rem 0 0;padding:.75rem 1rem;font-size:.75rem;line-height:1.4;overflow-x:auto}.page{max-width:1100px}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:2rem;display:flex}.page-header h1{letter-spacing:-.5px;margin:0 0 .25rem;font-size:1.75rem}.page-subtitle{color:var(--text);font-size:.95rem}.page-actions{flex-wrap:wrap;gap:.5rem;display:flex}.page-loading{text-align:center;color:var(--text);padding:3rem}.section{margin-top:2rem}.section-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.section h2,.detail-card h3{color:var(--text-h);margin:0 0 1rem;font-size:1.1rem}.stat-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem;margin-bottom:2rem;display:grid}.stat-card{background:var(--code-bg);border:1px solid var(--border);border-radius:8px;align-items:center;gap:1rem;padding:1.25rem;display:flex}.stat-icon{font-size:1.5rem}.stat-value{color:var(--text-h);font-size:1.75rem;font-weight:600;line-height:1.2;display:block}.stat-label{color:var(--text);font-size:.85rem}.table-wrap{border:1px solid var(--border);border-radius:8px;overflow-x:auto}.data-table{border-collapse:collapse;width:100%;font-size:.9rem}.data-table th,.data-table td{text-align:left;border-bottom:1px solid var(--border);padding:.75rem 1rem}.data-table th{background:var(--code-bg);color:var(--text-h);text-transform:uppercase;letter-spacing:.03em;font-size:.8rem;font-weight:500}.data-table tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:var(--accent-bg)}.detail-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem;margin-bottom:2rem;display:grid}.detail-card{background:var(--code-bg);border:1px solid var(--border);border-radius:8px;padding:1.25rem}.detail-list{grid-template-columns:auto 1fr;gap:.5rem 1.5rem;margin:0;display:grid}.detail-list dt{color:var(--text);font-size:.85rem}.detail-list dd{color:var(--text-h);margin:0;font-size:.9rem}.mono{font-family:var(--mono);word-break:break-all;font-size:.85rem}.stream-panel{margin-bottom:2rem}.stream-panel h2{margin:0 0 .75rem;font-size:1.1rem}.stream-frame{aspect-ratio:16/9;background:#000;border-radius:8px;justify-content:center;align-items:center;max-width:720px;display:flex;overflow:hidden}.stream-frame img{object-fit:contain;width:100%;height:100%}.auth-page{text-align:center;flex-direction:column;min-height:100svh;padding:2rem;display:flex}.auth-page-body{flex:1;justify-content:center;align-items:center;min-width:0;display:flex}.auth-card{background:var(--code-bg);border:1px solid var(--border);width:100%;max-width:400px;box-shadow:var(--shadow);border-radius:12px;padding:2rem}.auth-brand h1{margin:.5rem 0 .25rem;font-size:1.5rem}.auth-brand p{color:var(--text);margin-bottom:1.5rem;font-size:.9rem}.auth-form{text-align:left;flex-direction:column;gap:1rem;display:flex}.auth-form label,.settings-form label{color:var(--text-h);flex-direction:column;gap:.35rem;font-size:.85rem;display:flex}.auth-form input,.settings-form input{border:1px solid var(--border);background:var(--bg);color:var(--text-h);font:inherit;border-radius:6px;padding:.6rem .75rem}.auth-form input:focus,.settings-form input:focus{outline:2px solid var(--accent-border);outline-offset:1px}.auth-footer{color:var(--text);margin-top:1.25rem;font-size:.9rem}.settings-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.25rem;display:grid}.settings-form{flex-direction:column;gap:1rem;display:flex}.settings-form h4{color:var(--text-h);margin:.5rem 0 0;font-size:.95rem}.btn{font:inherit;cursor:pointer;border:1px solid #0000;border-radius:6px;justify-content:center;align-items:center;padding:.55rem 1rem;font-size:.9rem;text-decoration:none;transition:background .15s,border-color .15s;display:inline-flex}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover:not(:disabled){filter:brightness(1.1)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-ghost{color:var(--text);border-color:var(--border);background:0 0}.btn-ghost:hover{background:var(--code-bg);color:var(--text-h)}.btn-sm{padding:.35rem .65rem;font-size:.8rem}a.link,.link{color:var(--accent);text-decoration:none}a.link:hover,.link:hover{text-decoration:underline}.link-bold{color:var(--text-h);font-weight:500;text-decoration:none}.link-bold:hover{color:var(--accent)}.badge{border-radius:4px;padding:.2rem .5rem;font-size:.75rem;font-weight:500;display:inline-block}.badge-success{color:#16a34a;background:#22c55e26}.badge-muted{background:var(--border);color:var(--text)}.alert{border-radius:6px;padding:.75rem 1rem;font-size:.9rem}.alert-error{color:#dc2626;background:#ef44441a;border:1px solid #ef44444d}.alert-success{color:#16a34a;background:#22c55e1a;border:1px solid #22c55e4d}.empty-state{color:var(--text);text-align:center;padding:1.5rem;font-size:.9rem}.page-hint{margin:-1rem 0 1.5rem}.capitalize{text-transform:capitalize}body.modal-open{overflow:hidden}.modal-overlay{z-index:9999;background:#00000080;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.modal-panel{background:var(--bg);border:1px solid var(--border);width:100%;max-width:480px;max-height:min(90vh,720px);box-shadow:var(--shadow);border-radius:12px;flex-direction:column;display:flex;overflow:hidden}.modal-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.25rem;display:flex}.modal-header h2{margin:0;font-size:1.1rem;font-weight:600;line-height:1.3}.modal-close{background:var(--code-bg);border:1px solid var(--border);cursor:pointer;width:2rem;height:2rem;color:var(--text);border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;font-size:1.25rem;line-height:1;display:inline-flex}.modal-close:hover{color:var(--text-h);background:var(--accent-bg)}.modal-body{padding:1.25rem;overflow-y:auto}.entity-form{flex-direction:column;gap:1.125rem;width:100%;display:flex}.form-field{flex-direction:column;align-items:stretch;gap:.4rem;width:100%;display:flex}.form-label{color:var(--text-h);font-size:.85rem;font-weight:500;line-height:1.3;display:block}.form-hint{color:var(--text);margin:0;font-size:.78rem;line-height:1.4}.form-section-title{color:var(--text-h);border-top:1px solid var(--border);margin:.25rem 0 0;padding-top:1rem;font-size:.9rem;font-weight:600}.form-row{grid-template-columns:repeat(3,minmax(0,1fr));gap:.75rem;width:100%;display:grid}.form-control,.entity-form .form-control,.entity-form input,.entity-form select{box-sizing:border-box;border:1px solid var(--border);background:var(--bg);width:100%;color:var(--text-h);font:inherit;border-radius:6px;padding:.65rem .75rem;line-height:1.4;display:block}.form-control:focus,.entity-form input:focus,.entity-form select:focus{outline:2px solid var(--accent-border);outline-offset:1px}.form-actions{border-top:1px solid var(--border);justify-content:flex-end;gap:.625rem;margin-top:.25rem;padding-top:1rem;display:flex}@media (width<=768px){.form-row{grid-template-columns:1fr}.app-layout{flex-direction:column}.sidebar{border-right:none;border-bottom:1px solid var(--border);width:100%}.sidebar-nav{flex-flow:wrap}.main-content{padding:1.25rem}}
