*,::after,::before{margin:0;padding:0;box-sizing:border-box}:root{--bg:#030712;--surface:#0a0f1a;--surface-2:#111827;--glass:rgba(255,255,255,0.03);--glass-border:rgba(255,255,255,0.08);--border:rgba(83,140,190,0.2);--border-light:rgba(255,255,255,0.08);--primary:#538cbe;--primary-light:#7ab0d9;--text:#f9fafb;--text-muted:#b0b8c4;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--radius:12px;--radius-sm:8px;--transition:0.15s;--card-shadow:0 1px 3px rgba(0,0,0,0.3),0 4px 12px rgba(0,0,0,0.15);--bg-subtle:rgba(255,255,255,0.04);--bg-hover:rgba(255,255,255,0.06);--font-sans:'Outfit',system-ui,-apple-system,sans-serif;--font-mono:'JetBrains Mono','Fira Code',ui-monospace,SFMono-Regular,Menlo,monospace}html{height:100%}body{font-family:var(--font-sans);background:var(--bg);color:var(--text);line-height:1.6;min-height:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:rgba(83,140,190,.25);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:rgba(83,140,190,.4)}*{scrollbar-width:thin;scrollbar-color:rgba(83,140,190,0.25) transparent}:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.glow-blob{position:fixed;border-radius:50%;filter:blur(120px);pointer-events:none;z-index:0}@media(prefers-reduced-motion:reduce){.glow-blob{animation:none;opacity:.3}}.glow-blob-1{width:500px;height:500px;background:var(--primary);top:-200px;left:-150px;opacity:.12;animation:blobMove1 20s ease-in-out infinite}.glow-blob-2{width:500px;height:500px;background:var(--primary-light);bottom:-200px;right:-150px;opacity:.1;animation:blobMove2 25s ease-in-out infinite}.glow-blob-3{width:350px;height:350px;background:var(--primary);top:50%;left:50%;transform:translate(-50%,-50%);opacity:.04;animation:blobMove3 30s ease-in-out infinite}.grid-pattern{position:fixed;inset:0;pointer-events:none;z-index:0;background-image:linear-gradient(rgba(83,140,190,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(83,140,190,.03) 1px,transparent 1px);background-size:80px 80px;mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 40%,transparent 100%);-webkit-mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 40%,transparent 100%)}.login-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;padding:1rem;position:relative;z-index:1}.login-card{width:100%;max-width:400px;background:var(--glass);border:1px solid var(--glass-border);border-radius:20px;padding:40px 36px;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 8px 32px rgba(0,0,0,.3);animation:cardAppear .6s ease}.login-logo{text-align:center;margin-bottom:32px;display:flex;align-items:center;justify-content:center;gap:10px}.login-logo img{border-radius:6px}.logo-badge{background:linear-gradient(135deg,var(--primary),#3a6a96);color:#fff;font-size:11px;font-weight:700;padding:4px 10px;border-radius:6px;letter-spacing:1.5px}.login-form{display:flex;flex-direction:column;gap:18px}.form-group{display:flex;flex-direction:column}.form-group label{font-size:12px;font-weight:500;color:var(--text-muted);margin-bottom:6px}.form-group .input-wrap{position:relative}.form-group .input-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none;display:flex;transition:color .2s}.form-group .input-wrap input{padding-left:38px}.form-group input,.form-group select{width:100%;padding:12px 14px;background:var(--bg-subtle);border:1px solid var(--glass-border);border-radius:10px;color:var(--text);font-size:14px;font-family:inherit;outline:0;transition:border-color .2s,box-shadow .2s;caret-color:var(--primary-light)}.form-group input::placeholder{color:var(--text-muted)}input::-ms-reveal,input::-webkit-credentials-auto-fill-button{display:none}input[type=password]::-ms-reveal{display:none}.form-group input:focus,.form-group select:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(83,140,190,.15)}.form-group .input-wrap:focus-within .input-icon,.form-group input:focus~.input-icon{color:var(--primary-light)}.form-group select option{background:var(--surface);color:var(--text)}.password-wrap{position:relative}.password-wrap input{padding-right:44px}.password-toggle{position:absolute;right:4px;top:50%;transform:translateY(-50%);background:0 0;border:none;color:var(--text-muted);cursor:pointer;padding:8px;border-radius:6px;display:flex;align-items:center;transition:color .2s}.password-toggle:hover{color:var(--text)}.password-toggle:focus-visible{color:var(--text);outline:2px solid var(--primary);outline-offset:2px;border-radius:6px}.login-remember{display:flex;align-items:center;gap:8px;margin-top:-4px}.login-remember input{width:16px;height:16px;accent-color:var(--primary);cursor:pointer;flex-shrink:0}.login-remember label{font-size:12px;color:var(--text-muted);cursor:pointer}.btn-login{width:100%;padding:13px;border:none;border-radius:10px;background:linear-gradient(135deg,var(--primary),#4a8ec4);color:#fff;font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px rgba(83,140,190,.35);margin-top:4px}.btn-login:hover{background:linear-gradient(135deg,var(--primary-light),#5ca0d4);box-shadow:0 6px 20px rgba(83,140,190,.4);transform:translateY(-1px)}.btn-login:focus-visible{box-shadow:0 0 0 3px rgba(83,140,190,.4)}.btn-login:active{transform:translateY(0)}.btn-login:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.login-footer{text-align:right;margin-top:6px}.login-footer a{color:var(--text-muted);font-size:12px;text-decoration:none;transition:color .2s}.login-footer a:hover{color:var(--primary-light)}.login-error{background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.25);border-radius:8px;padding:10px 14px;font-size:13px;color:var(--danger);display:none;animation:tabFade .3s ease;margin-bottom:8px}.login-error.visible{display:block}.login-step{display:none}.login-step.active{display:block}.code-inputs{display:flex;gap:8px;justify-content:center;margin-bottom:20px}.code-inputs input{width:46px;height:56px;text-align:center;font-size:24px;font-weight:600;background:var(--bg-subtle);border:1px solid var(--glass-border);border-radius:10px;color:var(--text);font-family:inherit;outline:0;transition:border-color .2s,box-shadow .2s;caret-color:transparent}.code-inputs input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(83,140,190,.15)}.code-inputs input.filled{border-color:var(--primary);background:rgba(83,140,190,.04)}.code-inputs.error input{border-color:var(--danger);box-shadow:0 0 0 2px rgba(239,68,68,.15);animation:codeShake .4s}.code-inputs .code-gap{width:12px}.step-icon{text-align:center;margin-bottom:12px;color:var(--primary-light)}.step-title{text-align:center;font-size:1.1rem;font-weight:600;margin-bottom:6px}.step-desc{text-align:center;font-size:14px;color:var(--text-muted);margin-bottom:24px;line-height:1.5}.step-link{display:block;text-align:center;margin-top:12px;color:var(--text-muted);font-size:13px;text-decoration:none;cursor:pointer;transition:color .2s}.step-link:hover{color:var(--primary-light)}.lang-switch{position:fixed;bottom:1.2rem;left:50%;transform:translateX(-50%);z-index:10;display:flex;gap:2px;background:var(--glass);border:1px solid var(--glass-border);border-radius:8px;padding:2px;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.lang-switch a{display:flex;align-items:center;justify-content:center;width:28px;height:26px;border-radius:6px;border:none;background:0 0;color:var(--text-muted);font-size:10px;font-weight:600;text-decoration:none;text-transform:uppercase;transition:all .2s}.lang-switch a:hover{color:var(--text)}.lang-switch a:focus-visible{color:var(--text);outline:2px solid var(--primary);outline-offset:2px}.lang-switch a.active{color:#fff;background:var(--primary)}.chart-loader{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;border-radius:8px;background:rgba(0,0,0,.15);transition:opacity .3s ease;z-index:2}.chart-loader.hidden{opacity:0;pointer-events:none}.chart-loader-spinner{width:28px;height:28px;border:3px solid rgba(83,140,190,.15);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}.chart-loader-skeleton{background:0 0;padding:1.5rem 1.25rem}.chart-skeleton-bars{display:flex;align-items:flex-end;gap:.4rem;width:100%;height:100%}.chart-skeleton-bars .skeleton{border-radius:3px 3px 0 0;min-width:8px}.spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.sidebar{position:fixed;top:0;left:0;bottom:0;width:220px;background:linear-gradient(180deg,var(--surface),rgba(8,12,24,.98));border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:100;transition:width .2s ease}.sidebar--collapsed,html.sidebar-collapsed .sidebar{width:60px}.sidebar-header{height:56px;display:flex;align-items:center;justify-content:space-between;padding:0 12px;border-bottom:1px solid var(--border);flex-shrink:0}.sidebar-logo{display:flex;align-items:center;gap:8px;text-decoration:none;min-width:0}.sidebar-logo img{width:32px;height:32px;border-radius:6px;flex-shrink:0}.sidebar-logo-text{background:linear-gradient(135deg,var(--primary),#3a6a96);color:#fff;font-size:11px;padding:4px 10px;border-radius:6px;font-weight:700;letter-spacing:1.5px;white-space:nowrap}.sidebar-toggle{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;border:1px solid var(--border-light);background:0 0;color:var(--text-muted);cursor:pointer;transition:all .2s;flex-shrink:0}.sidebar-toggle:hover{color:var(--text);background:var(--bg-hover)}.sidebar-toggle:focus-visible{color:var(--text);background:var(--bg-hover);outline:0}.sidebar--collapsed .sidebar-toggle svg,html.sidebar-collapsed .sidebar .sidebar-toggle svg{transform:rotate(180deg)}.sidebar--collapsed .sidebar-logo-text,html.sidebar-collapsed .sidebar .sidebar-logo-text{display:none}.sidebar--collapsed .sidebar-header,html.sidebar-collapsed .sidebar .sidebar-header{justify-content:center;padding:0 8px}.sidebar--collapsed .sidebar-logo,html.sidebar-collapsed .sidebar .sidebar-logo{justify-content:center}.sidebar--collapsed .sidebar-toggle,html.sidebar-collapsed .sidebar .sidebar-toggle{position:absolute;top:14px;right:-14px;width:28px;height:28px;background:var(--surface);border:1px solid var(--border);border-radius:50%;z-index:10}.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:2px;padding:12px 8px;overflow-y:auto}.view-btn{position:relative;display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border-radius:8px;border:none;background:0 0;color:var(--text-muted);font-size:13px;font-family:inherit;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap;text-align:left}.view-btn:hover{color:var(--text);background:rgba(255,255,255,.04)}.view-btn:hover .nav-icon{color:var(--primary-light)}.view-btn:focus-visible{color:var(--text);background:rgba(255,255,255,.04);outline:2px solid var(--primary);outline-offset:2px}.view-btn.active{background:linear-gradient(90deg,rgba(83,140,190,.22) 0,rgba(83,140,190,.08) 100%);color:#fff;font-weight:600;letter-spacing:.2px;box-shadow:inset 0 0 0 1px rgba(83,140,190,.15)}.view-btn.active::after{content:'';position:absolute;top:50%;right:8px;width:6px;height:6px;border-radius:50%;background:var(--primary-light);box-shadow:0 0 10px rgba(122,176,217,.8);transform:translateY(-50%)}.view-btn.active .nav-icon{color:var(--primary-light);stroke-width:2.2}.sidebar--collapsed .view-btn.active::after,html.sidebar-collapsed .sidebar .view-btn.active::after{display:none}.nav-icon{width:18px;height:18px;flex-shrink:0;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.sidebar--collapsed .sidebar-nav .view-btn,html.sidebar-collapsed .sidebar .sidebar-nav .view-btn{justify-content:center;padding:10px 0}.sidebar--collapsed .sidebar-nav .view-btn span,html.sidebar-collapsed .sidebar .sidebar-nav .view-btn span{display:none}.sidebar-footer{padding:8px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:4px;flex-shrink:0}.sidebar-api-row{display:flex;align-items:center;justify-content:center;gap:.4rem;padding:6px 20px;flex-shrink:0}.sidebar-api-link{font-size:.65rem;color:var(--text-muted);text-decoration:none;opacity:.5;transition:opacity var(--transition)}.sidebar-api-link:hover{opacity:1}.sidebar--collapsed .sidebar-api-row,html.sidebar-collapsed .sidebar .sidebar-api-row{padding:0;height:0;overflow:hidden}.sidebar--collapsed .sidebar-api-link,html.sidebar-collapsed .sidebar .sidebar-api-link{font-size:0}.sidebar--collapsed .sidebar-api-sep,html.sidebar-collapsed .sidebar .sidebar-api-sep{font-size:0}.sidebar-avatar{width:32px;height:32px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;flex-shrink:0}.agent-menu-wrap{position:relative}.sidebar-user-btn{display:flex;align-items:center;gap:10px;width:100%;padding:8px 12px;border-radius:8px;border:none;background:0 0;color:var(--text-muted);font-size:13px;font-family:inherit;cursor:pointer;transition:all .2s;text-align:left}.sidebar-user-btn:hover{background:var(--bg-subtle);color:var(--text)}.sidebar-user-btn:focus-visible{background:var(--bg-subtle);color:var(--text);outline:2px solid var(--primary);outline-offset:-2px}.sidebar-user-btn svg{opacity:.5;transition:transform .2s;margin-left:auto}.agent-menu-wrap.open .sidebar-user-btn svg{transform:rotate(180deg)}.agent-menu-wrap.open .sidebar-user-btn{background:var(--bg-hover);color:var(--text)}.sidebar--collapsed .sidebar-user-btn,html.sidebar-collapsed .sidebar .sidebar-user-btn{justify-content:center;padding:8px 0}.sidebar--collapsed .sidebar-user-btn #sidebarUserName,.sidebar--collapsed .sidebar-user-btn svg:last-child,html.sidebar-collapsed .sidebar .sidebar-user-btn #sidebarUserName,html.sidebar-collapsed .sidebar .sidebar-user-btn svg:last-child{display:none}.agent-dropdown{position:fixed;bottom:12px;left:228px;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;min-width:180px;box-shadow:0 8px 24px rgba(0,0,0,.4);z-index:120;overflow:hidden;animation:dropdownRight .15s ease;white-space:nowrap;transition:left .2s ease}body.sidebar-collapsed .agent-dropdown,html.sidebar-collapsed .agent-dropdown{left:68px}.agent-dropdown-item{display:flex;align-items:center;gap:10px;width:100%;padding:11px 16px;background:0 0;border:none;border-bottom:1px solid var(--border-light);color:var(--text-muted);font-size:13px;font-family:inherit;cursor:pointer;transition:all var(--transition);text-align:left}.agent-dropdown-item:last-child{border-bottom:none}.agent-dropdown-item:hover{background:rgba(255,255,255,.05);color:var(--text)}.agent-dropdown-item:focus-visible{background:rgba(255,255,255,.05);color:var(--text);outline:2px solid var(--primary);outline-offset:2px}.agent-dropdown-item.danger:hover{color:var(--danger)}.topbar-mobile{display:none;height:56px;background:var(--surface);border-bottom:1px solid var(--border);align-items:center;justify-content:space-between;padding:0 12px;position:sticky;top:0;z-index:100}.topbar-logo{display:flex;align-items:center;gap:8px;text-decoration:none;flex-shrink:0}.topbar-logo img{height:28px;width:28px}.topbar-right{display:flex;align-items:center;gap:10px}.topbar-agent-name{font-size:13px;color:var(--text-muted);font-weight:500}.topbar-logout-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;border:1px solid var(--border-light);background:0 0;color:var(--text-muted);cursor:pointer;transition:all .2s}.topbar-logout-btn:hover{color:var(--danger);border-color:rgba(239,68,68,.3);background:rgba(239,68,68,.08)}.topbar-logout-btn:focus-visible{color:var(--danger);border-color:rgba(239,68,68,.3);outline:0}.mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;z-index:100;background:var(--surface);border-top:1px solid var(--border);padding:2px 0;padding-bottom:max(2px,env(safe-area-inset-bottom));justify-content:space-around}.mobile-nav .view-btn{flex-direction:column;gap:2px;padding:6px 2px 4px;font-size:0;flex:1;justify-content:center;align-items:center;border-radius:0;min-width:0;width:auto}.mobile-nav .view-btn span{display:none}.mobile-nav .view-btn.active span{display:block;font-size:9px;line-height:1}.mobile-nav .view-btn.active{background:0 0;color:var(--primary-light)}.mobile-nav .nav-icon{width:22px;height:22px}.gf-tab.active{background:var(--primary);color:#fff}.gf-tab:hover:not(.active){background:rgba(255,255,255,.05)}.gf-range-btn.active{background:var(--primary);color:#fff}.gf-range-btn:hover:not(.active){background:rgba(255,255,255,.05)}@media(max-width:768px){.gf-summary{grid-template-columns:repeat(3,1fr);gap:.35rem}.gf-summary-card{padding:.4rem .5rem}.gf-summary-val{font-size:.9rem}.gf-summary-label{font-size:.5rem}#gfSankey{height:250px!important}.gf-table{font-size:.65rem}.gf-table th{font-size:.5rem;padding:.3rem}.gf-table td{padding:.25rem .3rem}.gf-mono{font-size:.65rem}#gfAsnPie{width:200px!important;height:200px!important}}.gf-table th{text-align:left;font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);padding:.4rem .5rem;border-bottom:1px solid var(--glass-border)}.gf-table td{padding:.3rem .5rem;border-bottom:1px solid rgba(255,255,255,.03);color:var(--text-muted)}.gf-table tr:hover td{background:rgba(255,255,255,.02)}.mobile-more-btn.has-active{color:var(--primary-light)}.mobile-more-menu{display:none;position:fixed;bottom:calc(56px + env(safe-area-inset-bottom,0px));right:8px;z-index:99;background:var(--surface-2);border:1px solid var(--glass-border);border-radius:12px;padding:6px;min-width:160px;box-shadow:0 8px 32px rgba(0,0,0,.4);animation:tabFade .15s ease}.mobile-more-menu.open{display:flex;flex-direction:column}.mobile-more-menu .view-btn{flex-direction:row;gap:10px;padding:10px 14px;justify-content:flex-start;border-radius:8px;font-size:0;width:100%;min-width:0}.mobile-more-menu .view-btn span{display:block;font-size:13px;color:var(--text-muted)}.mobile-more-menu .view-btn:hover{background:var(--bg-hover)}.mobile-more-menu .view-btn.active{background:rgba(83,140,190,.1)}.mobile-more-menu .view-btn.active span{color:var(--primary-light)}.mobile-more-menu .nav-icon{width:18px;height:18px;flex-shrink:0}.dash-main{position:relative;z-index:1;margin:0;padding:1.5rem;padding-left:calc(220px + 1.5rem);transition:padding-left .2s ease}body.sidebar-collapsed .dash-main,html.sidebar-collapsed .dash-main{padding-left:calc(60px + 1.5rem)}.dash-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;flex-wrap:wrap;gap:.75rem}.dash-section-title{font-size:1.1rem;font-weight:700;display:flex;align-items:center;gap:.5rem;white-space:nowrap;letter-spacing:-.02em}.dash-toolbar-left{display:flex;align-items:center;gap:.5rem}.dash-toolbar-right{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-right:100px}.dash-toolbar-right>.btn-node-add,.dash-toolbar-right>.dash-select{height:34px;box-sizing:border-box}.wl-type-chips{display:inline-flex;gap:0;padding:3px;background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.06);border-radius:8px;height:34px;box-sizing:border-box;align-items:center}.wl-chip{background:0 0;border:none;color:var(--text-muted);padding:0 .9rem;height:26px;display:inline-flex;align-items:center;gap:.35rem;border-radius:6px;font-size:.7rem;font-weight:600;cursor:pointer;font-family:inherit;transition:background .12s,color .12s,box-shadow .12s;letter-spacing:.02em;white-space:nowrap}.wl-chip:hover{color:var(--text)}.wl-chip.active{color:var(--text);background:rgba(255,255,255,.06);box-shadow:0 1px 0 rgba(0,0,0,.2),inset 0 0 0 1px rgba(255,255,255,.03)}.wl-chip::before{content:'';width:5px;height:5px;border-radius:50%;background:currentColor;opacity:0;transition:opacity .12s}.wl-chip[data-wl-type=bypass]::before{background:#34d399}.wl-chip[data-wl-type=kernel]::before{background:#a78bfa}.wl-chip[data-wl-type=bypass].active::before,.wl-chip[data-wl-type=kernel].active::before{opacity:1}.dash-select{appearance:none;-webkit-appearance:none;background:var(--glass) url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%2394a3b8' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat right 10px center;border:1px solid var(--glass-border);border-radius:8px;color:var(--text);padding:.4rem 2rem .4rem .75rem;font-size:.75rem;font-weight:500;font-family:inherit;cursor:pointer;transition:all .2s;outline:0;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.dash-select:hover{border-color:var(--primary);background-color:rgba(83,140,190,.06)}.dash-select:focus{border-color:var(--primary);box-shadow:0 0 0 2px rgba(83,140,190,.12)}.dash-select option{background:var(--surface-2);color:var(--text)}.dash-metrics{display:grid;grid-template-columns:repeat(5,1fr);gap:.6rem;margin-bottom:1.15rem}.dash-metric{padding:.9rem 1rem;display:flex;flex-direction:column;gap:.3rem;background:linear-gradient(135deg,rgba(255,255,255,.035),rgba(255,255,255,.015));border:1px solid var(--glass-border);border-radius:var(--radius);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:var(--card-shadow);transition:border-color .2s,background .2s,transform .2s;position:relative;overflow:hidden}.dash-metric::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--glass-border);transition:background .3s}.dash-metric:hover{border-color:rgba(255,255,255,.12);transform:translateY(-1px)}.dash-metric:hover::before{background:var(--primary)}.dash-metric-label{font-size:.7rem;font-weight:500;color:var(--text-muted);opacity:.75}.dash-info-icon{display:flex;align-items:center;cursor:help;color:var(--primary-light);opacity:.7;position:absolute;top:.5rem;right:.5rem;transition:opacity var(--transition)}.dash-info-icon:hover{opacity:1}.dash-metric-val{font-size:1.4rem;font-weight:700;letter-spacing:-.5px;font-variant-numeric:tabular-nums;line-height:1.2}.dash-metric-split{flex-direction:row;align-items:stretch;gap:0;padding:0}.dash-metric-half{flex:1;display:flex;flex-direction:column;gap:.3rem;padding:.9rem 1rem;min-width:0}.dash-metric-divider{width:1px;background:var(--glass-border);margin:.6rem 0}.dash-metric-speed{font-size:1.4rem;color:#fff}.dash-metric-mode{display:inline-flex;align-items:center;font-size:.85rem;font-weight:700;letter-spacing:.5px;line-height:1;padding:.35rem .75rem;border-radius:6px;text-transform:uppercase;color:var(--text-muted);background:var(--bg-subtle)}.dash-metric-mode.mode-sensor{color:#fff;background:rgba(83,140,190,.12);border:1px solid rgba(83,140,190,.2)}.dash-metric-mode.mode-always-on{color:var(--text);background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12)}.survival-badge{font-size:.55rem;font-weight:700;letter-spacing:.5px;color:#fff;background:rgba(239,68,68,.2);border:1px solid rgba(239,68,68,.4);padding:.15rem .45rem;border-radius:4px;animation:survivalPulse 2s ease-in-out infinite}@keyframes survivalPulse{0%,100%{opacity:1;box-shadow:0 0 4px rgba(239,68,68,.3)}50%{opacity:.7;box-shadow:0 0 8px rgba(239,68,68,.6)}}.dash-live-badge{display:inline-flex;align-items:center;gap:.35rem;font-size:.6rem;font-weight:700;letter-spacing:1.2px;color:var(--primary-light);text-transform:uppercase;transition:opacity .3s;margin-left:auto;background:rgba(83,140,190,.1);padding:.2rem .55rem;border-radius:4px;border:1px solid rgba(83,140,190,.15)}.dash-live-badge.hidden{opacity:0}.dash-live-dot{width:6px;height:6px;border-radius:50%;background:var(--primary-light);box-shadow:0 0 8px rgba(83,140,190,.7);animation:livePulse 2s ease-in-out infinite}.dash-attack-btn{display:flex;align-items:center;gap:.4rem;background:0 0;border:none;padding:0;font-family:inherit;font-size:1.4rem;font-weight:700;color:var(--text-muted);cursor:default;transition:all .2s;letter-spacing:-.5px;font-variant-numeric:tabular-nums;line-height:1.2}.dash-attack-btn.loaded{color:var(--text)}.dash-attack-btn svg{display:none}.dash-attack-btn.has-attack{color:var(--danger);cursor:pointer;animation:attackPulse 2s ease-in-out infinite}.dash-attack-btn.has-attack svg{display:block;color:var(--danger)}.dash-attack-btn.has-attack:hover{opacity:.8}.dash-main-row{display:flex;gap:0;margin-bottom:1rem;align-items:stretch}.dash-main-row .dash-chart-panel{flex:1;min-width:0;margin-bottom:0;border-top-right-radius:0;border-bottom-right-radius:0;border-right:none}.dash-main-row .dash-attacks{flex:0 0 380px;max-height:none;display:flex;flex-direction:column;margin-bottom:0;border-top-left-radius:0;border-bottom-left-radius:0;border-left:1px solid var(--glass-border)}.dash-main-row .dash-attacks:first-child{flex:1;border-radius:var(--radius);border-left:1px solid rgba(239,68,68,.15)}.dash-main-row .dash-attacks:first-child .dash-attacks-cols,.dash-main-row .dash-attacks:first-child .dash-attacks-row{grid-template-columns:140px 1fr auto}.dash-main-row .atk-pagination,.dash-main-row .dash-legend{min-height:38px;box-sizing:border-box;display:flex;align-items:center}.dash-attacks{background:linear-gradient(135deg,rgba(239,68,68,.03),rgba(255,255,255,.015));border:1px solid rgba(239,68,68,.15);border-radius:var(--radius);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);overflow:hidden;animation:tabFade .3s ease;box-shadow:0 1px 3px rgba(239,68,68,.06),0 4px 16px rgba(0,0,0,.2)}.dash-attacks-header{display:flex;flex-direction:column;font-size:.72rem;font-weight:600;color:var(--danger);letter-spacing:.3px;border-bottom:1px solid rgba(239,68,68,.1);box-sizing:border-box}.dash-attacks-header-top{display:flex;align-items:center;gap:.45rem;padding:.3rem .75rem .05rem}.dash-attacks-cols{display:grid;grid-template-columns:120px 1fr 90px;gap:.3rem;padding:.1rem .75rem .2rem;font-size:.55rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);background:rgba(239,68,68,.03)}.dash-attacks-count{font-size:.6rem;font-weight:700;background:var(--danger);color:#fff;padding:.15rem .5rem;border-radius:10px;margin-left:.15rem}.dash-attacks-list{display:flex;flex-direction:column;padding:.3rem 0;overflow-y:auto;flex:1;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,0.1) transparent}.dash-attacks-list::-webkit-scrollbar{width:4px}.dash-attacks-list::-webkit-scrollbar-track{background:0 0}.dash-attacks-list::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:2px}.dash-attacks-row{display:grid;grid-template-columns:120px 1fr 90px;align-items:center;gap:.3rem;padding:.35rem .75rem;font-size:.72rem;border-left:2px solid transparent;transition:background var(--transition),border-color .15s}.dash-attacks-row:hover{background:rgba(239,68,68,.04);border-left-color:var(--danger)}.dash-main-row .dash-attacks .dash-attacks-spark{width:100%;height:22px}.dash-attacks-spark{width:120px;height:32px;display:block;border-radius:4px;background:linear-gradient(90deg,rgba(255,255,255,.02) 25%,rgba(255,255,255,.06) 50%,rgba(255,255,255,.02) 75%);background-size:200% 100%;animation:sparkShimmer 1.5s ease infinite}.dash-attacks-spark.spark-drawn,.dash-attacks-spark.spark-empty{animation:none;background:0 0}.dash-attacks-spark.loaded{background:0 0;animation:none}@keyframes sparkShimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}.dash-attacks-subnet{font-weight:600;font-variant-numeric:tabular-nums;font-size:.7rem;color:var(--text);flex-shrink:0}.dash-attacks-vectors{display:flex;gap:.25rem;flex-wrap:wrap;justify-content:flex-end}.dash-attacks-tag{font-size:.58rem;font-weight:600;text-transform:uppercase;padding:.15rem .4rem;border-radius:4px;background:rgba(255,255,255,.06);color:var(--text-muted);letter-spacing:.3px;border:1px solid rgba(255,255,255,.08)}.dash-attacks-ul{font-size:.65rem;font-weight:600;text-transform:uppercase;padding:.2rem .5rem;border-radius:5px;letter-spacing:.3px;white-space:nowrap}.dash-attacks-ul.on{background:rgba(83,140,190,.1);color:var(--primary-light)}.dash-attacks-ul.off{background:var(--bg-subtle);color:var(--text-muted);font-size:.6rem}.atk-ul{display:inline-flex;align-items:center;gap:5px;margin-left:10px;font-size:.65rem;font-weight:500;letter-spacing:.1px;text-transform:none;white-space:nowrap;vertical-align:middle;cursor:help;color:var(--text-muted);background:0 0;border:none;padding:0;height:auto}.atk-ul::before{content:'';width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0;box-shadow:0 0 0 2px rgba(255,255,255,.02)}.atk-ul.ul-active{color:#4ade80}.atk-ul.ul-flapping{color:#fbbf24;animation:ulFlapPulse 2.2s ease-in-out infinite}.atk-ul.ul-inactive{color:#94a3b8}.atk-ul.ul-never{color:#818cf8}@keyframes ulFlapPulse{0%,100%{box-shadow:0 0 0 0 rgba(234,179,8,.3)}50%{box-shadow:0 0 0 4px rgba(234,179,8,0)}}.dash-chart-panel{background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.01));border:1px solid var(--glass-border);border-radius:var(--radius);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);transition:border-color .3s;margin-bottom:1rem;overflow:hidden;box-shadow:var(--card-shadow);display:flex;flex-direction:column}.dash-chart-panel.has-error{border-color:rgba(239,68,68,.25)}.dash-chart-bar{display:flex;align-items:center;justify-content:space-between;padding:.6rem 1rem;border-bottom:1px solid var(--glass-border);box-sizing:border-box}.dash-chart-tabs{display:flex;gap:.25rem}.dash-chart-tab{background:0 0;border:1px solid transparent;color:var(--text-muted);font-size:.72rem;font-weight:500;font-family:inherit;padding:.3rem .75rem;border-radius:6px;cursor:pointer;transition:all var(--transition)}.dash-chart-tab:hover{color:var(--text);border-color:var(--glass-border)}.dash-chart-tab:focus-visible{color:var(--text);border-color:var(--glass-border)}.dash-chart-tab.active{color:var(--primary-light);background:rgba(83,140,190,.1);border-color:rgba(83,140,190,.2)}.dash-chart-body{position:relative;flex:1}.dash-chart-body canvas{width:100%;height:320px;cursor:crosshair;display:block}.chart-error{position:absolute;inset:0;display:none;align-items:center;justify-content:center;gap:.4rem;background:rgba(0,0,0,.3);color:var(--danger);font-size:.8rem;font-weight:500;z-index:2}.chart-error.visible{display:flex}.dash-legend{display:flex;flex-wrap:wrap;gap:.3rem .65rem;font-size:.62rem;color:var(--text-muted);padding:.5rem 1rem;border-top:1px solid var(--glass-border);align-items:center;background:rgba(0,0,0,.1);margin-top:auto}.dash-legend-item{display:flex;align-items:center;gap:.25rem;cursor:pointer;transition:all var(--transition);user-select:none}.dash-legend-item:hover{color:var(--text)}.dash-legend-item.disabled{opacity:.45;text-decoration:line-through}.dash-legend-item.disabled:hover{opacity:.65}.dash-legend-extra{display:none}.dash-legend.expanded .dash-legend-extra{display:flex}.dash-legend-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;transition:opacity var(--transition)}.dash-legend-toggle{background:0 0;border:1px solid var(--glass-border);border-radius:4px;color:var(--text-muted);font-size:.6rem;font-weight:500;font-family:inherit;padding:.1rem .45rem;cursor:pointer;transition:all .2s}.dash-legend-toggle:hover{color:var(--text);border-color:var(--primary)}.dash-legend-toggle:focus-visible{color:var(--text);border-color:var(--primary);outline:0}.dash-tooltip{position:fixed;display:none;background:rgba(10,15,26,.97);border:1px solid rgba(83,140,190,.15);border-radius:10px;padding:.65rem .85rem;font-size:.72rem;line-height:1.5;pointer-events:none;z-index:10000;color:var(--text);box-shadow:0 4px 16px rgba(0,0,0,.5),0 12px 32px rgba(0,0,0,.3);min-width:160px;max-width:280px;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px)}.modal-overlay{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s ease}.modal-overlay.open{opacity:1;pointer-events:auto}#confirmOverlay{z-index:300}.modal-card{width:100%;max-width:400px;margin:1rem;background:var(--surface-2);border:1px solid var(--border);border-radius:14px;box-shadow:0 8px 32px rgba(0,0,0,.5),0 24px 60px rgba(0,0,0,.3);animation:cardAppear .25s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem 0}.modal-header h3{font-size:1rem;font-weight:600}.modal-close{background:0 0;border:none;color:var(--text-muted);font-size:1.5rem;cursor:pointer;line-height:1;padding:0;transition:color .2s}.modal-close:hover{color:var(--text)}.modal-close:focus-visible{color:var(--text);outline:2px solid var(--primary);outline-offset:2px}.modal-body{padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:1rem}.modal-body .form-group input,.modal-body .form-group select{width:100%}.modal-select{width:100%;padding:12px 2rem 12px 14px;appearance:none;-webkit-appearance:none;background:var(--bg-subtle) url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%239ca3af' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat right 10px center;border:1px solid var(--glass-border);border-radius:10px;color:var(--text);font-size:14px;font-family:inherit;cursor:pointer;outline:0;transition:border-color .2s,box-shadow .2s}.modal-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(83,140,190,.15)}.modal-select option{background:var(--surface-2);color:var(--text)}.modal-footer{padding:0 1.5rem 1.25rem;display:flex;justify-content:flex-end;gap:.6rem}.modal-save{width:auto;padding:10px 28px;font-size:13px}.form-actions{margin-top:.75rem}.form-actions .btn-login{width:auto;padding-top:10px;padding-bottom:10px;padding-left:28px;padding-right:28px;font-size:13px}.modal-alert{font-size:13px;border-radius:8px;padding:0;transition:all .2s;overflow:hidden;max-height:0}.modal-alert.error{background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.25);color:var(--danger);padding:10px 14px;max-height:60px}.modal-alert.success{background:rgba(83,140,190,.08);border:1px solid rgba(83,140,190,.25);color:var(--primary-light);padding:10px 14px;max-height:60px}.modal-card-sm{max-width:360px}.confirm-text{font-size:.9rem;text-align:center;line-height:1.5;color:var(--text)}.xdp-node-sel{text-align:left}.xdp-sel-title{font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:10px;font-weight:600}.xdp-sel-all{display:flex;align-items:center;gap:8px;cursor:pointer;padding:8px 12px;border-radius:8px;font-weight:600;font-size:.9rem;background:rgba(83,140,190,.08);border:1px solid rgba(83,140,190,.2);margin-bottom:10px;transition:background var(--transition)}.xdp-sel-all:hover{background:rgba(83,140,190,.15)}.xdp-sel-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}.xdp-sel-item{display:flex;align-items:center;gap:8px;cursor:pointer;padding:7px 10px;border-radius:8px;font-size:.85rem;background:var(--bg-hover);border:1px solid transparent;transition:all var(--transition)}.xdp-sel-item:hover{background:rgba(255,255,255,.06);border-color:var(--glass-border)}.xdp-sel-item:has(input:checked){border-color:rgba(83,140,190,.3);background:rgba(83,140,190,.06)}.xdp-node-sel input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary);cursor:pointer;flex-shrink:0}.modal-footer-confirm{justify-content:center;gap:.5rem;padding-bottom:1.5rem}.btn-cancel{padding:10px 24px;border-radius:10px;background:var(--bg-hover);border:1px solid var(--glass-border);color:var(--text-muted);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s}.btn-cancel:hover{background:rgba(255,255,255,.1);color:var(--text)}.btn-cancel:focus-visible{background:rgba(255,255,255,.1);color:var(--text);border-color:var(--primary)}.btn-danger-solid{background:var(--danger);box-shadow:0 2px 8px rgba(239,68,68,.25)}.btn-danger-solid:hover{background:#dc2626;box-shadow:0 4px 12px rgba(239,68,68,.3)}.toggle-label{display:flex;align-items:center;gap:.65rem;cursor:pointer;font-size:13px;color:var(--text-muted);user-select:none}.toggle-label input{display:none}.toggle-switch{width:36px;height:20px;border-radius:10px;background:rgba(255,255,255,.1);position:relative;transition:background .2s;flex-shrink:0}.toggle-switch::after{content:'';position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:var(--text-muted);transition:all .2s}.toggle-label input:checked+.toggle-switch{background:var(--primary)}.toggle-label input:checked+.toggle-switch::after{left:18px;background:#fff}.toast{position:fixed;bottom:2rem;left:50%;transform:translateX(-50%) translateY(20px);padding:.6rem 1.2rem;border-radius:8px;font-size:.8rem;font-weight:600;color:#fff;opacity:0;transition:opacity .3s,transform .3s;z-index:10000;pointer-events:none}.toast-visible{opacity:1;transform:translateX(-50%) translateY(0)}.notif-wrap{position:fixed;top:1rem;right:1.5rem;z-index:900;display:flex;align-items:center;gap:.5rem}.notif-wrap .btn-maint-global{width:38px;height:38px;border-radius:50%;background:var(--surface-2)}.notif-bell{background:var(--surface-2);border:1px solid var(--glass-border);border-radius:50%;width:38px;height:38px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-muted);transition:color .2s,border-color .2s,box-shadow .2s;position:relative}.notif-bell:hover{color:var(--text);border-color:var(--primary)}.notif-bell.has-alerts{color:var(--danger);border-color:rgba(239,68,68,.4);box-shadow:0 0 12px rgba(239,68,68,.15)}.notif-bell.has-alerts svg{animation:bellShake .6s ease}.notif-bell-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;background:var(--danger);color:#fff;font-size:.65rem;font-weight:700;border-radius:9px;display:none;align-items:center;justify-content:center;padding:0 4px;line-height:1}.notif-bell.has-alerts .notif-bell-badge{display:flex}.notif-drop{display:none;position:absolute;top:calc(100% + 8px);right:0;width:320px;max-height:400px;background:var(--surface);border:1px solid var(--glass-border);border-radius:10px;overflow:hidden;box-shadow:0 8px 32px rgba(0,0,0,.5)}.notif-drop.open{display:block}.notif-drop-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid var(--glass-border);font-size:.8rem;font-weight:600;color:var(--text)}.notif-drop-count{background:var(--danger);color:#fff;font-size:.65rem;font-weight:700;border-radius:9px;padding:1px 6px;min-width:18px;text-align:center}.notif-drop-list{overflow-y:auto;max-height:340px}.notif-drop-list::-webkit-scrollbar{width:4px}.notif-drop-list::-webkit-scrollbar-thumb{background:var(--glass-border);border-radius:2px}.notif-drop-item{display:flex;align-items:center;justify-content:space-between;padding:.6rem 1rem;border-bottom:1px solid var(--glass-border);cursor:pointer;transition:background var(--transition)}.notif-drop-item:last-child{border-bottom:none}.notif-drop-item:hover{background:var(--glass)}.notif-drop-subnet{font-size:.78rem;font-weight:500;color:var(--text);font-family:var(--font-mono)}.notif-drop-vecs{display:flex;gap:4px;flex-wrap:wrap}.notif-drop-tag{font-size:.6rem;font-weight:600;padding:2px 6px;border-radius:4px;background:rgba(239,68,68,.15);color:var(--danger);text-transform:uppercase;letter-spacing:.3px}.notif-drop-empty{padding:2rem 1rem;text-align:center;color:var(--text-muted);font-size:.8rem}@keyframes bellShake{0%,100%{transform:rotate(0)}15%{transform:rotate(12deg)}30%{transform:rotate(-10deg)}45%{transform:rotate(8deg)}60%{transform:rotate(-6deg)}75%{transform:rotate(3deg)}}@media(max-width:768px){.notif-wrap{top:.5rem;right:.75rem;gap:.4rem}.notif-bell,.notif-wrap .btn-maint-global{width:34px;height:34px}.notif-drop{width:280px;right:-.5rem}}.btn-node-add{display:flex;align-items:center;gap:.4rem;background:var(--primary);border:none;border-radius:6px;color:#fff;padding:.45rem .9rem;font-size:.75rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s;box-shadow:0 1px 4px rgba(83,140,190,.25)}.btn-node-add:hover{background:var(--primary-light);box-shadow:0 2px 8px rgba(83,140,190,.35)}.btn-node-add:focus-visible{background:var(--primary-light);box-shadow:0 0 0 3px rgba(83,140,190,.4)}.nodes-grid{display:flex;flex-direction:column;gap:1.25rem}.nodes-dc-header{display:flex;align-items:center;gap:.4rem;font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.6rem;padding-bottom:.4rem;border-bottom:1px solid var(--glass-border)}.nodes-dc-header svg{color:var(--primary);opacity:.7}.nodes-dc-edit,.nodes-dc-ssh{display:flex;align-items:center;justify-content:center;background:0 0;border:none;color:var(--text-muted);cursor:pointer;opacity:0;transition:opacity var(--transition);padding:2px}.nodes-dc-header:hover .nodes-dc-edit,.nodes-dc-header:hover .nodes-dc-ssh{opacity:.6}.nodes-dc-edit:hover,.nodes-dc-ssh:hover{opacity:1;color:var(--primary-light)}.nodes-dc-edit:focus-visible,.nodes-dc-ssh:focus-visible{opacity:1;color:var(--primary-light);outline:0}.nodes-dc-input{background:var(--bg-hover);border:1px solid var(--primary);border-radius:4px;color:var(--text);font-size:.75rem;font-weight:600;font-family:inherit;text-transform:uppercase;letter-spacing:.5px;padding:.1rem .4rem;outline:0;width:160px}.nodes-dc-count{font-size:.6rem;font-weight:600;background:var(--bg-hover);color:var(--text-muted);padding:.1rem .4rem;border-radius:4px;margin-left:.15rem}.nodes-dc-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(320px,100%),1fr));gap:.75rem}.node-card{background:linear-gradient(135deg,rgba(255,255,255,.035),rgba(255,255,255,.015));border:1px solid var(--glass-border);border-radius:var(--radius);padding:1.1rem 1.25rem;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);transition:border-color .2s,box-shadow .2s,transform .2s;display:flex;flex-direction:column;gap:.65rem;box-shadow:var(--card-shadow)}.node-card:hover{border-color:rgba(255,255,255,.12);box-shadow:0 2px 6px rgba(0,0,0,.3),0 8px 20px rgba(0,0,0,.2);transform:translateY(-1px)}.node-disabled{opacity:.45}.node-disabled .node-status{background:var(--text-muted)!important;box-shadow:none!important;animation:none!important}.node-card-header{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.node-status{width:10px;height:10px;border-radius:50%;flex-shrink:0;background:rgba(255,255,255,.15);transition:all .3s}.node-status.online{background:var(--primary-light);box-shadow:0 0 6px rgba(83,140,190,.5)}.node-status.offline{background:var(--danger);box-shadow:0 0 6px rgba(239,68,68,.5)}.node-status.checking{background:#f59e0b;box-shadow:0 0 6px rgba(245,158,11,.5);animation:livePulse 1s ease-in-out infinite}.node-status.maint{background:#a78bfa;box-shadow:0 0 6px rgba(167,139,250,.5)}.node-status.loading{background:rgba(255,255,255,.15);animation:livePulse 1.4s ease-in-out infinite}.node-card-name{font-size:.85rem;font-weight:600;line-height:1.2;white-space:nowrap}.form-row-2{display:grid;grid-template-columns:1fr auto;gap:.75rem}.form-row-2 .form-group:last-child input{width:80px}.node-vlans{margin-top:.5rem;padding-top:.5rem;border-top:1px solid rgba(255,255,255,.04)}.node-vlans:empty{display:none}.vfl{text-align:center}.vfl-row{display:inline-flex;align-items:center}.vfl-col{display:flex;flex-direction:column;gap:3px}.vfl-col-in{border-right:1px solid rgba(83,140,190,.2);padding-right:4px}.vfl-col-out{border-left:1px solid rgba(83,140,190,.2);padding-left:4px}.vfl-wire{flex:0 0 24px;height:1px;background:rgba(83,140,190,.2);position:relative}.vfl-pkt{position:absolute;top:-2px;left:0;width:4px;height:4px;border-radius:50%;background:var(--primary);opacity:0;animation:vfPkt 2.5s ease-in-out infinite;will-change:transform,opacity}.vfl-maint .vfl-pkt{animation:none;display:none}.vfl-maint .vfl-wire{background:rgba(245,158,11,.18)}.vfl-drift .vfl-wire{background:rgba(239,68,68,.25)}.vf-missing{background:rgba(239,68,68,.12)!important;color:var(--danger)!important;border:1px dashed rgba(239,68,68,.5)!important;opacity:.8}@keyframes vfPkt{0%{transform:translateX(0);opacity:0}10%{opacity:.7}90%{opacity:.7}100%{transform:translateX(20px);opacity:0}}.vfl-core{position:relative;padding:0 4px}.vfl-zeus{font-size:.5rem;font-weight:700;letter-spacing:1px;color:var(--primary-light);background:var(--surface);border:1px solid rgba(83,140,190,.22);padding:.3rem .55rem;line-height:1;border-radius:4px}.vfl-label{font-size:.45rem;font-weight:600;letter-spacing:1px;color:var(--text-muted);text-align:center;text-transform:uppercase}.vfl-mir{font-size:.5rem;font-weight:500;color:rgba(168,85,247,.4);cursor:default;position:absolute;top:100%;left:50%;transform:translateX(-50%);white-space:nowrap;margin-top:1px}.vf-tag{font-size:.7rem;font-weight:600;font-variant-numeric:tabular-nums;padding:.15rem .5rem;border-radius:5px;cursor:default;line-height:1.3;text-align:center;white-space:nowrap;position:relative}.vf-tag[data-tip]:hover::after{content:attr(data-tip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);background:rgba(3,7,18,.96);color:var(--text);padding:4px 8px;border-radius:4px;font-size:.7rem;font-weight:500;white-space:nowrap;z-index:1000;border:1px solid rgba(83,140,190,.3);pointer-events:none;box-shadow:0 2px 8px rgba(0,0,0,.4)}.vf-tag[data-tip]:hover::before{content:"";position:absolute;bottom:calc(100% + 2px);left:50%;transform:translateX(-50%);border:4px solid transparent;border-top-color:rgba(83,140,190,.3);z-index:1000;pointer-events:none}.vf-in{color:rgba(255,255,255,.65);background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08)}.vf-eg{color:var(--primary-light);background:rgba(83,140,190,.08);border:1px solid rgba(83,140,190,.18)}.node-card-speed{font-size:.65rem;font-weight:500;color:var(--primary-light);margin-left:auto;white-space:nowrap;background:rgba(83,140,190,.12);padding:.15rem .4rem;border-radius:4px}.node-card-speed:empty{display:none}.node-product-badge{font-size:.55rem;font-weight:700;padding:.12rem .4rem;border-radius:4px;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.node-product-filter{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:.75rem;padding:.4rem .6rem;cursor:pointer;font-family:inherit}.node-product-filter:focus{border-color:var(--primary);outline:0}.node-card-ms{font-size:.7rem;font-weight:600;font-variant-numeric:tabular-nums;color:var(--text-muted);white-space:nowrap;cursor:pointer;transition:color .15s}.node-card-ms:hover{color:var(--primary-light)}.node-card-actions{display:flex;gap:.2rem;flex-shrink:0;margin-left:auto}.node-action-btn{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:5px;background:0 0;border:1px solid transparent;color:var(--text-muted);cursor:pointer;transition:all var(--transition)}.node-action-btn:hover{background:var(--bg-hover);border-color:var(--glass-border);color:var(--text)}.node-action-btn:focus-visible{background:var(--bg-hover)}.node-action-btn.danger:hover{color:var(--danger);border-color:rgba(239,68,68,.25);background:rgba(239,68,68,.06)}.node-action-btn.danger:focus-visible{color:var(--danger);border-color:rgba(239,68,68,.25);background:rgba(239,68,68,.06)}.node-pcap-btn.on{color:var(--success);border-color:rgba(16,185,129,.3);background:rgba(16,185,129,.08)}.node-pcap-btn.on:hover{background:rgba(16,185,129,.15);border-color:rgba(16,185,129,.5)}.node-pcap-btn.off{color:var(--text-muted);opacity:.55}.node-pcap-btn.off:hover{color:var(--text);opacity:.95;background:var(--bg-hover)}.node-pcap-btn.syncing{position:relative;opacity:.5;pointer-events:none}.node-pcap-btn.syncing::after{content:'';position:absolute;inset:0;border-radius:inherit;border:1px dashed var(--primary-light);animation:cap-pulse 1.4s ease-in-out infinite}@keyframes cap-pulse{0%,100%{opacity:.4}50%{opacity:.9}}.modal-card-pcap{max-width:600px;width:92%}.modal-card-pcap .modal-body{padding-top:.5rem;gap:1.4rem}.modal-card-pcap #pcapNodeTitle{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}.pcap-modal-stats{display:flex;flex-direction:column;gap:1.4rem}.pcap-toggle-card{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:1rem 1.1rem;background:linear-gradient(180deg,rgba(255,255,255,.015),rgba(255,255,255,0));border:1px solid var(--glass-border);border-radius:10px;transition:border-color .2s}.pcap-toggle-card:hover{border-color:rgba(83,140,190,.25)}.pcap-toggle-label{display:flex;flex-direction:column;gap:.45rem;flex:1;min-width:0}.pcap-toggle-title{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.9px;color:var(--text-muted)}.pcap-toggle-sub{font-size:.72rem;color:var(--text-muted);line-height:1.55}.pcap-switch{position:relative;display:inline-block;width:38px;height:20px;flex-shrink:0;cursor:pointer}.pcap-switch input{opacity:0;width:0;height:0}.pcap-switch-slider{position:absolute;inset:0;background:rgba(156,163,175,.25);border-radius:20px;transition:background .2s}.pcap-switch-slider::before{content:'';position:absolute;left:3px;top:3px;width:14px;height:14px;background:var(--text-muted);border-radius:50%;transition:transform .2s,background .2s}.pcap-switch input:checked+.pcap-switch-slider{background:rgba(16,185,129,.35)}.pcap-switch input:checked+.pcap-switch-slider::before{transform:translateX(18px);background:var(--success)}.pcap-switch.syncing{opacity:.5;pointer-events:none}.pcap-switch input:disabled{cursor:not-allowed}.pcap-modal-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.7rem}.pcap-stat{background:linear-gradient(180deg,rgba(255,255,255,.015),rgba(255,255,255,0));border:1px solid var(--glass-border);border-radius:10px;padding:.95rem 1rem;transition:border-color .2s;min-width:0}.pcap-stat:hover{border-color:rgba(83,140,190,.25)}.pcap-stat-label{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.9px;color:var(--text-muted);margin-bottom:.6rem}.pcap-stat-value{font-size:1rem;font-weight:700;color:var(--text);line-height:1.25;letter-spacing:.1px}.pcap-stat-sub{font-size:.7rem;color:var(--text-muted);margin-top:.55rem;line-height:1.55;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pcap-modal-section{display:flex;flex-direction:column;gap:.55rem}.pcap-modal-list-title{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.9px;color:var(--text-muted);opacity:.75}.pcap-modal-list{display:flex;flex-direction:column;gap:.5rem;max-height:240px;overflow-y:auto;padding-right:2px}.pcap-modal-row{display:flex;justify-content:space-between;align-items:center;padding:.7rem .85rem;background:rgba(255,255,255,.015);border:1px solid rgba(255,255,255,.04);border-radius:8px;gap:.8rem;transition:border-color .15s}.pcap-modal-row:hover{border-color:rgba(83,140,190,.2)}.pcap-row-main{display:flex;align-items:center;gap:.55rem;min-width:0;flex:1;overflow:hidden}.pcap-row-det{font-size:.78rem;font-weight:700;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;letter-spacing:.2px}.pcap-row-peak{font-size:.62rem;font-weight:700;letter-spacing:.3px;color:var(--primary-light);padding:2px 7px;border-radius:4px;background:rgba(83,140,190,.1);border:1px solid rgba(83,140,190,.25);font-family:var(--font-mono);flex-shrink:0;line-height:1.4}.pcap-row-meta{display:flex;align-items:center;gap:1rem;color:var(--text-muted);font-size:.7rem;flex-shrink:0}.pcap-row-size{font-variant-numeric:tabular-nums;min-width:60px;text-align:right}.pcap-row-when{font-variant-numeric:tabular-nums;min-width:32px;text-align:right}.pcap-modal-actions{display:flex;justify-content:flex-end;margin-top:.4rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.04)}.pcap-modal-actions .btn-danger{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.28);color:var(--danger);padding:.6rem 1.1rem;border-radius:8px;font-size:.78rem;font-weight:600;letter-spacing:.2px;display:inline-flex;align-items:center;gap:.5rem;cursor:pointer;font-family:inherit;transition:background .15s,border-color .15s}.pcap-modal-actions .btn-danger:hover:not(:disabled){background:rgba(239,68,68,.18);border-color:rgba(239,68,68,.45)}.pcap-modal-actions .btn-danger:disabled{opacity:.4;cursor:not-allowed}.pcap-modal-actions .btn-danger.loading{position:relative;color:transparent}.pcap-modal-actions .btn-danger.loading::after{content:'';position:absolute;width:14px;height:14px;left:50%;top:50%;margin:-7px 0 0 -7px;border:2px solid var(--danger);border-top-color:transparent;border-radius:50%;animation:btn-spin .7s linear infinite}@keyframes btn-spin{to{transform:rotate(360deg)}}@media (max-width:520px){.pcap-modal-grid{grid-template-columns:1fr}}.nodes-empty{grid-column:1/-1;text-align:center;padding:4rem 1rem;color:var(--text-muted);font-size:.85rem;display:flex;flex-direction:column;align-items:center;gap:.75rem;opacity:.6}.nodes-empty svg{opacity:.35}.nodes-empty-text{font-size:.8rem}.token-more-hint{margin-top:.75rem;padding:.6rem .85rem;font-size:.72rem;color:var(--text-muted);background:rgba(255,255,255,.02);border:1px dashed rgba(255,255,255,.06);border-radius:6px;text-align:center}.search-wrap{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:10px;color:var(--text-muted);opacity:.5;pointer-events:none}.search-input{padding:0 .75rem 0 2rem;height:34px;background:var(--glass);border:1px solid var(--glass-border);border-radius:8px;color:var(--text);font-size:.75rem;font-family:inherit;outline:0;transition:border-color .2s,box-shadow .2s;width:300px}.search-input:focus{border-color:var(--primary);box-shadow:0 0 0 2px rgba(83,140,190,.12)}.search-input::placeholder{color:var(--text-muted);opacity:.6}.wl-count{font-size:.65rem;font-weight:600;background:var(--bg-hover);color:var(--text-muted);padding:.1rem .5rem;border-radius:4px;margin-left:.15rem}.wl-list{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);overflow:hidden;box-shadow:var(--card-shadow)}.wl-group{margin-bottom:.25rem}.wl-group-header{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:rgba(255,255,255,.02);border-bottom:1px solid var(--glass-border);cursor:default}.wl-group-name{font-size:.72rem;font-weight:700;color:var(--primary-light);text-transform:uppercase;letter-spacing:.5px}.wl-group-count{font-size:.6rem;font-weight:600;color:var(--text-muted);background:rgba(255,255,255,.06);padding:.1rem .4rem;border-radius:10px}.wl-head,.wl-row{display:grid;grid-template-columns:minmax(200px,1.3fr) 110px minmax(220px,2fr) minmax(180px,1.3fr) 40px;gap:1rem;align-items:center;padding:.55rem 1rem;border-bottom:1px solid rgba(255,255,255,.03)}.wl-head{font-size:.58rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);background:rgba(255,255,255,.025);border-bottom:1px solid rgba(255,255,255,.06);opacity:.75;padding-top:.6rem;padding-bottom:.6rem}.wl-row{font-size:.8rem;transition:background var(--transition)}.wl-creator{font-size:.72rem;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;opacity:.85}.wl-row:last-child{border-bottom:none}.wl-row:hover{background:rgba(83,140,190,.04)}.wl-ip{font-weight:600;font-variant-numeric:tabular-nums;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:.35rem}.wl-dst{font-size:.75rem;font-variant-numeric:tabular-nums;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:.4rem}.wl-dst-ip{color:var(--text-muted)}.wl-mode{display:inline-flex;align-items:center;gap:.25rem;font-size:.6rem;font-weight:600;padding:.15rem .4rem;border-radius:4px;cursor:default;white-space:nowrap}.wl-mode svg{flex-shrink:0}.wl-mode-bypass{color:var(--success);background:rgba(16,185,129,.1)}.wl-mode-kernel{color:var(--warning,#f59e0b);background:rgba(245,158,11,.1)}.wl-org,.wl-reason{font-size:.7rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:default}.wl-reason[data-wl-edit-reason]{cursor:text;transition:color .12s;position:relative;padding-right:18px}.wl-reason[data-wl-edit-reason]:hover{color:var(--text)}.wl-reason[data-wl-edit-reason]::after{content:"";position:absolute;right:2px;top:50%;width:11px;height:11px;margin-top:-5.5px;opacity:0;transition:opacity .12s;background:no-repeat center/contain url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='11' height='11' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2'><path d='M12 20h9'/><path d='M16.5 3.5a2.121 2.121 0 0 1 3 3L7 19l-4 1 1-4L16.5 3.5z'/></svg>");pointer-events:none}.wl-row:hover .wl-reason[data-wl-edit-reason]::after{opacity:.6}.wl-reason.editing{overflow:visible;cursor:auto;padding-right:0}.wl-reason.editing::after{display:none}.wl-reason-input{width:100%;background:rgba(255,255,255,.04);border:1px solid var(--primary);color:var(--text);font-size:.7rem;padding:.25rem .4rem;border-radius:5px;outline:0;font-family:inherit;box-sizing:border-box}.wl-reason-input:focus{border-color:var(--primary-light);box-shadow:0 0 0 2px rgba(83,140,190,.15)}.wl-reason-input:disabled{opacity:.6}.wl-mode-tabs{display:flex;gap:.25rem;margin-bottom:.75rem}.wl-mode-tab{background:rgba(255,255,255,.04);border:1px solid var(--glass-border);border-radius:6px;color:var(--text-muted);font-size:.75rem;font-weight:600;font-family:inherit;padding:.3rem .75rem;cursor:pointer;transition:all var(--transition)}.wl-mode-tab:hover{color:var(--text);border-color:rgba(255,255,255,.15)}.wl-mode-tab.active{background:var(--primary);color:#fff;border-color:var(--primary)}#wl-batch{width:100%;resize:vertical;background:rgba(255,255,255,.04);border:1px solid var(--glass-border);border-radius:6px;color:var(--text);font-size:.8rem;font-family:var(--font-mono);padding:.5rem;outline:0;transition:border-color var(--transition)}#wl-batch:focus{border-color:var(--primary)}.wl-node-select{position:relative}.wl-node-trigger{width:100%;background:rgba(255,255,255,.04);border:1px solid var(--glass-border);border-radius:6px;color:var(--text);font-size:.78rem;font-family:inherit;padding:.45rem .7rem;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:.5rem;transition:border-color var(--transition)}.wl-node-trigger:hover{border-color:rgba(255,255,255,.18)}.wl-node-trigger.open{border-color:var(--primary)}.wl-node-trigger-label{flex:1;text-align:left;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.wl-node-trigger-caret{color:var(--text-muted);transition:transform var(--transition);flex-shrink:0}.wl-node-trigger.open .wl-node-trigger-caret{transform:rotate(180deg)}.wl-node-dropdown{display:none;position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--surface);border:1px solid var(--glass-border);border-radius:6px;padding:.3rem;max-height:240px;overflow-y:auto;box-shadow:0 8px 24px rgba(0,0,0,.5);z-index:50}.wl-node-dropdown.open{display:block}.wl-node-option{display:flex;align-items:center;gap:.55rem;padding:.4rem .55rem;border-radius:5px;cursor:pointer;font-size:.78rem;color:var(--text);transition:background .12s;user-select:none}.wl-node-option:hover{background:rgba(255,255,255,.05)}.wl-node-option input[type=checkbox]{width:14px;height:14px;accent-color:var(--primary);cursor:pointer;margin:0;flex-shrink:0}.wl-node-divider{height:1px;background:var(--glass-border);margin:.25rem 0}.wl-del-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;background:0 0;border:1px solid transparent;color:var(--text-muted);cursor:pointer;transition:all var(--transition);opacity:0}.wl-row:hover .wl-del-btn{opacity:1}.wl-del-btn:hover{color:var(--danger);border-color:rgba(239,68,68,.25);background:rgba(239,68,68,.06)}.wl-del-btn:focus-visible{opacity:1;background:rgba(239,68,68,.15);color:var(--danger)}.wl-empty{text-align:center;padding:3rem 1rem;color:var(--text-muted);font-size:.8rem;opacity:.6}.wl-empty svg{display:block;margin:0 auto .5rem;opacity:.3}.wl-empty-text{margin-top:.25rem;font-size:.7rem;opacity:.5}.skeleton{background:linear-gradient(90deg,rgba(255,255,255,.04) 25%,rgba(255,255,255,.08) 50%,rgba(255,255,255,.04) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-sm)}.skeleton-peer{height:120px;border-radius:var(--radius)}.skeleton-row{height:36px;margin-bottom:4px}@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}.badge{font-size:.55rem;font-weight:700;padding:.1rem .35rem;border-radius:3px;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}.badge-muted{color:var(--text-muted);background:rgba(255,255,255,.06)}@media(max-width:768px){.wl-row{grid-template-columns:1fr auto 32px;gap:.35rem}.wl-row .wl-creator,.wl-row .wl-reason{display:none}.wl-reason{display:none}}.bgp-summary-bar{display:flex;align-items:center;gap:.5rem;padding:.4rem .75rem;background:rgba(255,255,255,.02);border:1px solid var(--glass-border);border-radius:var(--radius-sm);margin-bottom:.75rem;font-size:.75rem;font-weight:600}.bgp-summary-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.bgp-summary-dot.online{background:var(--success);box-shadow:0 0 6px rgba(16,185,129,.5)}.bgp-summary-dot.offline{background:var(--danger);box-shadow:0 0 6px rgba(239,68,68,.5);animation:livePulse 1s ease-in-out infinite}.bgp-summary-ok{color:var(--success)}.bgp-summary-warn{color:var(--warning)}.bgp-summary-down{color:var(--danger);font-size:.65rem;margin-left:auto}.bgp-node-group{margin-bottom:1rem}.bgp-peer-chevron{flex-shrink:0;opacity:.3;transition:transform .2s,opacity .2s;margin-left:.2rem}.bgp-peer-card.expanded .bgp-peer-chevron{transform:rotate(180deg);opacity:.6}.bgp-peer-toggle{cursor:pointer}.bgp-peer-detail{padding-top:.35rem;border-top:1px solid rgba(255,255,255,.04);animation:tabFade .2s ease}.bgp-peer-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:.35rem .6rem}.bgp-routes-wrap{background:rgba(255,255,255,.02);border:1px solid var(--glass-border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--card-shadow)}.bgp-info{display:flex;gap:.4rem;margin-bottom:.6rem;flex-wrap:wrap}.bgp-info-tag{font-size:.65rem;font-weight:600;color:var(--primary-light);background:rgba(83,140,190,.1);padding:.15rem .45rem;border-radius:4px}.bgp-peer-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:.6rem}.bgp-peer-card{background:linear-gradient(135deg,rgba(255,255,255,.035),rgba(255,255,255,.015));border:1px solid var(--glass-border);border-radius:var(--radius);padding:.6rem .9rem .5rem;transition:border-color .2s;box-shadow:var(--card-shadow)}.bgp-peer-card.peer-up{border-left:3px solid var(--success)}.bgp-peer-card.peer-down{border-left:3px solid var(--danger);background:rgba(239,68,68,.04)}.bgp-peer-card.peer-connecting{border-left:3px solid var(--warning);background:rgba(234,179,8,.04)}.bgp-peer-card:hover{border-color:rgba(255,255,255,.12)}.bgp-peer-uptime{font-size:.6rem;color:var(--text-muted);margin-left:auto;font-variant-numeric:tabular-nums;opacity:.7}.bgp-peer-header{display:flex;align-items:center;gap:.4rem}.bgp-peer-name{font-size:.8rem;font-weight:600;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bgp-peer-as{font-size:.6rem;font-weight:600;color:var(--primary-light);background:rgba(83,140,190,.1);padding:.1rem .35rem;border-radius:4px;flex-shrink:0}.bgp-peer-ip{font-size:.65rem;color:var(--text-muted);margin:.15rem 0 .3rem 1.05rem;font-variant-numeric:tabular-nums}.bgp-peer-stats{display:grid;grid-template-columns:1fr 1fr;gap:.35rem .6rem;padding-top:.35rem;border-top:1px solid rgba(255,255,255,.04)}.bgp-peer-stat{display:flex;flex-direction:column;gap:.05rem}.bgp-peer-stat-label{font-size:.5rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);opacity:.5}.bgp-peer-stat-val{font-size:.75rem;font-weight:600;font-variant-numeric:tabular-nums}.bgp-state-up{color:var(--success)}.bgp-state-down{color:var(--danger)}.bgp-peer-actions{display:flex;gap:.3rem;margin-top:.35rem;padding-top:.3rem;border-top:1px solid rgba(255,255,255,.04);justify-content:flex-end}.bgp-peer-action{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:5px;background:0 0;border:1px solid transparent;color:var(--text-muted);cursor:pointer;opacity:0;transition:all var(--transition)}.bgp-peer-card:hover .bgp-peer-action{opacity:.6}.bgp-peer-action:hover{opacity:1;color:var(--primary-light);border-color:rgba(83,140,190,.25);background:rgba(83,140,190,.06)}.bgp-peer-del:hover{color:var(--danger);border-color:rgba(239,68,68,.25);background:rgba(239,68,68,.06)}.bgp-routes-topbar{display:flex;gap:1rem;margin-bottom:.6rem;align-items:center;flex-wrap:wrap}.bgp-routes-topbar .bgp-add-route{margin-bottom:0;flex:0 0 auto;align-items:center}.bgp-routes-topbar #bgp-routes-search-host{flex:1 1 auto;display:flex;justify-content:flex-end;align-items:center;min-width:280px}.bgp-routes-topbar #bgp-routes-search-host .bgp-routes-search-box{flex:1 1 auto;max-width:700px;height:42px;box-sizing:border-box}.bgp-add-route{display:flex;gap:.6rem;margin-bottom:.6rem;align-items:center}.bgp-add-route .search-input{flex:0 0 auto;width:280px;max-width:none;min-width:0;height:42px;box-sizing:border-box;padding:.85rem 1.15rem;border-radius:10px;border:1px solid rgba(255,255,255,.06);background:rgba(255,255,255,.02);font-size:.78rem;font-family:var(--font-mono);color:var(--text);transition:all .15s;outline:0}.bgp-add-route .search-input::placeholder{color:var(--text-muted);opacity:.55;font-family:inherit}.bgp-add-route .search-input:focus{border-color:rgba(83,140,190,.35);background:rgba(83,140,190,.03);box-shadow:0 0 0 3px rgba(83,140,190,.06)}.bgp-add-route .btn-node-add{padding:0 1.3rem;border-radius:10px;flex-shrink:0;white-space:nowrap;font-size:.8rem;line-height:1;height:42px;box-sizing:border-box;display:inline-flex;align-items:center;gap:.5rem}.bgp-add-route .btn-node-add svg{width:16px;height:16px}.bgp-add-route-cancel:hover{color:var(--danger);border-color:rgba(239,68,68,.25);background:rgba(239,68,68,.06)}.bgp-route-head,.bgp-route-row,.bgp-routes-list{font-variant-numeric:tabular-nums}.bgp-route-head{display:grid;grid-template-columns:minmax(120px,1fr) 60px minmax(90px,0.8fr) 55px 55px 55px minmax(50px,0.8fr) 60px;gap:.4rem;align-items:center;padding:.35rem .75rem;font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);opacity:.6;border-bottom:1px solid var(--glass-border)}.bgp-route-head-simple{grid-template-columns:1fr 40px}.bgp-route-row-simple{grid-template-columns:1fr 40px}.bgp-route-search:focus{border-color:rgba(83,140,190,.4);background-color:rgba(83,140,190,.04);box-shadow:0 0 0 3px rgba(83,140,190,.08)}.bgp-route-search::placeholder{color:var(--text-muted);opacity:.5}@media(max-width:1400px){.bgp-route-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:1000px){.bgp-route-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.bgp-route-grid{grid-template-columns:1fr}}.bgp-route-chip{padding:.38rem .6rem;border-radius:6px;border:1px solid rgba(255,255,255,.04);background:0 0;font-size:.7rem;font-family:var(--font-mono);color:var(--text-muted);cursor:default;transition:all .15s;display:flex;align-items:center;gap:.3rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;letter-spacing:.01em}.bgp-route-chip:hover{background:rgba(239,68,68,.05);border-color:rgba(239,68,68,.15);color:#fb7185;cursor:pointer}.bgp-route-chip:hover::after{content:'✕';font-size:.55rem;margin-left:auto;color:rgba(239,68,68,.5);flex-shrink:0}.bgp-peers-list{display:flex;flex-direction:column;gap:.25rem}.bgp-nodes-grid{column-width:540px;column-gap:1rem}.bgp-node-group{display:block;break-inside:avoid;-webkit-column-break-inside:avoid;page-break-inside:avoid;margin:0 0 1rem 0;background:rgba(255,255,255,.012);border:1px solid rgba(255,255,255,.04);border-radius:10px;padding:.7rem .85rem;min-width:0}.bgp-node-group:last-child{margin-bottom:0}.bgp-node-head{display:flex;align-items:center;gap:.7rem;padding:.5rem .85rem;margin-bottom:.35rem;border-bottom:1px solid rgba(255,255,255,.06);background:linear-gradient(180deg,rgba(255,255,255,.025) 0,rgba(255,255,255,0) 100%);border-radius:6px 6px 0 0}.bgp-ng-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.bgp-ng-ok .bgp-ng-dot{background:var(--success);box-shadow:0 0 6px rgba(16,185,129,.5)}.bgp-ng-warn .bgp-ng-dot{background:#f59e0b;box-shadow:0 0 6px rgba(245,158,11,.5)}.bgp-ng-err .bgp-ng-dot{background:var(--danger);box-shadow:0 0 6px rgba(239,68,68,.5)}.bgp-ng-empty .bgp-ng-dot{background:var(--text-muted);opacity:.5}.bgp-ng-empty .bgp-ng-count{color:var(--text-muted);opacity:.6}.bgp-ng-noPeers{font-size:.75rem;color:var(--text-muted);padding:.7rem .6rem;text-align:center;font-style:italic;opacity:.7}.bgp-ng-name{font-size:.82rem;font-weight:700;color:var(--text);letter-spacing:-.01em;text-transform:uppercase}.bgp-ng-count{margin-left:auto;font-size:.82rem;font-weight:700;font-family:var(--font-mono);letter-spacing:-.02em}.bgp-ng-ok .bgp-ng-count{color:var(--success)}.bgp-ng-warn .bgp-ng-count{color:#f59e0b}.bgp-ng-err .bgp-ng-count{color:var(--danger)}.bgp-ng-count-alt{color:var(--text-muted);font-weight:500;opacity:.7}.bgp-ng-shut{font-size:.62rem;font-weight:700;color:#f87171;background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.25);padding:1px 6px;border-radius:4px;letter-spacing:.05em;text-transform:uppercase}.bgp-ng-idle{font-size:.62rem;font-weight:700;color:#fbbf24;background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.28);padding:1px 6px;border-radius:4px;letter-spacing:.05em;text-transform:uppercase}.bgp-ng-down{font-size:.62rem;font-weight:700;color:#f87171;background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.22);padding:1px 6px;border-radius:4px;letter-spacing:.05em;text-transform:uppercase}.bgp-peer-item{display:grid;grid-template-columns:8px 120px minmax(60px,1fr) 55px 42px 80px auto;gap:.6rem;align-items:center;padding:.5rem .6rem;border-radius:7px;border:1px solid rgba(255,255,255,.03);background:rgba(255,255,255,.012);transition:background .15s,border-color .15s;min-width:0}.bgp-peer-item-filter{grid-template-columns:8px 120px minmax(60px,1fr) auto auto}.bgp-peer-item:hover{background:rgba(255,255,255,.035);border-color:rgba(255,255,255,.07)}.bgp-pi-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;justify-self:center}.bgp-pl-up .bgp-pi-dot{background:var(--success);box-shadow:0 0 6px rgba(16,185,129,.5)}.bgp-pl-down .bgp-pi-dot{background:var(--danger);box-shadow:0 0 6px rgba(239,68,68,.5)}.bgp-pl-partial .bgp-pi-dot{background:#f59e0b;box-shadow:0 0 6px rgba(245,158,11,.5)}.bgp-pi-ip{font-family:var(--font-mono);font-size:.78rem;color:var(--text);font-weight:600;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.bgp-pi-desc{font-size:.72rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;opacity:.9;min-width:0}.bgp-pi-uptime{min-width:0;overflow:hidden;text-overflow:ellipsis}.bgp-pi-uptime{font-size:.68rem;color:var(--text-muted);font-family:var(--font-mono);opacity:.7;white-space:nowrap}.bgp-pi-status{font-size:.72rem;font-weight:700;font-family:var(--font-mono);letter-spacing:-.02em;text-align:center}.bgp-pl-up .bgp-pi-status{color:var(--success)}.bgp-pl-down .bgp-pi-status{color:var(--danger)}.bgp-pl-idle .bgp-pi-status{color:#fbbf24}.bgp-pl-partial .bgp-pi-status{color:#f59e0b}.bgp-pl-idle{border-color:rgba(245,158,11,.12)!important;background:rgba(245,158,11,.018)!important}.bgp-pl-idle:hover{border-color:rgba(245,158,11,.25)!important;background:rgba(245,158,11,.035)!important}.bgp-pl-idle .bgp-pi-dot{background:#f59e0b!important;box-shadow:0 0 6px rgba(245,158,11,.45)!important;animation:bgpIdlePulse 2s ease-in-out infinite}@keyframes bgpIdlePulse{0%,100%{opacity:1}50%{opacity:.35}}.bgp-maint-overlay{position:fixed;inset:0;background:rgba(3,7,18,.75);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:200;opacity:0;pointer-events:none;transition:opacity .2s}.bgp-maint-overlay.open{opacity:1;pointer-events:auto}.bgp-maint-card{width:min(560px,94vw);max-height:85vh;background:var(--surface);border:1px solid rgba(255,255,255,.06);border-radius:14px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px rgba(0,0,0,.5);transform:translateY(8px);transition:transform .25s}.bgp-maint-overlay.open .bgp-maint-card{transform:translateY(0)}.bgp-maint-head{display:flex;align-items:center;gap:.85rem;padding:1rem 1.15rem;border-bottom:1px solid rgba(255,255,255,.05)}.bgp-maint-head-icon{color:var(--primary-light);display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:.85}.bgp-maint-head-text{flex:1;min-width:0}.bgp-maint-head-title{font-size:.92rem;font-weight:700;color:var(--text);letter-spacing:-.01em}.bgp-maint-head-sub{font-size:.68rem;color:var(--text-muted);margin-top:.15rem;opacity:.75}.bgp-maint-close{background:0 0;border:none;color:var(--text-muted);font-size:1.4rem;line-height:1;cursor:pointer;width:30px;height:30px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.bgp-maint-close:hover{background:rgba(255,255,255,.05);color:var(--text)}.bgp-maint-body{padding:.75rem;overflow-y:auto}.bgp-maint-list{display:flex;flex-direction:column;gap:.35rem}.bgp-maint-sub-active{color:#34d399}.bgp-maint-sub-paused{color:#fbbf24}.bgp-mrow{display:grid;grid-template-columns:8px minmax(0,1fr) auto auto;gap:.75rem;align-items:center;padding:.7rem .85rem;border-radius:9px;border:1px solid rgba(255,255,255,.05);background:rgba(255,255,255,.015);transition:background .12s,border-color .15s;min-width:0}.bgp-mrow:hover{background:rgba(255,255,255,.03)}.bgp-mrow.is-maint{background:linear-gradient(90deg,rgba(245,158,11,.05),rgba(245,158,11,.015));border-color:rgba(245,158,11,.18)}.bgp-mrow.is-maint:hover{background:linear-gradient(90deg,rgba(245,158,11,.08),rgba(245,158,11,.02));border-color:rgba(245,158,11,.28)}.bgp-mrow-dot{width:8px;height:8px;border-radius:50%}.bgp-mrow.is-active .bgp-mrow-dot{background:var(--success);box-shadow:0 0 6px rgba(16,185,129,.55)}.bgp-mrow.is-maint .bgp-mrow-dot{background:#f59e0b;box-shadow:0 0 6px rgba(245,158,11,.55)}.bgp-mrow-name{font-size:.78rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bgp-mrow-state{font-size:.68rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:600;white-space:nowrap;text-align:left}.bgp-mrow.is-maint .bgp-mrow-state{color:#fbbf24}.bgp-mrow.is-active .bgp-mrow-state{color:#34d399}.bgp-mrow-btn{padding:.42rem .85rem;border-radius:7px;font-size:.7rem;font-weight:600;cursor:pointer;border:1px solid transparent;font-family:inherit;transition:all .15s;white-space:nowrap;text-align:center}.bgp-mrow-btn-withdraw{background:rgba(239,68,68,.08);border-color:rgba(239,68,68,.25);color:#f87171}.bgp-mrow-btn-withdraw:hover{background:rgba(239,68,68,.16);border-color:rgba(239,68,68,.4)}.bgp-mrow-btn-reannounce{background:rgba(16,185,129,.1);border-color:rgba(16,185,129,.28);color:#34d399}.bgp-mrow-btn-reannounce:hover{background:rgba(16,185,129,.18);border-color:rgba(16,185,129,.45)}.bgp-mrow-btn:disabled{cursor:not-allowed;opacity:.85}.bgp-mrow-btn-loading{min-width:80px;display:inline-flex;align-items:center;justify-content:center}.bgp-mrow-spinner{width:14px;height:14px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:bgpMrowSpin .8s linear infinite;display:inline-block}@keyframes bgpMrowSpin{to{transform:rotate(360deg)}}.bgp-mrow-pending{background:rgba(245,158,11,.04)!important;border-color:rgba(245,158,11,.18)!important}.bgp-mrow-pending .bgp-mrow-dot{background:#f59e0b!important;box-shadow:0 0 6px rgba(245,158,11,.55)!important;animation:bgpMrowPulse 1s ease-in-out infinite}.bgp-mrow-pending .bgp-mrow-state{color:#fbbf24!important}@keyframes bgpMrowPulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.6}}@media(max-width:520px){.bgp-mrow{grid-template-columns:8px minmax(0,1fr) auto;gap:.5rem}.bgp-mrow-state{display:none}.bgp-mrow-btn{padding:.38rem .65rem;font-size:.65rem}.bgp-mrow-name{font-size:.72rem}.bgp-maint-head{padding:.85rem 1rem}.bgp-maint-head-title{font-size:.85rem}}.bgp-maint-item-off .bgp-maint-dot{background:var(--success);box-shadow:0 0 6px rgba(16,185,129,.5)}.bgp-maint-item-on .bgp-maint-dot{background:#f59e0b;box-shadow:0 0 6px rgba(245,158,11,.5)}.bgp-maint-item-on .bgp-maint-label{color:#f59e0b}.bgp-maint-btn-on:hover{background:rgba(239,68,68,.2)}.bgp-maint-btn-off:hover{background:rgba(16,185,129,.2)}.bgp-pi-actions{display:flex;flex-wrap:nowrap;gap:.25rem;opacity:.7;transition:opacity .15s;justify-self:end;pointer-events:auto;flex-shrink:0;white-space:nowrap}.bgp-peer-item:hover .bgp-pi-actions{opacity:1}.bgp-pi-btn{width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.02);color:var(--text-muted);border-radius:5px;cursor:pointer;padding:0;transition:all .15s;flex-shrink:0}.bgp-pi-btn:hover{background:rgba(83,140,190,.15);border-color:var(--primary);color:var(--primary-light);transform:translateY(-1px)}.bgp-pi-reset:hover{background:rgba(245,158,11,.15);border-color:#f59e0b;color:#fbbf24}.bgp-pi-toggle.is-shut{background:rgba(239,68,68,.12);border-color:rgba(239,68,68,.3);color:#f87171}.bgp-pi-toggle.is-shut:hover{background:rgba(16,185,129,.15);border-color:var(--success);color:#34d399}.bgp-pi-toggle:hover:not(.is-shut){background:rgba(239,68,68,.12);border-color:rgba(239,68,68,.3);color:#f87171}.bgp-pi-del:hover{background:rgba(239,68,68,.15);border-color:var(--danger);color:#f87171}.bgp-pl-shutdown{border-color:rgba(239,68,68,.15)!important;background:rgba(239,68,68,.025)!important}.bgp-pl-shutdown:hover{border-color:rgba(239,68,68,.28)!important;background:rgba(239,68,68,.04)!important}.bgp-pl-shutdown .bgp-pi-dot{background:var(--text-muted)!important;box-shadow:none!important}.bgp-pl-shutdown .bgp-pi-ip{color:var(--text-muted);text-decoration:line-through;text-decoration-color:rgba(248,113,113,0.5);text-decoration-thickness:1px}.bgp-pl-shutdown .bgp-pi-as,.bgp-pl-shutdown .bgp-pi-desc,.bgp-pl-shutdown .bgp-pi-pfx,.bgp-pl-shutdown .bgp-pi-status,.bgp-pl-shutdown .bgp-pi-uptime{opacity:.55}@media(max-width:520px){.bgp-peer-item{grid-template-columns:10px minmax(110px,1fr) 60px auto;gap:.5rem}.bgp-pi-desc,.bgp-pi-uptime{display:none}}.bgp-route-row{display:grid;grid-template-columns:minmax(120px,1fr) 60px minmax(90px,0.8fr) 55px 55px 55px minmax(50px,0.8fr) 60px;gap:.4rem;align-items:center;padding:.35rem .75rem;font-size:.8rem;border-bottom:1px solid rgba(255,255,255,.03);transition:background var(--transition)}.bgp-route-row:last-child{border-bottom:none}.bgp-route-row:hover{background:rgba(255,255,255,.02)}.bgp-route-row:hover .wl-del-btn{opacity:1}.bgp-route-net{font-weight:600;display:flex;align-items:center;gap:.3rem}.bgp-route-type.type-static{color:var(--primary-light);background:rgba(83,140,190,.1)}.bgp-route-type.type-connected{color:var(--success);background:rgba(16,185,129,.1)}.bgp-route-type.type-bgp{color:var(--warning);background:rgba(245,158,11,.1)}.bgp-route-type.type-kernel{color:var(--text-muted);background:rgba(255,255,255,.06)}@media(max-width:768px){.bgp-peer-grid{grid-template-columns:1fr}.bgp-route-head,.bgp-route-row{grid-template-columns:1fr 1fr 32px}.bgp-route-head span:nth-child(2),.bgp-route-head span:nth-child(4),.bgp-route-head span:nth-child(5),.bgp-route-head span:nth-child(6),.bgp-route-row span:nth-child(2),.bgp-route-row span:nth-child(4),.bgp-route-row span:nth-child(5),.bgp-route-row span:nth-child(6){display:none}}.bgp-kpis{display:grid;grid-template-columns:repeat(5,1fr);gap:.75rem;margin-bottom:1rem}.bgp-kpi{padding:.85rem 1rem;border-radius:10px;border:1px solid rgba(255,255,255,.05);background:rgba(255,255,255,.015);position:relative;overflow:hidden;transition:border-color .15s}.bgp-kpi:hover{border-color:rgba(255,255,255,.08)}.bgp-kpi::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:rgba(255,255,255,.04)}.bgp-kpi.bgp-kpi-ok::before{background:var(--success);box-shadow:0 0 8px rgba(16,185,129,.4)}.bgp-kpi.bgp-kpi-warn::before{background:#f59e0b;box-shadow:0 0 8px rgba(245,158,11,.4)}.bgp-kpi.bgp-kpi-err::before{background:var(--danger);box-shadow:0 0 8px rgba(239,68,68,.4)}.bgp-kpi.bgp-kpi-loading::before{background:linear-gradient(90deg,rgba(255,255,255,.04),rgba(255,255,255,.18),rgba(255,255,255,.04));background-size:200% 100%;animation:shimmer 1.4s ease-in-out infinite}.bgp-kpi.bgp-kpi-loading .bgp-kpi-num{color:var(--text-muted);opacity:.5}.bgp-kpi.bgp-kpi-loading .bgp-kpi-hint{color:var(--primary-light);opacity:.7}.bgp-kpi.bgp-kpi-stale{opacity:.75}.bgp-kpi.bgp-kpi-stale .bgp-kpi-hint::before{content:'◷ ';color:var(--primary-light)}.bgp-kpi-num{font-family:var(--font-mono);font-size:1.5rem;font-weight:700;color:var(--text);line-height:1;letter-spacing:-.01em;display:flex;align-items:baseline;gap:.15rem}.bgp-kpi-num-alt{font-size:.85rem;font-weight:500;color:var(--text-muted);opacity:.7}.bgp-kpi-mono{font-size:1.15rem}.bgp-kpi-label{font-size:.62rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-top:.5rem;font-weight:600}.bgp-kpi-hint{font-size:.62rem;color:var(--text-muted);opacity:.55;margin-top:.2rem;font-family:var(--font-mono)}.bgp-kpi-ok .bgp-kpi-num{color:var(--text)}.bgp-kpi-err .bgp-kpi-num{color:#f87171}@media(max-width:1100px){.bgp-kpis{grid-template-columns:repeat(3,1fr)}.bgp-kpis .bgp-kpi:nth-child(n+4){display:none}}@media(max-width:700px){.bgp-kpis{grid-template-columns:repeat(2,1fr)}}.help-icon{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%;background:rgba(255,255,255,.07);color:var(--text-muted);font-size:.6rem;font-weight:700;cursor:help;margin-left:.35rem;border:1px solid var(--glass-border);position:relative;font-family:var(--font-mono);flex-shrink:0;transition:background .12s,color .12s,border-color .12s;letter-spacing:normal;text-transform:none;line-height:1}.help-icon:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.help-icon[data-tip]:hover::after{content:attr(data-tip);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);background:var(--surface,#0a0f1a);color:var(--text);padding:.55rem .75rem;border-radius:6px;font-size:.72rem;font-weight:500;line-height:1.45;width:max-content;max-width:280px;text-align:left;white-space:normal;z-index:1000;border:1px solid var(--glass-border);box-shadow:0 8px 24px rgba(0,0,0,.6);pointer-events:none;text-transform:none;letter-spacing:normal;font-family:var(--font-sans)}.help-icon[data-tip]:hover::before{content:"";position:absolute;bottom:calc(100% + 4px);left:50%;transform:translateX(-50%);border:4px solid transparent;border-top-color:var(--glass-border);z-index:1000;pointer-events:none}.bgp-peer-bfd-badge{display:inline-flex;align-items:center;gap:.2rem;font-size:.55rem;font-weight:700;letter-spacing:.5px;color:#34d399;background:rgba(16,185,129,.13);border:1px solid rgba(16,185,129,.3);padding:.1rem .35rem;border-radius:4px;margin-left:.4rem;font-family:var(--font-mono);line-height:1;cursor:help;position:relative}.bgp-peer-bfd-badge svg{width:9px;height:9px}.bgp-peer-bfd-badge[data-tip]:hover::after{content:attr(data-tip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);background:var(--surface,#0a0f1a);color:var(--text);padding:.4rem .6rem;border-radius:5px;font-size:.7rem;font-weight:500;letter-spacing:normal;white-space:nowrap;z-index:1000;border:1px solid var(--glass-border);box-shadow:0 4px 12px rgba(0,0,0,.5);pointer-events:none;font-family:var(--font-sans);text-transform:none}.bgp-pi-bfd{display:inline-flex;align-items:center;font-size:.55rem;font-weight:700;letter-spacing:.5px;color:#34d399;background:rgba(16,185,129,.13);border:1px solid rgba(16,185,129,.3);padding:.08rem .3rem;border-radius:3px;font-family:var(--font-mono);line-height:1;cursor:help;position:relative}.bgp-pi-bfd[data-tip]:hover::after{content:attr(data-tip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);background:var(--surface,#0a0f1a);color:var(--text);padding:.4rem .6rem;border-radius:5px;font-size:.7rem;font-weight:500;letter-spacing:normal;white-space:nowrap;z-index:1000;border:1px solid var(--glass-border);box-shadow:0 4px 12px rgba(0,0,0,.5);pointer-events:none;font-family:var(--font-sans);text-transform:none}.bgp-checkbox-row{display:flex;align-items:flex-start;gap:.5rem;font-size:.78rem;color:var(--text-soft);cursor:pointer;line-height:1.4;user-select:none;text-transform:none;letter-spacing:normal;font-weight:500;margin-bottom:0;padding:.05rem 0}.bgp-checkbox-row input[type=checkbox]{margin-top:2px;width:15px;height:15px;accent-color:var(--primary);cursor:pointer;flex-shrink:0}.bgp-advanced-section{margin-top:.6rem;border:1px solid var(--glass-border);border-radius:6px;background:rgba(255,255,255,.02)}.bgp-advanced-section>summary{padding:.55rem .7rem;font-size:.74rem;font-weight:600;color:var(--text-muted);cursor:pointer;list-style:none;display:flex;align-items:center;gap:.4rem;user-select:none}.bgp-advanced-section>summary::-webkit-details-marker{display:none}.bgp-advanced-section>summary::before{content:'▸';font-size:.6rem;color:var(--text-muted);transition:transform var(--transition);display:inline-block}.bgp-advanced-section[open]>summary::before{transform:rotate(90deg)}.bgp-advanced-section[open]>summary{color:var(--text);border-bottom:1px solid var(--glass-border)}.bgp-advanced-grid{display:flex;flex-direction:column;gap:.7rem;padding:.85rem;margin:0}.bgp-advanced-grid .bgp-pair{display:grid;grid-template-columns:1fr 1fr;gap:.7rem 1rem}.bgp-advanced-grid label.bgp-fld-label{display:block;font-size:.62rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-weight:700;margin-bottom:.25rem}.bgp-advanced-grid input[type=number],.bgp-advanced-grid input[type=text]{width:100%;background:rgba(255,255,255,.04);border:1px solid var(--glass-border);border-radius:5px;color:var(--text);font-family:var(--font-mono);font-size:.78rem;padding:.4rem .55rem;outline:0;transition:border-color var(--transition)}.bgp-advanced-grid input:focus{border-color:var(--primary)}.bgp-advanced-grid input[type=number]::-webkit-inner-spin-button,.bgp-advanced-grid input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.bgp-advanced-grid input[type=number]{-moz-appearance:textfield}.bgp-bfd-block{display:flex;flex-direction:column;gap:.4rem}.bgp-bfd-block .bgp-bfd-profile-row{display:none;padding-left:1.55rem}.bgp-bfd-block .bgp-bfd-profile-row .bgp-fld-label{font-size:.58rem;margin-bottom:.15rem}.bgp-bfd-block.bfd-on .bgp-bfd-profile-row{display:block}.bgp-tabs{display:flex;gap:.1rem;margin-bottom:1rem;border-bottom:1px solid rgba(255,255,255,.06);padding:0}.bgp-tab{background:0 0;border:none;padding:.7rem 1.1rem;font-size:.78rem;font-weight:600;color:var(--text-muted);cursor:pointer;font-family:inherit;position:relative;transition:color .15s;display:flex;align-items:center;gap:.4rem}.bgp-tab:hover{color:var(--text)}.bgp-tab.active{color:var(--text)}.bgp-tab.active::after{content:'';position:absolute;bottom:-1px;left:.4rem;right:.4rem;height:2px;background:var(--primary);border-radius:2px 2px 0 0}.bgp-tab-count{font-size:.62rem;font-weight:500;padding:.12rem .4rem;border-radius:999px;background:rgba(255,255,255,.05);color:var(--text-muted);font-family:var(--font-mono);min-width:24px;text-align:center}.bgp-tab.active .bgp-tab-count{background:rgba(83,140,190,.15);color:var(--primary-light)}.bgp-tab-panel{animation:fadeIn .2s ease-out}@keyframes fadeIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.bgp-routes-wrap{display:flex;flex-direction:column;gap:.75rem}.bgp-routes-search-box{position:relative;display:flex;align-items:center;flex:1;max-width:700px;padding:.85rem 1.15rem;border-radius:10px;border:1px solid rgba(255,255,255,.06);background:rgba(255,255,255,.02);transition:all .15s}.bgp-routes-search-box:focus-within{border-color:rgba(83,140,190,.35);background:rgba(83,140,190,.03);box-shadow:0 0 0 3px rgba(83,140,190,.06)}.bgp-routes-search-box svg{color:var(--text-muted);opacity:.6;flex-shrink:0;margin-right:.7rem}.bgp-routes-search-box input{flex:1;background:0 0;border:none;outline:0;color:var(--text);font-size:.78rem;font-family:inherit;padding:0}.bgp-routes-search-box input::placeholder{color:var(--text-muted);opacity:.55}.bgp-routes-search-clear{background:0 0;border:none;color:var(--text-muted);font-size:1.1rem;line-height:1;cursor:pointer;padding:0 0 0 .5rem;opacity:.6;transition:opacity .15s}.bgp-routes-search-clear:hover{opacity:1;color:var(--danger)}.bgp-routes-meta{font-size:.65rem;color:var(--primary-light);font-family:var(--font-mono);letter-spacing:.02em;padding:2px 8px;background:rgba(83,140,190,.1);border:1px solid rgba(83,140,190,.2);border-radius:999px;white-space:nowrap;flex-shrink:0;margin-left:.5rem}.bgp-bypass-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 1rem;background:rgba(83,140,190,.05);border:1px solid rgba(83,140,190,.15);border-radius:10px;margin-bottom:.75rem;flex-wrap:wrap}.bgp-bypass-info{flex:1;min-width:240px}.bgp-bypass-info strong{font-size:.85rem;color:var(--primary-light)}.bgp-bypass-desc{font-size:.72rem;color:var(--text-muted);margin-top:.25rem;line-height:1.4}.bgp-bypass-actions{display:flex;gap:.4rem;align-items:center;flex-wrap:wrap}.bgp-bypass-actions .search-input{width:auto;min-width:140px;max-width:220px}.bgp-bypass-table{width:100%;border-collapse:collapse;font-variant-numeric:tabular-nums;border:1px solid rgba(255,255,255,.05);border-radius:10px;overflow:hidden;background:rgba(255,255,255,.01)}.bgp-bypass-table th{text-align:left;font-size:.58rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);padding:.6rem .75rem;background:rgba(255,255,255,.025);border-bottom:1px solid rgba(255,255,255,.06)}.bgp-bypass-table td{padding:.55rem .75rem;font-size:.78rem;border-bottom:1px solid rgba(255,255,255,.03)}.bgp-bypass-table tr:last-child td{border-bottom:none}.bgp-bypass-table tr:nth-child(2n) td{background:rgba(255,255,255,.008)}.bgp-bypass-table tr:hover td{background:rgba(83,140,190,.04)}.bgp-bypass-prefix{font-family:var(--font-mono);font-weight:600;color:var(--primary-light)}.bgp-bypass-nh{font-family:var(--font-mono);color:var(--text-muted);font-size:.72rem}.bgp-bypass-reason-cell{color:var(--text-muted);font-size:.72rem;max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:text;transition:color .12s;position:relative;padding-right:24px!important}.bgp-bypass-reason-cell:hover{color:var(--text)}.bgp-bypass-reason-cell::after{content:"";position:absolute;right:6px;top:50%;width:12px;height:12px;margin-top:-6px;opacity:0;transition:opacity .12s;background:no-repeat center/contain url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2'><path d='M12 20h9'/><path d='M16.5 3.5a2.121 2.121 0 0 1 3 3L7 19l-4 1 1-4L16.5 3.5z'/></svg>");pointer-events:none}.bgp-bypass-table tr:hover .bgp-bypass-reason-cell::after{opacity:.6}.bgp-bypass-reason-cell.editing{overflow:visible;padding:.3rem .5rem!important}.bgp-bypass-reason-cell.editing::after{display:none}.bgp-bypass-reason-input{width:100%;background:rgba(255,255,255,.04);border:1px solid var(--primary);color:var(--text);font-size:.72rem;padding:.3rem .5rem;border-radius:6px;outline:0;font-family:inherit;box-sizing:border-box}.bgp-bypass-reason-input:focus{border-color:var(--primary-light);box-shadow:0 0 0 2px rgba(83,140,190,.15)}.bgp-bypass-reason-input:disabled{opacity:.6}.bgp-bypass-actions-cell{width:48px;text-align:right;padding-right:.75rem}.bgp-bypass-actions-cell .wl-del-btn{opacity:1;background:0 0;border:1px solid rgba(239,68,68,.25);color:#ef4444;padding:.3rem;border-radius:6px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .12s}.bgp-bypass-actions-cell .wl-del-btn:hover{background:rgba(239,68,68,.12);border-color:rgba(239,68,68,.5)}.bgp-routes-table{border:1px solid rgba(255,255,255,.05);border-radius:10px;overflow:hidden;font-variant-numeric:tabular-nums;background:rgba(255,255,255,.01)}.bgp-routes-thead{display:grid;grid-template-columns:1fr 80px 50px;gap:1rem;padding:.6rem 1rem;background:rgba(255,255,255,.025);border-bottom:1px solid rgba(255,255,255,.06);font-size:.58rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);opacity:.75}.bgp-routes-row{display:grid;grid-template-columns:1fr 80px 50px;gap:1rem;align-items:center;padding:.55rem 1rem;font-size:.78rem;border-bottom:1px solid rgba(255,255,255,.03);transition:background .12s}.bgp-routes-row:last-child{border-bottom:none}.bgp-routes-row:nth-child(2n){background:rgba(255,255,255,.008)}.bgp-routes-row:hover{background:rgba(83,140,190,.04)}.bgp-routes-row:hover .bgp-rr-del{opacity:1}.bgp-rr-prefix{font-family:var(--font-mono);font-size:.82rem;font-weight:600;color:var(--text);letter-spacing:-.01em}.bgp-rr-type{font-size:.58rem;font-weight:700;padding:.18rem .45rem;border-radius:4px;text-transform:uppercase;letter-spacing:.04em;display:inline-block;width:fit-content;font-family:var(--font-mono)}.bgp-rr-type.bgp-rt-pair{color:var(--primary-light);background:rgba(83,140,190,.12);border:1px solid rgba(83,140,190,.2)}.bgp-rr-type.bgp-rt-single{color:var(--text-muted);background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05)}.bgp-rr-actions{display:flex;justify-content:flex-end}.bgp-rr-del{background:0 0;border:1px solid rgba(239,68,68,.15);color:#f87171;width:26px;height:26px;border-radius:5px;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .15s}.bgp-rr-del:hover{background:rgba(239,68,68,.12);border-color:rgba(239,68,68,.4)}.bgp-routes-empty{padding:3rem 1rem;text-align:center;color:var(--text-muted);font-size:.82rem;border:1px dashed rgba(255,255,255,.05);border-radius:10px}@media(max-width:768px){.bgp-routes-row,.bgp-routes-thead{grid-template-columns:1fr 60px 36px}}.bgp-filter-policy{display:flex;align-items:center;gap:.85rem;padding:1rem 1.15rem;border-radius:10px;border:1px solid rgba(83,140,190,.15);background:linear-gradient(135deg,rgba(83,140,190,.04),rgba(83,140,190,.01));margin-bottom:1rem}.bgp-filter-policy-advertiser{border-color:rgba(239,68,68,.12);background:linear-gradient(135deg,rgba(239,68,68,.035),rgba(239,68,68,.005))}.bgp-filter-policy-variable{border-color:rgba(245,158,11,.15);background:linear-gradient(135deg,rgba(245,158,11,.04),rgba(245,158,11,.01))}.bgp-filter-policy-icon{color:var(--primary-light);flex-shrink:0;opacity:.8}.bgp-filter-policy-advertiser .bgp-filter-policy-icon{color:#f87171}.bgp-filter-policy-variable .bgp-filter-policy-icon{color:#fbbf24}.bgp-filter-policy-body{flex:1;min-width:0}.bgp-filter-policy-text{font-size:.82rem;color:var(--text);line-height:1.5}.bgp-filter-policy-text strong{font-weight:600;color:var(--text)}.bgp-filter-policy-node{font-size:.68rem;color:var(--text-muted);margin-top:.3rem;opacity:.7}.bgp-filter-policy-node strong{color:var(--text-muted);font-weight:600}.bgp-f-pill{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .45rem;border-radius:5px;font-size:.65rem;font-weight:600;width:fit-content;border:1px solid transparent;font-family:inherit;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px}.bgp-peer-item-filter .bgp-f-pill{max-width:130px}.bgp-f-pill-icon{font-size:.8rem;line-height:1;opacity:.8}.bgp-f-ok{color:#34d399;background:rgba(16,185,129,.08);border-color:rgba(16,185,129,.18)}.bgp-f-err{color:#f87171;background:rgba(239,68,68,.08);border-color:rgba(239,68,68,.18)}.bgp-f-warn{color:#fbbf24;background:rgba(245,158,11,.08);border-color:rgba(245,158,11,.18)}.bgp-f-custom{color:var(--primary-light);background:rgba(83,140,190,.08);border-color:rgba(83,140,190,.18)}.bgp-f-pill-clickable{cursor:pointer;transition:transform .1s,filter .15s}.bgp-f-pill-clickable:hover{transform:translateY(-1px);filter:brightness(1.25)}.bgp-ng-add-btn,.bgp-ng-mgr-btn{background:0 0;border:1px solid rgba(255,255,255,.08);color:var(--text-muted);width:24px;height:24px;border-radius:5px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:0;transition:all .15s;margin-left:.4rem;flex-shrink:0}.bgp-ng-add-btn:hover,.bgp-ng-mgr-btn:hover{border-color:var(--primary);color:var(--primary-light);background:rgba(83,140,190,.08)}.bgp-ng-add-btn{margin-left:.3rem}.bgp-fm-tabs{display:flex;gap:0;border-bottom:1px solid rgba(255,255,255,.06);padding:0 1.2rem;margin:0}.bgp-fm-tab{background:0 0;border:none;border-bottom:2px solid transparent;padding:.75rem 1.1rem;font-size:.78rem;font-weight:600;color:var(--text-muted);cursor:pointer;transition:all .15s;font-family:inherit;letter-spacing:.01em}.bgp-fm-tab:hover{color:var(--text)}.bgp-fm-tab.active{color:var(--primary-light);border-bottom-color:var(--primary)}.bgp-fm-table{width:100%;border-collapse:collapse;font-size:.75rem}.bgp-fm-table thead th{text-align:left;padding:.45rem .6rem;font-size:.58rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);opacity:.75;border-bottom:1px solid rgba(255,255,255,.06)}.bgp-fm-table tbody td{padding:.45rem .6rem;border-bottom:1px solid rgba(255,255,255,.03);color:var(--text);vertical-align:top}.bgp-fm-table tbody tr:hover{background:rgba(255,255,255,.015)}.bgp-fm-mono{font-family:var(--font-mono);font-size:.72rem}.bgp-fm-small{font-size:.68rem;color:var(--text-muted);line-height:1.4}.bgp-fm-act{display:inline-flex;padding:1px 7px;border-radius:4px;font-size:.58rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;font-family:inherit}.bgp-fm-del{width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.08);background:0 0;color:var(--text-muted);border-radius:5px;cursor:pointer;padding:0;transition:all .15s}.bgp-fm-del:hover{border-color:var(--danger);color:#f87171;background:rgba(239,68,68,.08)}.bgp-nb-current{margin-bottom:.5rem}.bgp-nb-current-label{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:.4rem;opacity:.75}.bgp-nb-current-chip{display:inline-flex;align-items:center;gap:.45rem;padding:.35rem .7rem;background:rgba(83,140,190,.1);border:1px solid rgba(83,140,190,.3);border-radius:999px;font-family:var(--font-mono);font-size:.72rem;font-weight:600;color:var(--primary-light)}.bgp-nb-current-chip svg{color:var(--primary-light);flex-shrink:0}.bgp-nb-current-chip.bgp-nb-current-none{background:rgba(255,255,255,.03);border-color:rgba(255,255,255,.08);color:var(--text-muted);font-family:inherit;font-weight:500}.bgp-nb-hint{display:flex;align-items:flex-start;gap:.4rem;font-size:.68rem;color:var(--text-muted);margin-top:.5rem;padding:.45rem .6rem;background:rgba(245,158,11,.05);border:1px solid rgba(245,158,11,.15);border-radius:6px;line-height:1.45}.bgp-nb-hint svg{color:#f59e0b;flex-shrink:0;margin-top:1px}.bgp-fm-empty{text-align:center;padding:2rem 1.2rem;color:var(--text-muted);opacity:.7}.bgp-fm-empty-icon{display:block;margin:0 auto .6rem;opacity:.35}.bgp-fm-empty-text{font-size:.78rem;font-weight:500}.bgp-fm-empty-hint{font-size:.68rem;margin-top:.3rem;opacity:.6}.bgp-fm-addbox{margin-top:1rem;padding:.9rem 1rem;border:1px solid rgba(255,255,255,.05);background:rgba(255,255,255,.012);border-radius:8px}.bgp-fm-addtitle{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:.7rem;opacity:.8}.bgp-fm-addrow{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.bgp-fm-addrow input[type=number],.bgp-fm-addrow input[type=text],.bgp-fm-addrow select{flex:1;min-width:90px;background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.08);color:var(--text);border-radius:6px;padding:.45rem .6rem;font-size:.75rem;font-family:inherit;height:34px;box-sizing:border-box}.bgp-fm-addrow input:focus,.bgp-fm-addrow select:focus{border-color:var(--primary);outline:0;background:rgba(255,255,255,.04);box-shadow:0 0 0 2px rgba(83,140,190,.15)}.bgp-fm-addrow .btn-login{padding:0 1rem;font-size:.72rem;font-weight:700;flex:0 0 auto;height:34px;margin-left:auto}.bgp-fm-addbox textarea{width:100%;font-family:var(--font-mono);font-size:.72rem;background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.08);color:var(--text);border-radius:6px;padding:.45rem .6rem;margin-top:.45rem;transition:all .15s;resize:vertical;outline:0}.bgp-fm-addbox textarea:focus{border-color:var(--primary);background:rgba(255,255,255,.04);box-shadow:0 0 0 2px rgba(83,140,190,.15)}.atk-count{font-size:.65rem;font-weight:600;background:var(--bg-hover);color:var(--text-muted);padding:.1rem .5rem;border-radius:4px;margin-left:.15rem}.atk-count.atk-count-neutral{background:rgba(148,163,184,.1);color:#94a3b8;font-family:var(--font-mono)}.atk-active-badge{font-size:.6rem;font-weight:700;background:rgba(239,68,68,.12);color:var(--danger);padding:.15rem .5rem;border-radius:4px;animation:attackPulse 2s ease-in-out infinite}.atk-list{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);overflow:hidden;box-shadow:var(--card-shadow)}.atk-head{display:grid;grid-template-columns:20px minmax(50px,0.5fr) minmax(100px,1.3fr) minmax(70px,0.7fr) minmax(90px,1fr) minmax(90px,1fr) 55px minmax(45px,0.4fr) minmax(130px,2fr);gap:.5rem;align-items:center;padding:.4rem .75rem;font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);opacity:.6;border-bottom:1px solid var(--glass-border)}.atk-row{display:grid;grid-template-columns:20px minmax(50px,0.5fr) minmax(100px,1.3fr) minmax(70px,0.7fr) minmax(90px,1fr) minmax(90px,1fr) 55px minmax(45px,0.4fr) minmax(130px,2fr);gap:.5rem;align-items:center;padding:.45rem .75rem;font-size:.8rem;border-bottom:1px solid rgba(255,255,255,.03);border-left:2px solid transparent;transition:background var(--transition),border-color .15s;position:relative}.atk-row:last-child{border-bottom:none}.atk-row-mid,.atk-row-top{display:contents}.atk-row:hover{background:rgba(255,255,255,.02)}.atk-row.atk-ongoing{border-left-color:var(--danger);background:rgba(239,68,68,.05)}.atk-row.atk-sev-ended{border-left-color:transparent}.atk-row.atk-sev-ended>*{opacity:.45}.atk-peak-bar{height:4px;background:rgba(255,255,255,.08);border-radius:2px;margin-top:4px;width:80px}.atk-peak-bar-fill{height:100%;border-radius:2px;background:linear-gradient(90deg,#ef4444,#f97316);min-width:2px}.node-cap-bar{display:none;align-items:center;gap:.4rem;width:100%;margin-top:.35rem;padding:0 .75rem}.node-cap-bar>div:first-child{flex:1;height:4px;background:rgba(255,255,255,.06);border-radius:2px;overflow:hidden}.node-cap-fill{height:100%;background:linear-gradient(90deg,var(--success),var(--primary));border-radius:2px;transition:width .5s ease;width:0}.node-cap-pct{font-size:.6rem;color:var(--text-muted);font-variant-numeric:tabular-nums;min-width:32px;text-align:right}.cfg-jump-nav{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:1rem;padding:.5rem .75rem;background:var(--glass);border:1px solid var(--glass-border);border-radius:10px;position:sticky;top:0;z-index:5}.cfg-jump-link{font-size:.7rem;color:var(--text-muted);text-decoration:none;padding:.25rem .5rem;border-radius:5px;transition:all var(--transition);white-space:nowrap}.cfg-jump-link:hover{color:var(--text);background:rgba(255,255,255,.05)}.atk-subnet{font-weight:600;font-variant-numeric:tabular-nums;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;flex-direction:column;gap:.1rem}.atk-subnet-link{color:var(--text);text-decoration:none;transition:color .15s}.atk-subnet-link:hover{color:var(--primary-light)}.atk-client-btn{display:inline-flex;align-items:center;gap:.3rem;font-size:.65rem;font-weight:600;color:var(--primary-light);background:rgba(83,140,190,.1);border:1px solid rgba(83,140,190,.2);border-radius:4px;padding:.1rem .4rem;margin-top:.15rem;cursor:pointer;transition:all var(--transition);font-family:inherit;letter-spacing:.2px;line-height:1.3}.atk-client-btn:hover{background:rgba(83,140,190,.2);border-color:rgba(83,140,190,.4)}.atk-client-btn:focus-visible{background:rgba(83,140,190,.2);border-color:var(--primary);outline:0}.atk-client-asn{font-weight:400;opacity:.7;font-size:.6rem}.atk-client-pop{position:fixed;z-index:9999;background:var(--surface);border:1px solid var(--glass-border);border-radius:10px;padding:.75rem;min-width:160px;max-width:300px;box-shadow:0 8px 24px rgba(0,0,0,.5);opacity:0;transition:opacity var(--transition)}.atk-client-pop-header{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:.5rem;font-size:.8rem}.atk-client-pop-asn{font-size:.7rem;color:var(--text-muted);font-weight:400}.atk-client-pop-list{display:flex;flex-wrap:wrap;gap:.3rem;justify-content:center}.atk-client-pop-sn{font-size:.7rem;font-variant-numeric:tabular-nums;padding:.15rem .4rem;border-radius:4px;background:rgba(255,255,255,.05);border:1px solid var(--glass-border);color:var(--text-muted);font-family:var(--font-mono)}.atk-type{font-size:.55rem;font-weight:600;text-transform:uppercase;padding:2px 5px;border-radius:4px;letter-spacing:.3px;text-align:center;width:fit-content;white-space:nowrap;background:rgba(255,255,255,.06);color:var(--text-muted);border:1px solid rgba(255,255,255,.08)}.atk-nodes{display:flex;flex-wrap:wrap;gap:3px}.atk-node-badge{font-size:.65rem;padding:2px 6px;border-radius:4px;background:rgba(83,140,190,.12);color:var(--primary-light);white-space:nowrap}.atk-time{font-size:.7rem;color:var(--text-muted);font-variant-numeric:tabular-nums}.atk-status-on{font-size:.6rem;font-weight:700;color:var(--danger);display:flex;align-items:center;gap:.3rem}.atk-status-dot{width:6px;height:6px;border-radius:50%;background:var(--danger);animation:livePulse 2s ease-in-out infinite}.atk-duration{font-size:.7rem;color:var(--text-muted);font-variant-numeric:tabular-nums}.atk-detector{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px;padding:.15rem .45rem;border-radius:4px;text-align:center;width:fit-content;background:rgba(16,185,129,.1);color:var(--success);border:1px solid rgba(16,185,129,.15)}.atk-peak{font-size:.7rem;color:var(--primary-light);font-weight:500;font-variant-numeric:tabular-nums}.atk-pagination{display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.5rem .75rem;border-top:1px solid rgba(239,68,68,.1)}.atk-page-btn{background:0 0;border:1px solid var(--glass-border);border-radius:4px;color:var(--text-muted);font-size:.62rem;font-weight:500;font-family:inherit;padding:.2rem .5rem;cursor:pointer;transition:all var(--transition)}.atk-page-btn:hover:not(:disabled){color:var(--text);background:var(--bg-hover);border-color:var(--glass-border)}.atk-page-btn:focus-visible:not(:disabled){color:var(--text);background:var(--bg-hover);border-color:var(--primary)}.atk-page-btn:disabled{opacity:.3;cursor:not-allowed}.atk-page-info{font-size:.62rem;color:var(--text-muted)}.atk-empty{text-align:center;padding:3rem 1rem;color:var(--text-muted);font-size:.8rem;opacity:.6}.act-head,.act-row{display:grid;grid-template-columns:120px 1fr 1fr 1.5fr 120px;gap:.5rem;padding:.6rem .75rem;align-items:center;font-size:.8rem}.act-head{color:var(--text-muted);font-weight:600;font-size:.7rem;text-transform:uppercase;letter-spacing:.3px;border-bottom:1px solid var(--glass-border)}.act-row{border-bottom:1px solid var(--bg-subtle)}.act-row:last-child{border-bottom:none}.act-time{color:var(--text-muted);font-variant-numeric:tabular-nums;font-size:.75rem}.act-event{display:inline-block;padding:.15rem .5rem;border-radius:4px;font-size:.7rem;font-weight:500;width:fit-content}.act-user{color:var(--text);font-size:.8rem}.act-details{color:var(--text-muted);font-size:.75rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.act-ip{color:var(--text-muted);font-size:.75rem;font-variant-numeric:tabular-nums}.act-count{font-size:.7rem;background:rgba(255,255,255,.08);padding:.15rem .5rem;border-radius:10px;color:var(--text-muted);font-weight:500;margin-left:.35rem}.cl-grid{display:flex;flex-direction:column;gap:.75rem}.cl-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);overflow:hidden;transition:border-color .2s,box-shadow .2s;box-shadow:var(--card-shadow)}.cl-card:hover{border-color:rgba(255,255,255,.12);box-shadow:0 2px 6px rgba(0,0,0,.3),0 8px 20px rgba(0,0,0,.2)}.cl-card-header{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;cursor:pointer;transition:background var(--transition)}.cl-card-header:hover{background:rgba(255,255,255,.02)}.cl-card-name{font-size:.9rem;font-weight:600;flex:1;min-width:0}.cl-card-asn{font-size:.65rem;font-weight:600;color:var(--primary-light);background:rgba(83,140,190,.1);padding:.15rem .5rem;border-radius:4px}.cl-card-subnet-count{font-size:.65rem;font-weight:600;color:var(--text-muted);background:var(--bg-hover);padding:.15rem .5rem;border-radius:4px}.cl-card-notes{font-size:.7rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.cl-card-actions{display:flex;gap:.25rem;flex-shrink:0}.cl-card-chevron{color:var(--text-muted);transition:transform .2s,color .2s;flex-shrink:0;background:rgba(255,255,255,.05);border-radius:4px;padding:2px}.cl-card-header:hover .cl-card-chevron{color:var(--primary-light);background:rgba(83,140,190,.15)}.cl-card.open .cl-card-chevron{transform:rotate(90deg)}.cl-card-body{display:none;padding:0 1rem .75rem;border-top:1px solid var(--glass-border)}.cl-card.open .cl-card-body{display:block}.cl-subnet-list{display:flex;flex-wrap:wrap;gap:.4rem;padding-top:.65rem}.cl-subnet-tag{display:flex;align-items:center;gap:.35rem;font-size:.75rem;font-weight:500;font-variant-numeric:tabular-nums;padding:.3rem .6rem;border-radius:6px;background:rgba(255,255,255,.05);border:1px solid var(--glass-border);transition:all var(--transition)}.cl-subnet-tag:hover{border-color:rgba(239,68,68,.25)}.cl-subnet-del{display:flex;align-items:center;justify-content:center;background:0 0;border:none;color:var(--text-muted);cursor:pointer;padding:0;opacity:0;transition:all var(--transition)}.cl-subnet-tag:hover .cl-subnet-del{opacity:1}.cl-subnet-del:hover{color:var(--danger)}.cl-subnet-del:focus-visible{opacity:1;color:var(--danger);outline:0}.cl-modal-subnets{display:flex;flex-direction:column;gap:.5rem}.cl-modal-subnet-tags{display:flex;flex-wrap:wrap;gap:.35rem}.cl-modal-subnet-tags:empty{display:none}.cl-modal-stag{display:inline-flex;align-items:center;gap:.3rem;font-size:.75rem;font-weight:500;font-variant-numeric:tabular-nums;padding:.25rem .5rem;border-radius:6px;background:rgba(83,140,190,.12);border:1px solid rgba(83,140,190,.25);color:var(--primary-light)}.cl-modal-stag-del{display:flex;align-items:center;background:0 0;border:none;color:var(--text-muted);cursor:pointer;padding:0}.cl-modal-stag-del:hover{color:var(--danger)}.cl-modal-stag-del:focus-visible{color:var(--danger);outline:0}.cl-modal-subnet-input{display:flex;gap:.35rem}.cl-modal-subnet-input input{flex:1;min-width:0}.cl-modal-subnet-add{display:flex;align-items:center;justify-content:center;width:36px;flex-shrink:0;background:rgba(83,140,190,.15);border:1px solid rgba(83,140,190,.3);border-radius:6px;color:var(--primary-light);cursor:pointer;transition:all .2s}.cl-modal-subnet-add:hover{background:rgba(83,140,190,.25)}.cl-modal-subnet-add:focus-visible{background:rgba(83,140,190,.25);border-color:var(--primary);outline:0}.cl-subnet-add-btn{display:flex;align-items:center;gap:.3rem;font-size:.7rem;font-weight:500;color:var(--primary-light);background:0 0;border:1px dashed rgba(83,140,190,.3);border-radius:6px;padding:.3rem .6rem;cursor:pointer;transition:all var(--transition);font-family:inherit}.cl-subnet-add-btn:hover{border-color:var(--primary);background:rgba(83,140,190,.06)}.cl-subnet-add-btn:focus-visible{border-color:var(--primary);background:rgba(83,140,190,.06);outline:0}.cl-user-row:hover{background:rgba(255,255,255,.04)}.cl-user-row.disabled{opacity:.4}.cl-user-add-btn:hover{border-color:var(--primary);background:rgba(83,140,190,.06)}.cl-user-add-btn:focus-visible{border-color:var(--primary);background:rgba(83,140,190,.06);outline:0}.cl-empty{text-align:center;padding:3rem 1rem;color:var(--text-muted);font-size:.8rem;opacity:.6}.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.settings-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius);padding:1.25rem 1.5rem;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);display:flex;flex-direction:column;gap:1rem;box-shadow:var(--card-shadow)}.settings-card-wide{grid-column:1/-1}.settings-card-title{font-size:.85rem;font-weight:600;display:flex;align-items:center;gap:.5rem;padding-bottom:.65rem;border-bottom:1px solid var(--glass-border);color:var(--text)}.settings-card-title svg{color:var(--primary-light);opacity:.8}.set-field{display:flex;flex-direction:column;gap:.35rem}.set-field .modal-input{width:100%;padding:.55rem .75rem;background:var(--bg-subtle);border:1px solid var(--glass-border);border-radius:var(--radius-sm);color:var(--text);font-size:.8rem;font-family:inherit;outline:0;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.set-field .modal-input:focus{border-color:var(--primary);box-shadow:0 0 0 2px rgba(83,140,190,.15)}select.modal-input option{background:var(--surface-2);color:var(--text)}.set-label{font-size:.75rem;font-weight:500;color:var(--text-muted)}.set-logo-row{display:flex;align-items:center;gap:.75rem}.set-logo-preview{border-radius:8px;background:var(--bg-subtle);border:1px solid var(--glass-border);object-fit:contain}.set-favicon-preview{width:32px;height:32px;border-radius:6px}.set-upload-btn{display:inline-flex;align-items:center;gap:.35rem;cursor:pointer}.set-actions{padding-top:.5rem;display:flex;gap:.5rem;flex-wrap:wrap}.set-actions .btn-login{width:auto;padding:.5rem 1.5rem;font-size:.8rem}.set-row-2{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:.5rem}.set-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.75rem;margin-bottom:.5rem}.set-row-4{display:grid;grid-template-columns:1fr 100px 130px 1fr;gap:.75rem;margin-bottom:.5rem}.set-row-2:has(.set-field-sm){grid-template-columns:1fr 100px 130px}.set-field-sm .modal-input{text-align:center}.set-brand-row{display:grid;grid-template-columns:1fr 1fr 1fr auto auto auto;gap:1rem;align-items:end}.set-brand-upload{display:flex;flex-direction:column;gap:.35rem}.set-field-end{display:flex;align-items:flex-end;padding-bottom:.1rem}.smtp-loading{font-size:.8rem;color:var(--text-muted);padding:.5rem 0}.smtp-grid-bottom{display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:.75rem;align-items:end;margin-top:.75rem}.smtp-grid-bottom .set-field-end{display:flex;flex-direction:row;gap:.25rem;padding-bottom:.1rem}.smtp-test-result{font-size:.75rem;padding:.5rem .75rem;margin-top:.5rem;border-radius:var(--radius-sm)}.smtp-test-result.success{color:var(--success);background:rgba(16,185,129,.06);border:1px solid rgba(16,185,129,.15)}.smtp-test-result.error{color:var(--danger);background:rgba(239,68,68,.06);border:1px solid rgba(239,68,68,.15)}.table-wrapper{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);overflow:auto;box-shadow:var(--card-shadow)}.dash-table{width:100%;border-collapse:collapse}.dash-table thead th{padding:.4rem .75rem;font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);opacity:.6;text-align:left;border-bottom:1px solid var(--glass-border);white-space:nowrap}.dash-table tbody td{padding:.45rem .75rem;font-size:.8rem;border-bottom:1px solid rgba(255,255,255,.03)}.dash-table tbody tr:last-child td{border-bottom:none}.dash-table tbody tr:hover{background:rgba(255,255,255,.02)}.set-value{display:block;padding:.5rem .75rem;font-size:.85rem;color:var(--text-muted);background:rgba(255,255,255,.02);border:1px solid var(--glass-border);border-radius:var(--radius-sm);font-family:var(--font-mono)}.smtp-readonly-info{margin-bottom:.75rem}.tpl-card{border:1px solid var(--glass-border);border-radius:var(--radius-sm);padding:1rem;display:flex;flex-direction:column;gap:.75rem;background:rgba(255,255,255,.01)}.tpl-card-header{display:flex;align-items:center;gap:.5rem}.tpl-card-title{font-size:.7rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.tpl-vars{text-transform:none;letter-spacing:0;font-weight:400;font-family:var(--font-mono);font-size:.6rem;opacity:.6;color:var(--text-muted)}.btn-icon{padding:.45rem .55rem;display:inline-flex;align-items:center;justify-content:center;line-height:1}.set-color-row{display:flex;gap:.5rem;align-items:center}.set-color-input{width:36px;height:36px;padding:0;border:1px solid var(--glass-border);border-radius:var(--radius-sm);cursor:pointer;background:var(--bg-subtle)}.set-color-input::-webkit-color-swatch-wrapper{padding:2px}.set-color-input::-webkit-color-swatch{border:none;border-radius:4px}.set-field-color .modal-input{max-width:100px}.tpl-brand-grid{display:grid;grid-template-columns:1fr 1fr 1fr 1fr 1fr auto auto;gap:.75rem;align-items:end;margin-bottom:1rem}.tpl-preview-btn{margin-left:auto;background:0 0;border:1px solid var(--glass-border);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;padding:.3rem .4rem;display:inline-flex;align-items:center;justify-content:center;transition:all .2s;line-height:1}.tpl-preview-btn:hover{color:var(--primary-light);border-color:var(--primary);background:rgba(83,140,190,.08)}.tpl-columns{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}@media(max-width:900px){.settings-grid{grid-template-columns:1fr}.set-brand-row{grid-template-columns:1fr 1fr}.set-row-4{grid-template-columns:1fr 100px 130px}.tpl-brand-grid{grid-template-columns:1fr 1fr 1fr}.tpl-columns{grid-template-columns:1fr}.smtp-grid-bottom{grid-template-columns:1fr 1fr 1fr}}@media(max-width:600px){.set-row-2{grid-template-columns:1fr}.set-row-3{grid-template-columns:1fr}.set-row-4{grid-template-columns:1fr}.tpl-brand-grid{grid-template-columns:1fr 1fr}.smtp-grid-bottom{grid-template-columns:1fr}}.set-toggle{position:relative;display:inline-block;width:44px;height:24px;flex-shrink:0}.set-toggle input{opacity:0;width:0;height:0}.set-toggle-slider{position:absolute;cursor:pointer;inset:0;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);border-radius:24px;transition:all .3s}.set-toggle-slider::before{content:'';position:absolute;height:18px;width:18px;left:2px;bottom:2px;background:#9ca3af;border-radius:50%;transition:all .3s}.set-toggle input:checked+.set-toggle-slider{background:rgba(83,140,190,.2);border-color:var(--primary)}.set-toggle input:checked+.set-toggle-slider::before{transform:translateX(20px);background:var(--primary-light)}.set-toggle input:focus-visible+.set-toggle-slider{outline:2px solid var(--primary);outline-offset:2px}.set-maint-status{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:var(--success);padding:.5rem .75rem;border-radius:var(--radius-sm);background:rgba(16,185,129,.06);border:1px solid rgba(16,185,129,.15);transition:all .3s}.set-maint-status.active{color:var(--warning,#f59e0b);background:rgba(245,158,11,.06);border-color:rgba(245,158,11,.15)}.maint-banner{display:flex;align-items:center;gap:.5rem;padding:.6rem 1rem;margin-bottom:.75rem;font-size:.8rem;font-weight:500;color:var(--warning,#f59e0b);background:rgba(245,158,11,.06);border:1px solid rgba(245,158,11,.15);border-radius:var(--radius-sm)}.maint-banner svg{flex-shrink:0;opacity:.8}.set-alert{font-size:.8rem;padding:.6rem 1rem;border-radius:var(--radius-sm);margin-bottom:.75rem;display:none}.set-alert.success{display:block;background:rgba(16,185,129,.1);color:#10b981;border:1px solid rgba(16,185,129,.2)}.set-alert.error{display:block;background:rgba(239,68,68,.1);color:#ef4444;border:1px solid rgba(239,68,68,.2)}.deploy-actions{flex-wrap:wrap}.btn-ghost-alt{background:rgba(255,255,255,.06);color:var(--text-muted)}.btn-ghost-alt:hover{background:rgba(255,255,255,.1);color:var(--text)}.deploy-result{font-size:.8rem;margin-top:.5rem;min-height:1.2em;display:flex;align-items:center;gap:.4rem}.deploy-ok{color:#10b981}.deploy-error{color:#ef4444}.deploy-polling{color:var(--primary-light)}.deploy-check-icon{font-weight:700}.deploy-spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.1);border-top-color:var(--primary-light);border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}.btn-primary{background:var(--primary);color:#fff;border:none;border-radius:6px;padding:.6rem 1.25rem;font-family:inherit;font-weight:600;font-size:.9rem;cursor:pointer;transition:background .2s}.btn-primary:hover{background:var(--primary-light)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-sm{padding:.35rem .8rem;font-size:.8rem;border-radius:6px;font-family:inherit;font-weight:500;cursor:pointer;border:none;transition:all .2s}.btn-outline{background:0 0;color:var(--text-muted);border:1px solid var(--glass-border)}.btn-outline:hover{border-color:var(--primary);color:var(--primary-light)}.btn-danger-outline{background:0 0;color:var(--danger);border:1px solid rgba(239,68,68,.3)}.btn-danger-outline:hover{background:rgba(239,68,68,.1);border-color:var(--danger)}.sec-field{display:flex;flex-direction:column;gap:.3rem}.sec-field label{font-size:.75rem;color:var(--text-muted);font-weight:500}.sec-field input{background:rgba(255,255,255,.05);border:1px solid var(--glass-border);border-radius:6px;padding:.55rem .75rem;color:var(--text);font-size:.85rem;outline:0;transition:border-color .2s}.sec-field input:focus{border-color:var(--primary)}.sec-help{font-size:.75rem;color:var(--text-muted);margin:0}.totp-status{display:flex;align-items:center;gap:.5rem;font-size:.85rem;font-weight:500}.totp-on{color:var(--primary-light)}.totp-off{color:var(--text-muted)}.totp-actions{display:flex;gap:.5rem;margin-top:.5rem}.totp-setup{display:flex;flex-direction:column;gap:.75rem}.totp-qr{display:flex;justify-content:center;padding:1rem;background:rgba(0,0,0,.2);border-radius:8px}.totp-secret-display{text-align:center;font-size:.8rem;letter-spacing:2px;color:var(--text-muted)}.totp-secret-display code{background:var(--bg-hover);padding:.4rem .8rem;border-radius:6px;font-family:var(--font-mono)}.backup-codes-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem}.backup-codes-grid code{text-align:center;background:var(--bg-hover);padding:.5rem;border-radius:6px;font-size:.8rem;font-family:var(--font-mono);letter-spacing:1px;color:var(--text)}.totp-backup-codes{display:flex;flex-direction:column;gap:.75rem}.dash-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .2s ease}.dash-modal{background:var(--surface);border:1px solid var(--glass-border);border-radius:12px;width:min(420px,90vw);display:flex;flex-direction:column;gap:1rem;animation:modalPop .25s ease}.dash-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem 0}.dash-modal-header h3{font-size:.95rem;font-weight:600;margin:0}.dash-modal-close{background:0 0;border:none;color:var(--text-muted);font-size:1.25rem;cursor:pointer;padding:0;line-height:1}.dash-modal-close:hover{color:var(--text)}.dash-modal-close:focus-visible{color:var(--text);outline:2px solid var(--primary);outline-offset:2px}.dash-modal .sec-field{padding:0 1.25rem}.dash-modal .modal-alert{margin:0 1.25rem}.dash-modal-footer{display:flex;justify-content:flex-end;gap:.5rem;padding:0 1.25rem 1rem}@keyframes modalPop{from{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.btn-xs{font-size:.65rem;padding:.2rem .5rem;border-radius:4px;cursor:pointer;border:1px solid var(--glass-border);background:0 0;color:var(--text-muted);transition:all var(--transition)}.btn-xs:hover{color:var(--text);border-color:var(--text-muted)}.btn-xs:focus-visible{color:var(--text);border-color:var(--primary)}.btn-xs.btn-danger-outline{border-color:rgba(239,68,68,.3);color:var(--danger)}.btn-xs.btn-danger-outline:hover{border-color:var(--danger);background:rgba(239,68,68,.1)}.token-list{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem}.token-toolbar{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.token-search{flex:1;max-width:250px;background:rgba(255,255,255,.04);border:1px solid var(--glass-border);border-radius:6px;color:var(--text);font-size:.8rem;font-family:inherit;padding:.4rem .6rem;outline:0;transition:border-color var(--transition)}.token-search:focus{border-color:var(--primary)}.token-table{background:rgba(255,255,255,.02);border:1px solid var(--glass-border);border-radius:var(--radius);overflow:hidden}.token-thead{display:grid;grid-template-columns:minmax(100px,1.2fr) minmax(80px,1fr) minmax(80px,1fr) minmax(100px,1fr) 50px 32px;gap:.5rem;padding:.4rem .75rem;font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);opacity:.6;border-bottom:1px solid var(--glass-border)}.token-trow{display:grid;grid-template-columns:minmax(100px,1.2fr) minmax(80px,1fr) minmax(80px,1fr) minmax(100px,1fr) 50px 32px;gap:.5rem;align-items:center;padding:.45rem .75rem;font-size:.8rem;border-bottom:1px solid rgba(255,255,255,.03);transition:background var(--transition)}.token-trow:last-child{border-bottom:none}.token-trow:hover{background:rgba(255,255,255,.02)}.token-row-disabled{opacity:.45}.token-name{font-weight:600;color:var(--text);cursor:pointer;border-bottom:1px dashed transparent;transition:border-color var(--transition);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.token-name:hover{border-bottom-color:var(--primary-light)}.token-name-input{background:rgba(255,255,255,.05);border:1px solid var(--primary);border-radius:4px;color:var(--text);font-size:.8rem;font-weight:600;font-family:inherit;padding:.15rem .4rem;outline:0;width:100%}.toggle-sm{transform:scale(.75);transform-origin:center}.token-scope{font-size:.7rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.token-scope-cb:has(input:checked){border-color:var(--primary);background:rgba(83,140,190,.1)}.token-scope-cb input{accent-color:var(--primary);margin:0}.token-ips{font-size:.7rem;color:var(--text-muted);font-variant-numeric:tabular-nums;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.token-last{font-size:.7rem;color:var(--text-muted);font-variant-numeric:tabular-nums;white-space:nowrap;display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.token-ip-badge{font-size:.6rem;font-weight:500;color:var(--primary-light);background:rgba(83,140,190,.1);padding:.1rem .35rem;border-radius:4px;font-variant-numeric:tabular-nums}.token-toggle-cell{display:flex;justify-content:center}.token-del-cell{display:flex;justify-content:center}.token-del-cell .wl-del-btn{opacity:0}.token-trow:hover .token-del-cell .wl-del-btn{opacity:1}@media(max-width:768px){.token-thead,.token-trow{grid-template-columns:1fr 0.8fr 50px 32px}.token-ips,.token-last{display:none}}.token-display{display:flex;align-items:center;gap:.5rem;margin-top:.5rem;padding:.5rem .75rem;background:var(--bg);border:1px solid var(--glass-border);border-radius:6px}.token-display code{font-size:.7rem;color:var(--primary-light);word-break:break-all;flex:1}.modal-textarea{width:100%;font-size:.8rem;padding:.5rem .7rem;background:var(--surface);border:1px solid var(--glass-border);border-radius:6px;color:var(--text);resize:vertical;font-family:inherit}.modal-textarea:focus{border-color:var(--primary);outline:0}@media(max-width:1100px){.dash-metrics{grid-template-columns:repeat(3,1fr)}.dash-metrics .dash-metric:nth-child(4),.dash-metrics .dash-metric:nth-child(5){grid-column:auto}}.dash-view{animation:tabFade .3s ease}@media(max-width:768px){.sidebar{display:none}.topbar-mobile{display:flex}.mobile-nav{display:flex}.dash-main{padding:1rem 1rem calc(72px + env(safe-area-inset-bottom,0px));max-width:none}.dash-toolbar{flex-direction:column;align-items:flex-start}.dash-toolbar-right{width:100%;justify-content:space-between}.dash-metrics{grid-template-columns:repeat(2,1fr)}.dash-metric:last-child{grid-column:span 2}.dash-main-row{flex-direction:column;gap:1rem}.dash-main-row .dash-chart-panel{border-radius:var(--radius);border-right:1px solid var(--glass-border)}.dash-main-row .dash-attacks{flex:none;max-height:300px;border-radius:var(--radius);border-left:none}.dash-attacks-subnet{min-width:0}.dash-chart-body canvas{height:200px}.atk-head{display:none}.atk-row{display:flex;flex-direction:column;gap:.35rem;padding:.75rem;margin:0 .25rem .5rem;font-size:.75rem;border:1px solid rgba(255,255,255,.06);border-radius:10px;background:rgba(255,255,255,.02)}.atk-row.atk-ongoing{border-left:3px solid var(--danger);background:rgba(239,68,68,.03)}.atk-row-top{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.atk-row .atk-subnet{font-size:.85rem}.atk-row .atk-type{font-size:.6rem}.atk-row .atk-peak{font-size:.7rem;margin-left:auto}.atk-row-mid{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;color:var(--text-muted);font-size:.65rem}.atk-row .atk-time{font-size:.65rem}.atk-row .atk-duration{font-size:.65rem;font-weight:600;color:var(--text)}.atk-row .atk-status-on{font-size:.6rem}.atk-row .atk-detector{font-size:.55rem}.atk-row .atk-nodes{width:100%}.atk-node-badge{font-size:.6rem;padding:1px 4px}.metrics-cards{grid-template-columns:repeat(2,1fr)}.backup-codes-grid{grid-template-columns:repeat(2,1fr)}.settings-grid{grid-template-columns:1fr}.act-head,.act-row{grid-template-columns:1fr 1fr;gap:.35rem;font-size:.7rem}.act-head>:nth-child(n+3),.act-row>:nth-child(n+3){display:none}}@media(max-width:480px){.dash-chart-body canvas{height:170px}.dash-metric-val{font-size:1rem}.login-card{margin:0 8px;padding:32px 24px}.login-screen{padding:.75rem;align-items:flex-start;padding-top:8vh}.code-inputs input{width:40px;height:48px;font-size:20px}}.modal-card-specs{max-width:960px;width:95%}.modal-card-specs .modal-body{padding-top:.25rem}.modal-card-specs #specsTitle{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}.specs-title-name{font-weight:700}.specs-title-badge{font-size:.62rem!important;padding:2px 8px!important;letter-spacing:.5px;vertical-align:middle}.specs-empty,.specs-loading{display:flex;flex-direction:column;align-items:center;gap:.6rem;padding:40px 20px;color:var(--text-muted);font-size:.85rem;text-align:center}.specs-empty svg{opacity:.4}.specs-hero{display:flex;align-items:center;gap:.85rem;padding:.5rem 0 1rem;border-bottom:1px solid var(--glass-border);margin-bottom:1rem}.specs-hero-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(83,140,190,.15),rgba(83,140,190,.05));border:1px solid rgba(83,140,190,.25);border-radius:10px;color:var(--primary-light);flex-shrink:0}.specs-hero-main{flex:1;min-width:0}.specs-hero-title{font-size:1rem;font-weight:700;color:var(--text);line-height:1.2}.specs-hero-chips{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.4rem}.specs-chip{display:inline-flex;align-items:center;font-size:.62rem;font-weight:600;letter-spacing:.3px;padding:2px 8px;border-radius:999px;background:rgba(255,255,255,.04);color:var(--text-muted);border:1px solid rgba(255,255,255,.06);white-space:nowrap}.specs-chip-bios{background:rgba(83,140,190,.12);color:var(--primary-light);border-color:rgba(83,140,190,.25);font-family:var(--font-mono)}.specs-chip-muted{opacity:.75}.specs-chip-drv{background:rgba(99,102,241,.14);color:#a5b4fc;border-color:rgba(99,102,241,.25);font-family:var(--font-mono);text-transform:uppercase}.specs-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:.55rem;margin-bottom:1.2rem}@media(max-width:900px){.specs-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}}.specs-card{background:linear-gradient(180deg,rgba(255,255,255,.015),rgba(255,255,255,0));border:1px solid var(--glass-border);border-radius:10px;padding:.75rem .9rem;transition:border-color .2s}.specs-card:hover{border-color:rgba(83,140,190,.25)}.specs-card-head{display:flex;align-items:center;gap:.4rem;margin-bottom:.55rem}.specs-card-ico{color:var(--primary-light);opacity:.7;flex-shrink:0}.specs-card-title{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.9px;color:var(--text-muted)}.specs-card-main{font-size:.9rem;font-weight:700;color:var(--text);line-height:1.25;letter-spacing:.1px}.specs-card-sub{font-size:.7rem;color:var(--text-muted);margin-top:.4rem;line-height:1.55}.specs-card-sub strong{color:var(--text);font-weight:600}.specs-card-dim{opacity:.65;margin-top:2px;font-size:.65rem}.specs-section-title{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.9px;color:var(--text-muted);margin:.25rem 0 .6rem;opacity:.75}.specs-nics{display:flex;flex-direction:column;gap:.6rem}.specs-nic-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:10px;padding:.75rem .9rem}.specs-nic-head{display:flex;align-items:center;gap:.55rem;flex-wrap:wrap;margin-bottom:.6rem;padding-bottom:.6rem;border-bottom:1px solid rgba(255,255,255,.04)}.specs-nic-ico{color:var(--primary-light);opacity:.7;flex-shrink:0}.specs-nic-title{font-size:.82rem;font-weight:700;color:var(--text);flex:1;min-width:160px}.specs-nic-chips{display:flex;gap:.35rem;flex-wrap:wrap}.specs-nic-ports{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:.5rem}.specs-port{background:rgba(255,255,255,.015);border:1px solid rgba(255,255,255,.04);border-radius:8px;padding:.55rem .7rem;display:flex;flex-direction:column;gap:.4rem}.specs-port-head{display:flex;align-items:center;gap:.4rem}.specs-port-iface-code{background:rgba(83,140,190,.1);color:var(--primary-light);padding:2px 7px;border-radius:4px;font-size:.72rem;font-weight:600;font-family:var(--font-mono)}.specs-chip-xdp{background:rgba(34,197,94,.14);color:#86efac;border-color:rgba(34,197,94,.28);font-weight:700;letter-spacing:.5px}.specs-chip-warn{background:rgba(234,179,8,.14);color:#fde047;border-color:rgba(234,179,8,.3);font-weight:600}.specs-port-metrics{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.specs-port-metric{display:flex;flex-direction:column;gap:2px;min-width:0}.specs-port-label{font-size:.55rem;font-weight:600;text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);opacity:.7}.specs-port-val{font-size:.75rem;font-weight:600;color:var(--text);font-family:var(--font-mono)}.specs-port-q strong{color:var(--primary-light)}.specs-port-qmax{color:var(--text-muted);opacity:.6;font-weight:400}.specs-port-bar{height:3px;background:rgba(255,255,255,.04);border-radius:2px;overflow:hidden;margin-top:.1rem}.specs-port-bar-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--primary-light));border-radius:2px;transition:width .3s}.specs-badge{display:inline-flex;align-items:center;padding:2px 8px;font-size:.62rem;font-weight:700;letter-spacing:.3px;border-radius:6px;white-space:nowrap;text-transform:uppercase}.specs-pcie-big{font-size:.85rem!important;padding:4px 12px!important;letter-spacing:.5px!important}.specs-badge-muted{background:rgba(255,255,255,.04);color:var(--text-muted)}.specs-pcie-degraded{background:rgba(234,179,8,.14)!important;color:#fde047!important;border-color:rgba(234,179,8,.3)!important}.specs-pcie-degraded::after{content:' ⚠';opacity:.8}.specs-numa{background:rgba(99,102,241,.1);color:#a5b4fc;border:1px solid rgba(99,102,241,.22)}.modal-card-metrics{max-width:580px;width:95%}.modal-card-metrics .modal-header{border-bottom:1px solid var(--glass-border);padding-bottom:.85rem}.modal-card-metrics .modal-body{padding-bottom:.5rem;gap:.5rem}.modal-card-metrics .modal-body .metrics-chart-wrap{margin-bottom:0}.metrics-ranges{display:flex;gap:.3rem;margin-bottom:1rem}.metrics-range{background:var(--glass);border:1px solid var(--glass-border);border-radius:6px;color:var(--text-muted);padding:.3rem .75rem;font-size:.72rem;font-weight:500;cursor:pointer;transition:all .2s}.metrics-range:hover{color:var(--text);background:var(--bg-hover)}.metrics-range:focus-visible{color:var(--text);background:var(--bg-hover);border-color:var(--primary)}.metrics-range.active{background:var(--primary);color:#fff;border-color:var(--primary)}.metrics-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;margin-bottom:1rem}.metric-card{padding:.75rem .85rem;display:flex;flex-direction:column;gap:.2rem;background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:var(--card-shadow)}.metric-card-label{font-size:.7rem;font-weight:500;color:var(--text-muted);opacity:.8}.metric-card-val{font-size:1.3rem;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:-.5px;line-height:1.2;color:var(--text)}.metric-card-uptime{color:var(--primary-light)}.metrics-chart-wrap{position:relative;margin-bottom:.75rem;background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius);overflow:hidden;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:var(--card-shadow)}.metrics-chart-wrap canvas{width:100%;height:200px;cursor:crosshair}.metrics-checks{font-size:.75rem;color:var(--text-muted);text-align:center;padding-top:.25rem}.metrics-tooltip{position:fixed;display:none;background:var(--surface);border:1px solid var(--glass-border);border-radius:8px;padding:.4rem .65rem;font-size:.75rem;pointer-events:none;z-index:1001;box-shadow:0 4px 12px rgba(0,0,0,.4)}.dash-attacks-row{cursor:pointer;transition:background var(--transition)}.dash-attacks-row:not(.dash-attacks-row-head):hover{background:rgba(255,255,255,.03)}.sh-header-left{display:flex;align-items:center;gap:.5rem;min-width:0}.sh-header-left h3{margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sh-label{font-size:.65rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.sh-copy{background:0 0;border:1px solid var(--glass-border);color:var(--text-muted);cursor:pointer;padding:.25rem;border-radius:4px;display:flex;align-items:center;transition:all var(--transition)}.sh-copy:hover{color:var(--text);border-color:var(--text-muted)}.sh-copy:focus-visible{color:var(--text);border-color:var(--primary);outline:0}.sh-copy.copied{color:var(--success);border-color:var(--success)}.sh-header-right{display:flex;align-items:center;gap:.6rem}.sh-status{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:.2rem .5rem;border-radius:20px;white-space:nowrap}.sh-status-attack{background:rgba(239,68,68,.15);color:#ef4444;animation:attackPulse 2s ease-in-out infinite}.sh-status-normal{background:rgba(16,185,129,.15);color:#10b981}.sh-toolbar{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.75rem}.sh-toolbar .metrics-ranges{margin-bottom:0}.sh-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;margin-bottom:.75rem}.sh-vectors{display:flex;flex-wrap:wrap;gap:.3rem;align-items:center}.sh-vectors:empty{display:none}.sh-vectors .dash-attacks-tag{font-size:.65rem}.sh-vectors-label{font-size:.65rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.modal-card-metrics{transform:translateY(12px);opacity:0;transition:transform .2s ease,opacity .2s ease}.modal-overlay.open .modal-card-metrics{transform:translateY(0);opacity:1}.sh-ul-header{display:flex;align-items:center;gap:.5rem;margin:.25rem 0 .5rem;padding-top:.5rem;border-top:1px solid var(--glass-border)}.sh-ul-title{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.sh-tooltip{position:fixed;display:none;background:var(--surface);border:1px solid var(--glass-border);border-radius:8px;padding:.5rem .75rem;font-size:.75rem;pointer-events:none;z-index:10000;box-shadow:0 4px 12px rgba(0,0,0,.4)}.sh-loading{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.3);border-radius:var(--radius);z-index:1}.sh-spinner{width:24px;height:24px;border:2px solid rgba(255,255,255,.1);border-top-color:var(--primary);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes blobMove1{0%,100%{transform:translate(0,0)}33%{transform:translate(80px,40px)}66%{transform:translate(40px,80px)}}@keyframes blobMove2{0%,100%{transform:translate(0,0)}33%{transform:translate(-40px,-80px)}66%{transform:translate(-80px,-40px)}}@keyframes blobMove3{0%,100%{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.3)}}@keyframes cardAppear{from{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes tabFade{from{opacity:0}to{opacity:1}}@keyframes codeShake{0%,100%{transform:translateX(0)}25%{transform:translateX(-4px)}75%{transform:translateX(4px)}}@keyframes livePulse{0%,100%{opacity:1}50%{opacity:.3}}@keyframes dropdownRight{from{opacity:0;transform:translateX(-6px)}to{opacity:1;transform:translateX(0)}}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes attackPulse{0%,100%{opacity:1}50%{opacity:.7}}.cfg-tabs{display:flex;gap:.25rem;margin-left:1rem}.cfg-tab{background:0 0;border:1px solid var(--glass-border);border-radius:6px;color:var(--text-muted);font-size:.72rem;font-weight:500;font-family:inherit;padding:.3rem .75rem;cursor:pointer;transition:all var(--transition)}.cfg-tab:hover{border-color:rgba(255,255,255,.15);color:var(--text)}.cfg-tab:focus-visible{border-color:var(--primary);color:var(--text)}.cfg-tab.active{background:var(--primary);border-color:var(--primary);color:#fff}.cfg-maint-desc{font-size:.75rem;color:var(--text-muted);margin-bottom:.75rem;line-height:1.5}.cfg-maint-actions{display:flex;gap:.5rem;flex-wrap:wrap}.cfg-maint-btn{display:inline-flex;align-items:center;gap:.4rem;background:var(--glass);border:1px solid var(--glass-border);border-radius:8px;color:var(--text);font-size:.75rem;font-weight:500;font-family:inherit;padding:.5rem 1rem;cursor:pointer;transition:all var(--transition)}.cfg-maint-btn:hover{border-color:rgba(255,255,255,.15);background:rgba(255,255,255,.05)}.cfg-maint-btn:focus-visible{border-color:var(--primary);background:rgba(255,255,255,.05)}.cfg-maint-btn svg{opacity:.6}.cfg-maint-danger{color:var(--danger);border-color:rgba(239,68,68,.2)}.cfg-maint-danger:hover{background:rgba(239,68,68,.08);border-color:rgba(239,68,68,.3)}.cfg-maint-btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.cfg-maint-btn-busy{position:relative;color:transparent!important;pointer-events:none}.cfg-maint-btn-busy::after{content:'';position:absolute;top:50%;left:50%;width:14px;height:14px;margin:-7px 0 0 -7px;border:2px solid var(--text-muted);border-top-color:transparent;border-radius:50%;animation:cfgSpin .7s linear infinite}@keyframes cfgSpin{to{transform:rotate(360deg)}}.cfg-maint-count{margin-left:auto;font-size:.7rem;font-weight:700;color:var(--text);background:rgba(83,140,190,.15);padding:2px 8px;border-radius:10px;letter-spacing:.3px;font-family:var(--font-mono)}.cfg-maint-count.cfg-maint-count-empty{color:var(--text-muted);background:rgba(255,255,255,.04);opacity:.6}.cfg-maint-stats{font-size:.68rem;color:var(--text-muted);margin:0 0 .75rem;display:flex;flex-wrap:wrap;gap:.35rem;line-height:1.5;font-family:var(--font-mono)}.cfg-maint-stats strong{color:var(--text);font-weight:600}.cfg-maint-stat-on{color:var(--danger)!important;font-weight:700!important}.cfg-maint-empty-hint{opacity:.5;font-style:italic}.cfg-maint-last{font-size:.62rem;color:var(--text-muted);opacity:.6;margin-top:.65rem;letter-spacing:.2px}.cfg-maint-label{display:inline}.cfg-content{display:flex;flex-direction:column;gap:1rem}.cfg-group{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius);padding:1.25rem}.cfg-group-title{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.cfg-group-title svg{opacity:.5}.cfg-val-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.5rem}.cfg-val-card{background:var(--bg-subtle);border:1px solid transparent;border-radius:var(--radius-sm);padding:.65rem .75rem;transition:border-color var(--transition);position:relative}.cfg-val-card:hover{border-color:var(--glass-border)}.cfg-val-left{min-width:0}.cfg-val-label{font-size:.7rem;color:var(--text-muted);margin-bottom:.35rem;line-height:1.2}.cfg-info{display:flex;align-items:center;cursor:help;color:var(--primary-light);opacity:.7;position:absolute;top:.5rem;right:.5rem;transition:opacity var(--transition)}.cfg-info:hover{opacity:1}.cfg-tooltip{position:fixed;display:none;max-width:320px;padding:.5rem .75rem;background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--radius);color:var(--text-muted);font-size:.72rem;line-height:1.4;z-index:9999;pointer-events:none;box-shadow:0 4px 16px rgba(0,0,0,.4)}.debug-panel{position:fixed;bottom:12px;right:12px;width:min(860px,calc(100vw - 24px));max-height:70vh;background:var(--surface);border:1px solid rgba(83,140,190,.35);border-radius:10px;box-shadow:0 8px 40px rgba(0,0,0,.6);z-index:10000;display:flex;flex-direction:column;overflow:hidden;font-size:.72rem}.debug-panel-header{display:flex;align-items:center;justify-content:space-between;padding:.55rem .75rem;background:rgba(83,140,190,.08);border-bottom:1px solid rgba(255,255,255,.06)}.debug-panel-header strong{color:var(--primary-light);font-size:.78rem}.debug-panel-actions{display:flex;gap:.4rem;align-items:center}.debug-panel-actions .debug-clear{background:0 0;border:1px solid rgba(255,255,255,.1);color:var(--text-muted);padding:.25rem .5rem;border-radius:4px;font-size:.65rem;cursor:pointer}.debug-panel-actions .debug-clear:hover{border-color:rgba(239,68,68,.4);color:#ef4444}.debug-panel-actions .debug-close{background:0 0;border:none;color:var(--text-muted);font-size:1.2rem;cursor:pointer;line-height:1;padding:0 .3rem}.debug-panel-actions .debug-close:hover{color:var(--danger)}.debug-panel-meta{display:flex;gap:1rem;flex-wrap:wrap;padding:.55rem .75rem;background:rgba(255,255,255,.015);border-bottom:1px solid rgba(255,255,255,.04);font-size:.66rem;color:var(--text-muted);font-family:var(--font-mono)}.debug-panel-meta span b{color:var(--text);font-weight:600}.debug-panel-body{padding:.55rem .75rem;overflow-y:auto;flex:1}.dbg-empty{color:var(--text-muted);font-style:italic;padding:1rem;text-align:center}.dbg-table{width:100%;border-collapse:collapse;margin-bottom:.75rem;font-variant-numeric:tabular-nums}.dbg-table th{text-align:left;font-size:.58rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);padding:.35rem .4rem;border-bottom:1px solid rgba(255,255,255,.06)}.dbg-table td{padding:.3rem .4rem;font-size:.66rem;border-bottom:1px solid rgba(255,255,255,.02);font-family:var(--font-mono)}.dbg-table tr:hover td{background:rgba(83,140,190,.04)}.dbg-url{color:var(--text);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dbg-count,.dbg-time{color:var(--text-muted)}.dbg-dur-ok{color:#10b981}.dbg-dur-warn{color:#f59e0b}.dbg-dur-slow{color:#f97316}.dbg-dur-err{color:#ef4444}.dbg-dur-na{color:var(--text-muted);opacity:.4}.dbg-ok{color:#10b981}.dbg-err{color:#ef4444}.dbg-recent-label{font-size:.58rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin:.75rem 0 .35rem}.cfg-val-row{display:flex;align-items:center;gap:.35rem}.cfg-val-num{font-size:1rem;font-weight:600;font-variant-numeric:tabular-nums;color:var(--text);line-height:1.2}.cfg-val-num .cfg-unit{font-size:.7rem;font-weight:400;color:var(--text-muted);margin-left:.15rem}.cfg-val-edit{background:0 0;border:none;color:var(--text-muted);cursor:pointer;padding:2px;opacity:0;transition:opacity var(--transition);flex-shrink:0}.cfg-val-card:hover .cfg-val-edit{opacity:.6}.cfg-val-edit:hover{opacity:1!important;color:var(--primary-light)}.cfg-val-edit:focus-visible{opacity:1;color:var(--primary-light)}.cfg-val-input{width:100%;font-size:1rem;font-weight:600;padding:0;background:0 0;border:none;border-bottom:1px solid var(--primary);color:var(--text);outline:0;font-family:inherit;font-variant-numeric:tabular-nums}.cfg-val-default .cfg-val-num{opacity:.5}.cfg-default-tag{font-size:.55rem;font-weight:500;color:var(--text-muted);opacity:.6;text-transform:uppercase;letter-spacing:.3px;vertical-align:middle;margin-left:.25rem}.cfg-flag-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:0}.cfg-flag-item{padding:.45rem .5rem;border-bottom:1px solid rgba(255,255,255,.03);position:relative;padding-right:2rem}.cfg-flag-item>.cfg-info{top:50%;right:.5rem;transform:translateY(-50%)}.cfg-flag-item:last-child{border-bottom:none}.cfg-flag-label{display:flex;align-items:center;gap:.6rem;cursor:pointer;user-select:none}.cfg-flag-cb{position:absolute;opacity:0;width:0;height:0}.cfg-flag-switch{position:relative;width:32px;height:18px;background:rgba(255,255,255,.08);border-radius:9px;transition:background .2s;flex-shrink:0}.cfg-flag-switch::before{content:'';position:absolute;width:14px;height:14px;left:2px;top:2px;background:rgba(255,255,255,.4);border-radius:50%;transition:transform .2s,background .2s}.cfg-flag-cb:checked+.cfg-flag-switch{background:var(--primary)}.cfg-flag-cb:checked+.cfg-flag-switch::before{transform:translateX(14px);background:#fff}.cfg-flag-text{font-size:.78rem;color:var(--text);line-height:1.2}.cfg-flag-cb:not(:checked)~.cfg-flag-text{color:var(--text-muted)}.cfg-alert{font-size:.8rem;padding:.5rem .75rem;border-radius:var(--radius-sm);margin-bottom:.5rem;display:none}.cfg-alert.success{display:block;background:rgba(16,185,129,.12);color:var(--success);border:1px solid rgba(16,185,129,.2)}.cfg-alert.error{display:block;background:rgba(239,68,68,.12);color:var(--danger);border:1px solid rgba(239,68,68,.2)}.cfg-banner{font-size:.78rem;padding:.55rem .75rem;border-radius:var(--radius-sm);margin-bottom:.65rem;display:block;font-weight:500}.cfg-banner-warn{background:rgba(245,158,11,.1);color:#f59e0b;border:1px solid rgba(245,158,11,.25)}.cfg-banner-drift{background:rgba(239,68,68,.08);color:#ef4444;border:1px solid rgba(239,68,68,.2)}.nhmac-card{background:linear-gradient(135deg,rgba(83,140,190,.06),rgba(83,140,190,.02));border:1px solid rgba(83,140,190,.25);border-radius:10px;padding:.85rem 1rem;margin:0 0 1rem;display:flex;flex-direction:column;gap:.65rem}.nhmac-head{display:flex;align-items:center;justify-content:space-between;gap:.5rem;flex-wrap:wrap}.nhmac-titlewrap{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.nhmac-icon{color:var(--primary-light);flex-shrink:0}.nhmac-title{font-weight:600;color:var(--text);font-size:.82rem;letter-spacing:.2px}.nhmac-scope{font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:.1rem .4rem;background:rgba(83,140,190,.12);color:var(--primary-light);border:1px solid rgba(83,140,190,.2);border-radius:3px}.nhmac-status{font-size:.7rem;font-weight:500;font-family:var(--font-mono)}.nhmac-status-on{color:var(--success)}.nhmac-status-off{color:var(--text-muted)}.nhmac-status-mixed{color:#fbbf24}.nhmac-status-err{color:var(--danger)}.nhmac-desc{font-size:.7rem;color:var(--text-muted);line-height:1.45}.nhmac-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.nhmac-input{flex:0 0 200px;background:var(--surface);border:1px solid var(--glass-border);color:var(--text);padding:.5rem .7rem;border-radius:6px;font-size:.78rem;font-family:var(--font-mono);letter-spacing:.5px}.nhmac-input:focus{outline:0;border-color:var(--primary);box-shadow:0 0 0 2px rgba(83,140,190,.15)}.nhmac-toggle{position:relative;display:inline-block;width:42px;height:22px;flex-shrink:0}.nhmac-toggle input{opacity:0;width:0;height:0}.nhmac-toggle-slider{position:absolute;cursor:pointer;inset:0;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);border-radius:22px;transition:all .2s}.nhmac-toggle-slider::before{content:'';position:absolute;width:16px;height:16px;left:2px;top:2px;background:#fff;border-radius:50%;transition:transform .2s}.nhmac-toggle input:checked+.nhmac-toggle-slider{background:var(--success);border-color:rgba(16,185,129,.4)}.nhmac-toggle input:checked+.nhmac-toggle-slider::before{transform:translateX(20px)}.nhmac-toggle-label{font-size:.65rem;font-weight:700;letter-spacing:.6px;color:var(--text-muted);min-width:30px}.nhmac-toggle-label.on{color:var(--success)}.nhmac-toggle-label.off{color:var(--text-muted)}.nhmac-nodes{display:flex;flex-wrap:wrap;gap:.3rem;margin-top:.1rem}.nhmac-node{font-size:.6rem;font-weight:600;padding:.15rem .45rem;border-radius:4px;font-family:var(--font-mono);letter-spacing:.3px;cursor:help;border:1px solid transparent}.nhmac-node-on{background:rgba(16,185,129,.12);color:var(--success);border-color:rgba(16,185,129,.3)}.nhmac-node-off{background:rgba(255,255,255,.04);color:var(--text-muted);border-color:rgba(255,255,255,.08)}.nhmac-node-unreachable{background:rgba(239,68,68,.08);color:var(--danger);border-color:rgba(239,68,68,.2);text-decoration:line-through;opacity:.7}.cfg-drift-tag{display:inline-block;margin-left:.35rem;padding:.05rem .35rem;font-size:.55rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;background:rgba(239,68,68,.15);color:#ef4444;border:1px solid rgba(239,68,68,.3);border-radius:3px;vertical-align:middle;cursor:help}.cfg-val-drift{border-color:rgba(239,68,68,.35)!important;background:rgba(239,68,68,.03)}.cfg-flag-drift{background:rgba(239,68,68,.03)}@media(max-width:768px){.cfg-val-grid{grid-template-columns:repeat(2,1fr)}.cfg-flag-grid{grid-template-columns:1fr}}.cfg-tcp-est{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:.75rem 1rem;background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius-sm)}.cfg-tcp-est-left{display:flex;flex-direction:column;gap:.5rem;min-width:0;flex:1}.cfg-tcp-est-row{display:flex;align-items:center;gap:.75rem}.cfg-tcp-est-label{font-size:.8rem;color:var(--text-muted)}.cfg-tcp-est-val{font-size:1.35rem;font-weight:700;font-variant-numeric:tabular-nums;color:var(--primary-light);letter-spacing:-.02em}.cfg-tcp-est-nodes{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.35rem}.cfg-tcp-est-node{font-size:.7rem;color:var(--text-muted);font-variant-numeric:tabular-nums;display:flex;align-items:center;gap:.4rem;padding:.3rem .5rem;background:rgba(255,255,255,.02);border:1px solid var(--glass-border);border-radius:4px}.cfg-tcp-est-node::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--success);flex-shrink:0}.cfg-tcp-est-node strong{color:var(--text);font-weight:600;margin-left:auto}.cfg-tcp-est-node.node-offline::before{background:var(--danger)}.cfg-tcp-est-node.node-offline{opacity:.5}.metric-partial{color:var(--warning,#f59e0b)!important}.metric-maint{color:#fbbf24!important}.metric-stale{opacity:.75}.stat-maint-hint{position:absolute;bottom:.4rem;right:.75rem;font-size:.58rem;color:#fbbf24;font-weight:600;letter-spacing:.02em;opacity:.85;white-space:nowrap;pointer-events:none}.dash-chart-maint{display:inline-flex;align-items:center;gap:.4rem;font-size:.62rem;font-weight:700;color:#fbbf24;background:rgba(245,158,11,.08);border:1px solid rgba(245,158,11,.28);padding:.3rem .6rem;border-radius:999px;text-transform:uppercase;letter-spacing:.04em;margin-left:.6rem;white-space:nowrap;animation:chartMaintPulse 2.5s ease-in-out infinite}.dash-chart-maint svg{opacity:.9;flex-shrink:0}@keyframes chartMaintPulse{0%,100%{opacity:1}50%{opacity:.7}}.btn-maint-icon{position:relative;width:34px;height:34px;border-radius:8px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.02);color:var(--text-muted);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0;font-family:inherit}.btn-maint-icon:hover{border-color:rgba(245,158,11,.35);color:#fbbf24;background:rgba(245,158,11,.05)}.btn-maint-icon-active{border-color:rgba(245,158,11,.5);background:rgba(245,158,11,.08);color:#fbbf24;box-shadow:0 0 0 2px rgba(245,158,11,.08)}.btn-maint-icon-active svg{animation:btnMaintPulse 2.5s ease-in-out infinite}@keyframes btnMaintPulse{0%,100%{opacity:1}50%{opacity:.55}}.btn-maint-dot{position:absolute;top:-4px;right:-4px;min-width:16px;height:16px;padding:0 4px;border-radius:999px;background:#f59e0b;color:#030712;font-size:.6rem;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1;border:2px solid var(--surface,#0a0f1a)}.node-card-maint{border-color:rgba(245,158,11,.28)!important;background:linear-gradient(135deg,rgba(245,158,11,.04),rgba(245,158,11,.008))!important;box-shadow:inset 0 2px 0 rgba(245,158,11,.55),var(--card-shadow)!important}.node-card-maint-badge{display:inline-flex;align-items:center;gap:.25rem;font-size:.54rem;font-weight:700;color:#fbbf24;background:rgba(245,158,11,.12);border:1px solid rgba(245,158,11,.3);padding:.18rem .4rem;border-radius:4px;text-transform:uppercase;letter-spacing:.04em;line-height:1;white-space:nowrap;animation:chartMaintPulse 2.5s ease-in-out infinite}.node-card-maint-badge svg{flex-shrink:0;opacity:.9}.cfg-tcp-est-actions{display:flex;gap:.4rem;flex-shrink:0}.cfg-tcp-est-chart-wrap{margin-top:.75rem;background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius-sm);padding:.5rem .5rem .25rem}.cfg-tcp-est-chart-toolbar{display:flex;gap:.25rem;margin-bottom:.5rem}.cfg-tcp-est-range{background:0 0;border:1px solid var(--glass-border);color:var(--text-muted);font-size:.65rem;padding:2px 8px;border-radius:4px;cursor:pointer;transition:all var(--transition)}.cfg-tcp-est-range:hover{color:var(--text);border-color:var(--primary)}.cfg-tcp-est-range.active{background:var(--primary);color:#fff;border-color:var(--primary)}@media(max-width:480px){.cfg-val-grid{grid-template-columns:1fr}.cfg-tcp-est{flex-direction:column;align-items:flex-start}}.usr-table-wrap{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);overflow-x:auto;overflow-y:hidden;box-shadow:var(--card-shadow)}.usr-head,.usr-row{display:grid;grid-template-columns:minmax(90px,1.2fr) minmax(120px,2fr) 75px minmax(80px,1fr) 50px 70px 90px 68px;gap:.5rem;align-items:center;padding:.45rem .85rem}.usr-head{font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);opacity:.6;border-bottom:1px solid var(--glass-border)}.usr-row{font-size:.8rem;border-bottom:1px solid rgba(255,255,255,.03);transition:background var(--transition)}.usr-row:last-child{border-bottom:none}.usr-row:hover{background:rgba(255,255,255,.02)}.usr-cell-name{font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.usr-cell-email{color:var(--text-muted);font-size:.75rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.usr-cell-group{color:var(--text-muted);font-size:.7rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.usr-cell-login{color:var(--text-muted);font-size:.7rem;font-variant-numeric:tabular-nums}.usr-login-link{cursor:pointer;text-decoration:underline;text-decoration-color:rgba(255,255,255,0.15);text-underline-offset:2px;transition:color .2s}.usr-login-link:hover{color:var(--primary-light)}.usr-login-link:focus-visible{color:var(--primary-light)}.li-user{display:flex;align-items:center;gap:.6rem;padding:.7rem .8rem;background:var(--glass);border:1px solid var(--glass-border);border-radius:8px;margin-bottom:.8rem;font-weight:600;font-size:.85rem;color:var(--text)}.li-user svg{color:var(--primary-light);flex-shrink:0}.li-main{display:flex;flex-direction:column;gap:.5rem}.li-item{display:flex;align-items:center;gap:.7rem;padding:.45rem .6rem;border-radius:6px;background:rgba(255,255,255,.015);border:1px solid rgba(255,255,255,.04)}.li-icon{color:var(--primary);flex-shrink:0;opacity:.6}.li-item div{display:flex;flex-direction:column}.li-val{font-size:.8rem;font-weight:500;color:var(--text)}.li-sub{font-size:.6rem;color:var(--text-muted);margin-top:1px}.li-ua-details{margin-top:.7rem;font-size:.65rem;color:var(--text-muted)}.li-ua-details summary{cursor:pointer;font-weight:600;letter-spacing:.5px;text-transform:uppercase;font-size:.55rem;opacity:.5;transition:opacity .2s}.li-ua-details summary:hover{opacity:.8}.li-ua-details[open] summary{margin-bottom:.4rem}.li-ua-code{display:block;font-size:.6rem;color:var(--text-muted);word-break:break-all;line-height:1.5;padding:.5rem;background:rgba(0,0,0,.3);border-radius:6px;border:1px solid rgba(255,255,255,.04)}.usr-cell-actions{display:flex;gap:.25rem;justify-content:flex-end}.usr-badge{font-size:.6rem;font-weight:600;padding:.15rem .4rem;border-radius:4px;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap;display:inline-flex;align-items:center;gap:.2rem}.usr-badge-admin{color:var(--success);background:rgba(16,185,129,.12)}.usr-badge-client{color:var(--primary-light);background:rgba(83,140,190,.12)}.usr-badge-ok{color:var(--success);background:rgba(16,185,129,.12)}.usr-badge-off{color:var(--text-muted);opacity:.4}@media(max-width:900px){.usr-head,.usr-row{grid-template-columns:minmax(80px,1.2fr) minmax(100px,2fr) 65px 50px 68px;gap:.35rem}.usr-cell-group,.usr-cell-login,.usr-head span:nth-child(4),.usr-head span:nth-child(7){display:none}.usr-row span:nth-child(4),.usr-row span:nth-child(7){display:none}}@media(max-width:600px){.usr-head,.usr-row{grid-template-columns:1fr 1fr 68px;gap:.3rem;padding:.4rem .6rem}.usr-head span:nth-child(n+3):not(:last-child),.usr-row span:nth-child(n+3):not(:last-child){display:none}.usr-cell-email{font-size:.7rem}}.sh-pcaps{display:flex;flex-direction:column;gap:.5rem;padding:.75rem 0 0}.sh-pcap-group{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}.sh-pcap-label{font-size:.7rem;color:var(--text-muted);font-weight:500;white-space:nowrap;flex-shrink:0}.sh-pcap-pair{display:flex;gap:.4rem;align-items:center;flex-wrap:wrap}.sh-pcap-btn{display:inline-flex;align-items:center;gap:.3rem;padding:.35rem .65rem;border-radius:6px;font-size:.7rem;font-weight:500;text-decoration:none;transition:all .2s;cursor:pointer;white-space:nowrap}.sh-pcap-pre{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.25);color:#f87171}.sh-pcap-pre:hover{background:rgba(239,68,68,.2);border-color:var(--danger)}.sh-pcap-post{background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.25);color:#34d399}.sh-pcap-post:hover{background:rgba(16,185,129,.2);border-color:var(--success)}.sh-pcap-empty{opacity:.5}.sh-pcap-mitigated{display:inline-flex;align-items:center;gap:.3rem;padding:.35rem .65rem;border-radius:6px;font-size:.7rem;font-weight:600;background:rgba(16,185,129,.08);border:1px solid rgba(16,185,129,.22);color:#34d399;white-space:nowrap;cursor:help;letter-spacing:.15px}.sh-pcap-mitigated svg{flex-shrink:0;opacity:.95}.sh-pcap-hidden{display:none}.sh-pcap-more{display:inline-flex;align-items:center;gap:.35rem;margin-top:.5rem;padding:.5rem .9rem;border-radius:7px;font-size:.72rem;font-weight:500;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);color:var(--text-muted);cursor:pointer;transition:all .15s;font-family:inherit;letter-spacing:.15px;width:100%;justify-content:center}.sh-pcap-more:hover{color:var(--text);background:rgba(83,140,190,.08);border-color:rgba(83,140,190,.25)}.sh-pcap-more-n{color:var(--primary-light);font-weight:600;font-variant-numeric:tabular-nums;font-family:var(--font-mono)}.sh-pcap-node-tag{display:inline-block;padding:1px 6px;border-radius:3px;font-size:.6rem;font-weight:600;letter-spacing:.3px;background:rgba(83,140,190,.15);border:1px solid rgba(83,140,190,.3);color:var(--primary-light);margin-left:4px}.sh-pcap-node-tag.sh-pcap-node-guard{background:rgba(168,85,247,.15);border-color:rgba(168,85,247,.35);color:#c084fc}.sh-pcap-analyze{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);color:var(--text-muted)}.sh-pcap-analyze:hover{background:rgba(255,255,255,.1);color:var(--text)}.sh-pcap-analysis{width:100%;padding:.4rem 0 0}.sh-pcap-stats{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:.6rem;font-size:.68rem}.sh-pcap-stat-header{color:var(--text-muted);margin-bottom:.4rem;font-weight:500;font-size:.7rem}.sh-pcap-columns{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem}.sh-pcap-col-title{color:var(--primary-light);font-weight:600;margin-bottom:.2rem;font-size:.62rem;text-transform:uppercase;letter-spacing:.03em}.sh-pcap-row{display:flex;justify-content:space-between;align-items:center;gap:.3rem;padding:.15rem .25rem;border-bottom:1px solid rgba(255,255,255,.04);position:relative;overflow:hidden;border-radius:3px}.sh-pcap-bar{position:absolute;left:0;top:0;bottom:0;background:rgba(83,140,190,.12);border-radius:3px;pointer-events:none;transition:width .3s}.sh-pcap-row span{position:relative;z-index:1}.sh-pcap-row span:first-of-type{color:var(--text);font-family:var(--font-mono);font-size:.65rem;overflow:hidden;text-overflow:ellipsis}.sh-pcap-cnt{color:var(--text-muted);font-size:.62rem;flex-shrink:0;white-space:nowrap}.sh-pcap-cnt small{opacity:.6}.sh-pcap-unique{color:var(--danger);font-weight:600}.sh-pcap-loading{color:var(--text-muted);font-size:.72rem}.vlan-add-row{display:flex;align-items:center;gap:.5rem;padding-top:.75rem;border-top:1px solid var(--glass-border);margin-top:.75rem}.vlan-input{width:90px;padding:.4rem .6rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:.8rem;text-align:center}.vlan-input:focus{border-color:var(--primary);outline:0}.vlan-arrow{color:var(--text-muted);font-size:1.1rem}.vlan-add-btn{padding:.4rem .8rem;font-size:.75rem;white-space:nowrap}.vlan-table{width:100%;border-collapse:collapse}.vlan-table th{font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);opacity:.6;padding:.3rem .5rem;text-align:left;border-bottom:1px solid var(--glass-border)}.vlan-table td{padding:.45rem .5rem;font-size:.8rem;border-bottom:1px solid rgba(255,255,255,.03)}.vlan-table tr.vlan-disabled td{opacity:.4}.vlan-id{font-weight:600;font-variant-numeric:tabular-nums;color:var(--primary-light)}.vlan-eg-edit:hover{border-color:var(--border)}.vlan-eg-edit:focus{border-color:var(--primary);outline:0;background:var(--surface)}.vlan-actions{display:flex;gap:.25rem;justify-content:flex-end}.vlan-act-btn{background:0 0;border:none;color:var(--text-muted);cursor:pointer;padding:.2rem;border-radius:4px;transition:color .2s}.vlan-act-btn:hover{color:var(--danger)}.vlan-act-btn.save:hover{color:var(--success)}.vlan-toggle{position:relative;width:32px;height:18px;display:inline-block}.vlan-toggle input{opacity:0;width:0;height:0}.vlan-toggle .vt-slider{position:absolute;cursor:pointer;inset:0;background:rgba(255,255,255,.1);border-radius:9px;transition:.2s}.vlan-toggle .vt-slider::before{content:'';position:absolute;height:14px;width:14px;left:2px;bottom:2px;background:var(--text-muted);border-radius:50%;transition:.2s}.vlan-toggle input:checked+.vt-slider{background:var(--success)}.vlan-toggle input:checked+.vt-slider::before{transform:translateX(14px);background:#fff}.vfl-edit-btn{position:absolute;top:4px;right:4px;background:0 0;border:none;color:var(--text-muted);cursor:pointer;opacity:0;transition:opacity .2s;padding:2px}.node-vlans{position:relative}.node-vlans:hover .vfl-edit-btn{opacity:1}.vfl-edit-btn:hover{color:var(--primary-light)}.modal-card-provision{max-width:800px;width:95%}.provision-steps{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.75rem}.provision-step{padding:.3rem .65rem;border-radius:6px;font-size:.68rem;font-weight:600;border:1px solid rgba(255,255,255,.08);color:var(--text-muted);transition:all .25s;letter-spacing:.01em}.provision-step.running{color:var(--primary-light);border-color:rgba(83,140,190,.4);background:rgba(83,140,190,.1);animation:pulse 1.2s ease-in-out infinite;box-shadow:0 0 8px rgba(83,140,190,.15)}.provision-step.done{color:#3fb950;border-color:rgba(63,185,80,.3);background:rgba(63,185,80,.08)}.provision-step.error{color:#f85149;border-color:rgba(248,81,73,.3);background:rgba(248,81,73,.08)}.provision-step.outdated{color:#f59e0b;border-color:rgba(245,158,11,.3);background:rgba(245,158,11,.08)}.provision-terminal{background:#080b10;border:1px solid rgba(255,255,255,.06);border-radius:12px;padding:1rem 1.15rem;max-height:500px;overflow-y:auto;font-family:var(--font-mono);font-size:.72rem;line-height:1.8;color:#7d8590;min-height:100px;box-shadow:inset 0 2px 12px rgba(0,0,0,.5),0 0 0 1px rgba(255,255,255,.02)}.provision-terminal::-webkit-scrollbar{width:5px}.provision-terminal::-webkit-scrollbar-track{background:0 0}.provision-terminal::-webkit-scrollbar-thumb{background:rgba(255,255,255,.06);border-radius:3px}.provision-terminal::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.12)}.provision-terminal .prov-line{white-space:pre-wrap;word-break:break-all;padding:.15rem 0 .15rem 1.1rem;position:relative;transition:color .15s}.provision-terminal .prov-line::before{content:'›';position:absolute;left:.1rem;color:rgba(255,255,255,.12);font-weight:700;font-size:.8em}.provision-terminal .prov-line.prov-ok{color:#3fb950}.provision-terminal .prov-line.prov-ok::before{content:'✓';color:#3fb950}.provision-terminal .prov-line.prov-warn{color:#d29922}.provision-terminal .prov-line.prov-warn::before{content:'⚠';color:#d29922}.provision-terminal .prov-line.prov-err{color:#f85149}.provision-terminal .prov-line.prov-err::before{content:'✗';color:#f85149}.prov-tabs{display:flex;gap:2px;margin-bottom:.5rem;background:var(--bg-subtle);border-radius:8px;padding:2px}.prov-tab{flex:1;padding:6px 12px;border:none;background:0 0;color:var(--text-muted);font-size:.75rem;font-weight:600;font-family:inherit;cursor:pointer;border-radius:6px;transition:all var(--transition)}.prov-tab.active{background:var(--primary);color:#fff}.prov-tab:hover:not(.active){background:rgba(255,255,255,.05)}.prov-tab-panel{min-height:60px}.prov-sysinfo{font-size:.7rem;color:var(--text-muted);padding:.3rem .4rem;margin-bottom:.15rem;text-align:center;border-bottom:1px solid rgba(255,255,255,.05)}.prov-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:.3rem;padding:.2rem}.prov-tab-panel .prov-grid{grid-template-columns:repeat(5,1fr)}@media(max-width:768px){.prov-tab-panel .prov-grid{grid-template-columns:repeat(3,1fr)}.prov-grid{grid-template-columns:repeat(3,1fr)}}.prov-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.15rem;padding:.4rem .3rem;border-radius:8px;border:1px solid rgba(255,255,255,.06);background:rgba(255,255,255,.02);transition:all .2s;min-height:56px;position:relative}.prov-card:hover{background:rgba(255,255,255,.04);transform:translateY(-1px)}.prov-card.prov-ok{border-color:rgba(63,185,80,.2);background:rgba(63,185,80,.03)}.prov-card.prov-warn{border-color:rgba(210,153,34,.25);background:rgba(210,153,34,.03)}.prov-card.prov-err{border-color:rgba(248,81,73,.25);background:rgba(248,81,73,.04)}.prov-card-icon{font-size:.75rem;line-height:1;width:18px;height:18px;display:flex;align-items:center;justify-content:center;border-radius:50%}.prov-card.prov-ok .prov-card-icon{color:#3fb950;background:rgba(63,185,80,.1)}.prov-card.prov-warn .prov-card-icon{color:#d29922;background:rgba(210,153,34,.1)}.prov-card.prov-err .prov-card-icon{color:#f85149;background:rgba(248,81,73,.1)}.prov-card-name{font-size:.6rem;font-weight:600;color:var(--text-muted);text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%;text-transform:capitalize}.prov-card-ver{font-size:.7rem;font-weight:700;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%;color:var(--text)}.prov-card.prov-ok .prov-card-ver{color:#3fb950}.prov-card.prov-warn .prov-card-ver{color:#d29922}.prov-card.prov-err .prov-card-ver{color:#f85149}.prov-card-latest{font-size:.55rem;color:#484f58;text-align:center;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.xdp-countdown{color:var(--primary-light)!important;font-weight:600;animation:pulse 1s infinite}.btn-xdp-deploy{background:rgba(83,140,190,.1);border-color:rgba(83,140,190,.3)}.btn-xdp-deploy:hover{background:rgba(83,140,190,.18);border-color:rgba(83,140,190,.5)}.btn-integrity{background:0 0;border-color:rgba(255,255,255,.08);position:relative}.btn-integrity:hover{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.18)}.btn-integrity svg{transition:color .3s,filter .3s,opacity .3s}.btn-integrity.status-ok svg{color:var(--success);animation:integrity-glow-ok 3s ease-in-out infinite}.btn-integrity.status-ok:hover svg{color:var(--success)}.btn-integrity.status-warn svg{color:#fbbf24;animation:integrity-glow-warn 2s ease-in-out infinite}.btn-integrity.status-drift svg{color:var(--danger);animation:integrity-glow-drift 1s ease-in-out infinite}.btn-integrity.status-loading svg{color:var(--text-muted);opacity:.5}.integrity-status-dot{display:none}@keyframes integrity-glow-ok{0%,100%{filter:drop-shadow(0 0 2px rgba(16,185,129,.35))}50%{filter:drop-shadow(0 0 7px rgba(16,185,129,.85))}}@keyframes integrity-glow-warn{0%,100%{filter:drop-shadow(0 0 2px rgba(251,191,36,.35));opacity:.8}50%{filter:drop-shadow(0 0 7px rgba(251,191,36,.85));opacity:1}}@keyframes integrity-glow-drift{0%,100%{filter:drop-shadow(0 0 3px rgba(239,68,68,.5));opacity:.85}50%{filter:drop-shadow(0 0 9px rgba(239,68,68,1));opacity:1}}.modal-card-integrity{max-width:1100px;width:95%}.modal-card-integrity .modal-body{padding-top:.25rem}.integrity-banner{display:flex;align-items:center;gap:.5rem;padding:.7rem .95rem;border-radius:10px;font-size:.78rem;font-weight:600;margin-bottom:1rem;border:1px solid var(--glass-border)}.integrity-banner.ok{background:rgba(16,185,129,.08);border-color:rgba(16,185,129,.3);color:var(--success)}.integrity-banner.warn{background:rgba(239,68,68,.08);border-color:rgba(239,68,68,.3);color:var(--danger)}.integrity-banner.info{background:rgba(251,191,36,.06);border-color:rgba(251,191,36,.28);color:#fbbf24}.integrity-banner+.integrity-banner{margin-top:-.55rem}.integrity-section{margin-bottom:1.4rem}.integrity-section-title{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.9px;color:var(--text-muted);opacity:.85;margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}.integrity-section-sub{opacity:.6;font-weight:500;letter-spacing:.3px}.integrity-table-wrap{overflow-x:auto;border:1px solid var(--glass-border);border-radius:10px;background:linear-gradient(180deg,rgba(255,255,255,.015),rgba(255,255,255,0))}.integrity-table{width:100%;border-collapse:collapse;font-size:.72rem;font-family:var(--font-mono)}.integrity-table thead th{background:rgba(255,255,255,.02);color:var(--text-muted);font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.6px;padding:.6rem .7rem;text-align:left;border-bottom:1px solid rgba(255,255,255,.06);font-family:inherit}.integrity-table tbody td{padding:.55rem .7rem;border-bottom:1px solid rgba(255,255,255,.025);color:var(--text);font-variant-numeric:tabular-nums}.integrity-table tbody tr:last-child td{border-bottom:none}.integrity-table .integrity-label{font-weight:600;color:var(--text);font-family:inherit;font-size:.74rem}.integrity-table .integrity-cell-hash{color:var(--text);cursor:help}.integrity-table .integrity-cell-missing,.integrity-table .integrity-cell-unreachable{color:var(--text-muted);opacity:.5}.integrity-table .integrity-cell-error{color:var(--danger);font-weight:600}.integrity-table .integrity-row-ok td.integrity-cell-hash{color:var(--success)}.integrity-table .integrity-row-drift{background:rgba(239,68,68,.04)}.integrity-table .integrity-row-drift td.integrity-cell-hash{color:var(--danger)}.integrity-table .integrity-row-drift td.integrity-label{color:var(--danger)}.integrity-table .integrity-row-info{background:rgba(251,191,36,.035)}.integrity-table .integrity-row-info td.integrity-cell-hash{color:#fbbf24}.integrity-table .integrity-cell-stale{color:var(--danger);font-weight:600;cursor:help}.integrity-derived-tag{display:inline-block;font-size:.55rem;font-weight:600;text-transform:uppercase;letter-spacing:.4px;padding:.05rem .32rem;margin-left:.35rem;border-radius:3px;background:rgba(251,191,36,.12);color:#fbbf24;border:1px solid rgba(251,191,36,.25);font-family:var(--font-mono);cursor:help;vertical-align:middle}.integrity-stale-badge{display:inline-block;font-size:.55rem;font-weight:700;text-transform:uppercase;letter-spacing:.4px;padding:.05rem .3rem;margin-left:.3rem;border-radius:3px;background:rgba(239,68,68,.15);color:var(--danger);border:1px solid rgba(239,68,68,.3);font-family:var(--font-mono);vertical-align:middle}.prov-card-reboot{font-size:.55rem;color:#f85149;font-weight:600;padding:.1rem .3rem;background:rgba(248,81,73,.1);border-radius:3px}.prov-loading{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:2.5rem;color:#6b7280;font-size:.78rem;letter-spacing:.02em}.provision-terminal .prov-info{color:#58a6ff}.provision-terminal .prov-step-header{color:#58a6ff;font-weight:600;margin-top:.85rem;padding:.35rem 0 .35rem .75rem;border-left:2px solid rgba(88,166,255,.5);margin-left:0;background:rgba(88,166,255,.04);border-radius:0 4px 4px 0}.provision-terminal .prov-step-header::before{content:'';display:none}.provision-terminal .prov-phase-sep{margin:.75rem 0 .25rem;border:none;border-top:1px solid rgba(255,255,255,.06);position:relative}.prov-inline-confirm{margin:.85rem 0 .35rem;padding:1rem 1.15rem;border-radius:10px;border:1px solid rgba(83,140,190,.3);background:linear-gradient(135deg,rgba(83,140,190,.08) 0,rgba(83,140,190,.03) 100%);display:flex;flex-direction:column;gap:.75rem;font-family:var(--font-mono)}.pic-header{display:flex;align-items:flex-start;gap:.65rem}.pic-icon{width:22px;height:22px;color:var(--success);flex-shrink:0;margin-top:1px}.pic-header-text{display:flex;flex-direction:column;gap:.15rem}.pic-title{color:var(--text);font-size:.78rem;font-weight:600;line-height:1.4}.pic-subtitle{color:var(--text-muted);font-size:.72rem;font-weight:400;line-height:1.3}.pic-option{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.7rem;color:var(--text-muted);padding:.4rem .6rem;border-radius:6px;border:1px solid rgba(255,255,255,.06);background:rgba(255,255,255,.02);transition:all .15s;margin-left:.1rem;width:fit-content}.pic-option:hover{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.12)}.pic-option input[type=checkbox]{accent-color:var(--primary);width:14px;height:14px;cursor:pointer}.pic-option span{user-select:none}.pic-actions{display:flex;gap:.5rem;justify-content:flex-end}.pic-actions button{padding:.5rem 1.15rem;border-radius:6px;font-size:.72rem;font-weight:600;cursor:pointer;border:1px solid transparent;font-family:inherit;transition:all .15s}.pic-cancel{background:0 0;border-color:rgba(255,255,255,.14)!important;color:var(--text-muted)}.pic-cancel:hover{background:rgba(255,255,255,.08);color:var(--text);border-color:rgba(255,255,255,.24)!important}.pic-ok{background:var(--primary);border-color:var(--primary)!important;color:#fff}.pic-ok:hover{background:var(--primary-light);border-color:var(--primary-light)!important}.prov-done-card{display:flex;align-items:center;gap:.85rem;margin:.85rem 0 .25rem;padding:1rem 1.15rem;border-radius:10px;font-family:var(--font-mono);animation:provDoneIn .3s ease-out}@keyframes provDoneIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.prov-done-ok{border:1px solid rgba(63,185,80,.3);background:linear-gradient(135deg,rgba(63,185,80,.1) 0,rgba(63,185,80,.02) 100%);box-shadow:0 0 12px rgba(63,185,80,.06)}.prov-done-err{border:1px solid rgba(248,81,73,.3);background:linear-gradient(135deg,rgba(248,81,73,.1) 0,rgba(248,81,73,.02) 100%);box-shadow:0 0 12px rgba(248,81,73,.06)}.prov-done-icon{flex-shrink:0}.prov-done-icon svg{width:28px;height:28px}.prov-done-ok .prov-done-icon{color:#3fb950}.prov-done-err .prov-done-icon{color:#f85149}.prov-done-body{display:flex;flex-direction:column;gap:.2rem}.prov-done-title{font-size:.82rem;font-weight:600;letter-spacing:.01em}.prov-done-ok .prov-done-title{color:#3fb950}.prov-done-err .prov-done-title{color:#f85149}.prov-done-meta{font-size:.7rem;color:var(--text-muted);letter-spacing:.01em}.prov-footer{display:flex;justify-content:flex-end;padding:.5rem 0 0}.prov-copy-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .6rem;border-radius:5px;background:0 0;border:1px solid rgba(255,255,255,.08);color:var(--text-muted);cursor:pointer;transition:all var(--transition);font-size:.68rem;font-family:inherit;font-weight:500}.prov-copy-btn:hover{color:var(--text);border-color:var(--glass-border);background:rgba(255,255,255,.03)}.node-action-btn.provision:hover{color:var(--primary-light);border-color:rgba(83,140,190,.25);background:rgba(83,140,190,.06)}.node-action-btn.provision:focus-visible{color:var(--primary-light);border-color:rgba(83,140,190,.25);background:rgba(83,140,190,.06)}.guard-tabs{display:flex;gap:4px;margin-left:auto;padding-left:1rem;border-left:1px solid var(--border)}.ghist-filters{display:contents}.ghist-filters .search-input{width:240px}.guard-tab{background:0 0;border:1px solid var(--border);color:var(--text-muted);padding:6px 16px;border-radius:6px;cursor:pointer;font-size:13px;transition:all .2s}.guard-tab:hover{color:var(--text);border-color:var(--primary)}.guard-tab.active{background:var(--primary);color:#fff;border-color:var(--primary)}.guard-proto-table th{text-align:left;color:var(--text-muted);font-weight:500;padding:4px 8px;border-bottom:1px solid var(--border)}.guard-proto-table td{padding:4px 8px;color:var(--text)}.guard-proto-table .numeric{text-align:right;font-family:var(--font-mono)}.guard-proto-attack td{color:var(--danger)}.guard-config-container{padding:16px}.guard-config-title{color:var(--text);font-size:16px;margin:0 0 4px}.guard-config-desc{color:var(--text-muted);font-size:13px;margin-bottom:20px}.guard-threshold-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}.guard-threshold-item{display:flex;flex-direction:column;gap:4px}.guard-threshold-label{font-size:13px;font-weight:600;color:var(--text)}.guard-threshold-desc{font-weight:400;color:var(--text-muted);margin-left:8px;font-size:12px}.guard-threshold-input-wrap{display:flex;align-items:center;gap:8px}.guard-threshold-input{max-width:140px;background:var(--surface);border:1px solid var(--border);color:var(--text);padding:8px 10px;border-radius:6px;font-size:13px;font-family:var(--font-mono)}.guard-threshold-input:focus{outline:0;border-color:var(--primary)}.guard-threshold-default{font-size:11px;color:var(--text-muted)}.guard-config-extra{display:flex;gap:24px;margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}.guard-config-save{padding:8px 24px;background:var(--primary);color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:background .2s}.guard-config-save:hover{background:var(--primary-light)}.guard-history-table th{white-space:nowrap}.guard-status-ongoing td{background:rgba(239,68,68,.05)}.guard-status-badge.guard-status-ongoing{background:rgba(239,68,68,.15);color:var(--danger)}.guard-status-badge.guard-status-ended{background:rgba(16,185,129,.15);color:var(--success)}.guard-head,.guard-row{display:grid;grid-template-columns:20px minmax(100px,1.2fr) minmax(100px,1.2fr) minmax(80px,1.3fr) 60px minmax(55px,0.6fr) minmax(55px,0.6fr) minmax(85px,0.9fr) 50px minmax(65px,0.7fr) 42px;gap:.35rem}.guard-atk-list .guard-head,.guard-atk-list .guard-row{grid-template-columns:20px minmax(100px,1.1fr) minmax(100px,1.1fr) minmax(80px,1.2fr) 55px minmax(55px,0.55fr) minmax(65px,0.65fr) minmax(60px,0.6fr) minmax(80px,0.85fr) 50px minmax(65px,0.7fr) 42px}.guard-pps-cell{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.guard-ratio-badge{display:inline-flex;align-items:center;padding:1px 6px;border-radius:10px;font-size:.62rem;font-weight:600;font-family:inherit;line-height:1.3;letter-spacing:.3px;white-space:nowrap;cursor:help}.guard-ratio-vec{font-weight:700;letter-spacing:.5px;opacity:.85;font-size:.58rem;margin-left:2px}.guard-ratio-low{background:rgba(148,163,184,.12);color:#94a3b8}.guard-ratio-med{background:rgba(234,179,8,.14);color:#eab308}.guard-ratio-high{background:rgba(239,68,68,.14);color:#f87171}.guard-ratio-spike{background:rgba(239,68,68,.22);color:#fca5a5;box-shadow:0 0 0 1px rgba(239,68,68,.35),0 0 8px rgba(239,68,68,.25);animation:guardSpikePulse 1.8s ease-in-out infinite}@keyframes guardSpikePulse{0%,100%{box-shadow:0 0 0 1px rgba(239,68,68,.35),0 0 6px rgba(239,68,68,.2)}50%{box-shadow:0 0 0 1px rgba(239,68,68,.5),0 0 12px rgba(239,68,68,.4)}}.guard-baseline-cell{font-family:var(--font-mono);font-size:.75rem;color:var(--text-muted)}.guard-baseline-val{color:var(--text-muted)}.guard-baseline-warm{color:var(--text-muted);opacity:.45;font-style:italic}.guard-head{padding:.4rem .75rem;font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);opacity:.6;border-bottom:1px solid var(--glass-border)}.atk-sort-col,.guard-sort-col{cursor:pointer;user-select:none;white-space:nowrap}.atk-sort-col:hover,.guard-sort-col:hover{color:var(--text);opacity:1}.guard-sort-arrow{font-size:.5rem;opacity:.3}.guard-sort-arrow.active{opacity:1;color:var(--primary)}.guard-row{align-items:center;padding:.45rem .75rem;font-size:.8rem;border-bottom:1px solid rgba(255,255,255,.03);border-left:2px solid transparent;transition:background var(--transition)}.guard-sev-bar{height:6px;background:rgba(255,255,255,.06);border-radius:3px;overflow:hidden;width:100%}.guard-sev-fill{height:100%;border-radius:3px;min-width:2px;transition:width .3s}.guard-sev-low .guard-sev-fill{background:var(--success)}.guard-sev-med .guard-sev-fill{background:linear-gradient(90deg,#eab308,#f97316)}.guard-sev-high .guard-sev-fill{background:linear-gradient(90deg,#f97316,#ef4444)}.guard-sev-crit .guard-sev-fill{background:linear-gradient(90deg,#ef4444,#dc2626)}.guard-row:hover{background:rgba(255,255,255,.02)}.bgp-route-actions{display:flex;align-items:center;gap:8px;justify-content:flex-end}.bgp-toggle input{opacity:0;width:0;height:0}.bgp-toggle-slider::before{content:'';position:absolute;width:14px;height:14px;left:2px;bottom:2px;background:#fff;border-radius:50%;transition:transform .2s}.bgp-toggle input:checked+.bgp-toggle-slider{background:var(--success)}.bgp-toggle input:checked+.bgp-toggle-slider::before{transform:translateX(14px)}.bgp-toggle input:disabled+.bgp-toggle-slider{opacity:.4;cursor:not-allowed}.guard-row.atk-ongoing{border-left-color:var(--danger);background:rgba(239,68,68,.05)}.guard-row.atk-sev-ended{border-left-color:transparent}.guard-row.atk-sev-ended>*{opacity:.45}.guard-vectors{display:flex;gap:2px;overflow:hidden;min-width:0;flex-wrap:wrap}.guard-vectors .atk-type{font-size:.55rem;padding:1px 4px;white-space:nowrap}.atk-type.atk-type-secondary{opacity:.5;border-style:dashed!important;cursor:help}.guard-vectors .atk-type.atk-type-secondary{opacity:.55}.atk-type.atk-pattern{background:linear-gradient(135deg,rgba(239,68,68,.18),rgba(239,68,68,.08));color:var(--danger);border-color:rgba(239,68,68,.45)!important;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.guard-vectors .atk-type.atk-pattern{font-size:.58rem;padding:1px 6px}.guard-asn{font-size:.7rem;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.guard-asn-edit{cursor:pointer}.guard-asn-edit:hover{color:var(--primary-light)}.guard-asn-input{background:var(--surface);border:1px solid var(--primary);color:var(--text);padding:1px 4px;border-radius:3px;font-size:.7rem;width:80%;outline:0;font-family:inherit}.guard-row .atk-duration{font-family:var(--font-mono);font-size:.75rem;color:var(--text-muted)}.guard-pcap-cell{display:flex;align-items:center;justify-content:center}.guard-pcap-btn{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;padding:0;border-radius:6px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);color:var(--text-muted);cursor:pointer;transition:all .15s;flex-shrink:0}.guard-pcap-btn:hover{color:var(--primary-light);background:rgba(83,140,190,.12);border-color:rgba(83,140,190,.35);transform:scale(1.08)}.guard-pcap-btn:active{transform:scale(.94)}.guard-pcap-btn-loading{opacity:.4;pointer-events:none;animation:guard-pcap-pulse 1s ease-in-out infinite}.guard-pcap-btn svg{display:block}@keyframes guard-pcap-pulse{0%,100%{opacity:.4}50%{opacity:.8}}.ui-tip{position:fixed;left:0;top:0;max-width:320px;padding:8px 12px;background:linear-gradient(180deg,rgba(18,25,40,.98) 0,rgba(8,12,22,.98) 100%);border:1px solid rgba(255,255,255,.1);border-radius:7px;box-shadow:0 6px 22px rgba(0,0,0,.6),0 0 0 1px rgba(83,140,190,.06);color:var(--text);font-size:.72rem;font-weight:500;line-height:1.5;letter-spacing:.1px;pointer-events:none;z-index:99999;opacity:0;transform:translateY(3px);transition:opacity .12s,transform .12s;white-space:pre-wrap;word-break:break-word;font-family:inherit;backdrop-filter:blur(10px)}.ui-tip-visible{opacity:1;transform:translateY(0)}.ui-tip-left,.ui-tip-right{transform:translateX(0)}.ui-tip-left.ui-tip-visible,.ui-tip-right.ui-tip-visible{transform:translateX(0)}.ui-tip-right{transform:translateX(-3px)}.ui-tip-left{transform:translateX(3px)}.ui-tip-left::after,.ui-tip-left::before,.ui-tip-right::after,.ui-tip-right::before{content:'';position:absolute;top:50%;width:0;height:0;transform:translateY(-50%);pointer-events:none}.ui-tip-right::before{left:-7px;border-top:7px solid transparent;border-bottom:7px solid transparent;border-right:7px solid rgba(255,255,255,.1)}.ui-tip-right::after{left:-6px;border-top:6px solid transparent;border-bottom:6px solid transparent;border-right:6px solid rgba(14,20,34,.98)}.ui-tip-left::before{right:-7px;border-top:7px solid transparent;border-bottom:7px solid transparent;border-left:7px solid rgba(255,255,255,.1)}.ui-tip-left::after{right:-6px;border-top:6px solid transparent;border-bottom:6px solid transparent;border-left:6px solid rgba(14,20,34,.98)}.fp{--fp-card-bg:var(--surface);--fp-border:var(--border);--fp-text:var(--text);--fp-muted:var(--text-muted);--fp-primary:var(--primary-light);--fp-danger:#ef4444;--fp-danger-light:#fca5a5;--fp-gold:#fbbf24;--fp-silver:#cbd5e1;--fp-bronze:#d97706;padding:16px 20px 32px;display:flex;flex-direction:column;gap:16px}@keyframes fp-pulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.8);opacity:0}100%{transform:scale(1);opacity:0}}.fp-empty{padding:72px 16px;text-align:center;color:var(--text-muted);display:flex;flex-direction:column;align-items:center;gap:14px;max-width:480px;margin:0 auto}.fp-empty svg{opacity:.25}.fp-empty-title{font-size:1.05rem;color:var(--text);font-weight:500}.fp-empty-desc{font-size:.82rem;line-height:1.55}.fp-empty-inline{padding:28px 16px;text-align:center;color:var(--text-muted);font-size:.8rem}.fp-hero{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}.fp-metric{background:linear-gradient(180deg,var(--surface) 0,rgba(10,15,26,.6) 100%);border:1px solid var(--border);border-radius:12px;padding:18px 20px 16px;display:flex;flex-direction:column;gap:6px;position:relative;overflow:hidden;transition:border-color .2s,transform .2s}.fp-metric::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,rgba(83,140,190,.5),transparent)}.fp-metric:hover{border-color:rgba(83,140,190,.28);transform:translateY(-1px)}.fp-metric-label{font-size:.66rem;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);font-weight:600}.fp-metric-value{font-size:1.75rem;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums;font-family:var(--font-mono);line-height:1.05;letter-spacing:-.5px}.fp-metric-sub{font-size:.68rem;color:var(--text-muted);margin-top:2px;font-weight:500}.fp-metric-danger{background:linear-gradient(180deg,rgba(239,68,68,.1) 0,rgba(239,68,68,.02) 100%);border-color:rgba(239,68,68,.3)}.fp-metric-danger::before{background:linear-gradient(90deg,transparent,rgba(239,68,68,.7),transparent)}.fp-metric-danger:hover{border-color:rgba(239,68,68,.5)}.fp-metric-danger .fp-metric-value{color:#fca5a5;text-shadow:0 0 20px rgba(239,68,68,.15)}.fp-metric-danger .fp-metric-sub{color:#f87171;font-weight:600}.fp-card{background:linear-gradient(180deg,var(--surface) 0,rgba(10,15,26,.4) 100%);border:1px solid var(--border);border-radius:12px;padding:20px 22px;display:flex;flex-direction:column;gap:16px;min-width:0;transition:border-color .2s}.fp-card:hover{border-color:rgba(83,140,190,.18)}.fp-card-head{display:flex;justify-content:space-between;align-items:center;gap:12px;padding-bottom:14px;border-bottom:1px solid var(--border)}.fp-card-title{font-size:.72rem;text-transform:uppercase;letter-spacing:1.1px;color:var(--text);font-weight:600;display:flex;align-items:center;gap:8px}.fp-card-title::before{content:'';width:3px;height:14px;background:linear-gradient(180deg,var(--primary-light),rgba(83,140,190,.3));border-radius:2px;display:inline-block}.fp-card-meta{font-size:.7rem;color:var(--text-muted);font-family:var(--font-mono);font-variant-numeric:tabular-nums;letter-spacing:.3px}.fp-grid{display:grid;gap:16px}.fp-grid-2{grid-template-columns:1fr 1fr}.fp-card-map{padding:0;overflow:hidden}.fp-card-map .fp-card-head{padding:18px 22px 14px;border-bottom:1px solid var(--border);background:linear-gradient(180deg,rgba(83,140,190,.04),transparent)}.fp-map-svg{display:block;width:100%;height:auto;max-height:560px;background:radial-gradient(ellipse at center,#0e1828 0,#050a14 100%)}.fp-map-svg circle{transition:r .25s,opacity .25s}.fp-map-label{font-size:7px;fill:#fca5a5;font-family:var(--font-mono);font-weight:700;pointer-events:none;letter-spacing:.4px}.fp-map-pulse{animation:fp-pulse 2s ease-out infinite;transform-origin:center;transform-box:fill-box}.fp-map-container{position:relative;width:100%}.fp-map-dot{cursor:crosshair;transition:stroke-width .12s,filter .12s}.fp-map-dot:hover{stroke-width:.8;filter:drop-shadow(0 0 6px rgba(239,68,68,.55))}.fp-map-tooltip{position:absolute;top:0;left:0;min-width:200px;padding:10px 12px;background:linear-gradient(180deg,rgba(18,25,40,.98) 0,rgba(8,12,22,.98) 100%);border:1px solid rgba(239,68,68,.3);border-radius:8px;box-shadow:0 6px 28px rgba(0,0,0,.55),0 0 0 1px rgba(239,68,68,.08);pointer-events:none;z-index:10;opacity:0;transition:opacity .12s;backdrop-filter:blur(8px);will-change:transform,opacity}.fp-tip-visible{opacity:1}.fp-tip-head{display:flex;align-items:center;gap:8px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:8px}.fp-tip-flag{font-size:1.1rem;line-height:1}.fp-tip-name{font-size:.82rem;font-weight:600;color:var(--text);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.fp-tip-rank{font-family:var(--font-mono);font-size:.66rem;font-weight:700;padding:2px 6px;border-radius:4px;background:rgba(255,255,255,.05);color:var(--text-muted);border:1px solid rgba(255,255,255,.08);letter-spacing:.3px}.fp-tip-rank-gold{color:var(--fp-gold);background:rgba(251,191,36,.1);border-color:rgba(251,191,36,.3);text-shadow:0 0 6px rgba(251,191,36,.4)}.fp-tip-rank-silver{color:var(--fp-silver);background:rgba(203,213,225,.08);border-color:rgba(203,213,225,.25)}.fp-tip-rank-bronze{color:var(--fp-bronze);background:rgba(217,119,6,.1);border-color:rgba(217,119,6,.3)}.fp-tip-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.fp-tip-stat{display:flex;flex-direction:column;gap:1px;min-width:0}.fp-tip-val{font-family:var(--font-mono);font-size:.92rem;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums;letter-spacing:-.2px;line-height:1.1}.fp-tip-val-danger{color:#fca5a5}.fp-tip-lbl{font-size:.58rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.7px;font-weight:500}.fp-dist-body{display:flex;align-items:center;gap:24px}.fp-donut{width:150px;height:150px;flex-shrink:0}.fp-donut circle{transition:stroke-dasharray .4s ease}.fp-donut-val{fill:var(--text);font-size:6.5px;font-weight:700;font-family:var(--font-mono);letter-spacing:.3px}.fp-donut-sub{fill:var(--text-muted);font-size:3.4px;font-weight:600;font-family:var(--font-mono)}.fp-legend{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.fp-legend-row{display:grid;grid-template-columns:10px auto 1fr auto;gap:10px;align-items:center;font-size:.82rem;padding:5px 2px}.fp-legend-row:not(:last-child){border-bottom:1px dashed rgba(255,255,255,.04)}.fp-legend-dot{width:10px;height:10px;border-radius:2px}.fp-legend-name{font-family:var(--font-mono);color:var(--text);font-weight:500}.fp-legend-pct{text-align:right;color:var(--primary-light);font-weight:600;font-variant-numeric:tabular-nums;font-family:var(--font-mono)}.fp-legend-count{text-align:right;color:var(--text-muted);font-variant-numeric:tabular-nums;font-family:var(--font-mono);font-size:.72rem;min-width:56px}.fp-table{display:flex;flex-direction:column;gap:1px}.fp-thead{display:grid;align-items:center;gap:10px;padding:0 12px 10px;font-size:.62rem;text-transform:uppercase;letter-spacing:1.1px;color:var(--text-muted);font-weight:600;border-bottom:1px solid var(--border);margin-bottom:4px}.fp-thead>:nth-last-child(-n+3){text-align:right}.fp-trow{position:relative;display:grid;align-items:center;gap:10px;padding:11px 12px;border-radius:7px;font-size:.84rem;transition:background .15s,transform .15s}.fp-trow:not(:last-child):not(.fp-trow-unk){border-bottom:1px dashed rgba(255,255,255,.025)}.fp-trow:hover{background:rgba(255,255,255,.025)}.fp-bar{position:absolute;left:0;top:1px;bottom:1px;background:linear-gradient(90deg,rgba(83,140,190,.14),rgba(83,140,190,0));border-radius:6px;pointer-events:none;z-index:0}.fp-trow:nth-child(2) .fp-bar{background:linear-gradient(90deg,rgba(239,68,68,.18),rgba(239,68,68,.01))}.fp-trow:nth-child(3) .fp-bar{background:linear-gradient(90deg,rgba(251,191,36,.12),rgba(251,191,36,.01))}.fp-trow:nth-child(4) .fp-bar{background:linear-gradient(90deg,rgba(203,213,225,.09),rgba(203,213,225,.01))}.fp-trow>:not(.fp-bar){position:relative;z-index:1}.fp-table-domains .fp-thead,.fp-table-domains .fp-trow{grid-template-columns:28px minmax(0,1fr) 56px 80px}.fp-table-geo .fp-thead,.fp-table-geo .fp-trow{grid-template-columns:24px minmax(0,1fr) 40px 68px 80px 64px 42px}.fp-table-asn .fp-thead,.fp-table-asn .fp-trow{grid-template-columns:24px minmax(0,1fr) 40px 68px 80px 64px 42px}.fp-rate{font-family:var(--font-mono);color:var(--primary-light);font-size:.7rem;font-variant-numeric:tabular-nums;text-align:right;font-weight:600;letter-spacing:-.2px;white-space:nowrap}.fp-trow:nth-child(n+5) .fp-rate{color:var(--text-muted);font-weight:500}.fp-trow-unk{opacity:.55}.fp-trow-unk:hover{opacity:.85}.fp-unk-tag{display:inline-block;padding:0 5px;border-radius:3px;font-size:.58rem;letter-spacing:.4px;font-weight:600;background:rgba(255,255,255,.06);color:var(--text-muted);border:1px solid var(--border);text-transform:uppercase;margin-left:6px;vertical-align:middle;font-family:var(--font-mono)}.fp-rank{font-family:var(--font-mono);color:var(--text-muted);font-size:.82rem;font-variant-numeric:tabular-nums;font-weight:700;text-align:center;letter-spacing:-.3px}.fp-trow:nth-child(2) .fp-rank{color:#ef4444;text-shadow:0 0 10px rgba(239,68,68,.45);font-size:.88rem}.fp-trow:nth-child(3) .fp-rank{color:var(--fp-gold);text-shadow:0 0 8px rgba(251,191,36,.3)}.fp-trow:nth-child(4) .fp-rank{color:var(--fp-silver)}.fp-qname{font-family:var(--font-mono);color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:600;display:flex;align-items:center;gap:8px;min-width:0;letter-spacing:-.1px}.fp-qtype{display:inline-flex;align-items:center;padding:1px 7px;border-radius:4px;font-size:.62rem;font-weight:700;letter-spacing:.6px;background:rgba(255,255,255,.04);color:var(--text-muted);border:1px solid rgba(255,255,255,.06);flex-shrink:0;font-family:var(--font-mono);height:16px;line-height:1}.fp-qtype-any{background:rgba(239,68,68,.14);color:#fca5a5;border-color:rgba(239,68,68,.3);box-shadow:inset 0 0 0 .5px rgba(239,68,68,.15)}.fp-share{font-family:var(--font-mono);color:var(--text);font-size:.78rem;font-variant-numeric:tabular-nums;text-align:right;font-weight:500}.fp-trow:nth-child(n+5) .fp-share{color:var(--text-muted);font-size:.74rem}.fp-count{font-family:var(--font-mono);color:var(--primary-light);font-weight:700;font-variant-numeric:tabular-nums;text-align:right;font-size:.88rem;letter-spacing:-.2px}.fp-trow:nth-child(n+5) .fp-count{font-size:.82rem;font-weight:600}.fp-flag{font-size:1.1rem;line-height:1;text-align:center}.fp-geo-name{color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500;display:flex;align-items:center;gap:8px;min-width:0}.fp-geo-ips{text-align:right;font-family:var(--font-mono);color:var(--text-muted);font-size:.72rem;font-variant-numeric:tabular-nums}.fp-asn-num{font-family:var(--font-mono);font-size:.68rem;color:var(--text-muted);font-weight:600;flex-shrink:0;background:rgba(255,255,255,.04);padding:1px 6px;border-radius:3px;letter-spacing:.3px;border:1px solid rgba(255,255,255,.06)}.fp-mss-head,.fp-mss-row{display:grid;grid-template-columns:80px minmax(180px,1.6fr) 90px 90px 100px 70px;gap:.6rem;align-items:center;padding:.4rem .55rem;font-size:.78rem}.fp-mss-head span{cursor:default}.fp-mss-head span[data-tip]{cursor:help;border-bottom:1px dotted rgba(156,163,175,.4)}.fp-mss-row:hover{background:rgba(255,255,255,.025)}.fp-mss-row-anom:hover{background:rgba(239,68,68,.1)}.fp-mss-row-anom .fp-mss-val{color:#fca5a5}.fp-mss-row-anom .fp-mss-label{color:#fcd34d}.fp-mss-syn,.fp-mss-synack,.fp-mss-total{font-family:var(--font-mono);font-variant-numeric:tabular-nums;text-align:right;font-size:.76rem}@media(max-width:1280px){.fp-table-geo .fp-thead,.fp-table-geo .fp-trow{grid-template-columns:24px minmax(0,1fr) 40px 68px 64px 42px}.fp-table-asn .fp-thead,.fp-table-asn .fp-trow{grid-template-columns:24px minmax(0,1fr) 40px 68px 64px 42px}.fp-table-asn .fp-bps,.fp-table-asn .fp-bps-h,.fp-table-geo .fp-bps,.fp-table-geo .fp-bps-h{display:none}}@media(max-width:1024px){.fp-hero{grid-template-columns:repeat(3,1fr)}.fp-hero .fp-metric:nth-child(4),.fp-hero .fp-metric:nth-child(5){grid-column:span 1}}@media(max-width:860px){.fp-mss-head,.fp-mss-row{grid-template-columns:60px 1fr 60px 70px;gap:.5rem;font-size:.72rem}.fp-mss-head .fp-mss-ago-h,.fp-mss-head .fp-mss-syn-h,.fp-mss-row .fp-mss-ago,.fp-mss-row .fp-mss-syn{display:none}}@media(max-width:768px){.fp{padding:12px 10px 32px;gap:12px}.fp-card{padding:14px 14px}.fp-hero{grid-template-columns:repeat(2,1fr)}.fp-metric{padding:12px 14px}.fp-metric-value{font-size:1.3rem}.fp-grid-2{grid-template-columns:1fr}.fp-dist-body{flex-direction:column;gap:14px;align-items:stretch}.fp-donut{width:140px;height:140px;align-self:center}.fp-table-domains .fp-thead,.fp-table-domains .fp-trow{grid-template-columns:22px minmax(0,1fr) 50px 50px;gap:6px;font-size:.75rem}.fp-table-geo .fp-thead,.fp-table-geo .fp-trow{grid-template-columns:22px minmax(0,1fr) 50px 50px;gap:6px;font-size:.74rem}.fp-table-geo .fp-bps,.fp-table-geo .fp-bps-h,.fp-table-geo .fp-pps,.fp-table-geo .fp-pps-h,.fp-table-geo .fp-share{display:none}.fp-table-asn .fp-thead,.fp-table-asn .fp-trow{grid-template-columns:22px minmax(0,1fr) 50px 50px;gap:6px;font-size:.74rem}.fp-table-asn .fp-bps,.fp-table-asn .fp-bps-h,.fp-table-asn .fp-pps,.fp-table-asn .fp-pps-h,.fp-table-asn .fp-share{display:none}.fp-thead>span:nth-child(3),.fp-thead>span:nth-child(4),.fp-thead>span:nth-child(5){font-size:.6rem}}@media(max-width:768px){.guard-attacks-grid{grid-template-columns:1fr;padding:8px}.guard-threshold-grid{grid-template-columns:1fr}.guard-config-extra{flex-direction:column;gap:12px}.guard-tabs{overflow-x:auto;margin-left:0;padding-left:0;border-left:0}.ghist-filters .search-input{width:100%}.guard-atk-list .atk-head,.guard-atk-list .atk-row{grid-template-columns:1fr}.guard-atk-list .atk-row-mid,.guard-atk-list .atk-row-top{display:flex;flex-wrap:wrap;gap:.3rem}}@media(prefers-reduced-motion:reduce){*,::after,::before{animation:none!important;transition:none!important}.glow-blob{display:none}}.token-scope-edit{cursor:pointer}.token-scope-edit:hover{color:var(--primary-light)}.token-scope-dropdown{display:flex;flex-direction:column;gap:4px;padding:6px;background:var(--surface);border:1px solid var(--border);border-radius:6px;min-width:120px}.token-scope-dd-item{display:flex;align-items:center;gap:6px;font-size:.7rem;cursor:pointer;padding:2px 4px;border-radius:3px}.token-scope-dd-item:hover{background:rgba(255,255,255,.05)}.token-scope-dd-item input{margin:0}.token-scope-save{margin-top:4px;padding:3px 10px;font-size:.65rem}.token-perm-grid{display:flex;flex-direction:column;gap:6px}.token-perm{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:8px;border:1px solid var(--border);cursor:pointer;transition:all .15s}.token-perm:hover{border-color:var(--primary);background:rgba(83,140,190,.05)}.token-perm:has(input:checked){border-color:var(--primary);background:rgba(83,140,190,.1)}.token-perm-cb{width:16px;height:16px;accent-color:var(--primary);cursor:pointer;flex-shrink:0}.token-perm-info{display:flex;flex-direction:column;gap:1px}.token-perm-name{font-size:.8rem;font-weight:600;color:var(--text)}.token-perm-desc{font-size:.65rem;color:var(--text-muted)}.bgp-split-badge{font-size:.55rem;padding:1px 5px;border-radius:3px;background:rgba(83,140,190,.15);color:var(--primary-light);font-weight:600;margin-left:4px;vertical-align:middle}#setSshAllowlist{gap:.85rem}.sshg-toolbar{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.25rem}.sshg-title{margin:0;font-size:1.05rem;font-weight:600;color:var(--text);display:flex;align-items:center;gap:.4rem}.sshg-info{color:var(--text-muted);font-size:.85rem;cursor:help}.sshg-desc{margin:.3rem 0 0;font-size:.72rem;color:var(--text-muted);line-height:1.45;max-width:780px}.sshg-sync-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem .85rem;background:var(--surface);border:1px solid rgba(255,255,255,.08);border-radius:8px;color:var(--text);font-size:.78rem;font-weight:500;cursor:pointer;transition:all .15s}.sshg-sync-btn:hover{background:rgba(255,255,255,.04);border-color:rgba(83,140,190,.4);color:var(--primary-light)}.sshg-sync-btn:disabled{opacity:.5;cursor:wait}.sshg-sync-btn svg{flex-shrink:0}.sshg-sync-btn.spinning svg{animation:sshSpin .8s linear infinite}@keyframes sshSpin{from{transform:rotate(0)}to{transform:rotate(360deg)}}.sshg-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr)) minmax(0,1.6fr);gap:.6rem}.sshg-card{padding:.75rem .9rem;border-radius:10px;background:var(--surface);border:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;gap:.35rem;justify-content:space-between;min-height:96px}.sshg-card-pass{border-left:2px solid var(--success)}.sshg-card-drop{border-left:2px solid var(--danger)}.sshg-card-head{display:flex;align-items:center;gap:.4rem;font-size:.62rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em}.sshg-card-icon{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;flex-shrink:0}.sshg-card-pass .sshg-card-icon{color:var(--success);background:rgba(16,185,129,.12)}.sshg-card-drop .sshg-card-icon{color:var(--danger);background:rgba(239,68,68,.12)}.sshg-card-value{font-size:1.5rem;font-weight:700;font-family:var(--font-mono,monospace);color:var(--text);line-height:1}.sshg-card-foot{font-size:.65rem;color:var(--text-muted);font-family:var(--font-mono,monospace)}.sshg-card-pass .sshg-card-foot{color:var(--success)}.sshg-card-drop .sshg-card-foot{color:var(--danger)}.sshg-card-state{font-size:1rem;font-weight:600;display:flex;align-items:center;gap:.4rem}.sshg-dot{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0}.sshg-dot-green{background:var(--success);box-shadow:0 0 6px rgba(16,185,129,.6)}.sshg-dot-red{background:var(--danger);box-shadow:0 0 6px rgba(239,68,68,.6)}.sshg-dot-gray{background:var(--text-muted)}.sshg-chart-card{padding:.6rem .75rem;border-radius:10px;background:var(--surface);border:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;gap:.35rem;min-height:96px}.sshg-chart-head{display:flex;justify-content:space-between;align-items:center;gap:.5rem;font-size:.65rem}.sshg-range{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);color:var(--text);padding:.25rem .5rem;border-radius:6px;font-size:.7rem;cursor:pointer}.sshg-chart-legend{display:flex;gap:.6rem;align-items:center;color:var(--text-muted);font-size:.62rem}.sshg-legend{display:inline-flex;align-items:center;gap:.3rem}.sshg-mute{color:var(--text-muted);opacity:.7}.sshg-chart-card canvas{flex:1;width:100%;min-height:60px;display:block}.sshg-form{display:grid;grid-template-columns:1fr 1fr 200px 130px;gap:.5rem;background:var(--surface);border:1px solid rgba(255,255,255,.06);border-radius:10px;padding:.5rem}.sshg-input-wrap{position:relative}.sshg-input-icon{position:absolute;left:.6rem;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.sshg-form input,.sshg-form select{width:100%;padding:.5rem .65rem;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-radius:6px;color:var(--text);font-size:.78rem;font-family:inherit}.sshg-form input:focus,.sshg-form select:focus{outline:0;border-color:rgba(83,140,190,.5);background:rgba(255,255,255,.05)}.sshg-input-wrap input{padding-left:2rem;font-family:var(--font-mono,monospace)}.sshg-action{cursor:pointer}.sshg-action:disabled{cursor:not-allowed;opacity:.85}.sshg-add-btn{padding:.5rem .9rem;background:linear-gradient(135deg,var(--primary),#4a8ec4);border:none;border-radius:6px;color:#fff;font-size:.78rem;font-weight:600;cursor:pointer;transition:transform .15s,box-shadow .15s}.sshg-add-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(83,140,190,.3)}.sshg-add-btn:active{transform:translateY(0)}.sshg-table-wrap{background:var(--surface);border:1px solid rgba(255,255,255,.06);border-radius:10px;overflow:hidden}.sshg-table{width:100%;border-collapse:collapse}.sshg-table th{text-align:left;padding:.65rem .85rem;font-size:.62rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;background:rgba(255,255,255,.02);border-bottom:1px solid rgba(255,255,255,.06)}.sshg-table td{padding:.65rem .85rem;font-size:.8rem;border-bottom:1px solid rgba(255,255,255,.04);vertical-align:middle}.sshg-table tbody tr:last-child td{border-bottom:0}.sshg-table tbody tr:hover{background:rgba(255,255,255,.02)}.sshg-cidr{font-family:var(--font-mono,monospace);color:var(--primary-light);font-weight:500}.sshg-origin{display:inline-block;font-size:.6rem;font-weight:700;padding:2px 8px;border-radius:4px;text-transform:lowercase;letter-spacing:.04em}.sshg-origin-system{background:rgba(83,140,190,.15);color:var(--primary-light)}.sshg-origin-user{background:rgba(168,85,247,.15);color:#c084fc}.sshg-pkts-cell{font-family:var(--font-mono,monospace)}.sshg-pkts-num{display:inline-block;min-width:36px;color:var(--text)}.sshg-pkts-spark{display:inline-block;vertical-align:middle;margin-left:.5rem}.sshg-date{font-size:.72rem;color:var(--text-muted);font-family:var(--font-mono,monospace);white-space:nowrap}.sshg-row-actions{text-align:right;width:80px;white-space:nowrap}.sshg-row-btn{background:0 0;border:1px solid rgba(255,255,255,.08);width:26px;height:26px;border-radius:5px;cursor:pointer;color:var(--text-muted);display:inline-flex;align-items:center;justify-content:center;margin-left:4px;transition:all .15s}.sshg-row-btn:hover{background:rgba(255,255,255,.04);color:var(--text)}.sshg-row-btn.sshg-row-del:hover{border-color:rgba(239,68,68,.4);color:var(--danger);background:rgba(239,68,68,.05)}.sshg-row-btn:disabled{opacity:.3;cursor:not-allowed}.sshg-empty{text-align:center;color:var(--text-muted);padding:1.4rem!important;font-style:italic}.sshg-pagination{display:flex;justify-content:space-between;align-items:center;gap:.6rem;padding:.55rem .85rem;border-top:1px solid rgba(255,255,255,.04);font-size:.72rem;color:var(--text-muted)}.sshg-page-nav{display:inline-flex;align-items:center;gap:.4rem}.sshg-page-btn{background:0 0;border:1px solid rgba(255,255,255,.08);width:24px;height:24px;border-radius:4px;cursor:pointer;color:var(--text);font-size:.85rem;line-height:1}.sshg-page-btn:hover:not(:disabled){background:rgba(255,255,255,.05)}.sshg-page-btn:disabled{opacity:.3;cursor:not-allowed}.sshg-page-current{padding:2px 8px;background:var(--primary);color:#fff;border-radius:4px;font-weight:600}.sshg-page-size{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);color:var(--text);padding:.2rem .4rem;border-radius:4px;font-size:.7rem;cursor:pointer}.ssh-allow-sync-status{margin-top:.25rem;font-size:.72rem}.ssh-allow-sync-status:empty{display:none}.ssh-allow-ok{color:var(--success)}.ssh-allow-err{color:var(--danger)}.ssh-allow-syncing{color:var(--text-muted);font-style:italic}.sshg-edit-input{width:100%;padding:.3rem .5rem;background:rgba(83,140,190,.08);border:1px solid rgba(83,140,190,.4);border-radius:5px;color:var(--text);font-size:.78rem;font-family:inherit}.sshg-edit-input.sshg-edit-cidr{font-family:var(--font-mono,monospace);color:var(--primary-light)}.sshg-edit-input:focus{outline:0;border-color:var(--primary-light);background:rgba(83,140,190,.12)}.sshg-row-save{border-color:rgba(16,185,129,.4)!important;color:var(--success)!important}.sshg-row-save:hover{background:rgba(16,185,129,.08)!important}.sshg-row-cancel:hover{border-color:rgba(239,68,68,.4)!important;color:var(--danger)!important;background:rgba(239,68,68,.05)!important}.sshg-sync-block{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem}.sshg-last-sync{font-size:.65rem;color:var(--text-muted);font-family:var(--font-mono,monospace)}.sshg-card-clickable{cursor:pointer;transition:background .15s,border-color .15s}.sshg-card-clickable:hover{background:rgba(255,255,255,.03);border-color:rgba(83,140,190,.25)}.sshg-card-hint{font-size:.55rem;color:var(--text-muted);opacity:.65;text-transform:none;letter-spacing:0;font-weight:400;margin-left:auto}.sshg-card-clickable:hover .sshg-card-hint{color:var(--primary-light);opacity:1}@keyframes sshgPulse{0%{background:var(--surface)}30%{background:rgba(83,140,190,.18)}100%{background:var(--surface)}}.sshg-pulse{animation:sshgPulse .6s ease-out}.sshg-action-label{display:inline-flex;align-items:center;justify-content:center;padding:.5rem .65rem;background:rgba(16,185,129,.08);border:1px solid rgba(16,185,129,.25);border-radius:6px;color:var(--success);font-size:.78rem;font-weight:500;white-space:nowrap}.sshg-myip-btn{padding:.5rem .8rem;background:rgba(83,140,190,.08);border:1px solid rgba(83,140,190,.25);border-radius:6px;color:var(--primary-light);font-size:.75rem;font-weight:500;cursor:pointer;white-space:nowrap;transition:background .15s}.sshg-myip-btn:hover{background:rgba(83,140,190,.15)}.sshg-form{grid-template-columns:1fr 1fr 90px 110px 130px}.sshg-table-toolbar{display:flex;justify-content:space-between;align-items:center;gap:.5rem;padding:.5rem .1rem;font-size:.72rem;color:var(--text-muted)}.sshg-search-wrap{position:relative;flex:0 0 280px;max-width:100%}.sshg-search-wrap svg{position:absolute;left:.55rem;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.sshg-search-wrap input{width:100%;padding:.4rem .6rem .4rem 1.85rem;background:var(--surface);border:1px solid rgba(255,255,255,.08);border-radius:6px;color:var(--text);font-size:.75rem;font-family:inherit}.sshg-search-wrap input:focus{outline:0;border-color:rgba(83,140,190,.4)}.sshg-table-count{font-family:var(--font-mono,monospace)}.sshg-row-locked{color:var(--text-muted)!important;cursor:not-allowed!important;opacity:.6}.sshg-empty{padding:2rem 1rem!important}.sshg-empty-icon{font-size:1.5rem;color:var(--primary-light);margin-bottom:.4rem;animation:sshgBounce 1.5s ease-in-out infinite}.sshg-empty-title{font-style:normal;font-weight:600;color:var(--text);font-size:.9rem;margin-bottom:.2rem}.sshg-empty-sub{font-size:.75rem;color:var(--text-muted);font-style:normal}@keyframes sshgBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}.sshg-spark-empty{color:var(--text-muted);opacity:.4;margin-left:.5rem}.sshg-drilldown{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center}.sshg-drilldown-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.65);backdrop-filter:blur(2px)}.sshg-drilldown-panel{position:relative;background:var(--bg);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:0;width:min(640px,90vw);max-height:80vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px rgba(0,0,0,.5)}.sshg-drilldown-head{display:flex;justify-content:space-between;align-items:center;padding:.85rem 1.1rem;border-bottom:1px solid rgba(255,255,255,.06)}.sshg-drilldown-head h4{margin:0;font-size:.9rem;font-weight:600;color:var(--text)}.sshg-drilldown-close{background:0 0;border:none;color:var(--text-muted);font-size:1.4rem;cursor:pointer;line-height:1;padding:0;width:24px;height:24px}.sshg-drilldown-close:hover{color:var(--text)}.sshg-drilldown-body{padding:.6rem;overflow:auto}.sshg-drilldown-empty{padding:2rem;text-align:center;color:var(--text-muted);font-style:italic}.sshg-dd-table{width:100%;border-collapse:collapse;font-size:.78rem}.sshg-dd-table th{text-align:left;padding:.55rem .7rem;font-size:.6rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;border-bottom:1px solid rgba(255,255,255,.06)}.sshg-dd-table td{padding:.55rem .7rem;border-bottom:1px solid rgba(255,255,255,.04)}.sshg-dd-table tr:last-child td{border-bottom:0}.sshg-dd-num{font-family:var(--font-mono,monospace);text-align:right}.sshg-dd-table code{font-family:var(--font-mono,monospace);color:var(--primary-light);font-size:.72rem}.sshg-dd-err{font-size:.65rem;color:var(--danger);margin-top:2px;font-family:var(--font-mono,monospace)}@media (max-width:1100px){.sshg-stats{grid-template-columns:repeat(2,1fr);grid-auto-rows:auto}.sshg-chart-card{grid-column:span 2;min-height:140px}.sshg-form{grid-template-columns:1fr;gap:.4rem}.sshg-action-label,.sshg-form .sshg-input-wrap,.sshg-form button,.sshg-form input{width:100%}.sshg-toolbar{flex-direction:column;align-items:flex-start}.sshg-sync-block{align-items:flex-start}}