html,body,#root{-webkit-font-smoothing:antialiased;width:100%;height:100%;overflow:hidden}:root,[data-theme=light]{--bg:#f5f4ee;--bg-surface:#fff;--bg-card:#fff;--bg-data:#f0ebe1;--bg-chip:#efece6;--bg-code:#ebe7df;--bg-hover:#f7f5f1;--bg-zebra:#f9f7f4;--border:#e3ddd4;--border-soft:#ede9e2;--text:#0a0a0a;--text-muted:#6b6460;--text-faint:#a8a09a;--accent:#6366f1;--accent-hover:#4f46e5;--accent-light:#eeedfd;--btn-bg:#0a0a0a;--btn-text:#fff;--btn-hover-bg:#222;--bar-fill:#0a0a0a;--bar-active:#6366f1;--sidebar-bg:#fff;--sidebar-w:220px;--sidebar-w-collapsed:56px;--shadow-sm:0 1px 3px #0000000f;--shadow-card:0 2px 8px #0000000d}[data-theme=dark]{--bg:#0b1120;--bg-surface:#111827;--bg-card:#111827;--bg-data:#0d1829;--bg-chip:#151f30;--bg-code:#0a1220;--bg-hover:#1a2840;--bg-zebra:#0f1a2a;--border:#1f2937;--border-soft:#172030;--text:#e5e7eb;--text-muted:#9ca3af;--text-faint:#4b5563;--accent:#818cf8;--accent-hover:#6366f1;--accent-light:#1a1f40;--btn-bg:#e5e7eb;--btn-text:#0b1120;--btn-hover-bg:#fff;--bar-fill:#cbd5e1;--bar-active:#818cf8;--sidebar-bg:#0d1321;--sidebar-w:220px;--sidebar-w-collapsed:56px;--shadow-sm:0 1px 3px #0000004d;--shadow-card:0 2px 12px #0006}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:Inter,system-ui,sans-serif;font-size:14px;line-height:1.5;overflow:hidden}.app-layout{width:100%;height:100dvh;display:flex}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--sidebar-bg);border-right:1px solid var(--border);z-index:20;flex-direction:column;flex-shrink:0;height:100%;transition:width .25s cubic-bezier(.4,0,.2,1),min-width .25s cubic-bezier(.4,0,.2,1);display:flex;overflow:hidden}.sidebar--collapsed{width:52px;min-width:52px}.sidebar-header{border-bottom:1px solid var(--border-soft);justify-content:space-between;align-items:center;gap:8px;min-height:60px;padding:16px 14px;display:flex}.sidebar--collapsed .sidebar-header{justify-content:center}.sidebar-brand{white-space:nowrap;align-items:center;gap:9px;display:flex;overflow:hidden}.sidebar-brand-icon{flex-shrink:0;font-size:18px}.sidebar-brand-name{letter-spacing:-.3px;color:var(--text);font-size:15px;font-weight:700}.sidebar-toggle-btn{cursor:pointer;background:0 0;border:none;border-radius:6px;flex-direction:column;flex-shrink:0;gap:4px;padding:6px;transition:background .15s;display:flex}.sidebar-toggle-btn:hover{background:var(--bg-hover)}.bar{background:var(--text-muted);border-radius:2px;width:16px;height:1.5px;display:block}.sidebar-upload-area{padding:14px 12px 10px}.sidebar-add-btn{background:var(--btn-bg);width:100%;color:var(--btn-text);cursor:pointer;white-space:nowrap;border:none;border-radius:8px;align-items:center;gap:8px;padding:9px 14px;font-size:13.5px;font-weight:600;transition:background .15s;display:flex;overflow:hidden}.sidebar-add-btn:hover:not(:disabled){background:var(--btn-hover-bg)}.sidebar-add-btn:disabled{opacity:.5;cursor:not-allowed}.sidebar-reset-btn{width:100%;color:var(--text-muted);border:1px solid var(--border);cursor:pointer;white-space:nowrap;background:0 0;border-radius:8px;align-items:center;gap:8px;padding:9px 14px;font-size:13px;font-weight:500;transition:all .15s;display:flex;overflow:hidden}.sidebar-reset-btn:hover{border-color:var(--accent);color:var(--accent)}.add-icon{flex-shrink:0;font-size:16px;font-weight:400;line-height:1}.sidebar-error{color:#ef4444;margin-top:6px;padding:0 2px;font-size:11.5px}.sidebar-divider{background:var(--border-soft);height:1px;margin:6px 0}.sidebar-nav{flex-direction:column;gap:2px;padding:6px 8px;display:flex}.sidebar-nav-item{cursor:pointer;white-space:nowrap;text-align:left;background:0 0;border:none;border-radius:7px;align-items:center;gap:10px;width:100%;padding:8px 10px;transition:background .15s;display:flex;overflow:hidden}.sidebar-nav-item:hover,.sidebar-nav-item--active{background:var(--bg-hover)}.sidebar-nav-item--active .nav-label{color:var(--text);font-weight:600}.sidebar-nav-item--active .nav-icon{opacity:1}.nav-icon{text-align:center;width:18px;color:var(--text-muted);flex-shrink:0;font-size:15px}.nav-label{color:var(--text-muted);font-size:13.5px;font-weight:500}.sidebar-section{padding:4px 8px}.sidebar-section-title{letter-spacing:.07em;text-transform:uppercase;color:var(--text-faint);padding:6px 10px 4px;font-size:11px;font-weight:600}.sidebar-table-row{cursor:default;border-radius:7px;align-items:center;gap:9px;padding:7px 10px;transition:background .15s;display:flex}.sidebar-table-row:hover{background:var(--bg-hover)}.sidebar-table-icon{color:var(--text-faint);flex-shrink:0;font-size:13px}.sidebar-table-meta{flex-direction:column;gap:1px;display:flex;overflow:hidden}.sidebar-table-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.sidebar-table-count{color:var(--text-faint);font-size:11px}.sidebar-spacer{flex:1}.sidebar-bottom{padding:0 8px 12px}.sidebar-theme-row{align-items:center;gap:10px;padding:8px 10px;display:flex}.theme-switch{cursor:pointer;background:0 0;border:none;flex-shrink:0;align-items:center;gap:7px;padding:0;display:inline-flex}.theme-switch-track{background:#d1d5db;border-radius:20px;flex-shrink:0;width:36px;height:20px;transition:background .25s;position:relative}.theme-switch--dark .theme-switch-track{background:#4f46e5}.theme-switch-thumb{background:#fff;border-radius:50%;width:14px;height:14px;transition:transform .25s cubic-bezier(.4,0,.2,1);position:absolute;top:3px;left:3px;box-shadow:0 1px 4px #0003}.theme-switch--dark .theme-switch-thumb{transform:translate(16px)}.theme-switch-icon{justify-content:center;align-items:center;transition:color .2s;display:flex}.theme-switch-sun{color:#f59e0b}.theme-switch-moon{color:#6366f1}.theme-switch--dark .theme-switch-sun{color:#9ca3af}.theme-switch--dark .theme-switch-moon{color:#818cf8}.main-area{flex-direction:column;flex:1;min-width:0;height:100dvh;display:flex;overflow:hidden}.topbar{background:var(--bg-surface);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;gap:16px;height:60px;padding:0 28px;display:flex}.topbar-left{align-items:center;gap:12px;display:flex}.topbar-title{letter-spacing:-.2px;color:var(--text);font-size:16px;font-weight:700}.topbar-badge{background:var(--accent-light);color:var(--accent);border:1px solid var(--accent-light);border-radius:20px;padding:2px 9px;font-size:11px;font-weight:600}.topbar-hint{color:var(--text-faint);font-size:12.5px}.suggestions-bar{border-bottom:1px solid var(--border-soft);background:var(--bg-surface);flex-wrap:wrap;flex-shrink:0;gap:8px;padding:10px 28px;display:flex}.chip{background:var(--bg-chip);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;white-space:nowrap;border-radius:20px;padding:5px 13px;font-size:12.5px;font-weight:500;transition:all .15s}.chip:hover:not(:disabled){background:var(--accent-light);border-color:var(--accent);color:var(--accent)}.chip:disabled{opacity:.4;cursor:not-allowed}.chat-area{background:var(--bg);scrollbar-width:thin;scrollbar-color:var(--border) transparent;flex-direction:column;flex:1;gap:24px;padding:28px;display:flex;overflow-y:auto}.message{width:100%;display:flex}.user-message{justify-content:flex-end}.bot-message{justify-content:flex-start}.message-inner{align-items:flex-start;gap:12px;width:100%;display:flex}.user-inner{justify-content:flex-end;max-width:60%;margin-left:auto}.bot-inner{width:100%}.bot-avatar{background:var(--btn-bg);width:32px;height:32px;color:var(--btn-text);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;margin-top:2px;display:flex}.sidebar-brand-icon{color:var(--text);align-items:center;display:flex}.user-avatar{background:var(--bg-chip);border:1px solid var(--border);width:32px;height:32px;color:var(--text-muted);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;margin-top:2px;font-size:11px;font-weight:700;display:flex}.user-bubble{background:var(--btn-bg);color:var(--btn-text);border-radius:12px 12px 3px;padding:11px 16px;font-size:14px;line-height:1.6}.error-bubble{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:10px;flex:1;padding:13px 16px;font-size:14px}[data-theme=dark] .error-bubble{color:#fca5a5;background:#1c0a0a;border-color:#7f1d1d}.result-card{background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow-card);border-radius:3px 12px 12px;flex:1;overflow:hidden}.result-summary-section{border-bottom:1px solid var(--border-soft);padding:18px 20px 14px}.summary{color:var(--text);margin-bottom:14px;font-size:14.5px;font-weight:500;line-height:1.7}.result-meta-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.sql-toggle{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:6px;align-items:center;gap:5px;padding:4px 10px;font-size:12px;font-weight:500;transition:all .15s;display:inline-flex}.sql-toggle:hover{border-color:var(--accent);color:var(--accent)}.sql-toggle-icon{font-size:9px}.stat-pill{color:var(--text-faint);font-size:12px;font-weight:500}.sql-block{color:#a8b4c0;white-space:pre-wrap;word-break:break-all;background:#0a0a0a;border:none;border-radius:10px;margin-top:12px;padding:14px 16px;font-family:Fira Code,Cascadia Code,ui-monospace,monospace;font-size:12.5px;line-height:1.7;overflow-x:auto}[data-theme=dark] .sql-block{color:#89a;background:#000}.data-section{background:var(--bg-data);flex-direction:column;gap:18px;padding:18px 20px;display:flex}.table-wrapper{border:1px solid var(--border);background:var(--bg-card);border-radius:8px;overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:13px}th{background:var(--bg-card);color:var(--text-muted);text-align:left;text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;border-bottom:1px solid var(--border);padding:10px 14px;font-size:11px;font-weight:600}td{color:var(--text);white-space:nowrap;border-bottom:1px solid var(--border-soft);padding:9px 14px;font-size:13px}tbody tr:nth-child(2n) td{background:var(--bg-zebra)}tbody tr:last-child td{border-bottom:none}tbody tr:hover td{transition:background .12s;background:var(--accent-light)!important}.no-results{color:var(--text-faint);font-size:13px}.chart-wrapper{max-width:600px}.chart-title{letter-spacing:.09em;text-transform:uppercase;color:var(--text-faint);margin-bottom:10px;font-size:10.5px;font-weight:700}.view-scroll-area{background:var(--bg);scrollbar-width:thin;scrollbar-color:var(--border) transparent;flex:1;padding:28px;overflow-y:auto}.view-empty{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:8px;height:100%;display:flex}.view-empty-title{color:var(--text-muted);font-size:15px;font-weight:600}.view-empty-sub{color:var(--text-faint);font-size:13px}.schema-view{flex-direction:column;gap:16px;display:flex}.schema-view-header{align-items:center;gap:12px;margin-bottom:4px;display:flex}.schema-view-title{color:var(--text);font-size:15px;font-weight:700}.schema-view-count{color:var(--text-faint);background:var(--bg-chip);border:1px solid var(--border);border-radius:20px;padding:2px 10px;font-size:12px;font-weight:500}.schema-view-tables{flex-direction:column;gap:12px;display:flex}.schema-view-card{background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow-card);border-radius:10px;overflow:hidden}.schema-view-card-header{border-bottom:1px solid var(--border-soft);background:var(--bg-data);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.schema-view-table-name{color:var(--text);font-size:13.5px;font-weight:700}.schema-view-row-count{color:var(--text-faint);font-size:12px}.schema-col-table{border-collapse:collapse;width:100%;font-size:13px}.schema-col-table th{text-align:left;text-transform:uppercase;letter-spacing:.06em;color:var(--text-faint);border-bottom:1px solid var(--border-soft);padding:8px 16px;font-size:11px;font-weight:700}.schema-col-table td{border-bottom:1px solid var(--border-soft);padding:8px 16px}.schema-col-table tr:last-child td{border-bottom:none}.schema-col-table tbody tr:hover td{background:var(--bg-hover)}.col-name-cell{color:var(--text);font-weight:500}.col-type-cell{color:var(--text-faint);font-size:12px}.history-view{flex-direction:column;gap:16px;display:flex}.history-list{flex-direction:column;gap:8px;display:flex}.history-item{background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow-card);border-radius:10px;justify-content:space-between;align-items:center;gap:16px;padding:12px 16px;display:flex}.history-q{color:var(--text);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:14px;overflow:hidden}.history-rerun-btn{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;white-space:nowrap;background:0 0;border-radius:6px;flex-shrink:0;padding:5px 12px;font-size:12px;font-weight:500;transition:all .15s}.history-rerun-btn:hover{border-color:var(--accent);color:var(--accent)}.loading-inner{align-items:flex-start;gap:12px;display:flex}.loading-bubble{background:var(--bg-card);border:1px solid var(--border);border-radius:3px 10px 10px;align-items:center;gap:6px;padding:14px 18px;display:flex}.dot{background:var(--text-faint);border-radius:50%;width:7px;height:7px;animation:1.3s infinite bounce}.dot:nth-child(2){animation-delay:.18s}.dot:nth-child(3){animation-delay:.36s}@keyframes bounce{0%,80%,to{opacity:.3;transform:translateY(0)}40%{opacity:1;transform:translateY(-6px)}}.input-area{border-top:1px solid var(--border);background:var(--bg-surface);flex-shrink:0;align-items:center;gap:10px;padding:12px 28px 16px;display:flex}.voice-btn{background:var(--bg-chip);border:1px solid var(--border);cursor:pointer;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:18px;transition:all .15s;display:flex}.voice-btn:hover:not(:disabled){background:var(--accent-light);border-color:var(--accent)}.voice-btn.listening{background:#fef2f2;border-color:#fca5a5;animation:1s infinite pulse}[data-theme=dark] .voice-btn.listening{background:#1c0a0a}.voice-btn:disabled{opacity:.4;cursor:not-allowed}@keyframes pulse{0%,to{box-shadow:0 0 #ef44444d}50%{box-shadow:0 0 0 7px #ef444400}}.text-input{background:var(--bg-chip);border:1px solid var(--border);color:var(--text);border-radius:8px;outline:none;flex:1;padding:10px 16px;font-size:14px;transition:border-color .15s,box-shadow .15s}.text-input:focus{border-color:var(--accent);background:var(--bg-surface);box-shadow:0 0 0 3px #6366f11a}.text-input::placeholder{color:var(--text-faint)}.text-input:disabled{opacity:.5}.send-btn{background:var(--btn-bg);color:var(--btn-text);cursor:pointer;letter-spacing:.01em;border:none;border-radius:8px;flex-shrink:0;padding:10px 22px;font-size:14px;font-weight:600;transition:background .15s}.send-btn:hover:not(:disabled){background:var(--btn-hover-bg)}.send-btn:disabled{opacity:.4;cursor:not-allowed}
