#root{min-height:100vh}:root{--font-sans: "Inter", "IBM Plex Sans", "Segoe UI", system-ui, sans-serif;--font-mono: "JetBrains Mono", "IBM Plex Mono", "SFMono-Regular", monospace;--color-bg: #f4f6fa;--color-bg-subtle: #eef1f7;--color-surface: #ffffff;--color-surface-raised: #ffffff;--color-surface-muted: #f7f9fc;--color-border: #e3e8ef;--color-border-strong: #cfd6e1;--color-ring: rgba(15, 56, 104, .18);--color-text: #0f1b2d;--color-text-muted: #5b6b7d;--color-text-soft: #8894a3;--color-text-inverse: #f6f9fd;--color-primary: #2a5fd5;--color-primary-hover: #1f4cb8;--color-primary-soft: rgba(42, 95, 213, .12);--color-success: #158a6e;--color-success-soft: rgba(21, 138, 110, .14);--color-warn: #b4751a;--color-warn-soft: rgba(180, 117, 26, .16);--color-danger: #c2453c;--color-danger-soft: rgba(194, 69, 60, .14);--color-info: #295bbf;--color-info-soft: rgba(41, 91, 191, .12);--color-neutral-soft: #eef2f7;--color-sidebar-bg: #0c1a2d;--color-sidebar-bg-alt: #112341;--color-sidebar-text: #c7d3e3;--color-sidebar-text-strong: #ffffff;--color-sidebar-border: rgba(255, 255, 255, .08);--radius-xs: 4px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 18px;--radius-pill: 999px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-7: 32px;--space-8: 40px;--shadow-sm: 0 1px 2px rgba(12, 26, 45, .06);--shadow-md: 0 4px 12px rgba(12, 26, 45, .08);--shadow-lg: 0 18px 40px rgba(12, 26, 45, .12);--sidebar-width: 256px;--topbar-height: 64px;color-scheme:light;font-family:var(--font-sans);color:var(--color-text);line-height:1.5;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%}body{min-width:320px;background:var(--color-bg)}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit;color:inherit}button{cursor:pointer}input,select,textarea{width:100%;padding:10px 12px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text);transition:border-color .12s ease,box-shadow .12s ease}input::placeholder,textarea::placeholder{color:var(--color-text-soft)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-ring)}.app-shell{display:grid;grid-template-columns:var(--sidebar-width) minmax(0,1fr);min-height:100vh;background:var(--color-bg)}.sidebar{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;background:linear-gradient(180deg,var(--color-sidebar-bg),var(--color-sidebar-bg-alt));color:var(--color-sidebar-text);border-right:1px solid var(--color-sidebar-border)}.sidebar-brand{padding:22px 20px 18px;border-bottom:1px solid var(--color-sidebar-border)}.sidebar-brand-mark{display:flex;align-items:center;gap:10px}.sidebar-brand-dot{width:28px;height:28px;border-radius:8px;background:linear-gradient(135deg,#3b82f6,#22c7a9);box-shadow:0 4px 12px #3b82f659}.sidebar-brand-title{font-size:.96rem;font-weight:600;letter-spacing:.02em;color:var(--color-sidebar-text-strong)}.sidebar-brand-sub{margin-top:2px;font-size:.78rem;color:#c7d3e3b3}.sidebar-nav{flex:1;padding:12px 12px 0;overflow-y:auto}.sidebar-group{margin-top:14px}.sidebar-group:first-child{margin-top:4px}.sidebar-group-label{padding:6px 10px;font-size:.68rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:#c7d3e385}.sidebar-link{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:var(--radius-md);color:#c7d3e3e0;font-size:.92rem;transition:background-color .12s ease,color .12s ease}.sidebar-link:hover{background:#ffffff0d;color:var(--color-sidebar-text-strong)}.sidebar-link.active{background:#3b82f629;color:var(--color-sidebar-text-strong);box-shadow:inset 2px 0 #5b92f1}.sidebar-icon{width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center;color:currentColor;flex-shrink:0}.sidebar-footer{padding:14px 14px 18px;border-top:1px solid var(--color-sidebar-border)}.sidebar-user{display:flex;align-items:center;gap:10px;margin-bottom:12px}.sidebar-user-avatar{width:32px;height:32px;border-radius:var(--radius-pill);background:#ffffff1f;color:var(--color-sidebar-text-strong);display:grid;place-items:center;font-weight:600;font-size:.82rem}.sidebar-user-meta{display:flex;flex-direction:column;min-width:0}.sidebar-user-name{font-size:.9rem;font-weight:500;color:var(--color-sidebar-text-strong);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-email{font-size:.76rem;color:#c7d3e39e;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.main-area{display:flex;flex-direction:column;min-width:0}.topbar{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);min-height:var(--topbar-height);padding:0 var(--space-7);background:#ffffffe0;border-bottom:1px solid var(--color-border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.topbar-title{display:flex;flex-direction:column;gap:2px;min-width:0}.topbar-breadcrumbs{display:flex;gap:6px;font-size:.78rem;color:var(--color-text-soft)}.topbar-breadcrumbs span+span:before{content:"/";margin-right:6px;color:var(--color-text-soft)}.topbar-title h1{margin:0;font-size:1.1rem;font-weight:600}.topbar-actions{display:flex;align-items:center;gap:10px}.page{padding:var(--space-6) var(--space-7) var(--space-8);display:flex;flex-direction:column;gap:var(--space-5);min-width:0}.sidebar-toggle{display:none;background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:6px 8px;cursor:pointer;color:var(--color-text);align-items:center;justify-content:center}.sidebar-toggle:hover{background:var(--color-surface-muted)}.sidebar-close{display:none;background:transparent;border:1px solid rgba(255,255,255,.12);color:var(--color-sidebar-text-strong);border-radius:var(--radius-sm);padding:4px 8px;cursor:pointer;font-size:1.1rem;line-height:1}.sidebar-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0c1a2d73;z-index:19}@media(max-width:960px){.app-shell{grid-template-columns:minmax(0,1fr)}.sidebar{position:fixed;top:0;left:0;width:min(280px,82vw);height:100vh;transform:translate(-100%);transition:transform .2s ease;z-index:20;box-shadow:0 20px 50px #0c1a2d59}.sidebar.open{transform:translate(0)}.sidebar-backdrop.visible{display:block}.sidebar-toggle,.sidebar-close{display:inline-flex}.topbar{padding:0 var(--space-4);gap:var(--space-3)}.topbar-title h1{font-size:1rem}.page{padding:var(--space-4) var(--space-4) var(--space-6)}}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-4);min-width:0}.panel-header{display:flex;justify-content:space-between;align-items:center;gap:var(--space-3)}.panel-header h2,.panel-header h3{margin:0;font-size:1rem;font-weight:600}.panel-header-actions{display:flex;gap:8px;align-items:center}.panel-subtitle{margin:-4px 0 0;color:var(--color-text-muted);font-size:.86rem}.panel.ghost{background:var(--color-surface-muted);box-shadow:none}.panel.flush{padding:0;overflow:hidden}.panel.flush .panel-header{padding:var(--space-5) var(--space-5) 0}.panel.flush .panel-body{padding:0 var(--space-5) var(--space-5)}.panel.flush .data-table{border-top:1px solid var(--color-border)}.grid{display:grid;gap:var(--space-4)}.grid-cols-kpi{grid-template-columns:repeat(auto-fit,minmax(190px,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-kv{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}@media(max-width:1040px){.grid-cols-2,.grid-cols-3{grid-template-columns:1fr}}.charts-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--space-3)}@media(max-width:1280px){.charts-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:960px){.charts-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:640px){.charts-grid{grid-template-columns:1fr}}.chart-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:10px 12px;display:flex;flex-direction:column;gap:6px;min-width:0;box-shadow:var(--shadow-sm)}.chart-card-header{display:flex;flex-direction:column;gap:2px;min-width:0}.chart-card-header strong{font-size:.82rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chart-card-header .muted{font-size:.72rem;color:var(--color-text-muted)}.chart-card-body{width:100%;height:160px}.chart-card-empty{height:160px;display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);font-size:.78rem}.metric-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(clamp(160px,22vw,240px),1fr));gap:12px}@media(max-width:640px){.metric-cards-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}}.metric-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:12px 14px;display:flex;flex-direction:column;gap:4px;min-width:0;box-shadow:0 1px 1px #0c1a2d0a,0 6px 14px #0c1a2d14,0 16px 32px #0c1a2d0f;transition:transform .12s ease,box-shadow .12s ease}.metric-card:hover{transform:translateY(-1px);box-shadow:0 1px 1px #0c1a2d0d,0 10px 20px #0c1a2d1a,0 24px 44px #0c1a2d14}.metric-card.stale{background:linear-gradient(180deg,rgba(194,69,60,.08),var(--color-surface));border-color:#c2453c59}.metric-card-metric{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);font-weight:600}.metric-card-device{font-size:.9rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.metric-card-value{font-size:clamp(1.3rem,2.4vw,1.9rem);font-weight:700;text-align:center;line-height:1.1;margin:4px 0 2px;word-break:break-word}.metric-card-value .metric-card-unit{font-size:.9rem;font-weight:500;color:var(--color-text-muted);margin-left:4px}.metric-card-time{font-size:.78rem;color:var(--color-text-muted);text-align:right}.metric-card.stale .metric-card-time{color:#8a2a24;font-weight:600}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);display:flex;flex-direction:column;gap:6px;box-shadow:var(--shadow-sm);min-width:0}.stat-card-label{color:var(--color-text-muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;font-weight:600}.stat-card-value{font-size:1.6rem;font-weight:600;letter-spacing:-.01em}.stat-card-hint{font-size:.8rem;color:var(--color-text-soft)}.stat-card.accent-primary{border-color:var(--color-primary-soft);background:linear-gradient(180deg,rgba(42,95,213,.05),var(--color-surface))}.stat-card.accent-warn{border-color:var(--color-warn-soft);background:linear-gradient(180deg,rgba(180,117,26,.06),var(--color-surface))}.stat-card.accent-danger{border-color:var(--color-danger-soft);background:linear-gradient(180deg,rgba(194,69,60,.06),var(--color-surface))}.data-table{width:100%;border-collapse:separate;border-spacing:0}.data-table thead th{text-align:left;padding:10px var(--space-4);font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted);background:var(--color-surface-muted);border-bottom:1px solid var(--color-border);font-weight:600}.data-table tbody td{padding:12px var(--space-4);border-bottom:1px solid var(--color-border);vertical-align:top;font-size:.92rem}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover td{background:var(--color-surface-muted)}.data-table td.num,.data-table th.num{text-align:right;font-variant-numeric:tabular-nums}.cell-stack{display:flex;flex-direction:column;gap:2px}.cell-stack-sub{color:var(--color-text-soft);font-size:.78rem}.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.toolbar .toolbar-grow{flex:1;min-width:200px}.toolbar input,.toolbar select{max-width:320px}.filter-bar{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end}.filter-field{display:flex;flex-direction:column;gap:4px}.filter-field label{font-size:.74rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em}.filter-field input,.filter-field select{min-width:180px}.segmented{display:inline-flex;padding:4px;background:var(--color-surface-muted);border-radius:var(--radius-md);border:1px solid var(--color-border);gap:4px}.segmented-item{border:0;background:transparent;padding:6px 12px;font-size:.86rem;border-radius:var(--radius-sm);color:var(--color-text-muted);font-weight:500}.segmented-item.active{background:var(--color-surface);color:var(--color-text);box-shadow:var(--shadow-sm)}.tabs{display:flex;gap:2px;border-bottom:1px solid var(--color-border);margin-bottom:var(--space-4);overflow-x:auto}.tab{position:relative;background:transparent;border:0;padding:10px 14px;font-size:.92rem;color:var(--color-text-muted);font-weight:500;white-space:nowrap;border-radius:var(--radius-sm) var(--radius-sm) 0 0}.tab:hover{color:var(--color-text);background:var(--color-surface-muted)}.tab.active{color:var(--color-primary)}.tab.active:after{content:"";position:absolute;left:8px;right:8px;bottom:-1px;height:2px;background:var(--color-primary);border-radius:2px 2px 0 0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid transparent;background:transparent;border-radius:var(--radius-md);padding:8px 14px;font-size:.9rem;font-weight:500;transition:background-color .12s ease,border-color .12s ease,color .12s ease,transform 60ms ease;white-space:nowrap}.btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.btn:not(:disabled):active{transform:translateY(1px)}.btn.primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn.primary:hover:not(:disabled){background:var(--color-primary-hover);border-color:var(--color-primary-hover)}.btn.secondary{background:var(--color-surface);color:var(--color-text);border-color:var(--color-border)}.btn.secondary:hover:not(:disabled){border-color:var(--color-border-strong);background:var(--color-surface-muted)}.btn.ghost{color:var(--color-text-muted)}.btn.ghost:hover:not(:disabled){background:var(--color-surface-muted);color:var(--color-text)}.btn.danger{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}.btn.danger:hover:not(:disabled){background:#a7332a;border-color:#a7332a}.btn.sm{padding:6px 10px;font-size:.82rem}.badge{display:inline-flex;align-items:center;gap:6px;padding:3px 9px;border-radius:var(--radius-pill);font-size:.76rem;font-weight:500;background:var(--color-neutral-soft);color:var(--color-text);line-height:1.25}.badge.solid-neutral{background:#e5e9f0}.badge.success{background:var(--color-success-soft);color:var(--color-success)}.badge.warn{background:var(--color-warn-soft);color:var(--color-warn)}.badge.danger{background:var(--color-danger-soft);color:var(--color-danger)}.badge.info{background:var(--color-info-soft);color:var(--color-info)}.badge-dot{width:6px;height:6px;border-radius:50%;background:currentColor;display:inline-block}.kv-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space-3)}.kv-item{display:flex;flex-direction:column;gap:4px;padding:12px 14px;border-radius:var(--radius-md);background:var(--color-surface-muted);border:1px solid var(--color-border)}.kv-item .kv-label{font-size:.74rem;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);font-weight:600}.kv-item .kv-value{font-size:.95rem;font-weight:500;color:var(--color-text);word-break:break-word}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--space-3)}.form-grid .full-width{grid-column:1 / -1}.field{display:flex;flex-direction:column;gap:4px}.field label{font-size:.78rem;color:var(--color-text-muted);font-weight:500}.stack{display:flex;flex-direction:column;gap:var(--space-3)}.row{display:flex;gap:var(--space-3);align-items:center;flex-wrap:wrap}.row.between{justify-content:space-between}.button-row{display:flex;gap:var(--space-3);flex-wrap:wrap}.empty-state{padding:var(--space-5);border-radius:var(--radius-md);background:var(--color-surface-muted);border:1px dashed var(--color-border-strong);color:var(--color-text-muted);font-size:.9rem;display:flex;flex-direction:column;gap:4px;align-items:flex-start}.empty-state strong{color:var(--color-text);font-weight:600;font-size:.95rem}.loading-block{display:flex;align-items:center;gap:10px;padding:var(--space-5);color:var(--color-text-muted)}.spinner{width:16px;height:16px;border:2px solid rgba(42,95,213,.18);border-top-color:var(--color-primary);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0c1a2d61;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:50;display:flex;justify-content:flex-end}.drawer{width:min(480px,100%);height:100vh;background:var(--color-surface);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;animation:slide-in .18s ease}@keyframes slide-in{0%{transform:translate(16px);opacity:0}}.drawer-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-5);border-bottom:1px solid var(--color-border)}.drawer-header h3{margin:0;font-size:1rem;font-weight:600}.drawer-body{flex:1;overflow-y:auto;padding:var(--space-5)}.drawer-footer{padding:var(--space-4) var(--space-5);border-top:1px solid var(--color-border);display:flex;gap:var(--space-3);justify-content:flex-end}.auth-screen{min-height:100vh;display:grid;place-items:center;padding:var(--space-6);background:radial-gradient(circle at 15% 20%,rgba(59,130,246,.18),transparent 40%),radial-gradient(circle at 85% 80%,rgba(34,199,169,.14),transparent 40%),linear-gradient(180deg,#f8fbff,#eef3fb)}.auth-card{width:min(420px,100%);background:var(--color-surface);border-radius:var(--radius-xl);padding:var(--space-7);box-shadow:var(--shadow-lg);border:1px solid var(--color-border)}.auth-card h1{margin:0 0 4px;font-size:1.3rem;font-weight:600}.auth-card p{margin:0 0 var(--space-5);color:var(--color-text-muted);font-size:.92rem}.muted{color:var(--color-text-muted)}.soft{color:var(--color-text-soft)}.mono{font-family:var(--font-mono);font-size:.84rem;color:var(--color-text-muted)}.hr{height:1px;background:var(--color-border);border:0;margin:0}.text-sm{font-size:.86rem}.text-xs{font-size:.78rem}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.flex-1{flex:1}.stat-card.clickable{cursor:pointer;text-decoration:none;color:inherit;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}.stat-card.clickable:hover{transform:translateY(-1px);border-color:var(--color-border-strong);box-shadow:var(--shadow-md)}.data-table tbody tr.row-alert td{background:var(--color-danger-soft)}.data-table tbody tr.row-alert:hover td{background:#c2453c33}.data-table tbody tr.inbox-row-new td{background:var(--color-warn-soft)}.data-table tbody tr.inbox-row-new:hover td{background:#b4751a38}.data-table tbody tr.inbox-row-archived td{opacity:.6}.data-table tbody tr.inbox-row-expanded td{background:var(--color-surface-muted);border-top:0}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-sm);border:1px solid transparent;background:transparent;color:var(--color-text-muted);transition:background-color .12s ease,color .12s ease,border-color .12s ease}.icon-btn:hover:not(:disabled){background:var(--color-surface-muted);color:var(--color-text);border-color:var(--color-border)}.icon-btn:disabled{opacity:.5;cursor:not-allowed}.icon-btn-danger:hover:not(:disabled){color:var(--color-danger);border-color:var(--color-danger-soft);background:var(--color-danger-soft)}.profile-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space-3) var(--space-5)}.profile-field{display:flex;flex-direction:column;gap:2px;min-width:0}.profile-field-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);font-weight:600}.profile-field-value{font-size:.92rem;font-weight:500;color:var(--color-text);word-break:break-word}.radio-group{display:inline-flex;padding:4px;background:var(--color-surface-muted);border-radius:var(--radius-md);border:1px solid var(--color-border);gap:4px}.radio-group-item{border:0;background:transparent;padding:6px 12px;font-size:.82rem;border-radius:var(--radius-sm);color:var(--color-text-muted);font-weight:500}.radio-group-item.active{background:var(--color-surface);color:var(--color-text);box-shadow:var(--shadow-sm)}@media(max-width:960px){.app-shell{grid-template-columns:1fr}.sidebar{position:static;height:auto}.topbar{padding:0 var(--space-5)}.page{padding:var(--space-5)}}
