*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-darkest: #111111;--bg-dark: #171717;--bg-medium: #212121;--bg-card: #2f2f2f;--bg-elevated: #303030;--bg-hover: #383838;--blue: #2563eb;--blue-dark: #1d4ed8;--blue-glow: rgba(37, 99, 235, .15);--green: #22c55e;--orange: #f59e0b;--red: #ef4444;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #475569;--border: rgba(255,255,255,.06);--border-blue: rgba(59,130,246,.3);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--font: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--sidebar-w: 270px;--docs-w: 300px}html,body,#root{height:100%;overflow:hidden;font-family:var(--font);background:var(--bg-darkest);color:var(--text-primary);font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg-hover);border-radius:10px}.app-layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--bg-dark);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.sidebar-header{padding:18px 16px 14px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border)}.user-avatar{width:34px;height:34px;background:var(--bg-hover);color:var(--text-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:500;font-size:13px;flex-shrink:0}.user-info{flex:1;min-width:0}.user-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:10px;font-weight:600;letter-spacing:.5px;color:var(--blue);background:var(--blue-glow);padding:1px 6px;border-radius:20px;display:inline-block;margin-top:1px}.sidebar-btn-icon{width:28px;height:28px;border:none;background:var(--bg-hover);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:all .15s}.sidebar-btn-icon:hover{background:var(--bg-elevated);color:var(--text-primary)}.sidebar-scroll{flex:1;overflow-y:auto;padding:12px 8px}.sidebar-section-label{font-size:10px;font-weight:700;letter-spacing:1px;color:var(--text-muted);text-transform:uppercase;padding:8px 8px 4px}.workspace-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-sm);cursor:pointer;transition:background .15s;color:var(--text-secondary);font-size:13px;font-weight:400;margin-bottom:2px}.workspace-item:hover{background:var(--bg-hover);color:var(--text-primary)}.workspace-item.active{background:var(--bg-hover);color:var(--text-primary);font-weight:500}.workspace-icon{font-size:16px}.workspace-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.add-workspace-btn{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:var(--radius-md);cursor:pointer;color:var(--text-muted);font-size:12px;transition:all .15s;border:1px dashed var(--border);margin-bottom:2px}.add-workspace-btn:hover{color:var(--blue);border-color:var(--border-blue)}.sidebar-divider{height:1px;background:var(--border);margin:12px 8px}.chat-history-item{padding:7px 10px;border-radius:var(--radius-md);cursor:pointer;transition:all .15s;color:var(--text-secondary);font-size:12px;display:flex;align-items:center;gap:8px;margin-bottom:1px}.chat-history-item:hover,.chat-history-item.active{background:var(--bg-hover);color:var(--text-primary)}.chat-title{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-date{font-size:10px;color:var(--text-muted);flex-shrink:0}.chat-delete-btn{opacity:0;width:18px;height:18px;background:none;border:none;color:var(--red);cursor:pointer;border-radius:4px;font-size:12px;display:flex;align-items:center;justify-content:center}.chat-history-item:hover .chat-delete-btn{opacity:1}.main-area{flex:1;display:flex;flex-direction:row;overflow:hidden;background:var(--bg-medium)}.info-panel{width:320px;min-width:320px;max-width:320px;border-left:1px solid var(--border);background:var(--bg-dark);display:flex;flex-direction:column;padding:20px 14px;gap:12px;overflow-y:auto}.chat-header{height:54px;display:flex;align-items:center;padding:0 20px;gap:12px;border-bottom:1px solid var(--border);background:var(--bg-dark);flex-shrink:0}.chat-header-title{font-size:15px;font-weight:600;flex:1}.model-chip{display:flex;align-items:center;gap:6px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:20px;padding:4px 10px;font-size:11px;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all .15s}.model-chip:hover{border-color:var(--border-blue);color:var(--text-primary)}.model-dot{width:6px;height:6px;border-radius:50%;background:var(--green);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.header-btn{width:32px;height:32px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;font-size:15px;transition:all .15s}.header-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.messages-area{flex:1;overflow-y:auto;padding:24px 0;display:flex;flex-direction:column;gap:0}.message-group{display:flex;gap:14px;width:100%;max-width:780px;margin:0 auto;padding:8px 24px}.message-group.user{flex-direction:row-reverse;justify-content:flex-start}.message-group.assistant{align-self:flex-start;width:100%}.msg-avatar{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;margin-top:4px}.message-group.user .msg-avatar{background:linear-gradient(135deg,var(--blue),#6366f1);font-weight:700;font-size:11px;color:#fff}.message-group.assistant .msg-avatar{background:var(--bg-elevated);border:1px solid var(--border)}.msg-bubble{border-radius:var(--radius-lg);padding:13px 18px;font-size:15px;line-height:1.75;max-width:100%;min-width:0}.message-group.user .msg-bubble{background:linear-gradient(135deg,var(--blue),var(--blue-dark));color:#fff;border-bottom-right-radius:4px;max-width:600px}.message-group.assistant .msg-bubble{background:transparent;color:var(--text-primary);padding-left:0}.msg-bubble p{margin-bottom:8px}.msg-bubble p:last-child{margin-bottom:0}.msg-content{font-size:15px;line-height:1.8;color:var(--text-primary)}.msg-content p{margin:0 0 10px}.msg-content p:last-child{margin-bottom:0}.msg-content h2,.msg-content h3,.msg-content h4{color:var(--text-primary)}.msg-content ul,.msg-content ol{margin:4px 0 10px}.msg-sources{margin-top:10px;padding-top:10px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:4px}.source-tag{display:inline-flex;align-items:center;gap:5px;font-size:11px;color:var(--blue);background:var(--blue-glow);padding:2px 8px;border-radius:4px;border-left:2px solid var(--blue)}.msg-thinking{font-size:12px;color:var(--text-muted);font-style:italic;display:flex;align-items:center;gap:6px}.thinking-dots span{display:inline-block;width:4px;height:4px;border-radius:50%;background:var(--text-muted);animation:bounce 1.4s infinite both}.thinking-dots span:nth-child(2){animation-delay:.2s}.thinking-dots span:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,80%,to{transform:translateY(0)}40%{transform:translateY(-6px)}}.empty-chat{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-muted);text-align:center;gap:12px}.empty-chat-icon{font-size:48px;opacity:.3}.empty-chat h3{font-size:18px;color:var(--text-secondary)}.input-area{padding:16px 24px 20px;border-top:1px solid var(--border);background:var(--bg-dark)}.input-bar-container{padding:0 0 32px;background:linear-gradient(transparent,var(--bg-medium) 20%)}.input-bar{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-xl);padding:12px 14px;margin:0 auto;max-width:780px;box-shadow:0 4px 20px #0000001a}.input-top{display:flex;align-items:flex-end;gap:8px}.input-field{flex:1;min-height:24px;max-height:200px;background:none;border:none;outline:none;color:var(--text-primary);font-size:15px;font-family:var(--font);resize:none;overflow-y:auto;padding:4px 0;line-height:1.5}.input-field::placeholder{color:var(--text-secondary)}.input-actions{display:flex;align-items:center;gap:6px;padding:8px 12px;border-top:1px solid var(--border)}.input-btn{display:flex;align-items:center;gap:5px;padding:5px 10px;border-radius:var(--radius-sm);background:transparent;border:none;color:var(--text-secondary);cursor:pointer;font-size:13px;font-family:var(--font);transition:all .15s}.input-btn:hover{color:var(--text-primary)}.mic-btn{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:none;cursor:pointer;transition:all .2s;background:transparent;color:var(--text-secondary)}.mic-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.mic-btn.recording{background:#ef444426;color:var(--red);animation:mic-pulse 1.5s infinite}@keyframes mic-pulse{0%,to{box-shadow:0 0 #ef444466}50%{box-shadow:0 0 0 8px #ef444400}}.send-btn{width:32px;height:32px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.send-btn:hover{transform:scale(1.05)}.send-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.docs-panel{width:var(--docs-w);min-width:var(--docs-w);background:var(--bg-dark);border-left:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.docs-header{padding:16px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border)}.docs-title{font-size:13px;font-weight:700}.upload-btn{display:flex;align-items:center;gap:5px;padding:5px 10px;border-radius:var(--radius-sm);background:var(--blue);color:#fff;border:none;font-size:11px;font-weight:600;cursor:pointer;transition:all .15s}.upload-btn:hover{background:var(--blue-dark)}.docs-scroll{flex:1;overflow-y:auto;padding:12px}.docs-section-label{font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:8px 4px 4px;color:var(--text-muted)}.docs-section-label.temp{color:var(--orange)}.doc-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--radius-md);background:var(--bg-card);border:1px solid var(--border);margin-bottom:6px;transition:all .15s}.doc-item:hover{border-color:var(--border-blue)}.doc-icon{font-size:18px;flex-shrink:0}.doc-info{flex:1;min-width:0}.doc-name{font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.doc-meta{font-size:10px;color:var(--text-muted)}.doc-status{font-size:9px;font-weight:700;padding:2px 5px;border-radius:3px;text-transform:uppercase;letter-spacing:.5px}.doc-status.indexed{background:#22c55e26;color:var(--green)}.doc-status.pending{background:#f59e0b26;color:var(--orange)}.doc-ttl{font-size:10px;color:var(--orange);display:flex;align-items:center;gap:3px}.doc-delete-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px;border-radius:3px;opacity:.6;transition:all .15s;font-size:13px}.doc-item:hover .doc-delete-btn{opacity:1}.doc-delete-btn:hover{color:var(--red)}.add-doc-btn{width:100%;padding:10px;border-radius:var(--radius-md);border:1px dashed var(--border);background:none;color:var(--text-muted);cursor:pointer;font-size:12px;font-family:var(--font);transition:all .15s;display:flex;align-items:center;justify-content:center;gap:6px}.add-doc-btn:hover{border-color:var(--border-blue);color:var(--blue)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:24px;max-width:420px;width:100%;box-shadow:0 25px 60px #00000080}.modal-title{font-size:16px;font-weight:700;margin-bottom:6px}.modal-subtitle{font-size:13px;color:var(--text-secondary);margin-bottom:20px}.modal-checkbox{display:flex;align-items:center;gap:10px;padding:12px;background:var(--bg-elevated);border-radius:var(--radius-md);border:1px solid var(--border);cursor:pointer;margin-bottom:20px;font-size:13px;transition:all .15s}.modal-checkbox:hover{border-color:var(--border-blue)}.modal-checkbox input{accent-color:var(--blue);width:16px;height:16px}.modal-actions{display:flex;gap:8px;justify-content:flex-end}.btn{padding:8px 16px;border-radius:var(--radius-md);font-size:13px;font-weight:600;cursor:pointer;font-family:var(--font);transition:all .15s;border:1px solid transparent}.btn-secondary{background:var(--bg-elevated);color:var(--text-secondary);border-color:var(--border)}.btn-secondary:hover{color:var(--text-primary)}.btn-primary{background:linear-gradient(135deg,var(--blue),var(--blue-dark));color:#fff}.btn-primary:hover{opacity:.9}.btn-danger{background:#ef444426;color:var(--red);border-color:#ef44444d}.btn-danger:hover{background:var(--red);color:#fff}.login-page{height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-darkest)}.login-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:40px;width:380px;box-shadow:0 30px 80px #00000080}.login-header{text-align:center;margin-bottom:32px}.login-header h1{font-size:24px;font-weight:700}.login-header p{color:var(--text-secondary);font-size:13px;margin-top:6px}.form-group{margin-bottom:16px}.form-label{display:block;font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:6px;letter-spacing:.3px}.form-input{width:100%;padding:10px 12px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font);font-size:14px;outline:none;transition:border-color .2s}.form-input:focus{border-color:var(--border-blue)}.login-error{color:var(--red);font-size:12px;text-align:center;margin-top:8px}.login-btn{width:100%;padding:12px;background:linear-gradient(135deg,var(--blue),var(--blue-dark));border:none;border-radius:var(--radius-md);color:#fff;font-size:14px;font-weight:600;cursor:pointer;font-family:var(--font);transition:all .2s;margin-top:8px}.login-btn:hover{opacity:.9;transform:translateY(-1px)}.login-btn:active{transform:translateY(0)}.admin-modal{max-width:600px}.admin-tabs{display:flex;gap:4px;margin-bottom:20px;border-bottom:1px solid var(--border);padding-bottom:0}.admin-tab{padding:8px 14px;font-size:13px;font-weight:500;cursor:pointer;color:var(--text-muted);border:none;background:none;font-family:var(--font);border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .15s}.admin-tab.active{color:var(--blue);border-color:var(--blue)}.admin-tab:hover{color:var(--text-primary)}.admin-form-row{display:flex;align-items:center;gap:12px;margin-bottom:14px}.admin-form-row label{font-size:12px;color:var(--text-secondary);width:140px;flex-shrink:0}.admin-form-row input,.admin-form-row select,.admin-form-row textarea{flex:1;padding:8px 10px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font);font-size:13px;outline:none}.admin-form-row textarea{resize:vertical;min-height:80px}.new-chat-btn{margin:16px 16px 8px;padding:10px 12px;background:transparent;color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;font-size:14px;font-weight:500;font-family:var(--font);display:flex;align-items:center;justify-content:space-between;gap:6px;transition:all .15s}.new-chat-btn:hover{background:var(--bg-hover)}@media (max-width: 900px){.docs-panel{display:none}}@media (max-width: 768px){.sidebar{position:absolute;left:0;top:0;bottom:0;z-index:100;transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:none;width:280px;min-width:280px}.sidebar.open{transform:translate(0);box-shadow:4px 0 24px #00000080}.mobile-menu-btn{display:flex}.chat-header{padding:0 12px}.message-group{padding:8px 12px}.input-area{padding:12px}.main-area{flex-direction:column}.info-panel{width:100%;min-width:100%;max-width:100%;border-left:none;border-top:1px solid var(--border);max-height:50vh}}@media (min-width: 769px){.mobile-menu-btn{display:none}}
