:root{--bg: #0f172a;--card: #1e293b;--card-2: #273548;--border: #334155;--text: #e2e8f0;--muted: #94a3b8;--accent: #3b82f6;--green: #22c55e;--red: #ef4444;--orange: #f97316;--yellow: #fbbf24;--purple: #a78bfa}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);font-size:14px}.app{display:grid;grid-template-columns:220px 1fr;height:100vh}.sidebar{background:var(--card);border-right:1px solid var(--border);padding:18px 12px;overflow-y:auto}.brand{font-size:14px;font-weight:600;color:var(--text);padding:0 8px 16px;border-bottom:1px solid var(--border);margin-bottom:14px}.brand-accent{color:var(--yellow)}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 10px;margin-bottom:2px;border-radius:8px;cursor:pointer;color:var(--muted);font-size:13px;transition:background .15s,color .15s;border:1px solid transparent;background:transparent;width:100%;text-align:left}.nav-item:hover{background:var(--card-2);color:var(--text)}.nav-item.active{background:var(--accent);color:#fff;border-color:var(--accent)}.nav-icon{font-size:16px;width:20px;text-align:center}.content{overflow:auto;padding:20px 24px}.content h2{margin:0 0 16px;font-size:18px;font-weight:600}.content h2 .crumb{color:var(--muted);font-weight:400;font-size:14px}.card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:16px;box-shadow:0 4px 14px #00000040}.card h3{margin:0 0 12px;font-size:14px;font-weight:600}.card-title-sub{font-size:11px;color:var(--muted);font-weight:400;margin-left:8px}.grid{display:grid;gap:14px}.grid.kpi{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.grid.cols-2{grid-template-columns:1fr 1fr}.grid.cols-3{grid-template-columns:repeat(3,1fr)}.grid.cols-4{grid-template-columns:repeat(4,1fr)}.grid.col-2-1{grid-template-columns:2fr 1fr}@media (max-width: 1100px){.grid.cols-2,.grid.cols-3,.grid.cols-4,.grid.col-2-1{grid-template-columns:1fr}}.kpi{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:14px 16px;box-shadow:0 4px 14px #0003}.kpi-label{font-size:11px;text-transform:uppercase;color:var(--muted);letter-spacing:.5px}.kpi-value{font-size:24px;font-weight:600;margin-top:6px}.kpi-sub{font-size:12px;color:var(--muted);margin-top:4px}.kpi-sub.up{color:var(--green)}.kpi-sub.down{color:var(--red)}.kpi-sub.warn{color:var(--orange)}.chart-wrap{height:320px;position:relative}.chart-wrap.tall{height:380px}.chart-wrap.short{height:240px}.alert{border-radius:12px;padding:14px 18px;margin-bottom:14px;border:1px solid;display:flex;align-items:center;gap:12px;font-size:14px}.alert-low{background:#14532d33;border-color:var(--green);color:#bbf7d0}.alert-medium{background:#78350f33;border-color:var(--yellow);color:#fde68a}.alert-high{background:#7f1d1d33;border-color:var(--red);color:#fecaca}.alert-icon{font-size:22px}.data-table{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--border);border-radius:8px;overflow:hidden}.data-table thead th{background:var(--card-2);text-align:left;font-size:12px;text-transform:uppercase;color:var(--muted);padding:10px 12px;border-bottom:1px solid var(--border);cursor:pointer;-webkit-user-select:none;user-select:none}.data-table thead th:hover{color:var(--text)}.data-table tbody td{padding:8px 12px;border-bottom:1px solid var(--border);font-size:13px}.data-table tbody tr:hover{background:var(--card-2)}.data-table tbody tr:last-child td{border-bottom:none}.num{text-align:right;font-variant-numeric:tabular-nums}.up{color:var(--green)}.down{color:var(--red)}.heatmap{display:grid;gap:4px;margin-top:10px}.heatmap-row{display:grid;grid-template-columns:60px repeat(12,1fr);gap:3px;align-items:center}.heatmap-cell{aspect-ratio:2 / 1;border-radius:4px;font-size:10px;color:#fff;display:flex;align-items:center;justify-content:center;font-variant-numeric:tabular-nums}.heatmap-axis{font-size:11px;color:var(--muted);text-align:right;padding-right:4px}.heatmap-header .heatmap-cell{background:transparent;color:var(--muted);aspect-ratio:auto;padding:4px}.chain{display:flex;align-items:stretch;gap:0;margin:14px 0}.chain-step{flex:1;background:var(--card-2);border:1px solid var(--border);border-radius:12px;padding:14px;text-align:center;position:relative}.chain-step+.chain-step{margin-left:28px}.chain-step+.chain-step:before{content:"→";position:absolute;left:-22px;top:50%;transform:translateY(-50%);font-size:22px;color:var(--accent)}.chain-label{font-size:11px;text-transform:uppercase;color:var(--muted);letter-spacing:.5px}.chain-value{font-size:18px;font-weight:600;margin:6px 0 4px}.chain-note{font-size:11px;color:var(--muted)}.tabs{display:flex;gap:4px}.tab{background:transparent;border:1px solid transparent;color:var(--muted);padding:6px 14px;border-radius:6px;cursor:pointer;font-size:13px}.tab.active{background:var(--card-2);border-color:var(--border);color:var(--text)}.tables-toolbar{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:12px}.tables-toolbar select,.tables-toolbar input{background:var(--card);border:1px solid var(--border);color:var(--text);padding:6px 10px;border-radius:6px;font-size:13px}.tables-toolbar button{background:var(--card-2);border:1px solid var(--border);color:var(--text);padding:6px 12px;border-radius:6px;cursor:pointer;font-size:13px}.tables-toolbar button.primary{background:var(--accent);border-color:var(--accent);color:#fff}.subtabs{display:flex;gap:4px;margin-bottom:12px}.subtab{background:transparent;border:1px solid var(--border);color:var(--muted);padding:5px 12px;border-radius:5px;cursor:pointer;font-size:12px}.subtab.active{background:var(--accent);color:#fff;border-color:var(--accent)}.chat{display:flex;flex-direction:column;height:100%;max-width:980px;margin:0 auto}.chat-quick{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.quick-btn{background:var(--card);border:1px solid var(--border);color:var(--text);padding:6px 12px;border-radius:14px;font-size:12px;cursor:pointer}.quick-btn:hover{background:var(--card-2);border-color:var(--accent)}.chat-stream{flex:1;overflow-y:auto;background:var(--card);border:1px solid var(--border);border-radius:8px;padding:16px;margin-bottom:12px}.msg{margin-bottom:16px}.msg-role{font-size:11px;text-transform:uppercase;color:var(--muted);letter-spacing:.5px;margin-bottom:4px}.msg.user .msg-role{color:var(--accent)}.msg.assistant .msg-role{color:var(--yellow)}.msg-body{background:var(--card-2);border:1px solid var(--border);border-radius:6px;padding:10px 14px;line-height:1.55}.msg-body code{background:#0c1117;padding:1px 6px;border-radius:4px;font-size:12.5px}.msg-body pre{background:#0c1117;padding:10px;border-radius:6px;overflow-x:auto;font-size:12px}.sql-toggle{margin-top:6px;background:transparent;border:1px dashed var(--border);color:var(--muted);padding:6px 10px;border-radius:4px;cursor:pointer;font-size:11px;font-family:monospace}.sql-block{margin-top:6px;background:#0c1117;border:1px solid var(--border);border-radius:6px;padding:10px;font-size:12px;overflow-x:auto;font-family:SF Mono,Menlo,monospace}.chat-form{display:flex;gap:8px}.chat-form input{flex:1;background:var(--card);border:1px solid var(--border);color:var(--text);padding:12px 14px;border-radius:8px;font-size:14px}.chat-form input:focus{outline:none;border-color:var(--accent)}.chat-form button{background:var(--accent);color:#fff;border:none;padding:0 22px;border-radius:8px;cursor:pointer;font-weight:600}.chat-form button:disabled{opacity:.5;cursor:not-allowed}.spinner{display:inline-block;width:14px;height:14px;border:2px solid var(--muted);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.muted{color:var(--muted)}.error{background:#3b1d1d;border:1px solid var(--red);color:#fca5a5;padding:10px 14px;border-radius:6px;margin:8px 0}.empty{padding:60px 20px;text-align:center;color:var(--muted);border:1px dashed var(--border);border-radius:8px}.bullet{color:var(--accent)}
