:root{--bg:#f6f8ff;--surface:#fff;--surface-soft:#f1f5ff;--text:#172033;--muted:#64748b;--line:#dce5f5;--line-strong:#c5d3ea;--ink:#101a36;--blue:#2563eb;--cyan:#0891b2;--green:#2563eb;--violet:#7c3aed;--rose:#e11d48;--red:#c83232;--shadow:0 16px 42px #1f3d7c21;--shadow-soft:0 8px 22px #1f3d7c14;--radius:12px}*{box-sizing:border-box}html,body,#root{min-height:100%}html{background:var(--bg)}body{color:var(--text);background:radial-gradient(circle at 8% 8%, #2563eb1a, transparent 26rem), radial-gradient(circle at 92% 18%, #7c3aed14, transparent 24rem), linear-gradient(#0f172a09 1px, transparent 1px), linear-gradient(90deg, #0f172a09 1px, transparent 1px), var(--bg);background-size:28px 28px;margin:0;font-family:HarmonyOS Sans SC,MiSans,Microsoft YaHei,PingFang SC,Noto Sans CJK SC,sans-serif}body.no-scroll{overflow:hidden}button,input,select,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.58}h1,h2,h3{font-weight:800}@keyframes fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translate(28px)}to{opacity:1;transform:translate(0)}}@keyframes toastIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes pulseLine{0%,to{opacity:.52}50%{opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}.boot-screen{place-items:center;min-height:100vh;display:grid}.loading-block{color:var(--muted);justify-content:center;align-items:center;gap:12px;padding:48px 18px;font-weight:700;display:flex}.spinner{border:3px solid #2563eb33;border-top-color:var(--blue);border-radius:50%;width:22px;height:22px;animation:.8s linear infinite spin}.login-shell{place-items:center;min-height:100vh;padding:24px;display:grid}.login-card{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);width:min(980px,100%);box-shadow:var(--shadow);grid-template-columns:.92fr 1.08fr;animation:.36s ease-out both fadeUp;display:grid;overflow:hidden}.login-brand{color:#fff;background:radial-gradient(circle at 20% 20%,#60a5fa59,#0000 18rem),linear-gradient(135deg,#0b122f 0%,#172554 48%,#1d4ed8 100%);flex-direction:column;justify-content:space-between;min-height:430px;padding:44px;display:flex}.brand-mark{color:#fff;background:#ffffff1f;border:1px solid #ffffff42;border-radius:12px;place-items:center;width:48px;height:48px;font-weight:900;display:grid}.login-brand h1{margin:24px 0 10px;font-size:38px;line-height:1.02}.login-points{gap:10px;display:grid}.login-points span{color:#ffffffe0;background:#ffffff17;border:1px solid #ffffff2e;border-radius:8px;width:-moz-fit-content;width:fit-content;max-width:100%;padding:8px 10px;font-size:13px;font-weight:800}.login-form{align-content:center;gap:18px;padding:44px;display:grid}.login-form h2{margin:0 0 8px;font-size:26px}.login-form p{color:var(--muted);margin:0;line-height:1.7}.app-shell{grid-template-columns:268px minmax(0,1fr);min-height:100vh;display:grid}.sidebar{color:#fff;background:radial-gradient(circle at 18% 10%,#60a5fa40,#0000 16rem),linear-gradient(#0b122f 0%,#111c44 52%,#172554 100%);flex-direction:column;gap:18px;height:100vh;padding:20px;display:flex;position:sticky;top:0}.sidebar-title{border-bottom:1px solid #ffffff1f;align-items:center;gap:12px;padding:8px 6px 18px;display:flex}.sidebar-title strong{font-size:20px;display:block}.sidebar-title span{color:#ffffff94;font-size:12px}.nav{gap:6px;display:grid}.nav a{color:#ffffffc2;border:1px solid #0000;border-radius:10px;grid-template-columns:30px 1fr;align-items:center;gap:10px;width:100%;min-height:44px;padding:10px 12px;font-weight:800;text-decoration:none;transition:background .16s,color .16s,transform .16s,border-color .16s;display:grid}.nav a span{background:#ffffff1a;border-radius:8px;place-items:center;width:28px;height:28px;font-size:13px;display:grid}.nav a.active{color:var(--ink);background:#fff;box-shadow:0 10px 24px #00000029}.nav a.active span{color:#fff;background:linear-gradient(135deg, var(--blue), var(--violet))}.nav a:not(.active):hover{color:#fff;background:#ffffff14;border-color:#ffffff1a;transform:translate(2px)}.sidebar-foot{color:#ffffffb8;border-top:1px solid #ffffff1f;margin-top:auto;padding-top:16px;font-size:13px}.sidebar-foot strong{color:#fff;margin-bottom:4px;font-size:15px;display:block}.main{min-width:0}.topbar{z-index:4;border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#ffffffe0;justify-content:space-between;align-items:center;gap:16px;min-height:82px;padding:16px 28px;display:flex;position:sticky;top:0}.topbar-title{align-items:center;gap:12px;min-width:0;display:flex}.topbar h1{margin:0;font-size:25px;line-height:1.16}.topbar p{color:var(--muted);margin:5px 0 0;font-size:13px;line-height:1.55}.nav-toggle{display:none}.content{padding:24px 28px 44px;animation:.24s ease-out both fadeIn}.toolbar,.row-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.row-actions{justify-content:flex-start}.grid{gap:16px;display:grid}.grid.cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.panel{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow-soft)}.panel.pad{padding:18px}.helper-card{background:linear-gradient(90deg, #2563eb1a, transparent 48%), var(--surface);grid-template-columns:minmax(220px,.82fr) minmax(0,1.18fr);gap:18px;margin-bottom:18px;display:grid;overflow:hidden}.eyebrow{min-height:22px;color:var(--blue);background:#2563eb1f;border-radius:999px;align-items:center;padding:2px 8px;font-size:12px;font-weight:900;display:inline-flex}.helper-card h2,.form-intro h2{margin:10px 0 6px;font-size:20px;line-height:1.25}.helper-card p{color:var(--muted);margin:0;line-height:1.7}.helper-steps{gap:10px;display:grid}.helper-steps div{grid-template-columns:30px minmax(0,1fr);align-items:start;gap:3px 10px;min-width:0;padding:4px 0;display:grid}.helper-steps span{background:var(--ink);color:#fff;border-radius:8px;place-items:center;width:28px;height:28px;font-size:13px;font-weight:900;display:grid}.helper-steps strong{align-self:center;min-width:0;font-size:14px}.helper-steps p{color:var(--muted);grid-column:2;margin:0;font-size:13px}.metric{flex-direction:column;justify-content:space-between;min-height:120px;display:flex}.metric span{color:var(--muted);font-size:13px;font-weight:800}.metric strong{overflow-wrap:anywhere;margin:10px 0 8px;font-size:31px;line-height:1}.metric small{color:var(--muted);line-height:1.45}.section-head{justify-content:space-between;align-items:center;gap:12px;margin:24px 0 12px;display:flex}.section-head h2{margin:0;font-size:18px}.btn{border:1px solid var(--line-strong);min-height:38px;color:var(--text);background:#fff;border-radius:10px;justify-content:center;align-items:center;gap:7px;padding:8px 14px;font-weight:800;line-height:1.2;text-decoration:none;transition:transform .14s,box-shadow .14s,border-color .14s,background .14s;display:inline-flex}.btn:hover:not(:disabled){border-color:var(--green);transform:translateY(-1px);box-shadow:0 6px 16px #1f3d7c1f}.btn.primary{color:#fff;border-color:var(--green);background:linear-gradient(135deg, var(--blue), var(--violet))}.btn.danger{color:var(--red);background:#fff4f4;border-color:#f1b6b6}.btn.ghost{color:#ffffffdb;background:#ffffff14;border-color:#fff3;width:100%;margin-top:12px}.btn.ghost:hover:not(:disabled){background:#ffffff29}.field{min-width:0;color:var(--muted);gap:7px;font-size:13px;font-weight:800;display:grid}.field.align-end{align-content:end}.field-help{color:var(--muted);font-size:12px;font-weight:600;line-height:1.55}.input,.select,.textarea{border:1px solid var(--line-strong);width:100%;min-height:42px;color:var(--text);background:#fff;border-radius:10px;outline:none;padding:9px 11px;transition:border-color .14s,box-shadow .14s}.textarea{resize:vertical;min-height:86px}.input:focus,.select:focus,.textarea:focus{border-color:var(--green);box-shadow:0 0 0 3px #2563eb24}.select.compact{min-width:136px;min-height:34px;padding:6px 9px}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));align-items:start;gap:14px;display:grid}.form-grid .wide{grid-column:1/-1}.checkline{color:var(--muted);align-items:center;gap:7px;font-size:13px;font-weight:800;display:inline-flex}.checkline input{width:16px;height:16px}.user-result,.command-result{margin-bottom:14px}.user-result strong,.command-result strong{margin-bottom:8px;display:block}.command-result p{margin:0 0 10px}.table-wrap{border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-soft);background:#fff;overflow-x:auto}table{border-collapse:collapse;width:100%;min-width:780px}th,td{border-bottom:1px solid var(--line);text-align:left;vertical-align:middle;padding:13px 14px}th{color:var(--muted);background:var(--surface-soft);font-size:12px;font-weight:900}td{font-size:14px;line-height:1.45}td strong{overflow-wrap:anywhere}tbody tr:hover{background:#f8fbff}tr:last-child td{border-bottom:0}.cell-badges{flex-wrap:wrap;gap:6px;margin-top:4px;display:flex}.mono{font-family:SFMono-Regular,Cascadia Mono,Consolas,Menlo,monospace}.muted{color:var(--muted)}.badge{color:#38504a;white-space:nowrap;background:#e6eeeb;border-radius:999px;justify-content:center;align-items:center;gap:6px;max-width:100%;min-height:24px;padding:3px 8px;font-size:12px;font-weight:800;display:inline-flex}.badge.ok{color:#11613f;background:#dff7eb}.badge.warn{color:#895300;background:#fff1c7}.badge.danger{color:#9d2424;background:#ffe1e1}.badge.info{color:#1751b6;background:#dfeaff}.badge.neutral{color:#475569;background:#e2e8f0}.finding-list{gap:10px;display:grid}.finding{border:1px solid var(--line);border-left:4px solid var(--cyan);background:#fff;border-radius:10px;padding:13px 14px}.finding.warn{border-left-color:#c77700}.finding.critical{border-left-color:var(--red)}.finding span{color:var(--muted);margin-bottom:6px;font-size:12px;font-weight:900;display:inline-flex}.finding strong{margin-bottom:4px;display:block}.finding p{color:var(--muted);margin:0;line-height:1.6}.bar-track{background:#e8eefb;border-radius:999px;width:100%;height:10px;display:block;overflow:hidden}.bar-track>i{border-radius:inherit;background:linear-gradient(90deg, var(--blue), var(--cyan));min-width:0;height:100%;display:block}.bar-track>i.udp{background:linear-gradient(90deg, var(--violet), var(--rose))}.bar-track>i.bar-1{background:linear-gradient(90deg,#7c3aed,#d946ef)}.bar-track>i.bar-2{background:linear-gradient(90deg,#0284c7,#06b6d4)}.bar-track>i.bar-3{background:linear-gradient(90deg,#e11d48,#fb7185)}.bar-track>i.bar-4{background:linear-gradient(90deg,#f59e0b,#f97316)}.diag-card{gap:12px;min-height:190px;display:grid}.diag-head{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.diag-head strong{font-size:16px;display:block}.diag-head span{color:var(--muted);margin-top:3px;font-size:12px;display:block}.diag-card p{color:var(--muted);margin:0;line-height:1.6}.healthbar .bar-track{background:#e4ebe7;height:8px}.healthbar .bar-track>i{background:linear-gradient(90deg, var(--green), var(--cyan));animation:2.2s ease-in-out infinite pulseLine}.diag-mini{flex-wrap:wrap;gap:8px;margin-top:auto;display:flex}.diag-mini span{border:1px solid var(--line);color:var(--muted);background:var(--surface-soft);border-radius:999px;padding:4px 8px;font-size:12px;font-weight:700}.probe-stack,.rate-stack{gap:4px;display:grid}.probe-stack div{align-items:center;gap:6px;display:flex}.ruleset-details summary{color:var(--green);cursor:pointer;font-size:13px;font-weight:900}.ruleset-details .codebox{max-height:280px;margin-top:10px;overflow:auto}.codebox{white-space:pre-wrap;word-break:break-word;color:#e7f4ef;background:linear-gradient(#ffffff0a 1px, transparent 1px), var(--ink);background-size:100% 24px;border-radius:10px;margin:0;padding:14px;font-family:SFMono-Regular,Cascadia Mono,Consolas,Menlo,monospace;font-size:13px;line-height:1.65}.drawer .codebox{max-height:320px;overflow:auto}.toast-stack{z-index:30;gap:10px;max-width:min(420px,100vw - 40px);display:grid;position:fixed;bottom:20px;right:20px}.toast{background:var(--ink);color:#fff;box-shadow:var(--shadow);border-radius:10px;padding:13px 15px;animation:.2s ease-out both toastIn}.toast.danger{background:#991f1f}.toast.ok{background:#14693f}.empty-state{color:var(--muted);text-align:center;place-items:center;gap:8px;padding:30px;display:grid}.empty-state strong{color:var(--text);font-size:17px}.empty-state p{max-width:560px;margin:0;line-height:1.7}.empty-state span{color:var(--green);font-size:13px;font-weight:900}.empty-inline{color:var(--muted);border:1px dashed var(--line-strong);text-align:center;border-radius:10px;padding:14px}.drawer-backdrop{z-index:20;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#0f172a75;justify-content:flex-end;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.drawer{background:var(--surface);width:min(760px,100%);height:100vh;box-shadow:var(--shadow);grid-template-rows:auto 1fr;animation:.24s ease-out both slideIn;display:grid;overflow:hidden}.drawer-head{border-bottom:1px solid var(--line);background:var(--surface-soft);justify-content:space-between;align-items:flex-start;gap:14px;padding:18px;display:flex}.drawer-head h2{overflow-wrap:anywhere;margin:0;font-size:20px}.drawer-head p{color:var(--muted);margin:6px 0 0}.drawer-body{gap:18px;min-height:0;padding:18px;display:grid;overflow:auto}.detail-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;display:grid}.detail-grid div,.mini-table div,.metric-strip div{border:1px solid var(--line);background:var(--surface-soft);border-radius:10px;min-width:0;padding:12px}.detail-grid span{color:var(--muted);margin-bottom:6px;font-size:12px;display:block}.detail-grid strong{overflow-wrap:anywhere;display:block}.drawer-section{gap:10px;display:grid}.drawer-section h3{margin:0;font-size:15px}.mini-table{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.mini-table span,.mini-table em,.metric-strip span,.metric-strip em{color:var(--muted);font-size:12px;font-style:normal;display:block}.mini-table strong{overflow-wrap:anywhere;margin:5px 0;font-size:18px;display:block}.rule-mini-table strong{font-size:15px}.metric-strip{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;display:grid}.metric-strip strong{overflow-wrap:anywhere;margin:5px 0;font-size:20px;display:block}.chip-list{flex-wrap:wrap;gap:8px;display:flex}.chip-list span{border:1px solid var(--line);background:var(--surface-soft);border-radius:999px;padding:6px 9px;font-size:12px}.probe-list{gap:8px;display:grid}.probe-list div{border:1px solid var(--line);background:#fff;border-radius:10px;flex-wrap:wrap;align-items:center;gap:8px;padding:10px;display:flex}.probe-list small{color:var(--muted)}.notice-panel{background:#eff6ff;border:1px solid #bfdbfe;border-radius:10px;gap:8px;padding:13px;display:grid}.notice-panel p{color:#315178;margin:0;line-height:1.65}.modal-backdrop{z-index:25;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a85;justify-content:center;align-items:flex-start;padding:40px 20px;animation:.18s ease-out both fadeUp;display:flex;position:fixed;top:0;bottom:0;left:0;right:0;overflow-y:auto}.modal{border-radius:var(--radius);background:var(--surface);width:100%;max-height:calc(100vh - 80px);box-shadow:var(--shadow);grid-template-rows:auto 1fr;margin:auto;display:grid;overflow:hidden}.modal-head{border-bottom:1px solid var(--line);background:var(--surface-soft);justify-content:space-between;align-items:flex-start;gap:14px;padding:18px;display:flex}.modal-head>div{min-width:0}.modal-head h2{margin:0;font-size:19px}.modal-head p{color:var(--muted);margin:6px 0 0;font-size:13px;line-height:1.6}.modal-body{min-height:0;padding:18px;overflow:auto}.confirm-dialog{gap:18px;display:grid}.confirm-dialog p{color:var(--muted);margin:0;line-height:1.7}.traffic-panel{background:radial-gradient(circle at 16% 18%,#2563eb1f,#0000 22rem),radial-gradient(circle at 88% 20%,#7c3aed1a,#0000 18rem),#fff;gap:18px;margin-top:16px;display:grid;overflow:hidden}.traffic-head{justify-content:space-between;align-items:flex-start;gap:18px;display:flex}.traffic-head h2,.event-filter h2{margin:10px 0 6px;font-size:20px}.traffic-head p,.event-filter p{color:var(--muted);margin:0;line-height:1.7}.traffic-total{color:#fff;background:linear-gradient(135deg,#1d4ed8,#7c3aed);border-radius:12px;min-width:190px;padding:14px}.traffic-total strong{font-size:26px;display:block}.traffic-total span{color:#ffffffc7;margin-top:4px;font-size:12px;display:block}.traffic-split{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.traffic-split>div{gap:8px;display:grid}.traffic-split span{color:var(--muted);font-size:12px;font-weight:900}.traffic-bars{gap:10px;display:grid}.traffic-row{border:1px solid var(--line);background:#ffffffbd;border-radius:10px;grid-template-columns:minmax(170px,.9fr) minmax(160px,1fr) auto;align-items:center;gap:12px;min-width:0;padding:12px;display:grid}.traffic-row strong,.traffic-row span,.traffic-row .traffic-value{overflow-wrap:anywhere}.traffic-row span{color:var(--muted);margin-top:3px;font-size:12px;display:block}.rule-list{gap:14px;display:grid}.rule-card{gap:14px;padding:16px;display:grid;overflow:hidden}.rule-main{justify-content:space-between;align-items:flex-start;gap:14px;display:flex}.rule-title{min-width:0}.rule-title strong{overflow-wrap:anywhere;font-size:17px;display:block}.rule-title p{color:var(--muted);margin:5px 0 0;line-height:1.5}.rule-badges{flex-wrap:wrap;justify-content:flex-end;gap:6px;display:flex}.rule-path{grid-template-columns:minmax(0,1fr) 38px minmax(0,1fr);align-items:center;gap:10px;display:grid}.rule-path>div,.rule-meta div{border:1px solid var(--line);background:var(--surface-soft);border-radius:10px;min-width:0;padding:12px}.rule-path i{background:linear-gradient(90deg, var(--blue), var(--violet));border-radius:999px;height:2px}.rule-path span,.rule-meta span,.rule-meta em{color:var(--muted);font-size:12px;font-style:normal;display:block}.rule-path strong,.rule-meta strong{overflow-wrap:anywhere;margin-top:5px;display:block}.rule-meta{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;display:grid}.rule-actions{justify-content:flex-end}.event-filter{grid-template-columns:minmax(220px,1fr) auto;align-items:end;gap:16px;margin-bottom:14px;display:grid}.segment{background:var(--surface-soft);border-radius:10px;flex-wrap:wrap;gap:6px;padding:4px;display:flex}.segment button{min-height:32px;color:var(--muted);background:0 0;border:0;border-radius:8px;padding:6px 10px;font-weight:800}.segment button.active{color:#fff;background:linear-gradient(135deg, var(--blue), var(--violet))}.totp-setup{grid-template-columns:220px minmax(0,1fr);align-items:start;gap:16px;display:grid}.qr-card{border:1px solid var(--line);background:#fff;border-radius:12px;place-items:center;width:220px;min-height:220px;padding:12px;display:grid}.qr-svg{width:100%}.qr-svg svg{width:100%;height:auto;display:block}.qr-fallback{color:var(--muted);text-align:center;font-size:13px;line-height:1.5}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.001ms!important;animation-duration:.001ms!important;animation-iteration-count:1!important}}@media (max-width:1100px){.grid.cols-4{grid-template-columns:repeat(2,minmax(0,1fr))}.helper-card{grid-template-columns:1fr}}@media (max-width:980px){.app-shell{grid-template-columns:1fr}.sidebar{z-index:15;width:268px;transition:transform .2s;position:fixed;transform:translate(-100%)}.app-shell.nav-open .sidebar{transform:translate(0)}.nav-toggle{display:inline-flex}.grid.cols-3,.detail-grid,.metric-strip,.rule-meta{grid-template-columns:repeat(2,minmax(0,1fr))}.traffic-row{grid-template-columns:minmax(0,1fr)}.event-filter{grid-template-columns:1fr}.modal-backdrop{padding:24px 12px}.drawer{width:min(560px,100%)}}@media (max-width:720px){.login-shell{padding:14px}.login-card{grid-template-columns:1fr}.login-brand{min-height:240px;padding:28px}.login-form{padding:28px}.topbar{padding:14px 18px;position:static}.content{padding:18px 18px 34px}.modal-backdrop{padding:14px}.modal{max-height:calc(100vh - 28px)}.modal-head{flex-direction:column}.modal-head .btn{width:100%}.toolbar .btn,.row-actions .btn{min-width:0}.grid.cols-4,.grid.cols-3,.form-grid,.detail-grid,.mini-table,.metric-strip,.rule-meta,.traffic-split,.totp-setup{grid-template-columns:1fr}.rule-main{flex-direction:column}.rule-badges,.rule-actions{justify-content:flex-start}.rule-path{grid-template-columns:1fr}.rule-path i{background:linear-gradient(180deg, var(--blue), var(--violet));width:2px;height:22px;margin-left:14px}.traffic-head{flex-direction:column}.traffic-total{width:100%}.form-grid .wide{grid-column:auto}.drawer-head{flex-direction:column}.drawer{width:100%}.qr-card{width:min(220px,100%)}}
