*{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:#c00;--accent-light:#7c86a2;--header-bg:#2a2f34;--header-dark:#212529;--success:#0ab39c;--warning:#f7b84b;--danger:#f06548;--info:#299cdb;--teal:#405189;--teal-light:#7c86a2;--gold:#f7b84b;--nrs-red:#c00;--nrs-grey:#405189;--nrs-grey-light:#7c86a2;--shadow:0 1px 2px #0003;--shadow-lg:0 5px 10px #0000001f;--chart-grid:#ffffff0f;--chart-text:#adb5bd;--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:#4051892e;--sidebar-active-color:#7c86a2;--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}[data-theme=light]{--bg-primary:#f3f3f9;--bg-secondary:#fff;--bg-card:#fff;--bg-hover:#eff2f7;--border:#e9ebec;--text-primary:#212529;--text-secondary:#495057;--text-muted:#878a99;--accent:#c00;--accent-light:#405189;--header-bg:#fff;--header-dark:#f3f3f9;--success:#0ab39c;--warning:#f7b84b;--danger:#f06548;--info:#299cdb;--teal:#405189;--teal-light:#5c6670;--gold:#c5960c;--nrs-red:#c00;--nrs-grey:#405189;--nrs-grey-light:#5c6670;--shadow:0 1px 2px #38414a26;--shadow-lg:0 5px 10px #38414a1f;--chart-grid:#0000000f;--chart-text:#495057;--leaflet-bg:#f3f3f9;--leaflet-attr-bg:#ffffffe6;--leaflet-attr-text:#878a99;--map-tile-filter:none;--sidebar-bg:#fff;--sidebar-menu-bg:#f3f3f9;--sidebar-active-bg:#40518914;--sidebar-active-color:#405189;--topbar-bg:#fff;--topbar-text:#495057;--topbar-border:#e9ebec;--input-bg:#fff;--input-border:#ced4da;--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:15px;line-height:1.6}#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);width:100%;max-width:440px;box-shadow:var(--shadow);border-radius:16px;padding:40px 36px;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(--bg-primary);border:1px solid var(--border);width:100%;color:var(--text-primary);border-radius:8px;outline:none;padding:12px 14px;font-size:14px;transition:border-color .2s}.login-field input:focus,.login-select:focus{border-color:var(--teal)}.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){background:var(--accent)}.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-top:3px solid var(--teal);border-radius:10px;flex-direction:column;gap:4px;padding:16px 20px;display:flex}.stat-card-header{justify-content:space-between;align-items:center;display:flex}.stat-card-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:12px}.stat-card-icon{color:var(--accent);opacity:.7}.stat-card-value{color:var(--accent-light);font-size:22px;font-weight:700}.stat-card-subtitle{color:var(--text-muted);margin-top:2px;font-size:11px}.stat-card-trend{border-radius:6px;align-items:center;gap:4px;width:fit-content;margin-top:6px;padding:3px 8px;font-size:11px;font-weight:600;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:700;animation:2s ease-in-out infinite trend-bounce}.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)}}.data-table-toolbar{border-bottom:1px solid var(--border);padding:12px 16px}.data-table-search{background:var(--bg-primary);border:1px solid var(--border);width:100%;max-width:300px;color:var(--text-primary);border-radius:6px;outline:none;padding:8px 12px;font-size:13px}.data-table-search:focus{border-color:var(--accent)}.data-table-search::placeholder{color:var(--text-muted)}.data-table-scroll{overflow-x:auto}.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);white-space:nowrap;-webkit-user-select:none;user-select:none;padding:10px 16px;font-size:12px;font-weight:600}.data-table th.sortable{cursor:pointer}.data-table th.sortable:hover{color:var(--text-primary)}.sort-indicator{margin-left:2px;font-size:10px}.data-table-empty{text-align:center;color:var(--text-muted);padding:40px 16px!important}.data-table-pagination{border-top:1px solid var(--border);color:var(--text-secondary);justify-content:space-between;align-items:center;padding:10px 16px;font-size:13px;display:flex}.data-table-page-size{align-items:center;gap:8px;display:flex}.data-table-page-size select{background:var(--bg-primary);border:1px solid var(--border);color:var(--text-primary);border-radius:4px;padding:4px 8px;font-size:12px}.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);color:var(--text-secondary);cursor:pointer;border-radius:6px;padding:5px 12px;font-size:12px;transition:all .15s}.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{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;flex-wrap:wrap;align-items:center;gap:16px;padding:10px 16px;display:flex}.filter-bar-group{align-items:center;gap:8px;display:flex}.filter-bar-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;white-space:nowrap;font-size:11px}.filter-bar-buttons{background:var(--bg-primary);border-radius:6px;gap:2px;padding:2px;display:flex}.filter-bar-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:5px;padding:5px 12px;font-size:12px;transition:all .15s}.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);color:var(--text-primary);border-radius:6px;outline:none;min-width:120px;padding:5px 10px;font-size:12px}.filter-bar-select:focus{border-color:var(--accent)}.placeholder-view{background:var(--bg-card);border:1px solid var(--border);min-height:400px;color:var(--text-secondary);border-radius:12px;flex-direction:column;justify-content:center;align-items:center;display:flex}.placeholder-view h2{color:var(--text-primary);margin-bottom:8px;font-size:22px;font-weight:600}.placeholder-view p{color:var(--text-muted);font-size:14px}.error-banner{background:#ef444414;border:1px solid #ef444440;border-left:4px solid #ef4444;border-radius:12px;align-items:center;gap:16px;padding:16px 20px;display:flex}.error-banner-icon{color:#ef4444;opacity:.8;flex-shrink:0}.error-banner-content{flex:1}.error-banner-title{color:#ef4444;margin-bottom:4px;font-size:14px;font-weight:600}.error-banner-message{color:var(--text-secondary);font-size:12px;line-height:1.4}.error-banner-retry{color:#ef4444;cursor:pointer;background:#ef44441f;border:1px solid #ef44444d;border-radius:8px;flex-shrink:0;align-items:center;gap:6px;padding:8px 16px;font-size:12px;font-weight:600;transition:all .15s;display:flex}.error-banner-retry:hover{background:#ef444433}[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:0 1px 3px #00000014,0 1px 2px #0000000a}.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)}.fs-dd{background:var(--bg-card);border:1px solid var(--border);z-index:1000;border-radius:10px;max-height:220px;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow-y:auto;box-shadow:0 8px 32px #00000040}.fs-dd-item{cursor:pointer;border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:10px 14px;transition:background .15s;display:flex}.fs-dd-item:last-child{border-bottom:none}.fs-dd-item:hover{background:var(--bg-hover)}.fs-dd-name{color:var(--text-primary);font-size:13px;font-weight:500}.fs-dd-tin{color:var(--text-muted);font-family:monospace;font-size:11px}.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;flex-direction:column;width:250px;transition:background .2s;display:flex;position:fixed;top:0;bottom:0;left:0;box-shadow:0 2px 4px #00000014}.sidebar-header{border-bottom:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:6px;padding:20px 20px 18px;display:flex}.logo-img{object-fit:contain;border-radius:4px;width:auto;height:38px}.logo-sub{color:var(--text-muted);margin-top:4px;font-size:11px;line-height:1.4;display:block}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:8px;display:flex;overflow-y:auto}.nav-group{margin-bottom:2px}.nav-group-header{width:100%;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;cursor:pointer;-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;font-size:11px;font-weight:700;transition:color .15s;display:flex}.nav-group-header:hover{color:var(--text-secondary)}.nav-group-header.has-active{color:var(--accent)}.nav-group-items{max-height:0;transition:max-height .25s ease-out;overflow:hidden}.nav-group-items.expanded{max-height:500px;transition:max-height .35s ease-in}.nav-item{color:var(--text-secondary);cursor:pointer;text-align:left;white-space:nowrap;background:0 0;border:none;border-radius:4px;align-items:center;gap:10px;width:100%;padding:8px 14px 8px 22px;font-size:13px;transition:all .15s;display:flex;position:relative;overflow:hidden}.nav-item span{text-overflow:ellipsis;overflow:hidden}.nav-item svg{flex-shrink:0}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:var(--sidebar-active-bg);color:var(--sidebar-active-color);font-weight:600}.nav-item.active:before{content:"";background:var(--accent);border-radius:0 3px 3px 0;width:3px;position:absolute;top:4px;bottom:4px;left:0}.sidebar-footer{border-top:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.sidebar-badge{color:var(--text-muted);background:var(--bg-hover);letter-spacing:.5px;border-radius:4px;padding:3px 8px;font-size:10px;font-weight:700}.version{color:var(--text-muted);font-size:11px}.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{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:600;overflow:hidden}.sidebar-user-role{color:var(--text-muted);background:var(--bg-hover);letter-spacing:.3px;text-transform:capitalize;border-radius:4px;width:fit-content;padding:1px 6px;font-size:10px;font-weight:600}.sidebar-logout-btn{width:32px;height:32px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;transition:all .15s;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);background:var(--sidebar-bg);width:36px;height:36px;color:var(--text-primary);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;transition:background .15s;display:none;position:fixed;top:18px;left:14px;box-shadow:0 2px 6px #0000001f}.sidebar-hamburger:hover{background:var(--bg-hover)}@media (width<=1024px){.sidebar-hamburger{display:flex}.sidebar{width:250px;transition:transform .3s,background .2s;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:8px 14px 8px 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{flex-direction:column;gap:20px;display:flex}.page-header{justify-content:space-between;align-items:center;display:flex}.page-header h2{color:var(--text-primary);letter-spacing:.3px;font-size:22px;font-weight:700}.page-header-badge{color:var(--accent);background:#5c66701f;border-radius:20px;padding:4px 12px;font-size:12px;font-weight:600}.stat-grid-6{grid-template-columns:repeat(6,1fr);gap:14px;display:grid}.stat-grid-5{grid-template-columns:repeat(5,1fr);gap:14px;display:grid}.stat-grid-4{grid-template-columns:repeat(4,1fr);gap:14px;display:grid}.stat-grid-3{grid-template-columns:repeat(3,1fr);gap:14px;display:grid}.chart-row{grid-template-columns:1fr 1fr;gap:20px;display:grid}.chart-row-3{grid-template-columns:1fr 1fr 1fr;gap:20px;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{text-transform:capitalize;border-radius:10px;padding:2px 8px;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(--accent);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}.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:250px;display:flex}.top-bar{background:var(--topbar-bg);z-index:10;border-bottom:1px solid var(--topbar-border);height:70px;box-shadow:var(--shadow);justify-content:space-between;align-items:center;padding:0 24px;transition:background .2s,border-color .2s;display:flex;position:sticky;top:0}.top-bar-title{flex-direction:column;display:flex}.page-title{color:var(--text-primary);letter-spacing:.2px;font-size:18px;font-weight:600}.page-subtitle{color:var(--text-muted);letter-spacing:.2px;margin-top:1px;font-size:12px}.top-bar-actions{align-items:center;gap:12px;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{color:var(--text-secondary);font-size:13px}.top-bar-date{color:var(--text-muted);border-left:1px solid var(--border);padding-left:12px;font-size:12px}.content-area{background:var(--bg-primary);flex:1;padding:24px;overflow-y:auto}@media (width<=1024px){.main-content{margin-left:0}.top-bar{padding-left:60px}}
