:root{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-feature-settings:"cv11","ss01","ss03","tnum";font-variation-settings:normal;line-height:1.5;font-weight:400;color:#213547;background-color:#f5f7fa;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html,body{margin:0;padding:0;min-width:320px;height:100%}#root{width:100%;min-height:100%}.tct{margin:12px 0}.tct-header{display:flex;align-items:center;gap:8px;padding:6px 0;background:transparent;border:none;color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;text-align:left;width:100%}.tct-header:hover{color:var(--text-primary)}.tct-summary{flex:1}.tct-chev{transition:transform .15s ease;flex-shrink:0;transform:rotate(-90deg)}.tct-chev-open{transform:rotate(0)}.tct-chev-lg{color:var(--text-tertiary)}.tct-rows{position:relative;padding:6px 0 4px}.tct-rows:before{content:"";position:absolute;left:15px;top:12px;bottom:12px;width:2px;background:var(--border-primary)}.tct-row{display:flex;align-items:flex-start;gap:12px;position:relative;padding:6px 0}.tct-gutter{width:32px;flex-shrink:0;display:flex;justify-content:center;align-items:flex-start;padding-top:2px}.tct-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);border-radius:50%;font-size:15px;z-index:1;position:relative}.tct-content{flex:1;min-width:0;padding-top:4px}.tct-row-header{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}.tct-label{font-weight:500;color:var(--text-tertiary);text-transform:uppercase;font-size:10px;letter-spacing:.5px}.tct-desc{color:var(--text-secondary);font-size:13px}.tct-result-toggle{display:inline-flex;align-items:center;gap:6px;margin-top:6px;padding:3px 10px 3px 8px;background:var(--bg-tertiary);border:none;border-radius:6px;color:var(--text-tertiary);font-size:11px;font-weight:500;cursor:pointer;transition:background .15s ease,color .15s ease}.tct-result-toggle:hover{background:var(--bg-secondary);color:var(--text-primary)}.tct-result-toggle .tct-chev{transform:rotate(-90deg)}.tct-result-toggle .tct-chev.tct-chev-open{transform:rotate(0)}.tct-details-panel{margin-top:8px}.tct-details-card{border:1px solid var(--border-primary);border-radius:8px;overflow:hidden;background:var(--bg-secondary)}.tct-details-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-bottom:1px solid var(--border-primary);background:var(--bg-tertiary)}.tct-details-title{font-size:11px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.tct-copy-btn{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;background:transparent;border:1px solid var(--border-primary);border-radius:4px;color:var(--text-tertiary);font-size:11px;cursor:pointer;transition:background .15s ease,color .15s ease}.tct-copy-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.tct-code{margin:0;padding:10px 12px;font-size:12px;line-height:1.55;font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,Consolas,monospace;overflow:auto;max-height:320px}.tct-code-lineno{color:#666;margin-right:1em;-webkit-user-select:none;user-select:none;min-width:2em;display:inline-block;text-align:right}.tct-result-list{margin:0;padding:4px 0;list-style:none}.tct-result-item{padding:6px 12px;border-bottom:1px solid var(--border-primary)}.tct-result-item:last-child{border-bottom:none}.tct-result-name{font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,Consolas,monospace;font-size:12px;font-weight:500;color:var(--text-primary)}.tct-result-desc{font-size:11px;color:var(--text-tertiary);margin-top:2px}.tct-result-more{color:var(--text-tertiary);font-size:11px;font-style:italic}.tct-empty{padding:10px 12px;font-size:12px;color:var(--text-tertiary)}.tct-column-list{display:flex;flex-wrap:wrap;gap:6px;padding:10px 12px}.tct-column-chip{font-size:11px;padding:3px 8px;background:var(--bg-tertiary);border-radius:4px;color:var(--text-secondary);font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,Consolas,monospace}.tct-column-more{background:transparent;font-style:italic;color:var(--text-tertiary)}.tct-analysis{padding:10px 12px;font-size:12px;color:var(--text-secondary);display:flex;flex-direction:column;gap:6px}.tct-analysis-row{display:flex;gap:8px}.tct-analysis-label{font-weight:500;color:var(--text-tertiary);min-width:80px}.streaming-indicator{display:flex;align-items:center;gap:4px;padding:12px 0}.streaming-dot{width:8px;height:8px;background:var(--accent-color, #667eea);border-radius:50%;animation:streaming-bounce 1.4s infinite ease-in-out}.streaming-dot:nth-child(1){animation-delay:0s}.streaming-dot:nth-child(2){animation-delay:.2s}.streaming-dot:nth-child(3){animation-delay:.4s}@keyframes streaming-bounce{0%,80%,to{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}.text-renderer{color:var(--text-primary, #333);font-size:14px;line-height:1.6;margin-bottom:12px}.text-renderer .cursor{animation:blink 1s infinite;color:var(--accent-color, #667eea);font-weight:700}.text-renderer h1,.text-renderer h2,.text-renderer h3,.text-renderer h4{margin:16px 0 8px;font-weight:600;color:var(--text-primary, #1a1a1a)}.text-renderer h1{font-size:1.4em}.text-renderer h2{font-size:1.2em}.text-renderer h3{font-size:1.1em}.text-renderer h4{font-size:1em}.text-renderer h1:first-child,.text-renderer h2:first-child,.text-renderer h3:first-child{margin-top:0}.text-renderer p{margin:8px 0}.text-renderer p:first-child{margin-top:0}.text-renderer p:last-child{margin-bottom:0}.text-renderer ul,.text-renderer ol{margin:8px 0;padding-left:24px}.text-renderer li{margin:4px 0}.text-renderer strong{font-weight:600;color:var(--text-primary, #1a1a1a)}.text-renderer em{font-style:italic}.text-renderer code{background:var(--bg-tertiary, #f1f3f5);color:var(--text-primary, #333);padding:2px 6px;border-radius:4px;font-family:Monaco,Menlo,monospace;font-size:.9em}.text-renderer pre{background:var(--bg-code, #1e1e1e);color:var(--text-code, #d4d4d4);padding:12px 16px;border-radius:6px;overflow-x:auto;margin:12px 0}.text-renderer pre code{background:none;padding:0;color:inherit}.text-renderer blockquote{border-left:3px solid var(--accent-color, #667eea);margin:12px 0;padding:8px 16px;background:var(--bg-tertiary, #f8f9fa);color:var(--text-secondary, #555)}.text-renderer>div:has(table),.text-renderer table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}.text-renderer table{min-width:100%;border-collapse:collapse;margin:12px 0;font-size:13px;border:1px solid var(--border-primary, #e1e5eb);border-radius:8px}.text-renderer th,.text-renderer td{border:1px solid var(--border-primary, #e1e5eb);padding:10px 14px;text-align:left;white-space:nowrap}.text-renderer th{background:var(--bg-tertiary, #f8f9fa);font-weight:600;color:var(--text-primary, #333);position:sticky;top:0}.text-renderer td{color:var(--text-secondary, #555);background:var(--bg-secondary, #fff)}.text-renderer tbody tr:hover td{background:var(--bg-hover, #fafbfc)}.text-renderer hr{border:none;border-top:1px solid var(--border-primary, #e1e5eb);margin:16px 0}.text-renderer a{color:var(--accent-color, #667eea);text-decoration:none}.text-renderer a:hover{text-decoration:underline}.sql-code{background:#1e1e1e;color:#d4d4d4;padding:16px 20px;border-radius:8px;overflow-x:auto;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:14px;line-height:1.6;margin:0 0 16px}.sql-code .line-number{display:inline-block;width:2em;margin-right:1em;color:#666;text-align:right;-webkit-user-select:none;user-select:none}.sql-renderer{margin-top:12px}.sql-renderer-toggle{display:flex;align-items:center;gap:6px;padding:8px 12px;background:var(--bg-tertiary, #f1f3f4);border:none;border-radius:6px;font-size:13px;color:var(--text-secondary, #555);cursor:pointer;width:100%;text-align:left}.sql-renderer-toggle:hover{background:var(--bg-hover, #e8eaeb)}.sql-renderer-content{margin-top:8px}.sql-renderer-content .sql-code{margin:0}.data-grid{border-radius:8px;overflow:visible;min-height:200px}.data-grid .ag-root-wrapper{border-radius:8px}.data-grid .ag-header-cell-text{font-weight:600}.data-grid .ag-cell{display:flex;align-items:center}.data-grid .ag-body-viewport{min-height:100px}.results-renderer{margin-top:16px}.results-renderer-header{font-size:13px;color:var(--text-tertiary, #888);margin-bottom:8px;display:flex;align-items:center;gap:12px}.results-renderer .data-grid{height:300px!important}.implicit-insights-section{margin-top:12px;display:flex;flex-wrap:wrap;gap:6px}.implicit-insight{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border:1px solid transparent;border-radius:12px;background:transparent;font:inherit;text-align:left;cursor:pointer;transition:filter .15s ease,background .15s ease,border-color .15s ease}.implicit-insight:disabled{cursor:default}.implicit-insight:not(:disabled):hover{filter:brightness(1.08)}.implicit-insight.active{filter:brightness(1.15)}.implicit-insight-icon{font-size:12px;flex-shrink:0;line-height:1}.implicit-insight-title{font-size:11px;font-weight:500;white-space:nowrap}.implicit-insight-info{background:var(--insight-info-bg);border-color:var(--insight-info-border);color:var(--insight-info-title)}.implicit-insight-warning{background:var(--insight-warning-bg);border-color:var(--insight-warning-border);color:var(--insight-warning-title)}.implicit-insight-anomaly{background:var(--insight-anomaly-bg);border-color:var(--insight-anomaly-border);color:var(--insight-anomaly-title)}.implicit-insight-popover{z-index:1000;max-width:360px;padding:10px 14px;border-radius:8px;border:1px solid transparent;box-shadow:0 8px 24px #00000040;font-size:12px;line-height:1.5;white-space:normal;word-break:break-word}.implicit-insight-popover-info{background:var(--insight-info-bg);border-color:var(--insight-info-border);color:var(--insight-info-text)}.implicit-insight-popover-warning{background:var(--insight-warning-bg);border-color:var(--insight-warning-border);color:var(--insight-warning-text)}.implicit-insight-popover-anomaly{background:var(--insight-anomaly-bg);border-color:var(--insight-anomaly-border);color:var(--insight-anomaly-text)}.vega-chart-container{background:var(--chart-bg);border:1px solid var(--chart-border);border-radius:8px;padding:16px;margin-top:12px}.vega-chart{width:100%;display:flex;justify-content:center}.vega-chart svg{max-width:100%;height:auto}.vega-chart .vega-actions{margin-top:8px;text-align:right}.vega-chart .vega-actions a{color:var(--accent-color, #667eea);font-size:12px;text-decoration:none;margin-left:8px}.vega-chart .vega-actions a:hover{text-decoration:underline}.vega-chart-error{color:var(--error-color, #dc2626);background:var(--error-bg, #fef2f2);border:1px solid var(--border-primary);border-radius:4px;padding:12px;font-size:13px;white-space:pre-wrap}.vega-renderer{margin-top:16px;margin-bottom:16px;padding:20px 24px 12px;border:1px solid var(--border-primary, #e1e5eb);border-radius:10px;background:var(--bg-primary, transparent);overflow:hidden}.vega-renderer .vega-embed{width:100%!important}.vega-renderer .vega-embed svg{display:block;margin:0 auto}.error-renderer{margin-top:12px;padding:10px 14px;background:var(--insight-error-bg);border-radius:8px;color:var(--insight-error-title);font-size:13px}.thinking-aside{width:240px;flex-shrink:0;padding:24px 18px;border-right:1px solid var(--border-primary);background:var(--bg-secondary);display:flex;flex-direction:column;gap:10px;align-items:flex-start;overflow:hidden;transition:color .3s ease,opacity .3s ease}.thinking-aside-icon{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;background:var(--bg-tertiary);border:1px solid var(--border-primary)}.thinking-aside-label{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-tertiary)}.thinking-aside-body{font-size:12px;line-height:1.55;font-style:italic;color:var(--text-secondary);white-space:normal;word-break:break-word;max-height:22em;overflow-y:auto}.thinking-aside-active{color:var(--accent-color, #7c5cff)}.thinking-aside-active .thinking-aside-icon{background:var(--accent-color, #7c5cff);color:var(--bg-primary);border-color:var(--accent-color, #7c5cff);box-shadow:0 0 0 4px color-mix(in srgb,var(--accent-color, #7c5cff) 20%,transparent);animation:thinking-aside-glow 1.6s ease-in-out infinite}@keyframes thinking-aside-glow{0%,to{box-shadow:0 0 0 4px color-mix(in srgb,var(--accent-color, #7c5cff) 20%,transparent)}50%{box-shadow:0 0 0 10px color-mix(in srgb,var(--accent-color, #7c5cff) 12%,transparent)}}.thinking-aside-idle{opacity:.7}.thinking-aside-idle .thinking-aside-icon{color:var(--text-tertiary);opacity:.6}.thinking-aside-idle .thinking-aside-body{color:var(--text-tertiary)}.thinking-aside-pager{display:flex;align-items:center;gap:6px;margin-top:6px;font-size:11px;color:var(--text-tertiary)}.thinking-aside-pager-btn{width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;padding:0;background:transparent;border:1px solid var(--border-primary);border-radius:6px;color:var(--text-secondary);font-size:14px;line-height:1;cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease}.thinking-aside-pager-btn:not(:disabled):hover{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--text-tertiary)}.thinking-aside-pager-btn:disabled{opacity:.35;cursor:default}.thinking-aside-count{min-width:38px;text-align:center;font-variant-numeric:tabular-nums}.thinking-aside-latest{margin-left:4px;padding:3px 8px;background:transparent;border:1px solid var(--border-primary);border-radius:6px;color:var(--text-secondary);font-size:10px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;cursor:pointer;transition:background .15s ease,color .15s ease}.thinking-aside-latest:hover{background:var(--accent-color, #7c5cff);color:#fff;border-color:var(--accent-color, #7c5cff)}.thinking-classification{margin-top:16px;padding-top:14px;border-top:1px solid var(--border-primary);display:flex;flex-direction:column;gap:8px;width:100%}.thinking-classification-header{display:flex;align-items:center;gap:6px}.thinking-classification-emoji{font-size:14px;line-height:1}.thinking-classification-shape{font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-secondary);flex:1}.thinking-classification-confidence{font-size:10px;font-weight:600;padding:2px 6px;border-radius:8px;background:var(--bg-tertiary);color:var(--text-tertiary);font-variant-numeric:tabular-nums}.thinking-classification-reasoning{font-size:11px;line-height:1.5;color:var(--text-tertiary);font-style:italic}.thinking-classification-params{display:flex;flex-wrap:wrap;gap:4px}.thinking-classification-param{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;background:var(--bg-tertiary);border-radius:8px;font-size:10px;line-height:1.4}.thinking-classification-param-key{color:var(--text-tertiary);font-weight:500}.thinking-classification-param-val{color:var(--text-primary)}.thinking-classification-missing{display:flex;flex-wrap:wrap;align-items:center;gap:4px;margin-top:2px}.thinking-classification-missing-label{font-size:9px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--insight-warning-title, #b45309)}.thinking-classification-missing-chip{font-size:10px;padding:2px 7px;border-radius:8px;background:var(--insight-warning-bg, #fef3c7);color:var(--insight-warning-title, #92400e)}@media(max-width:900px){.thinking-aside{display:none}}*{box-sizing:border-box}:root{--bg-primary: #f5f5f7;--bg-secondary: #ffffff;--bg-tertiary: #f9fafb;--bg-input: #ffffff;--bg-code: #1e1e1e;--bg-hover: #f9fafb;--bg-example-icon: linear-gradient(135deg, #f0f3ff 0%, #e8ecff 100%);--text-primary: #1f2937;--text-secondary: #4b5563;--text-tertiary: #6b7280;--text-muted: #9ca3af;--text-code: #d4d4d4;--border-primary: #e5e7eb;--border-focus: rgba(102, 126, 234, .4);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06);--shadow-md: 0 2px 8px rgba(0, 0, 0, .06);--shadow-lg: 0 4px 24px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .04);--shadow-focus: 0 4px 24px rgba(102, 126, 234, .15), 0 1px 2px rgba(0, 0, 0, .04);--accent-gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--accent-color: #667eea;--accent-light: #eef0ff;--error-bg: #fef2f2;--error-color: #dc2626;--warning-bg: #fef3c7;--warning-color: #92400e;--insight-info-bg: #eef0ff;--insight-info-border: #667eea;--insight-info-title: #4a5ac7;--insight-info-text: #5563d4;--insight-warning-bg: #fef7ee;--insight-warning-border: #c9873a;--insight-warning-title: #9a6428;--insight-warning-text: #a8722f;--insight-error-bg: #fef2f2;--insight-error-border: #d45d5d;--insight-error-title: #b33a3a;--insight-error-text: #c04848;--insight-anomaly-bg: #f5eefa;--insight-anomaly-border: #9b59b6;--insight-anomaly-title: #7b3f9e;--insight-anomaly-text: #8a4dab;--confidence-high-bg: #eef6ee;--confidence-high-text: #2e7d32;--confidence-medium-bg: #fef7ee;--confidence-medium-text: #9a6428;--confidence-low-bg: #fef2f2;--confidence-low-text: #b33a3a;--alert-pii-bg: #eef0ff;--alert-pii-text: #4a5ac7;--insights-header-bg: var(--bg-tertiary);--insights-header-text: var(--text-primary);--insights-header-hover: var(--bg-hover);--insights-toggle-text: var(--text-muted);--insights-border: var(--border-primary);--chart-bg: var(--bg-secondary);--chart-border: var(--border-primary)}[data-theme=dark]{--bg-primary: #111111;--bg-secondary: #1c1c1c;--bg-tertiary: #2a2a2a;--bg-input: #1c1c1c;--bg-code: #0a0a0a;--bg-hover: #2a2a2a;--bg-example-icon: linear-gradient(135deg, #2a2a3e 0%, #1e1e2e 100%);--text-primary: #ffffff;--text-secondary: #e5e5e5;--text-tertiary: #b0b0b0;--text-muted: #888888;--text-code: #f0f0f0;--border-primary: #333333;--border-focus: rgba(102, 126, 234, .6);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .4);--shadow-md: 0 2px 8px rgba(0, 0, 0, .4);--shadow-lg: 0 4px 24px rgba(0, 0, 0, .5);--shadow-focus: 0 4px 24px rgba(102, 126, 234, .3);--error-bg: #2d1f1f;--error-color: #f87171;--warning-bg: #2d2a1f;--warning-color: #fbbf24;--accent-light: #1e1e3a;--insight-info-bg: #1a1a30;--insight-info-border: #667eea;--insight-info-title: #8b9af0;--insight-info-text: #99a6f2;--insight-warning-bg: #2a2418;--insight-warning-border: #c9873a;--insight-warning-title: #daa050;--insight-warning-text: #c99a4a;--insight-error-bg: #2d1f1f;--insight-error-border: #d45d5d;--insight-error-title: #f08080;--insight-error-text: #e07070;--insight-anomaly-bg: #261a2e;--insight-anomaly-border: #9b59b6;--insight-anomaly-title: #c084d8;--insight-anomaly-text: #b070cc;--confidence-high-bg: #1a2a1a;--confidence-high-text: #66bb6a;--confidence-medium-bg: #2a2418;--confidence-medium-text: #daa050;--confidence-low-bg: #2d1f1f;--confidence-low-text: #f08080;--alert-pii-bg: #1a1a30;--alert-pii-text: #8b9af0;--chart-bg: var(--bg-secondary);--chart-border: var(--border-primary)}.app{height:100vh;height:100dvh;display:flex;flex-direction:column;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow:hidden;background:var(--bg-primary);max-width:100vw}.welcome-view{flex:1;display:flex;align-items:center;justify-content:center;padding:24px;position:relative}.welcome-content{width:100%;max-width:680px;display:flex;flex-direction:column;align-items:center}.welcome-header{text-align:center;margin-bottom:40px}.welcome-icon{width:256px;height:256px;margin-bottom:8px}.welcome-header h1{margin:0;font-size:2rem;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.welcome-tagline{margin:8px 0 0;color:var(--text-tertiary);font-size:1rem}.connection-badge{display:inline-block;margin-top:12px;padding:4px 12px;background:var(--warning-bg);color:var(--warning-color);border-radius:12px;font-size:13px;font-weight:500}.welcome-input-area{width:100%;margin-bottom:32px}.query-form-welcome{width:100%}.query-form-welcome .input-container{background:var(--bg-input);border-radius:16px;box-shadow:var(--shadow-lg);padding:8px;display:flex;align-items:center;gap:8px;border:1px solid var(--border-primary);transition:box-shadow .2s,border-color .2s}.query-form-welcome .input-container:focus-within{box-shadow:var(--shadow-focus);border-color:var(--border-focus)}.query-form-welcome .query-input{flex:1;padding:12px 16px;font-size:16px;border:none;outline:none;background:transparent;color:var(--text-primary)}.query-form-welcome .query-input::placeholder{color:var(--text-muted)}.query-form-welcome .input-actions{display:flex;align-items:center;gap:8px}.query-form-welcome .domain-select{padding:8px 12px;font-size:13px;border:1px solid var(--border-primary);border-radius:8px;background:var(--bg-tertiary);cursor:pointer;color:var(--text-tertiary)}.query-form-welcome .submit-btn,.query-form-welcome .stop-btn{width:40px;height:40px;border-radius:10px;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .15s,box-shadow .15s}.query-form-welcome .submit-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.query-form-welcome .submit-btn:hover:not(:disabled){transform:scale(1.05);box-shadow:0 4px 12px #667eea66}.query-form-welcome .submit-btn:disabled{opacity:.5;cursor:not-allowed}.query-form-welcome .stop-btn{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.example-cards{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;width:100%}.example-card{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:12px;cursor:pointer;transition:all .2s;text-align:left;min-width:200px}.example-card:hover{border-color:var(--accent-color);box-shadow:0 4px 12px #667eea26;transform:translateY(-2px)}.example-icon{width:40px;height:40px;border-radius:10px;background:var(--bg-example-icon);display:flex;align-items:center;justify-content:center;color:var(--accent-color);flex-shrink:0}.example-text{display:flex;flex-direction:column;gap:2px}.example-title{font-size:14px;font-weight:600;color:var(--text-primary)}.example-desc{font-size:12px;color:var(--text-muted)}.chat-view{flex:1;display:flex;flex-direction:column;overflow:hidden}.chat-view-with-aside{flex-direction:row}.chat-view-with-aside .chat-view-main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);flex-shrink:0}.chat-title{display:flex;align-items:center;gap:8px;font-weight:600;color:var(--text-primary)}.chat-icon{width:24px;height:24px;border-radius:6px}.chat-header-spacer{width:100px}.header-actions{display:flex;align-items:center;gap:8px}.new-chat-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;color:var(--text-secondary);transition:all .15s}.new-chat-btn:hover{background:var(--bg-tertiary);border-color:var(--text-muted)}.theme-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:8px;cursor:pointer;color:var(--text-secondary);transition:all .15s}.theme-toggle:hover{background:var(--bg-tertiary);border-color:var(--text-muted)}.conversation{flex:1 1 0;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:20px;min-height:0;overscroll-behavior:contain}.messages{max-width:900px;margin:0 auto;display:flex;flex-direction:column;gap:20px;min-width:0}.message{max-width:100%;width:100%}.message-user{display:flex;justify-content:flex-end}.message-assistant{display:flex;justify-content:flex-start;width:100%}.message-assistant .assistant-content{width:100%}.user-content{max-width:70%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:12px 18px;border-radius:18px 18px 4px;font-size:15px;line-height:1.5}.assistant-content{background:var(--bg-secondary);padding:22px 26px;border-radius:4px 16px 16px;box-shadow:var(--shadow-sm);max-width:100%;overflow:hidden;min-width:0;font-size:15px;line-height:1.6;letter-spacing:-.005em}.chat-input-area{flex-shrink:0;padding:16px 20px 20px;background:var(--bg-primary)}.chat-input-area .query-form{max-width:900px;margin:0 auto}.chat-input-area .input-container{background:var(--bg-input);border-radius:12px;box-shadow:var(--shadow-md);padding:6px;display:flex;align-items:center;gap:6px;border:1px solid var(--border-primary);transition:box-shadow .2s,border-color .2s}.chat-input-area .input-container:focus-within{box-shadow:var(--shadow-focus);border-color:var(--border-focus)}.chat-input-area .query-input{flex:1;padding:10px 14px;font-size:15px;border:none;outline:none;background:transparent;color:var(--text-primary)}.chat-input-area .query-input::placeholder{color:var(--text-muted)}.chat-input-area .input-actions{display:flex;align-items:center;gap:6px}.chat-input-area .domain-select{padding:6px 10px;font-size:12px;border:1px solid var(--border-primary);border-radius:6px;background:var(--bg-tertiary);cursor:pointer;color:var(--text-tertiary)}.chat-input-area .submit-btn,.chat-input-area .stop-btn{width:36px;height:36px;border-radius:8px;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .15s,box-shadow .15s}.chat-input-area .submit-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.chat-input-area .submit-btn:hover:not(:disabled){transform:scale(1.05)}.chat-input-area .submit-btn:disabled{opacity:.5;cursor:not-allowed}.chat-input-area .stop-btn{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.tool-status{display:flex;align-items:center;gap:10px;padding:14px 18px;background:var(--bg-secondary);border-radius:12px;font-size:14px;color:var(--text-tertiary);box-shadow:var(--shadow-sm)}.spinner{width:16px;height:16px;border:2px solid var(--border-primary);border-top-color:var(--accent-color);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.status-text{font-weight:500}.sql-code{background:var(--bg-code);color:var(--text-code);padding:16px 20px;border-radius:10px;overflow-x:auto;font-family:JetBrains Mono,Monaco,Menlo,Ubuntu Mono,monospace;font-size:13px;line-height:1.6;margin:0}.assistant-text{color:var(--text-secondary);font-size:15px;line-height:1.7;white-space:pre-wrap;margin-bottom:12px}.cursor{animation:blink 1s infinite;color:var(--accent-color);font-weight:700}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.error-content{background:var(--error-bg);color:var(--error-color);padding:12px 18px;border-radius:10px;font-size:14px}.sql-section{margin-top:16px}.sql-toggle{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--bg-tertiary);border:none;border-radius:8px;font-size:13px;font-weight:500;color:var(--text-secondary);cursor:pointer;width:100%;text-align:left;transition:background .15s}.sql-toggle:hover{background:var(--bg-hover)}.sql-section .sql-code{margin-top:10px}.results-section{margin-top:16px}.results-header{font-size:13px;font-weight:500;color:var(--text-tertiary);margin-bottom:10px}.visualization-section{margin-top:16px;border:1px solid var(--border-primary);border-radius:10px;overflow:hidden;background:var(--bg-secondary)}.table-wrapper{overflow-x:auto;border-radius:10px;border:1px solid var(--border-primary)}.results-table{width:100%;border-collapse:collapse;font-size:13px}.results-table th,.results-table td{padding:10px 14px;text-align:left;border-bottom:1px solid var(--border-primary)}.results-table th{background:var(--bg-tertiary);font-weight:600;color:var(--text-primary);position:sticky;top:0}.results-table tbody tr:hover{background:var(--bg-hover)}.results-table td{background:var(--bg-secondary);color:var(--text-secondary)}.truncated{text-align:center;color:var(--text-muted);font-size:12px;margin-top:12px}.tag{display:inline-block;padding:4px 10px;background:var(--bg-tertiary);border-radius:6px;font-size:12px;color:var(--text-secondary)}.tag.skill-tag{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:500}.history-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:8px;cursor:pointer;color:var(--text-secondary);transition:all .15s}.history-toggle:hover{background:var(--bg-tertiary);border-color:var(--text-muted)}.history-overlay{position:fixed;inset:0;background:#0006;z-index:90}.history-sidebar{position:fixed;top:0;left:0;bottom:0;width:300px;background:var(--bg-secondary);border-right:1px solid var(--border-primary);z-index:100;transform:translate(-100%);transition:transform .25s ease-in-out;display:flex;flex-direction:column}.history-sidebar.open{transform:translate(0)}.history-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-primary);flex-shrink:0}.history-header h3{margin:0;font-size:16px;font-weight:600;color:var(--text-primary)}.history-header .close-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:none;border-radius:6px;cursor:pointer;color:var(--text-tertiary);transition:all .15s}.history-header .close-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.history-content{flex:1;overflow-y:auto;padding:12px}.history-empty{padding:24px;text-align:center;color:var(--text-muted);font-size:14px}.history-group{margin-bottom:16px}.history-group-label{padding:8px 12px;font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.history-item{display:block;width:100%;padding:12px 14px;background:transparent;border:none;border-radius:8px;text-align:left;cursor:pointer;transition:background .15s}.history-item:hover{background:var(--bg-tertiary)}.history-item.active{background:var(--bg-tertiary);border-left:3px solid var(--accent-color);padding-left:11px}.history-preview{display:block;font-size:14px;color:var(--text-secondary);line-height:1.4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.welcome-top-bar{display:none}@media(max-width:768px){.app{overflow-x:hidden}.welcome-view{flex-direction:column;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;align-items:stretch;justify-content:flex-start;padding:0;width:100%;max-width:100vw}.welcome-top-bar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);position:sticky;top:0;z-index:10;width:100%;flex-shrink:0;box-sizing:border-box}.welcome-top-bar-left,.welcome-top-bar-right{display:flex;align-items:center;gap:6px}.welcome-desktop-nav{display:none!important;visibility:hidden;position:absolute;left:-9999px}.welcome-content{padding:24px 16px 32px;width:100%;max-width:100%;box-sizing:border-box;overflow-x:hidden}.welcome-header{margin-bottom:24px;position:relative;width:100%}.welcome-icon{width:120px;height:120px;margin-bottom:12px}.welcome-header h1{font-size:1.5rem}.welcome-tagline{font-size:.9rem}.example-cards{flex-direction:column;width:100%;max-width:100%}.example-card{min-width:0;width:100%;box-sizing:border-box}.welcome-input-area{width:100%;max-width:100%;box-sizing:border-box}.query-form-welcome{width:100%;max-width:100%}.query-form-welcome .input-container{flex-direction:column;padding:12px;width:100%;box-sizing:border-box}.query-form-welcome .query-input{width:100%;box-sizing:border-box}.query-form-welcome .input-actions{width:100%;justify-content:space-between}.query-form-welcome .domain-select{flex:1;min-width:0}.chat-header{padding:10px 12px;flex-wrap:wrap;gap:8px}.chat-title{order:-1;width:100%;justify-content:center;padding-bottom:8px;border-bottom:1px solid var(--border-primary);margin-bottom:4px;display:none}.header-actions{gap:6px}.new-chat-btn{padding:6px 10px;font-size:12px}.new-chat-btn svg{width:14px;height:14px}.chat-header-spacer{display:none}.conversation{padding:12px}.assistant-content{padding:14px}.user-content{max-width:85%}.chat-input-area{padding:10px 12px 14px}.chat-input-area .input-container{flex-direction:column;padding:8px}.chat-input-area .input-actions{width:100%;justify-content:space-between}.chat-input-area .domain-select{flex:1}.chat-input-area .query-input{padding:8px 10px}.history-sidebar{width:280px}.theme-toggle,.history-toggle{width:32px;height:32px}.theme-toggle svg,.history-toggle svg{width:16px;height:16px}}@media(max-width:400px){.welcome-icon{width:80px;height:80px}.welcome-header h1{font-size:1.25rem}.example-card{padding:12px 14px}.example-icon{width:32px;height:32px}.example-title{font-size:13px}.example-desc{font-size:11px}.new-chat-btn span{display:none}.new-chat-btn{padding:6px 8px}}.connection-card{display:flex;flex-direction:column;gap:10px;padding:18px 20px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:12px;box-shadow:var(--shadow-sm, 0 1px 2px rgba(0, 0, 0, .04));transition:border-color .15s ease,box-shadow .15s ease}.connection-card:hover{border-color:var(--text-tertiary)}.connection-card.inactive{opacity:.6}.connection-header{display:flex;align-items:center;gap:10px}.connection-type{font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#fff;padding:3px 8px;border-radius:6px}.connection-name{margin:0;font-size:15px;font-weight:600;color:var(--text-primary)}.connection-summary{margin:0;font-size:12px;font-family:JetBrains Mono,ui-monospace,SFMono-Regular,Menlo,monospace;color:var(--text-tertiary)}.connection-schema-info{margin:0;font-size:11px;color:var(--text-tertiary);letter-spacing:.01em}.connection-actions{display:flex;gap:8px;margin-top:4px;flex-wrap:wrap}.btn-sm{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:8px;font-size:12px;font-weight:500;font-family:inherit;cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease,opacity .15s ease;border:1px solid var(--border-primary);background:var(--bg-primary);color:var(--text-secondary)}.btn-sm:hover:not(:disabled){background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--text-tertiary)}.btn-sm:disabled{cursor:default;opacity:.55}.btn-sm.btn-primary{background:var(--accent-color, #7c5cff);border-color:var(--accent-color, #7c5cff);color:#fff}.btn-sm.btn-primary:hover:not(:disabled){filter:brightness(1.06);background:var(--accent-color, #7c5cff);color:#fff}.btn-sm.btn-danger{color:#c2410c}.btn-sm.btn-danger:hover:not(:disabled){background:#fef2f2;color:#b91c1c;border-color:#fecaca}.connection-status{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:500;letter-spacing:.01em;width:max-content;max-width:100%}.connection-status-ok{background:#ecfdf5;color:#047857}.connection-status-err{background:#fef2f2;color:#b91c1c}.connection-status-info{background:var(--bg-tertiary);color:var(--text-secondary)}.connection-status-icon{display:inline-flex;align-items:center;justify-content:center}.connection-progress{display:flex;flex-direction:column;gap:6px}.connection-progress-header{display:flex;align-items:center;justify-content:space-between;font-size:11px}.connection-progress-label{font-weight:500;color:var(--text-secondary);display:inline-flex;align-items:center;gap:6px}.connection-progress-pct{font-variant-numeric:tabular-nums;color:var(--text-tertiary)}.connection-progress-track{position:relative;height:6px;border-radius:999px;background:var(--bg-tertiary);overflow:hidden}.connection-progress-fill{position:absolute;inset:0;width:var(--progress, 0%);background:linear-gradient(90deg,var(--accent-color, #7c5cff),color-mix(in srgb,var(--accent-color, #7c5cff) 60%,#4338ca));border-radius:999px;transition:width .4s cubic-bezier(.4,0,.2,1)}.connection-progress-indeterminate{position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,color-mix(in srgb,var(--accent-color, #7c5cff) 60%,transparent) 50%,transparent 100%);animation:progress-sweep 1.6s ease-in-out infinite}@keyframes progress-sweep{0%{transform:translate(-100%)}to{transform:translate(100%)}}.connection-spinner-dot{width:6px;height:6px;border-radius:50%;background:var(--accent-color, #7c5cff);animation:spinner-pulse 1s ease-in-out infinite}@keyframes spinner-pulse{0%,to{opacity:.35;transform:scale(.85)}50%{opacity:1;transform:scale(1.15)}}.new-connection-page{min-height:100vh;background:var(--bg-primary);padding:48px 32px 80px;color:var(--text-primary)}.new-connection-container{max-width:880px;margin:0 auto}.new-connection-back{display:inline-flex;align-items:center;gap:6px;background:transparent;border:none;color:var(--text-tertiary);font:inherit;font-size:13px;cursor:pointer;padding:0;margin-bottom:28px;transition:color .15s ease}.new-connection-back:hover{color:var(--text-primary)}.new-connection-hero{margin-bottom:36px}.new-connection-eyebrow{font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--text-tertiary);margin:0 0 8px}.new-connection-title{margin:0 0 8px;font-size:30px;font-weight:600;letter-spacing:-.02em;color:var(--text-primary)}.new-connection-subtitle{margin:0;font-size:15px;color:var(--text-secondary);line-height:1.5;max-width:600px}.new-connection-error{display:flex;align-items:center;gap:8px;padding:10px 14px;margin-bottom:24px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#b91c1c;font-size:13px}.db-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}.db-card{display:flex;flex-direction:column;align-items:flex-start;gap:12px;padding:18px 18px 20px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:14px;text-align:left;cursor:pointer;font:inherit;color:inherit;transition:border-color .15s ease,transform .15s ease,box-shadow .15s ease,background .15s ease}.db-card:hover{border-color:var(--text-tertiary);transform:translateY(-2px);box-shadow:0 8px 24px #0000000f;background:var(--bg-primary)}.db-card-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff}.db-card-icon-duckdb{background:linear-gradient(135deg,#ffc107,#f59e0b);color:#4a2c00}.db-card-icon-postgresql{background:linear-gradient(135deg,#4a72a3,#336791)}.db-card-icon-mysql{background:linear-gradient(135deg,#00a3c4,#00758f)}.db-card-icon-snowflake{background:linear-gradient(135deg,#5fd2f3,#29b5e8)}.db-card-icon-bigquery{background:linear-gradient(135deg,#5d9cf5,#4285f4)}.db-card-label{font-size:15px;font-weight:600;color:var(--text-primary)}.db-card-desc{font-size:12.5px;color:var(--text-tertiary);line-height:1.45}.connection-form-card{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:14px;padding:28px 32px 32px}.connection-form-card-header{display:flex;align-items:center;gap:14px;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid var(--border-primary)}.connection-form-card-header .db-card-icon{width:40px;height:40px;border-radius:10px}.connection-form-card-title{margin:0;font-size:17px;font-weight:600;color:var(--text-primary)}.connection-form-card-subtitle{margin:2px 0 0;font-size:12px;color:var(--text-tertiary)}.connection-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:12px;font-weight:500;color:var(--text-secondary);letter-spacing:.02em}.form-group input,.form-group select{padding:9px 12px;font:inherit;font-size:14px;color:var(--text-primary);background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;transition:border-color .15s ease,box-shadow .15s ease;font-family:JetBrains Mono,ui-monospace,SFMono-Regular,Menlo,monospace}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--accent-color, #7c5cff);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent-color, #7c5cff) 18%,transparent)}.form-group input[type=checkbox]{width:16px;height:16px;align-self:flex-start}.form-group .form-hint{font-size:11px;color:var(--text-tertiary);line-height:1.4}.connection-form-actions,.connection-form .form-actions{display:flex;gap:10px;margin-top:8px}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 18px;border-radius:10px;background:var(--accent-color, #7c5cff);border:1px solid var(--accent-color, #7c5cff);color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:filter .15s ease,opacity .15s ease}.btn-primary:hover:not(:disabled){filter:brightness(1.06)}.btn-primary:disabled{opacity:.6;cursor:default}.btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 18px;border-radius:10px;background:var(--bg-primary);border:1px solid var(--border-primary);color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease}.btn-secondary:hover:not(:disabled){background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--text-tertiary)}
