*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #fafafb;--surface: #ffffff;--surface2: #f5f6f8;--border: #ececf0;--border2: #f3f4f7;--text: #16181d;--muted: #868b95;--dim: #b4b9c2;--accent: #2f6bed;--accent-light: #e8eefc;--green: #16a34a;--green-bg: #dcfce7;--green-border: #86efac;--red: #dc2626;--red-bg: #fef2f2;--red-border: #fca5a5;--amber: #d97706;--amber-bg: #fef3c7;--amber-border: #fcd34d;--purple: #1a1a1a;--blue: #2563eb;--gold: #d97706;--maroon: #dc2626;--critical: #dc2626;--critical-bg: #fef2f2;--critical-border: #fca5a5;--high: #d97706;--high-bg: #fef3c7;--high-border: #fcd34d;--ok: #16a34a;--ok-bg: #dcfce7;--ok-border: #86efac;--sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--mono: "JetBrains Mono", ui-monospace, "SF Mono", "Cascadia Code", "Consolas", monospace;--display: "Space Grotesk", "Inter", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;--radius-sm: 8px;--radius: 12px;--radius-lg: 16px;--shadow-sm: 0 1px 2px rgba(20,24,40,.04);--shadow: 0 2px 8px rgba(20,24,40,.06);--shadow-md: 0 8px 30px rgba(20,24,40,.1);--sidebar-width: 236px;--topbar-height: 58px}html,body,#root{height:100%;font-family:var(--sans);background:var(--bg);color:var(--text);font-size:14px;letter-spacing:-.006em;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}a{color:inherit;text-decoration:none}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}.app-shell{display:flex;height:100vh;overflow:hidden}.sidebar{width:var(--sidebar-width);background:#0e0f13;display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto;border-right:1px solid rgba(255,255,255,.04)}.sidebar-logo{padding:16px 18px;border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;gap:10px}.sidebar-logo-wordmark{font-family:var(--display);font-size:16px;font-weight:600;color:#fff;letter-spacing:-.02em}.sidebar-logo-sub{font-size:10px;color:#ffffff59;letter-spacing:.06em;text-transform:uppercase;margin-top:2px}.sidebar-nav{padding:8px 0;flex:1}.nav-section{padding:0 18px 4px;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:#fff3;margin-top:20px;margin-bottom:2px;font-weight:600}.nav-item{display:flex;align-items:center;gap:9px;padding:9px 18px;border-radius:6px;margin:1px 8px;font-size:13.5px;font-weight:400;color:#ffffff8c;cursor:pointer;transition:all .12s ease;-webkit-user-select:none;user-select:none}.nav-item:hover{color:#ffffffd9;background:#ffffff0d}.nav-item.active{color:#fff;font-weight:500;background:#ffffff1a}.nav-icon{font-size:13px;width:18px;text-align:center;flex-shrink:0}.nav-badge{margin-left:auto;background:var(--red);color:#fff;font-size:9px;font-weight:700;padding:1px 6px;border-radius:10px}.sidebar-footer{padding:14px 18px;border-top:1px solid rgba(255,255,255,.06);font-size:10px;color:#ffffff4d}.sync-status{display:flex;align-items:center;gap:6px;font-size:10px;color:#ffffff59}.sync-dot{width:6px;height:6px;border-radius:50%;background:var(--green);animation:pulse 2s infinite;flex-shrink:0}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.main-area{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg)}.topbar{display:flex;align-items:center;justify-content:space-between;padding:0 32px;height:var(--topbar-height);border-bottom:1px solid var(--border);background:#ffffffb3;-webkit-backdrop-filter:saturate(180%) blur(12px);backdrop-filter:saturate(180%) blur(12px);flex-shrink:0}.page-title{font-family:var(--display);font-size:18px;font-weight:600;letter-spacing:-.02em}.topbar-actions{display:flex;align-items:center;gap:10px}.page-content{flex:1;overflow-y:auto;padding:30px 32px;background:var(--bg)}.btn{height:36px;padding:0 16px;display:inline-flex;align-items:center;justify-content:center;gap:6px;font-size:13px;font-weight:600;border-radius:10px;border:1px solid var(--border);background:#fff;color:var(--text);cursor:pointer;transition:all .14s ease;white-space:nowrap}.btn:hover{background:var(--surface2);border-color:#dcdee4}.btn-primary{background:#16181d;color:#fff;border-color:#16181d}.btn-primary:hover{background:#2b2f3a;border-color:#2b2f3a}.btn:disabled{opacity:.35;cursor:not-allowed}.stats-grid{display:grid;gap:16px;margin-bottom:24px}.g2{grid-template-columns:repeat(2,1fr)}.g3{grid-template-columns:repeat(3,1fr)}.g4{grid-template-columns:repeat(4,1fr)}.g5{grid-template-columns:repeat(5,1fr)}.stat-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:20px 22px;position:relative;box-shadow:var(--shadow-sm);transition:box-shadow .16s ease,transform .16s ease}.stat-card:hover{box-shadow:var(--shadow);transform:translateY(-1px)}.stat-card:before{display:none}.sc-purple:before,.sc-blue:before,.sc-gold:before,.sc-maroon:before,.sc-critical:before,.sc-ok:before,.sc-high:before{display:none}.stat-label{font-size:11px;font-weight:500;text-transform:uppercase;color:var(--muted);margin-bottom:6px;letter-spacing:.03em}.stat-val{font-family:var(--display);font-size:32px;font-weight:600;line-height:1;letter-spacing:-.03em}.stat-val span{font-size:18px}.stat-sub{font-size:11px;color:var(--dim);margin-top:4px}.sc-critical .stat-val{color:var(--red)}.sc-high .stat-val{color:var(--amber)}.sc-ok .stat-val{color:var(--green)}.sc-purple .stat-val{color:var(--text)}.sc-blue .stat-val{color:var(--accent)}.sc-gold .stat-val{color:var(--amber)}.pill{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:600;letter-spacing:.02em;white-space:nowrap;border:none}.pill.critical{color:#fff;background:var(--red)}.pill.high{color:#92400e;background:var(--amber-bg)}.pill.low{color:#166534;background:var(--green-bg)}.pill-dot{width:5px;height:5px;border-radius:50%;background:currentColor}.flag-tag{font-size:10px;padding:2px 8px;border-radius:4px;border:1px solid;font-weight:500}.flag-c{color:var(--red);background:var(--red-bg);border-color:var(--red-border)}.flag-h{color:var(--amber);background:var(--amber-bg);border-color:var(--amber-border)}.flag-ok{color:var(--green);background:var(--green-bg);border-color:var(--green-border)}.table-wrap{background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:20px;box-shadow:var(--shadow-sm)}.tbl-head{display:grid;padding:11px 20px;border-bottom:1px solid var(--border);background:var(--surface2);gap:10px;align-items:center}.th{font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);-webkit-user-select:none;user-select:none;font-weight:600}.tbl-row{display:grid;padding:12px 20px;gap:10px;border-bottom:1px solid var(--border2);align-items:center;transition:background .08s ease;font-size:13px}.tbl-row:last-child{border-bottom:none}.tbl-row.clickable{cursor:pointer}.tbl-row.clickable:hover{background:var(--surface2)}.tbl-name{font-weight:600}.tbl-sub{font-family:var(--mono);font-size:10px;color:var(--dim);margin-top:2px}.tbl-mono{font-family:var(--mono);font-size:12px}.tbl-muted{font-size:12px;color:var(--muted)}.gb-wrap{display:flex;flex-direction:column;gap:3px}.gb-val{font-family:var(--mono);font-size:12px;font-weight:600}.gb-val.g{color:var(--green)}.gb-val.w{color:var(--amber)}.gb-val.b{color:var(--red)}.gb-bg{height:3px;background:var(--border);border-radius:2px}.gb-fill{height:3px;border-radius:2px;transition:width .3s ease}.gb-fill.g{background:var(--green)}.gb-fill.w{background:var(--amber)}.gb-fill.b{background:var(--red)}.controls{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}.search-wrap{position:relative;flex:1;max-width:300px}.search-ic{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--dim);font-size:14px;pointer-events:none}.search-input{width:100%;background:#fff;border:1px solid var(--border);color:var(--text);padding:9px 12px 9px 32px;font-size:13px;outline:none;border-radius:10px;transition:border-color .12s,box-shadow .12s}.search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.search-input::placeholder{color:var(--dim)}.sel-wrap{position:relative}.sel-wrap:after{content:"▾";position:absolute;right:10px;top:50%;transform:translateY(-50%);color:var(--muted);font-size:9px;pointer-events:none}select.flt{background:#fff;border:1px solid var(--border);color:var(--text);padding:8px 28px 8px 12px;font-size:13px;outline:none;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:var(--radius-sm)}select.flt:focus{border-color:var(--accent)}.ml-auto{margin-left:auto}.count-lbl{font-size:12px;color:var(--muted)}.tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:20px;gap:0}.tab{padding:10px 18px;font-size:13px;font-weight:500;cursor:pointer;color:var(--muted);border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .12s ease;-webkit-user-select:none;user-select:none;display:flex;align-items:center;gap:6px}.tab:hover{color:var(--text)}.tab.active{color:var(--text);border-bottom-color:var(--accent);font-weight:600}.section-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.section-title{font-family:var(--display);font-size:15px;font-weight:600;letter-spacing:-.01em}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px}.card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow-sm)}.card-title{font-family:var(--display);font-size:13.5px;font-weight:600;letter-spacing:-.01em;margin-bottom:14px}.risk-bar-wrap{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:20px}.risk-bar-label{font-size:13px;font-weight:700;margin-bottom:14px}.risk-bar{display:flex;height:8px;border-radius:4px;overflow:hidden;gap:2px;margin-bottom:12px}.rb-seg{height:100%;border-radius:4px;transition:width .5s ease}.risk-legend{display:flex;gap:20px}.rl-item{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted)}.rl-dot{width:8px;height:8px;border-radius:2px}.flags-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:20px}.flag-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;cursor:pointer;transition:all .12s ease}.flag-card:hover{border-color:#ccc;box-shadow:var(--shadow)}.fc-count{font-size:26px;font-weight:700;color:var(--red)}.fc-label{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin-top:4px;font-weight:600}.expand-btn{width:26px;height:26px;border:1px solid var(--border);background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:13px;color:var(--muted);transition:all .1s ease;flex-shrink:0;font-family:var(--mono);border-radius:var(--radius-sm)}.expand-btn:hover{background:#f5f5f5}.expand-btn.open{background:var(--accent);color:#fff;border-color:var(--accent)}.roster-wrap{border-top:1px solid var(--border);background:#fafafa;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.roster-hdr{display:flex;align-items:center;justify-content:space-between;padding:10px 20px 10px 52px;border-bottom:1px solid var(--border2);font-size:11px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.06em}.warn-actions{display:flex;gap:6px}.warn-btn{padding:5px 12px;font-size:12px;font-weight:500;border-radius:var(--radius-sm);border:1px solid var(--border);background:#fff;color:var(--muted);cursor:pointer;transition:all .1s ease}.warn-btn:hover{background:var(--text);color:#fff;border-color:var(--text)}.warn-btn.resolve{border-color:var(--green-border);color:var(--green)}.warn-btn.resolve:hover{background:var(--green);color:#fff;border-color:var(--green)}.report-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}.report-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:22px;cursor:pointer;transition:all .12s ease;position:relative}.report-card:hover{border-color:#ccc;box-shadow:var(--shadow)}.rc-icon{font-size:22px;margin-bottom:12px}.rc-title{font-size:14px;font-weight:700;margin-bottom:6px}.rc-desc{font-size:12px;color:var(--muted);line-height:1.6}.rc-badge{position:absolute;top:14px;right:14px;font-size:10px;padding:2px 8px;background:var(--green-bg);color:var(--green);border-radius:10px;font-weight:600}.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.setting-section{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:22px}.ss-title{font-size:13px;font-weight:700;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border)}.setting-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border2);font-size:13px}.setting-row:last-child{border-bottom:none}.setting-key{font-weight:500}.setting-val{font-family:var(--mono);font-size:12px;color:var(--muted);max-width:180px;text-align:right;word-break:break-all}.toggle{width:38px;height:20px;background:var(--green);border-radius:10px;position:relative;cursor:pointer;flex-shrink:0;transition:background .2s ease}.toggle:after{content:"";width:16px;height:16px;background:#fff;border-radius:50%;position:absolute;top:2px;right:2px;transition:right .2s ease;box-shadow:0 1px 2px #00000026}.toggle.off{background:#ddd}.toggle.off:after{right:20px}.health-bar-bg{height:6px;background:#eee;border-radius:3px;overflow:hidden;margin:6px 0}.health-bar-fill{height:100%;background:var(--green);border-radius:3px;transition:width .3s ease}.health-label{font-size:11px;color:var(--muted);display:flex;justify-content:space-between}.wr-section{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:22px;margin-bottom:16px}.wr-title{font-size:14px;font-weight:700;margin-bottom:14px;display:flex;align-items:center;gap:12px}.wr-title:after{content:"";flex:1;height:1px;background:var(--border)}.wr-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border2);font-size:13px}.wr-row:last-child{border-bottom:none}.wr-key{color:var(--muted)}.wr-val{font-family:var(--mono);font-size:13px;font-weight:600}.wr-val.up{color:var(--red)}.wr-val.dn{color:var(--green)}.wr-val.neu{color:var(--muted)}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;z-index:100;animation:fadeIn .15s ease}.drawer{position:fixed;right:0;top:0;bottom:0;width:500px;background:#fff;border-left:1px solid var(--border);z-index:101;overflow-y:auto;animation:slideIn .25s cubic-bezier(.4,0,.2,1);box-shadow:-4px 0 24px #00000014}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.drawer-head{padding:22px 24px 18px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;justify-content:space-between;position:sticky;top:0;background:#fff;z-index:1}.drawer-name{font-size:18px;font-weight:700}.drawer-sub{font-size:12px;color:var(--muted);margin-top:3px}.drawer-close{background:transparent;border:1px solid var(--border);width:30px;height:30px;display:flex;align-items:center;justify-content:center;font-size:13px;color:var(--muted);cursor:pointer;flex-shrink:0;border-radius:var(--radius-sm);transition:all .1s ease}.drawer-close:hover{background:#f5f5f5}.drawer-body{padding:22px 24px}.drawer-section{margin-bottom:24px}.ds-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border)}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:22px}.info-item{background:#f9f9f9;border:1px solid var(--border2);border-radius:var(--radius-sm);padding:14px}.info-item-label{font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:5px;font-weight:600}.info-item-val{font-family:var(--mono);font-size:13px;font-weight:600}.activity-chart{display:flex;align-items:flex-end;gap:1px;height:50px;margin-top:10px}.act-bar{flex:1;border-radius:1px 1px 0 0;min-height:1px;transition:height .2s ease}.act-bar.ca{background:var(--green)}.act-bar.intl{background:var(--red)}.act-bar.vpn{background:var(--amber)}.act-bar.none{background:#eee}.chart-legend{display:flex;gap:14px;margin-top:8px;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:5px;font-size:10px;color:var(--muted)}.legend-dot{width:8px;height:8px;border-radius:2px}.ip-table-row{display:grid;grid-template-columns:1fr 70px 90px 80px;gap:8px;padding:8px 0;border-bottom:1px solid var(--border2);font-family:var(--mono);font-size:11px;align-items:center}.ip-table-row:last-child{border-bottom:none}.ip-head{font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--dim);font-weight:600}.spinner{display:inline-block;width:14px;height:14px;border:2px solid #eee;border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite;vertical-align:middle}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{padding:48px;text-align:center;font-size:13px;color:var(--dim)}.loading-state{padding:48px;text-align:center;font-size:13px;color:var(--muted);display:flex;align-items:center;justify-content:center;gap:10px}.error-state{padding:14px 18px;background:var(--amber-bg);border:1px solid var(--amber-border);border-radius:var(--radius-sm);color:#92400e;font-size:13px;margin-bottom:20px;font-weight:500}.sync-log-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border2);font-size:12px}.sync-log-row:last-child{border-bottom:none}.sync-ok{color:var(--green);font-weight:600}.sync-warn{color:var(--amber);font-weight:600}.sync-err{color:var(--red);font-weight:600}.activity-row{display:flex;align-items:center;gap:12px;padding:7px 0;border-bottom:1px solid var(--border2);font-size:13px}.activity-row:last-child{border-bottom:none}.activity-row.clickable{cursor:pointer}.activity-row.clickable:hover{background:#f9f9f9;margin:0 -18px;padding:7px 18px}.activity-name{font-weight:500;flex:1}.drop-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:36px;text-align:center;cursor:pointer;transition:all .15s ease;margin-top:12px}.drop-zone:hover{border-color:var(--accent);background:var(--accent-light)}
