:root{--bg:#fafafa;--foreground:#111;--surface:#fff;--border:#eaeaea;--border-strong:#e5e5e5;--text-h:#111;--text-body:#374151;--text-muted:#6b7280;--text-subtle:#9ca3af;--accent:#111;--accent-hover:#1f2937;--accent-soft:#f3f4f6;--emerald-50:#ecfdf5;--emerald-100:#d1fae5;--emerald-600:#059669;--emerald-700:#047857;--blue-50:#eff6ff;--blue-600:#2563eb;--red-50:#fef2f2;--red-600:#dc2626;--amber-50:#fffbeb;--amber-700:#b45309;--shadow-sm:0 1px 2px #0000000a;--shadow-md:0 4px 12px #0000000f;--shadow-lg:0 12px 40px #00000014;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem;--radius-2xl:1.25rem;--radius-full:9999px;color:var(--foreground);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-weight:400;line-height:1.5}*{box-sizing:border-box}body{background:var(--bg);min-height:100vh;margin:0}body::selection{background:var(--accent);color:#fff}#root{min-height:100vh}.app{flex-direction:column;min-height:100vh;display:flex}.app-header{border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:50;background:#ffffffd9;justify-content:space-between;align-items:center;gap:1.5rem;padding:1rem 2rem;display:flex;position:sticky;top:0}.brand{align-items:center;gap:.75rem;display:flex}.brand-mark{border-radius:var(--radius-lg);background:var(--accent);color:#fff;letter-spacing:-.02em;justify-content:center;align-items:center;width:36px;height:36px;font-size:.85rem;font-weight:700;display:flex}.app-header h1{letter-spacing:-.02em;color:var(--text-h);margin:0;font-size:1.125rem;font-weight:600}.subtitle{color:var(--text-muted);margin:.15rem 0 0;font-size:.875rem;font-weight:400}.header-actions{align-items:center;gap:.75rem;display:flex}.app-main{flex:1;grid-template-columns:340px 1fr;gap:1.5rem;width:100%;max-width:1400px;min-height:0;margin:0 auto;padding:1.5rem 2rem 2rem;display:grid}.sidebar{flex-direction:column;gap:1rem;display:flex;overflow-y:auto}.chat-section{flex-direction:column;min-height:0;display:flex}.card,.upload-panel,.chat-panel,.conversations-panel,.status-details{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-2xl);box-shadow:var(--shadow-sm);padding:1.25rem}.upload-panel,.chat-panel{flex-direction:column;gap:.875rem;display:flex}.upload-panel h2,.chat-panel h2,.conversations-panel h3,.status-details h3{letter-spacing:-.01em;color:var(--text-h);margin:0;font-size:.95rem;font-weight:600}.panel-desc{color:var(--text-muted);margin:0;font-size:.8125rem;line-height:1.5}.section-label{border-radius:var(--radius-full);background:var(--emerald-50);border:1px solid var(--emerald-100);color:var(--emerald-700);letter-spacing:.01em;align-items:center;gap:.35rem;width:fit-content;padding:.35rem .75rem;font-size:.75rem;font-weight:500;display:inline-flex}.status-badge{border-radius:var(--radius-full);border:1px solid var(--border);background:var(--surface);align-items:center;gap:.5rem;padding:.4rem .85rem;font-size:.8125rem;font-weight:500;display:inline-flex}.status-badge.ready{background:var(--emerald-50);color:var(--emerald-700);border-color:var(--emerald-100)}.status-badge.pending{background:var(--amber-50);color:var(--amber-700);border-color:#fde68a}.status-dot{background:currentColor;border-radius:50%;width:7px;height:7px}.btn{border-radius:var(--radius-lg);cursor:pointer;border:none;padding:.625rem 1.125rem;font-family:inherit;font-size:.875rem;font-weight:500;transition:background .15s,transform .1s,box-shadow .15s}.btn:disabled{opacity:.45;cursor:not-allowed}.btn.primary{background:var(--accent);color:#fff;box-shadow:var(--shadow-sm)}.btn.primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:var(--shadow-md)}.btn.secondary{background:var(--surface);border:1px solid var(--border-strong);color:var(--text-h)}.btn.secondary:hover:not(:disabled){background:var(--accent-soft)}.btn.secondary.small{border-radius:var(--radius-md);padding:.35rem .75rem;font-size:.75rem}.btn.link{color:var(--text-muted);cursor:pointer;background:0 0;border:none;margin-top:.5rem;padding:.25rem;font-size:.875rem}.btn.link:hover{color:var(--text-h)}.file-drop{border:1.5px dashed var(--border-strong);border-radius:var(--radius-xl);cursor:pointer;text-align:center;color:var(--text-muted);background:var(--bg);justify-content:center;align-items:center;padding:1.5rem 1rem;font-size:.8125rem;transition:border-color .15s,background .15s;display:flex}.file-drop:hover,.file-drop.dragging{border-color:var(--text-subtle);background:var(--accent-soft)}.file-drop input{display:none}.file-drop-label{color:var(--text-h);font-weight:500}.file-drop-hint{color:var(--text-muted);margin-top:.35rem;font-size:.8rem;display:block}.file-list{color:var(--text-muted);margin:0;padding-left:1.1rem;font-size:.8125rem}.chat-input-row input{border:1px solid var(--border-strong);border-radius:var(--radius-lg);background:var(--bg);color:var(--text-h);padding:.7rem .9rem;font-family:inherit;font-size:.9rem;transition:border-color .15s,box-shadow .15s}.chat-input-row input:focus{border-color:var(--text-subtle);outline:none;box-shadow:0 0 0 3px #1111110f}.chat-input-row{border-top:1px solid var(--border);gap:.625rem;padding-top:1rem;display:flex}.chat-input-row input{background:var(--surface);flex:1}.banner{padding:.75rem 2rem;font-size:.875rem;font-weight:500}.banner.error{background:var(--red-50);color:var(--red-600);border-bottom:1px solid #fecaca}.message{border-radius:var(--radius-lg);margin:0;padding:.6rem .85rem;font-size:.8125rem}.message.error{background:var(--red-50);color:var(--red-600);border:1px solid #fecaca}.message.success{background:var(--emerald-50);color:var(--emerald-700);border:1px solid var(--emerald-100)}.message.info{color:var(--blue-600);background:var(--blue-50);border:1px solid #dbeafe}.conversations-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.conversation-list{flex-direction:column;gap:.25rem;margin:0;padding:0;list-style:none;display:flex}.conversation-list button{text-align:left;border-radius:var(--radius-lg);cursor:pointer;width:100%;color:var(--text-body);background:0 0;border:1px solid #0000;padding:.6rem .85rem;font-family:inherit;font-size:.8125rem;font-weight:500;transition:background .12s,border-color .12s}.conversation-list button:hover{background:var(--accent-soft)}.conversation-list button.active{background:var(--accent-soft);border-color:var(--border-strong);color:var(--text-h)}.status-details ul{flex-direction:column;gap:.5rem;margin:.75rem 0 0;padding:0;list-style:none;display:flex}.status-details li{color:var(--text-muted);text-transform:capitalize;border-bottom:1px solid var(--border);justify-content:space-between;padding:.35rem 0;font-size:.75rem;display:flex}.status-details li:last-child{border-bottom:none}.status-details .ok{color:var(--emerald-700);font-weight:600}.status-details .no{color:var(--red-600);font-weight:600}.chat-panel{flex:1;min-height:0}.chat-header{margin-bottom:.25rem}.chat-messages{flex-direction:column;flex:1;gap:.875rem;min-height:380px;padding:.75rem 0;display:flex;overflow-y:auto}.chat-empty{color:var(--text-muted);text-align:center;flex:1;justify-content:center;align-items:center;padding:2rem;font-size:.9rem;display:flex}.chat-bubble{border-radius:var(--radius-xl);border:1px solid var(--border);background:var(--surface);max-width:78%;box-shadow:var(--shadow-sm);padding:.85rem 1rem}.chat-bubble.user{background:var(--accent);border-color:var(--accent);color:#fff;border-bottom-right-radius:.25rem;align-self:flex-end}.chat-bubble.user .bubble-label{color:#ffffffa6}.chat-bubble.user p{color:#fff}.chat-bubble.assistant{background:var(--emerald-50);border-color:var(--emerald-100);border-bottom-left-radius:.25rem;align-self:flex-start}.chat-bubble.loading p{opacity:.6}.bubble-label{color:var(--text-subtle);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.3rem;font-size:.6875rem;font-weight:600;display:block}.chat-bubble p{white-space:pre-wrap;color:var(--text-h);margin:0;font-size:.9rem;line-height:1.55}.message-content h3,.message-content h4{color:var(--text-h);margin:.75rem 0 .35rem;font-weight:600;line-height:1.35}.message-content h3{font-size:1rem}.message-content h4{font-size:.95rem}.message-content h3:first-child,.message-content h4:first-child{margin-top:0}.message-content ul{margin:.35rem 0 .5rem;padding-left:1.25rem}.message-content li{color:var(--text-h);margin:.2rem 0;font-size:.9rem;line-height:1.5}.chat-error{margin-bottom:.5rem}.stream-toggle{color:var(--text-muted);align-items:center;gap:.5rem;margin-top:.25rem;font-size:.8125rem;display:flex}.stream-toggle input{accent-color:var(--accent)}.source-cards{border-top:1px solid var(--emerald-100);margin-top:.65rem;padding-top:.5rem;font-size:.8125rem}.source-cards summary{cursor:pointer;color:var(--emerald-700);font-weight:500}.source-cards ul{color:var(--text-muted);margin:.5rem 0 0;padding-left:1rem}.landing-page{background:radial-gradient(ellipse 80% 60% at 50% -10%, #10b98114, transparent), var(--bg);flex-direction:column;min-height:100vh;display:flex}.landing-header{border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffd9;justify-content:space-between;align-items:center;padding:1.25rem 2rem;display:flex}.brand-name{letter-spacing:-.02em;color:var(--text-h);font-size:1rem;font-weight:600}.landing-main{flex-direction:column;flex:1;align-items:center;gap:2.5rem;padding:3rem 1.5rem 4rem;display:flex}.landing-hero{text-align:center;max-width:640px}.landing-hero h1{letter-spacing:-.03em;color:var(--text-h);margin:0;font-size:clamp(2rem,5vw,3rem);font-weight:700;line-height:1.1}.landing-hero .subtitle{max-width:520px;margin-top:1rem;margin-left:auto;margin-right:auto;font-size:1.05rem;line-height:1.65}.local-notice{color:var(--text-muted,#6b7280);background:#0000000a;border-radius:8px;max-width:520px;margin-top:1.25rem;margin-left:auto;margin-right:auto;padding:.75rem 1rem;font-size:.875rem;line-height:1.5}.hero-upload{width:100%;max-width:560px}.upload-panel-hero{box-shadow:none;background:0 0;border:none;padding:0}.file-drop-hero{border-radius:var(--radius-2xl);border:2px dashed var(--border-strong);background:var(--surface);min-height:180px;box-shadow:var(--shadow-lg);cursor:pointer;flex-direction:column;justify-content:center;align-items:center;padding:2.5rem 2rem;transition:border-color .15s,background .15s,box-shadow .15s;display:flex}.file-drop-hero:hover,.file-drop-hero.dragging{border-color:var(--accent);background:var(--emerald-50);box-shadow:var(--shadow-lg)}.file-drop-hero .file-drop-label{font-size:1.05rem}.hero-progress{text-align:center;margin-top:1rem}.hero-upload-btn{width:100%;max-width:560px;margin:1rem auto 0;display:block}.landing-error{text-align:center;max-width:560px}.steps-section{text-align:center;width:100%;max-width:900px}.steps-section h2{letter-spacing:-.02em;color:var(--text-h);margin:0 0 1.5rem;font-size:1.25rem;font-weight:600}.steps-grid{text-align:left;grid-template-columns:repeat(3,1fr);gap:1.25rem;display:grid}.step-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-2xl);box-shadow:var(--shadow-sm);padding:1.25rem}.step-number{background:var(--accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;margin-bottom:.75rem;font-size:.8rem;font-weight:600;display:inline-flex}.step-card h3{color:var(--text-h);margin:0 0 .4rem;font-size:.95rem;font-weight:600}.step-card p{color:var(--text-muted);margin:0;font-size:.85rem;line-height:1.55}.landing-footer{text-align:center;color:var(--text-muted);border-top:1px solid var(--border);padding:1.25rem 2rem;font-size:.8rem}@media (width<=900px){.steps-grid{grid-template-columns:1fr}.landing-main{padding:2rem 1rem 3rem}.app-main{grid-template-columns:1fr;padding:1rem}.app-header{flex-wrap:wrap;padding:1rem 1.25rem}}@media (width<=600px){.header-actions{justify-content:space-between;width:100%}.chat-bubble{max-width:92%}}.rag-overlay{z-index:200;justify-content:center;align-items:center;padding:1.5rem;animation:.3s rag-overlay-in;display:flex;position:fixed;inset:0}.rag-overlay-backdrop{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#11111173;position:absolute;inset:0}.rag-overlay-panel{border-radius:var(--radius-2xl);background:var(--surface);border:1px solid var(--border);width:min(920px,100%);box-shadow:var(--shadow-lg);text-align:center;padding:2rem 2rem 1.75rem;position:relative}.rag-overlay-panel--failed{border-color:#fecaca}.rag-overlay-eyebrow{letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin:0 0 .35rem;font-size:.75rem;font-weight:600}.rag-overlay-title{letter-spacing:-.02em;color:var(--text-h);margin:0 0 1.25rem;font-size:1.35rem;font-weight:600}.rag-flow-diagram{max-width:100%;margin:0 auto 1rem;overflow-x:auto}.rag-flow-svg{width:100%;min-width:640px;height:auto}.rag-node-shape{fill:#e6f4fe;stroke:#111;stroke-width:1.5px;transition:fill .35s,stroke .35s,filter .35s}.rag-node--active .rag-node-shape{fill:#bae6fd;stroke:#2563eb;animation:1.4s ease-in-out infinite rag-node-pulse}.rag-node--done .rag-node-shape{fill:var(--emerald-100);stroke:var(--emerald-700)}.rag-node--failed .rag-node-shape{fill:var(--red-50);stroke:var(--red-600);animation:1s ease-in-out infinite rag-node-pulse}.rag-node--pending .rag-node-shape{fill:#f3f4f6;stroke:#d1d5db}.rag-node-label{fill:#111;text-anchor:middle;dominant-baseline:middle;font-size:11px;font-weight:600}.rag-node-label--sm{font-size:9px;font-weight:500}.rag-node-sublabel{fill:#374151;text-anchor:middle;dominant-baseline:middle;font-size:9px}.rag-node-meta{fill:#6b7280;text-anchor:middle;dominant-baseline:middle;font-size:8px}.rag-node-check{fill:var(--emerald-700);text-anchor:middle;dominant-baseline:middle;font-size:14px;font-weight:700}.rag-node--chunk.rag-node--lit .rag-node-shape{fill:#bae6fd;stroke:#2563eb}.rag-node--chunk.rag-node--active .rag-node-shape{animation:.5s forwards rag-chunk-pop}.rag-cylinder-top,.rag-cylinder-bottom{fill:#dbeafe}.rag-cylinder-body{fill:#e6f4fe}.rag-vector-dot{fill:#93c5fd;stroke:#2563eb;stroke-width:.5px;opacity:0;transform-box:fill-box;transform-origin:50%}.rag-vector-dot--visible{animation:.35s forwards rag-dot-pop}.rag-connector{stroke:#d1d5db;stroke-width:1.5px;stroke-linecap:round}.rag-connector--active{stroke:#2563eb;stroke-dasharray:6 4;animation:.8s linear infinite rag-dash-flow}.rag-connector--done{stroke:var(--emerald-600);stroke-width:2px}.rag-overlay-status{color:var(--text-body);min-height:1.5rem;margin:.5rem 0 0;font-size:.95rem}.rag-overlay-status--error{color:var(--red-600)}.rag-overlay-close{margin-top:1rem}@keyframes rag-overlay-in{0%{opacity:0}to{opacity:1}}@keyframes rag-node-pulse{0%,to{filter:drop-shadow(0 0 #2563eb00)}50%{filter:drop-shadow(0 0 10px #2563eb8c)}}@keyframes rag-dash-flow{to{stroke-dashoffset:-20px}}@keyframes rag-chunk-pop{0%{transform:scale(.92)}60%{transform:scale(1.04)}to{transform:scale(1)}}@keyframes rag-dot-pop{0%{opacity:0;transform:scale(.4)}to{opacity:1;transform:scale(1)}}@media (width<=700px){.rag-overlay-panel{padding:1.25rem 1rem 1rem}.rag-overlay-title{font-size:1.1rem}.rag-flow-svg{min-width:520px}}
