.rag-demo{max-width:1200px;margin:0 auto;padding:2rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.rag-header{text-align:center;margin-bottom:3rem}.rag-header h1{font-size:2.5rem;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:.5rem}.subtitle{color:#666;font-size:1.1rem}.query-form{display:flex;gap:1rem;margin-bottom:2rem}.query-input{flex:1;padding:1rem 1.5rem;font-size:1.1rem;border:2px solid #e0e0e0;border-radius:12px;transition:all .3s ease}.query-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.submit-btn{padding:1rem 2.5rem;font-size:1.1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;cursor:pointer;transition:all .3s ease}.submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #667eea4d}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.answer-section,.sources-section,.metadata-section{background:#fff;border-radius:16px;padding:2rem;margin-bottom:2rem;box-shadow:0 4px 6px #00000012}.answer-section h3,.sources-section h3,.metadata-section h3{margin-top:0;margin-bottom:1.5rem;font-size:1.3rem;color:#333}.answer-content{font-size:1.1rem;line-height:1.8;color:#444;max-height:500px;overflow-y:auto;white-space:pre-wrap}.cursor{animation:blink 1s infinite;color:#667eea;font-weight:700}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.sources-list{display:flex;flex-direction:column;gap:1.5rem}.source-item{border-left:4px solid #667eea;padding:1rem 1.5rem;background:#f8f9ff;border-radius:8px}.source-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem;flex-wrap:wrap}.source-number{background:#667eea;color:#fff;padding:.25rem .75rem;border-radius:6px;font-weight:600;font-size:.9rem}.source-title{font-weight:600;color:#333;flex:1;min-width:200px}.source-section{background:#e0e7ff;padding:.25rem .75rem;border-radius:6px;font-size:.9rem;color:#4c51bf}.source-content{color:#555;line-height:1.6;margin-bottom:.75rem}.source-meta{font-size:.9rem;color:#888}.metadata-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.metric{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);border-radius:12px}.metric-label{font-size:.9rem;color:#666;text-transform:uppercase;letter-spacing:.5px}.metric-value{font-size:1.5rem;font-weight:700;color:#333}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-thumb{background-color:#0003;border-radius:4px}::-webkit-scrollbar-thumb:hover{background-color:#0000004d}::-webkit-scrollbar-track{background-color:transparent}.markdown-content{line-height:1.6}.markdown-content p{margin:0 0 12px}.markdown-content p:last-child{margin-bottom:0}.markdown-content ul,.markdown-content ol{margin:8px 0;padding-left:24px}.markdown-content li{margin:4px 0}.markdown-content li>ul,.markdown-content li>ol{margin:4px 0}.markdown-content code{background-color:#0000000f;padding:2px 6px;border-radius:4px;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:.9em}.markdown-content pre{background-color:#0000000f;padding:12px;border-radius:6px;overflow-x:auto;margin:12px 0}.markdown-content pre code{background-color:transparent;padding:0}.markdown-content blockquote{border-left:4px solid #d9d9d9;padding-left:12px;margin:12px 0;color:#666}.markdown-content table{border-collapse:collapse;width:100%;margin:12px 0}.markdown-content th,.markdown-content td{border:1px solid #d9d9d9;padding:8px 12px;text-align:left}.markdown-content th{background-color:#0000000a}.markdown-content h1,.markdown-content h2,.markdown-content h3,.markdown-content h4{margin:16px 0 8px;font-weight:600}.markdown-content h1:first-child,.markdown-content h2:first-child,.markdown-content h3:first-child{margin-top:0}.markdown-content a{color:#1890ff;text-decoration:none}.markdown-content a:hover{text-decoration:underline}.markdown-content strong{font-weight:600}
