*{box-sizing:border-box;margin:0;padding:0}:root,[data-theme=dark]{--bg-primary:#212529;--bg-secondary:#2a2f34;--bg-card:#2a2f34;--bg-hover:#32383e;--border:#32383e;--text-primary:#ced4da;--text-secondary:#adb5bd;--text-muted:#878a99;--accent:#4f6bdb;--accent-light:#8b9cf7;--header-bg:#2a2f34;--header-dark:#212529;--success:#0ab39c;--warning:#f7b84b;--danger:#f06548;--info:#299cdb;--teal:#4f6bdb;--teal-light:#8b9cf7;--gold:#f7b84b;--nrs-red:#c00;--nrs-grey:#4f6bdb;--nrs-grey-light:#8b9cf7;--shadow-sm:0 1px 2px #00000014;--shadow:0 2px 6px #00000026;--shadow-md:0 4px 12px #0000001f;--shadow-lg:0 8px 24px #0000002e;--chart-grid:#ffffff0f;--chart-text:#adb5bd;--chart-tooltip-bg:#2a2f34;--chart-tooltip-border:#32383e;--chart-tooltip-text:#ced4da;--leaflet-bg:#212529;--leaflet-attr-bg:#2a2f34cc;--leaflet-attr-text:#878a99;--map-tile-filter:none;--sidebar-bg:#2a2f34;--sidebar-menu-bg:#212529;--sidebar-active-bg:#4f6bdb26;--sidebar-active-color:#8b9cf7;--topbar-bg:#2a2f34;--topbar-text:#ced4da;--topbar-border:#32383e;--input-bg:#212529;--input-border:#32383e;--badge-soft-success-bg:#0ab39c1a;--badge-soft-success-text:#0ab39c;--badge-soft-danger-bg:#f065481a;--badge-soft-danger-text:#f06548;--badge-soft-warning-bg:#f7b84b1a;--badge-soft-warning-text:#f7b84b;--badge-soft-info-bg:#299cdb1a;--badge-soft-info-text:#299cdb;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--font-xs:11px;--font-sm:12px;--font-base:13px;--font-md:14px;--font-lg:16px;--font-xl:20px;--font-2xl:24px;--weight-normal:400;--weight-medium:500;--weight-semibold:600;--weight-bold:700;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-full:9999px;--transition-fast:.15s ease;--transition-normal:.25s ease;--transition-slow:.35s ease}[data-theme=light]{--bg-primary:#f5f7fa;--bg-secondary:#fff;--bg-card:#fff;--bg-hover:#edf0f5;--border:#dfe3eb;--text-primary:#212529;--text-secondary:#495057;--text-muted:#6c757d;--accent:#3d5bd6;--accent-light:#3d5bd6;--header-bg:#fff;--header-dark:#f5f7fa;--success:#0ab39c;--warning:#f7b84b;--danger:#f06548;--info:#299cdb;--teal:#3d5bd6;--teal-light:#5c6670;--gold:#c5960c;--nrs-red:#c00;--nrs-grey:#3d5bd6;--nrs-grey-light:#5c6670;--shadow-sm:0 1px 2px #38414a0f;--shadow:0 2px 6px #38414a1a;--shadow-md:0 4px 12px #38414a14;--shadow-lg:0 8px 24px #38414a1f;--chart-grid:#0000000f;--chart-text:#495057;--chart-tooltip-bg:#fff;--chart-tooltip-border:#dfe3eb;--chart-tooltip-text:#212529;--leaflet-bg:#f5f7fa;--leaflet-attr-bg:#ffffffe6;--leaflet-attr-text:#6c757d;--map-tile-filter:none;--sidebar-bg:#fff;--sidebar-menu-bg:#f5f7fa;--sidebar-active-bg:#3d5bd61a;--sidebar-active-color:#3d5bd6;--topbar-bg:#fff;--topbar-text:#495057;--topbar-border:#dfe3eb;--input-bg:#fff;--input-border:#c5ccd6;--badge-soft-success-bg:#0ab39c1a;--badge-soft-success-text:#0ab39c;--badge-soft-danger-bg:#f065481a;--badge-soft-danger-text:#f06548;--badge-soft-warning-bg:#f7b84b1a;--badge-soft-warning-text:#f7b84b;--badge-soft-info-bg:#299cdb1a;--badge-soft-info-text:#299cdb}body{background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;line-height:1.5}#root{min-height:100vh;display:flex}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}.login-page{background:var(--bg-primary);justify-content:center;align-items:center;width:100%;min-height:100vh;padding:20px;display:flex}.login-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg,16px);width:100%;max-width:460px;box-shadow:var(--shadow-lg);padding:48px 40px;animation:.5s ease-out fadeIn}.login-header{text-align:center;margin-bottom:32px}.login-logo-img{object-fit:contain;border-radius:6px;width:auto;height:64px;margin-bottom:12px}.login-title{color:var(--text-primary);letter-spacing:-.5px;margin-bottom:4px;font-size:24px;font-weight:700}.login-subtitle{color:var(--text-muted);font-size:13px}.auth-tabs{background:var(--bg-primary);border-radius:10px;gap:4px;margin-bottom:24px;padding:4px;display:flex}.auth-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;flex:1;justify-content:center;align-items:center;gap:8px;padding:10px 16px;font-size:13px;font-weight:600;transition:all .2s;display:flex}.auth-tab:hover{color:var(--text-secondary)}.auth-tab.active{background:var(--bg-secondary);color:var(--text-primary);box-shadow:0 1px 3px #00000026}.auth-tab svg{flex-shrink:0}.login-form{flex-direction:column;gap:20px;display:flex}.login-error{color:#ef4444;text-align:center;background:#ef44441f;border:1px solid #ef44444d;border-radius:8px;padding:10px 14px;font-size:13px}.login-field{flex-direction:column;gap:6px;display:flex}.login-field label{color:var(--text-secondary);font-size:13px;font-weight:500}.login-field input,.login-select{background:var(--input-bg,var(--bg-primary));border:1px solid var(--input-border,var(--border));width:100%;color:var(--text-primary);transition:border-color var(--transition-fast,.15s ease), box-shadow var(--transition-fast,.15s ease);border-radius:8px;outline:none;padding:12px 14px;font-size:14px}.login-field input:focus,.login-select:focus{border-color:var(--teal);box-shadow:0 0 0 3px #4f6bdb26}.login-field input::placeholder{color:var(--text-muted)}.login-select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%235C6670' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;padding-right:36px}.login-select option{background:var(--bg-secondary);color:var(--text-primary)}.password-wrapper{position:relative}.password-wrapper input{padding-right:44px}.password-toggle{color:var(--text-muted);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:4px;transition:color .2s;display:flex;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.password-toggle:hover{color:var(--text-primary)}.login-submit{background:var(--teal);color:#fff;cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;width:100%;margin-top:4px;padding:12px;font-size:15px;font-weight:600;transition:background .2s,opacity .2s;display:flex}.login-submit:hover:not(:disabled){filter:brightness(1.1);box-shadow:var(--shadow-md,0 4px 12px #0000001f)}.login-submit:active:not(:disabled){transform:scale(.98)}.login-submit:disabled{opacity:.7;cursor:not-allowed}.system-status-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;margin-top:24px;padding:0;transition:border-color .3s;overflow:hidden}.system-status-panel.all-online{border-color:#5c66704d}.system-status-panel.has-offline{border-color:#ef44444d}.system-status-header{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:6px;font-size:12px;font-weight:600;display:flex}.system-status-toggle{cursor:pointer;background:0 0;border:none;width:100%;margin-bottom:0;padding:12px 16px}.system-status-toggle:hover{background:var(--bg-hover)}.system-status-header svg{color:var(--text-muted)}.system-status-badge{text-transform:none;letter-spacing:0;border-radius:10px;margin-left:auto;padding:2px 8px;font-size:10px;font-weight:600}.system-status-badge.online{color:#22c55e;background:#22c55e1f}.system-status-badge.degraded{color:#f59e0b;background:#f59e0b26}.system-status-grid{flex-direction:column;gap:8px;padding:0 16px 14px;display:flex}.status-item{align-items:center;gap:8px;font-size:12px;display:flex}.status-indicator{border-radius:50%;flex-shrink:0;width:8px;height:8px;position:relative}.status-indicator.online{background:#22c55e;box-shadow:0 0 6px #22c55e80}.status-indicator.offline{background:#ef4444;box-shadow:0 0 6px #ef444466}.status-indicator.checking{background:#f59e0b;animation:1.5s ease-in-out infinite pulse-dot}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}.status-label{color:var(--text-secondary);flex:1}.status-value{font-size:11px;font-weight:600}.status-value.online{color:#22c55e}.status-value.offline{color:#ef4444}.status-value.checking{color:#f59e0b}.login-footer{text-align:center;border-top:1px solid var(--border);color:var(--text-muted);margin-top:24px;padding-top:20px;font-size:11px}@media (width<=480px){.login-card{padding:28px 20px}.auth-tab span{font-size:12px}}.mfa-page{background:var(--bg-primary);justify-content:center;align-items:center;width:100%;min-height:100vh;padding:20px;display:flex}.mfa-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:16px;width:100%;max-width:420px;padding:40px 36px;animation:.5s ease-out fadeIn}.mfa-header{text-align:center;margin-bottom:28px}.mfa-icon{color:#5c6670;background:#5c66701f;border-radius:14px;justify-content:center;align-items:center;width:56px;height:56px;margin-bottom:16px;display:inline-flex}.mfa-title{color:var(--text-primary);margin-bottom:6px;font-size:22px;font-weight:700}.mfa-subtitle{color:var(--text-muted);font-size:13px;line-height:1.5}.mfa-error{color:#ef4444;text-align:center;background:#ef44441f;border:1px solid #ef44444d;border-radius:8px;margin-bottom:20px;padding:10px 14px;font-size:13px}.mfa-code-section{flex-direction:column;gap:20px;display:flex}.mfa-digit-inputs{justify-content:center;gap:8px;display:flex}.mfa-digit{text-align:center;width:48px;height:56px;color:var(--text-primary);background:var(--input-bg);border:1px solid var(--input-border);caret-color:var(--teal);border-radius:10px;outline:none;font-size:22px;font-weight:600;transition:border-color .2s}.mfa-digit:focus{border-color:var(--teal);box-shadow:0 0 0 2px #40518933}.mfa-submit{background:var(--teal);color:#fff;cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;width:100%;padding:12px;font-size:15px;font-weight:600;transition:background .2s,opacity .2s;display:flex}.mfa-submit:hover:not(:disabled){background:var(--accent)}.mfa-submit:disabled{opacity:.7;cursor:not-allowed}.mfa-backup-form{flex-direction:column;gap:16px;display:flex}.mfa-backup-input{background:var(--input-bg);border:1px solid var(--input-border);width:100%;color:var(--text-primary);text-align:center;letter-spacing:2px;border-radius:8px;outline:none;padding:12px 14px;font-family:monospace;font-size:15px;transition:border-color .2s}.mfa-backup-input:focus{border-color:var(--teal)}.mfa-backup-input::placeholder{color:var(--text-muted);letter-spacing:normal;font-family:inherit}.mfa-links{border-top:1px solid var(--border);flex-direction:column;align-items:center;gap:10px;margin-top:24px;padding-top:20px;display:flex}.mfa-link{color:var(--teal);cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;font-size:13px;transition:color .2s;display:flex}.mfa-link:hover{color:var(--teal-light)}.mfa-back{color:var(--text-muted)}.mfa-back:hover{color:var(--text-primary)}@media (width<=420px){.mfa-card{padding:28px 20px}.mfa-digit{width:42px;height:50px;font-size:20px}.mfa-digit-inputs{gap:6px}}.spin{animation:1s linear infinite spin}.mfa-setup-page{background:var(--bg-primary);justify-content:center;align-items:center;width:100%;min-height:100vh;padding:20px;display:flex;overflow-y:auto}.mfa-setup-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:16px;width:100%;max-width:520px;margin:20px 0;padding:40px 36px;animation:.5s ease-out fadeIn}.mfa-setup-loading{color:var(--text-muted);flex-direction:column;align-items:center;gap:16px;padding:40px 0;display:flex}.mfa-setup-header{text-align:center;margin-bottom:32px}.mfa-setup-icon{color:#5c6670;background:#5c66701f;border-radius:14px;justify-content:center;align-items:center;width:56px;height:56px;margin-bottom:16px;display:inline-flex}.mfa-setup-icon.success{color:#22c55e;background:#22c55e1f}.mfa-setup-title{color:var(--text-primary);margin-bottom:6px;font-size:22px;font-weight:700}.mfa-setup-subtitle{color:var(--text-muted);font-size:13px}.mfa-setup-steps{flex-direction:column;gap:28px;display:flex}.setup-step{gap:16px;display:flex}.step-number{color:#5c6670;background:#5c667026;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;margin-top:2px;font-size:13px;font-weight:700;display:flex}.step-content{flex:1;min-width:0}.step-content h3{color:var(--text-primary);margin-bottom:6px;font-size:15px;font-weight:600}.step-content p{color:var(--text-muted);margin-bottom:10px;font-size:13px;line-height:1.5}.app-list{flex-direction:column;gap:4px;list-style:none;display:flex}.app-list li{color:var(--text-secondary);padding-left:16px;font-size:13px;position:relative}.app-list li:before{content:"";background:var(--teal);border-radius:50%;width:6px;height:6px;position:absolute;top:7px;left:0}.qr-container{background:#fff;border-radius:12px;justify-content:center;width:fit-content;margin:12px 0;padding:16px;display:flex}.qr-image{width:180px;height:180px;display:block}.qr-placeholder{background:var(--input-bg);width:180px;height:180px;color:var(--text-muted);border-radius:12px;justify-content:center;align-items:center;margin:12px 0;display:flex}.manual-key{margin-top:12px}.manual-key-label{color:var(--text-muted);margin-bottom:6px;font-size:12px;display:block}.manual-key-value{background:var(--input-bg);border:1px solid var(--input-border);border-radius:8px;align-items:center;gap:8px;padding:8px 12px;display:flex}.manual-key-value code{color:var(--teal);letter-spacing:1px;word-break:break-all;flex:1;font-size:13px}.copy-secret-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;flex-shrink:0;align-items:center;padding:4px;transition:color .2s;display:flex}.copy-secret-btn:hover{color:var(--teal)}.mfa-setup-error{color:#ef4444;text-align:center;background:#ef44441f;border:1px solid #ef44444d;border-radius:8px;margin-bottom:12px;padding:8px 12px;font-size:13px}.mfa-setup-digit-inputs{justify-content:flex-start;gap:8px;margin-bottom:16px;display:flex}.mfa-setup-digit{text-align:center;width:48px;height:56px;color:var(--text-primary);background:var(--input-bg);border:1px solid var(--input-border);caret-color:var(--teal);border-radius:10px;outline:none;font-size:22px;font-weight:600;transition:border-color .2s}.mfa-setup-digit:focus{border-color:var(--teal);box-shadow:0 0 0 2px #40518933}.mfa-setup-submit{background:var(--teal);color:#fff;cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;width:100%;padding:12px;font-size:15px;font-weight:600;transition:background .2s,opacity .2s;display:flex}.mfa-setup-submit:hover:not(:disabled){background:var(--accent)}.mfa-setup-submit:disabled{opacity:.7;cursor:not-allowed}.backup-warning{color:#f59e0b;background:#f59e0b1a;border:1px solid #f59e0b4d;border-radius:8px;margin-bottom:20px;padding:12px 16px;font-size:13px;line-height:1.5}.backup-codes-grid{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:20px;display:grid}.backup-code{background:var(--input-bg);border:1px solid var(--input-border);color:var(--text-primary);text-align:center;letter-spacing:1px;border-radius:8px;padding:10px 14px;font-family:monospace;font-size:14px}.backup-actions{gap:10px;margin-bottom:20px;display:flex}.backup-btn{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:8px;flex:1;justify-content:center;align-items:center;gap:8px;padding:10px;font-size:13px;transition:all .2s;display:flex}.backup-btn:hover{background:var(--bg-hover);border-color:var(--teal);color:var(--text-primary)}.mfa-setup-continue{background:var(--teal);color:#fff;cursor:pointer;border:none;border-radius:8px;width:100%;padding:12px;font-size:15px;font-weight:600;transition:background .2s}.mfa-setup-continue:hover{background:var(--accent)}@media (width<=540px){.mfa-setup-card{padding:28px 20px}.mfa-setup-digit{width:42px;height:50px;font-size:20px}.mfa-setup-digit-inputs{gap:6px}.qr-image{width:150px;height:150px}}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md,10px);padding:var(--space-md,16px) var(--space-lg,24px);border-top:3px solid var(--stat-color,var(--teal));transition:transform var(--transition-fast,.15s ease), box-shadow var(--transition-fast,.15s ease);flex-direction:column;gap:4px;display:flex}.stat-card:hover{box-shadow:var(--shadow-md,0 4px 12px #0000001f);transform:translateY(-1px)}.stat-card-header{justify-content:space-between;align-items:center;display:flex}.stat-card-label{font-size:var(--font-xs,11px);font-weight:var(--weight-semibold,600);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.stat-card-icon{color:var(--stat-color,var(--accent));opacity:.5}.stat-card-value{font-size:22px;font-weight:var(--weight-bold,700);color:var(--text-primary)}.stat-card-subtitle{font-size:var(--font-xs,11px);color:var(--text-muted);margin-top:2px}.stat-card-trend{font-size:var(--font-xs,11px);font-weight:var(--weight-semibold,600);border-radius:var(--radius-full,9999px);align-items:center;gap:4px;width:fit-content;margin-top:6px;padding:3px 10px;display:flex}.stat-card-trend.up{color:#10b981;background:#10b9811a}.stat-card-trend.down{color:#ef4444;background:#ef44441a}.stat-card-trend-arrow{font-size:13px;font-weight:var(--weight-bold,700)}.stat-card-trend.up .stat-card-trend-arrow{animation:2s ease-in-out infinite trend-bounce-up}.stat-card-trend.down .stat-card-trend-arrow{animation:2s ease-in-out infinite trend-bounce-down}@keyframes trend-bounce-up{0%,to{transform:translateY(0)}50%{transform:translateY(-2px)}}@keyframes trend-bounce-down{0%,to{transform:translateY(0)}50%{transform:translateY(2px)}}.chart-card h3{font-size:var(--font-sm,12px);font-weight:var(--weight-bold,700);color:var(--text-muted);margin-bottom:var(--space-md,16px);text-transform:uppercase;letter-spacing:.4px}.chart-card-hdr{justify-content:space-between;align-items:center;margin-bottom:0;display:flex}.chart-card-hdr h3{margin-bottom:12px}.chart-expand-btn{border-radius:var(--radius-sm,6px);border:1px solid var(--border);background:var(--bg-hover);width:28px;height:28px;color:var(--text-muted);cursor:pointer;opacity:0;transition:opacity var(--transition-fast,.15s ease), background var(--transition-fast,.15s ease);flex-shrink:0;justify-content:center;align-items:center;display:flex}.chart-card:hover .chart-expand-btn{opacity:.6}.chart-expand-btn:hover{background:var(--bg-card);color:var(--text-primary);opacity:1!important}.chart-fullscreen-backdrop{z-index:999;background:#000000b3;animation:.2s chartFadeIn;position:fixed;inset:0}.chart-fullscreen{inset:var(--space-lg,24px);z-index:1000;background:var(--bg-card);border-radius:var(--radius-lg,16px);border:1px solid var(--border);flex-direction:column;animation:.25s cubic-bezier(.32,.72,0,1) chartScaleIn;display:flex;position:fixed;overflow:hidden;box-shadow:0 24px 80px #0006}.chart-fullscreen-header{padding:var(--space-md,16px) var(--space-lg,24px);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.chart-fullscreen-header h3{font-size:var(--font-lg,16px);font-weight:var(--weight-bold,700);color:var(--text-primary);text-transform:uppercase;letter-spacing:.3px;margin-bottom:0}.chart-fullscreen-body{padding:var(--space-lg,24px);flex:1;min-height:0;overflow:auto}.chart-fullscreen-body .recharts-responsive-container{min-height:500px;height:100%!important}.chart-fullscreen-body table{width:100%}.chart-fullscreen-body>div{height:100%}@keyframes chartFadeIn{0%{opacity:0}to{opacity:1}}@keyframes chartScaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.data-table-toolbar{padding:12px var(--space-md,16px);border-bottom:1px solid var(--border)}.data-table-search{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm,6px);width:100%;max-width:300px;color:var(--text-primary);font-size:var(--font-base,13px);transition:border-color var(--transition-fast,.15s ease), box-shadow var(--transition-fast,.15s ease);outline:none;padding:8px 12px}.data-table-search:focus{border-color:var(--teal);box-shadow:0 0 0 3px #4f6bdb1f}.data-table-search::placeholder{color:var(--text-muted)}.data-table-scroll{overflow-x:auto}.data-table th{text-align:left;padding:12px var(--space-md,16px);font-size:var(--font-sm,12px);font-weight:var(--weight-semibold,600);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);background:var(--bg-primary);white-space:nowrap;-webkit-user-select:none;user-select:none}.data-table th.sortable{cursor:pointer;transition:color var(--transition-fast,.15s ease)}.data-table th.sortable:hover{color:var(--text-primary)}.sort-indicator{opacity:.6;margin-left:2px;font-size:11px}.data-table td{padding:12px var(--space-md,16px);font-size:var(--font-base,13px);color:var(--text-secondary);border-bottom:1px solid var(--border)}.data-table tr{transition:background var(--transition-fast,.15s ease)}.data-table-empty{text-align:center;color:var(--text-muted);padding:40px var(--space-md,16px)!important}.data-table-pagination{padding:10px var(--space-md,16px);border-top:1px solid var(--border);font-size:var(--font-base,13px);color:var(--text-secondary);justify-content:space-between;align-items:center;display:flex}.data-table-page-size{align-items:center;gap:var(--space-sm,8px);display:flex}.data-table-page-size select{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm,6px);color:var(--text-primary);font-size:var(--font-sm,12px);padding:4px 8px}.data-table-page-nav{align-items:center;gap:10px;display:flex}.data-table-page-nav button{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-full,9999px);color:var(--text-secondary);font-size:var(--font-sm,12px);cursor:pointer;transition:all var(--transition-fast,.15s ease);padding:5px 12px}.data-table-page-nav button:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.data-table-page-nav button:disabled{opacity:.4;cursor:not-allowed}.filter-bar{align-items:center;gap:var(--space-md,16px);padding:10px var(--space-md,16px);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md,10px);flex-wrap:wrap;display:flex}.filter-bar-group{align-items:center;gap:var(--space-sm,8px);display:flex}.filter-bar-label{font-size:var(--font-xs,11px);color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}.filter-bar-buttons{background:var(--bg-primary);border-radius:var(--radius-sm,6px);gap:2px;padding:2px;display:flex}.filter-bar-btn{color:var(--text-secondary);font-size:var(--font-sm,12px);cursor:pointer;transition:all var(--transition-fast,.15s ease);background:0 0;border:none;border-radius:4px;padding:5px 12px}.filter-bar-btn:hover{color:var(--text-primary)}.filter-bar-btn.active{background:var(--teal);color:#fff}.filter-bar-select{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm,6px);color:var(--text-primary);font-size:var(--font-sm,12px);min-width:120px;transition:border-color var(--transition-fast,.15s ease);outline:none;padding:5px 10px}.filter-bar-select:focus{border-color:var(--teal)}.placeholder-view{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md,10px);min-height:400px;color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;display:flex}.placeholder-view h2{font-size:var(--font-xl,20px);font-weight:var(--weight-semibold,600);color:var(--text-primary);margin-bottom:var(--space-sm,8px)}.placeholder-view p{font-size:var(--font-md,14px);color:var(--text-muted)}.error-banner{align-items:center;gap:var(--space-md,16px);padding:var(--space-md,16px) 20px;border-radius:var(--radius-md,10px);background:#ef44440d;border:1px solid #ef444426;border-left:4px solid #ef4444;display:flex}.error-banner-icon{color:#ef4444;opacity:.8;flex-shrink:0}.error-banner-content{flex:1}.error-banner-title{font-size:var(--font-md,14px);font-weight:var(--weight-semibold,600);color:#ef4444;margin-bottom:4px}.error-banner-message{font-size:var(--font-sm,12px);color:var(--text-secondary);line-height:1.4}.error-banner-retry{padding:8px var(--space-md,16px);border-radius:var(--radius-sm,6px);color:#ef4444;font-size:var(--font-sm,12px);font-weight:var(--weight-semibold,600);cursor:pointer;transition:all var(--transition-fast,.15s ease);background:#ef44441a;border:1px solid #ef444440;flex-shrink:0;align-items:center;gap:6px;display:flex}.error-banner-retry:hover{background:#ef44442e}[data-theme=light] .stat-card,[data-theme=light] .chart-card,[data-theme=light] .data-table-wrap,[data-theme=light] .filter-bar,[data-theme=light] .funnel-container,[data-theme=light] .realtime-counter,[data-theme=light] .health-service-card,[data-theme=light] .placeholder-view{box-shadow:var(--shadow-sm,0 1px 2px #0000000f)}.db{flex-direction:column;gap:20px;padding-bottom:20px;display:flex}.kpi-row{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.kpi-tile{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;align-items:stretch;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden}.kpi-tile:after{content:"";pointer-events:none;opacity:0;background:linear-gradient(135deg,#ffffff08,#0000);border-radius:12px;transition:opacity .25s;position:absolute;inset:0}.kpi-tile:hover{border-color:#ffffff1f;transform:translateY(-2px);box-shadow:0 8px 32px #0000002e,0 2px 8px #0000001a}.kpi-tile:hover:after{opacity:1}.kpi-tile-accent{border-radius:4px 0 0 4px;flex-shrink:0;width:4px}.kpi-tile-body{flex:1;min-width:0;padding:18px 20px}.kpi-label{color:var(--text-muted);letter-spacing:.5px;text-transform:uppercase;margin-bottom:10px;font-size:12px;font-weight:600}.kpi-value{color:var(--text-primary);letter-spacing:-.5px;font-family:SF Mono,Fira Code,Consolas,monospace;font-size:28px;font-weight:800;line-height:1.1}.kpi-sub{color:var(--text-muted);align-items:center;gap:6px;margin-top:6px;font-size:12px;display:flex}.kpi-trend{border-radius:4px;align-items:center;gap:3px;padding:2px 6px;font-size:11px;font-weight:600;display:inline-flex}.kpi-trend.up{color:#22c55e;background:#22c55e1a}.kpi-trend.down{color:#ef4444;background:#ef44441a}.kpi-micro{opacity:.8;align-items:flex-end;padding:0 16px 14px 0;display:flex}.filter-strip{z-index:100;background:var(--bg-card);border:1px solid var(--border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:12px;align-items:flex-end;gap:12px;padding:14px 18px;display:flex;position:relative}.fs-group{flex-direction:column;gap:4px;min-width:130px;display:flex;position:relative}.fs-group.fs-grow{flex:1;min-width:200px}.fs-group label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:700}.fs-group input,.fs-group select{background:var(--bg-primary);border:1px solid var(--border);color:var(--text-primary);border-radius:8px;outline:none;padding:9px 14px;font-family:inherit;font-size:14px;transition:all .2s}.fs-group input:focus,.fs-group select:focus{border-color:var(--teal);box-shadow:0 0 0 3px #40518926}.fs-group select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23666' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding-right:28px}.fs-group select option{background:var(--bg-card);color:var(--text-primary)}.fs-clear{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;white-space:nowrap;background:0 0;border-radius:8px;padding:8px 14px;font-size:11px;font-weight:600;transition:all .2s}.fs-clear:hover{border-color:var(--accent);color:var(--accent);background:var(--badge-soft-danger-bg)}.fs-go{background:var(--teal);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:8px;align-self:flex-end;padding:8px 18px;font-size:12px;font-weight:600;transition:all .2s}.fs-go:hover{background:var(--accent)}.smart-search-wrap{align-items:center;display:flex;position:relative}.smart-search-icon{color:var(--text-muted);pointer-events:none;z-index:1;display:flex;position:absolute;left:12px}.smart-search-input{background:var(--bg-primary);border:1px solid var(--border);width:100%;color:var(--text-primary);border-radius:10px;outline:none;padding:10px 36px;font-size:14px;transition:border-color .2s,box-shadow .2s}.smart-search-input:focus{border-color:var(--accent,#4f6bdb);box-shadow:0 0 0 3px #4f6bdb1f}.smart-search-input::placeholder{color:var(--text-muted);opacity:.7}.smart-search-clear{background:var(--bg-hover);width:24px;height:24px;color:var(--text-muted);cursor:pointer;border:none;border-radius:6px;justify-content:center;align-items:center;transition:all .15s;display:flex;position:absolute;right:8px}.smart-search-clear:hover{background:var(--border);color:var(--text-primary)}.smart-dd{background:var(--bg-card);border:1px solid var(--border);z-index:1000;border-radius:12px;max-height:380px;animation:.15s ease-out smartDdIn;position:absolute;top:calc(100% + 6px);left:0;right:0;overflow-y:auto;box-shadow:0 12px 40px #0003,0 0 0 1px #0000000a}@keyframes smartDdIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.smart-dd-header{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);opacity:.7;align-items:center;gap:6px;padding:8px 14px 4px;font-size:10px;font-weight:700;display:flex}.smart-dd-item{cursor:pointer;border-left:3px solid #0000;padding:10px 14px;transition:all .12s}.smart-dd-item:hover,.smart-dd-item.active{background:var(--bg-hover);border-left-color:var(--accent,#4f6bdb)}.smart-dd-item.top-payer{background:#f59e0b0a}.smart-dd-item.top-payer.active,.smart-dd-item.top-payer:hover{background:#f59e0b14;border-left-color:#f59e0b}.smart-dd-row1{justify-content:space-between;align-items:center;gap:8px;margin-bottom:3px;display:flex}.smart-dd-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;min-width:0;font-size:13px;font-weight:600;overflow:hidden}.smart-dd-badges{flex-shrink:0;align-items:center;gap:4px;display:flex}.smart-dd-badges .badge-top{color:#d97706;background:#f59e0b26;border-radius:4px;align-items:center;gap:3px;padding:1px 6px;font-size:9px;font-weight:700;display:inline-flex}.smart-dd-badges .badge-sector{color:var(--accent,#4f6bdb);text-overflow:ellipsis;white-space:nowrap;background:#4f6bdb1a;border-radius:4px;max-width:100px;padding:1px 6px;font-size:9px;font-weight:600;overflow:hidden}.smart-dd-badges .badge-party{color:#6366f1;background:#6366f11f;border-radius:4px;padding:1px 5px;font-size:9px;font-weight:600}.smart-dd-row2{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.smart-dd-tin{color:var(--text-muted);background:var(--bg-hover);border-radius:4px;padding:1px 5px;font-family:SF Mono,Fira Code,monospace;font-size:11px}.smart-dd-meta{color:var(--text-muted);opacity:.8;font-size:10.5px}.smart-dd-meta:before{content:"·";opacity:.4;margin-right:6px}.smart-dd-empty{color:var(--text-muted);flex-direction:column;align-items:center;gap:6px;padding:28px 16px;font-size:13px;display:flex}.smart-dd-hint{opacity:.5;font-size:11px}.smart-dd-loading{padding:6px 0}.smart-dd-skeleton{flex-direction:column;gap:6px;padding:10px 14px;display:flex}.skel-line{background:linear-gradient(90deg, var(--bg-hover) 25%, var(--border) 50%, var(--bg-hover) 75%);background-size:200% 100%;border-radius:4px;height:10px;animation:1.2s ease-in-out infinite shimmer}.skel-w60{width:60%}.skel-w40{width:40%}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.fs-dd{display:none}.panel{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:20px 24px;transition:box-shadow .2s;overflow:hidden}.panel:hover{box-shadow:0 4px 20px #00000014}.sec-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;display:flex}.sec-head-left{align-items:center;gap:10px;display:flex}.sec-title{color:var(--text-primary);letter-spacing:-.2px;margin:0;font-size:16px;font-weight:700}.sec-count{color:var(--text-muted);background:var(--bg-primary);border:1px solid var(--border);letter-spacing:.3px;border-radius:12px;padding:2px 10px;font-size:11px;font-weight:700}.sec-icon{border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.geo-section{grid-template-columns:1fr 380px;gap:16px;min-height:520px;display:grid}.map-panel{z-index:1;border-radius:12px;position:relative;overflow:hidden;padding:0!important}.map-panel .nga-map-wrap{height:100%;min-height:520px;position:relative}.geo-sidebar{flex-direction:column;gap:16px;display:flex}.nga-map-wrap{height:100%;position:relative}.map-legend{z-index:1000;background:var(--bg-card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:10px;min-width:110px;padding:10px 14px;position:absolute;bottom:12px;right:12px}.map-legend-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:9px;font-weight:700}.map-legend-bar{border-radius:4px;gap:1px;height:8px;display:flex;overflow:hidden}.map-legend-seg{flex:1}.map-legend-labels{color:var(--text-muted);justify-content:space-between;margin-top:4px;font-size:9px;font-weight:500;display:flex}.map-info-badge{z-index:1000;background:var(--bg-card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border);color:var(--text-muted);border-radius:8px;align-items:center;gap:6px;padding:6px 12px;font-size:11px;font-weight:600;display:flex;position:absolute;top:12px;left:12px}.fiori-map-tip{box-shadow:none!important;background:0 0!important;border:none!important;padding:0!important}.fiori-map-tip:before{display:none!important}.map-tip-inner{background:var(--bg-card);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:10px;min-width:170px;padding:12px 14px;box-shadow:0 8px 32px #00000080}.map-tip-head{color:var(--text-primary);border-bottom:2px solid;align-items:center;gap:8px;margin-bottom:8px;padding-bottom:8px;font-size:14px;font-weight:700;display:flex}.map-tip-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;box-shadow:0 0 6px}.map-tip-badge{color:#ccc;background:#ffffff1f;border-radius:4px;margin-left:auto;padding:2px 6px;font-size:9px;font-weight:700}.map-tip-row{justify-content:space-between;gap:16px;font-size:12px;line-height:1.7;display:flex}.map-tip-row span{color:var(--text-muted)}.map-tip-row b{color:var(--text-secondary);font-family:SF Mono,monospace;font-weight:600}.city-lbl-tip{box-shadow:none!important;background:0 0!important;border:none!important;padding:0!important}.city-lbl-tip:before{display:none!important}.city-lbl{color:#ffffffd9;text-shadow:0 1px 6px #000000e6,0 0 20px #00000080;letter-spacing:.4px;font-size:10px;font-weight:700}.city-lbl-primary{color:#fff;font-size:12px}[data-theme=light] .city-lbl{color:#000000bf;text-shadow:0 1px 4px #ffffffe6,0 0 12px #ffffffb3}[data-theme=light] .city-lbl-primary{color:#000000e6;text-shadow:0 1px 4px #fffffff2,0 0 16px #fffc}.rank-list{flex-direction:column;gap:4px;display:flex}.rank-list-scroll{max-height:420px;padding-right:4px;overflow-y:auto}.rank-row{cursor:pointer;border-radius:8px;align-items:center;gap:12px;padding:10px;transition:all .15s;display:flex}.rank-row:hover{background:var(--bg-hover);transform:translate(2px)}.rank-active{background:var(--bg-hover);border-left:3px solid var(--teal);padding-left:7px}.rank-pos{text-align:center;flex-shrink:0;width:24px;font-size:14px;font-weight:800}.rank-detail{flex:1;min-width:0}.rank-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;margin-bottom:5px;font-size:14px;font-weight:500;overflow:hidden}.rank-bar{background:#5c66701a;border-radius:3px;height:4px;overflow:hidden}.rank-bar-fill{border-radius:3px;height:100%;transition:width .4s cubic-bezier(.4,0,.2,1)}.rank-val{color:var(--text-secondary);white-space:nowrap;font-family:SF Mono,monospace;font-size:13px;font-weight:700}.detail-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.detail-item{background:var(--bg-primary);border:1px solid var(--border);border-radius:8px;padding:12px;transition:border-color .15s}.detail-item:hover{border-color:var(--teal)}.detail-lbl{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-size:9px;font-weight:700}.detail-val{color:var(--text-primary);font-family:SF Mono,monospace;font-size:15px;font-weight:700}.detail-coord{color:var(--text-muted);border-top:1px solid var(--border);align-items:center;gap:6px;margin-top:10px;padding-top:10px;font-family:monospace;font-size:10px;display:flex}.detail-coord:before{content:"";background:var(--teal);border-radius:50%;flex-shrink:0;width:6px;height:6px}.dist-section{gap:16px;display:flex}.data-tbl{border-collapse:separate;border-spacing:0;width:100%;font-size:14px}.data-tbl th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;border-bottom:2px solid var(--border);white-space:nowrap;background:var(--bg-card);z-index:1;padding:12px 14px;font-size:12px;font-weight:700;position:sticky;top:0}.data-tbl th.r{text-align:right}.data-tbl td{color:var(--text-secondary);border-bottom:1px solid var(--border);white-space:nowrap;padding:12px 14px;transition:background .1s}.data-tbl td.r{text-align:right}.data-tbl tbody tr{transition:background .1s}.data-tbl tbody tr:hover td{background:var(--bg-hover)}.data-tbl tbody tr.tr-active td{background:#40518914}.data-tbl tbody tr:last-child td{border-bottom:none}.data-tbl tbody tr:nth-child(2n) td{background:#ffffff04}.data-tbl tbody tr:nth-child(2n):hover td{background:var(--bg-hover)}.data-tbl .tr-total td{border-top:2px solid var(--border);background:#4051890d;border-bottom:none;padding-top:12px}.st-indicator{vertical-align:middle;border-radius:2px;width:3px;height:16px;margin-right:10px;display:inline-block}.share-cell{justify-content:flex-end;align-items:center;gap:8px;display:flex}.share-bar{background:#5c667014;border-radius:3px;width:56px;height:5px;overflow:hidden}.share-bar>div{border-radius:3px;height:100%;transition:width .4s}.mono{font-family:SF Mono,Fira Code,Consolas,monospace}.tp-name{color:var(--text-primary);font-weight:600}.pie-legend{flex-wrap:wrap;justify-content:center;gap:8px;padding-top:12px;display:flex}.pie-legend-item{color:var(--text-muted);align-items:center;gap:5px;font-size:12px;font-weight:500;display:flex}.pie-legend-dot{border-radius:3px;flex-shrink:0;width:10px;height:10px}.type-cards{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.type-card{background:var(--bg-primary);border:1px solid var(--border);border-radius:10px;padding:16px 18px;transition:all .2s;position:relative;overflow:hidden}.type-card:hover{transform:translateY(-1px);box-shadow:0 4px 16px #0000001a}.type-card-bar{height:3px;position:absolute;top:0;left:0;right:0}.type-card-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;margin-bottom:6px;font-size:12px;font-weight:600}.type-card-value{color:var(--text-primary);font-family:SF Mono,monospace;font-size:24px;font-weight:800;line-height:1.2}.type-card-sub{color:var(--text-muted);margin-top:4px;font-family:SF Mono,monospace;font-size:12px}.empty-state{height:140px;color:var(--text-muted);justify-content:center;align-items:center;font-size:14px;font-weight:500;display:flex}.db-loading{justify-content:center;align-items:center;height:400px;display:flex}.db-spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:40px;height:40px;animation:.7s linear infinite dbSpin}@keyframes dbSpin{to{transform:rotate(360deg)}}.leaflet-container{background:var(--bg-primary)!important}.leaflet-control-zoom{border:none!important}.leaflet-control-zoom a{background:var(--bg-card)!important;color:var(--text-secondary)!important;border-color:var(--border)!important;-webkit-backdrop-filter:blur(8px)!important;backdrop-filter:blur(8px)!important;border-radius:8px!important;width:32px!important;height:32px!important;margin-bottom:2px!important;font-size:16px!important;line-height:32px!important}.leaflet-control-zoom a:hover{background:var(--bg-hover)!important;color:var(--text-primary)!important}.leaflet-control-attribution{display:none!important}.summary-stats{background:var(--border);border-radius:8px;gap:1px;margin-top:12px;display:flex;overflow:hidden}.summary-stat{background:var(--bg-primary);text-align:center;flex:1;padding:10px 14px}.summary-stat:first-child{border-radius:8px 0 0 8px}.summary-stat:last-child{border-radius:0 8px 8px 0}.summary-stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-size:9px;font-weight:700}.summary-stat-value{color:var(--text-primary);font-family:SF Mono,monospace;font-size:14px;font-weight:700}.chart-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;display:flex}.chart-header-title{color:var(--text-primary);letter-spacing:-.2px;font-size:16px;font-weight:700}.chart-header-subtitle{color:var(--text-muted);margin-top:2px;font-size:12px}.map-panel:before{content:"";z-index:10;opacity:.7;background:linear-gradient(90deg,#427cac,#2b7a78,#d4a843,#d97b2a,#c0392b);height:3px;position:absolute;top:0;left:0;right:0}[data-theme=light] .panel,[data-theme=light] .kpi-tile,[data-theme=light] .type-card{box-shadow:var(--shadow)}[data-theme=light] .kpi-tile:hover{box-shadow:var(--shadow-lg)}[data-theme=light] .data-tbl tbody tr:nth-child(2n) td{background:#00000004}@media (width<=1200px){.kpi-row{grid-template-columns:repeat(2,1fr)}.geo-section{grid-template-columns:1fr;min-height:auto}.map-panel .nga-map-wrap{min-height:400px}.geo-sidebar{flex-direction:row}.geo-sidebar>.panel{flex:1}.dist-section{flex-direction:column}.type-cards{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.kpi-row{grid-template-columns:1fr}.geo-sidebar{flex-direction:column}.type-cards{grid-template-columns:1fr}.filter-strip{flex-wrap:wrap}.kpi-value{font-size:22px}}.sidebar{background:var(--sidebar-bg);border-right:1px solid var(--border);z-index:20;width:230px;transition:background var(--transition-normal,.25s ease);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-header{padding:var(--space-md,16px) var(--space-md,16px);border-bottom:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:6px;display:flex}.logo-img{object-fit:contain;border-radius:var(--radius-sm,6px);width:auto;height:36px}.logo-sub{font-size:var(--font-xs,11px);color:var(--text-muted);margin-top:4px;line-height:1.4;display:block}.sidebar-nav{padding:var(--space-sm,8px);flex-direction:column;flex:1;gap:2px;display:flex;overflow-y:auto}.nav-group{margin-bottom:2px}.nav-group-divider{background:var(--border);height:1px;margin:var(--space-xs,4px) var(--space-md,16px);opacity:.5}.nav-group-header{width:100%;color:var(--text-muted);font-size:var(--font-xs,11px);font-weight:var(--weight-semibold,600);text-transform:uppercase;letter-spacing:.6px;cursor:pointer;transition:color var(--transition-fast,.15s ease);-webkit-user-select:none;user-select:none;white-space:nowrap;background:0 0;border:none;justify-content:space-between;align-items:center;padding:8px 14px;display:flex}.nav-group-header:hover{color:var(--text-secondary)}.nav-group-header.has-active{color:var(--accent-light)}.nav-group-items{max-height:0;transition:max-height var(--transition-normal,.25s ease);overflow:hidden}.nav-group-items.expanded{max-height:500px;transition:max-height var(--transition-slow,.35s ease)}.nav-item{border-radius:var(--radius-sm,6px);color:var(--text-secondary);font-size:var(--font-base,13px);font-weight:var(--weight-medium,500);cursor:pointer;transition:all var(--transition-fast,.15s ease);text-align:left;white-space:nowrap;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:9px 14px 9px 20px;display:flex;position:relative;overflow:hidden}.nav-item span{text-overflow:ellipsis;overflow:hidden}.nav-item svg{opacity:.7;flex-shrink:0}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item:hover svg{opacity:1}.nav-item.active{background:var(--sidebar-active-bg);color:var(--sidebar-active-color);font-weight:var(--weight-semibold,600)}.nav-item.active svg{opacity:1}.nav-item.active:before{content:"";background:var(--accent);border-radius:0 4px 4px 0;width:3px;position:absolute;top:4px;bottom:4px;left:0}.sidebar-footer{padding:14px var(--space-md,16px);border-top:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.sidebar-badge{font-size:10px;font-weight:var(--weight-bold,700);color:var(--text-muted);background:var(--bg-hover);border-radius:var(--radius-sm,6px);letter-spacing:.5px;padding:3px 8px}.version{font-size:var(--font-xs,11px);color:var(--text-muted)}.sidebar-user-section{justify-content:space-between;align-items:center;gap:10px;width:100%;display:flex}.sidebar-user-info{flex-direction:column;gap:2px;min-width:0;display:flex}.sidebar-user-name{font-size:var(--font-sm,12px);font-weight:var(--weight-semibold,600);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.sidebar-user-role{font-size:10px;font-weight:var(--weight-semibold,600);color:var(--text-muted);background:var(--bg-hover);border-radius:var(--radius-full,9999px);letter-spacing:.3px;text-transform:capitalize;width:fit-content;padding:1px 8px}.sidebar-logout-btn{border-radius:var(--radius-sm,6px);width:32px;height:32px;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast,.15s ease);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-logout-btn:hover{background:var(--badge-soft-danger-bg);color:var(--danger)}.sidebar-hamburger{z-index:30;border:1px solid var(--border);border-radius:var(--radius-sm,6px);background:var(--sidebar-bg);width:36px;height:36px;color:var(--text-primary);cursor:pointer;box-shadow:var(--shadow-sm,0 1px 2px #00000014);transition:background var(--transition-fast,.15s ease);justify-content:center;align-items:center;display:none;position:fixed;top:14px;left:14px}.sidebar-hamburger:hover{background:var(--bg-hover)}@media (width<=1024px){.sidebar-hamburger{display:flex}.sidebar{width:250px;transition:transform .3s ease, background var(--transition-normal,.25s ease);transform:translate(-100%)}.sidebar.mobile-open{transform:translate(0)}.nav-group-header .nav-group-label,.nav-group-header svg{opacity:1;width:auto}.nav-group-header{justify-content:space-between;padding:8px 14px}.nav-item{justify-content:flex-start;gap:10px;padding:9px 14px 9px 22px}.nav-item span{display:inline}.sidebar-footer{justify-content:space-between;padding:14px 16px}.sidebar-user-info,.sidebar-badge,.version{display:flex}.sidebar-logout-btn{margin:0}.logo-img{height:38px;margin:0}.sidebar-header{align-items:flex-start;padding:20px 20px 18px}}.sidebar-overlay{display:none}@media (width<=1024px){.sidebar-overlay{z-index:19;opacity:0;pointer-events:none;background:#0006;transition:opacity .3s;display:block;position:fixed;inset:0}.sidebar-overlay.visible{opacity:1;pointer-events:auto}}.view{flex-direction:column;gap:20px;display:flex}.view-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.view-header h2{color:var(--text-primary);font-size:18px;font-weight:600}.view-count{color:var(--text-muted);font-size:13px}.loading{height:300px;color:var(--text-muted);justify-content:center;align-items:center;font-size:16px;display:flex}.empty-state{text-align:center;background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);border-radius:12px;padding:60px 20px}.empty-state code{background:var(--bg-primary);color:var(--accent-light);border-radius:4px;margin-top:8px;padding:4px 10px;font-size:13px;display:inline-block}.filter-group{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;align-items:center;gap:4px;padding:3px;display:flex}.filter-label{color:var(--text-muted);white-space:nowrap;padding:0 8px;font-size:12px}.filter-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:6px 14px;font-size:13px;transition:all .15s}.filter-btn:hover{color:var(--text-primary)}.filter-btn.active{background:var(--teal);color:#fff}.chart-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:20px}.chart-card h3{color:var(--text-primary);text-transform:uppercase;letter-spacing:.3px;margin-bottom:16px;font-size:14px;font-weight:600}.trends-grid{grid-template-columns:1fr 1fr;gap:20px;display:grid}@media (width<=1100px){.trends-grid{grid-template-columns:1fr}}.anomaly-stats-row{gap:8px;display:flex}.anomaly-stat{border-radius:6px;padding:4px 10px;font-size:12px;font-weight:600}.anomaly-stat.high{color:#ef4444;background:#ef444426}.anomaly-stat.medium{color:#f59e0b;background:#f59e0b26}.anomaly-stat.low{color:#3b82f6;background:#3b82f626}.anomaly-charts-row{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}@media (width<=1100px){.anomaly-charts-row{grid-template-columns:1fr}}.anomaly-filters{flex-wrap:wrap;gap:12px;display:flex}.anomalies-list{flex-direction:column;gap:10px;display:flex}.anomaly-card{background:var(--bg-card);border:1px solid var(--border);border-left:3px solid var(--border);border-radius:10px;align-items:flex-start;gap:14px;padding:16px;transition:background .15s;display:flex}.anomaly-card:hover{background:var(--bg-hover)}.anomaly-card.severity-high{border-left-color:#ef4444}.anomaly-card.severity-medium{border-left-color:#f59e0b}.anomaly-card.severity-low{border-left-color:#3b82f6}.anomaly-icon-col{color:var(--text-muted);flex-shrink:0;padding-top:2px}.anomaly-card.severity-high .anomaly-icon-col{color:#ef4444}.anomaly-card.severity-medium .anomaly-icon-col{color:#f59e0b}.anomaly-card.severity-low .anomaly-icon-col{color:#3b82f6}.anomaly-body{flex:1;min-width:0}.anomaly-top{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:6px;display:flex}.anomaly-type{color:var(--text-primary);font-size:14px;font-weight:600}.anomaly-severity-badge,.anomaly-status-badge{text-transform:uppercase;letter-spacing:.3px;border-radius:10px;padding:2px 8px;font-size:10px;font-weight:600}.anomaly-severity-badge.high{color:#ef4444;background:#ef444426}.anomaly-severity-badge.medium{color:#f59e0b;background:#f59e0b26}.anomaly-severity-badge.low{color:#3b82f6;background:#3b82f626}.anomaly-status-badge.investigating{color:#f87171;background:#ef44441a}.anomaly-status-badge.flagged{color:#fbbf24;background:#f59e0b1a}.anomaly-status-badge.resolved{color:#4ade80;background:#22c55e1a}.anomaly-desc{color:var(--text-secondary);margin-bottom:8px;font-size:13px;line-height:1.4}.anomaly-meta{color:var(--text-muted);flex-wrap:wrap;gap:16px;font-size:12px;display:flex}.anomaly-meta strong{color:var(--text-secondary);font-weight:500}.system-summary{gap:8px;display:flex}.sys-badge{border-radius:6px;padding:4px 10px;font-size:12px;font-weight:600}.sys-badge.healthy{color:#22c55e;background:#22c55e26}.sys-badge.degraded{color:#f59e0b;background:#f59e0b26}.sys-badge.unhealthy{color:#ef4444;background:#ef444426}.system-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px;display:grid}.system-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:20px}.system-card.healthy{border-top:3px solid var(--success)}.system-card.degraded{border-top:3px solid var(--warning)}.system-card.unhealthy{border-top:3px solid var(--danger)}.sys-header{color:var(--text-secondary);align-items:center;gap:10px;margin-bottom:16px;display:flex}.sys-header h3{color:var(--text-primary);flex:1;font-size:15px}.service-badge{text-transform:capitalize;border-radius:10px;padding:2px 8px;font-size:11px;font-weight:600}.service-badge.healthy{color:var(--success);background:#22c55e20}.service-badge.degraded{color:var(--warning);background:#f59e0b20}.service-badge.unhealthy{color:var(--danger);background:#ef444420}.sys-stats{flex-direction:column;gap:10px;margin-bottom:16px;display:flex}.sys-stat{align-items:center;gap:10px;display:flex}.sys-stat label{color:var(--text-muted);width:55px;font-size:12px}.sys-stat span{color:var(--text-secondary);text-align:right;width:45px;font-size:12px}.progress-bar{background:var(--bg-hover);border-radius:3px;flex:1;height:6px;overflow:hidden}.progress-fill{border-radius:3px;height:100%;transition:width .3s}.sys-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;padding-top:12px;display:flex}.sys-uptime{color:var(--text-secondary);align-items:center;gap:6px;font-size:12px;display:flex}.sys-check{color:var(--text-muted);font-size:11px}.data-table-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;overflow:hidden}.data-table-wrap h3{border-bottom:1px solid var(--border);padding:16px 20px;font-size:15px;font-weight:600}.data-table{border-collapse:collapse;width:100%}.data-table th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);background:var(--bg-primary);padding:10px 16px;font-size:12px;font-weight:600}.data-table td{color:var(--text-secondary);border-bottom:1px solid var(--border);padding:10px 16px;font-size:13px}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--bg-hover)}.page-view{gap:var(--space-lg,24px);flex-direction:column;display:flex}.page-header{justify-content:space-between;align-items:center;display:flex}.page-header h2{font-size:var(--font-xl,20px);font-weight:var(--weight-bold,700);color:var(--text-primary);letter-spacing:-.2px}.page-header-badge{font-size:var(--font-sm,12px);color:var(--teal);border-radius:var(--radius-full,9999px);font-weight:var(--weight-semibold,600);background:#4f6bdb1a;padding:4px 12px}.stat-grid-6{gap:var(--space-md,16px);grid-template-columns:repeat(6,1fr);display:grid}.stat-grid-5{gap:var(--space-md,16px);grid-template-columns:repeat(5,1fr);display:grid}.stat-grid-4{gap:var(--space-md,16px);grid-template-columns:repeat(4,1fr);display:grid}.stat-grid-3{gap:var(--space-md,16px);grid-template-columns:repeat(3,1fr);display:grid}.chart-row{gap:var(--space-lg,24px);grid-template-columns:1fr 1fr;display:grid}.chart-row-3{gap:var(--space-lg,24px);grid-template-columns:1fr 1fr 1fr;display:grid}.chart-full{grid-column:1/-1}.funnel-container{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:24px}.funnel-title{color:var(--text-primary);text-transform:uppercase;letter-spacing:.3px;margin-bottom:24px;font-size:14px;font-weight:600}.funnel-stages{align-items:center;gap:0;display:flex;position:relative}.funnel-stage{border-radius:8px;flex-direction:column;flex:1;align-items:center;padding:16px 8px;transition:background .15s;display:flex;position:relative}.funnel-stage:hover{background:var(--bg-hover)}.funnel-stage-bar{border-radius:4px;width:100%;min-height:8px;margin-bottom:12px;transition:height .5s}.funnel-stage-count{color:var(--accent-light);margin-bottom:4px;font-size:20px;font-weight:700}.funnel-stage-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;text-align:center;margin-bottom:4px;font-size:11px}.funnel-stage-pct{color:var(--text-secondary);font-size:12px;font-weight:600}.funnel-arrow{color:var(--border);flex-shrink:0;margin:0 -4px;font-size:18px}.realtime-counter{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;align-items:center;gap:16px;padding:20px;display:flex}.realtime-counter-value{color:var(--accent-light);text-align:center;min-width:80px;font-family:SF Mono,Fira Code,Consolas,monospace;font-size:36px;font-weight:800}.realtime-counter-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:14px}.realtime-counter-dot{background:#4ade80;border-radius:50%;width:8px;height:8px;animation:1.5s ease-in-out infinite pulse-dot}.status-badge{border-radius:var(--radius-full,9999px);text-transform:capitalize;padding:3px 10px;font-size:11px;font-weight:600;display:inline-block}.status-badge.created{color:#36a2eb;background:#36a2eb26}.status-badge.validated{color:#4bc0c0;background:#4bc0c026}.status-badge.cleared{color:#96f;background:#9966ff26}.status-badge.sent{color:#ffce56;background:#ffce5626}.status-badge.accepted{color:#4ade80;background:#4ade8026}.status-badge.paid{color:#5c6670;background:#5c667026}.status-badge.stuck{color:#ef4444;background:#ef444426}.status-badge.low{color:#ff9f40;background:#ff9f4026}.status-badge.high{color:#ef4444;background:#ef444426}.status-badge.medium{color:#ffce56;background:#ffce5626}.page-loading{min-height:400px;color:var(--text-muted);justify-content:center;align-items:center;gap:10px;font-size:14px;display:flex}.page-loading-spinner{border:2px solid var(--border);border-top-color:var(--teal);border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin}.geo-layout{grid-template-columns:2fr 1fr;gap:20px;display:grid}.geo-detail-content{flex-direction:column;gap:12px;margin-bottom:16px;display:flex}.geo-detail-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:6px 0;display:flex}.geo-detail-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;font-size:12px}.geo-detail-value{color:var(--text-primary);font-size:13px;font-weight:600}.geo-state-list{flex-wrap:wrap;gap:6px;margin-top:12px;display:flex}.geo-state-btn{background:var(--bg-primary);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;border-radius:6px;align-items:center;gap:6px;padding:5px 10px;font-size:11px;transition:all .15s;display:flex}.geo-state-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.geo-state-btn.active{border-color:var(--accent);color:var(--accent);background:#5c667026}.geo-state-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.pulse-header{justify-content:space-between;align-items:center;display:flex}.pulse-title-group{align-items:center;gap:14px;display:flex}.pulse-title{color:var(--text-primary);letter-spacing:.3px;font-size:22px;font-weight:800}.pulse-live-indicator{background:#4ade801a;border:1px solid #4ade804d;border-radius:20px;align-items:center;gap:6px;padding:4px 12px;display:flex}.pulse-dot{background:#4ade80;border-radius:50%;width:8px;height:8px;animation:1.5s ease-in-out infinite pulse-dot}.pulse-dot-sm{background:#4ade80;border-radius:50%;width:6px;height:6px;animation:1.5s ease-in-out infinite pulse-dot;display:inline-block}.pulse-live-text{color:#4ade80;letter-spacing:1px;font-size:11px;font-weight:700}.pulse-ticker{background:var(--bg-card);border:1px solid var(--border);border-left:3px solid #4ade80;border-radius:10px;align-items:center;gap:16px;padding:14px 20px;display:flex}.pulse-ticker-label{color:#4ade80;letter-spacing:.5px;white-space:nowrap;align-items:center;gap:8px;font-size:11px;font-weight:700;display:flex}.pulse-ticker-content{color:var(--text-primary);font-family:SF Mono,Fira Code,Consolas,monospace;font-size:14px;font-weight:600}.irn-ticker-item{background:#0ab39c08;border-left:3px solid #0ab39c66;border-radius:8px;align-items:center;gap:12px;margin-bottom:4px;padding:8px 12px;animation:.3s ease-out both slideInRight;display:flex}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.uptime-badge{color:#4ade80;background:#4ade801a;border:1px solid #4ade8033;border-radius:20px;align-items:center;gap:8px;padding:4px 12px;font-size:12px;font-weight:600;display:flex}.health-services-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;display:grid}.health-service-card{background:var(--bg-primary);border:1px solid var(--border);border-top:3px solid var(--border);border-radius:10px;padding:16px}.health-service-card.healthy{border-top-color:#4ade80}.health-service-card.degraded{border-top-color:#f59e0b}.health-service-card.unhealthy{border-top-color:#ef4444}.health-service-header{align-items:center;gap:8px;margin-bottom:12px;display:flex}.health-dot{border-radius:50%;width:8px;height:8px}.health-dot.healthy{background:#4ade80}.health-dot.degraded{background:#f59e0b}.health-dot.unhealthy{background:#ef4444}.health-service-name{color:var(--text-primary);flex:1;font-size:13px;font-weight:600}.health-service-stats{gap:16px;margin-bottom:10px;display:flex}.health-service-stat{flex-direction:column;gap:2px;display:flex}.health-stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;font-size:10px}.health-stat-value{color:var(--text-secondary);font-size:13px;font-weight:600}.health-service-footer{color:var(--text-muted);border-top:1px solid var(--border);padding-top:8px;font-size:11px}@media (width<=1400px){.stat-grid-6,.stat-grid-5{grid-template-columns:repeat(3,1fr)}}@media (width<=1200px){.chart-row,.chart-row-3{grid-template-columns:1fr}.stat-grid-4,.stat-grid-3,.stat-grid-5{grid-template-columns:repeat(2,1fr)}.geo-layout{grid-template-columns:1fr}.health-services-grid{grid-template-columns:1fr 1fr}}@media (width<=768px){.stat-grid-6,.stat-grid-5,.stat-grid-4,.stat-grid-3{grid-template-columns:1fr}.funnel-stages{flex-direction:column}.funnel-arrow{transform:rotate(90deg)}}.app{width:100%;min-height:100vh;display:flex}.main-content{flex-direction:column;flex:1;margin-left:230px;display:flex}.top-bar{padding:0 var(--space-lg);background:var(--topbar-bg);z-index:10;border-bottom:1px solid var(--topbar-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);height:60px;transition:background var(--transition-normal), border-color var(--transition-normal);justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.top-bar-title{flex-direction:column;display:flex}.page-title{font-size:var(--font-lg);font-weight:var(--weight-bold);color:var(--text-primary);letter-spacing:-.2px}.page-subtitle{font-size:var(--font-xs);color:var(--text-muted);letter-spacing:.1px;margin-top:1px}.top-bar-actions{align-items:center;gap:var(--space-sm);display:flex}.status-dot{background:var(--danger);border-radius:50%;width:8px;height:8px}.status-dot.online{background:var(--success);box-shadow:0 0 8px #0ab39c80}.status-text{font-size:var(--font-base);color:var(--text-secondary)}.top-bar-date{font-size:var(--font-sm);color:var(--text-muted);padding-left:var(--space-sm);border-left:1px solid var(--border)}.content-area{padding:var(--space-lg);background:var(--bg-primary);flex:1;overflow-y:auto}@media (width<=1024px){.main-content{margin-left:0}.top-bar{padding-left:56px}}
