*{margin:0;padding:0;box-sizing:border-box}:root{--bg: #0f172a;--surface: #1e293b;--surface-hover: #334155;--primary: #3b82f6;--primary-hover: #2563eb;--text: #f1f5f9;--text-muted: #94a3b8;--border: #334155;--success: #22c55e;--error: #ef4444;--warning: #f59e0b}body{font-family:Inter,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--surface-hover)}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{padding:1.5rem 2rem;border-bottom:1px solid var(--border);background:var(--surface)}.app-header h1{font-size:1.5rem;font-weight:700}.app-header p{color:var(--text-muted);font-size:.875rem;margin-top:.25rem}.app-main{flex:1;display:grid;grid-template-columns:360px 1fr;gap:1.5rem;padding:1.5rem;max-width:1400px;margin:0 auto;width:100%}.namespace-bar{display:flex;align-items:center;gap:.5rem;padding:.5rem 1.25rem;background:var(--bg);border-bottom:1px solid var(--border);font-size:.875rem;color:var(--text-muted)}.namespace-bar label{font-weight:500}.namespace-input{flex:1;max-width:200px;padding:.25rem .5rem;background:var(--surface);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:.875rem}.namespace-input:focus{outline:none;border-color:var(--primary)}.namespace-select-wrapper{position:relative;display:flex;align-items:center}.namespace-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:.25rem 1.75rem .25rem .5rem;background:var(--surface);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:.875rem;cursor:pointer;max-width:220px}.namespace-select:focus{outline:none;border-color:var(--primary)}.select-chevron{position:absolute;right:.45rem;pointer-events:none;color:var(--text-muted)}.btn-clear-ns{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.2rem;display:flex;align-items:center;border-radius:4px;transition:color .2s}.btn-clear-ns:hover{color:var(--error)}.ns-empty-hint{font-size:.8rem;color:var(--text-muted);font-style:italic}.custom-ns-row{display:flex;align-items:center;gap:.375rem}.btn-ns-confirm{padding:.25rem .625rem;background:var(--primary);color:#fff;border:none;border-radius:6px;font-size:.8rem;cursor:pointer;white-space:nowrap}.btn-ns-confirm:hover{background:var(--primary-hover)}.sidebar{display:flex;flex-direction:column;gap:1rem}.ingest-card,.info-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1.25rem}.card-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;color:var(--primary)}.card-header h2{font-size:1rem;font-weight:600}.input-field{width:100%;padding:.625rem .875rem;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:.875rem;margin-bottom:.75rem;transition:border-color .2s}.input-field:focus{outline:none;border-color:var(--primary)}.input-field::placeholder{color:var(--text-muted)}.btn-primary{width:100%;padding:.625rem;background:var(--primary);color:#fff;border:none;border-radius:8px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:background .2s;font-size:.875rem}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.alert{margin-top:.75rem;padding:.625rem .875rem;border-radius:8px;font-size:.875rem;display:flex;align-items:center;gap:.5rem}.alert.success{background:#22c55e1a;color:var(--success);border:1px solid rgba(34,197,94,.2)}.alert.error{background:#ef44441a;color:var(--error);border:1px solid rgba(239,68,68,.2)}.info-card h3{font-size:.875rem;font-weight:600;margin-bottom:.75rem;color:var(--text-muted)}.info-card ol{padding-left:1.25rem;font-size:.875rem;color:var(--text-muted)}.info-card li{margin-bottom:.5rem}.chat-section{min-height:0}.chat-container{background:var(--surface);border:1px solid var(--border);border-radius:12px;height:calc(100vh - 140px);display:flex;flex-direction:column}.chat-header{padding:1rem 1.25rem;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:.75rem}.chat-header h2{font-size:1rem;font-weight:600}.subtitle{display:block;font-size:.75rem;color:var(--text-muted)}.messages-area{flex:1;overflow-y:auto;padding:1.25rem;display:flex;flex-direction:column;gap:1rem}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-muted);gap:.75rem}.empty-state p{font-size:1rem}.hint{font-size:.875rem;opacity:.7}.message{display:flex;gap:.75rem;max-width:90%;animation:fadeIn .2s ease-out}.message.user{align-self:flex-end;flex-direction:row-reverse}.message.error{align-self:center}.message-avatar{width:32px;height:32px;border-radius:8px;background:var(--bg);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--primary)}.message.user .message-avatar{background:var(--primary);color:#fff}.message-content{background:var(--bg);padding:.875rem 1rem;border-radius:4px 12px 12px;min-width:0}.message.user .message-content{border-top-left-radius:12px;border-top-right-radius:4px;background:var(--primary);color:#fff}.message.error .message-content{background:#ef44441a;color:var(--error);border:1px solid rgba(239,68,68,.2)}.message-text{white-space:pre-wrap;word-break:break-word;font-size:.875rem;line-height:1.6}.citations{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border)}.citations h4{font-size:.75rem;text-transform:uppercase;color:var(--text-muted);margin-bottom:.5rem;letter-spacing:.05em;font-weight:600}.citation{display:flex;align-items:center;gap:.5rem;padding:.375rem .5rem;background:var(--surface);border-radius:6px;margin-bottom:.375rem;font-size:.75rem}.cite-path{color:var(--primary);font-family:SF Mono,Fira Code,monospace;font-size:.75rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cite-lines{color:var(--text-muted);font-family:SF Mono,Fira Code,monospace;flex-shrink:0}.cite-score{margin-left:auto;color:var(--success);font-weight:500;flex-shrink:0}.meta{margin-top:.5rem;display:flex;align-items:center;gap:.25rem;font-size:.75rem;color:var(--text-muted)}.typing-indicator{display:flex;gap:.375rem;padding:.5rem}.typing-indicator span{width:8px;height:8px;background:var(--text-muted);border-radius:50%;animation:bounce 1.4s infinite ease-in-out}.typing-indicator span:nth-child(1){animation-delay:0s}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.chat-input-area{padding:1rem 1.25rem;border-top:1px solid var(--border);display:flex;gap:.75rem}.chat-input{flex:1;padding:.625rem 1rem;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:.875rem;transition:border-color .2s}.chat-input:focus{outline:none;border-color:var(--primary)}.chat-input::placeholder{color:var(--text-muted)}.btn-send{width:40px;height:40px;background:var(--primary);color:#fff;border:none;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s;flex-shrink:0}.btn-send:hover:not(:disabled){background:var(--primary-hover)}.btn-send:disabled{opacity:.6;cursor:not-allowed}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:1024px){.app-main{grid-template-columns:1fr}.chat-container{height:60vh}}@media(max-width:640px){.app-header{padding:1rem}.app-main{padding:1rem;gap:1rem}.message{max-width:100%}}
