*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0a0a1a;--bg-surface: #12122a;--bg-card: #1a1a3a;--text: #e0e0f0;--text-dim: #8888aa;--text-muted: #b0b0cc;--accent: #ffd700;--accent-glow: rgba(255, 215, 0, .4);--accent-soft: rgba(255, 215, 0, .15);--accent-faint: rgba(255, 215, 0, .04);--accent-flash: rgba(255, 215, 0, .15);--accent-highlight: rgba(255, 215, 0, .1);--link-color: #66bbff;--top-k-color: #ff6b6b;--success-color: #51cf66;--border: #2a2a4a;--border-soft: #222244;--border-strong: #333366;--border-muted: #444466;--shadow: rgba(0, 0, 0, .5);--scrollbar-thumb: #333355;--scrollbar-thumb-hover: #444477;--done-bg: #2a4a2a;--done-text: #66ff66;--on-accent: var(--bg);--font-mono: "SF Mono", "Fira Code", "Cascadia Code", monospace;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif}[data-theme=light]{--bg: #f7f7fb;--bg-surface: #ffffff;--bg-card: #eceef5;--text: #1a1a2e;--text-dim: #5a5a78;--text-muted: #3a3a55;--accent: #a67c00;--accent-glow: rgba(166, 124, 0, .35);--accent-soft: rgba(166, 124, 0, .18);--accent-faint: rgba(166, 124, 0, .06);--accent-flash: rgba(166, 124, 0, .2);--accent-highlight: rgba(166, 124, 0, .12);--link-color: #0b63b8;--top-k-color: #c03434;--success-color: #2f8f44;--border: #d0d4e0;--border-soft: #e3e6ee;--border-strong: #b8bccc;--border-muted: #c0c4d0;--shadow: rgba(30, 30, 60, .18);--scrollbar-thumb: #c0c4d0;--scrollbar-thumb-hover: #a0a4b4;--done-bg: #d7efd9;--done-text: #2f8f44;--on-accent: #ffffff}html,body{height:100%;background:var(--bg);color:var(--text);font-family:var(--font-sans);font-size:16px;line-height:1.5;overflow:hidden;transition:background .2s,color .2s}#loading-overlay{position:fixed;inset:0;z-index:1000;background:var(--bg);display:flex;align-items:center;justify-content:center;transition:opacity .5s ease}#loading-overlay.hidden{opacity:0;pointer-events:none}.loading-content{text-align:center}.loading-content h2{font-size:1.5rem;margin-bottom:.5rem;color:var(--accent)}#loading-status{font-size:1.1rem;color:var(--text-dim);margin-bottom:.5rem}.loading-note{font-size:.85rem;color:var(--text-dim);opacity:.6}.loading-spinner{width:48px;height:48px;border:3px solid var(--border-strong);border-top-color:var(--accent);border-radius:50%;margin:0 auto 1.5rem;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}#app{display:flex;height:100vh;gap:0}#scatter-container{flex:0 0 60%;display:flex;flex-direction:column;padding:1rem 1rem 1rem 1.5rem;position:relative}.scatter-title{font-size:1.1rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.5rem}#scatter-plot{flex:1;position:relative}#scatter-plot svg{width:100%;height:100%}#legend{display:flex;flex-wrap:wrap;gap:.75rem;padding:.5rem 0}.legend-item{display:flex;align-items:center;gap:.35rem;font-size:.8rem;color:var(--text-dim);cursor:default}.legend-swatch{width:14px;height:14px;vertical-align:middle}#panel-container{flex:0 0 40%;display:flex;flex-direction:column;padding:1rem 1.5rem 1rem 1rem;border-left:1px solid var(--border-soft);overflow-y:auto;gap:1rem}.panel-title{font-size:1.1rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em}#pipeline-strip{display:flex;align-items:center;gap:.3rem;flex-wrap:wrap}.pipeline-step{padding:.25rem .6rem;border-radius:4px;font-size:.8rem;font-weight:600;font-family:var(--font-mono);background:var(--bg-card);color:var(--text-dim);transition:all .3s ease}.pipeline-step.active{background:var(--accent);color:var(--on-accent);box-shadow:0 0 12px var(--accent-glow)}.pipeline-step.done{background:var(--done-bg);color:var(--done-text)}.pipeline-arrow{color:var(--text-dim);font-size:.8rem;opacity:.4}#query-section{display:flex;flex-direction:column;gap:.5rem}#query-input-wrapper{position:relative}#query-input{width:100%;padding:.75rem 2.2rem .75rem 1rem;font-size:1.15rem;font-family:var(--font-sans);background:var(--bg-surface);border:2px solid var(--border-strong);border-radius:8px;color:var(--text);outline:none;transition:border-color .2s;box-sizing:border-box}#clear-query-btn{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-dim);font-size:1.25rem;cursor:pointer;padding:.2rem .4rem;line-height:1;border-radius:4px;opacity:.6;transition:opacity .15s}#clear-query-btn:hover{opacity:1;color:var(--text)}#query-input:focus{border-color:var(--accent);box-shadow:0 0 16px var(--accent-soft)}#query-input::placeholder{color:var(--text-dim);opacity:.6}#example-queries{display:flex;flex-wrap:wrap;gap:.4rem}.example-chip{padding:.2rem .6rem;font-size:.75rem;background:var(--bg-card);border:1px solid var(--border-strong);border-radius:12px;color:var(--text-dim);cursor:pointer;transition:all .2s;white-space:nowrap}.example-chip:hover{border-color:var(--accent);color:var(--accent)}#heatmap-section{padding:.5rem;background:var(--bg-surface);border-radius:6px}#heatmap-section h3{font-size:.8rem;color:var(--text-dim);margin-bottom:.4rem}#heatmap-list{display:flex;flex-direction:column;gap:2px}.heatmap-row{display:flex;align-items:center;gap:.4rem;height:20px}.heatmap-label{flex:0 0 70px;font-size:.6rem;font-family:var(--font-mono);color:var(--text-dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.heatmap-label-query{color:var(--accent);font-weight:700}.heatmap-canvas{flex:1;height:16px;border-radius:2px;image-rendering:pixelated}.heatmap-score{flex:0 0 45px;font-size:.65rem;font-family:var(--font-mono);color:var(--text-dim);text-align:right}#results-section h3{font-size:.9rem;color:var(--text-dim);margin-bottom:.5rem}#results-count{font-weight:400;opacity:.6}#results-list{display:flex;flex-direction:column;gap:.5rem}.result-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:.75rem;transition:all .3s ease}.result-card.highlight{border-color:var(--accent);box-shadow:0 0 12px var(--accent-highlight)}.result-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.4rem}.result-rank{font-size:.75rem;font-weight:700;color:var(--accent);font-family:var(--font-mono)}.result-score{font-size:1rem;font-weight:700;font-family:var(--font-mono);color:var(--accent)}.result-source{font-size:.7rem;color:var(--text-dim);background:var(--bg-surface);padding:.1rem .4rem;border-radius:3px;font-family:var(--font-mono)}.result-text{font-size:.85rem;color:var(--text);line-height:1.5;opacity:.85}#augmented-section{border-top:1px solid var(--border-soft);padding-top:.75rem}.section-toggle{background:none;border:none;color:var(--text-dim);font-size:.85rem;font-family:var(--font-sans);cursor:pointer;padding:.25rem 0}.section-toggle:hover{color:var(--accent)}#augmented-prompt{margin-top:.5rem;padding:.75rem;background:var(--bg-surface);border-radius:6px;font-size:.75rem;font-family:var(--font-mono);color:var(--text);line-height:1.5;white-space:pre-wrap;word-break:break-word;max-height:300px;overflow-y:auto}#generation-bar{margin-top:.5rem}.generation-settings{display:flex;align-items:center;gap:.35rem;flex-wrap:wrap}#api-key-input{width:160px;padding:.3rem .5rem;font-size:.7rem;font-family:var(--font-mono);background:var(--bg-card);border:1px solid var(--border-strong);border-radius:4px;color:var(--text);outline:none}#api-key-input:focus{border-color:var(--accent)}#model-input{width:150px;padding:.3rem .5rem;font-size:.7rem;font-family:var(--font-mono);background:var(--bg-card);border:1px solid var(--border-strong);border-radius:4px;color:var(--text);outline:none}#model-input:focus{border-color:var(--accent)}#generate-btn{padding:.3rem .75rem;font-size:.75rem;font-weight:600;font-family:var(--font-sans);background:var(--accent);color:var(--on-accent);border:none;border-radius:4px;cursor:pointer;transition:opacity .2s}#generate-btn:disabled{opacity:.35;cursor:not-allowed}#generate-btn.generating{background:var(--top-k-color);color:#fff}#clear-key-btn{background:none;border:1px solid var(--border-muted);border-radius:4px;color:var(--text-dim);font-size:.7rem;padding:.2rem .4rem;cursor:pointer;line-height:1}#clear-key-btn:hover{border-color:var(--top-k-color);color:var(--top-k-color)}#generation-hint{font-size:.7rem;color:var(--text-dim);opacity:.6;margin-top:.3rem;font-style:italic}#generation-outputs{margin-top:.5rem;display:flex;flex-direction:column;gap:.5rem}.gen-block{display:flex;flex-direction:column;gap:.25rem}.gen-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.gen-label.no-rag{color:var(--top-k-color)}.gen-label.with-rag{color:var(--success-color)}.gen-output{padding:.6rem .75rem;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;font-size:.8rem;font-family:var(--font-mono);color:var(--text);line-height:1.6;white-space:pre-wrap;word-break:break-word;max-height:200px;overflow-y:auto;min-height:2rem}#controls{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding-top:.5rem;border-top:1px solid var(--border-soft);font-size:.8rem;color:var(--text-dim)}#controls label{display:flex;align-items:center;gap:.4rem;cursor:pointer}#controls input[type=checkbox]{accent-color:var(--accent)}.control-hint{font-size:.7rem;opacity:.5;font-family:var(--font-mono)}.theme-toggle{background:var(--bg-card);color:var(--text);border:1px solid var(--border-strong);border-radius:6px;padding:.3rem .55rem;font-size:.95rem;line-height:1;cursor:pointer;transition:border-color .15s,color .15s,background .15s}.theme-toggle:hover{border-color:var(--accent)}.theme-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.chunk-tooltip{position:absolute;pointer-events:none;background:var(--bg-card);border:1px solid var(--border-muted);border-radius:6px;padding:.5rem .75rem;font-size:.8rem;color:var(--text);max-width:260px;z-index:100;box-shadow:0 4px 20px var(--shadow);line-height:1.4;opacity:0;transition:opacity .15s ease}.chunk-tooltip.visible{opacity:1}.chunk-tooltip .tooltip-source{font-size:.65rem;color:var(--text-dim);font-family:var(--font-mono);margin-bottom:.3rem}.hidden{display:none!important}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-thumb-hover)}
