:root{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;color:#1e293b;background:#f8fafc}*{-webkit-tap-highlight-color:transparent}*{box-sizing:border-box}body{margin:0}.app-shell{min-height:100vh;display:grid;grid-template-columns:240px 1fr}.sidebar{background:#0f172a;color:#e2e8f0;padding:20px}.sidebar h1{font-size:1.1rem;margin:0 0 18px}.sidebar-role{margin:0 0 12px;color:#93c5fd;font-size:.85rem}.sidebar nav{display:grid;gap:10px}.sidebar a{color:#cbd5e1;text-decoration:none}.content{padding:24px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px}.topbar-label{margin:0 0 4px;font-size:.78rem;color:#64748b;text-transform:uppercase;letter-spacing:.04em}.topbar-actions{margin-left:auto}.card{background:#fff;border:1px solid #dbe2ea;border-radius:10px;padding:14px;margin-bottom:16px}.muted{color:#64748b}.controls-row{display:flex;gap:12px;margin:12px 0}.controls-row.wrap{flex-wrap:wrap}.status-row{display:flex;gap:10px;margin:10px 0 14px;flex-wrap:wrap}.badge{display:inline-flex;align-items:center;border:1px solid #cbd5e1;border-radius:999px;padding:4px 10px;font-size:.82rem;background:#fff}.badge-ok{border-color:#16a34a;color:#166534;background:#dcfce7}.badge-warn{border-color:#f59e0b;color:#854d0e;background:#fef3c7}.badge-no-signal{border-color:#64748b;color:#334155;background:#e2e8f0}.badge-critical{border-color:#dc2626;color:#991b1b;background:#fee2e2}label{display:grid;gap:6px;font-size:.9rem}input,select,button{border:1px solid #cbd5e1;border-radius:8px;padding:8px 10px;font:inherit;color:#1e293b;background:#fff}.form-field{display:grid;gap:6px;font-size:.9rem}button{cursor:pointer;background:#f8fafc;transition:background .15s,opacity .15s,transform .1s}button:active:not(:disabled){transform:scale(.97)}.btn-secondary{background:#e2e8f0;color:#475569;font-size:.85rem}.button-link{border:1px solid #0f172a;border-radius:8px;padding:8px 12px;text-decoration:none;color:#0f172a;height:fit-content;align-self:end;background:#fff}.stats-grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.chart-card{min-height:320px}.chart-wrap{width:100%;min-height:260px}.big-number{font-size:2rem;margin:0}.form-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.button-row{display:flex;gap:8px;align-items:end}.signed-out-shell{min-height:100vh;min-height:100dvh;display:grid;place-items:center;padding:24px env(safe-area-inset-right) 24px env(safe-area-inset-left);background:radial-gradient(circle at top,rgba(14,165,233,.16),transparent 35%),linear-gradient(180deg,#eff6ff,#f8fafc)}.login-card{width:min(420px,100%);background:#fff;border:1px solid #dbe2ea;border-radius:16px;padding:36px 32px 32px;box-shadow:0 4px 24px #0f172a14;animation:login-fade-in .35s ease both}@keyframes login-fade-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes login-shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-6px)}80%{transform:translate(6px)}}.login-card--shake{animation:login-shake .45s ease}.login-header{text-align:center;margin-bottom:28px}.login-logo{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;background:#0f172a;color:#38bdf8;border-radius:14px;margin-bottom:14px}.login-title{margin:0 0 6px;font-size:1.5rem;font-weight:700;color:#0f172a}.login-subtitle{margin:0;color:#64748b;font-size:.9rem}.login-form{display:grid;gap:16px}.login-field{display:grid;gap:6px;font-size:.9rem;font-weight:500;color:#374151}.login-field input{width:100%;height:48px;padding:0 14px;font-size:1rem;border:1.5px solid #cbd5e1;border-radius:10px;transition:border-color .15s,box-shadow .15s;box-sizing:border-box}.login-field input:focus{outline:none;border-color:#0ea5e9;box-shadow:0 0 0 3px #0ea5e926}.password-wrap{position:relative}.password-wrap input{padding-right:48px}.password-toggle{position:absolute;right:0;top:0;height:48px;width:48px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:#64748b;border-radius:0 10px 10px 0;padding:0}.password-toggle:hover{color:#0f172a}.login-error{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#b91c1c;font-size:.875rem}.login-btn{height:48px;width:100%;background:#0f172a;color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:600;display:flex;align-items:center;justify-content:center;gap:10px;margin-top:4px;transition:background .15s,transform .1s,opacity .15s}.login-btn:hover:not(:disabled){background:#1e293b}.login-btn:active:not(:disabled){transform:scale(.98)}.login-btn:disabled{opacity:.65}@keyframes spin{to{transform:rotate(360deg)}}.login-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}.login-dev{width:100%;justify-content:center;font-size:.85rem}.signed-out-card{width:min(460px,100%)}.route-loading-card{min-height:180px;display:grid;place-items:center}.table-wrap{border:1px solid #dbe2ea;border-radius:10px;overflow:auto;background:#fff}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:12px 10px;border-bottom:1px solid #edf2f7;font-size:.9rem}thead th{background:#f8fafc;position:sticky;top:0}.error{color:#b91c1c}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a8c;display:grid;place-items:center;padding:20px}.modal{width:min(900px,100%);background:#fff;border-radius:12px;padding:14px;border:1px solid #dbe2ea}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.clip-player{width:100%;border-radius:10px;background:#020617}.player-shell{position:relative;margin-top:10px}.overlay-layer{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.overlay-box{position:absolute;border:2px solid #f97316;box-shadow:0 0 0 1px #02061773 inset}.overlay-label{position:absolute;left:0;top:-20px;font-size:.75rem;font-weight:600;color:#fff;background:#f97316;border-radius:4px;padding:2px 6px;white-space:nowrap}.thumb{width:72px;height:40px;object-fit:cover;border-radius:6px;border:1px solid #cbd5e1}.sidebar a,.sidebar-logout{transition:background .15s,color .15s}.sidebar a:active{opacity:.7}.sidebar-logout{display:none}@media (max-width: 900px){.app-shell{grid-template-columns:1fr}.sidebar{padding:12px 16px;padding-left:max(16px,env(safe-area-inset-left));padding-right:max(16px,env(safe-area-inset-right))}.sidebar h1{margin-bottom:10px}.sidebar-role{display:none}.sidebar nav{grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}.sidebar a{display:flex;align-items:center;justify-content:center;padding:10px 6px;border-radius:8px;font-size:.82rem;text-align:center;background:#ffffff0f;min-height:44px}.sidebar a:active{background:#ffffff24;opacity:1}.sidebar-logout{display:flex;align-items:center;justify-content:center;background:#1e293b;color:#e2e8f0;border-color:#334155;font-size:.82rem;min-height:44px;border-radius:8px}.sidebar-logout:active{background:#334155}.topbar-actions{display:none}.topbar{flex-direction:column;align-items:flex-start;gap:4px}.content{padding:16px;padding-bottom:max(16px,env(safe-area-inset-bottom))}}
