@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--bg-primary:#212121;--bg-secondary:#171717;--bg-tertiary:#2f2f2f;--bg-elevated:#2f2f2f;--bg-hover:#383838;--glass-bg:#212121d9;--glass-border:#ffffff1a;--glass-hover:#ffffff26;--accent-primary:#ececec;--accent-secondary:#d9d9d9;--accent-hover:#fff;--accent-glow:#ffffff0d;--accent-gradient:#ececec;--text-primary:#ececec;--text-secondary:#b4b4b4;--text-tertiary:#888;--text-accent:#ececec;--status-success:#34d399;--status-success-bg:#34d3991a;--status-warning:#fbbf24;--status-warning-bg:#fbbf241a;--status-error:#f87171;--status-error-bg:#f871711a;--status-processing:#60a5fa;--status-processing-bg:#60a5fa1a;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--font-family:"Inter", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;--font-size-xs:.75rem;--font-size-sm:.8125rem;--font-size-base:.875rem;--font-size-md:1rem;--font-size-lg:1.125rem;--font-size-xl:1.5rem;--font-size-2xl:2rem;--font-size-3xl:2.5rem;--shadow-sm:0 2px 8px #0000004d;--shadow-md:0 4px 20px #0006;--shadow-lg:0 8px 40px #00000080;--shadow-glow:0 0 30px var(--accent-glow);--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.4s cubic-bezier(.4, 0, .2, 1);--sidebar-width:320px;--header-height:64px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-family);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.6;overflow:hidden}#root{flex-direction:column;min-height:100vh;display:flex}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--bg-elevated);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.glass{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border)}.gradient-text{background:var(--accent-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes gradientShift{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}@keyframes borderGlow{0%,to{border-color:#fff3}50%{border-color:#ffffff80}}@keyframes typingDot{0%,to{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1)}}.app-layout{background:var(--bg-primary);width:100vw;height:100vh;display:flex;overflow:hidden}.app-layout:before{display:none}.header{height:var(--header-height);padding:0 var(--space-lg);border-bottom:1px solid var(--glass-border);background:var(--bg-primary);z-index:100;justify-content:space-between;align-items:center;display:flex;position:relative}.header-logo{align-items:center;gap:var(--space-md);display:flex}.header-logo-icon{border-radius:var(--radius-md);background:var(--text-primary);width:36px;height:36px;color:var(--bg-primary);justify-content:center;align-items:center;font-size:18px;display:flex}.header-title{font-size:var(--font-size-lg);letter-spacing:-.02em;font-weight:700}.header-subtitle{font-size:var(--font-size-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em;font-weight:500}.header-status{align-items:center;gap:var(--space-sm);font-size:var(--font-size-sm);color:var(--text-secondary);display:flex}.header-status-dot{background:var(--status-success);width:8px;height:8px;box-shadow:0 0 8px var(--status-success);border-radius:50%}.header-status-dot.disconnected{background:var(--status-error);box-shadow:0 0 8px var(--status-error)}.sidebar{width:var(--sidebar-width);border-right:1px solid var(--glass-border);background:var(--bg-secondary);z-index:10;flex-direction:column;flex-shrink:0;height:100%;display:flex;position:relative}.sidebar-header{padding:var(--space-lg);border-bottom:1px solid var(--glass-border)}.sidebar-title{font-size:var(--font-size-sm);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--space-md);font-weight:600}.upload-btn{width:100%;padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);border:1px dashed var(--glass-border);background:var(--bg-tertiary);color:var(--text-secondary);font-family:var(--font-family);font-size:var(--font-size-base);cursor:pointer;transition:all var(--transition-base);justify-content:center;align-items:center;gap:var(--space-sm);font-weight:500;display:flex}.upload-btn:hover{background:var(--bg-hover);border-color:var(--accent-primary);color:var(--text-primary);box-shadow:var(--shadow-glow)}.sidebar-list{padding:var(--space-md);flex:1;overflow-y:auto}.doc-card{padding:var(--space-md);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);margin-bottom:var(--space-sm);border:1px solid #0000;animation:.3s fadeIn}.doc-card:hover{background:var(--bg-hover);border-color:var(--glass-border)}.doc-card.active{background:var(--bg-elevated);border-color:var(--accent-primary);box-shadow:inset 0 0 0 1px #ffffff1a}.doc-card-name{font-size:var(--font-size-base);color:var(--text-primary);margin-bottom:var(--space-xs);text-overflow:ellipsis;white-space:nowrap;font-weight:600;overflow:hidden}.doc-card-meta{align-items:center;gap:var(--space-sm);font-size:var(--font-size-xs);color:var(--text-tertiary);display:flex}.doc-card-status{border-radius:var(--radius-full);font-size:var(--font-size-xs);align-items:center;gap:4px;padding:2px 8px;font-weight:500;display:inline-flex}.doc-card-status.ready{background:var(--status-success-bg);color:var(--status-success)}.doc-card-status.processing{background:var(--status-processing-bg);color:var(--status-processing);animation:1.5s infinite pulse}.doc-card-status.error{background:var(--status-error-bg);color:var(--status-error)}.doc-card-actions{gap:var(--space-xs);margin-top:var(--space-sm);display:flex}.doc-card-delete{border-radius:var(--radius-sm);background:var(--status-error-bg);color:var(--status-error);font-size:var(--font-size-xs);font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast);opacity:0;border:none;padding:4px 10px}.doc-card:hover .doc-card-delete{opacity:1}.doc-card-delete:hover{background:#f8717133}.main-content{z-index:1;flex-direction:column;flex:1;min-width:0;height:100%;display:flex;position:relative}.chat-area{flex-direction:column;flex:1;display:flex;overflow:hidden}.chat-messages{padding:var(--space-xl) var(--space-2xl);gap:var(--space-lg);flex-direction:column;flex:1;display:flex;overflow-y:auto}.empty-state{text-align:center;padding:var(--space-2xl);flex-direction:column;flex:1;justify-content:center;align-items:center;animation:.6s fadeIn;display:flex}.empty-state-icon{margin-bottom:var(--space-lg);font-size:64px;animation:3s ease-in-out infinite float}.empty-state-title{font-size:var(--font-size-2xl);margin-bottom:var(--space-md);letter-spacing:-.03em;font-weight:800}.empty-state-description{font-size:var(--font-size-base);color:var(--text-secondary);max-width:500px;line-height:1.7}.empty-state-steps{gap:var(--space-xl);margin-top:var(--space-2xl);display:flex}.empty-state-step{align-items:center;gap:var(--space-sm);padding:var(--space-lg);border-radius:var(--radius-lg);background:var(--glass-bg);border:1px solid var(--glass-border);width:160px;transition:all var(--transition-base);flex-direction:column;display:flex}.empty-state-step:hover{border-color:var(--glass-hover);box-shadow:var(--shadow-md);transform:translateY(-4px)}.empty-state-step-icon{font-size:28px}.empty-state-step-label{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:500}.message{gap:var(--space-md);max-width:85%;animation:.3s slideInUp;display:flex}.message.user{flex-direction:row-reverse;align-self:flex-end}.message.ai{align-self:flex-start}.message-avatar{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;display:flex}.message.user .message-avatar{background:var(--bg-tertiary);color:var(--text-primary)}.message.ai .message-avatar{background:var(--bg-elevated);border:1px solid var(--glass-border)}.message-content{padding:var(--space-md) var(--space-lg);border-radius:var(--radius-lg);font-size:var(--font-size-base);line-height:1.7}.message.user .message-content{background:var(--bg-tertiary);color:var(--text-primary);border-bottom-right-radius:var(--space-xs)}.message.ai .message-content{background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--text-primary);border-bottom-left-radius:var(--space-xs)}.message-text{white-space:pre-wrap;word-break:break-word}.message-text p{margin-bottom:var(--space-sm)}.message-text p:last-child{margin-bottom:0}.message-text ul,.message-text ol{padding-left:var(--space-lg);margin-bottom:var(--space-sm)}.message-text li{margin-bottom:var(--space-xs)}.message-sources{margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--glass-border)}.sources-toggle{align-items:center;gap:var(--space-sm);color:var(--text-accent);font-family:var(--font-family);font-size:var(--font-size-xs);cursor:pointer;padding:var(--space-xs) 0;transition:color var(--transition-fast);background:0 0;border:none;font-weight:500;display:flex}.sources-toggle:hover{color:var(--accent-secondary)}.sources-list{margin-top:var(--space-sm);gap:var(--space-sm);flex-direction:column;display:flex}.source-item{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);font-size:var(--font-size-xs);color:var(--text-secondary);background:#0003;border:1px solid #ffffff14;line-height:1.5}.source-item-header{margin-bottom:var(--space-xs);color:var(--text-accent);justify-content:space-between;font-weight:600;display:flex}.source-item-score{color:var(--status-success)}.typing-indicator{gap:var(--space-md);align-self:flex-start;animation:.3s fadeIn;display:flex}.typing-dots{padding:var(--space-md) var(--space-lg);border-radius:var(--radius-lg);background:var(--glass-bg);border:1px solid var(--glass-border);border-bottom-left-radius:var(--space-xs);align-items:center;gap:5px;display:flex}.typing-dot{background:var(--accent-secondary);border-radius:50%;width:8px;height:8px;animation:1.4s ease-in-out infinite typingDot}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}.chat-input-container{padding:var(--space-lg) var(--space-2xl) var(--space-xl);background:linear-gradient(to top, var(--bg-primary) 60%, transparent);position:relative}.chat-input-wrapper{align-items:flex-end;gap:var(--space-md);padding:var(--space-md);border-radius:var(--radius-lg);background:var(--glass-bg);border:1px solid var(--glass-border);transition:border-color var(--transition-base), box-shadow var(--transition-base);display:flex}.chat-input-wrapper:focus-within{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-glow)}.chat-input{color:var(--text-primary);font-family:var(--font-family);font-size:var(--font-size-base);resize:none;background:0 0;border:none;outline:none;flex:1;min-height:24px;max-height:120px;line-height:1.5}.chat-input::placeholder{color:var(--text-tertiary)}.chat-send-btn{border-radius:var(--radius-md);background:var(--text-primary);width:40px;height:40px;color:var(--bg-primary);cursor:pointer;transition:all var(--transition-base);border:none;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;display:flex}.chat-send-btn:hover:not(:disabled){box-shadow:var(--shadow-glow);transform:scale(1.05)}.chat-send-btn:disabled{opacity:.4;cursor:not-allowed}.chat-input-hint{text-align:center;font-size:var(--font-size-xs);color:var(--text-tertiary);margin-top:var(--space-sm)}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background:#000000b3;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-content{border-radius:var(--radius-xl);background:var(--bg-secondary);border:1px solid var(--glass-border);width:90%;max-width:520px;padding:var(--space-2xl);box-shadow:var(--shadow-lg);animation:.3s slideInUp}.modal-title{font-size:var(--font-size-xl);margin-bottom:var(--space-lg);letter-spacing:-.02em;font-weight:700}.modal-close{top:var(--space-lg);right:var(--space-lg);color:var(--text-tertiary);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;font-size:20px;position:absolute}.modal-close:hover{color:var(--text-primary)}.drop-zone{border:2px dashed var(--glass-border);border-radius:var(--radius-lg);padding:var(--space-2xl) var(--space-xl);text-align:center;cursor:pointer;transition:all var(--transition-base);position:relative;overflow:hidden}.drop-zone:before{content:"";background:var(--text-primary);opacity:0;transition:opacity var(--transition-base);position:absolute;inset:0}.drop-zone:hover,.drop-zone.dragging{border-color:var(--accent-primary);background:#ffffff0d}.drop-zone.dragging:before{opacity:.05}.drop-zone:hover{animation:2s infinite borderGlow}.drop-zone-icon{margin-bottom:var(--space-md);z-index:1;font-size:48px;position:relative}.drop-zone-text{font-size:var(--font-size-base);color:var(--text-secondary);margin-bottom:var(--space-xs);z-index:1;position:relative}.drop-zone-hint{font-size:var(--font-size-xs);color:var(--text-tertiary);z-index:1;position:relative}.upload-progress{margin-top:var(--space-lg)}.upload-file-info{align-items:center;gap:var(--space-md);padding:var(--space-md);border-radius:var(--radius-md);background:var(--bg-tertiary);margin-bottom:var(--space-md);display:flex}.upload-file-icon{font-size:24px}.upload-file-name{font-size:var(--font-size-sm);text-overflow:ellipsis;white-space:nowrap;flex:1;font-weight:500;overflow:hidden}.upload-file-size{font-size:var(--font-size-xs);color:var(--text-tertiary)}.progress-bar{border-radius:var(--radius-full);background:var(--bg-tertiary);width:100%;height:4px;overflow:hidden}.progress-bar-fill{border-radius:var(--radius-full);background:var(--text-primary);height:100%;transition:width var(--transition-slow)}.upload-status-text{font-size:var(--font-size-xs);color:var(--text-secondary);margin-top:var(--space-sm);text-align:center}.select-doc-state{text-align:center;padding:var(--space-2xl);flex-direction:column;flex:1;justify-content:center;align-items:center;animation:.6s fadeIn;display:flex}.select-doc-icon{margin-bottom:var(--space-lg);opacity:.6;font-size:48px}.select-doc-text{font-size:var(--font-size-md);color:var(--text-secondary)}@media (width<=768px){:root{--sidebar-width:260px}.chat-messages,.chat-input-container{padding:var(--space-md)}.empty-state-steps{flex-direction:column}.message{max-width:95%}}
