@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600&display=swap");:root{--bg-app:#fff;--bg-sidebar:#f8f9fb;--bg-surface-1:#fff;--bg-surface-2:#f3f4f6;--bg-surface-3:#e5e7eb;--bg-overlay:rgba(0,0,0,.3);--text-primary:#111827;--text-secondary:#4b5563;--text-muted:#6b7280;--text-disabled:#9ca3af;--text-body:#374151;--accent:#2563eb;--accent-light:#3b82f6;--accent-dim:rgba(37,99,235,.08);--accent-border:rgba(37,99,235,.2);--accent-bg:rgba(37,99,235,.05);--success:#059669;--warning:#d97706;--danger:#dc2626;--info:#0891b2;--purple:#7c3aed;--border-subtle:#e5e7eb;--border-medium:#d1d5db;--border-strong:#9ca3af;--shadow-sm:0 1px 2px rgba(0,0,0,.05);--shadow-md:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.04);--shadow-lg:0 4px 12px rgba(0,0,0,.08),0 2px 4px rgba(0,0,0,.04);--shadow-xl:0 8px 24px rgba(0,0,0,.1),0 4px 8px rgba(0,0,0,.06);--font-sans:"Inter",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--font-mono:"JetBrains Mono",ui-monospace,monospace;--text-xs:10px;--text-sm:12px;--text-base:14px;--text-md:16px;--text-lg:18px;--text-xl:20px;--text-2xl:24px;--text-3xl:30px;--text-4xl:34px;--text-5xl:48px;--sp-1:3px;--sp-2:8px;--sp-3:10px;--sp-4:12px;--sp-5:16px;--sp-6:20px;--sp-8:24px;--sp-10:30px;--sp-12:40px;--sp-16:60px;--sp-20:80px;--radius-none:0px;--radius-sm:4px;--radius-md:6px;--radius-lg:10px;--radius-pill:50px;--ease-default:ease-in-out;--t-fast:0.15s;--t-default:0.25s ease-in-out;--t-medium:0.3s ease;--t-slow:0.35s;--surface-hover:rgba(0,0,0,.03)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:1.5;color:var(--text-primary);background:var(--bg-app);overflow:hidden;height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;font-family:var(--font-sans);font-size:var(--text-base);font-weight:500;padding:6px 14px;border-radius:var(--radius-sm);border:1px solid transparent;cursor:pointer;white-space:nowrap;line-height:1.4;background:var(--bg-surface-2);color:var(--text-primary);border-color:var(--border-subtle);transition:background-color var(--t-medium),border-color var(--t-medium),color var(--t-medium)}.btn:hover{background:var(--bg-surface-3);border-color:var(--border-medium)}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover{background:#2563eb;border-color:#2563eb}.btn-ghost{background:transparent;border-color:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:var(--surface-hover);color:var(--text-primary)}.btn-sm{padding:3px 8px;font-size:var(--text-sm)}.btn-outlined{background:transparent;border-color:var(--accent);color:var(--accent)}.btn-outlined:hover{background:var(--accent-dim)}.btn-icon{padding:4px;width:28px;height:28px}.btn-icon.btn-sm{width:22px;height:22px;padding:2px}.input{font-family:var(--font-sans);font-size:var(--text-base);color:var(--text-primary);background:var(--bg-surface-3);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:6px 10px;width:100%;outline:none;transition:border-color var(--t-default),box-shadow var(--t-default)}.input::placeholder{color:var(--text-disabled)}.input:focus{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),0 0 20px rgba(59,130,246,.12)}.input-lg{padding:10px 14px;font-size:var(--text-md)}.input-group{position:relative;display:flex;align-items:center;width:100%}.input-group .input-icon{position:absolute;left:10px;color:var(--text-disabled);pointer-events:none;z-index:1}.input-group .input{padding-left:34px}.input-group-lg .input-icon{left:14px}.input-group-lg .input{padding-left:42px}.select{font-family:var(--font-sans);font-size:var(--text-base);color:var(--text-primary);background:var(--bg-surface-3);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:6px 10px;outline:none;cursor:pointer}.card{background:var(--bg-surface-1);border:1px solid var(--border-subtle);border-radius:var(--radius-md);box-shadow:var(--shadow-md);transition:box-shadow var(--t-medium),border-color var(--t-medium)}.card-interactive:hover,.card:hover{box-shadow:var(--shadow-lg);border-color:var(--border-medium);cursor:pointer}.tag{display:inline-flex;align-items:center;gap:4px;font-size:var(--text-sm);font-weight:500;padding:2px 8px;border-radius:var(--radius-sm);white-space:nowrap;line-height:1.5;background:#f3f4f6;color:var(--text-secondary)}.tag-success{background:rgba(5,150,105,.1);color:#059669}.tag-warning{background:rgba(217,119,6,.1);color:#d97706}.tag-danger{background:rgba(220,38,38,.1);color:#dc2626}.tag-primary{background:var(--accent-dim);color:var(--accent)}.tag-lg{font-size:var(--text-base);padding:4px 12px}.tag-interactive{cursor:pointer}.tag-interactive:hover{opacity:.8}.badge{font-size:var(--text-xs);font-weight:600;padding:2px 8px;border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.05em;display:inline-block;line-height:1.4}.badge-high{background:var(--accent-dim);color:var(--accent)}.badge-vhigh{background:rgba(5,150,105,.1);color:#059669}.badge-medium{background:rgba(217,119,6,.1);color:#d97706}.badge-low{background:rgba(220,38,38,.1);color:#dc2626}.badge{white-space:nowrap;overflow:visible;text-overflow:unset}.data-table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.data-table th{color:var(--text-muted);font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-medium);text-align:left}.data-table td,.data-table th{padding:var(--sp-2) var(--sp-4)}.data-table td{color:var(--text-body);border-bottom:1px solid var(--border-subtle)}.data-table tbody tr:nth-child(odd) td{background:#f9fafb}.data-table tbody tr:hover td{background:#f3f4f6}.data-table .tr{text-align:right}.callout{display:flex;gap:10px;align-items:flex-start;padding:var(--sp-4) var(--sp-5);border-radius:var(--radius-md);font-size:var(--text-sm);line-height:1.5;background:var(--bg-surface-2);color:var(--text-body);border-left:3px solid var(--border-medium)}.callout-icon{flex-shrink:0;margin-top:1px}.callout-primary{border-left-color:var(--accent)}.callout-success{border-left-color:var(--success)}.callout-warning{border-left-color:var(--warning)}.callout-danger{border-left-color:var(--danger)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:40px 20px;text-align:center}.empty-state-icon{color:var(--text-disabled)}.empty-state-title{font-size:var(--text-base);font-weight:500;color:var(--text-secondary)}.empty-state-desc{font-size:var(--text-sm);color:var(--text-muted)}@keyframes spin{to{transform:rotate(1turn)}}.spinner{animation:spin .8s linear infinite;color:var(--accent)}.modal-overlay{position:fixed;inset:0;z-index:100;background:var(--bg-overlay);display:flex;justify-content:center;padding-top:15vh;animation:fadeIn var(--t-fast) var(--ease-default)}.modal{background:var(--bg-surface-1);border:1px solid var(--border-medium);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);width:560px;max-width:90vw;max-height:70vh;display:flex;flex-direction:column;overflow:hidden;animation:slideUp .2s var(--ease-default)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-4) var(--sp-5);background:var(--bg-surface-2);border-bottom:1px solid var(--border-subtle);font-size:var(--text-base);font-weight:600}.modal-body{padding:var(--sp-5);overflow-y:auto;flex:1 1}.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:var(--sp-4) var(--sp-5);border-top:1px solid var(--border-subtle)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.topbar{display:flex;align-items:center;justify-content:space-between;height:44px;padding:0 8px;background:var(--bg-sidebar);border-bottom:1px solid var(--border-subtle);flex-shrink:0}.topbar-left,.topbar-right{display:flex;align-items:center;gap:4px;height:100%}.topbar-divider{width:1px;height:16px;background:var(--border-subtle);margin:0 4px}.topbar-logo{font-size:13px;font-weight:700;letter-spacing:.02em;cursor:pointer;margin-right:8px;-webkit-user-select:none;-moz-user-select:none;user-select:none}.sidebar{flex-direction:column;padding:8px 0;background:var(--bg-sidebar);border-right:1px solid var(--border-subtle);flex-shrink:0;transition:width .2s var(--ease-default)}.sidebar,.sidebar-item{display:flex;overflow:hidden}.sidebar-item{align-items:center;gap:10px;padding:6px 12px;margin:1px 8px;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);font-size:13px;white-space:nowrap;transition:all var(--t-fast)}.sidebar-item:hover{background:var(--surface-hover);color:var(--text-primary)}.sidebar-item svg{flex-shrink:0}.sidebar-divider{height:1px;background:var(--border-subtle);margin:8px 12px}.sidebar-footer{padding:8px 12px;font-size:9px;color:var(--text-muted);text-align:center}.panel{background:var(--bg-surface-1);border:1px solid var(--border-subtle);border-radius:var(--radius-md);overflow:hidden;height:100%;display:flex;flex-direction:column;transition:border-color .2s var(--ease-default)}.panel:hover{border-color:var(--border-medium)}.panel-header{background:var(--bg-surface-2);border-bottom:1px solid var(--border-subtle);padding:var(--sp-2) var(--sp-4);display:flex;align-items:center;justify-content:space-between;cursor:-webkit-grab;cursor:grab;-webkit-user-select:none;-moz-user-select:none;user-select:none;min-height:36px}.panel-header:active{cursor:-webkit-grabbing;cursor:grabbing}.panel-title{font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.panel-body{flex:1 1;overflow-y:auto;overflow-x:hidden;padding:var(--sp-4);overscroll-behavior:contain}.kpi{text-align:center;padding:var(--sp-5) var(--sp-4)}.kpi-value{font-family:var(--font-mono);font-size:28px;font-weight:700;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;line-height:1.2}.kpi-label{font-size:var(--text-xs);font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-top:4px}.prob-bar{height:6px;border-radius:3px;background:#e5e7eb;overflow:hidden}.prob-fill{height:100%;border-radius:3px;transition:width var(--t-slow)}.prob-fill-high{background:linear-gradient(90deg,#059669,#10b981)}.prob-fill-medium{background:linear-gradient(90deg,#d97706,#f59e0b)}.prob-fill-low{background:linear-gradient(90deg,#dc2626,#ef4444)}.status-dot{width:6px;height:6px;border-radius:50%;display:inline-block}.status-dot-ok{background:var(--success);box-shadow:0 0 6px var(--success)}.status-dot-warn{background:var(--warning);box-shadow:0 0 6px var(--warning)}.status-dot-err{background:var(--danger);box-shadow:0 0 6px var(--danger)}.section-label{font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:8px}.search-row{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;cursor:pointer;border-radius:var(--radius-md);transition:background var(--t-fast)}.search-row:hover{background:var(--surface-hover)}.tab-bar{display:flex;gap:2px;border-bottom:1px solid var(--border-subtle);margin-bottom:var(--sp-5)}.tab{padding:8px 16px;font-size:var(--text-base);font-weight:500;cursor:pointer;color:var(--text-muted);transition:color var(--t-default),border-color var(--t-default);background:none;border:none;border-bottom:2px solid transparent}.tab:hover{color:var(--text-secondary)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.ws-tab{padding:3px 10px;font-size:var(--text-xs);font-weight:500;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;gap:4px;border:1px solid transparent;color:var(--text-muted);transition:all var(--t-fast)}.ws-tab:hover{background:var(--surface-hover);color:var(--text-secondary)}.ws-tab.active{background:var(--accent-dim);color:var(--accent-light);border-color:var(--accent-border)}.kbd{font-family:var(--font-mono);font-size:10px;padding:1px 5px;background:#f3f4f6;border:1px solid var(--border-medium);border-radius:var(--radius-sm);color:var(--text-muted)}.msg-user{background:var(--accent-dim);border:1px solid var(--accent-border);border-radius:var(--radius-md);align-self:flex-end}.msg-bot,.msg-user{padding:8px 12px;max-width:85%;font-size:13px;line-height:1.5;color:var(--text-body);white-space:pre-wrap}.msg-bot{background:var(--surface-hover);border:1px solid var(--border-subtle);border-radius:var(--radius-md);align-self:flex-start}.cmd-input{font-family:var(--font-sans);font-size:var(--text-md);color:var(--text-primary);background:var(--bg-surface-2);border:none;border-bottom:1px solid var(--border-subtle);padding:14px 16px 14px 44px;width:100%;outline:none}.cmd-input::placeholder{color:var(--text-disabled)}.cmd-results{max-height:400px;overflow-y:auto;padding:4px 0}.cmd-item{display:flex;align-items:center;gap:10px;padding:8px 12px;margin:2px 8px;border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-base);color:var(--text-body);transition:background var(--t-fast)}.cmd-item.active,.cmd-item:hover{background:var(--surface-hover)}.cmd-item-icon{color:var(--text-muted);flex-shrink:0}.cmd-item-desc{font-size:var(--text-xs);color:var(--text-muted);margin-left:auto}.react-grid-layout{position:relative}.react-grid-item{transition:all .2s var(--ease-default)}.react-grid-item.react-grid-placeholder{background:var(--accent-bg)!important;border:2px dashed var(--accent-border)!important;border-radius:var(--radius-md)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#9ca3af}.divider{height:1px;background:var(--border-subtle);margin:8px 0}