:root{--text:#6b6375;--text-h:#08060d;--bg:#fbfaff;--surface:#ffffffb8;--border:#e8e4f0;--code-bg:#f3f0fb;--accent:#863bff;--accent-2:#47bfff;--accent-bg:#863bff14;--accent-border:#863bff73;--gradient:linear-gradient(120deg, #7e14ff 0%, #a855f7 45%, #47bfff 100%);--glow-1:#863bff47;--glow-2:#47bfff38;--glow-3:#a855f72e;--shadow:#4c1d951f 0 18px 40px -12px, #0000000d 0 4px 10px -4px;--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:#0d0b14;--surface:#1f1b2e99;--border:#2c2740;--code-bg:#1a172a;--accent:#c084fc;--accent-2:#5ec8ff;--accent-bg:#c084fc24;--accent-border:#c084fc80;--gradient:linear-gradient(120deg, #a855f7 0%, #c084fc 45%, #5ec8ff 100%);--glow-1:#863bff59;--glow-2:#47bfff47;--glow-3:#a855f742;--shadow:#00000080 0 18px 40px -12px, #0000004d 0 4px 10px -4px}.badge-success{color:#4ade80}.alert-error{color:#f87171}.alert-success{color:#4ade80}}*,:before,:after{box-sizing:border-box}body{background-color:var(--bg);min-height:100svh;margin:0;position:relative}body:before,body:after{content:"";z-index:-1;filter:blur(90px);opacity:.9;pointer-events:none;border-radius:50%;position:fixed}body:before{background:radial-gradient(circle at 30% 30%, var(--glow-1), transparent 70%);width:520px;height:520px;animation:22s ease-in-out infinite alternate drift-a;top:-180px;left:-140px}body:after{background:radial-gradient(circle at 60% 40%, var(--glow-2), transparent 70%);width:600px;height:600px;animation:26s ease-in-out infinite alternate drift-b;bottom:-220px;right:-160px}@keyframes drift-a{0%{transform:translate(0)scale(1)}to{transform:translate(80px,60px)scale(1.15)}}@keyframes drift-b{0%{transform:translate(0)scale(1.1)}to{transform:translate(-70px,-50px)scale(.9)}}@media (prefers-reduced-motion:reduce){body:before,body:after{animation:none}}#root{z-index:0;min-height:100svh;position:relative}h1,h2,h3,h4{font-family:var(--heading);color:var(--text-h);letter-spacing:-.01em;font-weight:600}p{margin:0}a{color:var(--accent)}.app-layout{text-align:left;min-height:100svh;display:flex}.sidebar{background:var(--surface);-webkit-backdrop-filter:blur(18px);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:.6rem;margin-bottom:1rem;padding:0 1.25rem 1.5rem;display:flex}.brand-icon{filter:drop-shadow(0 2px 6px var(--glow-1));display:block}.brand-name{letter-spacing:-.02em;background:var(--gradient);-webkit-text-fill-color:transparent;color:var(--accent);-webkit-background-clip:text;background-clip:text;font-size:1.25rem;font-weight:700}.sidebar-nav{flex-direction:column;flex:1;gap:.25rem;padding:0 .75rem;display:flex}.nav-link{color:var(--text);border-radius:8px;padding:.6rem .85rem;font-size:.95rem;text-decoration:none;transition:background .18s,color .18s,transform .18s;display:block;position:relative}.nav-link:hover{background:var(--accent-bg);color:var(--text-h);transform:translate(2px)}.nav-link.active{background:var(--accent-bg);color:var(--accent);font-weight:600}.nav-link.active:before{content:"";background:var(--gradient);border-radius:0 3px 3px 0;width:3px;height:60%;position:absolute;top:50%;left:0;transform:translateY(-50%)}.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;animation:.45s cubic-bezier(.22,1,.36,1) both fade-up}@keyframes fade-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes pop-in{0%{opacity:0;transform:translateY(14px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.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:-.03em;background:linear-gradient(120deg, var(--text-h) 30%, var(--accent) 130%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0 0 .25rem;font-size:1.9rem}.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);flex-direction:column;align-items:center;gap:1rem;padding:3rem;display:flex}.spinner{background:var(--gradient);border-radius:50%;width:2.25rem;height:2.25rem;animation:.8s linear infinite spin;-webkit-mask:radial-gradient(farthest-side,#0000 calc(100% - 4px),#000 0);mask:radial-gradient(farthest-side,#0000 calc(100% - 4px),#000 0)}@keyframes spin{to{transform:rotate(360deg)}}.section{margin-top:2rem;animation:.5s cubic-bezier(.22,1,.36,1) 80ms both fade-up}.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(--surface);-webkit-backdrop-filter:blur(14px);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:14px;align-items:center;gap:1rem;padding:1.25rem;transition:transform .2s,box-shadow .2s;animation:.5s cubic-bezier(.22,1,.36,1) both pop-in;display:flex;position:relative;overflow:hidden}.stat-grid .stat-card:first-child{animation-delay:50ms}.stat-grid .stat-card:nth-child(2){animation-delay:.12s}.stat-grid .stat-card:nth-child(3){animation-delay:.19s}.stat-grid .stat-card:nth-child(4){animation-delay:.26s}.stat-card:hover .stat-icon{transform:scale(1.08)rotate(-4deg)}.stat-icon{transition:transform .25s}.stat-card:after{content:"";background:var(--gradient);opacity:0;height:3px;transition:opacity .2s;position:absolute;inset:0 0 auto}.stat-card:hover{transform:translateY(-3px);box-shadow:0 24px 48px -16px #4c1d952e}.stat-card:hover:after{opacity:1}.stat-icon{background:var(--accent-bg);border:1px solid var(--accent-border);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:2.75rem;height:2.75rem;font-size:1.35rem;display:flex}.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);background:var(--surface);-webkit-backdrop-filter:blur(14px);box-shadow:var(--shadow);border-radius:14px;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(--accent-bg);color:var(--text-h);text-transform:uppercase;letter-spacing:.05em;font-size:.78rem;font-weight:600}.data-table tr:last-child td{border-bottom:none}.data-table tbody tr{transition:background .18s}.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(--surface);-webkit-backdrop-filter:blur(14px);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:14px;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(--surface);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border);width:100%;max-width:400px;box-shadow:var(--shadow);border-radius:20px;padding:2.5rem 2rem;animation:.5s cubic-bezier(.22,1,.36,1) both pop-in;position:relative;overflow:hidden}.auth-card:before{content:"";background:var(--gradient);height:4px;position:absolute;inset:0 0 auto}.auth-brand-icon{filter:drop-shadow(0 6px 18px var(--glow-1));animation:5s ease-in-out infinite float-icon;display:inline-block}@keyframes float-icon{0%,to{transform:translateY(0)}50%{transform:translateY(-7px)}}@media (prefers-reduced-motion:reduce){.auth-brand-icon{animation:none}}.auth-brand h1{letter-spacing:-.02em;background:var(--gradient);-webkit-text-fill-color:transparent;color:var(--accent);-webkit-background-clip:text;background-clip:text;margin:.65rem 0 .25rem;font-size:1.6rem}.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:8px;padding:.6rem .75rem;transition:border-color .18s,box-shadow .18s}.auth-form input:focus,.settings-form input:focus{border-color:var(--accent-border);box-shadow:0 0 0 3px var(--accent-bg);outline:none}.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:9px;justify-content:center;align-items:center;padding:.6rem 1.1rem;font-size:.9rem;font-weight:500;text-decoration:none;transition:filter .15s,border-color .15s,transform .15s,box-shadow .15s;display:inline-flex}.btn-primary{background:var(--gradient);color:#fff;box-shadow:0 8px 20px -8px var(--glow-1);background-size:160% 160%;border-color:#0000}.btn-primary:hover:not(:disabled){filter:brightness(1.06);box-shadow:0 12px 26px -8px var(--glow-1);transform:translateY(-1px)}.btn:active:not(:disabled){transform:translateY(0)scale(.97)}.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(--accent-bg);color:var(--text-h);border-color:var(--accent-border)}.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{-webkit-backdrop-filter:blur(4px);z-index:9999;background:#0c08188c;justify-content:center;align-items:center;padding:1.5rem;animation:.2s both overlay-in;display:flex;position:fixed;inset:0}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}.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:16px;flex-direction:column;animation:.3s cubic-bezier(.22,1,.36,1) both modal-in;display:flex;overflow:hidden}@keyframes modal-in{0%{opacity:0;transform:translateY(20px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.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:8px;padding:.65rem .75rem;line-height:1.4;transition:border-color .18s,box-shadow .18s;display:block}.form-control:focus,.entity-form input:focus,.entity-form select:focus{border-color:var(--accent-border);box-shadow:0 0 0 3px var(--accent-bg);outline:none}.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}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.001ms!important;animation-duration:.001ms!important;animation-iteration-count:1!important}}
