:root{font-family:DM Sans,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.6;font-weight:400;color:#0f172a;background:#f1f5f9;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}a{color:#2563eb}button{font:inherit;cursor:pointer}button:disabled{opacity:.55;cursor:not-allowed}input,select{font:inherit}.app-root{min-height:100vh;display:flex;flex-direction:column}.app-shell{flex:1;display:flex;min-height:0}.sidebar{width:260px;flex-shrink:0;background:#fff;border-right:1px solid #e2e8f0;padding:1rem}.main{flex:1;display:flex;flex-direction:column;min-height:0;padding:1.25rem 1.5rem 0}.main-scroll{flex:1 1 auto;min-height:0;overflow-y:auto}.main-header{font-size:1.75rem;font-weight:700;text-align:center;color:#2563eb;margin-bottom:1.25rem}.tabs{display:flex;gap:.35rem;flex-wrap:wrap;margin-bottom:1rem}.tab{padding:.5rem .85rem;border:1px solid #cbd5e1;border-radius:6px;background:#fff}.tab.active{background:#2563eb;color:#fff;border-color:#2563eb}.card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:1rem;margin-bottom:1rem}.rtsp-url{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;padding:.65rem .75rem;font-family:ui-monospace,monospace;font-size:.9rem;word-break:break-all}.row{display:flex;gap:1rem;flex-wrap:wrap}.col{flex:1;min-width:200px}.btn-primary{background:#2563eb;color:#fff;border:none;border-radius:6px;padding:.55rem 1rem;font-weight:600;text-align:center}.btn-primary:hover:not(:disabled){background:#1d4ed8}.btn-secondary{background:#e2e8f0;color:#0f172a;border:none;border-radius:6px;padding:.55rem 1rem;font-weight:600}.btn-danger{background:#dc2626;color:#fff;border:none;border-radius:6px;padding:.45rem .75rem;font-size:.875rem}.alert{border-radius:6px;padding:.75rem 1rem;margin:.5rem 0}.alert-error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.alert-success{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534}.alert-info{background:#eff6ff;border:1px solid #bfdbfe;color:#1e40af}.va-login-root{min-height:100vh;background:#f9fafb;color:#111827}.va-login-header{width:100%;border-bottom:1px solid #e5e7eb;background:#fff;box-shadow:0 1px 2px #0000000d}.va-login-header-inner{max-width:1440px;margin:0 auto;display:flex;align-items:center;gap:.75rem;padding:1.25rem 1rem;min-height:3.75rem;box-sizing:border-box}.va-login-brand-icon{width:2.5rem;height:2.5rem;flex-shrink:0;font-size:1.5rem;line-height:1;display:flex;align-items:center;justify-content:center}.va-login-brand-title{margin:0;font-size:1.25rem;line-height:1.75rem;font-weight:700;color:#111827;text-align:left}.va-login-main{margin:0 auto;display:flex;min-height:calc(100vh - 5.5rem);max-width:28rem;flex-direction:column;justify-content:center;padding:2rem 1rem}.va-login-card{border-radius:.5rem;border:1px solid #e5e7eb;background:#fff;padding:2rem;box-shadow:0 1px 2px #0000000d}.va-login-card h2{margin:0 0 .25rem;font-size:1.25rem;font-weight:700;color:#111827;text-align:center}.va-login-sub{margin:0 0 1.5rem;font-size:.875rem;color:#4b5563;text-align:center}.va-login-form{display:flex;flex-direction:column;gap:1rem}.va-login-field{display:flex;flex-direction:column;gap:.25rem}.va-login-label{display:block;font-size:.875rem;font-weight:400;color:#111827}.va-login-req{color:#ef4444;margin-left:.25rem}.va-login-input{width:100%;border-radius:.375rem;border:1px solid #d1d5db;padding:.5rem .75rem;font-size:.875rem;line-height:1.5;color:#111827;background:#fff;box-sizing:border-box}.va-login-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 1px #3b82f6}.va-login-input:disabled{background:#f3f4f6;color:#6b7280;cursor:not-allowed}.va-login-error{margin:0;font-size:.875rem;color:#dc2626}.va-login-submit{width:100%;margin-top:0;border:none;border-radius:.375rem;background:#2563eb;color:#fff;font-size:.875rem;font-weight:500;padding:.625rem 1rem;box-shadow:0 1px 2px #0000000d;cursor:pointer}.va-login-submit:hover:not(:disabled){background:#1d4ed8}.va-login-submit:disabled{opacity:.6;cursor:not-allowed}.field{margin-bottom:.85rem}.field label{display:block;font-size:.875rem;font-weight:600;margin-bottom:.25rem}.field input:not([type=checkbox]):not([type=radio]){width:100%;padding:.5rem .65rem;border:1px solid #94a3b8;border-radius:6px}.field label.checkbox-inline{display:flex;flex-direction:row;align-items:center;gap:.5rem;margin-bottom:0;cursor:pointer}.field label.checkbox-inline input[type=checkbox]{width:auto;margin:0;flex-shrink:0}.logout-bar{display:flex;justify-content:flex-end;margin-bottom:.75rem}.metric{font-size:1.5rem;font-weight:700}.metric-label{font-size:.75rem;color:#64748b;text-transform:uppercase}.stream-grid{display:grid;gap:.75rem}.stream-item{border:1px solid #e2e8f0;border-radius:8px;padding:.85rem;background:#fafafa}.stream-actions{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.65rem}.stream-actions>button{flex:0 0 auto;width:9rem;max-width:calc(50% - .25rem);box-sizing:border-box;text-align:center}.toast{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);z-index:10000;padding:.65rem 1.25rem;background:#1e293b;color:#fff;border-radius:.5rem;font-size:.875rem;font-weight:500;box-shadow:0 4px 14px #0000002e;pointer-events:none}.preview-img{max-width:100%;border-radius:8px;border:1px solid #e2e8f0;background:#000}.code-block{background:#0f172a;color:#e2e8f0;padding:1rem;border-radius:8px;overflow:auto;font-size:.8rem;line-height:1.45}.footer{flex-shrink:0;text-align:center;color:#64748b;font-size:.875rem;margin-top:auto;padding-top:1.25rem;padding-bottom:1.5rem;border-top:1px solid #e2e8f0}.progress-wrap{margin:.65rem 0}.progress-label{font-size:.8125rem;color:#475569;margin-bottom:.3rem}.progress-bar-bg{height:10px;border-radius:6px;background:#e2e8f0;overflow:hidden}.progress-bar-fill{height:100%;border-radius:6px;background:#2563eb;transition:width .15s ease-out}
