.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}:root{--bg: #080c18;--card: #0f1729;--card-2: #182034;--ink: #e8edf5;--muted: #8b9dc3;--accent: #2563eb;--accent-2: #3b82f6;--tint-1: rgba(37, 99, 235, .15);--tint-2: rgba(37, 99, 235, .06);--tint-strong: rgba(37, 99, 235, .28);--bg-1: #111d36;--bg-2: #0a1225;--bg-3: #050914;--glow-1: rgba(37, 99, 235, .3);--glow-2: rgba(59, 130, 246, .15);--border: rgba(255, 255, 255, .08);--shadow: 0 25px 50px rgba(0, 0, 0, .5);--surface: #111d36;--danger: #ef4444;--error: #ef4444;--success: #22c55e;--bg-elevated: #111d36;--accent-hover: #1d4ed8;--fg: #e8edf5;--hover: rgba(255, 255, 255, .04);--tint: rgba(37, 99, 235, .08)}html[data-theme=light]{--bg: #F8FAFC;--card: #ffffff;--card-2: #F1F5F9;--ink: #1E293B;--muted: #64748B;--accent: #2563EB;--accent-2: #3B82F6;--tint-1: rgba(37, 99, 235, .06);--tint-2: rgba(37, 99, 235, .03);--tint-strong: rgba(37, 99, 235, .15);--bg-1: #F1F5F9;--bg-2: #F8FAFC;--bg-3: #E2E8F0;--glow-1: rgba(37, 99, 235, .12);--glow-2: rgba(59, 130, 246, .08);--border: #E2E8F0;--shadow: 0 1px 3px rgba(0,0,0,.06), 0 4px 16px rgba(0,0,0,.04);--surface: #F1F5F9;--danger: #dc2626;--error: #dc2626;--success: #16a34a;--bg-elevated: #ffffff;--accent-hover: #1D4ED8;--fg: #1E293B;--hover: rgba(37, 99, 235, .04);--tint: rgba(37, 99, 235, .03)}*{box-sizing:border-box}body{margin:0;font-family:Sora,sans-serif;background:radial-gradient(ellipse at top left,var(--bg-1) 0%,var(--bg-2) 50%,var(--bg-3) 100%);color:var(--ink);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased}html[data-theme=light] body{background:#f8fafc}#root:before{content:"";position:fixed;top:-20%;right:0;bottom:0;left:-30%;background:radial-gradient(circle at 15% 15%,var(--glow-1),transparent 50%),radial-gradient(circle at 85% 20%,var(--glow-2),transparent 40%);filter:blur(0px);z-index:-1}html[data-theme=light] #root:before{display:none}html[data-palette=blue]{--accent: #ef4444;--accent-2: #f97316;--glow-1: rgba(239, 68, 68, .35);--glow-2: rgba(249, 115, 22, .2);--tint-1: rgba(239, 68, 68, .15);--tint-2: rgba(239, 68, 68, .06);--tint-strong: rgba(239, 68, 68, .3)}html[data-theme=dark][data-palette=blue]{--bg-1: #1a0f0f;--bg-2: #120a0a;--bg-3: #080505}html[data-palette=knight]{--accent: #facc15;--accent-2: #fbbf24;--glow-1: rgba(250, 204, 21, .35);--glow-2: rgba(251, 191, 36, .25);--tint-1: rgba(250, 204, 21, .18);--tint-2: rgba(250, 204, 21, .06);--tint-strong: rgba(250, 204, 21, .3)}html[data-theme=dark][data-palette=knight]{--bg: #0c0f1a;--card: rgba(18, 24, 38, .85);--card-2: rgba(28, 36, 54, .7);--ink: #fafaf9;--muted: #a8a29e;--border: rgba(250, 204, 21, .1);--bg-1: #141826;--bg-2: #0c0f1a;--bg-3: #06080f}html[data-theme=light][data-palette=knight]{--bg: #FAFAF9;--card: #ffffff;--card-2: #F5F5F4;--ink: #1C1917;--muted: #6B7280;--bg-1: #F5F5F4;--bg-2: #FAFAF9;--bg-3: #E7E5E4;--border: #E5E7EB}html[data-palette=violet]{--accent: #8b5cf6;--accent-2: #a78bfa;--glow-1: rgba(139, 92, 246, .35);--glow-2: rgba(196, 181, 253, .25);--tint-1: rgba(139, 92, 246, .18);--tint-2: rgba(139, 92, 246, .06);--tint-strong: rgba(139, 92, 246, .3)}html[data-theme=dark][data-palette=violet]{--bg: #0f0720;--card: #1a0f30;--card-2: #2e1065;--ink: #f5f3ff;--muted: #c4b5fd;--bg-1: #1e1040;--bg-2: #0f0720;--bg-3: #050210;--border: rgba(196, 181, 253, .12)}html[data-theme=light][data-palette=violet]{--bg: #FAFAFF;--card: #ffffff;--card-2: #F5F3FF;--ink: #1E1B4B;--muted: #6B7280;--bg-1: #F5F3FF;--bg-2: #FAFAFF;--bg-3: #EDE9FE;--border: #E5E7EB}@keyframes universalPulse{0%,to{box-shadow:0 0 6px var(--glow-1),0 0 12px var(--glow-2)}50%{box-shadow:0 0 14px var(--glow-1),0 0 28px var(--glow-2)}}@keyframes glowBreathe{0%,to{opacity:.3}50%{opacity:.7}}html[data-theme=dark] body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;background:radial-gradient(ellipse 100% 50% at 50% 0%,var(--glow-1) 0%,transparent 55%),radial-gradient(ellipse 60% 40% at 15% 85%,var(--glow-2) 0%,transparent 50%),radial-gradient(ellipse 60% 40% at 85% 70%,var(--glow-2) 0%,transparent 50%);opacity:.25;pointer-events:none;animation:glowBreathe 12s ease-in-out infinite}html[data-theme=dark] body:after{content:"";position:fixed;bottom:0;left:0;right:0;height:200px;z-index:-1;background:linear-gradient(to top,var(--glow-2),transparent);opacity:.3;pointer-events:none;animation:glowBreathe 10s ease-in-out infinite reverse}html[data-theme=dark] .card{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-left:2px solid var(--accent);transition:all .35s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;box-shadow:inset 0 0 0 1px #ffffff0a}html[data-theme=dark] .card:after{content:"";position:absolute;top:0;left:-100%;width:60%;height:100%;background:linear-gradient(90deg,transparent,var(--tint-2),transparent);transition:left .6s ease;pointer-events:none}html[data-theme=dark] .card:hover:after{left:150%}html[data-theme=dark] .card:hover{border-left-color:var(--accent-2);box-shadow:var(--shadow),0 0 20px -4px var(--glow-1),inset 0 0 30px -20px var(--glow-2)}html[data-theme=dark] h1,html[data-theme=dark] h2{text-shadow:0 0 25px var(--glow-1),0 0 50px var(--glow-2)}html[data-theme=dark] .stat-value{text-shadow:0 0 18px var(--glow-1),0 0 35px var(--glow-2)}html[data-theme=dark] .nav .pill.active{border:1px solid color-mix(in srgb,var(--accent) 35%,transparent);animation:universalPulse 3s ease-in-out infinite}html[data-theme=dark] .nav .pill:hover:not(.active){background:var(--tint-1);transition:all .25s ease}html[data-theme=dark] button.primary{background:linear-gradient(135deg,var(--accent),var(--accent-2));box-shadow:0 0 14px var(--glow-1),0 2px 8px #0000004d;transition:all .3s ease;position:relative;overflow:hidden}html[data-theme=dark] button.primary:before{content:"";position:absolute;top:-50%;left:-60%;width:40%;height:200%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transform:skew(-15deg);transition:left .5s ease;pointer-events:none}html[data-theme=dark] button.primary:hover:before{left:140%}html[data-theme=dark] button.primary:hover{box-shadow:0 0 25px var(--glow-1),0 0 45px var(--glow-2),0 4px 12px #0006}html[data-theme=dark] input:focus,html[data-theme=dark] select:focus,html[data-theme=dark] textarea:focus{box-shadow:0 0 0 2px var(--tint-strong),0 0 18px -3px var(--glow-1);outline:none}html[data-theme=dark] .list-row:hover{background:var(--tint-2);box-shadow:inset 2px 0 0 var(--accent);transition:all .2s ease}html[data-theme=dark] .modal{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--tint-1);box-shadow:0 0 50px var(--glow-2),0 0 100px var(--glow-2),0 25px 60px #00000080}html[data-theme=dark] .loading-bar{box-shadow:0 0 16px var(--glow-1),0 0 30px var(--glow-2)}html[data-theme=dark] .eyebrow{color:var(--accent);text-shadow:0 0 12px var(--glow-1);letter-spacing:.3px}html[data-theme=dark] .login-card{backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border);border-left:3px solid var(--accent);box-shadow:var(--shadow),0 0 30px var(--glow-2)}html[data-theme=dark] .topbar{position:relative}html[data-theme=dark] .topbar:after{content:"";position:absolute;bottom:-1px;left:5%;right:5%;height:1px;background:linear-gradient(90deg,transparent,var(--accent),var(--accent-2),var(--accent),transparent);opacity:.4;animation:glowBreathe 4s ease-in-out infinite}html[data-theme=dark] .panel-header{border-bottom:1px solid var(--tint-1);padding-bottom:8px}html[data-theme=dark] th{text-shadow:0 0 8px var(--glow-2)}html[data-theme=dark] ::-webkit-scrollbar{width:8px;height:8px}html[data-theme=dark] ::-webkit-scrollbar-track{background:var(--bg);border-radius:4px}html[data-theme=dark] ::-webkit-scrollbar-thumb{background:var(--tint-strong);border-radius:4px;border:1px solid transparent}html[data-theme=dark] ::-webkit-scrollbar-thumb:hover{background:var(--accent)}html[data-theme=dark] ::selection{background:var(--tint-strong);color:var(--ink)}html[data-theme=dark] .badge:hover,html[data-theme=dark] .chip:hover{box-shadow:0 0 8px var(--glow-1);transition:all .2s ease}html[data-theme=dark] [data-tooltip]:hover:after{box-shadow:0 0 12px var(--glow-2)}html[data-theme=light] .card{background:#fffc;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border);box-shadow:0 1px 3px #0000000a,0 4px 16px #00000008}html[data-theme=light] .card:hover{box-shadow:0 4px 12px #0000000f,0 8px 24px #0000000a;border-color:#0000001a}html[data-theme=light] button.primary{box-shadow:0 1px 2px #00000014;transition:all .2s ease}html[data-theme=light] button.primary:hover{box-shadow:0 2px 8px #0000001f}html[data-theme=light] .modal{background:#ffffffd9;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid var(--border);box-shadow:0 16px 48px #0000001a,0 32px 80px #0000000d}html[data-theme=light] .modal-backdrop{background:#0f172a40;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}html[data-theme=light] input:focus,html[data-theme=light] select:focus,html[data-theme=light] textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #2563eb1f;outline:none}html[data-theme=light] textarea{background:#00000008;border-color:var(--border)}html[data-theme=light] .sidebar{background:#ffffffb3;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-right:1px solid var(--border)}html[data-theme=light] .topbar{background:#ffffffbf;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border)}html[data-theme=light] .topbar:after{display:none}html[data-theme=light] .sidebar-item:hover{background:var(--tint-1)}html[data-theme=light] .sidebar-item.active{background:var(--tint-1);color:var(--accent)}html[data-theme=light] .sidebar-sub-item:hover{background:var(--tint-1)}html[data-theme=light] .sidebar-sub-item.active{background:color-mix(in srgb,var(--accent) 10%,transparent);color:var(--accent)}html[data-theme=light] .nav .pill{background:#0f172a0a;border-color:#0f172a14;color:#475569}html[data-theme=light] .nav .pill:hover:not(.active){background:#0f172a14;color:#1e293b;border-color:#0f172a1f}html[data-theme=light] .nav .pill.active{background:color-mix(in srgb,var(--accent) 14%,transparent);color:var(--accent);border-color:color-mix(in srgb,var(--accent) 25%,transparent);box-shadow:none}html[data-theme=light] .list-row:hover{background:var(--tint-2)}html[data-theme=light] .table-row.header,html[data-theme=light] .table-row.head{background:var(--surface);border-bottom:1px solid var(--border)}html[data-theme=light] .stat{background:#ffffffb3;border:1px solid var(--border);border-top:none}html[data-theme=light] .card.panel .panel-header{border-left:none}html[data-theme=light] .form-section{border-left-color:var(--border)}html[data-theme=light] .docs-card{border-left-color:var(--border);background:#fff}html[data-theme=light] .settings-card,html[data-theme=light] .config-log-meta,html[data-theme=light] .cert-panel-header{border-left-color:var(--border)}html[data-theme=light] .banner.warning{border-left-color:#f59e0b;background:#fffbeb}html[data-theme=light] .banner.info{border-left-color:var(--accent);background:#eff6ff}html[data-theme=light] .banner.success{background:#f0fdf4;border-left:3px solid var(--success)}html[data-theme=light] .banner.error{background:#fef2f2}html[data-theme=light] .modal-header{border-bottom:1px solid var(--border)}html[data-theme=light] .login-card{background:#fffc;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid var(--border);box-shadow:0 8px 32px #0000000f,0 24px 64px #00000008}html[data-theme=light] .search-modal{background:#ffffffd9;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid var(--border);box-shadow:0 16px 48px #0000001a}html[data-theme=light] ::selection{background:#2563eb26;color:var(--ink)}html[data-theme=light] ::-webkit-scrollbar{width:8px;height:8px}html[data-theme=light] ::-webkit-scrollbar-track{background:transparent}html[data-theme=light] ::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}html[data-theme=light] ::-webkit-scrollbar-thumb:hover{background:#94a3b8}html[data-theme=light] .filter-pills .pill,html[data-theme=light] .docs-categories .pill{background:#0f172a0a;border-color:#0f172a1a;color:#475569}html[data-theme=light] .filter-pills .pill:hover:not(.active),html[data-theme=light] .docs-categories .pill:hover:not(.active){background:#0f172a14;color:#1e293b}html[data-theme=light] .filter-pills .pill.active,html[data-theme=light] .docs-categories .pill.active{background:color-mix(in srgb,var(--accent) 14%,transparent);color:var(--accent);border-color:color-mix(in srgb,var(--accent) 25%,transparent);box-shadow:none}html[data-theme=light] .profile-menu{background:#ffffffd9;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-color:var(--border);box-shadow:0 8px 32px #00000014,0 2px 8px #0000000a}html[data-theme=light] .badge,html[data-theme=light] .log-viewer{background:var(--surface);border:1px solid var(--border)}html[data-theme=light] .card.panel .panel-header h2{background:none;-webkit-background-clip:unset;-webkit-text-fill-color:var(--ink)}html[data-theme=light] .docs-code{background:var(--surface);border:1px solid var(--border)}html[data-theme=light] tbody tr:nth-child(2n){background:#f1f5f980}@keyframes authcoreGlow{0%,to{opacity:.04}50%{opacity:.08}}@keyframes authcoreSweep{0%{background-position:-200% 0}to{background-position:200% 0}}html[data-theme=dark][data-palette=authcore]{--bg-1: #0a0f1e;--bg-2: #0d1426;--bg-3: #111827;--card: rgba(15, 23, 42, .85);--card-2: rgba(30, 41, 59, .7);--border: rgba(37, 99, 235, .12);--fg: #e2e8f0;--muted: #94a3b8;--accent: #2563eb;--accent-2: #818cf8;--hover: rgba(37, 99, 235, .08);--tint: rgba(37, 99, 235, .06);--tint-1: rgba(37, 99, 235, .06);--tint-2: rgba(37, 99, 235, .1);--glow-1: rgba(37, 99, 235, .3);--glow-2: rgba(129, 140, 248, .2);--shadow: 0 2px 12px rgba(0, 0, 0, .3)}html[data-theme=light][data-palette=authcore]{--accent: #2563eb;--accent-2: #818cf8}html[data-theme=dark][data-palette=authcore] body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;background:radial-gradient(ellipse 600px 400px at 20% 20%,rgba(37,99,235,.08),transparent),radial-gradient(ellipse 500px 500px at 80% 80%,rgba(129,140,248,.06),transparent);animation:authcoreGlow 12s ease-in-out infinite}html[data-theme=dark][data-palette=authcore] body:after{content:"";position:fixed;bottom:0;left:0;right:0;height:200px;z-index:-1;pointer-events:none;background:linear-gradient(to top,rgba(37,99,235,.04),transparent)}html[data-theme=dark][data-palette=authcore] .card{border:1px solid rgba(37,99,235,.1);transition:border-color .2s ease}html[data-theme=dark][data-palette=authcore] .card:hover{border-color:#2563eb40}html[data-theme=dark][data-palette=authcore] h1,html[data-theme=dark][data-palette=authcore] h2{text-shadow:0 0 20px rgba(37,99,235,.15)}html[data-theme=dark][data-palette=authcore] .sidebar-item.active{background:linear-gradient(135deg,#2563eb,#4f46e5)}html[data-theme=dark][data-palette=authcore] button.primary{background:linear-gradient(135deg,#2563eb,#4f46e5);box-shadow:0 2px 8px #2563eb4d}html[data-theme=dark][data-palette=authcore] button.primary:hover{background:linear-gradient(135deg,#3b82f6,#6366f1);box-shadow:0 4px 16px #2563eb66}html[data-theme=dark][data-palette=authcore] .stat-value{text-shadow:0 0 12px rgba(37,99,235,.25)}html[data-theme=dark][data-palette=authcore] .loading-bar{background:linear-gradient(90deg,#2563eb,#818cf8,#2563eb);background-size:200% 100%;animation:authcoreSweep 2s linear infinite;box-shadow:0 0 10px #2563eb80}html[data-palette=authcore] .eyebrow{color:var(--accent)}html[data-theme=dark][data-palette=authcore] .list-row:hover{background:#2563eb0f;box-shadow:inset 2px 0 0 var(--accent)}html[data-theme=dark][data-palette=authcore] input:focus,html[data-theme=dark][data-palette=authcore] select:focus,html[data-theme=dark][data-palette=authcore] textarea:focus{box-shadow:0 0 0 2px #2563eb40}html[data-theme=dark][data-palette=authcore] .modal{border:1px solid rgba(37,99,235,.15);box-shadow:0 25px 60px #00000080,0 0 30px #2563eb14}html[data-theme=dark][data-palette=authcore] .topbar:after{background:linear-gradient(90deg,transparent,#2563eb,#818cf8,#2563eb,transparent);opacity:.4;height:1px}html[data-theme=dark][data-palette=authcore] .login-card{border:1px solid rgba(37,99,235,.12);box-shadow:0 4px 24px #0006,0 0 30px #2563eb0f}html[data-theme=dark][data-palette=authcore] th{text-shadow:0 0 8px rgba(37,99,235,.15);border-bottom:1px solid rgba(37,99,235,.08)}html[data-theme=dark][data-palette=authcore] .panel-header{border-bottom:1px solid rgba(37,99,235,.1)}html[data-theme=dark][data-palette=authcore] .card:after{background:linear-gradient(90deg,transparent,rgba(37,99,235,.04),transparent)}@keyframes emberSweep{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes emberBreath{0%,to{opacity:1}50%{opacity:.7}}html[data-theme=dark][data-palette=blue] body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;background:radial-gradient(ellipse 600px 400px at 20% 20%,rgba(239,68,68,.06),transparent),radial-gradient(ellipse 500px 500px at 80% 80%,rgba(249,115,22,.04),transparent);animation:emberBreath 12s ease-in-out infinite}html[data-theme=dark][data-palette=blue] body:after{content:"";position:fixed;bottom:0;left:0;right:0;height:200px;z-index:-1;pointer-events:none;background:linear-gradient(to top,rgba(239,68,68,.04),transparent)}html[data-theme=dark][data-palette=blue] .card{border:1px solid rgba(239,68,68,.1);transition:border-color .2s ease}html[data-theme=dark][data-palette=blue] .card:hover{border-color:#ef444438}html[data-theme=dark][data-palette=blue] h1,html[data-theme=dark][data-palette=blue] h2{text-shadow:0 0 20px rgba(239,68,68,.15)}html[data-theme=dark][data-palette=blue] .sidebar-item.active{background:linear-gradient(135deg,#dc2626,#ef4444)}html[data-theme=dark][data-palette=blue] button.primary{background:linear-gradient(135deg,#dc2626,#ef4444);box-shadow:0 2px 8px #ef44444d}html[data-theme=dark][data-palette=blue] button.primary:hover{background:linear-gradient(135deg,#ef4444,#f97316);box-shadow:0 4px 16px #ef444466}html[data-theme=dark][data-palette=blue] .stat-value{text-shadow:0 0 12px rgba(239,68,68,.25)}html[data-theme=dark][data-palette=blue] .loading-bar{background:linear-gradient(90deg,#dc2626,#ef4444,#dc2626);background-size:200% 100%;animation:emberSweep 2s linear infinite;box-shadow:0 0 10px #ef444480}html[data-palette=blue] .eyebrow{color:var(--accent)}html[data-theme=dark][data-palette=blue] .list-row:hover{background:#ef44440f;box-shadow:inset 2px 0 0 var(--accent)}html[data-theme=dark][data-palette=blue] input:focus,html[data-theme=dark][data-palette=blue] select:focus,html[data-theme=dark][data-palette=blue] textarea:focus{box-shadow:0 0 0 2px #ef444440}html[data-theme=dark][data-palette=blue] .modal{border:1px solid rgba(239,68,68,.12);box-shadow:0 25px 60px #00000080,0 0 30px #ef44440f}html[data-theme=dark][data-palette=blue] .topbar:after{background:linear-gradient(90deg,transparent,#dc2626,#ef4444,#dc2626,transparent);opacity:.4;height:1px}html[data-theme=dark][data-palette=blue] .login-card{border:1px solid rgba(239,68,68,.1);box-shadow:0 4px 24px #0006,0 0 30px #ef44440d}html[data-theme=dark][data-palette=blue] th{text-shadow:0 0 8px rgba(239,68,68,.15);border-bottom:1px solid rgba(239,68,68,.08)}html[data-theme=dark][data-palette=blue] .panel-header{border-bottom:1px solid rgba(239,68,68,.08)}html[data-theme=dark][data-palette=blue] .card:after{background:linear-gradient(90deg,transparent,rgba(239,68,68,.04),transparent)}@keyframes revLine{0%{background-position:200% center}to{background-position:-200% center}}@keyframes gothamBreath{0%,to{opacity:.04}50%{opacity:.08}}@keyframes knightWatch{0%{transform:scale(1);opacity:.03}50%{transform:scale(1.05);opacity:.06}to{transform:scale(1);opacity:.03}}html[data-theme=dark][data-palette=knight] body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;background:radial-gradient(ellipse 600px 400px at 20% 20%,rgba(250,204,21,.06),transparent),radial-gradient(ellipse 500px 500px at 80% 80%,rgba(251,191,36,.04),transparent);animation:gothamBreath 12s ease-in-out infinite}html[data-theme=dark][data-palette=knight] body:after{content:"";position:fixed;bottom:0;left:0;right:0;height:200px;z-index:-1;pointer-events:none;background:linear-gradient(to top,rgba(250,204,21,.04),transparent)}html[data-theme=dark][data-palette=knight] #root:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;pointer-events:none;background:radial-gradient(300px 300px at 15% 70%,rgba(250,204,21,.05),transparent),radial-gradient(250px 250px at 85% 25%,rgba(251,191,36,.04),transparent);animation:knightWatch 18s ease-in-out infinite}html[data-theme=dark][data-palette=knight] .card{border:1px solid rgba(250,204,21,.08);transition:border-color .2s ease}html[data-theme=dark][data-palette=knight] .card:hover{border-color:#facc1533}html[data-theme=dark][data-palette=knight] h1,html[data-theme=dark][data-palette=knight] h2{text-shadow:0 0 20px rgba(250,204,21,.15)}html[data-theme=dark][data-palette=knight] .sidebar-item.active{background:linear-gradient(135deg,#d97706,#ca8a04)}html[data-theme=dark][data-palette=knight] .loading-bar{background:linear-gradient(90deg,#d97706,#facc15,#d97706);background-size:200% 100%;animation:revLine 2s linear infinite;box-shadow:0 0 10px #facc1580}html[data-theme=dark][data-palette=knight] button.primary{background:linear-gradient(135deg,#d97706,#ca8a04);color:#0c0a09;box-shadow:0 2px 8px #facc1540}html[data-theme=dark][data-palette=knight] button.primary:hover{background:linear-gradient(135deg,#facc15,#d97706);box-shadow:0 4px 16px #facc1559}html[data-theme=dark][data-palette=knight] .stat-value{text-shadow:0 0 12px rgba(250,204,21,.25)}html[data-theme=dark][data-palette=knight] .list-row:hover{background:#facc150d;box-shadow:inset 2px 0 0 var(--accent)}html[data-theme=dark][data-palette=knight] input:focus,html[data-theme=dark][data-palette=knight] select:focus,html[data-theme=dark][data-palette=knight] textarea:focus{box-shadow:0 0 0 2px #facc1533}html[data-theme=dark][data-palette=knight] .modal{border:1px solid rgba(250,204,21,.12);box-shadow:0 25px 60px #00000080,0 0 30px #facc150f}html[data-palette=knight] .eyebrow{color:var(--accent)}html[data-theme=dark][data-palette=knight] .topbar:after{background:linear-gradient(90deg,transparent,#d97706,#facc15,#d97706,transparent);opacity:.4;height:1px}html[data-theme=dark][data-palette=knight] .login-card{border:1px solid rgba(250,204,21,.1);box-shadow:0 4px 24px #0006,0 0 30px #facc150d}html[data-theme=dark][data-palette=knight] th{text-shadow:0 0 8px rgba(250,204,21,.15);border-bottom:1px solid rgba(250,204,21,.08)}html[data-theme=dark][data-palette=knight] .card:after{background:linear-gradient(90deg,transparent,rgba(250,204,21,.03),transparent)}html[data-theme=dark][data-palette=knight] .panel-header{border-bottom:1px solid rgba(250,204,21,.08)}@keyframes retroGrid{0%,to{opacity:1}50%{opacity:.7}}@keyframes synthSweep{0%{background-position:-200% 0}to{background-position:200% 0}}html[data-theme=dark][data-palette=violet] body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;background:radial-gradient(ellipse 600px 400px at 20% 20%,rgba(139,92,246,.07),transparent),radial-gradient(ellipse 500px 500px at 80% 80%,rgba(167,139,250,.05),transparent);animation:retroGrid 12s ease-in-out infinite}html[data-theme=dark][data-palette=violet] body:after{content:"";position:fixed;bottom:0;left:0;right:0;height:200px;z-index:-1;pointer-events:none;background:linear-gradient(to top,rgba(139,92,246,.04),transparent)}html[data-theme=dark][data-palette=violet] .card{border:1px solid rgba(139,92,246,.1);transition:border-color .2s ease}html[data-theme=dark][data-palette=violet] .card:hover{border-color:#8b5cf638}html[data-theme=dark][data-palette=violet] h1,html[data-theme=dark][data-palette=violet] h2{text-shadow:0 0 20px rgba(139,92,246,.15)}html[data-theme=dark][data-palette=violet] .sidebar-item.active{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}html[data-theme=dark][data-palette=violet] button.primary{background:linear-gradient(135deg,#8b5cf6,#7c3aed);box-shadow:0 2px 8px #8b5cf64d}html[data-theme=dark][data-palette=violet] button.primary:hover{background:linear-gradient(135deg,#a78bfa,#8b5cf6);box-shadow:0 4px 16px #8b5cf666}html[data-theme=dark][data-palette=violet] .loading-bar{background:linear-gradient(90deg,#8b5cf6,#a78bfa,#8b5cf6);background-size:200% 100%;animation:synthSweep 2s linear infinite;box-shadow:0 0 10px #8b5cf680}html[data-theme=dark][data-palette=violet] .stat-value{text-shadow:0 0 12px rgba(139,92,246,.25)}html[data-theme=dark][data-palette=violet] .list-row:hover{background:#8b5cf60f;box-shadow:inset 2px 0 0 var(--accent)}html[data-theme=dark][data-palette=violet] input:focus,html[data-theme=dark][data-palette=violet] select:focus,html[data-theme=dark][data-palette=violet] textarea:focus{box-shadow:0 0 0 2px #8b5cf640}html[data-theme=dark][data-palette=violet] .modal{border:1px solid rgba(139,92,246,.12);box-shadow:0 25px 60px #00000080,0 0 30px #8b5cf60f}html[data-palette=violet] .eyebrow{color:var(--accent)}html[data-theme=dark][data-palette=violet] .topbar:after{background:linear-gradient(90deg,transparent,#8b5cf6,#a78bfa,#8b5cf6,transparent);opacity:.4;height:1px}html[data-theme=dark][data-palette=violet] .login-card{border:1px solid rgba(139,92,246,.1);box-shadow:0 4px 24px #0006,0 0 30px #8b5cf60d}html[data-theme=dark][data-palette=violet] th{text-shadow:0 0 8px rgba(139,92,246,.15);border-bottom:1px solid rgba(139,92,246,.08)}html[data-theme=dark][data-palette=violet] .card:after{background:linear-gradient(90deg,transparent,rgba(139,92,246,.04),transparent)}html[data-theme=dark][data-palette=violet] .panel-header{border-bottom:1px solid rgba(139,92,246,.08)}html[data-theme=dark][data-palette=violet] #root:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;background:radial-gradient(ellipse at center,transparent 50%,rgba(0,0,0,.25) 100%)}h1,h2{font-family:Sora,sans-serif;margin:0}.app-layout{display:flex;min-height:100vh}.sidebar{width:240px;min-width:240px;height:100vh;position:fixed;top:0;left:0;z-index:50;display:flex;flex-direction:column;background:#ffffff08;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-right:1px solid rgba(255,255,255,.06);transition:width .2s ease,min-width .2s ease}.sidebar-collapsed .sidebar{width:64px;min-width:64px}.sidebar-header{display:flex;flex-direction:column;align-items:center;gap:4px;padding:24px 20px;border-bottom:1px solid rgba(255,255,255,.06);min-height:80px;position:relative}.sidebar-logo-wrap{width:100%;max-width:220px;height:56px;overflow:hidden;flex-shrink:0;clip-path:inset(0)}.sidebar-logo{width:100%;height:56px;object-fit:contain;transform:scale(2.8);transform-origin:center center}.sidebar-title{font-size:0;font-weight:700;color:var(--ink);white-space:nowrap;overflow:hidden;height:0}.sidebar-toggle{position:absolute;top:12px;right:12px;background:none;border:none;color:var(--muted);padding:6px;border-radius:10px;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center}.sidebar-toggle:hover{background:var(--tint-1);color:var(--ink)}.sidebar-collapsed .sidebar-toggle{position:static;margin:0 auto}.sidebar-nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:8px;display:flex;flex-direction:column;gap:2px}.sidebar-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:10px;background:none;border:none;color:var(--muted);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s ease;white-space:nowrap;width:100%;text-align:left;min-height:40px}.sidebar-item:hover{background:#ffffff0f;color:var(--ink)}.sidebar-item.active{background:linear-gradient(120deg,var(--accent),var(--accent-2));color:#fff;font-weight:600}.sidebar-icon{width:20px;height:20px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.sidebar-icon svg{width:20px;height:20px}.sidebar-label{overflow:hidden;text-overflow:ellipsis}.sidebar-chevron{margin-left:auto;opacity:.5;transition:transform .2s ease;flex-shrink:0}.sidebar-chevron.open{transform:rotate(180deg)}.sidebar-subs{display:flex;flex-direction:column;gap:1px;padding:2px 0 4px 32px}.sidebar-sub-item{display:block;width:100%;text-align:left;padding:7px 12px;border-radius:8px;background:none;border:none;color:var(--muted);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s ease;white-space:nowrap}.sidebar-sub-item:hover{background:#ffffff0f;color:var(--ink)}.sidebar-sub-item.active{color:var(--accent);background:color-mix(in srgb,var(--accent) 12%,transparent);font-weight:600}.sidebar-divider{height:1px;background:var(--border);margin:6px 4px}.sidebar-footer{padding:8px;border-top:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;gap:4px}.sidebar-profile{position:relative}.sidebar-profile .profile-chip{width:100%;justify-content:flex-start}.sidebar-profile .profile-menu{position:absolute;bottom:calc(100% + 8px);left:0;top:auto;min-width:220px}.sidebar-collapsed .sidebar-profile .profile-menu{position:fixed;left:72px;bottom:12px;top:auto}.sidebar-collapsed .sidebar-header{padding:8px;min-height:0}.sidebar-collapsed .sidebar-logo-wrap{display:none}.sidebar-collapsed .sidebar-item{justify-content:center;padding:10px}.sidebar-collapsed .sidebar-nav,.sidebar-collapsed .sidebar-footer{padding:8px 6px}.sidebar-collapsed .sidebar-profile .profile-chip{justify-content:center;padding:8px}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:49}.hamburger-btn{display:none;background:none;border:none;color:var(--ink);padding:8px;border-radius:10px;cursor:pointer}.hamburger-btn:hover{background:var(--tint-1)}.main-area{flex:1;margin-left:240px;display:flex;flex-direction:column;min-height:100vh;transition:margin-left .2s ease}.sidebar-collapsed .main-area{margin-left:64px}.topbar{display:flex;align-items:center;gap:16px;padding:12px 28px;border-bottom:1px solid rgba(255,255,255,.06);background:#ffffff08;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);position:sticky;top:0;z-index:20;min-height:60px}.topbar-logo-wrap{display:none;width:200px;height:52px;overflow:hidden;flex-shrink:0;margin-right:8px}.sidebar-collapsed .topbar-logo-wrap{display:block}.topbar-logo{height:52px;width:auto;transform:scale(3);transform-origin:left center}.topbar-title{flex:1;min-width:0}.topbar-title h1{font-size:18px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar-status{display:flex;align-items:center;gap:6px;margin-top:2px}.topbar-time{font-size:11px;color:var(--muted)}.topbar-actions{display:flex;align-items:center;gap:8px}.icon-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;background:none;border:1px solid var(--border);color:var(--muted);cursor:pointer;transition:all .15s ease;padding:0}.icon-btn:hover{background:var(--tint-1);color:var(--ink);border-color:var(--accent)}.main-content{flex:1;padding:24px 28px 60px;display:flex;flex-direction:column;gap:20px;animation:fadeIn .3s ease-out}@media (max-width: 1024px){.sidebar{transform:translate(-100%);width:260px;min-width:260px;box-shadow:none}.sidebar-collapsed .sidebar{width:260px;min-width:260px}.sidebar-mobile-open .sidebar{transform:translate(0);box-shadow:4px 0 24px #0003}.sidebar-mobile-open .sidebar-overlay{display:block}.sidebar-collapsed .sidebar-mobile-open .sidebar .sidebar-label,.sidebar-mobile-open .sidebar .sidebar-label{display:inline}.sidebar-mobile-open .sidebar .sidebar-item{justify-content:flex-start;padding:10px 12px}.main-area,.sidebar-collapsed .main-area{margin-left:0}.hamburger-btn{display:flex}.topbar-logo-wrap{display:block;width:160px;height:44px}.topbar-logo{height:44px;transform:scale(2.6)}.sidebar-toggle{display:none}.topbar{padding:12px 16px;gap:10px}.main-content{padding:20px 16px 60px}}@media (max-width: 480px){.topbar{padding:10px 12px;gap:8px;min-height:52px}.topbar h1{font-size:16px}.topbar-status{display:none}.topbar-logo-wrap{width:120px;height:36px}.topbar-logo{height:36px;transform:scale(2.2)}.main-content{padding:16px 10px 60px}.site-selector select{min-width:0;max-width:140px;font-size:12px;padding:6px 28px 6px 10px}.card,.card.panel{padding:14px 12px}}.app{padding:24px 5vw 60px;display:flex;flex-direction:column;gap:20px;animation:fadeIn .4s ease-out;max-width:min(1440px,100%);margin:0 auto}.brand{display:grid;grid-auto-flow:column;align-items:center;gap:8px;justify-content:start}.site-selector{display:inline-flex;align-items:center}.site-selector select{background:#ffffff0a;color:var(--ink);border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:8px 32px 8px 12px;font-size:14px;font-family:inherit;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%239ca3af' d='M2 4l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;min-width:140px}.site-selector select:hover{border-color:var(--accent)}.site-selector select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--tint-1)}.live-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-left:4px;vertical-align:middle}.live-dot.online{background:#22c55e;box-shadow:0 0 6px #22c55e}.live-dot.offline{background:#ef4444;box-shadow:0 0 6px #ef4444}.left-actions{display:inline-flex;align-items:center;gap:10px}.logo{width:120px;height:auto;max-width:100%}.app-logo{width:240px;height:auto;margin:-20px 0;display:block;line-height:0}.profile-dock{position:fixed;top:clamp(18px,3vw,32px);left:clamp(12px,2vw,24px);display:inline-flex;flex-direction:column;gap:10px;z-index:45;animation:slideDown .5s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-15px)}to{opacity:1;transform:translateY(0)}}.profile-chip{display:inline-flex;align-items:center;gap:6px;border:1px solid rgba(255,255,255,.08);background:#ffffff0a;color:var(--ink);padding:8px 14px;border-radius:12px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:border-color .2s ease,box-shadow .2s ease}.profile-chip:hover{border-color:var(--accent);box-shadow:0 2px 10px #0000001f}.avatar{width:28px;height:28px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(120deg,var(--accent),var(--accent-2));color:#08121f;font-weight:700;font-size:12px}.profile-name{font-size:13px;font-weight:600}.dropdown-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40}.profile-menu{position:absolute;top:calc(100% + 10px);left:0;width:max(220px,100%);max-width:min(320px,92vw);background:#141923eb;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.12);border-radius:16px;padding:16px;box-shadow:0 16px 48px #00000080;z-index:46;display:grid;gap:12px;animation:menuPop .2s cubic-bezier(.16,1,.3,1);transform-origin:top left}@keyframes menuPop{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.profile-header{display:flex;align-items:center;gap:12px;padding-bottom:12px;border-bottom:1px solid var(--border);margin-bottom:4px}.avatar.big{width:44px;height:44px;font-size:14px}.profile-actions{display:grid;gap:4px}.profile-actions button{justify-content:flex-start;padding:10px 12px;border-radius:10px;font-size:14px}.profile-actions button:hover{background:var(--tint-1)}.nav{display:flex;flex-wrap:wrap;gap:6px;animation:slideUp .35s ease-out}.nav .pill{border:1px solid rgba(255,255,255,.06);background:#ffffff08;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:var(--muted);padding:8px 18px;border-radius:8px;font-size:13px;font-weight:500;letter-spacing:.01em;transition:all .25s ease;cursor:pointer}.nav .pill:hover:not(.active){color:var(--ink);border-color:#ffffff1f;background:#ffffff12}.nav .pill:active{transform:scale(.97)}.nav .pill.active{background:color-mix(in srgb,var(--accent) 18%,transparent);color:var(--accent);border-color:color-mix(in srgb,var(--accent) 30%,transparent);box-shadow:0 0 12px color-mix(in srgb,var(--accent) 12%,transparent);font-weight:600}.eyebrow{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);margin-bottom:2px}.card{background:#ffffff0a;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:24px 28px;box-shadow:0 4px 24px #0003;animation:cardReveal .25s ease-out backwards;transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease}.card:hover{border-color:#ffffff24;box-shadow:0 8px 32px #0000004d}@keyframes cardReveal{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.grid>.card:nth-child(1){animation-delay:0ms}.grid>.card:nth-child(2){animation-delay:80ms}.grid>.card:nth-child(3){animation-delay:.16s}.grid>.card:nth-child(4){animation-delay:.24s}.grid>.card:nth-child(5){animation-delay:.32s}.grid>.card:nth-child(6){animation-delay:.4s}.card.panel{position:relative;overflow:hidden;border-left:2px solid color-mix(in srgb,var(--accent) 40%,transparent)}.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.stats.compact{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px}.stats-period-label{grid-column:1 / -1;text-align:center;padding:8px 16px;background:#ffffff0a;border-radius:10px;margin-bottom:4px}.stat{position:relative;overflow:hidden;border-radius:14px;animation:statPop .25s ease-out backwards;transition:border-color .2s ease,box-shadow .2s ease}.stat:hover{box-shadow:0 8px 24px #00000040;border-color:#ffffff24}.stats>.stat:nth-child(1){animation-delay:.1s}.stats>.stat:nth-child(2){animation-delay:.18s}.stats>.stat:nth-child(3){animation-delay:.26s}.stats>.stat:nth-child(4){animation-delay:.34s}.stats>.stat:nth-child(5){animation-delay:.42s}.stats>.stat:nth-child(6){animation-delay:.5s}@keyframes statPop{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.stat>*{position:relative}.stat .label{color:var(--muted);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.stat .value{font-size:26px;font-weight:700;margin:8px 0 4px;letter-spacing:-.02em}.stat .sub{color:var(--muted);font-size:11px}html[data-theme=light] .stat .value{color:var(--ink)}html[data-theme=light] .stat .label,html[data-theme=light] .stat .sub{color:#475569}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px;animation:gridFadeIn .3s ease-out}@keyframes gridFadeIn{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}.panel-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}.panel-header p{color:var(--muted);margin:4px 0 12px;font-size:13px;width:100%}.panel-header h2{font-size:15px;font-weight:700;margin:0}.filter-bar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;padding:10px 14px;background:#ffffff0a;border-radius:10px;border:1px solid rgba(255,255,255,.08);margin-bottom:12px}.filter-group{display:flex;align-items:center;gap:10px}.filter-group label{font-size:13px;font-weight:500;color:var(--muted);white-space:nowrap}.filter-group select{min-width:160px}.filter-pills{display:flex;gap:6px;margin-bottom:12px;flex-wrap:wrap}.pill.small{padding:5px 12px;font-size:12px;border-radius:6px;border:1px solid rgba(255,255,255,.06);background:#ffffff08;color:var(--muted);cursor:pointer;transition:all .25s ease}.pill.small:hover:not(.active){background:#ffffff12;color:var(--ink);border-color:#ffffff1f}.pill.small.active{background:color-mix(in srgb,var(--accent) 18%,transparent);color:var(--accent);border-color:color-mix(in srgb,var(--accent) 30%,transparent);font-weight:600}.table-row.error-row{border-left:3px solid var(--danger)}.error-card{background:#ff54681a!important;border-color:#ff54684d!important}.modal-card.wide.error-card{border-left:3px solid var(--danger);background:#ff546814!important}.error-card .label{color:var(--danger)}.modal-card.wide{grid-column:1 / -1}input{background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:10px 14px;color:var(--ink);font-size:14px;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}input:focus{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 15%,transparent);background:#ffffff12;outline:none}select{background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:10px 14px;color:var(--ink);font-size:14px;transition:border-color .2s ease,box-shadow .2s ease;cursor:pointer}select:hover{border-color:#fff3}select:focus{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 15%,transparent);outline:none}select option{background:var(--card);color:var(--ink)}html[data-theme=light] input,html[data-theme=light] select{background:#00000008;border-color:var(--border);color:var(--ink)}html[data-theme=light] input:focus,html[data-theme=light] select:focus{background:#fff}html[data-theme=light] select option{background:#fff;color:var(--ink)}button{border:none;border-radius:10px;padding:10px 18px;font-weight:600;cursor:pointer;transition:all .2s ease}@media (max-width: 720px){button.ghost,button.primary,button.danger{width:100%;min-width:0}}button.primary{background:linear-gradient(120deg,var(--accent),var(--accent-2));color:#fff}button.ghost{background:#ffffff0a;color:var(--ink);border:1px solid rgba(255,255,255,.1);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}button.ghost.success{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 55%,transparent);background:color-mix(in srgb,var(--tint-strong) 55%,transparent)}button.ghost.danger{color:color-mix(in srgb,var(--danger) 70%,white);border-color:#ff546873;background:#ff54681f}button.ghost:hover{background:#ffffff14;box-shadow:0 4px 16px #0003}button.ghost:active{opacity:.85}button.primary:hover{filter:brightness(1.1);box-shadow:0 6px 20px color-mix(in srgb,var(--accent) 35%,transparent);transform:translateY(-1px)}button.primary:active{opacity:.85}button.danger:hover{filter:brightness(1.08);box-shadow:0 6px 20px #ff546859}button.danger:active{opacity:.85}html[data-theme=light] button.ghost:hover{background:#2f7bff1f;border-color:#2f7bff4d}html[data-theme=light] button.ghost{color:var(--ink);border-color:var(--border);background:#ffffff80;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}html[data-theme=light] button.primary,html[data-theme=light] button.danger{color:#fff}html[data-theme=light] .banner.error{background:#ff54681f;color:#7a2230}.login-card .banner.error{animation:shake .5s cubic-bezier(.36,.07,.19,.97),fadeIn .3s ease-out}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-4px)}20%,40%,60%,80%{transform:translate(4px)}}button:disabled{opacity:.6;cursor:not-allowed}button.loading{position:relative;color:transparent!important;pointer-events:none}button.loading:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);background-size:200% 100%;animation:shimmer 1.5s infinite}button.loading:after{content:"";position:absolute;width:18px;height:18px;top:50%;left:50%;margin-left:-9px;margin-top:-9px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:spin .7s linear infinite}button.primary.loading:after{border-top-color:#0a1220}button.ghost.loading:after{border-top-color:var(--ink)}button.danger.loading:after{border-top-color:#0a1220}.list{margin-top:8px;display:flex;flex-direction:column;gap:2px}.list.scroll{max-height:420px;overflow:auto;padding-right:4px}.panel .list{margin-top:12px}.list-row{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:transparent;border-radius:10px;border:1px solid transparent;border-bottom:1px solid color-mix(in srgb,var(--border) 50%,transparent);transition:background .15s ease,border-color .15s ease}.list-row:last-child{border-bottom:none}.list-row:hover{background:color-mix(in srgb,var(--accent) 4%,transparent);border-color:color-mix(in srgb,var(--accent) 20%,transparent)}.list>.list-row:nth-child(2){animation-delay:40ms}.list>.list-row:nth-child(3){animation-delay:80ms}.list>.list-row:nth-child(4){animation-delay:.12s}.list>.list-row:nth-child(5){animation-delay:.16s}.list>.list-row:nth-child(6){animation-delay:.2s}.list>.list-row:nth-child(7){animation-delay:.24s}.list>.list-row:nth-child(8){animation-delay:.28s}.row-actions{display:flex;gap:8px;flex-wrap:wrap}.panel>.row-actions{margin:8px 0 6px}.list-row em{margin-left:10px;font-style:normal;color:var(--muted)}.list-row.disabled{opacity:.55}.table{display:flex;flex-direction:column;gap:8px}.table.scroll{max-height:420px;overflow:auto;padding-right:6px}.table.scroll .table-row.head{position:sticky;top:0;z-index:2;background:#0f1729e6;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}html[data-theme=light] .table.scroll .table-row.head{background:#ffffffe6}.table-row{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;padding:10px 14px;background:transparent;border-radius:10px;border:1px solid transparent;align-items:center;transition:background .15s ease,border-color .15s ease}.list>.table-row:nth-child(1){animation-delay:0ms}.list>.table-row:nth-child(2){animation-delay:40ms}.list>.table-row:nth-child(3){animation-delay:80ms}.list>.table-row:nth-child(4){animation-delay:.12s}.list>.table-row:nth-child(5){animation-delay:.16s}.list>.table-row:nth-child(6){animation-delay:.2s}.list>.table-row:nth-child(7){animation-delay:.24s}.list>.table-row:nth-child(8){animation-delay:.28s}.list>.table-row:nth-child(9){animation-delay:.32s}.list>.table-row:nth-child(10){animation-delay:.36s}@keyframes rowSlideIn{0%{opacity:0}to{opacity:1}}.table-row:not(.head):hover{background:#ffffff0a;border-color:#ffffff14}.table-row.clickable{cursor:pointer;transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}.table-row.clickable:hover{border-color:#ffffff1f;background:#ffffff0a}.table-row.head{background:transparent;border:none;border-bottom:1px solid rgba(255,255,255,.06);border-radius:0;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);padding-bottom:8px;margin-bottom:4px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#07090ea6;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);display:grid;place-items:center;z-index:100;animation:backdropFadeIn .3s ease-out;cursor:pointer}.modal-backdrop>*{cursor:default}@keyframes backdropFadeIn{0%{opacity:0;-webkit-backdrop-filter:blur(0);backdrop-filter:blur(0)}to{opacity:1;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}}.modal{width:min(880px,92vw);background:#ffffff0d;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.1);border-radius:24px;padding:32px 36px;box-shadow:0 40px 80px #00000080,0 0 1px #ffffff1a;display:grid;gap:18px;animation:modalSlideIn .3s cubic-bezier(.16,1,.3,1)}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:14px;border-bottom:1px solid rgba(255,255,255,.08);position:relative}.modal-header:after{content:"";position:absolute;bottom:-1px;left:0;width:60px;height:2px;background:linear-gradient(90deg,var(--accent),var(--accent-2));border-radius:1px}.modal-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.modal-card{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:12px 14px;animation:modalCardPop .3s ease-out backwards;transition:border-color .2s ease,background .2s ease}.modal-card:hover{border-color:#ffffff26;background:#ffffff0f}.modal-grid>.modal-card:nth-child(1){animation-delay:.1s}.modal-grid>.modal-card:nth-child(2){animation-delay:.15s}.modal-grid>.modal-card:nth-child(3){animation-delay:.2s}.modal-grid>.modal-card:nth-child(4){animation-delay:.25s}.modal-grid>.modal-card:nth-child(5){animation-delay:.3s}.modal-grid>.modal-card:nth-child(6){animation-delay:.35s}.modal-grid>.modal-card:nth-child(7){animation-delay:.4s}.modal-grid>.modal-card:nth-child(8){animation-delay:.45s}@keyframes modalCardPop{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.modal-card .label{text-transform:uppercase;font-size:10px;letter-spacing:.06em;font-weight:600;color:var(--muted)}.modal-card .value{margin-top:6px;font-size:15px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;border-top:1px solid var(--border);margin-top:16px;padding-top:16px}.wizard-body{display:grid;grid-template-columns:minmax(0,1fr) minmax(220px,.6fr);gap:16px;align-items:start}.wizard-help{background:linear-gradient(160deg,var(--card),var(--card-2)),linear-gradient(120deg,var(--tint-strong),transparent 60%);border:1px solid var(--border);border-radius:16px;padding:14px;color:var(--ink);display:grid;gap:8px;animation:slideInRight .4s ease-out}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.wizard-help h3{margin:0;font-size:16px}.wizard-help p{margin:0;color:var(--muted);font-size:13px;line-height:1.5}.config-log-meta{display:grid;gap:4px;border-left:3px solid var(--accent);padding-left:12px}.config-log-list{margin-top:8px}.wizard-steps .pill{background:#ffffff0a;color:var(--muted);border:1px solid var(--border)}.wizard-steps .pill.active{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;border-color:transparent;box-shadow:0 2px 8px color-mix(in srgb,var(--accent) 30%,transparent)}.wizard-steps .pill.done{background:#2ec47d2e;color:#c8f6e1;border-color:#2ec47d59}.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.wizard-nas-entry{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:14px;display:grid;gap:10px;margin-bottom:8px}.wizard-nas-header{display:flex;justify-content:space-between;align-items:center}.form-card{background:linear-gradient(160deg,var(--card),var(--card-2)),linear-gradient(120deg,var(--tint-strong),transparent 60%);border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:12px 14px;display:grid;gap:6px;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.form-card:hover{border-color:var(--accent)}.form-card .label{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.12em}.form-card .value{font-size:14px}.theme-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;max-height:380px;overflow-y:auto;padding-right:6px;scrollbar-width:thin;scrollbar-color:var(--accent) transparent}.theme-grid::-webkit-scrollbar{width:6px}.theme-grid::-webkit-scrollbar-track{background:transparent}.theme-grid::-webkit-scrollbar-thumb{background:var(--accent);border-radius:999px;opacity:.5}.theme-card{border:1px solid var(--border);border-radius:16px;padding:14px;background:linear-gradient(160deg,#0c1018b3,#0c101840),linear-gradient(120deg,var(--tint-strong),transparent 60%);display:grid;gap:10px;text-align:left;animation:themeCardPop .4s ease-out backwards;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;cursor:pointer}.theme-card:hover{box-shadow:0 8px 25px #00000026;border-color:color-mix(in srgb,var(--accent) 40%,transparent)}.theme-card:active{transform:scale(.98)}.theme-grid>.theme-card:nth-child(1){animation-delay:0ms}.theme-grid>.theme-card:nth-child(2){animation-delay:30ms}.theme-grid>.theme-card:nth-child(3){animation-delay:60ms}.theme-grid>.theme-card:nth-child(4){animation-delay:90ms}.theme-grid>.theme-card:nth-child(5){animation-delay:.12s}.theme-grid>.theme-card:nth-child(6){animation-delay:.15s}.theme-grid>.theme-card:nth-child(7){animation-delay:.18s}.theme-grid>.theme-card:nth-child(8){animation-delay:.21s}.theme-grid>.theme-card:nth-child(9){animation-delay:.24s}.theme-grid>.theme-card:nth-child(10){animation-delay:.27s}.theme-grid>.theme-card:nth-child(11){animation-delay:.3s}.theme-grid>.theme-card:nth-child(12){animation-delay:.33s}@keyframes themeCardPop{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}html[data-theme=light] .theme-card{background:linear-gradient(160deg,#ffffffeb,#f0f5fbd9),linear-gradient(120deg,var(--tint-strong),transparent 60%)}html[data-theme=light] .list-row,html[data-theme=light] .table-row,html[data-theme=light] .modal-card,html[data-theme=light] .form-card{background:#fff9;border-color:var(--border)}.theme-card.active{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 30%,transparent)}.theme-swatch{height:28px;border-radius:999px}.theme-name{font-weight:600;color:var(--ink)}.theme-sub{color:var(--muted);font-size:12px}.settings-modal{max-width:540px;width:100%}.settings-tabs{display:flex;gap:4px;padding:0 4px;margin-bottom:20px;border-bottom:1px solid var(--border)}.settings-tab{flex:1;padding:12px 16px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--muted);font-size:14px;font-weight:500;cursor:pointer;transition:all .25s ease;display:flex;align-items:center;justify-content:center;gap:8px}.settings-tab:hover{color:var(--ink);background:#ffffff0f}.settings-tab.active{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;border-bottom-color:var(--accent)}.tab-icon{font-size:16px}.settings-content{padding:0 4px}.settings-section{animation:settingsFadeIn .4s ease-out}@keyframes settingsFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.settings-form{display:flex;flex-direction:column;gap:16px}.settings-card{padding:16px;border-radius:14px;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-left:2px solid color-mix(in srgb,var(--accent) 25%,transparent);animation:settingsCardPop .4s ease-out backwards}.settings-card-header{display:flex;align-items:center;gap:14px}.settings-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:600;color:#fff;text-transform:uppercase}.settings-username{font-size:16px;font-weight:600;color:var(--ink)}.settings-role{font-size:13px;color:var(--muted)}.settings-field-group{display:grid;grid-template-columns:1fr 1fr;gap:12px}.settings-field{display:flex;flex-direction:column;gap:6px}.settings-field label{text-transform:uppercase;font-size:10px;letter-spacing:.06em;font-weight:600;color:var(--muted)}.settings-field input{padding:10px 14px;border-radius:10px;border:1px solid var(--border);background:var(--bg);color:var(--ink);font-size:14px;transition:all .2s ease}.settings-field input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #3ad0ff26}.settings-actions{display:flex;justify-content:flex-end;padding-top:8px}.settings-actions button{min-width:140px}.settings-error{padding:10px 14px;border-radius:10px;background:#ff54681f;border:1px solid rgba(255,84,104,.25);color:var(--danger);font-size:13px;animation:shake .4s ease}@keyframes settingsCardPop{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.settings-section .settings-card:nth-child(1){animation-delay:0ms}.settings-section .settings-card:nth-child(2){animation-delay:50ms}.settings-section .settings-field-group{animation:settingsFadeIn .4s ease-out .1s backwards}.settings-section .settings-field{animation:settingsFadeIn .4s ease-out .15s backwards}.settings-section .settings-actions{animation:settingsFadeIn .4s ease-out .2s backwards}html[data-theme=light] .settings-card{background:#fffc}html[data-theme=light] .settings-field input{background:#fff}.password-strength{margin-top:8px;animation:fadeIn .2s ease-out}.password-strength-bar{height:4px;background:#ffffff0f;border-radius:2px;overflow:hidden}.password-strength-fill{height:100%;border-radius:2px;transition:width .3s ease-out,background .3s ease-out}.password-strength-fill.weak{background:#ef4444}.password-strength-fill.fair{background:#f59e0b}.password-strength-fill.strong{background:#22c55e}.password-strength-label{font-size:11px;font-weight:600;margin-top:4px;text-transform:uppercase;letter-spacing:.5px}.password-strength-label.weak{color:#ef4444}.password-strength-label.fair{color:#f59e0b}.password-strength-label.strong{color:#22c55e}.password-strength-checks{display:flex;flex-wrap:wrap;gap:6px 12px;margin-top:8px;font-size:11px}.password-strength-checks .check{color:var(--muted);transition:color .2s ease}.password-strength-checks .check.pass{color:#22c55e}.password-strength-checks .check.fail{color:var(--muted);opacity:.7}.password-strength.compact{margin-top:4px}.password-strength.compact .password-strength-checks{display:none}.help-tip{position:relative;display:inline-flex;align-items:center;margin-left:6px;cursor:help}.help-tip-icon{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:var(--card-2);border:1px solid var(--border);color:var(--muted);font-size:10px;font-weight:600;transition:all .2s ease}.help-tip:hover .help-tip-icon{background:var(--accent);color:#fff;border-color:var(--accent)}.help-tip-text{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);width:max-content;max-width:280px;padding:8px 12px;background:#ffffff0f;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.1);border-radius:10px;box-shadow:0 8px 24px #0000004d;color:var(--ink);font-size:12px;font-weight:400;line-height:1.5;opacity:0;visibility:hidden;transition:opacity .2s ease,visibility .2s ease;z-index:1000;pointer-events:none}.help-tip-text:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:var(--border)}.help-tip:hover .help-tip-text{opacity:1;visibility:visible}.label-with-help{display:inline-flex;align-items:center}.table{overflow-x:auto}.table-row{min-width:520px}.mono-block{margin-top:12px;padding:12px 14px;border-radius:12px;background:#0c1018b3;border:1px solid rgba(255,255,255,.08);color:var(--ink);font-family:JetBrains Mono,monospace;font-size:12px;white-space:pre-wrap}html[data-theme=light] .mono-block{background:#ffffffe6;border-color:#0c12201f;color:var(--ink)}.login{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px 56px;position:relative;overflow:hidden;background:var(--bg)}.login:before,.login:after{content:"";position:absolute;border-radius:50%;filter:blur(80px);z-index:0;animation:loginOrb 12s ease-in-out infinite}.login:before{width:600px;height:600px;top:-15%;left:-10%;background:var(--glow-1);opacity:.5}.login:after{width:500px;height:500px;bottom:-15%;right:-10%;background:var(--glow-2);opacity:.4;animation-delay:-6s}@keyframes loginOrb{0%,to{transform:translate(0) scale(1);opacity:.4}33%{transform:translate(30px,-20px) scale(1.1);opacity:.6}66%{transform:translate(-20px,15px) scale(.95);opacity:.5}}.login>*{position:relative;z-index:1}.login-toolbar{position:fixed;top:20px;right:20px;display:flex;gap:8px;z-index:45;animation:fadeIn .6s ease-out .4s both}.login-toolbar .ghost{width:40px;height:40px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:12px;background:#ffffff0f;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);color:var(--muted);transition:all .2s ease}.login-toolbar .ghost:hover{background:#ffffff1f;color:var(--ink)}html[data-theme=light] .login-toolbar .ghost{background:#0000000a;border-color:var(--border)}html[data-theme=light] .login-toolbar .ghost:hover{background:#00000014}.login-toolbar .theme-select{height:40px;width:min(160px,40vw);border-radius:12px;padding:0 12px;background:#ffffff0f;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);color:var(--ink);font-size:13px;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}html[data-theme=light] .login-toolbar .theme-select{background:#0000000a;border-color:var(--border)}html[data-theme=dark] .login-toolbar .theme-select{color-scheme:dark}html[data-theme=dark] .login-toolbar .theme-select option,html[data-theme=light] .login-toolbar .theme-select option{background:var(--card);color:var(--ink)}.login-card{width:min(440px,92vw);background:#ffffff0d;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.1);border-radius:24px;padding:48px 40px 40px;display:flex;flex-direction:column;gap:0;animation:loginCardIn .5s cubic-bezier(.16,1,.3,1) both;position:relative;overflow:hidden}@keyframes loginCardIn{0%{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.login-card:before{content:"";position:absolute;top:0;left:24px;right:24px;height:2px;background:linear-gradient(90deg,transparent,var(--accent),var(--accent-2),transparent);border-radius:0 0 2px 2px}.login-card:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(160deg,var(--tint-strong),transparent 50%);opacity:.6;pointer-events:none;border-radius:24px}.login-card>*{position:relative;z-index:1}html[data-theme=light] .login-card{background:#ffffffd9;border-color:var(--border);box-shadow:0 20px 60px #0000000f,0 1px 3px #0000000a}.login-logo-wrap{display:flex;justify-content:center;margin-bottom:24px;width:200px;height:56px;overflow:hidden;align-self:center;flex-shrink:0;clip-path:inset(0)}.login-logo{height:56px;width:auto;transform:scale(2.8);transform-origin:center center;transition:filter .3s ease}.login-logo:hover{filter:brightness(1.15)}.login-heading{text-align:center;margin-bottom:28px}.login-heading h1{font-size:26px;font-weight:700;margin:0 0 6px;background:linear-gradient(135deg,var(--ink),var(--accent-2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-heading p{font-size:14px;color:var(--muted);margin:0;line-height:1.5}.login-message{text-align:center;font-size:13px;color:var(--muted);margin-bottom:8px}.login-form{display:flex;flex-direction:column;gap:18px;width:100%}.login-field{display:flex;flex-direction:column;gap:6px}.login-field label{font-size:13px;font-weight:500;color:var(--muted);padding-left:2px}.login-input-wrap{position:relative;display:flex;align-items:center}.login-input-icon{position:absolute;left:14px;color:var(--muted);pointer-events:none;opacity:.5;transition:opacity .2s ease;z-index:1}.login-input-wrap input{width:100%;padding:12px 14px 12px 42px;background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:12px;color:var(--ink);font-size:14px;transition:all .2s ease;outline:none}html[data-theme=light] .login-input-wrap input{background:#00000008;border-color:var(--border)}.login-input-wrap input:focus{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 15%,transparent);background:#ffffff14}html[data-theme=light] .login-input-wrap input:focus{background:#fff}.login-input-wrap:focus-within .login-input-icon{opacity:1;color:var(--accent)}.login-input-wrap input:disabled{opacity:.5;cursor:not-allowed}.login-field .mfa-input{background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:12px;transition:all .2s ease}html[data-theme=light] .login-field .mfa-input{background:#00000008;border-color:var(--border)}.login-field .mfa-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 15%,transparent)}.login-btn{position:relative;overflow:hidden;width:100%;padding:13px 24px;margin-top:6px;border:none;border-radius:12px;font-size:15px;font-weight:600;color:#fff;cursor:pointer;background:linear-gradient(135deg,var(--accent),var(--accent-2));box-shadow:0 4px 16px color-mix(in srgb,var(--accent) 25%,transparent);transition:all .25s ease;display:flex;align-items:center;justify-content:center;gap:8px}.login-btn:not(:disabled):hover{filter:brightness(1.1);box-shadow:0 6px 24px color-mix(in srgb,var(--accent) 35%,transparent);transform:translateY(-1px)}.login-btn:not(:disabled):active{transform:translateY(0) scale(.98)}.login-btn.loading{pointer-events:none;color:transparent}.login-btn.loading svg{display:none}.login-btn.loading:after{content:"";position:absolute;width:22px;height:22px;top:50%;left:50%;margin:-11px 0 0 -11px;border:2.5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}.login-btn.loading:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);background-size:200% 100%;animation:shimmer 1.5s infinite}.login-back{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:10px;background:none;border:none;color:var(--muted);font-size:13px;cursor:pointer;border-radius:10px;transition:all .2s ease}.login-back:hover{color:var(--ink);background:#ffffff0d}html[data-theme=light] .login-back:hover{background:#0000000a}.login-hint{text-align:center;font-size:12px;color:var(--muted);margin:12px 0 0;opacity:.7}.login-card .banner.error{margin-top:16px;border-radius:12px;animation:shake .5s cubic-bezier(.36,.07,.19,.97),fadeIn .3s ease-out}.login-footer{position:absolute;bottom:20px;left:24px;display:flex;align-items:center;gap:10px;font-size:12px;color:var(--muted);opacity:.5;letter-spacing:.3px;z-index:1}@media (max-width: 600px){.login{padding:60px 12px 20px;justify-content:flex-start}.login:before{width:300px;height:300px}.login:after{width:250px;height:250px}.login-card{width:min(440px,100%);padding:32px 20px 28px;border-radius:20px}.login-heading{margin-bottom:20px}.login-heading h1{font-size:22px}.login-logo-wrap{width:160px;height:48px;margin-bottom:16px}.login-logo{height:48px;transform:scale(2.4)}.login-form{gap:14px}.login-input-wrap input{padding:14px 14px 14px 42px;min-height:48px}.login-btn{padding:14px 24px;min-height:48px}.login-footer{bottom:12px;left:16px;font-size:11px}}@media (max-width: 380px){.login{padding:50px 8px 16px}.login-card{padding:24px 16px 20px;border-radius:16px}.login-heading h1{font-size:20px}.login-heading p{font-size:13px}.login-logo-wrap{width:140px;height:42px;margin-bottom:12px}.login-logo{height:42px;transform:scale(2.2)}.login-toolbar .ghost{width:36px;height:36px}.login-toolbar .theme-select{height:36px;width:min(120px,35vw);font-size:11px}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(.97)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@media (max-width: 900px){.table-row{grid-template-columns:1fr 1fr;min-width:0}.table-row div:nth-child(3),.table-row div:nth-child(4),.table-row div:nth-child(5){grid-column:span 2}}@media (max-width: 720px){.grid,.stats,.stats.compact,.wizard-body,.form-row-2,.inline-form,.grid-form,.inline-form.compact,.grid-form.compact{grid-template-columns:1fr}.topbar-actions,.left-actions{flex-wrap:wrap}.topbar-title h1{font-size:15px}.topbar-status{display:none}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center}.empty-icon{font-size:48px;margin-bottom:16px;opacity:.6}.empty-title{font-size:18px;font-weight:600;color:var(--ink);margin-bottom:8px}.empty-desc{font-size:14px;color:var(--muted);max-width:300px}html[data-theme=light] .wizard-steps .pill{background:#0f172a0f;color:#334155;border-color:#0f172a1f}html[data-theme=light] .wizard-steps .pill.active{background:#2f7bff2e;color:#0b1a3a;border-color:#2f7bff73}html[data-theme=light] .wizard-steps .pill.done{background:#2ec47d33;color:#0d4b2f;border-color:#2ec47d73}html[data-theme=light] .wizard-nas-entry{background:#0f172a08;border-color:#0f172a1a}.muted{color:var(--muted)}.small{font-size:12px}.inline-form.wrap{flex-wrap:wrap;gap:8px}.donut-chart-wrap{display:flex;align-items:center;gap:28px;padding:20px}.donut-chart-wrap svg{flex-shrink:0;filter:drop-shadow(0 0 8px rgba(var(--accent-rgb, 99, 102, 241),.15))}.donut-center-text{font-size:22px;font-weight:700;fill:var(--ink)}.donut-legend{display:flex;flex-direction:column;gap:10px}.donut-legend-item{display:flex;align-items:center;gap:10px;font-size:13px;padding:6px 10px;border-radius:8px;transition:background .15s ease}.donut-legend-item:hover{background:#ffffff0a}.donut-legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;box-shadow:0 0 6px currentColor}.donut-legend-label{color:var(--ink);min-width:100px;font-weight:500}.donut-legend-value{color:var(--muted);font-variant-numeric:tabular-nums}@media (max-width: 480px){.donut-chart-wrap{flex-direction:column;gap:16px}.donut-legend-label{min-width:auto}}.table.compact .table-row{padding:8px 12px}.audit-row .audit-main{font-weight:600}.audit-row .muted.small{display:block}.grid,.stats,.info-grid,.sophos-info-grid{min-width:0;overflow:hidden}.page-info{display:none}.feature-list{margin:0;padding:0;list-style:none}.feature-list li{padding:6px 0 6px 20px;position:relative;color:var(--muted);font-size:13px;line-height:1.5;animation:featureSlide .4s ease-out backwards}.feature-list li:nth-child(1){animation-delay:.2s}.feature-list li:nth-child(2){animation-delay:.26s}.feature-list li:nth-child(3){animation-delay:.32s}.feature-list li:nth-child(4){animation-delay:.38s}.feature-list li:nth-child(5){animation-delay:.44s}.feature-list li:nth-child(6){animation-delay:.5s}@keyframes featureSlide{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.feature-list li:before{content:"•";position:absolute;left:6px;color:var(--accent);font-weight:700}.nav-scroll-container{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}.nav-scroll-container::-webkit-scrollbar{display:none}@media (max-width: 600px){.app{padding:20px 4vw 70px;gap:20px}.topbar h1{font-size:22px}.app-logo{width:180px;margin:-20px 0 -10px}.brand{gap:10px}.brand .eyebrow{font-size:11px}.nav{gap:4px;flex-wrap:nowrap;padding:6px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:999px}.nav .pill{padding:8px 12px;font-size:12px;text-transform:none;letter-spacing:.02em;white-space:nowrap;flex-shrink:0}.card{padding:16px 14px;border-radius:14px}.stat .value{font-size:24px}.stat .label,.stat .sub{font-size:11px}.panel-header h2{font-size:18px}.panel-header p{font-size:13px;line-height:1.5}.list-row{padding:10px 12px;flex-direction:column;align-items:flex-start;gap:8px}.row-actions{width:100%;justify-content:flex-start}.inline-form,.grid-form{gap:10px}input,select{padding:10px 12px;font-size:14px;width:100%}button{padding:10px 14px;font-size:13px}.modal{width:96vw;max-height:90vh;overflow-y:auto;padding:20px 16px;border-radius:16px}.modal-header h2{font-size:18px}.profile-dock{position:static;margin-bottom:10px}.profile-menu{position:relative;width:100%;max-width:none}.topbar-actions{width:100%;flex-direction:column;gap:8px}.topbar-actions button{width:100%}.login-toolbar{top:10px;right:10px}.login-toolbar .theme-select{width:min(140px,40vw);padding:8px 10px;font-size:12px}.sophos-info-grid,.info-grid{grid-template-columns:1fr}.chart-row{grid-template-columns:1fr 1.5fr auto;gap:8px}.chart-bar{height:16px}.chart-value{text-align:right;min-width:60px;font-size:12px}.page-info .info-grid{gap:10px}.page-info .form-card{padding:10px 12px}.feature-list li{font-size:12px;padding:4px 0 4px 16px}}@media (max-width: 480px){.stats{grid-template-columns:1fr}.stats.compact{grid-template-columns:repeat(2,1fr)}.stat .value{font-size:20px}.theme-grid{grid-template-columns:repeat(2,1fr)}.app-logo{width:140px;margin:-15px 0 -5px}.topbar h1{font-size:18px}.brand .eyebrow{font-size:10px}.settings-modal{max-width:100%;margin:10px}.settings-tabs{gap:2px}.settings-tab{padding:10px 8px;font-size:12px;gap:4px}.tab-icon{font-size:14px}.settings-field-group{grid-template-columns:1fr}.settings-avatar{width:40px;height:40px;font-size:16px}.wizard-help{display:none}.chart-row{grid-template-columns:1fr;gap:6px}.chart-label{font-size:13px}.chart-bar{height:14px;order:1}.chart-value{text-align:left;font-size:11px;order:2;color:var(--ink)}.table-row{min-width:0;grid-template-columns:1fr 1fr;gap:10px}.table-row.head{display:none}.table-row>div{display:flex;flex-direction:column;min-width:0}.table-row>div[data-label]:before{content:attr(data-label);font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-bottom:2px;font-weight:500}.table-row>div.device-cell{grid-column:span 2}.info-grid{grid-template-columns:1fr;gap:10px}.pill-row{gap:6px}.pill-row .pill{font-size:10px;padding:3px 8px}.modal-grid{grid-template-columns:1fr}}@media (hover: none) and (pointer: coarse){button,input,select{min-height:44px}.nav .pill{min-height:40px}.list-row{min-height:48px}}.list.scroll,.table.scroll,.chart-list.scroll{scrollbar-width:thin;scrollbar-color:var(--accent) transparent}.list.scroll::-webkit-scrollbar-track,.table.scroll::-webkit-scrollbar-track,.chart-list.scroll::-webkit-scrollbar-track{background:transparent}.list.scroll::-webkit-scrollbar-thumb,.table.scroll::-webkit-scrollbar-thumb,.chart-list.scroll::-webkit-scrollbar-thumb{background:var(--accent);border-radius:999px;opacity:.5}.table{-webkit-overflow-scrolling:touch}@media (min-width: 481px) and (max-width: 720px){.stats,.stats.compact{grid-template-columns:repeat(2,1fr)}}@media (min-width: 721px) and (max-width: 1024px){.grid,.info-grid{grid-template-columns:repeat(2,1fr)}}.list-row>div,.table-row>div{min-width:0;word-break:break-word}html{scroll-behavior:smooth}button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,.nav .pill:focus-visible,.list-row:focus-visible,.clickable:focus-visible,[role=button]:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.clickable,.list-row.clickable,[role=button]{cursor:pointer}@media (max-width: 600px){.modal-backdrop{align-items:flex-end}.modal{border-radius:16px 16px 0 0;max-height:85vh;margin-bottom:0;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}}.page-info .panel-header h2{color:var(--accent)}.info-grid .form-card .label{font-weight:600;color:var(--accent);margin-bottom:4px}.audit-row{min-width:0}.audit-row .audit-main{word-break:break-word}@media (max-width: 480px){.pill-row{flex-wrap:wrap}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--tint-strong);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--accent)}@media (max-height: 500px) and (orientation: landscape){.app{padding-top:16px;padding-bottom:16px}.modal{max-height:95vh}}.mfa-input{font-size:32px!important;letter-spacing:12px;text-align:center;font-family:SF Mono,Monaco,Inconsolata,Fira Code,monospace;padding:16px 16px 16px 24px!important;width:100%}.mfa-input::placeholder{letter-spacing:6px;opacity:.25}.mfa-modal{max-width:480px}.mfa-setup-content{display:flex;flex-direction:column;gap:20px;padding:8px 0}.mfa-step{display:flex;gap:16px;align-items:flex-start}.step-number{width:28px;height:28px;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;flex-shrink:0}.step-content{flex:1}.step-content strong{display:block;margin-bottom:4px}.step-content p{margin:0;color:var(--muted);font-size:14px}.qr-container{display:flex;justify-content:center;padding:24px;background:#fff;border-radius:16px;margin:8px 0}.qr-container svg{display:block}.mfa-manual{text-align:center;font-size:13px}.mfa-secret{display:block;margin-top:8px;padding:12px 16px;background:var(--card-2);border-radius:10px;font-size:14px;letter-spacing:2px;word-break:break-all;-webkit-user-select:all;user-select:all}.mfa-loading{display:flex;flex-direction:column;align-items:center;gap:16px;padding:40px 0}.mfa-loading .spinner{width:40px;height:40px;border:3px solid var(--tint-1);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}.mfa-backup-content{display:flex;flex-direction:column;gap:20px}.mfa-backup-warning{background:#ffffff0a;padding:16px;border-radius:14px;font-size:14px;line-height:1.5}.backup-codes-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.backup-code{padding:12px 16px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:10px;font-family:Fira Code,SF Mono,monospace;font-size:14px;text-align:center;letter-spacing:1px}.mfa-status-badge{display:inline-block;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;margin-top:12px}.mfa-status-badge[data-enabled=true]{background:#22c55e26;color:#22c55e}.mfa-status-badge[data-enabled=false]{background:var(--tint-1);color:var(--muted)}.mfa-settings{position:relative}.mfa-actions{display:flex;flex-direction:column;gap:12px}.settings-divider{height:1px;background:var(--border);margin:24px 0}button.danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none}button.danger:hover{filter:brightness(1.1)}button.danger:disabled{opacity:.5;cursor:not-allowed}.mfa-prompt-modal{max-width:420px;text-align:center;padding:32px}.mfa-prompt-icon{font-size:48px;margin-bottom:16px;color:var(--accent)}.mfa-prompt-modal h2{margin:0 0 12px;font-size:24px}.mfa-prompt-modal p{color:var(--muted);font-size:14px;line-height:1.6;margin:0 0 24px}.mfa-prompt-benefits{display:flex;flex-direction:column;gap:12px;text-align:left;margin-bottom:28px;background:#ffffff08;padding:16px 20px;border-radius:14px}.benefit{display:flex;align-items:center;gap:12px;font-size:14px}.benefit-icon{color:#22c55e;font-weight:700}.mfa-prompt-actions{display:flex;flex-direction:column;gap:12px}.mfa-prompt-actions button{width:100%;padding:14px 20px}@keyframes skeletonShimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg,var(--card-2) 25%,var(--tint-1) 50%,var(--card-2) 75%);background-size:200% 100%;animation:skeletonShimmer 1.5s ease-in-out infinite;border-radius:10px}.skeleton-text{height:16px;border-radius:4px}.skeleton-text.short{width:30%}.skeleton-text.medium{width:60%}.skeleton-text.long{width:90%}.skeleton-stat{height:100px;border-radius:16px}.skeleton-row{height:56px;border-radius:12px;margin-bottom:8px}.skeleton-card{height:180px;border-radius:16px}.stats-grid .skeleton-stat{animation-delay:calc(var(--i, 0) * .1s)}.page-content{animation:pageEnter .5s ease-out}@keyframes pageEnter{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.tab-content{animation:tabFade .3s ease-out}@keyframes tabFade{0%{opacity:0;transform:translate(8px)}to{opacity:1;transform:translate(0)}}.modal-backdrop.closing{animation:backdropFadeOut .2s ease-in forwards}.modal-backdrop.closing .modal{animation:modalSlideOut .2s ease-in forwards}@keyframes backdropFadeOut{0%{opacity:1;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}to{opacity:0;-webkit-backdrop-filter:blur(0);backdrop-filter:blur(0)}}@keyframes modalSlideOut{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(20px) scale(.95)}}@keyframes successFlash{0%{background-color:transparent}30%{background-color:#22c55e26}to{background-color:transparent}}.list-row.success-flash{animation:successFlash .8s ease-out}button:active:not(:disabled){transform:scale(.97)}.splash-screen{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at top left,var(--bg-1) 0%,var(--bg-2) 50%,var(--bg-3) 100%);z-index:10000}html[data-theme=light] .splash-screen{background:var(--bg)}.splash-content{display:flex;flex-direction:column;align-items:center;gap:20px;animation:fadeIn .3s ease-out}.splash-logo-wrap{width:280px;height:280px;overflow:hidden;clip-path:inset(0)}.splash-logo{width:280px;height:280px;object-fit:contain;transform:scale(1.6);transform-origin:center center}.splash-title{font-size:24px;font-weight:600;color:var(--fg);letter-spacing:-.3px;margin:0}.splash-spinner{width:28px;height:28px;border:2.5px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:splashSpin .7s linear infinite}.splash-text{font-size:12px;color:var(--muted);margin:0}@keyframes splashSpin{to{transform:rotate(360deg)}}@media (max-width: 600px){.splash-logo-wrap,.splash-logo{width:200px;height:200px}.splash-title{font-size:20px}}@media (max-width: 380px){.splash-logo-wrap,.splash-logo{width:160px;height:160px}.splash-title{font-size:18px}}.loading-bar{position:fixed;top:0;left:0;right:0;height:3px;background:var(--accent);z-index:9999;transform-origin:left;animation:loadingProgress 1.5s ease-in-out infinite}@keyframes loadingProgress{0%{transform:scaleX(0);opacity:1}50%{transform:scaleX(.6);opacity:1}to{transform:scaleX(1);opacity:0}}button.refreshing svg{animation:spin 1s linear infinite}.content-loading{opacity:.5;pointer-events:none;transition:opacity .2s ease}input:focus,select:focus,textarea:focus{box-shadow:0 0 0 3px var(--tint-1),0 0 20px var(--glow-1)}.list>.list-row{animation:rowSlideIn .4s ease-out backwards}.list>.list-row:nth-child(1){animation-delay:0ms}.list>.list-row:nth-child(2){animation-delay:30ms}.list>.list-row:nth-child(3){animation-delay:60ms}.list>.list-row:nth-child(4){animation-delay:90ms}.list>.list-row:nth-child(5){animation-delay:.12s}.list>.list-row:nth-child(6){animation-delay:.15s}.list>.list-row:nth-child(7){animation-delay:.18s}.list>.list-row:nth-child(8){animation-delay:.21s}.list>.list-row:nth-child(9){animation-delay:.24s}.list>.list-row:nth-child(10){animation-delay:.27s}.card:hover{border-color:color-mix(in srgb,var(--accent) 30%,transparent)}.card{transition:border-color .2s ease,box-shadow .2s ease}.pulse{animation:pulse 2s ease-in-out infinite}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.skeleton{animation:none;background:var(--card-2)}.stat:hover,.card:hover,.profile-chip:hover,.nav .pill:hover,.nav .pill:active,button.primary:hover,button.danger:hover,button.ghost:hover,.login-card input:focus{transform:none!important}}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.flex-wrap{flex-wrap:wrap}.flex-center{display:flex;align-items:center}.flex-between{display:flex;justify-content:space-between;align-items:center}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.flex-1{flex:1}.gap-2{gap:4px}.gap-4{gap:6px}.gap-6{gap:8px}.gap-8{gap:10px}.gap-12{gap:12px}.gap-16{gap:16px}.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.text-xs{font-size:11px}.text-sm{font-size:12px}.text-base{font-size:14px}.text-bold{font-weight:600}.text-center{text-align:center}.overflow-x-auto{overflow-x:auto;-webkit-overflow-scrolling:touch}.table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:10px}.inline-pill{display:inline-flex;align-items:center;gap:4px}.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}.status-dot.online,.status-dot.ok{background:var(--success);box-shadow:0 0 6px var(--success)}.status-dot.offline,.status-dot.bad{background:var(--muted)}.stat-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px;color:#fff;flex-shrink:0;background:linear-gradient(135deg,var(--accent),var(--accent-2))}.stat-icon.success{background:linear-gradient(135deg,#22c55e,#16a34a)}.stat-icon.danger{background:linear-gradient(135deg,#ef4444,#dc2626)}.stat-icon.muted{background:linear-gradient(135deg,#6b7280,#4b5563)}.progress-track{width:100%;height:6px;background:var(--tint-2);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-2));border-radius:3px;transition:width .4s ease-out}.table-empty{text-align:center;padding:32px 16px;color:var(--muted);font-style:italic}.select-full{max-width:100%}.select-compact{padding:6px 10px;border-radius:10px;border:1px solid rgba(255,255,255,.1);background:#ffffff0a;color:var(--ink);font-size:13px}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.text-accent{color:var(--accent)}.text-muted{color:var(--muted)}.text-warning{color:#f59e0b}.text-gradient{background:linear-gradient(135deg,var(--accent),var(--accent-2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.pill-divider{border-left:1px solid var(--border);height:16px;margin:0 4px;align-self:center}.pill-remove{padding:0 4px;font-size:10px;line-height:1;min-width:auto;border:none;background:none;color:inherit;cursor:pointer;opacity:.7}.pill-remove:hover{opacity:1}.btn-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.btn-row.end{justify-content:flex-end}.filter-row-flex{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-bottom:12px}.filter-row-flex label{font-size:12px;font-weight:600;color:var(--muted);white-space:nowrap}.filter-row-flex input,.filter-row-flex select{min-width:130px}.section-divider{margin-top:16px;border-top:1px solid var(--border);padding-top:16px}.section-heading{margin:0 0 12px;font-size:14px;font-weight:600}.input-sm{width:100px;max-width:100%}.input-md{width:160px;max-width:100%}.scroll-sm{max-height:200px;overflow:auto}.scroll-md{max-height:280px;overflow:auto}.scroll-lg{max-height:400px;overflow:auto}.info-block{margin:0 0 12px;padding:12px 16px;background:var(--tint-2);border:1px solid var(--border);border-radius:10px;font-size:13px;color:var(--muted);line-height:1.6}.textarea-mono{font-family:monospace;font-size:13px;width:100%;resize:vertical}.badge.stale,.pill.stale{opacity:.6}.page-section{margin-bottom:24px}.page-section:last-child{margin-bottom:0}.card.panel{padding:18px 20px}.card.panel .panel-header{margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.06);border-left:3px solid var(--accent);padding-left:16px}.card.panel .panel-header h2{font-size:15px;font-weight:700;margin:0 0 4px;background:linear-gradient(135deg,var(--ink) 0%,var(--accent-2) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.card.panel .panel-header p{font-size:13px;color:var(--muted);margin:0;line-height:1.5;width:100%}.panel-actions{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px}.panel-actions.end{justify-content:flex-end}.panel-actions.between{justify-content:space-between;align-items:center}.admins-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:14px;align-items:start;grid-auto-rows:auto}.admins-grid .card.panel{padding:20px 22px;align-self:stretch}.admins-grid .card.panel:not(.page-info){height:100%}.admins-grid .page-info{height:auto;align-self:start}.admins-grid .card.panel .panel-header{margin-bottom:14px;padding-bottom:10px}.admins-grid .panel-actions{margin-bottom:12px;align-items:center}.admins-grid .info-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px}.admins-grid .form-section{background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:14px}.admins-grid .form-section-title{margin-bottom:10px}.admins-grid .list{gap:8px}.admins-grid .list-row{padding:10px 14px;align-items:flex-start;flex-wrap:wrap}.admins-grid .list-row span{line-height:1.4}.admins-grid .list-row>span:first-child{flex:1 1 200px;min-width:160px}.admins-grid .list-row .muted{flex:0 1 200px;min-width:140px}.admins-grid .row-actions{margin-left:auto;flex:1 1 200px;justify-content:flex-end;align-items:center}.admins-grid .panel-actions button,.admins-grid .row-actions button{min-height:36px}.admins-grid .panel-actions button{min-width:140px}.admins-grid .row-actions button{min-width:110px}.admins-panel .admins-list{gap:10px}.admins-panel .admin-row{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;gap:16px;flex-wrap:wrap}.admins-panel .admin-info{flex:1 1 250px;min-width:180px;display:flex;flex-direction:column;gap:4px}.admins-panel .admin-name{font-weight:600;font-size:15px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}.admins-panel .admin-name .badge{font-size:11px;padding:3px 8px}.admins-panel .admin-details{display:flex;flex-wrap:wrap;gap:12px;font-size:13px;color:var(--muted)}.admins-panel .admin-username{font-family:SF Mono,Fira Code,Cascadia Code,monospace;opacity:.8}.admins-panel .admin-email{opacity:.7}.admins-panel .row-actions{flex-shrink:0;gap:8px;display:flex;flex-wrap:wrap;justify-content:flex-end}.admins-panel .row-actions button{min-width:70px;white-space:nowrap}.admin-modal{max-width:480px}.admin-form{display:flex;flex-direction:column;gap:18px}.admin-form .form-group{display:flex;flex-direction:column;gap:6px}.admin-form .form-group label{font-size:13px;font-weight:500;color:var(--ink);opacity:.9}.admin-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.admin-form input{padding:12px 14px;font-size:14px}.admin-form button[type=submit]{margin-top:8px;padding:14px 20px;font-size:15px}@media (max-width: 600px){.admins-panel .admin-row{flex-direction:column;align-items:flex-start;gap:12px}.admins-panel .admin-info{min-width:0;width:100%}.admins-panel .row-actions{width:100%;justify-content:flex-start}.admins-panel .row-actions button{min-width:0;flex:1}.admins-grid .list-row>span:first-child,.admins-grid .list-row .muted{min-width:0;flex-basis:auto}.admins-grid .panel-actions button,.admins-grid .row-actions button{min-width:0}.admin-form .form-row{grid-template-columns:1fr}}.card.panel>.row-actions{margin:0 0 20px}.form-section{background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-left:2px solid color-mix(in srgb,var(--accent) 25%,transparent);border-radius:12px;padding:16px;margin-bottom:12px;margin-left:0}.form-section:last-child{margin-bottom:0}.form-section-title{font-size:11px;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.06em;margin-bottom:12px;display:flex;align-items:center;gap:8px}.form-section-title .icon{font-size:16px;opacity:.8}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.form-grid.two-col{grid-template-columns:1fr 1fr}.form-grid.three-col{grid-template-columns:repeat(3,1fr)}@media (max-width: 768px){.form-grid.two-col,.form-grid.three-col{grid-template-columns:1fr}.admins-panel .row-actions button{min-width:80px;padding:6px 10px;font-size:12px}}.form-field{display:flex;flex-direction:column;gap:8px}.form-field label{font-size:13px;font-weight:500;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.form-field input,.form-field select{width:100%}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin-top:20px}.info-grid .form-card{padding:16px 18px;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:14px;transition:border-color .2s ease}.info-grid .form-card:hover{border-color:#ffffff1f}.info-grid .form-card .label{font-size:12px;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px}.info-grid .form-card .value{font-size:13px;color:var(--ink);line-height:1.6}.info-grid .form-card .value.small{font-size:13px;color:var(--muted)}.sophos-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin-top:20px}.sophos-info-grid .form-card{padding:16px 18px;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:14px}.sophos-info-grid .form-card .label{font-size:12px;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px}.sophos-info-grid .form-card .value.small{font-size:13px;color:var(--muted);line-height:1.7}.list-row{padding:14px 18px;gap:12px}.list-row>div:first-child{flex:1;min-width:0}.list-row .row-actions{flex-shrink:0}.list.compact .list-row{padding:10px 14px}.inline-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;align-items:end;padding:16px;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:14px;margin-bottom:16px}.inline-form.compact{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));padding:14px}.inline-form.wrap{flex-wrap:wrap}.form-section .inline-form{background:transparent;border:none;padding:0;margin-bottom:0}.inline-form input,.inline-form select{width:100%}.inline-form button{white-space:nowrap}.grid-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px}.grid-form.compact{gap:12px}.table{margin-top:16px}.table-row{padding:16px 18px;gap:16px}.table-row.head{padding:12px 18px;margin-bottom:4px}.note{padding:12px 16px;background:var(--tint-2);border:1px solid var(--border);border-radius:10px;font-size:13px;color:var(--muted);margin-top:16px;line-height:1.5}.note strong{color:var(--ink)}.banner{padding:14px 18px;border-radius:14px;margin-top:16px;font-size:14px;display:flex;align-items:center;gap:10px}.banner.success{background:#22c55e1f;border:1px solid rgba(34,197,94,.25);color:#22c55e}.alert{padding:14px 18px;border-radius:14px;font-size:14px;display:flex;align-items:center;gap:10px;border:1px solid rgba(255,255,255,.08);background:#ffffff0a;color:var(--ink)}.alert.warning{border-left:3px solid #f59e0b;background:#f59e0b14}.alert.error{border-left:3px solid var(--danger);background:#ff54680f}.alert.info{border-left:3px solid var(--accent);background:#3b82f60f}.banner.error{background:#ef44441f;border:1px solid rgba(239,68,68,.25);border-left:3px solid var(--danger);color:#ef4444}.pill-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-left:8px;background:var(--tint-1);color:var(--muted)}.badge.super{background:linear-gradient(120deg,var(--accent),var(--accent-2));color:#0a1220}.badge.info{background:#ffffff0f;color:var(--accent)}.chart-list{margin-top:16px}.chart-list.scroll{max-height:280px;overflow-y:auto;padding-right:8px}.chart-row{display:grid;grid-template-columns:minmax(120px,160px) minmax(80px,1fr) auto;gap:12px;align-items:center;padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.04);border-radius:10px;margin:0 -14px;transition:background .2s ease}.chart-row:hover{background:#ffffff08}.chart-row:last-child{border-bottom:none}.chart-row-top .chart-label{color:var(--accent)}.chart-label{font-size:13px;color:var(--ink);min-width:0;word-break:break-word;font-weight:500}.chart-label .muted.small{font-size:11px;margin-top:2px;opacity:.6}.chart-bar{height:10px;background:#ffffff0f;border-radius:5px;overflow:hidden;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.chart-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-2));border-radius:5px;transition:width .6s cubic-bezier(.16,1,.3,1);box-shadow:0 0 12px rgba(var(--accent-rgb, 99, 102, 241),.3);position:relative}.chart-row-top .chart-bar-fill{box-shadow:0 0 16px rgba(var(--accent-rgb, 99, 102, 241),.5)}.chart-value{font-size:13px;font-variant-numeric:tabular-nums;color:var(--muted);text-align:right;white-space:nowrap;min-width:80px;font-weight:500}.audit-row{flex-direction:column;align-items:flex-start;gap:6px}.audit-main{font-size:14px}.filter-pills{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.card.panel.wide{grid-column:1 / -1}section.grid{margin-bottom:24px}section.grid:last-child{margin-bottom:0}.stats{gap:20px;margin-bottom:24px}.stats .card.stat{padding:20px 24px;border-top:2px solid var(--accent);background:linear-gradient(180deg,#ffffff0f,#ffffff05)}.card.stat .value{text-shadow:0 0 20px color-mix(in srgb,var(--accent) 20%,transparent)}.modal{padding:28px 32px;gap:20px}.modal-header{padding-bottom:16px;border-bottom:2px solid transparent;border-image:linear-gradient(90deg,var(--accent),var(--accent-2),transparent) 1;margin-bottom:4px}.modal-grid{gap:14px}.modal-card{padding:14px 16px}@media (max-width: 768px){.card.panel{padding:20px 22px}.inline-form{padding:14px;gap:10px}.info-grid{grid-template-columns:1fr}.modal{padding:22px 24px}.stats{gap:14px}.list-row{flex-wrap:wrap;gap:10px}.list-row .row-actions{width:100%;justify-content:flex-end}}.list.scroll::-webkit-scrollbar,.table.scroll::-webkit-scrollbar,.chart-list.scroll::-webkit-scrollbar{width:6px}.list.scroll::-webkit-scrollbar-track,.table.scroll::-webkit-scrollbar-track,.chart-list.scroll::-webkit-scrollbar-track{background:var(--tint-2);border-radius:3px}.list.scroll::-webkit-scrollbar-thumb,.table.scroll::-webkit-scrollbar-thumb,.chart-list.scroll::-webkit-scrollbar-thumb{background:var(--accent);border-radius:3px}.list.scroll::-webkit-scrollbar-thumb:hover,.table.scroll::-webkit-scrollbar-thumb:hover,.chart-list.scroll::-webkit-scrollbar-thumb:hover{background:var(--accent-2)}.list.scroll,.table.scroll,.chart-list.scroll{scrollbar-width:thin;scrollbar-color:var(--accent) var(--tint-2)}.muted.small{font-size:12px;color:var(--muted)}.pill{display:inline-flex;align-items:center;padding:5px 12px;border-radius:20px;font-size:12px;font-weight:600;background:var(--tint-1);color:var(--ink);border:1px solid var(--border)}.pill.ok{background:#22c55e26;color:#22c55e;border-color:#22c55e4d}.pill.bad{background:#ef444426;color:#ef4444;border-color:#ef44444d}.checkbox{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--ink);cursor:pointer;padding:10px 0}.checkbox input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent);cursor:pointer}html[data-theme=light] .form-section,html[data-theme=light] .inline-form{background:#fff9}html[data-theme=light] .info-grid .form-card,html[data-theme=light] .sophos-info-grid .form-card{background:#ffffffb3}html[data-theme=light] .note{background:#fff9}html[data-theme=light] .list-row{background:linear-gradient(160deg,#ffffffd9,#ffffff80),linear-gradient(120deg,var(--tint-strong),transparent 60%)}html[data-theme=light] .table-row:not(.head){background:linear-gradient(160deg,#ffffffd9,#ffffff80),linear-gradient(120deg,var(--tint-strong),transparent 60%)}html[data-theme=light] .chart-bar{background:#0000000f}html[data-theme=light] .chart-row:hover{background:#00000008}html[data-theme=light] .line-chart-wrap,html[data-theme=light] .peak-hours-chart{background:#ffffff80;border-color:#00000014}html[data-theme=light] .report-table thead th{background:#ffffffb3;border-bottom-color:#0000001a}html[data-theme=light] .report-table tbody tr:hover{background:#00000008}html[data-theme=light] .report-table tbody td,html[data-theme=light] .chart-row{border-bottom-color:#0000000f}.log-actions{margin-bottom:12px;display:flex;align-items:center}.error-banner{background:#ef444426;border:1px solid rgba(239,68,68,.3);color:var(--danger);padding:10px 14px;border-radius:10px;margin-bottom:12px;font-size:13px}.log-viewer{max-height:400px;overflow-y:auto;font-family:JetBrains Mono,Fira Code,SF Mono,Monaco,Consolas,monospace;font-size:12px;background:#00000040;border-radius:10px;padding:12px;border:1px solid rgba(255,255,255,.06)}.log-line{padding:2px 0;border-bottom:1px solid var(--border);display:flex;gap:12px;align-items:flex-start;line-height:1.6}.log-line:last-child{border-bottom:none}.log-timestamp{color:var(--muted);white-space:nowrap;flex-shrink:0;font-size:11px;min-width:140px;margin-right:8px}.log-message{word-break:break-word;color:var(--ink);flex:1}.log-message.log-error{color:var(--danger)}.log-message.log-warning{color:#f59e0b}.log-message.log-success{color:#22c55e}.filter-row{display:flex;gap:12px;align-items:center;margin-bottom:16px;flex-wrap:wrap}.filter-row input{flex:1;min-width:180px;max-width:280px}.pagination{display:flex;justify-content:center;align-items:center;gap:16px;margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}.pagination span{color:var(--muted);font-size:13px}.auth-table .table-row,.accounting-table .table-row{grid-template-columns:minmax(130px,1fr) minmax(80px,1fr) minmax(70px,.8fr) minmax(100px,1.2fr) minmax(100px,1fr)}.accounting-table .table-row{grid-template-columns:minmax(130px,1fr) minmax(80px,1fr) minmax(100px,1fr) minmax(80px,1fr) minmax(70px,.8fr) minmax(70px,.8fr)}.table-row.error-row{background:linear-gradient(160deg,rgba(239,68,68,.08),transparent 60%),linear-gradient(120deg,var(--tint-strong),transparent 60%);border-left:3px solid #ef4444}.table-row.active-row{background:linear-gradient(160deg,rgba(34,197,94,.08),transparent 60%),linear-gradient(120deg,var(--tint-strong),transparent 60%);border-left:3px solid #22c55e}.table-row.empty{grid-template-columns:1fr;text-align:center;color:var(--muted)}.text-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width: 900px){.auth-table .table-row,.accounting-table .table-row{grid-template-columns:repeat(3,1fr)}.auth-table .table-row>div:nth-child(4),.auth-table .table-row>div:nth-child(5),.accounting-table .table-row>div:nth-child(5),.accounting-table .table-row>div:nth-child(6){display:none}}@media (max-width: 600px){.filter-row{flex-direction:column;align-items:stretch}.filter-row input{max-width:none;width:100%;min-width:0}.filter-row .filter-pills{justify-content:flex-start}.filter-row-flex{flex-direction:column;align-items:stretch}.filter-row-flex input,.filter-row-flex select{min-width:0;width:100%}.log-line{flex-direction:column;gap:4px}.log-timestamp{min-width:auto;font-size:10px}.log-viewer{font-size:11px;padding:8px}.pagination{flex-wrap:wrap;gap:10px}.auth-table .table-row,.accounting-table .table-row{grid-template-columns:1fr 1fr}.auth-table .table-row>div:nth-child(n+3),.accounting-table .table-row>div:nth-child(n+3){display:none}.auth-table .table-row.head>div:nth-child(n+3),.accounting-table .table-row.head>div:nth-child(n+3){display:none}.filter-group select{min-width:0;width:100%}.table-row.head{font-size:10px}}html[data-theme=light] .log-viewer{background:#f8f9fc}html[data-theme=light] .table-row.error-row{background:linear-gradient(160deg,rgba(239,68,68,.12),transparent 60%),linear-gradient(120deg,var(--tint-strong),transparent 60%)}html[data-theme=light] .table-row.active-row{background:linear-gradient(160deg,rgba(34,197,94,.12),transparent 60%),linear-gradient(120deg,var(--tint-strong),transparent 60%)}.sessions-table .table-row{grid-template-columns:minmax(100px,1fr) minmax(140px,1.4fr) minmax(100px,1fr) minmax(100px,1fr) minmax(100px,1fr) minmax(80px,.8fr)}.relays-table .table-row{grid-template-columns:minmax(80px,1fr) minmax(120px,1.4fr) minmax(60px,.6fr) minmax(70px,.7fr) minmax(70px,.7fr) minmax(60px,.6fr) minmax(140px,1.2fr)}.sites-table .table-row{grid-template-columns:minmax(100px,1fr) minmax(150px,2fr) minmax(70px,.7fr) minmax(120px,1fr) minmax(100px,1fr)}.auth-table .table-row{grid-template-columns:minmax(100px,1fr) minmax(140px,1.4fr) minmax(80px,.8fr) minmax(120px,1fr) minmax(120px,1fr)}.device-cell{max-width:220px;overflow:hidden}.device-cell>div{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-details{display:flex;flex-direction:column;gap:6px;min-width:0}.user-details .pill-row{flex-wrap:wrap;gap:4px}.user-details .pill{max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-actions{display:flex;flex-wrap:wrap;gap:6px}.user-actions button{padding:6px 10px;font-size:12px}.timestamp-cell{white-space:nowrap;font-size:12px}.audit-details{display:flex;flex-direction:column;gap:4px}.audit-details .user-agent{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:11px;color:var(--muted)}@media (max-width: 900px){.sessions-table .table-row{grid-template-columns:repeat(3,1fr)}.sessions-table .table-row>div:nth-child(4),.sessions-table .table-row>div:nth-child(5),.sessions-table .table-row>div:nth-child(6){display:none}.relays-table .table-row{grid-template-columns:repeat(4,1fr)}.relays-table .table-row>div:nth-child(5),.relays-table .table-row>div:nth-child(6),.relays-table .table-row>div:nth-child(7){grid-column:span 2}.sites-table .table-row{grid-template-columns:1fr 1fr}.sites-table .table-row>div:nth-child(n+3){display:none}}@media (max-width: 600px){.sessions-table .table-row,.relays-table .table-row,.sites-table .table-row{grid-template-columns:1fr 1fr}.sessions-table .table-row>div:nth-child(n+3),.relays-table .table-row>div:nth-child(n+3),.sites-table .table-row>div:nth-child(n+3){display:none}.user-actions button{padding:5px 8px;font-size:11px}.device-cell{max-width:140px}}.button-row{display:flex;gap:8px;grid-column:1 / -1}.list-row-main{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.list-row-main strong{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.list-row-main .muted.small{font-size:11px}.backup-actions{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}@media (max-width: 768px){.backup-actions{grid-template-columns:1fr}}.docs-page{display:flex;flex-direction:column;gap:20px}.docs-header{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:20px 24px}.docs-filters{display:flex;flex-direction:column;gap:12px}.docs-search{max-width:400px;padding:12px 16px;font-size:14px}.docs-categories{display:flex;flex-wrap:wrap;gap:8px}.docs-content{display:flex;flex-direction:column;gap:24px}.docs-section{background:var(--tint-1);border:1px solid var(--border);border-radius:12px;padding:24px}.docs-section>h2{margin:0 0 20px;padding-bottom:12px;border-bottom:1px solid var(--border);color:var(--accent);font-size:20px}.docs-card{background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-left:3px solid color-mix(in srgb,var(--accent) 25%,transparent);border-radius:12px;padding:16px 20px;margin-bottom:16px}.docs-card:last-child{margin-bottom:0}.docs-card h3{margin:0 0 12px;font-size:16px;background:linear-gradient(135deg,var(--ink) 0%,var(--accent-2) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.docs-card p{margin:0 0 12px;line-height:1.6;color:var(--muted)}.docs-card p:last-child{margin-bottom:0}.docs-card ul,.docs-card ol{margin:0 0 12px;padding-left:24px;color:var(--muted);line-height:1.8}.docs-card ul:last-child,.docs-card ol:last-child{margin-bottom:0}.docs-card li{margin-bottom:4px}.docs-card strong{color:var(--ink)}.docs-card code{background:#ffffff0f;padding:2px 6px;border-radius:4px;font-family:monospace;font-size:13px;color:var(--accent)}.docs-code{background:#0003;border:1px solid rgba(255,255,255,.06);border-radius:10px;padding:16px;font-family:Fira Code,SF Mono,Consolas,monospace;font-size:12px;line-height:1.5;overflow-x:auto;white-space:pre;color:var(--muted);margin:12px 0}.docs-note{background:#3b82f614;border-left:3px solid color-mix(in srgb,var(--accent) 40%,transparent);padding:12px 16px;border-radius:0 10px 10px 0;margin:12px 0;color:var(--muted)}.docs-note strong{color:var(--accent)}.docs-example{background:#ffffff0a;border-radius:10px;padding:16px;margin:12px 0}.docs-table{width:100%;border-collapse:collapse;margin:12px 0;font-size:13px}.docs-table th,.docs-table td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--border)}.docs-table th{background:#ffffff0a;color:var(--ink);font-weight:600;text-transform:uppercase;font-size:10px;letter-spacing:.05em}.docs-table td{color:var(--muted)}.docs-table tr:last-child td{border-bottom:none}html[data-theme=light] .docs-section{background:#ffffffb3}html[data-theme=light] .docs-card{background:#ffffff80}html[data-theme=light] .docs-code{background:#f5f7fa}html[data-theme=light] .docs-example{background:#00000005}html[data-theme=light] .search-modal{background:#ffffffd9;border-color:var(--border)}@media (max-width: 600px){.docs-section{padding:16px}.docs-card{padding:14px 16px}.docs-code{font-size:11px;padding:12px}.docs-table{font-size:12px}.docs-table th,.docs-table td{padding:8px 10px}.docs-header{padding:14px 16px}.docs-search{max-width:100%}.docs-categories{gap:6px}}.modal .form-group{display:flex;flex-direction:column;gap:6px}.modal .form-group label{text-transform:uppercase;font-size:10px;letter-spacing:.06em;font-weight:600;color:var(--muted);margin-bottom:4px}.modal .form-group .hint{font-size:11px;color:var(--muted);margin-top:2px}.modal .grid-form.compact{grid-template-columns:1fr 1fr;gap:16px}@media (max-width: 500px){.modal .grid-form.compact{grid-template-columns:1fr}}.password-field-row{display:flex;gap:6px;align-items:center}.password-field-row input{flex:1;min-width:0}.password-field-row button{flex-shrink:0;padding:8px 10px;font-size:12px}.password-field-row button.ghost{background:transparent;border:1px solid var(--border);color:var(--muted)}.password-field-row button.ghost:hover{background:var(--tint-1);color:var(--ink)}.password-field-row button:not(.ghost){background:var(--accent);color:#fff;border:none}.password-field-row button:not(.ghost):hover{background:var(--accent-2)}.ssid-table .table-row{grid-template-columns:minmax(100px,150px) minmax(80px,110px) minmax(80px,110px) minmax(60px,85px) minmax(80px,120px) 1fr minmax(80px,110px)}@media (max-width: 900px){.ssid-table .table-row{grid-template-columns:repeat(3,1fr)}.ssid-table .table-row>div:nth-child(n+4){display:none}}@media (max-width: 600px){.ssid-table .table-row{grid-template-columns:1fr 1fr}.ssid-table .table-row>div:nth-child(n+3){display:none}.ssid-table .table-row.head{display:none}}@media (max-width: 600px){.nav-scroll-container{-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;scroll-padding:8px}.nav-scroll-container .pill{scroll-snap-align:start;flex-shrink:0;font-size:12px;padding:8px 14px}select,input[type=text],input[type=password],input[type=email],input[type=number],textarea{max-width:100%!important;min-width:0!important;width:100%!important;box-sizing:border-box}.card{margin-bottom:8px}.topbar{padding:12px 16px}.topbar h1{font-size:18px!important}.brand .logo{max-width:140px!important}.profile-dock{position:relative!important;top:auto!important;right:auto!important}.modal{width:100%!important;max-width:100%!important;border-radius:16px 16px 0 0!important;max-height:92vh!important}.inline-form{flex-direction:column;gap:8px}.inline-form>*{width:100%}.filter-bar{flex-direction:column;align-items:stretch;gap:10px}.filter-group{flex-wrap:wrap}.filter-group select{min-width:0;width:100%}.form-grid{grid-template-columns:1fr}.list.scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}}@media (max-width: 380px){.app{padding:16px 12px 60px!important}.topbar h1{font-size:16px!important}.stat-value{font-size:22px!important}.modal{padding:16px 12px}.modal-header h2{font-size:16px}.device-cell{max-width:100px}.nav-scroll-container .pill{font-size:11px;padding:6px 10px}.card{padding:14px!important}}@media (hover: none) and (pointer: coarse){.list-row{min-height:52px;padding:12px 16px}button,.pill{min-height:44px;cursor:pointer}.table-row>span{padding:10px 8px}}.search-icon-btn{padding:6px;border-radius:10px;display:flex;align-items:center;justify-content:center}.search-modal{max-width:560px;width:90vw;padding:0;border-radius:16px;overflow:hidden;margin-top:12vh;align-self:flex-start;background:#ffffff0d;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.1);box-shadow:0 24px 64px #0006}.search-modal-input-wrap{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid color-mix(in srgb,var(--accent) 20%,var(--border))}.search-modal-input{flex:1;border:none;background:transparent;color:var(--fg);font-size:16px;outline:none}.search-modal-input::placeholder{color:var(--muted)}.search-modal-results{max-height:420px;overflow-y:auto;padding:6px 0}.search-category{padding:0}.search-category+.search-category{border-top:1px solid var(--border);margin-top:4px;padding-top:4px}.search-category-header{display:flex;align-items:center;gap:6px;padding:8px 16px 4px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--accent)}.search-category-icon{font-size:13px}.search-category-label{flex:1}.search-category-count{font-size:10px;background:var(--hover);padding:1px 6px;border-radius:8px;font-weight:500}.search-modal-item{display:flex;align-items:center;gap:10px;padding:8px 16px 8px 38px;cursor:pointer;transition:background .15s}.search-modal-item:hover,.search-modal-item.selected{background:color-mix(in srgb,var(--accent) 8%,transparent);border-left:2px solid var(--accent)}.search-modal-label{font-weight:500;font-size:14px}.search-modal-item .muted.small{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.search-modal-empty{padding:24px 16px;text-align:center;color:var(--muted);font-size:14px}.sort-bar{display:flex;gap:4px;padding:8px 16px;border-bottom:1px solid var(--border)}.sort-btn{background:none;border:none;color:var(--muted);font-size:12px;font-weight:500;padding:4px 8px;border-radius:4px;cursor:pointer;transition:color .15s,background .15s;white-space:nowrap}.sort-btn:hover{color:var(--fg);background:var(--hover)}.sort-btn.active{color:var(--accent)}.user-table-wrap{max-height:600px;overflow-y:auto;overflow-x:auto}.user-table{width:100%;border-collapse:collapse;table-layout:fixed}.user-table thead{position:sticky;top:0;z-index:2}.user-table thead th{background:#ffffff0a;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);padding:10px 14px;text-align:left;border-bottom:1px solid color-mix(in srgb,var(--accent) 20%,var(--border));white-space:nowrap}.user-table thead th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .15s}.user-table thead th.sortable:hover{color:var(--fg)}.user-table tbody tr{cursor:pointer;transition:background .15s}.user-table tbody tr:hover{background:var(--hover)}.user-table tbody tr.disabled{opacity:.55}.user-table tbody tr.selected{background:color-mix(in srgb,var(--accent) 10%,transparent)}.user-table tbody td{padding:10px 12px;font-size:13px;border-bottom:1px solid var(--border);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;vertical-align:middle}.user-table tbody tr:last-child td{border-bottom:none}.user-table tbody tr.expanded-detail td{border-top:none;padding:0}.user-table tbody tr.expanded-detail .info-grid{border-top:1px dashed var(--border);border-bottom:1px dashed var(--border)}.user-table .user-table-check-col{width:40px;text-align:center;padding:10px 8px}.user-table .user-table-check-col input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--accent);vertical-align:middle}.user-table .col-actions{width:180px;text-align:right;overflow:visible;text-overflow:clip}.user-table .col-actions button{padding:4px 10px;font-size:12px}.user-table .col-email{max-width:200px}.user-table .col-dept{max-width:140px}.user-table .col-group{max-width:180px}@media (max-width: 900px){.user-table .col-email,.user-table .col-dept{display:none}}@media (max-width: 600px){.user-table .col-group,.user-table thead{display:none}.user-table,.user-table tbody,.user-table tr,.user-table td{display:block;width:100%}.user-table tbody tr{padding:10px 12px;border-bottom:1px solid var(--border);display:flex;flex-wrap:wrap;gap:4px 12px;align-items:center}.user-table tbody td{border-bottom:none;padding:2px 0;overflow:visible;white-space:normal}.user-table .user-table-check-col{width:auto;flex:0 0 24px;padding:2px 0}.user-table .col-actions{width:100%;text-align:left;padding-top:6px;border-top:1px solid var(--border);margin-top:4px}}.cert-panel{border-top:1px solid var(--border);padding:16px 0 0;margin-top:20px}.cert-panel-header{display:flex;align-items:center;justify-content:space-between;font-weight:600;font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px;border-left:3px solid var(--accent);padding-left:12px}.cert-empty{font-size:13px;color:var(--muted);margin:4px 0 0}.cert-table{width:100%;border-collapse:collapse;font-size:13px}.cert-table th{text-align:left;padding:4px 8px;font-size:10px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);background:#ffffff0a}.cert-table td{padding:6px 8px;border-bottom:1px solid var(--border);vertical-align:middle}.cert-table tr:last-child td{border-bottom:none}.cert-row-revoked td{opacity:.5}.cert-row-expired td{opacity:.7}.pill.small.danger{background:var(--danger, #e53935);color:#fff}.pill.small.warning{background:#f59e0b;color:#fff}.pill.small.success{background:#22c55e;color:#fff}.nas-table-wrap{max-height:600px;overflow-y:auto}.nas-table{width:100%;border-collapse:collapse}.nas-table thead{position:sticky;top:0;z-index:2}.nas-table thead th{background:#ffffff0a;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);padding:10px 12px;text-align:left;border-bottom:2px solid color-mix(in srgb,var(--accent) 20%,var(--border));white-space:nowrap}.nas-table tbody tr{cursor:pointer;transition:background .15s}.nas-table tbody tr:hover{background:var(--hover)}.nas-table tbody td{padding:10px 12px;font-size:13.5px;border-bottom:1px solid var(--border);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;vertical-align:middle}.nas-table tbody tr:last-child td{border-bottom:none}.nas-col-actions{width:140px;text-align:right;overflow:visible;text-overflow:clip}.nas-col-actions button{padding:4px 10px;font-size:12px}@media (max-width: 700px){.nas-hide-mobile,.nas-table thead{display:none}.nas-table,.nas-table tbody,.nas-table tr,.nas-table td{display:block;width:100%}.nas-table tbody tr{padding:10px 12px;border-bottom:1px solid var(--border);display:flex;flex-wrap:wrap;gap:4px 12px;align-items:center}.nas-table tbody td{border-bottom:none;padding:2px 0}.nas-col-actions{width:100%;text-align:left;padding-top:6px;border-top:1px solid var(--border);margin-top:4px}}.sites-table-wrap{max-height:600px;overflow-y:auto}.sites-table{width:100%;border-collapse:collapse}.sites-table thead{position:sticky;top:0;z-index:2}.sites-table thead th{position:relative;background:#ffffff0a;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);padding:10px 12px;text-align:left;border-bottom:2px solid color-mix(in srgb,var(--accent) 20%,var(--border));white-space:nowrap}.sites-table tbody tr{cursor:pointer;transition:background .15s}.sites-table tbody tr:hover{background:var(--hover)}.sites-table tbody td{padding:10px 12px;font-size:13.5px;border-bottom:1px solid var(--border);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;vertical-align:middle}.sites-table tbody tr:last-child td{border-bottom:none}.sites-table tr.selected{background:var(--hover)}.sites-table input[type=radio]{cursor:pointer;accent-color:var(--accent)}@media (max-width: 900px){.sites-hide-mobile{display:none}}@media (max-width: 700px){.sites-table thead{display:none}.sites-table,.sites-table tbody,.sites-table tr,.sites-table td{display:block;width:100%}.sites-table tbody tr{padding:10px 12px;border-bottom:1px solid var(--border);display:flex;flex-wrap:wrap;gap:4px 12px;align-items:center}.sites-table tbody td{border-bottom:none;padding:2px 0}}.sessions-table{width:100%;border-collapse:collapse}.sessions-table thead{position:sticky;top:0;z-index:2}.sessions-table thead th{position:relative;background:#ffffff0a;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);padding:10px 12px;text-align:left;border-bottom:2px solid color-mix(in srgb,var(--accent) 20%,var(--border));white-space:nowrap}.sessions-table tbody tr{cursor:pointer;transition:background .15s}.sessions-table tbody tr:hover{background:var(--hover)}.sessions-table tbody td{padding:10px 12px;font-size:13.5px;border-bottom:1px solid var(--border);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;vertical-align:middle}.sessions-table tbody tr:last-child td{border-bottom:none}@media (max-width: 700px){.sessions-table thead{display:none}.sessions-table,.sessions-table tbody,.sessions-table tr,.sessions-table td{display:block;width:100%}.sessions-table tbody tr{padding:10px 12px;border-bottom:1px solid var(--border);display:flex;flex-wrap:wrap;gap:4px 12px;align-items:center}.sessions-table tbody td{border-bottom:none;padding:2px 0}}.auth-events-table{width:100%;border-collapse:collapse}.auth-events-table thead{position:sticky;top:0;z-index:2}.auth-events-table thead th{position:relative;background:#ffffff0a;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);padding:10px 12px;text-align:left;border-bottom:2px solid color-mix(in srgb,var(--accent) 20%,var(--border));white-space:nowrap}.auth-events-table tbody tr{cursor:pointer;transition:background .15s}.auth-events-table tbody tr:hover{background:var(--hover)}.auth-events-table tbody tr.error-row{background:color-mix(in srgb,var(--danger, var(--error, #e74c3c)) 6%,transparent)}.auth-events-table tbody tr.error-row:hover{background:color-mix(in srgb,var(--danger, var(--error, #e74c3c)) 12%,transparent)}.auth-events-table tbody td{padding:10px 12px;font-size:13.5px;border-bottom:1px solid var(--border);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;vertical-align:middle}.auth-events-table tbody td.device-cell{overflow:visible;white-space:normal}.auth-events-table tbody tr:last-child td{border-bottom:none}@media (max-width: 700px){.auth-events-table thead{display:none}.auth-events-table,.auth-events-table tbody,.auth-events-table tr,.auth-events-table td{display:block;width:100%}.auth-events-table tbody tr{padding:10px 12px;border-bottom:1px solid var(--border);display:flex;flex-wrap:wrap;gap:4px 12px;align-items:center}.auth-events-table tbody td{border-bottom:none;padding:2px 0}}.line-chart-wrap{padding:12px 4px 4px;background:#ffffff05;border-radius:12px;border:1px solid rgba(255,255,255,.04)}.line-chart-svg{width:100%;display:block}.line-chart-axis-label{font-size:11px;fill:var(--muted);font-family:inherit}.line-chart-legend{display:flex;gap:20px;padding:0 12px 10px;font-size:12px}.line-chart-legend-item{display:flex;align-items:center;gap:8px;color:var(--muted);font-weight:500}.line-chart-legend-dot{width:10px;height:10px;border-radius:50%;display:inline-block;flex-shrink:0;box-shadow:0 0 6px currentColor}.peak-hours-chart{display:flex;align-items:flex-end;gap:3px;height:120px;padding:12px 8px 0;background:#ffffff05;border-radius:12px;border:1px solid rgba(255,255,255,.04)}.peak-hour-bar{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;justify-content:flex-end;position:relative;cursor:default}.peak-hour-bar:hover .peak-hour-fill{opacity:.9;filter:brightness(1.2)}.peak-hour-fill{width:100%;border-radius:4px 4px 0 0;transition:height .5s cubic-bezier(.16,1,.3,1),opacity .2s,filter .2s;min-height:2px}.peak-hour-label{font-size:9px;color:var(--muted);margin-top:4px;text-align:center;font-weight:500;opacity:.7}.peak-hour-bar:hover .peak-hour-label{opacity:1;color:var(--ink)}.report-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}.report-row.wide{grid-column:1 / -1}.report-row>.card.panel{margin:0}@media (max-width: 768px){.report-row{grid-template-columns:1fr}}.report-table{width:100%;border-collapse:separate;border-spacing:0}.report-table thead{position:sticky;top:0;z-index:2}.report-table thead th{position:relative;background:#ffffff0f;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);padding:12px 14px;text-align:left;border-bottom:1px solid rgba(255,255,255,.08);white-space:nowrap}.report-table thead th:first-child{border-radius:10px 0 0}.report-table thead th:last-child{border-radius:0 10px 0 0}.report-table tbody tr{transition:background .2s ease}.report-table tbody tr:hover{background:#ffffff0a}.report-table tbody td{padding:10px 14px;font-size:13px;border-bottom:1px solid rgba(255,255,255,.04);vertical-align:middle}.report-table tbody td.device-cell{white-space:normal}.report-table tbody tr:last-child td{border-bottom:none}@media (max-width: 700px){.report-table thead{display:none}.report-table,.report-table tbody,.report-table tr,.report-table td{display:block;width:100%}.report-table tbody tr{padding:10px 12px;border-bottom:1px solid var(--border);display:flex;flex-wrap:wrap;gap:4px 12px;align-items:center}.report-table tbody td{border-bottom:none;padding:2px 0}}.edit-user-groups{display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin-top:4px}.edit-user-groups .pill{margin:0}.edit-user-groups select{padding:4px 8px;font-size:12px}.bulk-action-bar{display:flex;align-items:center;gap:12px;padding:10px 16px;background:#ffffff0a;border:1px solid var(--accent);border-radius:10px;margin-bottom:8px;flex-wrap:wrap}.bulk-action-count{font-weight:600;font-size:13px;white-space:nowrap}.bulk-action-divider{width:1px;height:24px;background:var(--border);flex-shrink:0}.bulk-action-group{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.bulk-action-group select{padding:4px 8px;font-size:12px;min-width:120px}.bulk-action-bar button.small{padding:4px 10px;font-size:12px}@media (max-width: 600px){.bulk-action-bar{flex-direction:column;align-items:flex-start}.bulk-action-group{width:100%}.bulk-action-group select{min-width:0;flex:1}.bulk-action-divider{display:none}}.col-resize-handle{position:absolute;right:0;top:0;bottom:0;width:5px;cursor:col-resize;-webkit-user-select:none;user-select:none;z-index:2;border-radius:0 2px 2px 0;transition:background .15s}.col-resize-handle:hover{background:var(--accent);opacity:.5}.groups-table-wrap{overflow-x:auto}.groups-table{width:100%;border-collapse:collapse;table-layout:auto}.groups-table thead{position:sticky;top:0;z-index:2}.groups-table thead th{background:#ffffff0a;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);padding:10px 12px;text-align:left;border-bottom:2px solid color-mix(in srgb,var(--accent) 20%,var(--border));white-space:nowrap;position:relative}.groups-table tbody td{padding:10px 12px;font-size:13.5px;border-bottom:1px solid var(--border);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;vertical-align:middle}.groups-table tbody tr:last-child td{border-bottom:none}.grp-col-actions{width:160px;text-align:right;white-space:nowrap}.grp-col-actions button{padding:4px 10px;font-size:12px}@media (max-width: 600px){.groups-table thead{display:none}.groups-table,.groups-table tbody,.groups-table tr,.groups-table td{display:block;width:100%}.groups-table tbody tr{padding:10px 12px;border-bottom:1px solid var(--border);display:flex;flex-wrap:wrap;align-items:center;gap:6px}.groups-table tbody td{border-bottom:none;padding:2px 0}.grp-col-actions{width:100%;text-align:left}}.rules-table-wrap{max-height:400px;overflow-y:auto;overflow-x:auto}.rules-table{width:100%;border-collapse:collapse;table-layout:auto}.rules-table thead{position:sticky;top:0;z-index:2}.rules-table thead th{background:#ffffff0a;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);padding:10px 12px;border-bottom:2px solid color-mix(in srgb,var(--accent) 20%,var(--border));text-align:left;white-space:nowrap;position:relative}.rules-table tbody tr{transition:background .15s}.rules-table tbody tr:hover{background:var(--hover)}.rules-table tbody td{padding:10px 12px;font-size:13.5px;border-bottom:1px solid var(--border);vertical-align:middle}.rules-table tbody tr:last-child td{border-bottom:none}@media (max-width: 600px){.rules-table thead{display:none}.rules-table,.rules-table tbody,.rules-table tr,.rules-table td{display:block;width:100%}.rules-table tbody tr{padding:10px 12px;border-bottom:1px solid var(--border);display:flex;flex-wrap:wrap;align-items:center;gap:6px}.rules-table tbody td{border-bottom:none;padding:2px 0}}.user-table thead th,.nas-table thead th{position:relative}.grp-row{cursor:pointer}.grp-row:hover{background:var(--hover)}.grp-expand-icon{display:inline-block;width:16px;font-size:11px;color:var(--muted);transition:color .15s;-webkit-user-select:none;user-select:none}.grp-row.grp-selected .grp-expand-icon{color:var(--accent)}.grp-col-count{width:100px}.grp-expand-row>td.grp-expand-td{padding:0!important;background:var(--surface);border-bottom:2px solid var(--accent);border-top:none}.grp-expand-inner{padding:14px 16px 16px 28px;display:flex;flex-direction:column;gap:10px}.grp-expand-toolbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.grp-expand-label{font-size:13px;color:var(--muted);white-space:nowrap}.grp-expand-label strong{color:var(--fg)}.grp-expand-empty{color:var(--muted);font-size:13px;padding:8px 0;font-style:italic}.grp-members-table{width:100%;border-collapse:collapse;border:1px solid var(--border);border-radius:6px;overflow:hidden}.grp-members-table thead th{background:#ffffff0a;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);padding:7px 10px;border-bottom:2px solid color-mix(in srgb,var(--accent) 20%,var(--border));text-align:left}.grp-members-table tbody tr{transition:background .12s}.grp-members-table tbody tr:hover{background:var(--hover)}.grp-members-table tbody td{padding:7px 10px;font-size:13px;border-bottom:1px solid var(--border);vertical-align:middle}.grp-members-table tbody tr:last-child td{border-bottom:none}.grp-members-actions{width:80px;text-align:right;white-space:nowrap}.grp-members-actions button{padding:3px 8px;font-size:12px}@media (max-width: 640px){.grp-hide-mobile{display:none}.grp-expand-inner{padding:10px 12px}}.grp-add-rule-form{padding:12px 16px;background:var(--surface);border-bottom:1px solid var(--border)}.rules-group-name{vertical-align:top;background:color-mix(in srgb,var(--accent) 5%,transparent);border-right:2px solid var(--accent)}.rules-group-first td{border-top:1px solid var(--border)}.rules-group-cont td:not(.rules-group-name){border-top:1px dashed var(--border)}.bulk-preview-scroll{max-height:400px;overflow-y:auto;border:1px solid var(--border);border-radius:6px}.bulk-preview-table{width:100%;border-collapse:collapse}.bulk-preview-table thead{position:sticky;top:0;z-index:1}.bulk-preview-table th{background:#ffffff0a;font-weight:600;font-size:10px;text-transform:uppercase;letter-spacing:.3px;color:var(--muted);padding:8px 6px;text-align:left;border-bottom:2px solid var(--border);white-space:nowrap}.bulk-preview-table td{padding:4px;border-bottom:1px solid var(--border);vertical-align:middle}.bulk-preview-table tbody tr:last-child td{border-bottom:none}.bulk-preview-table tbody tr:hover{background:var(--hover)}.bp-input{width:100%;font-size:12px;padding:5px 8px;border:1px solid var(--border);border-radius:4px;background:var(--bg);color:var(--fg);box-sizing:border-box;transition:border-color .15s}.bp-input:focus{outline:none;border-color:var(--accent)}.bp-input.bp-error{border-color:var(--danger, #e53e3e);background:color-mix(in srgb,var(--danger, #e53e3e) 6%,var(--bg))}.bp-col-remove{width:36px;text-align:center}.bp-remove-btn{padding:3px 7px!important;min-width:0!important}.bp-group-cell{display:flex;flex-wrap:wrap;gap:3px;align-items:center}.bp-group-pill{display:inline-flex!important;align-items:center;gap:3px}.bp-group-remove{background:none;border:none;color:var(--muted);cursor:pointer;padding:0 2px;font-size:11px;line-height:1}.bp-group-remove:hover{color:var(--danger, var(--fg))}.bp-group-add{font-size:11px;padding:2px 4px;border:1px solid var(--border);border-radius:4px;background:var(--bg);color:var(--fg);min-width:36px;cursor:pointer}@media (max-width: 900px){.bp-hide-tablet{display:none}}@media (max-width: 600px){.bp-hide-mobile{display:none}}.user-table tbody tr:nth-child(2n),.nas-table tbody tr:nth-child(2n),.sites-table tbody tr:nth-child(2n),.sessions-table tbody tr:nth-child(2n),.auth-events-table tbody tr:nth-child(2n),.report-table tbody tr:nth-child(2n),.groups-table tbody tr:nth-child(2n),.rules-table tbody tr:nth-child(2n),.grp-members-table tbody tr:nth-child(2n){background:#ffffff05}.filter-pills .pill.active{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;box-shadow:0 2px 8px color-mix(in srgb,var(--accent) 30%,transparent)}.empty-state .empty-icon{font-size:36px;margin-bottom:12px;opacity:.4}.empty-state .empty-title{font-size:16px;font-weight:600;margin-bottom:4px}.empty-state .empty-desc{color:var(--muted);font-size:13px}.stats.compact .card.stat{border-top:none;background:#ffffff08}html[data-theme=light] .card.stat{border-top-color:var(--accent);background:linear-gradient(180deg,#2563eb0a,#fffc)}html[data-theme=light] .user-table thead th,html[data-theme=light] .nas-table thead th,html[data-theme=light] .sites-table thead th,html[data-theme=light] .sessions-table thead th,html[data-theme=light] .auth-events-table thead th,html[data-theme=light] .report-table thead th,html[data-theme=light] .groups-table thead th,html[data-theme=light] .rules-table thead th,html[data-theme=light] .grp-members-table thead th{background:#00000008}
