@import url(https://fonts.googleapis.com/css2?family=Syne:wght@400;500;600;700;800&family=JetBrains+Mono:wght@300;400;500;600&display=swap);:root{--bg:#080b0f;--surface:#0d1117;--surface2:#111820;--border:#1a2233;--border2:#243044;--teal:#00d4aa;--teal-dim:#00d4aa22;--amber:#f59e0b;--amber-dim:#f59e0b22;--red:#ef4444;--red-dim:#ef444422;--blue:#3b82f6;--blue-dim:#3b82f622;--purple:#a855f7;--purple-dim:#a855f722;--text:#e2e8f0;--muted:#4a5568;--muted2:#2d3748;--font-mono:"JetBrains Mono",monospace;--font-sans:"Syne",sans-serif}*,:after,:before{box-sizing:border-box;margin:0;padding:0}#root,body,html{-webkit-font-smoothing:antialiased;background:#080b0f;background:var(--bg);color:#e2e8f0;color:var(--text);font-family:JetBrains Mono,monospace;font-family:var(--font-mono);font-size:13px;height:100%}body:before{background:repeating-linear-gradient(0deg,#0000,#0000 2px,#0000000a 0,#0000000a 4px);content:"";inset:0;pointer-events:none;position:fixed;z-index:9999}.app-layout{display:flex;height:100vh;overflow:hidden}.app-main{background:#080b0f;background:var(--bg);flex:1 1;overflow-y:auto}.page{max-width:1400px;padding:32px 36px}.loading-screen{align-items:center;display:flex;height:100vh;justify-content:center}.loading-spinner{animation:spin .8s linear infinite;border:2px solid #1a2233;border-top-color:#00d4aa;border:2px solid var(--border);border-radius:50%;border-top-color:var(--teal);height:32px;width:32px}.sidebar{background:#0d1117;background:var(--surface);border-right:1px solid #1a2233;border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;padding:0;width:200px}.sidebar-logo{align-items:center;border-bottom:1px solid #1a2233;border-bottom:1px solid var(--border);display:flex;font-family:Syne,sans-serif;font-family:var(--font-sans);font-size:17px;font-weight:800;gap:10px;letter-spacing:.5px;padding:22px 20px 18px}.logo-icon{color:#00d4aa;color:var(--teal)}.logo-text{color:#e2e8f0;color:var(--text)}.logo-accent{color:#00d4aa;color:var(--teal)}.sidebar-live{align-items:center;background:#0003;border-bottom:1px solid #1a2233;border-bottom:1px solid var(--border);display:flex;gap:8px;letter-spacing:1px;padding:10px 20px}.sidebar-cpu,.sidebar-live{color:#4a5568;color:var(--muted);font-size:10px}.sidebar-cpu{margin-left:auto}.sidebar-nav{display:flex;flex:1 1;flex-direction:column;gap:2px;padding:12px}.nav-item{align-items:center;border-radius:6px;color:#4a5568;color:var(--muted);display:flex;font-size:11px;font-weight:500;gap:10px;letter-spacing:.5px;padding:9px 12px;text-decoration:none;transition:all .15s}.nav-item:hover{background:#111820;background:var(--surface2);color:#e2e8f0;color:var(--text)}.nav-item--active{background:#00d4aa22;background:var(--teal-dim);border:1px solid #00d4aa22;border:1px solid var(--teal)22;color:#00d4aa;color:var(--teal)}.sidebar-footer{border-top:1px solid #1a2233;border-top:1px solid var(--border);gap:10px;padding:14px 16px}.sidebar-footer,.user-info{align-items:center;display:flex}.user-info{flex:1 1;gap:8px;min-width:0}.user-avatar-sm{align-items:center;background:#00d4aa22;background:var(--teal-dim);border-radius:6px;color:#00d4aa;color:var(--teal);display:flex;flex-shrink:0;font-size:11px;font-weight:700;height:26px;justify-content:center;width:26px}.user-info-text{min-width:0}.user-info-name{color:#e2e8f0;color:var(--text);font-size:11px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-info-role{font-size:9px;letter-spacing:1px}.logout-btn,.user-info-role{color:#4a5568;color:var(--muted)}.logout-btn{background:none;border:none;border-radius:4px;cursor:pointer;padding:4px;transition:color .15s}.logout-btn:hover{color:#ef4444;color:var(--red)}.login-bg{align-items:center;background:radial-gradient(ellipse 60% 50% at 50% -10%,#00d4aa14 0,#0000 70%),#080b0f;background:radial-gradient(ellipse 60% 50% at 50% -10%,#00d4aa14 0,#0000 70%),var(--bg);display:flex;justify-content:center;min-height:100vh}.login-panel{background:#0d1117;background:var(--surface);border:1px solid #243044;border:1px solid var(--border2);border-radius:12px;padding:36px 32px;width:380px}.login-logo{align-items:center;display:flex;font-family:Syne,sans-serif;font-family:var(--font-sans);font-size:22px;font-weight:800;gap:12px;margin-bottom:6px}.login-sub{color:#4a5568;color:var(--muted);font-size:11px;letter-spacing:.5px;margin-bottom:28px}.login-error{align-items:center;background:#ef444422;background:var(--red-dim);border:1px solid #ef444444;border:1px solid var(--red)44;border-radius:6px;color:#ef4444;color:var(--red);display:flex;font-size:11px;gap:8px;margin-bottom:16px;padding:10px 12px}.login-form{display:flex;flex-direction:column;gap:16px}.login-btn{align-items:center;background:#00d4aa;background:var(--teal);border:none;border-radius:6px;color:#000;cursor:pointer;display:flex;font-family:JetBrains Mono,monospace;font-family:var(--font-mono);font-size:11px;font-weight:700;gap:8px;justify-content:center;letter-spacing:2px;margin-top:8px;padding:12px;transition:opacity .15s}.login-btn:hover{opacity:.85}.login-btn:disabled{cursor:not-allowed;opacity:.5}.login-footer{align-items:center;color:#4a5568;color:var(--muted);display:flex;font-size:10px;gap:8px;justify-content:center;margin-top:24px;text-align:center}.field-group{display:flex;flex-direction:column;gap:5px}.field-label{color:#4a5568;color:var(--muted);font-size:10px;font-weight:600;letter-spacing:1px}.field-input{background:#080b0f;background:var(--bg);border:1px solid #243044;border:1px solid var(--border2);border-radius:6px;color:#e2e8f0;color:var(--text);font-family:JetBrains Mono,monospace;font-family:var(--font-mono);font-size:12px;outline:none;padding:8px 10px;transition:border-color .15s;width:100%}.field-input:focus{border-color:#00d4aa;border-color:var(--teal)}.field-input::placeholder{color:#4a5568;color:var(--muted)}.field-select{cursor:pointer}.field-select option{background:#111820;background:var(--surface2)}.field-row{align-items:flex-end;display:flex;gap:10px}.flex-1{flex:1 1}.checkbox-label{align-items:center;color:#4a5568;color:var(--muted);cursor:pointer;display:flex;font-size:12px;gap:8px}.checkbox-label input[type=checkbox]{accent-color:#00d4aa;accent-color:var(--teal)}.dot{border-radius:50%;display:inline-block;flex-shrink:0;height:7px;width:7px}.dot.running{animation:pulse 2s ease-in-out infinite;background:#00d4aa;background:var(--teal);box-shadow:0 0 6px #00d4aa;box-shadow:0 0 6px var(--teal)}.dot.stopped{background:#2d3748;background:var(--muted2)}.dot.error{background:#ef4444;background:var(--red);box-shadow:0 0 6px #ef4444;box-shadow:0 0 6px var(--red)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.btn-primary{align-items:center;background:#00d4aa;background:var(--teal);border:none;border-radius:6px;color:#000;cursor:pointer;display:inline-flex;font-family:JetBrains Mono,monospace;font-family:var(--font-mono);font-size:11px;font-weight:700;gap:7px;letter-spacing:1px;padding:9px 16px;transition:opacity .15s}.btn-primary:hover{opacity:.85}.btn-primary:disabled{cursor:not-allowed;opacity:.4}.btn-ghost{align-items:center;background:#0000;border:1px solid #243044;border:1px solid var(--border2);border-radius:6px;color:#4a5568;color:var(--muted);cursor:pointer;display:inline-flex;font-family:JetBrains Mono,monospace;font-family:var(--font-mono);font-size:11px;gap:7px;letter-spacing:1px;padding:9px 16px;transition:all .15s}.btn-ghost:hover{border-color:#243044;border-color:var(--border2);color:#e2e8f0;color:var(--text)}.btn-ghost-sm{align-items:center;background:#0000;border:1px solid #00d4aa44;border:1px solid var(--teal)44;border-radius:5px;color:#00d4aa;color:var(--teal);cursor:pointer;display:inline-flex;font-family:JetBrains Mono,monospace;font-family:var(--font-mono);font-size:10px;font-weight:600;gap:5px;letter-spacing:1px;padding:5px 10px;transition:all .15s}.btn-ghost-sm:hover{background:#00d4aa22;background:var(--teal-dim)}.icon-btn{align-items:center;border:none;border-radius:5px;cursor:pointer;display:inline-flex;height:26px;justify-content:center;transition:all .15s;width:26px}.icon-btn--teal{background:#00d4aa22;background:var(--teal-dim);color:#00d4aa;color:var(--teal)}.icon-btn--teal:hover{background:#00d4aa;background:var(--teal);color:#000}.icon-btn--red{background:#ef444422;background:var(--red-dim);color:#ef4444;color:var(--red)}.icon-btn--red:hover{background:#ef4444;background:var(--red);color:#fff}.icon-btn--amber{background:#f59e0b22;background:var(--amber-dim);color:#f59e0b;color:var(--amber)}.icon-btn--amber:hover{background:#f59e0b;background:var(--amber);color:#000}.icon-btn--ghost{background:#0000;color:#4a5568;color:var(--muted)}.icon-btn--ghost:hover{background:#111820;background:var(--surface2);color:#e2e8f0;color:var(--text)}.stat-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(4,1fr);margin-bottom:16px}.stat-card{align-items:flex-start;background:#0d1117;background:var(--surface);border:1px solid #1a2233;border:1px solid var(--border);border-radius:10px;display:flex;gap:14px;overflow:hidden;padding:18px 20px;position:relative}.stat-card:before{content:"";height:100%;left:0;position:absolute;top:0;width:3px}.stat-card--teal:before{background:#00d4aa;background:var(--teal)}.stat-card--amber:before{background:#f59e0b;background:var(--amber)}.stat-card--red:before{background:#ef4444;background:var(--red)}.stat-card--blue:before{background:#3b82f6;background:var(--blue)}.stat-card--purple:before{background:#a855f7;background:var(--purple)}.stat-icon{align-items:center;background:#00d4aa22;background:var(--teal-dim);border-radius:7px;color:#00d4aa;color:var(--teal);display:flex;flex-shrink:0;height:32px;justify-content:center;width:32px}.stat-card--amber .stat-icon{background:#f59e0b22;background:var(--amber-dim);color:#f59e0b;color:var(--amber)}.stat-card--red .stat-icon{background:#ef444422;background:var(--red-dim);color:#ef4444;color:var(--red)}.stat-card--blue .stat-icon{background:#3b82f622;background:var(--blue-dim);color:#3b82f6;color:var(--blue)}.stat-card--purple .stat-icon{background:#a855f722;background:var(--purple-dim);color:#a855f7;color:var(--purple)}.stat-body{display:flex;flex-direction:column;gap:2px}.stat-label{color:#4a5568;color:var(--muted);font-size:9px;letter-spacing:1.5px}.stat-value{color:#e2e8f0;color:var(--text);font-size:22px;font-weight:600;letter-spacing:-.5px;line-height:1.2}.stat-sub{color:#4a5568;color:var(--muted);font-size:10px}.chart-row{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr;margin-bottom:28px}.mini-chart{background:#0d1117;background:var(--surface);border:1px solid #1a2233;border:1px solid var(--border);border-radius:10px;padding:14px 16px 10px}.mini-chart-title{color:#4a5568;color:var(--muted);font-size:10px;letter-spacing:1px;margin-bottom:6px}.section-header{align-items:center;display:flex;gap:10px;margin-bottom:14px}.section-title{font-size:11px;font-weight:600;letter-spacing:2px}.badge-count,.section-title{color:#4a5568;color:var(--muted)}.badge-count{background:#111820;background:var(--surface2);border:1px solid #1a2233;border:1px solid var(--border);border-radius:20px;font-size:10px;padding:1px 8px}.stream-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.stream-card{background:#0d1117;background:var(--surface);border:1px solid #1a2233;border:1px solid var(--border);border-radius:10px;display:flex;flex-direction:column;gap:10px;padding:16px 18px;transition:border-color .2s}.stream-card--running{border-color:#00d4aa44;border-color:var(--teal)44}.stream-card--error{border-color:#ef444444;border-color:var(--red)44}.stream-card-header{align-items:center;display:flex;justify-content:space-between}.stream-status-row{align-items:center;display:flex;gap:6px}.stream-status-label{color:#4a5568;color:var(--muted);font-size:9px;letter-spacing:1.5px}.stream-actions{display:flex;gap:5px}.stream-name{align-items:center;color:#e2e8f0;color:var(--text);display:flex;font-family:Syne,sans-serif;font-family:var(--font-sans);font-size:14px;font-weight:600;gap:7px}.stream-icon{flex-shrink:0}.stream-desc,.stream-icon{color:#4a5568;color:var(--muted)}.stream-desc{font-size:11px;line-height:1.4}.stream-url{background:#080b0f;background:var(--bg);border:1px solid #1a2233;border:1px solid var(--border);border-radius:5px;color:#00d4aa;color:var(--teal);font-size:10px;overflow:hidden;padding:6px 10px;text-overflow:ellipsis;white-space:nowrap}.stream-stats-row{display:flex;gap:8px}.stat-pill{background:#080b0f;background:var(--bg);border:1px solid #1a2233;border:1px solid var(--border);border-radius:5px;display:flex;flex:1 1;flex-direction:column;gap:2px;padding:6px 8px}.stat-pill-label{color:#4a5568;color:var(--muted);font-size:8px;letter-spacing:1px}.stat-pill-value{color:#e2e8f0;color:var(--text);font-size:11px}.output-badges{display:flex;flex-wrap:wrap;gap:5px}.output-badge{border:1px solid;border-radius:4px;font-weight:600;padding:2px 8px}.expand-btn,.output-badge{font-size:9px;letter-spacing:1px}.expand-btn{align-items:center;background:none;border:none;color:#4a5568;color:var(--muted);cursor:pointer;display:flex;font-family:JetBrains Mono,monospace;font-family:var(--font-mono);gap:5px;padding:2px 0}.expand-btn:hover{color:#e2e8f0;color:var(--text)}.stream-details{border-top:1px solid #1a2233;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:6px;padding-top:10px}.detail-row{align-items:center;display:flex;justify-content:space-between}.detail-label{color:#4a5568;color:var(--muted);font-size:9px;letter-spacing:1px}.detail-value{color:#e2e8f0;color:var(--text);font-size:11px}.output-list{display:flex;flex-direction:column;gap:5px}.output-row{align-items:center;background:#080b0f;background:var(--bg);border:1px solid #1a2233;border:1px solid var(--border);border-radius:5px;display:flex;gap:8px;padding:6px 8px}.output-type{flex-shrink:0;font-size:9px;font-weight:700;letter-spacing:1px}.output-url{color:#4a5568;color:var(--muted);flex:1 1;font-size:10px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.enabled-badge{color:#00d4aa;color:var(--teal);flex-shrink:0;font-size:9px}.disabled-badge{color:#4a5568;color:var(--muted);flex-shrink:0;font-size:9px}.page-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:28px}.page-title{color:#e2e8f0;color:var(--text);font-family:Syne,sans-serif;font-family:var(--font-sans);font-size:20px;font-weight:700}.page-sub{color:#4a5568;color:var(--muted);font-size:11px;margin-top:3px}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000bf;display:flex;inset:0;justify-content:center;padding:24px;position:fixed;z-index:1000}.modal{background:#0d1117;background:var(--surface);border:1px solid #243044;border:1px solid var(--border2);border-radius:12px;display:flex;flex-direction:column;max-height:90vh;max-width:640px;overflow-y:auto;width:100%}.modal--sm{max-width:440px}.modal-header{border-bottom:1px solid #1a2233;border-bottom:1px solid var(--border);justify-content:space-between;padding:20px 24px 16px}.modal-header,.modal-title-row{align-items:center;display:flex}.modal-title-row{gap:10px}.modal-icon{color:#00d4aa;color:var(--teal)}.modal-title{font-family:Syne,sans-serif;font-family:var(--font-sans);font-size:14px;font-weight:700;letter-spacing:1px}.modal-error{align-items:center;background:#ef444422;background:var(--red-dim);border-bottom:1px solid #ef444433;border-bottom:1px solid var(--red)33;color:#ef4444;color:var(--red);display:flex;font-size:11px;gap:8px;padding:10px 24px}.modal-form{gap:20px;padding:20px 24px}.form-section,.modal-form{display:flex;flex-direction:column}.form-section{border-bottom:1px solid #1a2233;border-bottom:1px solid var(--border);gap:12px;padding-bottom:20px}.form-section:last-child{border-bottom:none;padding-bottom:0}.form-section-title{color:#00d4aa;color:var(--teal);font-size:9px;font-weight:700;letter-spacing:2px}.form-section-title-row{align-items:center;display:flex;justify-content:space-between}.output-config{background:#080b0f;background:var(--bg);border:1px solid #1a2233;border:1px solid var(--border);border-radius:8px;padding:12px}.output-controls{gap:6px;padding-top:18px}.output-controls,.toggle-label{align-items:center;display:flex}.toggle-label{cursor:pointer;gap:5px;white-space:nowrap}.toggle-label input{accent-color:#00d4aa;accent-color:var(--teal)}.toggle-text{color:#4a5568;color:var(--muted);font-size:10px;letter-spacing:1px}.modal-footer{display:flex;gap:10px;justify-content:flex-end;padding-top:4px}.users-table{background:#0d1117;background:var(--surface);border:1px solid #1a2233;border:1px solid var(--border);border-radius:10px;overflow:hidden}.table-header-row{background:#111820;background:var(--surface2);color:#4a5568;color:var(--muted);font-size:9px;font-weight:600;letter-spacing:1.5px;padding:12px 20px}.table-header-row,.table-row{grid-gap:10px;border-bottom:1px solid #1a2233;border-bottom:1px solid var(--border);display:grid;gap:10px;grid-template-columns:180px 1fr 100px 100px 110px 80px}.table-row{align-items:center;padding:14px 20px;transition:background .1s}.table-row:last-child{border-bottom:none}.table-row:hover{background:#111820;background:var(--surface2)}.table-row--self{background:#00d4aa22;background:var(--teal-dim)}.user-cell{gap:10px}.user-avatar,.user-cell{align-items:center;display:flex}.user-avatar{border-radius:8px;flex-shrink:0;font-size:13px;font-weight:700;height:30px;justify-content:center;width:30px}.user-name{color:#e2e8f0;color:var(--text);font-size:12px;font-weight:500}.user-id{color:#4a5568;color:var(--muted);font-size:9px}.table-cell{color:#e2e8f0;color:var(--text);font-size:11px}.table-cell--muted{color:#4a5568;color:var(--muted)}.table-actions{display:flex;gap:5px;justify-content:flex-end}.role-badge{border:1px solid;border-radius:4px;display:inline-block}.role-badge,.status-chip{font-size:9px;font-weight:700;letter-spacing:1px;padding:3px 8px}.status-chip{border-radius:4px}.status-chip--active{background:#00d4aa22;background:var(--teal-dim);color:#00d4aa;color:var(--teal)}.status-chip--inactive{background:#2d3748;background:var(--muted2);color:#4a5568;color:var(--muted)}.empty-state{color:#4a5568;color:var(--muted);padding:64px 24px;text-align:center}.empty-icon{display:block;margin:0 auto 16px;opacity:.3}.empty-state p{color:#e2e8f0;color:var(--text);font-family:Syne,sans-serif;font-family:var(--font-sans);font-size:14px;margin-bottom:6px}.empty-state span{font-size:11px}.success-banner{align-items:center;background:#00d4aa22;background:var(--teal-dim);border:1px solid #00d4aa44;border:1px solid var(--teal)44;border-radius:7px;color:#00d4aa;color:var(--teal);display:flex;font-size:11px;gap:8px;margin-bottom:20px;padding:10px 14px}@keyframes spin{to{transform:rotate(1turn)}}.spin{animation:spin .8s linear infinite}::-webkit-scrollbar{height:5px;width:5px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#243044;background:var(--border2);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#4a5568;background:var(--muted)}@media (max-width:900px){.stat-grid{grid-template-columns:repeat(2,1fr)}.table-header-row,.table-row{grid-template-columns:1fr 1fr 80px}.table-header-row span:nth-child(2),.table-header-row span:nth-child(5),.table-row span:nth-child(2),.table-row span:nth-child(5){display:none}}@media (max-width:640px){.sidebar{width:60px}.nav-item span,.sidebar-cpu,.sidebar-live span,.sidebar-logo span,.user-info-text{display:none}.page{padding:20px 16px}.stat-grid{grid-template-columns:1fr 1fr}}
/*# sourceMappingURL=main.27aef5ee.css.map*/