.toast-container[data-v-66112427]{position:fixed;bottom:1.5rem;right:1.5rem;z-index:9999;display:flex;flex-direction:column-reverse;gap:.5rem;pointer-events:none}.toast-item[data-v-66112427]{display:flex;align-items:center;gap:.5rem;padding:.6rem 1rem;border-radius:var(--radius-sm, 6px);font-size:.85rem;font-weight:500;color:#fff;box-shadow:0 4px 12px #0003;pointer-events:auto;min-width:200px;max-width:360px}.toast-icon[data-v-66112427]{font-size:1rem;flex-shrink:0}.toast-success[data-v-66112427]{background:var(--success, #22c55e)}.toast-error[data-v-66112427]{background:var(--danger, #ef4444)}.toast-info[data-v-66112427]{background:var(--primary, #4a72a8)}.toast-enter-active[data-v-66112427]{transition:all .25s ease-out}.toast-leave-active[data-v-66112427]{transition:all .2s ease-in}.toast-enter-from[data-v-66112427],.toast-leave-to[data-v-66112427]{opacity:0;transform:translate(30px)}.error-boundary[data-v-fc6b7035]{padding:2rem;text-align:center}.error-boundary-content[data-v-fc6b7035]{max-width:500px;margin:0 auto;padding:2rem;border:1px solid var(--danger, #dc3545);border-radius:8px;background:var(--bg, #fff)}.error-boundary-content h3[data-v-fc6b7035]{margin:0 0 .5rem;color:var(--danger, #dc3545)}.error-message[data-v-fc6b7035]{font-family:var(--font-mono, monospace);font-size:.85rem;color:var(--text-muted, #666);margin:.5rem 0 1rem;word-break:break-word}.sql-editor-wrapper[data-v-c61e8256]{position:relative;height:100%}.sql-editor-container[data-v-c61e8256]{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;height:100%}.sql-editor-container[data-v-c61e8256] .cm-editor{border-radius:var(--radius);height:100%}.sql-editor-container[data-v-c61e8256] .cm-focused{outline:none}.sql-editor-container[data-v-c61e8256] .cm-tooltip-autocomplete{font-family:var(--font-mono);font-size:.8rem}.plan-view[data-v-35418726]{display:flex;flex-direction:column;gap:.65rem;min-height:0}.plan-summary[data-v-35418726]{display:flex;align-items:center;gap:.45rem;flex-wrap:wrap}.plan-mode-badge[data-v-35418726],.plan-metric[data-v-35418726]{display:inline-flex;align-items:center;gap:.3rem;padding:.25rem .55rem;border-radius:999px;font-size:.74rem;border:1px solid var(--border);background:var(--bg-secondary)}.plan-mode-badge.mode-analyze[data-v-35418726]{border-color:color-mix(in srgb,var(--primary) 30%,var(--border));background:color-mix(in srgb,var(--primary) 10%,var(--bg-secondary));color:var(--primary)}.plan-scroll[data-v-35418726]{flex:1;min-height:0;overflow:auto;border:1px solid var(--border);border-radius:var(--radius);background:color-mix(in srgb,var(--bg-secondary) 88%,white);padding:.6rem .75rem}.plan-line[data-v-35418726]{font-family:var(--font-mono);font-size:.76rem;line-height:1.45;white-space:pre-wrap}.line-heading[data-v-35418726]{font-weight:700;color:var(--text)}.line-metric[data-v-35418726]{color:var(--primary)}.line-operator[data-v-35418726]{color:color-mix(in srgb,var(--primary) 72%,var(--text))}.line-detail[data-v-35418726]{color:var(--text-muted)}.line-spacer[data-v-35418726]{min-height:.55rem}.console-panel[data-v-ad4e647d]{display:grid;gap:.75rem;min-height:0;height:100%;position:relative}.console-panel.mode-page[data-v-ad4e647d]{grid-template-rows:minmax(380px,1.1fr) minmax(240px,.9fr)}.console-panel.mode-dock[data-v-ad4e647d]{grid-template-rows:minmax(220px,1fr) minmax(180px,.9fr)}.editor-panel[data-v-ad4e647d],.result-panel[data-v-ad4e647d]{min-height:0}.editor-card[data-v-ad4e647d],.result-card[data-v-ad4e647d],.history-card[data-v-ad4e647d]{height:100%;display:flex;flex-direction:column}.header-left[data-v-ad4e647d],.header-right[data-v-ad4e647d]{display:flex;align-items:center;gap:.5rem;min-width:0}.result-pane-tabs[data-v-ad4e647d]{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem;border-radius:999px;background:color-mix(in srgb,var(--primary) 6%,var(--bg-secondary))}.result-pane-tab[data-v-ad4e647d]{border:0;background:transparent;color:var(--text-muted);font-size:.76rem;font-weight:600;padding:.22rem .7rem;border-radius:999px;cursor:pointer}.result-pane-tab.active[data-v-ad4e647d]{background:var(--bg);color:var(--primary);box-shadow:var(--shadow)}.header-left>span[data-v-ad4e647d]:first-child{flex-shrink:0}.editor-body[data-v-ad4e647d],.result-body[data-v-ad4e647d]{flex:1;min-height:0;overflow:hidden}.result-body[data-v-ad4e647d]{display:flex;flex-direction:column}.status-bar[data-v-ad4e647d]{padding:.35rem .75rem;font-size:.75rem;border-top:1px solid var(--border);background:var(--bg-secondary, #f8fafc)}.status-disconnected[data-v-ad4e647d]{color:var(--text-muted)}.status-running[data-v-ad4e647d]{color:var(--primary)}.status-ok[data-v-ad4e647d]{color:var(--success)}.status-error[data-v-ad4e647d]{color:var(--danger)}.status-ready[data-v-ad4e647d]{color:var(--text-muted)}.missing-tables-warning[data-v-ad4e647d]{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.85rem 1rem;border:1px solid color-mix(in srgb,var(--secondary) 30%,var(--border));border-radius:var(--radius);background:color-mix(in srgb,var(--secondary) 10%,var(--bg))}.warning-content[data-v-ad4e647d],.warning-actions[data-v-ad4e647d]{display:flex;align-items:center;gap:.75rem}.warning-icon[data-v-ad4e647d]{width:1.35rem;height:1.35rem;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-weight:700;color:color-mix(in srgb,var(--secondary) 85%,black);background:color-mix(in srgb,var(--secondary) 18%,var(--bg))}.history-panel[data-v-ad4e647d]{position:absolute;top:0;right:0;width:min(420px,100%);height:100%;z-index:10;box-shadow:-8px 0 24px #0f172a1f}.history-list[data-v-ad4e647d]{flex:1;overflow-y:auto;padding:.5rem}.history-item[data-v-ad4e647d]{width:100%;text-align:left;border:0;background:transparent;padding:.65rem .75rem;border-bottom:1px solid var(--border);cursor:pointer;border-radius:4px}.history-item[data-v-ad4e647d]:hover{background:color-mix(in srgb,var(--primary) 6%,var(--bg))}.history-error[data-v-ad4e647d]{background:color-mix(in srgb,var(--danger) 5%,var(--bg))}.history-sql[data-v-ad4e647d]{display:block;font-family:var(--font-mono);font-size:.78rem;white-space:pre-wrap}.history-meta[data-v-ad4e647d]{margin-top:.35rem;font-size:.75rem;color:var(--text-muted)}.result-scroll[data-v-ad4e647d]{flex:1;overflow:auto}.result-table[data-v-ad4e647d]{width:100%;border-collapse:collapse;font-family:var(--font-mono);font-size:.8rem}.result-table th[data-v-ad4e647d],.result-table td[data-v-ad4e647d]{padding:.35rem .75rem;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap;max-width:400px;overflow:hidden;text-overflow:ellipsis}.result-table th[data-v-ad4e647d]{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;position:sticky;top:0;background:var(--bg);z-index:1;border-bottom:2px solid var(--border);box-shadow:0 1px 0 var(--border)}.result-table tbody tr[data-v-ad4e647d]:nth-child(2n){background:var(--bg-secondary)}.result-table tbody tr[data-v-ad4e647d]:hover{background:#4a72a80f}.row-num[data-v-ad4e647d]{color:var(--text-muted);font-size:.7rem;width:40px;text-align:right;padding-right:.5rem}.null-val[data-v-ad4e647d]{color:var(--text-muted);font-style:italic}.error-box[data-v-ad4e647d]{padding:1rem;margin:1rem;background:#e157590f;border-radius:var(--radius);border:1px solid rgba(225,87,89,.15)}.error-label[data-v-ad4e647d]{font-size:.75rem;font-weight:600;color:var(--danger);text-transform:uppercase;margin-bottom:.5rem}.error-text[data-v-ad4e647d]{color:var(--danger);font-family:var(--font-mono);font-size:.85rem;white-space:pre-wrap;margin:0}.success-msg[data-v-ad4e647d]{padding:2rem;color:var(--success);font-size:.9rem;text-align:center}.placeholder[data-v-ad4e647d]{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-muted);font-size:.9rem}.placeholder-content[data-v-ad4e647d]{text-align:center;max-width:28rem;display:flex;flex-direction:column;align-items:center;gap:.25rem}.placeholder-icon[data-v-ad4e647d]{font-size:1.6rem;color:color-mix(in srgb,var(--primary) 55%,var(--text-muted));margin-bottom:.15rem}.placeholder-lede[data-v-ad4e647d]{margin:0;font-size:.95rem;font-weight:600;color:var(--text)}.truncation-warning[data-v-ad4e647d]{padding:.75rem 1rem;font-size:.78rem;color:var(--text-muted)}kbd[data-v-ad4e647d]{display:inline-block;padding:.15rem .4rem;font-size:.75rem;font-family:var(--font-mono);background:var(--bg-secondary, #f0f0f0);border:1px solid var(--border);border-radius:3px;box-shadow:0 1px 0 var(--border)}.mt-half[data-v-ad4e647d]{margin-top:.5rem}@media (max-width: 900px){.console-panel.mode-page[data-v-ad4e647d],.console-panel.mode-dock[data-v-ad4e647d]{grid-template-rows:minmax(300px,1fr) minmax(220px,.9fr)}.missing-tables-warning[data-v-ad4e647d]{flex-direction:column;align-items:stretch}.warning-actions[data-v-ad4e647d]{justify-content:flex-end}}.sql-console-workspace[data-v-089ad7b2]{display:flex;flex-direction:column;gap:.75rem;min-height:0;height:100%}.workspace-toolbar[data-v-089ad7b2],.workspace-collapsed[data-v-089ad7b2]{padding:.6rem .75rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.workspace-collapsed-title[data-v-089ad7b2]{display:flex;align-items:center;gap:.5rem;min-width:0}.workspace-tabs[data-v-089ad7b2]{display:flex;align-items:center;gap:.5rem;min-width:0;overflow-x:auto;padding-bottom:.1rem}.workspace-actions[data-v-089ad7b2]{display:flex;align-items:center;gap:.4rem;flex-shrink:0}.session-menu[data-v-089ad7b2]{position:relative}.session-menu summary[data-v-089ad7b2]{list-style:none}.session-menu summary[data-v-089ad7b2]::-webkit-details-marker{display:none}.session-popover[data-v-089ad7b2]{position:absolute;top:calc(100% + .4rem);right:0;width:min(28rem,80vw);padding:.75rem;z-index:20;display:flex;flex-direction:column;gap:.65rem}.session-save-row[data-v-089ad7b2]{display:flex;align-items:center;gap:.5rem}.session-input[data-v-089ad7b2]{min-width:0;flex:1;border:1px solid var(--border);border-radius:var(--radius-sm);padding:.4rem .55rem;font-size:.82rem;background:var(--bg);color:var(--text)}.session-rename-input[data-v-089ad7b2]{font-size:.85rem;padding:.18rem .4rem;font-weight:700}.session-name[data-v-089ad7b2]{cursor:text;border-radius:var(--radius-sm);padding:0 .15rem}.session-name[data-v-089ad7b2]:hover{background:color-mix(in srgb,var(--primary) 8%,transparent)}.session-list[data-v-089ad7b2]{display:flex;flex-direction:column;gap:.35rem;max-height:14rem;overflow:auto}.session-item[data-v-089ad7b2]{display:flex;align-items:center;justify-content:space-between;gap:.75rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);padding:.45rem .55rem;cursor:pointer;text-align:left}.session-item[data-v-089ad7b2]:hover{border-color:color-mix(in srgb,var(--primary) 28%,var(--border));background:color-mix(in srgb,var(--primary) 5%,var(--bg))}.session-item-main[data-v-089ad7b2],.session-item-actions[data-v-089ad7b2]{display:flex;align-items:center;gap:.5rem}.workspace-tab[data-v-089ad7b2]{display:inline-flex;align-items:center;gap:.45rem;min-width:0;max-width:280px;padding:.4rem .5rem .4rem .7rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);cursor:pointer;transition:all .15s ease}.workspace-tab[data-v-089ad7b2]:hover{border-color:color-mix(in srgb,var(--primary) 28%,var(--border));background:color-mix(in srgb,var(--primary) 5%,var(--bg))}.workspace-tab.active[data-v-089ad7b2]{border-color:color-mix(in srgb,var(--primary) 48%,var(--border));background:color-mix(in srgb,var(--primary) 8%,var(--bg));box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--primary) 24%,transparent)}.tab-label[data-v-089ad7b2]{display:inline-flex;align-items:center;gap:.4rem;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.82rem}.tab-sequence[data-v-089ad7b2]{color:var(--text-muted);font-size:.72rem;font-weight:600}.tab-rename[data-v-089ad7b2]{width:12rem;min-width:0;border:1px solid var(--primary);border-radius:4px;padding:.2rem .35rem;font-size:.82rem}.tab-dirty[data-v-089ad7b2]{width:.42rem;height:.42rem;border-radius:999px;background:var(--secondary);flex-shrink:0}.tab-close[data-v-089ad7b2]{width:1.2rem;height:1.2rem;border:0;border-radius:999px;background:transparent;color:var(--text-muted);cursor:pointer;flex-shrink:0}.tab-close[data-v-089ad7b2]:hover{color:var(--danger);background:color-mix(in srgb,var(--danger) 10%,transparent)}.workspace-add-tab[data-v-089ad7b2]{white-space:nowrap}.recently-closed-row[data-v-089ad7b2]{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;padding:0 .25rem}.recently-closed-chip[data-v-089ad7b2]{border:1px solid var(--border);border-radius:999px;background:var(--bg);color:var(--text-muted);font-size:.74rem;padding:.2rem .55rem;cursor:pointer}.recently-closed-chip[data-v-089ad7b2]:hover{color:var(--text);border-color:color-mix(in srgb,var(--primary) 26%,var(--border));background:color-mix(in srgb,var(--primary) 5%,var(--bg))}@media (max-width: 900px){.workspace-toolbar[data-v-089ad7b2],.workspace-collapsed[data-v-089ad7b2]{flex-direction:column;align-items:stretch}.workspace-actions[data-v-089ad7b2]{justify-content:flex-end;flex-wrap:wrap}}.app-workspace[data-v-bb01b3df]{flex:1;min-height:0;display:flex;flex-direction:column}.app-workspace.with-right-dock[data-v-bb01b3df]{flex-direction:row;align-items:stretch}.app-workspace.with-right-dock .main-content[data-v-bb01b3df],.app-workspace.with-bottom-dock .main-content[data-v-bb01b3df]{min-width:0;min-height:0}.sql-console-dock[data-v-bb01b3df]{min-height:0;padding:0 1.5rem 1.5rem;background:var(--bg-secondary)}.sql-console-dock.dock-bottom[data-v-bb01b3df]{height:clamp(320px,40vh,560px);border-top:1px solid var(--border)}.sql-console-dock.collapsed.dock-bottom[data-v-bb01b3df]{height:72px}.sql-console-dock.dock-right[data-v-bb01b3df]{width:clamp(380px,36vw,640px);min-width:380px;border-left:1px solid var(--border);padding:1.5rem 1.5rem 1.5rem 0}.sql-console-dock.collapsed.dock-right[data-v-bb01b3df]{width:min(26vw,360px);min-width:280px}.breadcrumb-bar[data-v-bb01b3df]{padding:.25rem 1.5rem;font-size:.75rem;color:var(--text-muted);border-bottom:1px solid var(--border);background:var(--bg)}.breadcrumb-link[data-v-bb01b3df]{color:var(--primary);text-decoration:none}.breadcrumb-link[data-v-bb01b3df]:hover{text-decoration:underline}.breadcrumb-sep[data-v-bb01b3df]{margin:0 .35rem;opacity:.5}.breadcrumb-current[data-v-bb01b3df]{font-weight:500}@media (max-width: 1280px){.app-workspace.with-right-dock[data-v-bb01b3df]{flex-direction:column}.sql-console-dock.dock-right[data-v-bb01b3df]{width:auto;min-width:0;height:clamp(320px,40vh,560px);border-left:0;border-top:1px solid var(--border);padding:0 1.5rem 1.5rem}}:root{--primary: #4a72a8;--primary-light: #6b9fd4;--primary-dark: #365d8c;--secondary: #f59e0b;--danger: #ef4444;--success: #22c55e;--info: #06b6d4;--bg: #ffffff;--bg-secondary: #f8fafc;--bg-dark: #0f172a;--text: #1e293b;--text-muted: #64748b;--border: #e2e8f0;--shadow: 0 1px 3px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .06);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07), 0 2px 4px rgba(0, 0, 0, .05);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .08), 0 4px 6px rgba(0, 0, 0, .04);--shadow-card: 0 1px 2px rgba(15, 23, 42, .04), 0 1px 1px rgba(15, 23, 42, .03);--shadow-card-hover: 0 3px 6px rgba(15, 23, 42, .07), 0 1px 3px rgba(15, 23, 42, .04);--radius: 8px;--radius-sm: 6px;--fs-xs: .7rem;--fs-sm: .8rem;--fs-base: .9rem;--fs-md: 1rem;--fs-lg: 1.15rem;--fs-xl: 1.35rem;--fs-2xl: 1.75rem;--motion-fast: .12s;--motion-base: .18s;--motion-ease: cubic-bezier(.32, .72, .28, 1);--font-mono: "JetBrains Mono", "Fira Code", "Consolas", monospace}*{margin:0;padding:0;box-sizing:border-box}:focus{outline:none}:focus-visible{outline:2px solid color-mix(in srgb,var(--primary) 60%,transparent);outline-offset:2px;border-radius:4px}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:var(--fs-base);color:var(--text);background:var(--bg-secondary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4{font-weight:600;line-height:1.25;color:var(--text)}h1{font-size:var(--fs-2xl)}h2{font-size:var(--fs-xl)}h3{font-size:var(--fs-lg)}h4{font-size:var(--fs-md)}#app{min-height:100vh;display:flex;flex-direction:column}.container{max-width:1400px;margin:0 auto;padding:0 1rem}.main-content{flex:1;padding:1.5rem}.app-header{background:#ffffffd9;backdrop-filter:saturate(180%) blur(12px);-webkit-backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--border);padding:.6rem 1.25rem;display:flex;align-items:center;gap:1.5rem;box-shadow:0 1px #0f172a05;position:sticky;top:0;z-index:50}html.dark .app-header{background:#0f172ad9;border-bottom-color:color-mix(in srgb,var(--border) 70%,transparent)}.app-header .logo-link{display:flex;align-items:center;text-decoration:none;flex-shrink:0}.app-header .header-logo{height:28px;width:auto}.app-header .header-logo-dark,html.dark .app-header .header-logo-light{display:none}html.dark .app-header .header-logo-dark{display:block}.app-header nav{display:flex;gap:.25rem}.app-header nav a{padding:.4rem .85rem;text-decoration:none;color:var(--text-muted);border-radius:var(--radius-sm);font-size:var(--fs-base);transition:color var(--motion-fast) var(--motion-ease),background-color var(--motion-fast) var(--motion-ease)}.app-header nav a:hover{color:var(--text);background:color-mix(in srgb,var(--text) 6%,transparent)}.app-header nav a.router-link-active{color:var(--primary);background:color-mix(in srgb,var(--primary) 10%,transparent);font-weight:600}html.dark .app-header nav a{color:color-mix(in srgb,var(--text) 70%,transparent)}html.dark .app-header nav a:hover{color:var(--text);background:color-mix(in srgb,var(--text) 10%,transparent)}html.dark .app-header nav a.router-link-active{color:color-mix(in srgb,var(--primary) 80%,white);background:color-mix(in srgb,var(--primary) 20%,transparent)}.card{background:var(--bg);border:1px solid color-mix(in srgb,var(--primary) 10%,var(--border));border-radius:var(--radius);box-shadow:var(--shadow-card);transition:box-shadow var(--motion-base) var(--motion-ease),border-color var(--motion-base) var(--motion-ease)}.card:hover{box-shadow:var(--shadow-card-hover)}html.dark .card{background:color-mix(in srgb,var(--primary) 3%,var(--bg, #0f172a));border-color:color-mix(in srgb,var(--primary) 14%,var(--border))}.card-header{padding:.75rem 1rem;border-bottom:1px solid var(--border);font-weight:600;font-size:var(--fs-base);display:flex;align-items:center;justify-content:space-between}.card-body{padding:1rem}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1.15rem;border:1px solid transparent;border-radius:var(--radius-sm);font-size:var(--fs-sm);cursor:pointer;transition:transform var(--motion-fast) var(--motion-ease),background-color var(--motion-fast) var(--motion-ease),border-color var(--motion-fast) var(--motion-ease),box-shadow var(--motion-fast) var(--motion-ease),color var(--motion-fast) var(--motion-ease);font-weight:500;min-height:2rem}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 1px 2px #4e79a74d}.btn-primary:hover{background:var(--primary-light);transform:translateY(-1px);box-shadow:0 3px 6px #4e79a740}.btn-primary:active{transform:translateY(0);box-shadow:0 1px 2px #4e79a733}.btn-secondary{background:var(--bg);color:var(--text);border-color:var(--border)}.btn-secondary:hover{background:var(--bg-secondary);border-color:var(--primary-light);transform:translateY(-1px);box-shadow:var(--shadow)}.btn-secondary:active{transform:translateY(0)}.btn-danger{background:var(--danger);color:#fff;box-shadow:0 1px 2px #e157594d}.btn-danger:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 3px 6px #e1575940}.btn-danger:active{transform:translateY(0)}.btn-go{background:var(--success);color:#fff;box-shadow:0 1px 2px #22c55e4d}.btn-go:hover{filter:brightness(1.05);transform:translateY(-1px);box-shadow:0 3px 6px #22c55e4d}.btn-go:active{transform:translateY(0)}.btn-go:disabled{background:color-mix(in srgb,var(--success) 35%,var(--bg-secondary));color:color-mix(in srgb,white 70%,transparent);box-shadow:none;cursor:not-allowed;transform:none}html.dark .btn-go:disabled{background:color-mix(in srgb,var(--success) 22%,var(--bg));border:1px solid color-mix(in srgb,var(--success) 30%,var(--border));color:color-mix(in srgb,white 55%,transparent)}.btn-sm{padding:.35rem .8rem;font-size:.82rem;min-height:1.8rem}.btn-xs{padding:.22rem .55rem;font-size:.74rem;min-height:1.5rem;gap:.3rem}.btn-lg{padding:.7rem 1.4rem;font-size:1rem;min-height:2.6rem}.btn-ghost{background:transparent;color:var(--text-muted);border-color:transparent}.btn-ghost:hover{color:var(--text);background:var(--bg-secondary)}.panel-layout{display:grid;grid-template-columns:1fr 1fr;gap:1rem;height:calc(100vh - 120px)}.panel-layout.three-col{grid-template-columns:1fr 1fr 1fr}.tabs{display:flex;gap:.25rem;border-bottom:2px solid var(--border);padding-bottom:0}.tab{padding:.45rem .9rem;cursor:pointer;font-size:.875rem;color:var(--text-muted);border-bottom:2px solid transparent;border-radius:var(--radius-sm) var(--radius-sm) 0 0;margin-bottom:-2px;transition:all .15s ease}.tab:hover{color:var(--text);background:#4a72a80d}.tab.active{color:var(--primary);border-bottom-color:var(--primary);background:#4a72a814;font-weight:600}.tab:focus-visible{outline:2px solid var(--primary);outline-offset:-2px;border-radius:var(--radius-sm) var(--radius-sm) 0 0}.tabs.tabs-outer{align-items:center}.tab.tab-outer{font-weight:600;font-size:.92rem}.tab-spacer{flex:1}.tab-subcount{display:inline-flex;align-items:center;justify-content:center;margin-left:.4rem;min-width:1.1rem;height:1.1rem;padding:0 .3rem;border-radius:999px;font-size:.65rem;font-weight:700;background:color-mix(in srgb,var(--text-muted) 25%,transparent);color:var(--text-muted)}.tab.tab-outer.active .tab-subcount{background:color-mix(in srgb,var(--primary) 30%,transparent);color:var(--primary)}.tabs.tabs-inner{border-bottom:1px solid var(--border);background:color-mix(in srgb,var(--bg-secondary) 60%,var(--bg));padding:.15rem .5rem 0;gap:.15rem}.tab.tab-inner{padding:.3rem .7rem;font-size:.78rem;border-radius:var(--radius-sm) var(--radius-sm) 0 0}.tab.tab-inner.active{background:var(--bg);color:var(--text);border-bottom-color:var(--primary)}.sql-display{font-family:var(--font-mono);font-size:.8125rem;background:#f8f9fa;padding:1rem;border-radius:var(--radius);overflow-x:auto;white-space:pre-wrap;line-height:1.5}.badge{display:inline-flex;align-items:center;padding:.2rem .65rem;border-radius:999px;font-size:.8rem;font-weight:600;letter-spacing:.01em}.badge-primary{background:#4a72a81f;color:var(--primary)}.badge-success{background:#22c55e1f;color:#16a34a}.badge-danger{background:#ef44441f;color:var(--danger)}.badge-info{background:#06b6d41f;color:#0891b2}.badge-warning{background:#eab3081f;color:#ca8a04}.badge-secondary{background:#6b72801f;color:#6b7280}.badge-muted{background:#9ca3af26;color:#6b7280}.chip{display:inline-flex;align-items:center;gap:.35rem;padding:.2rem .7rem;border-radius:999px;font-size:var(--fs-xs);font-weight:500;line-height:1.4;color:var(--text-muted);background:color-mix(in srgb,var(--text-muted) 10%,transparent);border:1px solid transparent;white-space:nowrap;transition:background var(--motion-fast) var(--motion-ease),color var(--motion-fast) var(--motion-ease)}.chip.is-active,.chip-primary{background:color-mix(in srgb,var(--primary) 14%,transparent);color:var(--primary);font-weight:600}.chip-success{background:color-mix(in srgb,var(--success) 14%,transparent);color:#16a34a;font-weight:600}.chip-warning{background:color-mix(in srgb,var(--secondary, #f59e0b) 16%,transparent);color:#b45309;font-weight:600}.chip-danger{background:color-mix(in srgb,var(--danger) 14%,transparent);color:var(--danger);font-weight:600}.chip-outline{background:transparent;border-color:var(--border);color:var(--text-muted)}.chip-xs{padding:.1rem .5rem;font-size:.65rem}.chip-sm{padding:.15rem .6rem;font-size:.7rem}.chip-md{padding:.3rem .85rem;font-size:var(--fs-sm)}.chip-kv{gap:.5rem}.chip-kv .chip-label{font-weight:500;color:var(--text-muted);text-transform:lowercase;letter-spacing:.01em}.chip-kv .chip-value{font-weight:600;color:var(--text)}.chip-dot{width:6px;height:6px;border-radius:50%;background:currentColor;flex:0 0 auto}html.dark .chip{background:color-mix(in srgb,var(--text-muted) 18%,transparent)}html.dark .chip.is-active,html.dark .chip-primary{background:color-mix(in srgb,var(--primary) 26%,transparent);color:color-mix(in srgb,var(--primary) 40%,white)}.stats-row{display:flex;gap:.4rem .9rem;flex-wrap:wrap;align-items:baseline;font-size:.8rem;line-height:1.4}.stat{display:inline-flex;align-items:baseline;gap:.3rem}.stat-label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-weight:600;order:1}.stat-value{font-size:.9rem;font-weight:700;color:var(--text);order:2}.loading{display:flex;align-items:center;justify-content:center;padding:2rem;color:var(--text-muted)}.fade-enter-active,.fade-leave-active{transition:opacity .2s ease,transform .2s ease}.fade-enter-from{opacity:0;transform:translateY(6px)}.fade-leave-to{opacity:0;transform:translateY(-4px)}.tab-fade-enter-active{transition:opacity .15s ease}.tab-fade-enter-from{opacity:0}details[open]>.config-group-body{animation:slideDown .15s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:.6}50%{opacity:1}}.loading{animation:pulse 1.5s ease-in-out infinite}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.gap-1{gap:.5rem}.gap-2{gap:1rem}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-muted{color:var(--text-muted)}.font-mono{font-family:var(--font-mono)}.overflow-auto{overflow:auto}.app-header .text-muted{color:#ffffffa6}.app-header .text-xs{color:#ffffffd9}.app-header .db-backend-label{color:var(--text)}.app-header .badge{border:1px solid var(--border)}.app-header .badge-muted{background:var(--bg-secondary);color:var(--text-muted)}html.dark .app-header .db-backend-label{color:var(--text)}html.dark .app-header .badge-muted{background:color-mix(in srgb,var(--bg-secondary) 60%,transparent);color:var(--text-muted)}.db-switch{text-decoration:none;color:inherit;padding:.2rem .5rem;border-radius:var(--radius, 4px);border:1px solid transparent;transition:border-color .15s,background .15s;cursor:pointer}.db-switch:hover{border-color:var(--border);background:color-mix(in srgb,var(--text) 4%,transparent)}html.dark .db-switch:hover{background:color-mix(in srgb,var(--text) 10%,transparent)}.db-backend-label{font-weight:600}.db-indicator{display:inline-flex;align-items:center;gap:.35rem;margin-right:.75rem}.db-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.db-dot-connected{background:var(--success);box-shadow:0 0 4px var(--success)}.db-dot-disconnected{background:var(--text-muted);opacity:.5}.db-switcher{position:relative}.dock-control{position:relative;display:inline-flex;align-items:stretch;border-radius:var(--radius-sm);overflow:hidden;line-height:1}.dock-control-main{padding:.25rem .55rem;font-size:.75rem;border-radius:var(--radius-sm) 0 0 var(--radius-sm);display:inline-flex;align-items:center;gap:.35rem}.dock-control-label{font-size:.75rem}.dock-control-arrow{padding:.25rem .35rem;font-size:.68rem;border-radius:0 var(--radius-sm) var(--radius-sm) 0;border-left:1px solid color-mix(in srgb,var(--border) 70%,transparent)}.dock-menu{position:absolute;top:calc(100% + 4px);right:0;z-index:60;min-width:14rem;padding:.3rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md)}.dock-menu-item{display:block;width:100%;padding:.5rem .7rem;text-align:left;border:1px solid transparent;background:transparent;border-radius:var(--radius-sm);font-size:.82rem;color:var(--text);cursor:pointer}.dock-menu-item:hover{background:var(--bg-secondary)}.dock-menu-item.active{background:color-mix(in srgb,var(--primary) 12%,transparent);color:var(--primary)}.db-switch{background:none;font-family:inherit}.db-caret{font-size:.6rem;opacity:.5;margin-left:.15rem}.db-dropdown{position:absolute;top:100%;right:0;margin-top:.25rem;min-width:220px;background:var(--bg, #fff);border:1px solid var(--border, #ddd);border-radius:var(--radius, 4px);box-shadow:0 4px 12px #00000026;z-index:1000;overflow:hidden}.db-dropdown-header{padding:.5rem .75rem;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted, #888);border-bottom:1px solid var(--border, #eee)}.db-dropdown-item{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem .75rem;border:none;background:none;cursor:pointer;font-family:inherit;font-size:.8rem;color:var(--text, #333);text-align:left;transition:background .1s}.db-dropdown-item:hover{background:var(--bg-secondary, #f5f5f5)}.db-dropdown-item:disabled{opacity:.5;cursor:not-allowed}.db-dropdown-item-active{background:#4e79a714}.db-dropdown-item-label{font-weight:500}.db-dropdown-item-sub{font-size:.7rem;color:var(--text-muted, #888)}.db-dropdown-check{margin-left:auto;color:var(--success, #4caf50);font-weight:700}.db-dropdown-footer{border-top:1px solid var(--border, #eee);padding:.4rem .75rem}.db-dropdown-settings{font-size:.75rem;color:var(--primary, #4e79a7);text-decoration:none}.db-dropdown-settings:hover{text-decoration:underline}.dark{--primary: #93c5fd;--primary-light: #bfdbfe;--primary-dark: #3b6da8;--secondary: #fbbf24;--danger: #f87171;--success: #4ade80;--info: #22d3ee;--bg: #0f172a;--bg-secondary: #1e293b;--text: #e2e8f0;--text-muted: #cbd5e1;--border: #334155;--shadow: 0 1px 3px rgba(0, 0, 0, .5);--shadow-md: 0 4px 6px rgba(0, 0, 0, .4), 0 2px 4px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .4), 0 4px 6px rgba(0, 0, 0, .2)}.dark body{background:var(--bg-secondary);color:var(--text)}.dark .card{background:var(--bg);border-color:var(--border)}.dark .btn-secondary{background:var(--bg-secondary);color:var(--text);border-color:var(--border)}.dark pre,.dark .sql-display,.dark .explain-output,.dark .sql-diff-code{background:#0d1117;color:#c9d1d9}html.sql-dark .example-sql,html.sql-dark .demo-sql,html.sql-dark .demo-sql-result,html.sql-dark .sql-preview,html.sql-dark .expanded-sql,html.sql-dark .optimized-sql,html.sql-dark .logical-plan-pre,html.sql-dark .explain-pre,html.sql-dark .explain-output,html.sql-dark .plan-modal-pre,html.sql-dark .step-sql,html.sql-dark .sql-display,html.sql-dark .sql-diff-code,html.sql-dark .export-preview{background:#0d1117;color:#c9d1d9;border-color:#30363d}.segmented-control,.query-mode-switcher{display:inline-flex;gap:0;padding:.15rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:999px}.segmented-tab,.query-mode-tab{padding:.35rem 1rem;border:none;background:transparent;color:var(--text-muted);border-radius:999px;font-size:.82rem;font-weight:600;cursor:pointer;transition:all .15s ease}.segmented-tab:hover,.query-mode-tab:hover{color:var(--text)}.segmented-tab.active,.query-mode-tab.active{background:var(--bg);color:var(--primary);box-shadow:0 1px 3px #00000014}.segmented-tab:focus-visible,.query-mode-tab:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.dark .steps-table th,.dark .results-table th{background:var(--bg)}.dark input,.dark select{background:var(--bg-secondary);color:var(--text);border-color:var(--border)}.dark .tab.active{border-bottom-color:var(--primary);color:var(--primary);background:#6b9fd41f}.dark .tab:hover{background:#6b9fd414}.dark .step-header:hover{background:var(--bg-secondary)}.dark .warning-item{background:#ffc10726;border-color:#ffc10766;color:#ffc107}.dark .suggestion-item{background:#91d5d11f;border-color:#91d5d14d;color:var(--info)}.dark .step-sql{background:#0d1117;color:#c9d1d9}.dark .error-banner{background:#ff6b6b1f;border-color:var(--danger);color:var(--danger)}.dark .steps-table td,.dark .results-table td,.dark .results-table-wrapper{border-color:var(--border)}.dark .copy-btn{background:#ffffff26;border-color:#ffffff40}.dark .empty-state{color:var(--text-muted)}.dark .config-section{border-color:var(--border)}input:focus-visible,select:focus-visible,.config-input:focus-visible,.timeout-input:focus-visible,.form-input:focus-visible{outline:2px solid var(--primary, #4e79a7);outline-offset:1px}button:focus-visible{outline:2px solid var(--primary, #4e79a7);outline-offset:2px}.wasm-loading-bar{position:fixed;top:max(.85rem,env(safe-area-inset-top));right:max(.85rem,env(safe-area-inset-right));z-index:10020;width:min(360px,calc(100vw - 1.7rem));background:color-mix(in srgb,var(--bg, #ffffff) 94%,var(--primary, #4e79a7) 6%);border:1px solid color-mix(in srgb,var(--border, #e2e8f0) 78%,var(--primary, #4e79a7) 22%);border-radius:999px;box-shadow:var(--shadow-md);padding:.55rem .85rem;display:flex;align-items:center;gap:.75rem;font-size:.75rem;color:var(--text);pointer-events:none;backdrop-filter:blur(8px)}.wasm-loading-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.wasm-loading-track{flex:0 0 96px;height:3px;background:color-mix(in srgb,var(--border, #e2e8f0) 70%,transparent);border-radius:2px;overflow:hidden}.wasm-loading-fill{height:100%;background:var(--primary, #4e79a7);border-radius:2px;transition:width .2s ease}.wasm-loading-indeterminate{width:30%!important;animation:wasm-slide 1.2s ease-in-out infinite}@keyframes wasm-slide{0%{transform:translate(-100%)}to{transform:translate(400%)}}@media (max-width: 768px){.app-header{flex-wrap:wrap;padding:.5rem .75rem;gap:.5rem}.app-header .header-logo{height:22px}.app-header nav{order:3;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:.15rem}.app-header nav::-webkit-scrollbar{display:none}.app-header nav a{padding:.35rem .6rem;font-size:.75rem;white-space:nowrap;flex-shrink:0}.db-switcher .db-backend-label,.db-switcher .text-muted{display:none}.db-switch{padding:.15rem .35rem}.card-header{padding:.5rem .75rem;font-size:.8rem}.card-body{padding:.75rem}.wasm-loading-bar{top:auto;bottom:max(.85rem,env(safe-area-inset-bottom));right:.85rem;left:.85rem;width:auto;font-size:.68rem;padding:.5rem .75rem}}@media (max-width: 480px){.app-header nav a{padding:.3rem .5rem;font-size:.7rem}.badge{font-size:.6rem;padding:.15rem .35rem}.main-content{padding:.75rem}}input[type=checkbox],input[type=radio]{accent-color:var(--primary);cursor:pointer}html.dark input[type=checkbox]{outline:1px solid color-mix(in srgb,var(--text) 40%,transparent);outline-offset:-1px;border-radius:2px}
