*,*:before,*:after{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased;background:#0f1117}.top-bar{grid-column:1 / -1;display:flex;align-items:center;gap:1rem;padding:0 1rem;height:48px;background:var(--bg-surface);border-bottom:1px solid var(--border);z-index:10}.top-bar-left{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.top-bar-logo{display:flex;align-items:center;color:var(--accent-highlight)}.top-bar-title{font-size:.95rem;font-weight:700;color:var(--accent-highlight);letter-spacing:-.02em;white-space:nowrap}.top-bar-center{flex:1;display:flex;align-items:center;gap:.6rem;justify-content:center;min-width:0}.top-bar-progress-wrap{display:flex;flex-direction:column;gap:4px;min-width:200px}.top-bar-progress-bar{height:3px;background:var(--border);border-radius:2px;overflow:hidden}.top-bar-progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .15s ease}.top-bar-status{font-size:.82rem;color:var(--text-muted)}.top-bar-filename{font-weight:600;color:var(--text-primary);font-size:.82rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.top-bar-meta{font-size:.78rem;color:var(--text-muted);white-space:nowrap}.top-bar-right{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.top-bar-table-select{background:var(--border);color:var(--accent-highlight);border:1px solid var(--border-strong);border-radius:4px;padding:.25rem .5rem;font-size:.8rem;font-family:Courier New,monospace;cursor:pointer}.top-bar-table-select option{background:var(--bg-surface);color:var(--text-primary)}.top-bar-table-select:focus{outline:1px solid var(--accent)}.theme-toggle{display:flex;align-items:center;justify-content:center;width:30px;height:30px;background:none;border:1px solid var(--border-strong);border-radius:6px;cursor:pointer;color:var(--text-muted);transition:all .15s;flex-shrink:0}.theme-toggle:hover{background:var(--accent-subtle);color:var(--accent-highlight);border-color:var(--accent)}.top-bar-compare-btn{display:flex;align-items:center;gap:5px}.top-bar-compare-btn.active{background:var(--accent-soft);color:var(--accent-soft-text);border-color:var(--accent-border)}.top-bar-union-btn{display:flex;align-items:center;gap:5px}.top-bar-union-btn.active{background:var(--accent-soft);color:var(--accent-soft-text);border-color:var(--accent-border)}.upgrade-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.upgrade-modal{background:var(--bg-elevated);border:1px solid var(--border);border-radius:12px;padding:2rem 2.25rem;max-width:400px;width:90%;text-align:center;display:flex;flex-direction:column;align-items:center;gap:.75rem;box-shadow:0 20px 60px #0006}.upgrade-modal-icon{color:var(--accent);margin-bottom:.25rem}.upgrade-modal-feature{font-size:1.1rem;font-weight:700;color:var(--text-primary);margin:0}.upgrade-modal-message{font-size:.88rem;color:var(--text-secondary);line-height:1.55;margin:0}.upgrade-modal-actions{display:flex;flex-direction:column;align-items:center;gap:.5rem;margin-top:.5rem;width:100%}.upgrade-modal-cta{width:100%;padding:.7rem 1.5rem;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .15s,transform .1s;font-family:inherit}.upgrade-modal-cta:hover:not(:disabled){background:var(--accent-hover)}.upgrade-modal-cta:active:not(:disabled){transform:scale(.98)}.upgrade-modal-cta:disabled{opacity:.6;cursor:not-allowed}.upgrade-modal-yearly{background:none;border:none;color:var(--text-muted);font-size:.82rem;cursor:pointer;padding:.25rem;font-family:inherit;transition:color .15s}.upgrade-modal-yearly:hover:not(:disabled){color:var(--accent)}.upgrade-modal-yearly:disabled{opacity:.6;cursor:not-allowed}.upgrade-modal-dismiss{background:none;border:none;color:var(--text-ghost);font-size:.8rem;cursor:pointer;margin-top:.25rem;padding:.25rem .5rem;font-family:inherit;transition:color .15s}.upgrade-modal-dismiss:hover{color:var(--text-muted)}.upgrade-banner{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;background:var(--bg-surface);border-left:3px solid var(--accent);border-radius:0 6px 6px 0;font-size:.82rem;color:var(--text-secondary)}.upgrade-banner-msg{flex:1}.upgrade-banner-link{background:none;border:none;color:var(--accent);font-weight:600;cursor:pointer;font-size:.82rem;padding:0;font-family:inherit;white-space:nowrap}.upgrade-banner-link:hover{text-decoration:underline}.upgrade-banner-close{background:none;border:none;color:var(--text-ghost);cursor:pointer;font-size:1rem;padding:0 .25rem;line-height:1}.upgrade-toast{position:fixed;bottom:1.5rem;right:1.5rem;z-index:1100;display:flex;align-items:flex-start;gap:.5rem;padding:.75rem 1rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px;box-shadow:0 8px 32px #0000004d;max-width:380px;animation:toast-slide-in .25s ease-out}@keyframes toast-slide-in{0%{transform:translateY(1rem);opacity:0}to{transform:translateY(0);opacity:1}}.upgrade-toast-body{display:flex;flex-direction:column;gap:.35rem}.upgrade-toast-msg{font-size:.82rem;color:var(--text-secondary);line-height:1.4}.upgrade-toast-link{background:none;border:none;color:var(--accent);font-weight:600;cursor:pointer;font-size:.82rem;padding:0;text-align:left;font-family:inherit}.upgrade-toast-link:hover{text-decoration:underline}.upgrade-toast-close{background:none;border:none;color:var(--text-ghost);cursor:pointer;font-size:1.1rem;padding:0 .15rem;line-height:1;flex-shrink:0}.pro-badge{display:inline-flex;align-items:center;padding:.1rem .4rem;background:var(--accent);color:#fff;font-size:.6rem;font-weight:700;letter-spacing:.05em;border-radius:4px;line-height:1.2;text-transform:uppercase;vertical-align:middle;margin-left:.35rem}.sidebar{grid-row:2;grid-column:1;background:var(--bg-surface);border-right:1px solid var(--border);overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column}.sidebar-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:2rem 1rem}.sidebar-empty-text{color:var(--text-faint);font-size:.85rem;font-weight:600}.sidebar-empty-hint{color:var(--text-ghost);font-size:.75rem;text-align:center;line-height:1.4}.sidebar-add-btn{display:flex;align-items:center;gap:6px;width:calc(100% - 16px);margin:8px 8px 4px;padding:6px 10px;border:1px dashed var(--border-strong);border-radius:6px;background:transparent;color:var(--text-secondary);font-size:.8rem;font-family:inherit;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.sidebar-add-btn:hover:not(:disabled){background:var(--accent-subtle);color:var(--accent-soft-text);border-color:var(--accent-border)}.sidebar-add-btn:disabled{opacity:.5;cursor:default}.sidebar-section-header{display:flex;align-items:center;gap:.4rem;padding:.6rem .75rem;background:var(--bg-elevated);border-bottom:1px solid var(--border);cursor:pointer;-webkit-user-select:none;user-select:none}.sidebar-section-icon{font-size:.6rem;color:var(--text-muted)}.sidebar-section-title{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary)}.sidebar-section-badge{margin-left:auto;background:var(--accent-soft);color:var(--accent-soft-text);padding:.05rem .4rem;border-radius:10px;font-size:.65rem;font-weight:500}.sidebar-files{padding:.25rem 0}.sidebar-files-empty{padding:.5rem .75rem;font-size:.75rem;color:var(--text-ghost)}.sidebar-file-row{display:flex;align-items:center;gap:.35rem;padding:.3rem .75rem;cursor:pointer;transition:background .1s;font-size:.78rem;position:relative}.sidebar-file-row:hover{background:var(--accent-subtle)}.sidebar-file-row.active{background:var(--accent-soft);border-left:2px solid var(--accent);padding-left:calc(.75rem - 2px)}.sidebar-file-icon{flex-shrink:0;color:var(--text-faint)}.sidebar-file-row.active .sidebar-file-icon{color:var(--accent-highlight)}.sidebar-file-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-secondary);font-size:.78rem}.sidebar-file-row.active .sidebar-file-name{color:var(--text-primary);font-weight:500}.sidebar-file-rows{font-size:.65rem;color:var(--text-faint);flex-shrink:0}.sidebar-file-remove{display:none;background:none;border:none;color:var(--text-muted);font-size:1rem;cursor:pointer;padding:0 .15rem;line-height:1;flex-shrink:0}.sidebar-file-row:hover .sidebar-file-remove{display:block}.sidebar-file-remove:hover{color:var(--error-text)}.sidebar-schema{flex:1;padding:.5rem 0}.sidebar-table-row{display:flex;align-items:center;gap:.4rem;padding:.35rem .75rem;font-size:.82rem}.sidebar-table-name{font-family:Courier New,monospace;color:var(--accent-highlight);font-weight:600;font-size:.85rem}.sidebar-row-badge{background:var(--accent-soft);color:var(--accent-soft-text);padding:.05rem .45rem;border-radius:10px;font-size:.7rem;font-weight:500;margin-left:auto}.sidebar-columns{padding:.25rem 0}.sidebar-column-row{display:flex;align-items:center;gap:.4rem;padding:.2rem .75rem .2rem 1.75rem;cursor:pointer;transition:background .1s;font-size:.78rem}.sidebar-column-row:hover{background:var(--accent-subtle)}.sidebar-col-icon{font-size:.6rem;color:var(--text-faint);font-family:Courier New,monospace;width:1.4rem;flex-shrink:0}.sidebar-table-icon{color:var(--accent-highlight)}.sidebar-empty-icon{color:var(--border-strong)}.sidebar-col-name{font-family:Courier New,monospace;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-col-type{margin-left:auto;font-family:Courier New,monospace;font-size:.6rem;opacity:.5;white-space:nowrap;flex-shrink:0}.sidebar-col-icon.type-str{color:var(--text-faint)}.sidebar-col-icon.type-int{color:#22c55e}.sidebar-col-icon.type-float{color:#f59e0b}.sidebar-col-icon.type-bool{color:#a78bfa}.sidebar-col-icon.type-date{color:#38bdf8}.sidebar-col-type.type-str{color:var(--text-faint)}.sidebar-col-type.type-int{color:#22c55e}.sidebar-col-type.type-float{color:#f59e0b}.sidebar-col-type.type-bool{color:#a78bfa}.sidebar-col-type.type-date{color:#38bdf8}.sidebar-column-row:hover .sidebar-col-name{color:var(--accent-highlight)}.sidebar-saved-queries{padding:.25rem 0}.sidebar-saved-row{display:flex;align-items:center;gap:.35rem;padding:.25rem .75rem;cursor:pointer;transition:background .1s;font-size:.78rem;position:relative}.sidebar-saved-row:hover{background:var(--accent-subtle)}.sidebar-saved-icon{flex-shrink:0;color:var(--text-faint)}.sidebar-saved-row:hover .sidebar-saved-icon{color:var(--accent-highlight)}.sidebar-saved-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-secondary);font-size:.76rem}.sidebar-saved-row:hover .sidebar-saved-name{color:var(--text-primary)}.sidebar-saved-remove{display:none;background:none;border:none;color:var(--text-muted);font-size:1rem;cursor:pointer;padding:0 .15rem;line-height:1;flex-shrink:0}.sidebar-saved-row:hover .sidebar-saved-remove{display:block}.sidebar-saved-remove:hover{color:var(--error-text)}.sidebar-pro-footer{margin-top:auto;padding:.6rem .75rem;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:center;gap:.5rem}.sidebar-pro-label{font-size:.7rem;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.05em}.editor-panel{display:flex;flex-direction:column;border-bottom:1px solid var(--border);flex-shrink:0}.editor-header{display:flex;align-items:center;justify-content:space-between;padding:.45rem 1rem;background:var(--bg-elevated);border-bottom:1px solid var(--border)}.editor-title{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary)}.editor-hint{font-size:.7rem;color:var(--text-faint)}.editor-area{display:flex;position:relative;min-height:160px;max-height:300px;background:var(--bg-base)}.line-numbers{width:40px;flex-shrink:0;padding:.75rem 0;background:var(--bg-inset);border-right:1px solid var(--border);overflow:hidden;-webkit-user-select:none;user-select:none;pointer-events:none}.line-number{height:1.6em;line-height:1.6;padding:0 .5rem;text-align:right;font-family:Courier New,Courier,monospace;font-size:.875rem;color:var(--text-ghost)}.sql-textarea{flex:1;display:block;width:100%;min-height:160px;max-height:300px;padding:.75rem 1rem;font-family:Courier New,Courier,monospace;font-size:.875rem;line-height:1.6;color:var(--text-primary);background:transparent;border:none;resize:none;outline:none;overflow:auto;white-space:pre}.sql-textarea:focus{background:var(--textarea-focus)}.sql-textarea:disabled{opacity:.4;cursor:not-allowed}.sql-textarea::placeholder{color:var(--border-strong)}.editor-actions{display:flex;align-items:center;justify-content:space-between;padding:.45rem 1rem;background:var(--bg-surface);border-top:1px solid var(--border)}.editor-actions-left{display:flex;align-items:center;gap:.4rem}.editor-actions-right{display:flex;align-items:center}.example-queries{display:flex;align-items:center;flex-wrap:wrap;gap:.35rem;padding:.35rem 1rem .5rem;background:var(--bg-surface)}.examples-label{font-size:.72rem;color:var(--text-faint)}.example-btn{background:transparent;border:1px solid var(--border-strong);border-radius:3px;padding:.15rem .45rem;font-size:.72rem;color:var(--text-muted);cursor:pointer;transition:all .12s}.example-btn:hover{border-color:var(--accent);color:var(--accent-soft-text);background:var(--accent-subtle)}.results-panel{flex:1;display:flex;flex-direction:column;overflow:hidden}.results-empty{padding:1.5rem 1rem;text-align:center;color:var(--text-faint);font-size:.82rem}.results-meta{padding:.4rem 1rem;font-size:.75rem;color:var(--text-muted);border-bottom:1px solid var(--border);background:var(--bg-elevated);flex-shrink:0}.truncate-hint{color:var(--warning)}.table-scroll{flex:1;overflow:auto}.results-table{width:100%;border-collapse:collapse;font-size:.78rem}.results-table th{position:sticky;top:0;background:var(--bg-elevated);padding:.45rem .75rem;text-align:left;font-weight:600;color:var(--text-secondary);white-space:nowrap;border-bottom:2px solid var(--border-strong);z-index:1}.results-table td{padding:.35rem .75rem;border-bottom:1px solid var(--bg-elevated);color:var(--text-primary);max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.results-table tr:hover td{background:var(--table-row-hover)}.null-val{color:var(--null-text);font-style:italic}.compare-panel{display:flex;flex-direction:column;height:100%;overflow:hidden}.compare-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border);background:var(--bg-surface)}.compare-header-left{display:flex;align-items:center;gap:8px;color:var(--text-primary)}.compare-title{font-weight:600;font-size:.95rem}.compare-close-btn{display:flex;align-items:center;gap:4px}.compare-selectors{display:flex;align-items:center;gap:12px;padding:16px;border-bottom:1px solid var(--border);background:var(--bg-surface)}.compare-selector{flex:1;display:flex;flex-direction:column;gap:4px}.compare-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.compare-select{padding:8px 10px;border-radius:6px;border:1px solid var(--border-strong);background:var(--bg-elevated);color:var(--text-primary);font-size:.85rem;font-family:inherit;cursor:pointer}.compare-select:focus{outline:none;border-color:var(--accent)}.compare-vs{font-size:.8rem;font-weight:600;color:var(--text-muted);padding-top:18px}.compare-warning{display:flex;align-items:center;gap:8px;padding:10px 16px;margin:0;background:#fbbf2414;border-bottom:1px solid rgba(251,191,36,.2);color:var(--warning);font-size:.85rem}.compare-actions{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border);background:var(--bg-surface)}.compare-summary-cards{display:flex;gap:12px;padding:16px;border-bottom:1px solid var(--border);background:var(--bg-surface);overflow-x:auto}.compare-card{flex:1;min-width:100px;display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 16px;border-radius:8px;background:var(--bg-elevated);border:1px solid var(--border)}.compare-card-value{font-size:1.3rem;font-weight:700;font-variant-numeric:tabular-nums;color:var(--text-primary)}.compare-card-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.compare-card-diff{border-color:#fbbf244d}.compare-card-diff .compare-card-value{color:var(--warning)}.compare-card-match{border-color:#22c55e4d}.compare-card-match .compare-card-value{color:#22c55e}.compare-tabs{display:flex;gap:0;padding:0 16px;border-bottom:1px solid var(--border);background:var(--bg-surface)}.compare-tab{display:flex;align-items:center;gap:6px;padding:10px 16px;border:none;border-bottom:2px solid transparent;background:none;color:var(--text-muted);font-size:.85rem;font-family:inherit;cursor:pointer;transition:color .15s,border-color .15s}.compare-tab:hover{color:var(--text-secondary)}.compare-tab.active{color:var(--accent-soft-text);border-bottom-color:var(--accent)}.compare-tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;padding:1px 6px;border-radius:10px;background:var(--accent-soft);color:var(--accent-soft-text);font-size:.7rem;font-weight:600}.compare-results{flex:1;overflow:auto}.compare-diff-filters{display:flex;align-items:center;gap:6px;padding:10px 16px;background:var(--bg-surface);border-bottom:1px solid var(--border)}.compare-diff-filters-label{font-size:.8rem;color:var(--text-muted);margin-right:4px}.compare-diff-filter-btn{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;border:1px solid var(--border);border-radius:14px;background:var(--bg-main);color:var(--text-muted);font-size:.78rem;font-family:inherit;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.compare-diff-filter-btn:hover{color:var(--text-secondary);border-color:var(--text-muted)}.compare-diff-filter-btn.active{background:var(--accent-soft);color:var(--accent-soft-text);border-color:var(--accent-soft);font-weight:600}.compare-diff-filter-count{font-size:.7rem;opacity:.7}.compare-columns{border-bottom:1px solid var(--border);background:var(--bg-surface)}.compare-columns-header{display:flex;align-items:center;gap:6px;padding:8px 16px;cursor:pointer;-webkit-user-select:none;user-select:none}.compare-columns-toggle{font-size:.65rem;color:var(--text-muted);width:12px}.compare-columns-title{font-size:.8rem;font-weight:600;color:var(--text-secondary)}.compare-columns-count{margin-left:auto;font-size:.7rem;color:var(--text-muted);font-variant-numeric:tabular-nums}.compare-columns-body{padding:0 16px 10px}.compare-columns-actions{display:flex;gap:8px;margin-bottom:6px}.compare-columns-link{border:none;background:none;color:var(--accent-soft-text);font-size:.75rem;font-family:inherit;cursor:pointer;padding:0;text-decoration:underline;text-underline-offset:2px}.compare-columns-link:hover{color:var(--accent)}.compare-columns-list{display:flex;flex-wrap:wrap;gap:2px 12px;max-height:160px;overflow-y:auto}.compare-col-item{display:flex;align-items:center;gap:5px;padding:2px 0;cursor:pointer;font-size:.8rem;color:var(--text-secondary);min-width:140px}.compare-col-item:hover{color:var(--text-primary)}.compare-col-item input[type=checkbox]{accent-color:var(--accent);margin:0;cursor:pointer}.compare-col-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.union-panel{display:flex;flex-direction:column;height:100%;overflow:hidden}.union-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border);background:var(--bg-surface)}.union-header-left{display:flex;align-items:center;gap:8px;color:var(--text-primary)}.union-title{font-weight:600;font-size:.95rem}.union-close-btn{display:flex;align-items:center;gap:4px}.union-file-selector{border-bottom:1px solid var(--border);background:var(--bg-surface)}.union-file-selector-header{display:flex;align-items:center;gap:8px;padding:10px 16px}.union-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.union-file-selector-actions{display:flex;gap:8px}.union-link{border:none;background:none;color:var(--accent-soft-text);font-size:.75rem;font-family:inherit;cursor:pointer;padding:0;text-decoration:underline;text-underline-offset:2px}.union-link:hover{color:var(--accent)}.union-file-count{margin-left:auto;font-size:.7rem;color:var(--text-muted);font-variant-numeric:tabular-nums}.union-file-list{max-height:180px;overflow-y:auto;padding:0 16px 10px;display:flex;flex-direction:column;gap:2px}.union-file-item{display:flex;align-items:center;gap:8px;padding:5px 8px;border-radius:4px;cursor:pointer;font-size:.82rem;color:var(--text-secondary);transition:background .1s}.union-file-item:hover{background:var(--accent-subtle)}.union-file-item.selected{background:var(--accent-soft)}.union-file-item input[type=checkbox]{accent-color:var(--accent);margin:0;cursor:pointer}.union-file-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.union-file-meta{font-size:.7rem;color:var(--text-faint);white-space:nowrap;flex-shrink:0}.union-warning{display:flex;align-items:center;gap:8px;padding:10px 16px;margin:0;background:#fbbf2414;border-bottom:1px solid rgba(251,191,36,.2);color:var(--warning);font-size:.85rem}.union-info{display:flex;align-items:center;gap:8px;padding:10px 16px;margin:0;background:var(--accent-subtle);border-bottom:1px solid var(--border);color:var(--accent-soft-text);font-size:.85rem}.union-columns{border-bottom:1px solid var(--border);background:var(--bg-surface)}.union-columns-header{display:flex;align-items:center;gap:6px;padding:8px 16px;cursor:pointer;-webkit-user-select:none;user-select:none}.union-columns-toggle{font-size:.65rem;color:var(--text-muted);width:12px}.union-columns-title{font-size:.8rem;font-weight:600;color:var(--text-secondary)}.union-columns-count{margin-left:auto;font-size:.7rem;color:var(--text-muted);font-variant-numeric:tabular-nums}.union-columns-body{padding:0 16px 10px}.union-columns-actions{display:flex;gap:8px;margin-bottom:6px}.union-columns-link{border:none;background:none;color:var(--accent-soft-text);font-size:.75rem;font-family:inherit;cursor:pointer;padding:0;text-decoration:underline;text-underline-offset:2px}.union-columns-link:hover{color:var(--accent)}.union-columns-list{display:flex;flex-wrap:wrap;gap:2px 12px;max-height:160px;overflow-y:auto}.union-col-item{display:flex;align-items:center;gap:5px;padding:2px 0;cursor:pointer;font-size:.8rem;color:var(--text-secondary);min-width:140px}.union-col-item:hover{color:var(--text-primary)}.union-col-item input[type=checkbox]{accent-color:var(--accent);margin:0;cursor:pointer}.union-col-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.union-actions{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border);background:var(--bg-surface)}.union-mode-toggle{display:flex;gap:0;border:1px solid var(--border);border-radius:6px;overflow:hidden}.union-mode-btn{padding:4px 12px;border:none;background:transparent;color:var(--text-muted);font-size:.75rem;font-weight:600;font-family:inherit;cursor:pointer;transition:background .15s,color .15s}.union-mode-btn:not(:last-child){border-right:1px solid var(--border)}.union-mode-btn:hover{color:var(--text-secondary)}.union-mode-btn.active{background:var(--accent-soft);color:var(--accent-soft-text)}.union-summary-cards{display:flex;gap:12px;padding:16px;border-bottom:1px solid var(--border);background:var(--bg-surface);overflow-x:auto}.union-card{flex:1;min-width:90px;display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 16px;border-radius:8px;background:var(--bg-elevated);border:1px solid var(--border)}.union-card-value{font-size:1.3rem;font-weight:700;font-variant-numeric:tabular-nums;color:var(--text-primary)}.union-card-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center}.union-card-file{border-color:var(--accent-soft)}.union-card-file .union-card-value{color:var(--accent-soft-text)}.union-card-file .union-card-label{text-transform:none;letter-spacing:normal;font-weight:500}.union-register{display:flex;align-items:center;gap:8px;padding:10px 16px;border-bottom:1px solid var(--border);background:var(--bg-surface)}.union-register-label{font-size:.8rem;color:var(--text-muted);white-space:nowrap}.union-register-input{padding:5px 10px;border-radius:4px;border:1px solid var(--border-strong);background:var(--bg-elevated);color:var(--text-primary);font-size:.82rem;font-family:Courier New,monospace;width:200px}.union-register-input:focus{outline:none;border-color:var(--accent)}.union-register-success{display:flex;align-items:center;gap:8px;padding:10px 16px;margin:0;background:#22c55e14;border-bottom:1px solid rgba(34,197,94,.2);color:#22c55e;font-size:.85rem}.union-results{flex:1;overflow:auto}.pricing-section{width:100%;display:flex;flex-direction:column;align-items:center;gap:1.5rem}.pricing-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0}.pricing-subtitle{font-size:.92rem;color:var(--text-muted);margin:0}.pricing-cards{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;width:100%}.pricing-card{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:12px;background:var(--bg-surface);padding:1.5rem;gap:1.25rem}.pricing-card-pro{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),0 4px 24px #3b82f61f}.pricing-card-header{display:flex;flex-direction:column;gap:.5rem}.pricing-card-name-row{display:flex;align-items:center;gap:.4rem}.pricing-card-name{font-size:1.1rem;font-weight:700;color:var(--text-primary);margin:0}.pricing-pro-star{color:var(--accent);display:flex;align-items:center}.pricing-card-price{display:flex;align-items:baseline;gap:.25rem}.pricing-amount{font-size:2rem;font-weight:800;color:var(--text-primary);letter-spacing:-.03em}.pricing-period{font-size:.85rem;color:var(--text-muted)}.pricing-save{font-size:.75rem;color:var(--accent);font-weight:600}.pricing-toggle{display:inline-flex;border:1px solid var(--border);border-radius:6px;overflow:hidden;align-self:flex-start}.pricing-toggle-btn{padding:.3rem .75rem;border:none;background:transparent;color:var(--text-muted);font-size:.75rem;font-weight:500;cursor:pointer;font-family:inherit;transition:background .15s,color .15s}.pricing-toggle-btn.active{background:var(--accent);color:#fff}.pricing-features{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem;flex:1}.pricing-feature{display:flex;align-items:flex-start;gap:.5rem;font-size:.82rem;color:var(--text-secondary);line-height:1.4}.pricing-feature.disabled{opacity:.45}.pricing-feature-check{flex-shrink:0;width:1rem;text-align:center;font-weight:700;font-size:.85rem}.pricing-feature:not(.disabled) .pricing-feature-check{color:var(--accent)}.pricing-feature.disabled .pricing-feature-check{color:var(--text-ghost)}.pricing-card-cta{display:block;width:100%;padding:.65rem 1rem;border-radius:8px;font-size:.9rem;font-weight:600;text-align:center;cursor:pointer;font-family:inherit;transition:background .15s,transform .1s;border:none}.pricing-card-cta-primary{background:var(--accent);color:#fff}.pricing-card-cta-primary:hover:not(:disabled){background:var(--accent-hover)}.pricing-card-cta-primary:active:not(:disabled){transform:scale(.98)}.pricing-card-cta-primary:disabled{opacity:.6;cursor:not-allowed}.pricing-card-cta-secondary{background:transparent;border:1px solid var(--border);color:var(--text-secondary)}.pricing-card-cta-secondary:hover{border-color:var(--border-strong);color:var(--text-primary)}.pricing-card-cta-current{background:var(--bg-elevated);color:var(--text-muted);cursor:default;font-weight:500}.landing{flex:1;display:flex;align-items:flex-start;justify-content:center;overflow-y:auto;padding:3rem 1.5rem}.landing-inner{max-width:820px;width:100%;display:flex;flex-direction:column;align-items:center;gap:3rem}.landing-hero{display:flex;flex-direction:column;align-items:center;gap:.75rem}.landing-logo{margin-bottom:.25rem}.landing-name{font-size:2.5rem;font-weight:800;letter-spacing:-.04em;color:var(--text-primary);line-height:1}.landing-tagline{font-size:1.1rem;color:var(--text-muted);font-weight:400}.landing-subtitle{font-size:.88rem;color:var(--text-ghost);margin:0}.landing-cta{display:inline-flex;align-items:center;gap:.5rem;margin-top:.75rem;padding:.75rem 2rem;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .15s,transform .1s;font-family:inherit}.landing-cta:hover{background:var(--accent-hover)}.landing-cta:active{transform:scale(.98)}.landing-hint{font-size:.82rem;color:var(--text-ghost)}.landing-features{display:grid;grid-template-columns:1fr 1fr;gap:1rem;width:100%}.landing-feature{display:flex;flex-direction:column;gap:.5rem;padding:1.25rem;border-radius:8px;border:1px solid var(--border);background:var(--bg-surface);transition:border-color .15s;position:relative}.landing-feature:hover{border-color:var(--border-strong)}.landing-feature-icon{color:var(--accent);height:28px}.landing-feature-title{font-size:.92rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:.4rem}.landing-feature-desc{font-size:.8rem;color:var(--text-secondary);line-height:1.5}.landing-pro-badge{display:inline-flex;align-items:center;padding:.1rem .4rem;background:var(--accent);color:#fff;font-size:.58rem;font-weight:700;letter-spacing:.05em;border-radius:4px;line-height:1.2;text-transform:uppercase}.landing-how-it-works{width:100%;display:flex;flex-direction:column;align-items:center;gap:1.5rem}.landing-section-title{font-size:1.35rem;font-weight:700;color:var(--text-primary);margin:0}.landing-steps{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem;width:100%}.landing-step{display:flex;flex-direction:column;gap:.4rem;padding:1.25rem;border-radius:8px;background:var(--bg-surface);border:1px solid var(--border)}.landing-step-number{font-size:1.5rem;font-weight:800;color:var(--accent);opacity:.5;letter-spacing:-.02em;line-height:1}.landing-step-title{font-size:.92rem;font-weight:600;color:var(--text-primary);margin:0}.landing-step-desc{font-size:.78rem;color:var(--text-secondary);line-height:1.5;margin:0}.landing-extras{font-size:.78rem;color:var(--text-faint);text-align:center}:root{--bg-base: #0f1117;--bg-surface: #161b27;--bg-elevated: #1a2033;--bg-inset: #0d0f15;--border: #1e2535;--border-strong: #2d3a52;--text-primary: #e2e8f0;--text-secondary: #94a3b8;--text-muted: #64748b;--text-faint: #475569;--text-ghost: #334155;--accent: #3b82f6;--accent-hover: #1d4ed8;--accent-bg: #2563eb;--accent-soft: rgba(59, 130, 246, .15);--accent-soft-text:#60a5fa;--accent-subtle: rgba(59, 130, 246, .08);--accent-border: #1d4ed8;--accent-highlight:#7dd3fc;--error-bg: rgba(220, 38, 38, .1);--error-border: #dc2626;--error-text: #f87171;--warning: #fbbf24;--null-text: #334155;--btn-secondary-bg: #1e2535;--btn-secondary-text: #94a3b8;--btn-secondary-border:#2d3a52;--btn-secondary-hover: #2d3a52;--table-row-hover: rgba(255,255,255,.02);--scrollbar-track: #0f1117;--scrollbar-thumb: #2d3a52;--scrollbar-hover: #3b4b6b;--overlay-bg: rgba(15, 17, 23, .85);--textarea-focus: rgba(17, 24, 39, .4)}[data-theme=light]{--bg-base: #ffffff;--bg-surface: #f8fafc;--bg-elevated: #f1f5f9;--bg-inset: #f8fafc;--border: #e2e8f0;--border-strong: #cbd5e1;--text-primary: #1e293b;--text-secondary: #475569;--text-muted: #64748b;--text-faint: #94a3b8;--text-ghost: #cbd5e1;--accent: #2563eb;--accent-hover: #1d4ed8;--accent-bg: #2563eb;--accent-soft: rgba(37, 99, 235, .1);--accent-soft-text:#2563eb;--accent-subtle: rgba(37, 99, 235, .06);--accent-border: #1d4ed8;--accent-highlight:#0369a1;--error-bg: rgba(220, 38, 38, .06);--error-border: #dc2626;--error-text: #dc2626;--warning: #d97706;--null-text: #cbd5e1;--btn-secondary-bg: #f1f5f9;--btn-secondary-text: #475569;--btn-secondary-border:#e2e8f0;--btn-secondary-hover: #e2e8f0;--table-row-hover: rgba(0,0,0,.02);--scrollbar-track: #ffffff;--scrollbar-thumb: #cbd5e1;--scrollbar-hover: #94a3b8;--overlay-bg: rgba(255, 255, 255, .85);--textarea-focus: rgba(241, 245, 249, .6)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;background:var(--bg-base);color:var(--text-primary);min-height:100vh;overflow:hidden}.app-layout{display:grid;grid-template-columns:240px 1fr;grid-template-rows:auto 1fr auto;height:100vh;overflow:hidden}.main-content{grid-row:2;grid-column:2;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-base)}.btn{display:inline-flex;align-items:center;gap:.3rem;padding:.35rem .75rem;border:1px solid transparent;border-radius:4px;font-size:.78rem;font-weight:500;cursor:pointer;transition:all .12s;white-space:nowrap}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--accent-bg);color:#fff;border-color:var(--accent-border)}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-run{background:var(--accent-bg);color:#fff;border-color:var(--accent-border)}.btn-run:hover:not(:disabled){background:var(--accent-hover)}.btn-secondary{background:var(--btn-secondary-bg);color:var(--btn-secondary-text);border-color:var(--btn-secondary-border)}.btn-secondary:hover:not(:disabled){background:var(--btn-secondary-hover);color:var(--text-primary)}.spin{animation:spin .8s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-banner{padding:.75rem 1rem;background:var(--error-bg);border-left:3px solid var(--error-border);color:var(--error-text);font-size:.82rem;font-family:Courier New,monospace;white-space:pre-wrap;word-break:break-all}.result-info{font-size:.78rem;color:var(--text-muted)}.status-bar{grid-column:1 / -1;display:flex;align-items:center;gap:1rem;padding:0 1rem;height:26px;background:var(--bg-surface);border-top:1px solid var(--border);font-size:.7rem;color:var(--text-faint)}.status-bar-item{white-space:nowrap}.status-bar-warning{color:var(--warning)}.drop-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;background:var(--overlay-bg);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:all}.drop-overlay-inner{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:3rem 4rem;border:2px dashed var(--accent);border-radius:12px;background:var(--accent-subtle)}.drop-overlay-icon{color:var(--accent)}.drop-overlay-text{font-size:1.1rem;color:var(--text-secondary);font-weight:500}.drop-overlay-hint{font-size:.82rem;color:var(--text-faint)}.dots:after{content:"";animation:dots 1.2s steps(3,end) infinite}@keyframes dots{0%{content:""}33%{content:"."}66%{content:".."}to{content:"..."}}.welcome-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:var(--text-ghost)}.welcome-icon{opacity:.3}.welcome-title{font-size:1.1rem;font-weight:600;color:var(--text-faint)}.welcome-hint{font-size:.85rem;color:var(--text-ghost)}.welcome-cta{margin-top:.5rem;padding:.5rem 1.5rem;background:var(--accent);color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s}.welcome-cta:hover{background:var(--accent-hover)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--scrollbar-track)}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-hover)}
