*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #1e1e2e;--surface: #282840;--surface2: #313150;--border: #444466;--text: #cdd6f4;--text-dim: #a6adc8;--accent: #89b4fa;--accent-hover: #74c7ec;--danger: #f38ba8;--success: #a6e3a1;--warning: #f9e2af;--radius: 8px;--font-mono: "Cascadia Code", "Fira Code", "JetBrains Mono", monospace}html,body,#root{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text)}.app{display:flex;flex-direction:column;height:100vh;overflow:hidden}.app-header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.app-header h1{font-size:1.25rem;font-weight:700;color:var(--accent);letter-spacing:.5px}.toolbar{display:flex;align-items:center;gap:12px;padding:10px 20px;background:var(--surface);border-bottom:1px solid var(--border);flex-wrap:wrap;flex-shrink:0}.toolbar label{font-size:.8rem;color:var(--text-dim);display:flex;align-items:center;gap:6px}.toolbar select{background:var(--surface2);border:1px solid var(--border);color:var(--text);padding:6px 10px;border-radius:var(--radius);font-size:.85rem;cursor:pointer}.toolbar select:focus{outline:2px solid var(--accent);outline-offset:1px}.btn{display:inline-flex;align-items:center;gap:4px;padding:7px 16px;border:none;border-radius:var(--radius);font-size:.85rem;font-weight:600;cursor:pointer;transition:background .15s,transform .1s}.btn:active{transform:scale(.97)}.btn-primary{background:var(--accent);color:#1e1e2e}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:var(--surface2);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--border)}.btn-danger{background:var(--danger);color:#1e1e2e}.btn-danger:hover{opacity:.85}.btn:disabled{opacity:.5;cursor:not-allowed}.toolbar-separator{width:1px;height:24px;background:var(--border)}.editors{display:flex;flex:1;min-height:0}.editor-pane{flex:1;display:flex;flex-direction:column;min-width:0}.editor-pane:first-child{border-right:1px solid var(--border)}.editor-pane-header{padding:8px 16px;background:var(--surface2);font-size:.8rem;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;border-bottom:1px solid var(--border);flex-shrink:0}.editor-wrapper{flex:1;min-height:0}.logging-panel{background:var(--surface);border-top:1px solid var(--border);padding:12px 20px;flex-shrink:0}.logging-header{display:flex;align-items:center;gap:12px;cursor:pointer;-webkit-user-select:none;user-select:none}.logging-header h3{font-size:.9rem;font-weight:600;color:var(--text-dim)}.logging-body{margin-top:12px;display:flex;flex-wrap:wrap;align-items:flex-start;gap:16px}.toggle{display:inline-flex;align-items:center;gap:8px;font-size:.82rem;cursor:pointer}.toggle input{display:none}.toggle-track{position:relative;width:36px;height:20px;background:var(--surface2);border:1px solid var(--border);border-radius:10px;transition:background .2s}.toggle input:checked+.toggle-track{background:var(--accent);border-color:var(--accent)}.toggle-track:after{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;background:#fff;border-radius:50%;transition:transform .2s}.toggle input:checked+.toggle-track:after{transform:translate(16px)}.status-msg{font-size:.8rem;padding:6px 12px;border-radius:var(--radius);max-width:100%;word-break:break-all}.status-msg.success{background:#a6e3a11f;color:var(--success);border:1px solid rgba(166,227,161,.3)}.status-msg.error{background:#f38ba81f;color:var(--danger);border:1px solid rgba(243,139,168,.3)}.status-msg.info{background:#89b4fa1f;color:var(--accent);border:1px solid rgba(137,180,250,.3)}.btn-accent{background:var(--warning);color:#1e1e2e}.btn-accent:hover{filter:brightness(.9)}.footprint-panel{background:var(--surface);border-top:1px solid var(--border);flex-shrink:0;max-height:45vh;overflow-y:auto}.footprint-header{display:flex;align-items:center;gap:12px;padding:10px 20px;cursor:pointer;-webkit-user-select:none;user-select:none;position:sticky;top:0;background:var(--surface);z-index:1}.footprint-header h3{font-size:.9rem;font-weight:600;color:var(--accent)}.footprint-badge{font-size:.75rem;color:var(--text-dim);margin-left:auto}.footprint-badge .warning-count{color:var(--warning)}.footprint-body{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;padding:0 20px 16px}.fp-section{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px}.fp-section h4{font-size:.78rem;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.8px;margin-bottom:8px}.fp-section ul{list-style:none;padding:0}.fp-section li{font-size:.8rem;padding:3px 0;display:flex;align-items:baseline;gap:6px;flex-wrap:wrap}.fp-section code{font-family:var(--font-mono);font-size:.8rem;color:var(--text);background:#89b4fa14;padding:1px 5px;border-radius:3px}.fp-alias{font-size:.72rem;color:var(--text-dim);font-style:italic}.fp-ctx{font-size:.65rem;color:var(--text-dim);background:#ffffff0d;padding:1px 6px;border-radius:3px;margin-left:auto;white-space:nowrap}.fp-unresolved li code{color:var(--warning)}.fp-hint{font-size:.72rem;color:var(--text-dim);margin-bottom:6px;font-style:italic}.fp-conf{font-size:.7rem;font-weight:700;border-radius:3px;padding:0 4px;margin-left:2px;line-height:1}.fp-conf-high{color:#a6e3a1}.fp-conf-none{color:var(--warning);opacity:.8}.fp-low-conf{opacity:.7}.fp-errors .status-msg.error{background:#f38ba81f;color:#f38ba8;border:1px solid rgba(243,139,168,.3);font-size:.78rem;padding:6px 10px;border-radius:var(--radius);margin-bottom:4px}.footprint-badge .error-count{color:#f38ba8}.status-msg.warning{background:#f9e2af1f;color:var(--warning);border:1px solid rgba(249,226,175,.3)}.collapse-arrow{font-size:.7rem;transition:transform .2s;color:var(--text-dim)}.collapse-arrow.open{transform:rotate(90deg)}.copy-ok{color:var(--success);font-size:.8rem;animation:fadeout 1.5s forwards}@keyframes fadeout{0%{opacity:1}70%{opacity:1}to{opacity:0}}.tab-nav{display:flex;gap:4px}.tab-btn{background:transparent;border:none;color:var(--text-dim);font-size:.85rem;font-weight:600;padding:6px 16px;cursor:pointer;border-bottom:2px solid transparent;transition:all .15s}.tab-btn:hover{color:var(--text)}.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}.btn-export{background:#74c7ec;color:#1e1e2e}.btn-export:hover{filter:brightness(.9)}.log-badge{font-size:.72rem;padding:3px 10px;border-radius:12px;font-weight:600;animation:fadeout 4s forwards}.log-badge-success{background:#a6e3a126;color:var(--success)}.log-badge-error{background:#f38ba826;color:var(--danger)}.log-badge-info{background:#89b4fa26;color:var(--accent)}.logs-container{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}.logs-toolbar{display:flex;align-items:center;gap:10px;padding:12px 20px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.logs-search{flex:1;max-width:400px;background:var(--surface2);border:1px solid var(--border);color:var(--text);padding:7px 12px;border-radius:var(--radius);font-size:.85rem}.logs-search:focus{outline:2px solid var(--accent);outline-offset:1px}.logs-list{flex:1;overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column;gap:10px}.logs-empty{text-align:center;color:var(--text-dim);padding:40px;font-size:.9rem}.log-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px;cursor:pointer;transition:border-color .15s}.log-card:hover{border-color:var(--accent)}.log-card-header{display:flex;align-items:center;gap:10px;margin-bottom:6px}.log-card-dialect{font-size:.72rem;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.5px}.log-card-time{font-size:.72rem;color:var(--text-dim)}.log-card-badge{font-size:.65rem;padding:1px 8px;border-radius:8px;font-weight:600;margin-left:auto}.badge-redacted{background:#a6e3a126;color:var(--success)}.badge-raw{background:#f9e2af26;color:var(--warning)}.log-card-preview{font-family:var(--font-mono);font-size:.78rem;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0;max-height:2.5em}.logs-load-more{align-self:center;margin:12px 0}.log-modal-backdrop{position:fixed;inset:0;background:#0009;z-index:100;display:flex;align-items:center;justify-content:center}.log-modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:min(90vw,800px);max-height:85vh;display:flex;flex-direction:column;overflow:hidden}.log-modal-header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-bottom:1px solid var(--border)}.log-modal-header h3{font-size:1rem;color:var(--accent)}.log-modal-body{padding:16px 20px;overflow-y:auto}.log-detail-meta{display:flex;flex-wrap:wrap;gap:12px;font-size:.78rem;color:var(--text-dim);margin-bottom:12px}.log-detail-meta strong{color:var(--text)}.log-detail-summary{font-size:.78rem;color:var(--text-dim);margin-bottom:12px;padding:6px 10px;background:var(--surface2);border-radius:var(--radius)}.log-detail-sql{display:grid;grid-template-columns:1fr 1fr;gap:12px}.log-detail-sql h4{font-size:.78rem;font-weight:700;color:var(--accent);text-transform:uppercase;margin-bottom:6px}.log-detail-sql pre{font-family:var(--font-mono);font-size:.78rem;color:var(--text);background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:10px;white-space:pre-wrap;word-break:break-all;max-height:300px;overflow-y:auto;margin:0 0 8px}.btn-sm{padding:4px 10px;font-size:.72rem}
