:root{--bg: #fafbfd;--bg2: #ffffff;--bg3: #f1f5f9;--card: #ffffff;--border: #e2e8f0;--text: #0f172a;--text2: #64748b;--accent: #3b7fff;--accent-dim: rgba(59,127,255,.08);--ok: #16a34a;--ok-dim: rgba(22,163,74,.08);--warn: #d97706;--warn-dim: rgba(217,119,6,.08);--critical: #dc2626;--critical-dim: rgba(220,38,38,.08);--transit: #2563eb;--transit-dim: rgba(37,99,235,.08);--radius: 10px;--radius-sm: 6px;--font: "DM Sans", system-ui, sans-serif;--mono: "DM Mono", "JetBrains Mono", monospace;--shadow-sm: 0 1px 2px rgba(15,23,42,.04);--shadow-md: 0 4px 12px rgba(15,23,42,.06);--sidebar-bg: #f1f5f9;--sidebar-border: #e2e8f0;--sidebar-text: #0f172a;--sidebar-text2: #64748b;--sidebar-hover: #e2e8f0;--sidebar-active-bg: rgba(59,127,255,.1)}[data-theme=dark]{--bg: #0d0f12;--bg2: #13161b;--bg3: #1a1e25;--card: #13161b;--border: #252b35;--text: #e8edf5;--text2: #8a95a8;--accent: #3b7fff;--accent-dim: rgba(59,127,255,.12);--ok: #22c55e;--ok-dim: rgba(34,197,94,.12);--warn: #f59e0b;--warn-dim: rgba(245,158,11,.12);--critical: #ef4444;--critical-dim: rgba(239,68,68,.12);--transit: #3b82f6;--transit-dim: rgba(59,130,246,.12);--shadow-sm: 0 1px 2px rgba(0,0,0,.3);--shadow-md: 0 4px 12px rgba(0,0,0,.4);--sidebar-bg: #0a0d14;--sidebar-border: #1a1e25;--sidebar-text: #e2e8f0;--sidebar-text2: #94a3b8;--sidebar-hover: #1e293b;--sidebar-active-bg: rgba(59,127,255,.15)}@media (prefers-color-scheme: dark){:root:not([data-theme=light]){--bg: #0d0f12;--bg2: #13161b;--bg3: #1a1e25;--card: #13161b;--border: #252b35;--text: #e8edf5;--text2: #8a95a8;--ok: #22c55e;--ok-dim: rgba(34,197,94,.12);--warn: #f59e0b;--warn-dim: rgba(245,158,11,.12);--critical: #ef4444;--critical-dim: rgba(239,68,68,.12);--transit: #3b82f6;--transit-dim: rgba(59,130,246,.12);--shadow-sm: 0 1px 2px rgba(0,0,0,.3);--shadow-md: 0 4px 12px rgba(0,0,0,.4);--sidebar-bg: #0a0d14;--sidebar-border: #1a1e25;--sidebar-text: #e2e8f0;--sidebar-text2: #94a3b8;--sidebar-hover: #1e293b;--sidebar-active-bg: rgba(59,127,255,.15)}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--font);background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}.app-shell{display:flex;height:100vh;overflow:hidden}.sidebar{width:220px;background:var(--sidebar-bg);border-right:1px solid var(--sidebar-border);display:flex;flex-direction:column;flex-shrink:0;transition:width .25s ease;overflow:hidden;z-index:100}.sidebar.collapsed{width:56px}.sidebar.collapsed .sidebar-logo span,.sidebar.collapsed .sidebar-title,.sidebar.collapsed .sidebar-subtitle,.sidebar.collapsed .sidebar-link span{display:none}.sidebar.collapsed .sidebar-link{justify-content:center;padding:10px}.sidebar.collapsed .sidebar-user{padding:8px}.sidebar-logo{padding:20px 16px 16px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--sidebar-border);margin-bottom:0;white-space:nowrap}.sidebar-logo span{color:var(--accent)}.sidebar-badge{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:12px;flex-shrink:0;letter-spacing:.5px}.sidebar-title{font-size:15px;font-weight:700;color:var(--sidebar-text);letter-spacing:-.3px;line-height:1}.sidebar-subtitle{font-size:10px;color:var(--sidebar-text2);margin-top:3px}.sidebar-nav{flex:1;padding:8px;display:flex;flex-direction:column;gap:2px;overflow-y:auto;min-height:0}.sidebar::-webkit-scrollbar,.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-track,.sidebar-nav::-webkit-scrollbar-track{background:var(--bg2)}.sidebar::-webkit-scrollbar-thumb,.sidebar-nav::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.sidebar::-webkit-scrollbar-thumb:hover,.sidebar-nav::-webkit-scrollbar-thumb:hover{background:var(--text3)}.sidebar-link{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius-sm);color:var(--sidebar-text2);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;border:none;background:none;width:100%;text-align:left}.sidebar-link:hover{background:var(--sidebar-hover);color:var(--sidebar-text)}.sidebar-link.active{background:var(--sidebar-active-bg);color:var(--accent)}.sidebar-link .icon{width:18px;text-align:center;font-size:15px}.sidebar-sep{height:1px;background:var(--sidebar-border);margin:8px 4px}.sidebar-user{padding:10px 14px;border-top:1px solid var(--sidebar-border);white-space:nowrap;overflow:hidden}.sidebar-user-row{display:flex;gap:10px;align-items:flex-start}.sidebar-avatar{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:13px;font-weight:700;flex-shrink:0}.sidebar-username{font-size:12px;font-weight:600;color:var(--sidebar-text);overflow:hidden;text-overflow:ellipsis}.sidebar-user-email{font-size:12px;color:var(--sidebar-text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:11px;color:var(--accent);font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-top:2px}.sidebar-footer{display:flex;align-items:center;gap:6px;padding:8px 16px}.sidebar .btn-ghost{color:var(--sidebar-text2);border-color:var(--sidebar-border)}.sidebar .btn-ghost:hover{background:var(--sidebar-hover);color:var(--sidebar-text)}.main-content{flex:1;overflow-y:auto;padding:24px 28px}.page-title{font-size:22px;font-weight:700;letter-spacing:-.5px;margin-bottom:4px}.page-subtitle{font-size:13px;color:var(--text2);margin-bottom:20px}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-sm);min-width:0;overflow:hidden}.card-grid{display:grid;gap:12px}.card-grid-4{grid-template-columns:repeat(4,1fr)}.card-grid-3{grid-template-columns:repeat(3,1fr)}.card-grid-2{grid-template-columns:repeat(auto-fit,minmax(400px,1fr))}.kpi-card{cursor:pointer;transition:border-color .15s,transform .15s}.kpi-card:hover{border-color:var(--accent);transform:translateY(-1px)}.kpi-label{font-size:12px;color:var(--text2);font-weight:500;text-transform:uppercase;letter-spacing:.4px;margin-bottom:6px}.kpi-value{font-size:28px;font-weight:700;letter-spacing:-1px;font-family:var(--mono)}.kpi-value.critical{color:var(--critical)}.kpi-value.warn{color:var(--warn)}.kpi-value.ok{color:var(--ok)}.kpi-value.transit{color:var(--transit)}.badge{display:inline-flex;align-items:center;padding:3px 8px;border-radius:20px;font-size:11px;font-weight:600;letter-spacing:.3px;white-space:nowrap}.badge-ok{background:var(--ok-dim);color:var(--ok)}.badge-warn{background:var(--warn-dim);color:var(--warn)}.badge-critical{background:var(--critical-dim);color:var(--critical)}.badge-transit{background:var(--transit-dim);color:var(--transit)}.badge-neutral{background:var(--bg3);color:var(--text2)}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;border:1px solid transparent;font-family:var(--font)}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover{background:#2b6bef}.btn-ghost{background:transparent;color:var(--text2);border-color:var(--border)}.btn-ghost:hover{background:var(--bg3);color:var(--text)}.btn-danger{background:var(--critical-dim);color:var(--critical);border-color:transparent}.btn-danger:hover{background:#dc262626}.btn-sm{padding:5px 10px;font-size:12px}.btn:disabled{opacity:.4;cursor:not-allowed}.input,.select{width:100%;padding:8px 12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:13px;font-family:var(--font);outline:none;transition:border-color .15s}.input:focus,.select:focus{border-color:var(--accent)}.input::placeholder{color:var(--text2)}.select{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238a95a8' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px}.form-group{display:flex;flex-direction:column;gap:4px}.form-label{font-size:12px;color:var(--text2);font-weight:500}.tbl-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius);background:var(--card);box-shadow:var(--shadow-sm)}table{width:100%;border-collapse:collapse;font-size:13px;table-layout:auto}thead th{background:var(--bg3);color:var(--text2);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.4px;padding:10px 12px;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap;position:sticky;top:0;z-index:1}tbody td{padding:9px 12px;border-bottom:1px solid var(--border);vertical-align:middle}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background:var(--accent-dim)}tbody tr.row-critical{background:var(--critical-dim)}tbody tr.row-critical:hover{background:#dc26261f}tbody tr.row-warn{background:var(--warn-dim)}tbody tr.row-warn:hover{background:#d977061f}.col-mono{font-family:var(--mono);font-size:12px;letter-spacing:.3px;white-space:nowrap}.col-num{text-align:right;font-family:var(--mono);font-size:12px;white-space:nowrap;width:1%}.col-desc{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:180px}.col-narrow{white-space:nowrap;width:1%}td.mono{font-family:var(--mono);font-size:12px;letter-spacing:.3px}td.num{text-align:right;font-family:var(--mono);font-size:12px}.skeleton-row td{padding:12px}.skeleton-cell{height:14px;border-radius:4px;background:linear-gradient(90deg,var(--bg3) 25%,var(--border) 50%,var(--bg3) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.pagination-bar{display:flex;align-items:center;justify-content:space-between;padding:12px 0;margin-top:8px;font-size:13px;color:var(--text2);flex-wrap:wrap;gap:8px}.pagination-controls{display:flex;align-items:center;gap:4px}.pagination-ellipsis{padding:0 6px;color:var(--text2)}.pagination-size{width:auto;max-width:110px;padding:5px 28px 5px 10px;font-size:12px;margin-left:8px}.pagination-info strong{color:var(--text)}.filter-bar{display:flex;align-items:center;gap:8px;margin-bottom:16px;flex-wrap:wrap}.filter-btn{padding:5px 12px;border-radius:20px;font-size:12px;font-weight:600;cursor:pointer;border:1px solid var(--border);background:transparent;color:var(--text2);transition:all .15s}.filter-btn:hover{background:var(--bg3)}.filter-btn.active{background:var(--accent-dim);color:var(--accent);border-color:var(--accent)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:var(--card);border:1px solid var(--border);border-radius:12px;width:90%;max-width:520px;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-md)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.modal-title{font-size:16px;font-weight:700}.modal-close{background:none;border:none;color:var(--text2);font-size:20px;cursor:pointer;padding:4px;line-height:1}.modal-close:hover{color:var(--text)}.modal-body{padding:20px;display:flex;flex-direction:column;gap:14px}.modal-footer{padding:14px 20px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px}.progress-bar{height:6px;background:var(--bg3);border-radius:3px;overflow:hidden}.progress-fill{height:100%;border-radius:3px;transition:width .3s}.progress-fill.ok{background:var(--ok)}.progress-fill.warn{background:var(--warn)}.progress-fill.critical{background:var(--critical)}.spinner{display:inline-block;width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-center{display:flex;align-items:center;justify-content:center;gap:10px;padding:60px 0;color:var(--text2);font-size:14px}.drop-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:40px;text-align:center;cursor:pointer;transition:all .15s;color:var(--text2)}.drop-zone:hover,.drop-zone.drag-over{border-color:var(--accent);background:var(--accent-dim);color:var(--accent)}.drop-zone-icon{font-size:32px;margin-bottom:8px}.drop-zone-text{font-size:13px}.toast{position:fixed;bottom:20px;right:20px;padding:12px 20px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;z-index:2000;animation:slideUp .3s}.toast-ok{background:var(--ok);color:#fff}.toast-error{background:var(--critical);color:#fff}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.theme-toggle{width:32px;height:32px;border-radius:50%;border:1px solid var(--sidebar-border);background:var(--sidebar-hover);color:var(--sidebar-text2);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;padding:0;line-height:1}.theme-toggle:hover{background:var(--sidebar-active-bg);color:var(--sidebar-text);border-color:var(--accent);transform:rotate(15deg)}.sidebar-collapse-btn{border-top:1px solid var(--sidebar-border)}.sidebar-collapse{width:100%;padding:10px;border:none;background:none;color:var(--sidebar-text2);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:color .15s}.sidebar-collapse:hover{color:var(--sidebar-text)}.wh-hamburger{display:none;position:fixed;top:12px;left:12px;z-index:200;width:40px;height:40px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--card);color:var(--text);font-size:20px;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow-md)}.wh-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:90}.wh-overlay.open{display:block}@media (max-width: 768px){.wh-hamburger{display:flex}.sidebar{position:fixed;top:0;left:0;bottom:0;width:220px!important;transform:translate(-100%);transition:transform .25s ease;z-index:100}.sidebar.open{transform:translate(0)}.sidebar.collapsed{width:220px!important}.main-content{margin-left:0!important;max-width:100vw!important;padding:60px 16px 16px!important}.card-grid-4{grid-template-columns:repeat(2,1fr)}table .col-hide-sm{display:none}}@media (max-width: 600px){.card-grid-4,.card-grid-3{grid-template-columns:1fr 1fr}.filter-bar{flex-direction:column;align-items:stretch}.pagination-bar{flex-direction:column;align-items:flex-start}}
