:root{--bg-body:#f0f3f7;--bg-nav:#fff;--bg-card:#fff;--bg-input:#f5f7fa;--bg-row:#fafbfc;--bg-row-alt:#f5f7fa;--border:#e5e8ee;--border-light:#f0f3f7;--border-hover:#c8d6e5;--blue:#1677ff;--blue-light:#4096ff;--blue-bg:#ecf4ff;--teal:#08a89d;--teal-bg:#e8faf8;--green:#00a854;--green-bg:#edfaf3;--orange:#fa8c16;--orange-bg:#fff7e6;--red:#f5222d;--red-bg:#fff1f0;--purple:#722ed1;--purple-bg:#f5f0ff;--cyan:#0891b2;--cyan-bg:#ecfeff;--text-primary:#1a1d2e;--text-secondary:#596177;--text-muted:#999db3;--shadow-sm:0 1px 6px #0000000a;--shadow-md:0 4px 16px #0000000f;--shadow-lg:0 8px 32px #00000014;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--nav-height:56px;--transition:.2s ease}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%}body{color:var(--text-primary);background:var(--bg-body);-webkit-font-smoothing:antialiased;min-width:1100px;font-family:PingFang SC,Microsoft YaHei,-apple-system,sans-serif;font-size:13px;line-height:1.5}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#d0d5dd;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#b0b7c2}button{font:inherit;cursor:pointer;transition:all var(--transition);border:none;outline:none}table{border-collapse:collapse;width:100%}input,select,textarea{font-family:inherit}.app-shell{background:var(--bg-body);flex-direction:column;height:100vh;display:flex}.topnav{height:var(--nav-height);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm);z-index:100;background:#fff;flex-shrink:0;align-items:center;gap:10px;padding:0 22px;display:flex;position:relative}.topnav-brand{flex-shrink:0;align-items:center;gap:10px;margin-right:18px;display:flex}.topnav-brand .logo{border-radius:var(--radius-sm);background:linear-gradient(135deg, var(--blue), var(--teal));color:#fff;place-items:center;width:32px;height:32px;font-size:15px;font-weight:900;display:grid;box-shadow:0 2px 10px #1677ff40}.topnav-brand .brand-text{color:var(--text-primary);font-size:15px;font-weight:700}.topnav-nav{flex:1;align-items:center;gap:2px;display:flex}.nav-item{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);white-space:nowrap;align-items:center;gap:6px;padding:7px 13px;font-size:13px;font-weight:500;display:inline-flex}.nav-item:hover{color:var(--text-primary);background:var(--border-light)}.nav-item.active{color:var(--blue);background:var(--blue-bg);font-weight:600}.nav-item.active:after{content:"";background:var(--blue);border-radius:1px;height:2px;position:absolute;bottom:-1px;left:8px;right:8px}.nav-item svg{opacity:.62;flex-shrink:0;width:16px;height:16px}.nav-item.active svg{opacity:1}.nav-item .nav-admin-badge{background:var(--orange-bg);color:var(--orange);border-radius:4px;margin-left:2px;padding:1px 5px;font-size:9px}.topnav-right{flex-shrink:0;align-items:center;gap:12px;margin-left:12px;display:flex}.edition-badge{background:var(--blue-bg);color:var(--blue);letter-spacing:.04em;border:1px solid #1677ff1f;border-radius:999px;padding:3px 10px;font-size:10px}.status-dot{color:var(--text-muted);align-items:center;gap:5px;font-size:11px;display:inline-flex}.status-dot i{background:var(--green);border-radius:50%;width:7px;height:7px;box-shadow:0 0 6px #00a8544d}.status-dot.offline i{background:var(--red);box-shadow:0 0 6px #f5222d4d}.btn-login-nav{border-radius:var(--radius-sm);background:var(--blue);color:#fff;padding:6px 15px;font-size:12px;font-weight:500}.btn-login-nav:hover{background:var(--blue-light)}.btn-logout-nav{border-radius:var(--radius-sm);background:var(--border-light);color:var(--text-secondary);padding:5px 12px;font-size:12px}.btn-logout-nav:hover{background:var(--red-bg);color:var(--red)}.nav-admin-info{color:var(--text-secondary);align-items:center;gap:6px;font-size:12px;display:flex}.nav-admin-info .avatar{background:linear-gradient(135deg, var(--blue), var(--teal));color:#fff;border-radius:50%;place-items:center;width:24px;height:24px;font-size:11px;font-weight:700;display:grid}.content{background:var(--bg-body);flex:1;padding:22px 24px 32px;overflow-y:auto}.section,.grid{gap:16px;display:grid}.grid-2{grid-template-columns:1fr 1fr}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.grid-2-1{grid-template-columns:2fr 1fr}.grid-1-2{grid-template-columns:1fr 2fr}.kpi-row{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.kpi-card{border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fff;align-items:center;gap:14px;padding:18px 20px;transition:all .2s;display:flex}.kpi-card:hover{box-shadow:var(--shadow-md);border-color:#1677ff26;transform:translateY(-1px)}.kpi-card .kpi-icon{border-radius:var(--radius-md);flex-shrink:0;place-items:center;width:44px;height:44px;display:grid}.kpi-card .kpi-icon svg{width:20px;height:20px}.kpi-card .kpi-body{flex:1;min-width:0}.kpi-card .kpi-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;margin-bottom:3px;font-size:11px}.kpi-card .kpi-value{letter-spacing:-.03em;font-family:DIN Alternate,Segoe UI,sans-serif;font-size:28px;font-weight:700}.kpi-card .kpi-unit{color:var(--text-muted);margin-left:4px;font-size:12px}.kpi-blue .kpi-icon{background:var(--blue-bg);color:var(--blue)}.kpi-blue .kpi-value{color:var(--blue)}.kpi-green .kpi-icon{background:var(--green-bg);color:var(--green)}.kpi-green .kpi-value{color:var(--green)}.kpi-red .kpi-icon{background:var(--red-bg);color:var(--red)}.kpi-red .kpi-value{color:var(--red)}.kpi-orange .kpi-icon{background:var(--orange-bg);color:var(--orange)}.kpi-orange .kpi-value{color:var(--orange)}.kpi-purple .kpi-icon{background:var(--purple-bg);color:var(--purple)}.kpi-purple .kpi-value{color:var(--purple)}.kpi-teal .kpi-icon{background:var(--teal-bg);color:var(--teal)}.kpi-teal .kpi-value{color:var(--teal)}.data-card{border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fff;transition:all .2s;overflow:hidden}.data-card:hover{box-shadow:var(--shadow-md)}.data-card-header{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:flex-start;padding:16px 20px 12px;display:flex}.data-card-header .dc-title{color:var(--text-primary);font-size:14px;font-weight:600}.data-card-header .dc-desc{color:var(--text-muted);margin-top:3px;font-size:11px}.data-card-body{padding:16px 20px 20px}.table-wrap{border-radius:var(--radius-md);border:1px solid var(--border);overflow-x:auto}.table-wrap table{min-width:700px}.table-wrap thead th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border);white-space:nowrap;z-index:1;background:#f8fafc;padding:11px 16px;font-size:11px;font-weight:600;position:sticky;top:0}.table-wrap thead th:first-child{border-radius:var(--radius-md) 0 0 0}.table-wrap thead th:last-child{border-radius:0 var(--radius-md) 0 0}.table-wrap tbody td{color:var(--text-secondary);border-bottom:1px solid var(--border-light);padding:11px 16px;font-size:13px}.table-wrap tbody tr:last-child td{border-bottom:none}.table-wrap tbody tr:nth-child(2n) td{background:#fafbfc}.table-wrap tbody tr:hover td{background:var(--blue-bg)}.table-wrap tbody tr:last-child td:first-child{border-radius:0 0 0 var(--radius-md)}.table-wrap tbody tr:last-child td:last-child{border-radius:0 0 var(--radius-md) 0}.table-wrap .empty{text-align:center;color:var(--text-muted);border:1px dashed var(--border);border-radius:var(--radius-md);background:#fafbfc;padding:44px 20px;font-size:13px}.badge{border-radius:999px;align-items:center;gap:4px;padding:3px 10px;font-size:11px;font-weight:500;display:inline-flex}.badge-blue{background:var(--blue-bg);color:var(--blue)}.badge-green{background:var(--green-bg);color:var(--green)}.badge-red{background:var(--red-bg);color:var(--red)}.badge-orange{background:var(--orange-bg);color:var(--orange)}.badge-purple{background:var(--purple-bg);color:var(--purple)}.badge-teal{background:var(--teal-bg);color:var(--teal)}.badge-gray{background:var(--border-light);color:var(--text-muted)}.item-list{gap:6px;display:grid}.item-row{border-radius:var(--radius-md);border:1px solid var(--border-light);background:#fff;align-items:center;gap:12px;padding:10px 16px;transition:all .15s;display:flex}.item-row:hover{border-color:var(--blue);box-shadow:0 2px 10px #1677ff0f}.event-item{border-radius:var(--radius-md);border:1px solid var(--border-light);cursor:pointer;background:#fff;grid-template-columns:8px 1fr;gap:12px;padding:12px 16px;transition:all .15s;display:grid}.event-item:hover{border-color:var(--blue)}.event-item .event-dot{border-radius:50%;width:8px;height:8px;margin-top:4px}.event-item .event-body b{color:var(--text-primary);margin-bottom:2px;font-size:13px;display:block}.event-item .event-body span{color:var(--text-muted);font-size:11px;display:block}.event-item .event-body p{color:var(--text-secondary);margin-top:6px;font-size:12px;line-height:1.5}.finding-row{border-radius:var(--radius-md);border:1px solid var(--border-light);background:#fff;align-items:center;gap:12px;padding:12px 16px;transition:all .15s;display:flex}.finding-row:hover{border-color:var(--blue)}.finding-row .finding-info{flex:1}.finding-row .finding-info b{color:var(--text-primary);font-size:13px;display:block}.finding-row .finding-info span{color:var(--text-muted);margin-top:3px;font-size:11px;display:block}.asset-row{border-radius:var(--radius-md);border:1px solid var(--border-light);background:#fff;grid-template-columns:1fr 100px 85px 95px;align-items:center;gap:12px;padding:12px 16px;transition:all .15s;display:grid}.asset-row:hover{border-color:var(--blue)}.asset-row .asset-info{align-items:center;gap:10px;display:flex}.asset-row .asset-info .initial{border-radius:var(--radius-sm);color:#fff;background:linear-gradient(135deg, var(--blue), var(--teal));place-items:center;width:30px;height:30px;font-size:12px;font-weight:700;display:grid}.asset-row .asset-info b{color:var(--text-primary);font-size:13px;display:block}.asset-row .asset-info span{color:var(--text-muted);margin-top:2px;font-size:11px;display:block}.policy-row{border-radius:var(--radius-md);border:1px solid var(--border-light);background:#fff;grid-template-columns:1fr 100px;align-items:center;gap:12px;padding:12px 16px;transition:all .15s;display:grid}.policy-row:hover{border-color:var(--blue)}.policy-row .policy-info b{color:var(--text-primary);font-size:13px;display:block}.policy-row .policy-info span{color:var(--text-muted);margin-top:3px;font-size:11px;display:block}.policy-row .policy-controls{justify-content:flex-end;align-items:center;gap:12px;display:flex}.rank-list{gap:5px;display:grid}.rank-item{border-radius:var(--radius-sm);background:var(--border-light);border:1px solid var(--border);grid-template-columns:24px 1fr 44px;align-items:center;gap:10px;padding:8px 12px;transition:all .15s;display:grid}.rank-item:hover{background:var(--blue-bg)}.rank-item .rank-num{color:var(--text-muted);text-align:center;font-size:12px;font-weight:700}.rank-item:first-child .rank-num{color:var(--orange)}.rank-item .rank-name{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:12px;overflow:hidden}.rank-item .rank-count{color:var(--teal);text-align:right;font-size:12px;font-weight:600}.rank-item .rank-bar{background:#1677ff14;border-radius:2px;height:4px;overflow:hidden}.rank-item .rank-bar i{background:linear-gradient(90deg, var(--blue), var(--teal));border-radius:2px;height:100%;display:block}.hbar-chart{gap:7px;display:grid}.hbar-item{grid-template-columns:100px 1fr 40px;align-items:center;gap:12px;display:grid}.hbar-item .hbar-label{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.hbar-item .hbar-track{background:#1677ff14;border-radius:4px;height:8px;overflow:hidden}.hbar-item .hbar-track i{background:linear-gradient(90deg, var(--blue), var(--teal));border-radius:4px;height:100%;transition:width .8s;display:block}.hbar-item .hbar-value{color:var(--text-muted);text-align:right;font-size:11px;font-weight:600}.score-ring{flex-shrink:0;width:140px;height:140px;position:relative}.score-ring svg{transform:rotate(-90deg)}.score-ring .score-value{text-align:center;place-items:center;display:grid;position:absolute;inset:0}.score-ring .score-value b{color:var(--text-primary);font-size:34px;font-weight:800;display:block}.score-ring .score-value span{color:var(--text-muted);font-size:10px;display:block}.risk-donut{align-items:center;gap:24px;width:100%;padding:4px 0;display:flex}.risk-donut-chart{border-radius:50%;flex-shrink:0;width:76px;height:76px}.risk-donut-legend{flex:1;gap:7px;display:grid}.risk-donut-legend .rl-item{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:4px 0;font-size:12px;display:flex}.risk-donut-legend .rl-item:last-child{border-bottom:none}.gateway-board{gap:7px;display:grid}.gateway-item{border-radius:var(--radius-sm);background:var(--border-light);border:1px solid var(--border);align-items:center;gap:10px;padding:10px 14px;transition:all .15s;display:flex}.gateway-item:hover{background:var(--blue-bg)}.gateway-item .gw-dot{border-radius:50%;width:7px;height:7px}.gateway-item .gw-dot.online{background:var(--green);box-shadow:0 0 6px #00a8544d}.gateway-item .gw-dot.offline{background:var(--red)}.gateway-item .gw-info b{color:var(--text-primary);font-size:12px;display:block}.gateway-item .gw-info span{color:var(--text-muted);font-size:10px;display:block}.process-steps{grid-template-columns:repeat(5,1fr);gap:8px;display:grid}.process-step{text-align:center;border-radius:var(--radius-md);border:1px solid var(--border-light);background:#fff;padding:14px 10px}.process-step .step-num{color:var(--blue);font-size:20px;font-weight:800}.process-step .step-text{color:var(--text-secondary);margin-top:4px;font-size:11px}.action-list{gap:8px;display:grid}.action-item{border-radius:var(--radius-md);border:1px solid var(--border-light);cursor:pointer;background:#fff;align-items:center;gap:10px;padding:10px 14px;transition:all .15s;display:flex}.action-item:hover{border-color:var(--blue)}.action-item .action-num{background:var(--blue-bg);width:26px;height:26px;color:var(--blue);border-radius:50%;place-items:center;font-size:12px;font-weight:700;display:grid}.action-item .action-text b{color:var(--text-primary);font-size:12px;display:block}.action-item .action-text span{color:var(--text-muted);margin-top:2px;font-size:11px;display:block}.btn{border-radius:var(--radius-sm);align-items:center;gap:5px;padding:7px 14px;font-size:12px;font-weight:500;transition:all .15s;display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--blue), var(--teal));color:#fff;box-shadow:0 6px 16px #1677ff2e}.btn-primary:hover{filter:brightness(1.04);transform:translateY(-1px);box-shadow:0 10px 24px #1677ff3d}.btn-action{letter-spacing:.02em;border-radius:999px;padding:8px 18px;font-weight:700}.btn-outline{border:1px solid var(--border);color:var(--text-secondary);background:0 0}.btn-outline:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-bg)}.btn-sm{padding:4px 10px;font-size:11px}.btn-danger{background:var(--red-bg);color:var(--red);border:1px solid #f5222d1a}.btn-danger:hover{background:#ffe8e6}.btn-success{background:var(--green-bg);color:var(--green)}.btn-success:hover{background:#e0f7ec}.btn-warning{background:var(--orange-bg);color:var(--orange)}.btn-warning:hover{background:#ffecd6}.btn-ghost{color:var(--text-muted);background:0 0}.btn-ghost:hover{color:var(--text-secondary);background:var(--border-light)}.toggle{cursor:pointer;width:38px;height:22px;display:inline-block;position:relative}.toggle input{display:none}.toggle .slider{background:#d0d5dd;border-radius:999px;transition:all .2s;position:absolute;inset:0}.toggle .slider:before{content:"";background:#fff;border-radius:50%;width:18px;height:18px;transition:all .2s;position:absolute;top:2px;left:2px}.toggle input:checked+.slider{background:var(--blue)}.toggle input:checked+.slider:before{transform:translate(16px)}.metric-row{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:6px 0;display:flex}.metric-row:last-child{border-bottom:none}.metric-row .ml{color:var(--text-muted);font-size:12px}.metric-row .mv{font-size:16px;font-weight:700}.empty{text-align:center;color:var(--text-muted);border:1px dashed var(--border);border-radius:var(--radius-md);background:#fafbfc;padding:36px 20px;font-size:12px}.modal-overlay{z-index:2000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000059;place-items:center;animation:.15s fadeIn;display:grid;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.login-modal{border:1px solid var(--border);border-radius:var(--radius-lg);background:#fff;width:380px;padding:36px 32px 28px;animation:.25s slideUp;box-shadow:0 16px 48px #0000001f}@keyframes slideUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.login-modal .login-logo{text-align:center;margin-bottom:28px}.login-modal .login-logo .logo-icon{border-radius:var(--radius-md);background:linear-gradient(135deg, var(--blue), var(--teal));color:#fff;place-items:center;width:46px;height:46px;font-size:20px;font-weight:900;display:inline-grid;box-shadow:0 2px 14px #1677ff40}.login-modal .login-logo h2{color:var(--text-primary);margin-top:10px;font-size:18px}.login-modal .login-logo p{color:var(--text-muted);margin-top:4px;font-size:12px}.form-group{margin-bottom:16px}.form-group label{color:var(--text-secondary);margin-bottom:6px;font-size:12px;font-weight:500;display:block}.form-group input{border-radius:var(--radius-sm);border:1px solid var(--border);width:100%;color:var(--text-primary);background:#f7f8fa;outline:none;padding:10px 12px;font-size:13px;transition:all .15s}.form-group input:focus{border-color:var(--blue);background:#fff;box-shadow:0 0 0 3px #1677ff14}.form-group input::placeholder{color:var(--text-muted)}.btn-login-modal{border-radius:var(--radius-sm);background:var(--blue);color:#fff;width:100%;margin-top:4px;padding:11px;font-size:14px;font-weight:600}.btn-login-modal:hover{background:var(--blue-light)}.login-error{color:var(--red);text-align:center;background:var(--red-bg);border-radius:var(--radius-sm);border:1px solid #f5222d1a;margin-bottom:14px;padding:8px 12px;font-size:12px}.policy-modal{border:1px solid var(--border);border-radius:var(--radius-lg);background:#fff;width:560px;max-height:85vh;padding:28px 28px 24px;animation:.25s slideUp;overflow-y:auto;box-shadow:0 16px 48px #0000001f}.policy-modal .pm-header{justify-content:space-between;align-items:center;margin-bottom:22px;display:flex}.policy-modal .pm-header h3{color:var(--text-primary);font-size:17px;font-weight:700}.policy-modal .pm-close{background:var(--border-light);width:28px;height:28px;color:var(--text-muted);cursor:pointer;border-radius:50%;place-items:center;font-size:16px;display:grid}.policy-modal .pm-close:hover{background:var(--red-bg);color:var(--red)}.policy-modal .form-row{margin-bottom:16px}.policy-modal .form-row label{color:var(--text-secondary);margin-bottom:6px;font-size:12px;font-weight:600;display:block}.policy-modal .form-row input,.policy-modal .form-row select,.policy-modal .form-row textarea{border-radius:var(--radius-sm);border:1px solid var(--border);width:100%;color:var(--text-primary);background:#f7f8fa;outline:none;padding:9px 12px;font-size:13px;transition:all .15s}.policy-modal .form-row input:focus,.policy-modal .form-row select:focus,.policy-modal .form-row textarea:focus{border-color:var(--blue);background:#fff;box-shadow:0 0 0 3px #1677ff14}.policy-modal .form-row textarea{resize:vertical;min-height:80px;font-family:Cascadia Code,Courier New,monospace;font-size:12px;line-height:1.5}.policy-modal .form-row select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='%23999db3' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;background-size:16px;padding-right:32px}.policy-modal .form-hint{color:var(--text-muted);margin-top:5px;font-size:11px}.policy-modal .pm-actions{border-top:1px solid var(--border-light);justify-content:flex-end;gap:10px;margin-top:20px;padding-top:16px;display:flex}.policy-modal .btn-cancel{border-radius:var(--radius-sm);border:1px solid var(--border);color:var(--text-secondary);background:0 0;padding:8px 18px;font-size:13px}.policy-modal .btn-cancel:hover{border-color:var(--border-hover)}.policy-modal .btn-submit{border-radius:var(--radius-sm);background:linear-gradient(135deg, var(--blue), var(--teal));color:#fff;padding:8px 22px;font-size:13px;font-weight:700;box-shadow:0 6px 16px #1677ff2e}.policy-modal .btn-submit:hover{filter:brightness(1.04);transform:translateY(-1px);box-shadow:0 10px 22px #1677ff3d}.policy-modal .btn-submit:disabled{opacity:.5;cursor:not-allowed}.event-detail-modal{border:1px solid var(--border);border-radius:var(--radius-lg);background:#fff;width:560px;max-height:80vh;padding:28px 28px 24px;animation:.25s slideUp;overflow-y:auto;box-shadow:0 16px 48px #0000001f}.event-detail-modal .ed-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.event-detail-modal .ed-header h3{color:var(--text-primary);font-size:17px;font-weight:700}.event-detail-modal .ed-close{background:var(--border-light);width:28px;height:28px;color:var(--text-muted);cursor:pointer;border-radius:50%;place-items:center;display:grid}.event-detail-modal .ed-close:hover{background:var(--red-bg);color:var(--red)}.event-detail-modal .ed-field{margin-bottom:16px}.event-detail-modal .ed-field .ed-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px;font-size:11px;font-weight:600}.event-detail-modal .ed-field .ed-value{color:var(--text-primary);font-size:13px}.event-detail-modal .ed-field .ed-prompt{color:var(--text-secondary);border:1px solid var(--border-light);border-radius:var(--radius-sm);white-space:pre-wrap;word-break:break-all;background:#f7f8fa;max-height:160px;padding:12px;font-family:Cascadia Code,Courier New,monospace;font-size:12px;line-height:1.6;overflow-y:auto}.dropdown{display:inline-flex;position:relative}.dropdown-menu{border-radius:var(--radius-md);border:1px solid var(--border);z-index:200;background:#fff;min-width:180px;padding:4px;animation:.12s slideUp;position:absolute;top:calc(100% + 4px);left:0;box-shadow:0 8px 32px #0000001f}.dropdown-menu .dropdown-item{border-radius:var(--radius-sm);width:100%;color:var(--text-secondary);cursor:pointer;text-align:left;background:0 0;align-items:center;gap:8px;padding:9px 12px;font-size:13px;transition:all .12s;display:flex}.dropdown-menu .dropdown-item svg{opacity:.65;flex-shrink:0;width:15px;height:15px}.dropdown-menu .dropdown-item:hover{background:var(--blue-bg);color:var(--blue)}.page-toolbar{justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.toolbar-title b{color:var(--text-primary);font-size:15px;display:block}.toolbar-title span{color:var(--text-muted);margin-top:3px;font-size:11px;display:block}.inline-form{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.inline-form select,.inline-form input{border:1px solid var(--border);border-radius:var(--radius-sm);height:34px;color:var(--text-primary);background:#f7f8fa;outline:none;padding:0 10px;font-size:12px;transition:all .12s}.inline-form select:focus,.inline-form input:focus{border-color:var(--blue);background:#fff;box-shadow:0 0 0 2px #1677ff14}.node-cell{align-items:center;gap:10px;display:flex}.node-cell .initial{border-radius:var(--radius-sm);color:#fff;background:linear-gradient(135deg, var(--blue), var(--teal));place-items:center;width:30px;height:30px;font-size:12px;font-weight:700;display:grid}.node-cell .node-meta b{color:var(--text-primary);font-size:13px;display:block}.node-cell .node-meta span{text-overflow:ellipsis;white-space:nowrap;max-width:420px;color:var(--text-muted);margin-top:2px;font-size:11px;display:block;overflow:hidden}.secret-box{border-radius:var(--radius-md);background:var(--blue-bg);border:1px solid #1677ff1f;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;padding:12px 14px;display:flex}.secret-box code{color:var(--blue);word-break:break-all;font-family:Cascadia Code,Courier New,monospace;font-size:13px}.key-generated{background:linear-gradient(135deg,#1677ff14,#08a89d1a);border-color:#08a89d38;align-items:flex-start}.key-generated b{color:var(--text-primary);margin-bottom:6px;display:block}.key-preview{justify-content:flex-start}.profile-card{gap:12px;display:grid}.profile-card b{color:var(--text-primary);margin-bottom:4px;font-size:12px;display:block}.profile-card span{color:var(--text-secondary);font-size:12px}.mini-trend{border-top:1px solid var(--border-light);align-items:flex-end;gap:8px;min-height:78px;padding-top:8px;display:flex}.mini-bar{color:var(--text-muted);justify-items:center;gap:4px;font-size:10px;display:grid}.mini-bar i{background:linear-gradient(180deg, var(--blue), var(--teal));border-radius:6px 6px 2px 2px;width:12px;display:block}.status-dot-mini{border-radius:50%;width:8px;height:8px;display:inline-block}.status-dot-mini.pending{background:var(--orange)}.status-dot-mini.approved{background:var(--green)}.status-dot-mini.rejected{background:var(--red)}.admin-section-note{border-radius:var(--radius-sm);background:var(--orange-bg);color:#d46b08;border:1px solid #fa8c161f;align-items:center;gap:8px;padding:10px 14px;font-size:12px;display:flex}.search-input{border-radius:var(--radius-sm);border:1px solid var(--border);color:var(--text-primary);background:#f7f8fa;outline:none;width:200px;padding:8px 12px 8px 34px;font-size:12px;transition:all .12s}.search-input:focus{border-color:var(--blue);background:#fff;box-shadow:0 0 0 2px #1677ff14}.btn-icon{border-radius:var(--radius-sm);width:30px;height:30px;color:var(--text-muted);background:0 0;place-items:center;transition:all .12s;display:grid}.btn-icon:hover{background:var(--red-bg);color:var(--red)}.btn-icon svg{width:15px;height:15px}@keyframes fadeInUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.page-enter{animation:.3s fadeInUp}.breadcrumb{border:1px solid var(--border);color:var(--text-secondary);box-shadow:var(--shadow-sm);background:#fff;border-radius:999px;align-items:center;gap:8px;margin:0 0 14px;padding:7px 16px;font-size:12px;display:inline-flex}.breadcrumb b{color:var(--text-muted);font-weight:500}.breadcrumb span:last-child{color:var(--text-primary);font-weight:700}.situation-screen{--neon:#00d2ff;--neon-blue:#005bb5;--neon-red:#ff3b30;--neon-yellow:#ff9500;--bg-dark:#07111c;--panel-bg:#0b1a2abf;--border:#00d2ff4d;--text:#c0d8f0;--muted:#6889a6;background:var(--bg-dark);height:calc(100vh - 56px);color:var(--text);font-family:Rajdhani,Segoe UI,PingFang SC,sans-serif;position:relative;overflow:hidden}.ss-grid-bg{z-index:0;background-image:linear-gradient(#00d2ff0a 1px,#0000 1px),linear-gradient(90deg,#00d2ff0a 1px,#0000 1px);background-size:40px 40px;width:200vw;height:200vh;animation:20s linear infinite gridDrift;position:absolute;top:-50%;left:-50%;transform:perspective(600px)rotateX(45deg)}@keyframes gridDrift{0%{transform:perspective(600px)rotateX(45deg)translateY(0)}to{transform:perspective(600px)rotateX(45deg)translateY(40px)}}.ss-header{z-index:10;-webkit-backdrop-filter:blur(16px);background:#0b1a2a66;border-bottom:1px solid #00d2ff33;justify-content:center;align-items:center;height:56px;display:flex;position:relative}.ss-header:before,.ss-header:after{content:"";background:linear-gradient(90deg, transparent, var(--neon), transparent);width:220px;height:1px;position:absolute;top:50%}.ss-header:before{left:40px}.ss-header:after{right:40px}.ss-header h1{letter-spacing:3px;color:#fff;text-shadow:0 0 12px var(--neon);font-size:22px;font-weight:700}.ss-header .ver{color:var(--neon);vertical-align:super;margin-left:6px;font-size:11px}.ss-clock{z-index:11;color:var(--muted);text-align:right;font-family:monospace;font-size:12px;position:absolute;top:50%;right:24px;transform:translateY(-50%)}.ss-clock b{color:var(--text);font-size:16px;display:block}.ss-body{z-index:10;grid-template-columns:310px 1fr 310px;gap:16px;height:calc(100% - 56px);padding:16px;display:grid;position:relative}.ss-side{flex-direction:column;gap:12px;display:flex;overflow-y:auto}.ss-card{border:1px solid var(--border);-webkit-backdrop-filter:blur(20px);background:#0b1a2a73;border-radius:8px;flex-shrink:0;position:relative;overflow:hidden}.ss-card:before,.ss-card:after{content:"";border:2px solid var(--neon);border-radius:2px;width:10px;height:10px;position:absolute}.ss-card:before{border-bottom:none;border-right:none;top:-1px;left:-1px}.ss-card:after{border-top:none;border-left:none;bottom:-1px;right:-1px}.ss-card:hover{box-shadow:0 0 16px #00d2ff1f}.ss-card-head{letter-spacing:1px;color:#fff;background:linear-gradient(90deg,#00d2ff1a,#0000);border-bottom:1px solid #00d2ff33;justify-content:space-between;align-items:center;padding:8px 15px;font-size:11px;font-weight:700;display:flex}.ss-card-body{flex:1;padding:14px}.ss-kpi{grid-template-columns:1fr 1fr;gap:8px;display:grid}.ss-kpi-item{text-align:center;background:#00d2ff0a;border:1px solid #00d2ff14;border-radius:4px;padding:10px 6px}.ss-kpi-item .v{font-family:D-DIN,monospace;font-size:26px;font-weight:700;line-height:1;display:block}.ss-kpi-item .l{color:var(--muted);letter-spacing:1px;text-transform:uppercase;margin-top:3px;font-size:10px;display:block}.ss-prog{margin:8px 0}.ss-prog .pr{justify-content:space-between;margin-bottom:4px;font-size:11px;display:flex}.ss-prog .pr span{color:var(--muted)}.ss-prog .pr b{color:var(--text);font-family:monospace}.ss-prog .pt{background:#00d2ff14;border-radius:99px;height:5px;overflow:hidden}.ss-prog .pt i{border-radius:inherit;background:var(--neon);height:100%;box-shadow:0 0 6px var(--neon);transition:width .8s;display:block}.ss-zlist{gap:4px;display:grid}.ss-zrow{background:#00d2ff05;border:1px solid #00d2ff0a;border-radius:6px;align-items:center;gap:8px;padding:7px 10px;display:flex}.ss-zrow:hover{border-color:#00d2ff26}.ss-zrow .zd{border-radius:3px;flex-shrink:0;width:8px;height:8px}.ss-zrow .zi{flex:1;min-width:0}.ss-zrow .zi b{color:var(--text);font-size:11px;display:block}.ss-zrow .zi span{color:var(--muted);margin-top:1px;font-size:10px;display:block}.ss-zrow .zr{font-family:monospace;font-size:11px}.ss-alerts{gap:3px;display:grid}.ss-alert{background:#00d2ff05;border-bottom:1px dashed #00d2ff1a;border-radius:4px;align-items:center;gap:8px;padding:7px 10px;display:flex}.ss-alert .ad{border-radius:50%;flex-shrink:0;width:6px;height:6px}.ss-alert .at{flex:1;min-width:0}.ss-alert .at b{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:11px;display:block;overflow:hidden}.ss-alert .at span{color:var(--muted);margin-top:1px;font-size:9px;display:block}.ss-alert .al{white-space:nowrap;font-family:monospace;font-size:10px}.ss-feed{gap:3px;display:grid}.ss-feed-item{background:#00d2ff05;border-radius:3px;align-items:center;gap:8px;padding:5px 8px;font-size:11px;display:flex}.ss-feed-item .fd{border-radius:50%;flex-shrink:0;width:5px;height:5px}.ss-feed-item .ft{color:var(--text);flex:1}.ss-feed-item .fv{color:var(--muted);font-family:monospace}.ss-none{color:#305870;text-align:center;padding:10px;font-size:11px}.ss-center{min-width:0;min-height:0}.ss-topo{border:1px solid var(--border);-webkit-backdrop-filter:blur(8px);background:#0b1a2a4d;border-radius:8px;height:100%;position:relative;overflow:hidden}.ss-topo:before{content:"";z-index:0;pointer-events:none;background:radial-gradient(circle,#00d2ff0f 0%,#0000 60%);position:absolute;inset:0}.ss-topo-svg{width:100%;height:100%;position:absolute;inset:0}.ss-topo-svg .base-line{fill:none;stroke:#00d2ff1a;stroke-width:.8px;stroke-dasharray:4 4}.ss-topo-svg .flow-line{fill:none;stroke-width:1.5px;stroke-dasharray:10 40;filter:url(#neonGlow);animation:2.5s linear infinite flowDash}.ss-topo-svg .flow-line.risk{stroke:var(--neon-red)}.ss-hub{z-index:5;justify-content:center;align-items:center;width:140px;height:140px;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.ss-hub .r1,.ss-hub .r2{border:1.5px dashed var(--neon);border-radius:50%;position:absolute}.ss-hub .r1{width:100%;height:100%;animation:15s linear infinite rotate}.ss-hub .r2{border-style:dotted;border-color:#fff6;width:70%;height:70%;animation:10s linear infinite rotateRev}.ss-hub .core{background:radial-gradient(circle, var(--neon) 0%, transparent 80%);border-radius:50%;justify-content:center;align-items:center;width:45%;height:45%;display:flex;box-shadow:0 0 30px #00d2ff80}.ss-hub .core i{border:2px solid #fff;border-radius:50%;width:20px;height:20px}.ss-hub .lbl{text-align:center;color:#fff;text-shadow:0 0 6px var(--neon);white-space:nowrap;font-size:13px;font-weight:700;position:absolute;bottom:-38px}.ss-hub .lbl span{color:var(--muted);font-size:9px;font-weight:400;display:block}.ss-node{z-index:4;align-items:center;display:flex;position:absolute;transform:translate(-50%,-50%)}.ss-node .nr{justify-content:center;align-items:center;width:64px;height:64px;display:flex;position:relative}.ss-node .nr .out{border:2px solid var(--neon);border-radius:50%;animation:2s infinite pulse;position:absolute;inset:0}.ss-node .nr .in{-webkit-backdrop-filter:blur(6px);background:#00d2ff14;border-radius:50%;position:absolute;inset:15%}.ss-node .nr .icon{z-index:2;font-size:20px;position:relative}.ss-node.risk .nr .out{border-color:var(--neon-red);animation:1s infinite pulseAlert;box-shadow:0 0 20px #ff3b3066}.ss-node.risk .nr .in{background:#ff3b3026}.ss-node .tip{border:1px solid var(--border);z-index:10;-webkit-backdrop-filter:blur(8px);background:#07111ce0;border-radius:6px;width:130px;padding:8px;font-size:10px;position:absolute}.ss-node .tip.left{right:72px}.ss-node .tip.right{left:72px}.ss-node .tip .th{color:#fff;border-bottom:1px solid var(--border);margin-bottom:4px;padding-bottom:4px;font-weight:700}.ss-node .tip .tb{color:var(--muted)}.ss-node .tip .tb .v{color:#fff}.ss-node .tip .ts{justify-content:space-between;margin-top:4px;display:flex}.ss-node .tip .ts .d{background:var(--neon);width:5px;height:5px;box-shadow:0 0 4px var(--neon);vertical-align:middle;border-radius:50%;margin-right:2px;display:inline-block}.ss-node.risk .tip .ts .d{background:var(--neon-red);box-shadow:0 0 4px var(--neon-red)}.ss-inet{z-index:5;justify-content:center;align-items:center;width:100px;height:100px;display:flex;position:absolute;top:46%;right:2%;transform:translateY(-50%)}.ss-inet-ring{border:1.5px dashed var(--neon);border-radius:50%;width:100%;height:100%;animation:20s linear infinite rotate;position:absolute}.ss-inet-ring.small{border-style:dotted;border-color:#ffffff4d;width:65%;height:65%;animation-duration:14s;animation-direction:reverse}.ss-inet-core{background:radial-gradient(circle,#2080c0 0%,#0000 80%);border-radius:50%;width:40%;height:40%;box-shadow:0 0 20px #00d2ff4d}.ss-inet-lbl{text-align:center;color:#fff;text-shadow:0 0 6px var(--neon);white-space:nowrap;font-size:12px;font-weight:700;position:absolute;bottom:-36px}.ss-inet-lbl span{color:var(--muted);font-size:9px;font-weight:400;display:block}@keyframes rotate{to{transform:rotate(360deg)}}@keyframes rotateRev{to{transform:rotate(-360deg)}}@keyframes pulse{0%{box-shadow:0 0 #00d2ff4d}70%{box-shadow:0 0 0 14px #00d2ff00}to{box-shadow:0 0 #00d2ff00}}@keyframes pulseAlert{0%{box-shadow:0 0 #ff3b3080}70%{box-shadow:0 0 0 18px #ff3b3000}}@media (width<=1300px){.kpi-row,.grid-4{grid-template-columns:repeat(2,1fr)}.ss-body{grid-template-columns:270px 1fr 270px}}
