*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-base:#0b0a14;--bg-surface:#110f1f;--bg-elevated:#1a1730;--bg-card:#ffffff0a;--bg-glass:#110f1fd1;--border:#ffffff12;--border-hover:#8b5cf659;--accent:#8b5cf6;--accent-2:#a78bfa;--accent-3:#c4b5fd;--accent-glow:#8b5cf659;--accent-glow-sm:#8b5cf62e;--teal:#06b6d4;--teal-glow:#06b6d440;--user-bubble:linear-gradient(135deg, #7c3aed, #a855f7);--bot-bubble:#ffffff0a;--text-primary:#f1f0ff;--text-secondary:#a09ec0;--text-muted:#625f80;--radius-sm:8px;--radius-md:14px;--radius-lg:20px;--radius-xl:28px;--font-body:"Inter", system-ui, sans-serif;--font-display:"Outfit", system-ui, sans-serif;--transition:.2s cubic-bezier(.4, 0, .2, 1);--transition-slow:.4s cubic-bezier(.4, 0, .2, 1)}html,body,#root{height:100%;font-family:var(--font-body);background:var(--bg-base);color:var(--text-primary);-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#8b5cf640;border-radius:99px}::-webkit-scrollbar-thumb:hover{background:#8b5cf673}.app{background:var(--bg-base);height:100vh;display:flex;position:relative;overflow:hidden}.app:before,.app:after{content:"";pointer-events:none;z-index:0;border-radius:50%;position:fixed}.app:before{background:radial-gradient(circle,#8b5cf617,#0000 65%);width:700px;height:700px;top:-250px;left:-200px}.app:after{background:radial-gradient(circle,#06b6d412,#0000 65%);width:600px;height:600px;bottom:-200px;right:-100px}.sidebar-overlay{z-index:9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;animation:.2s fadeIn;display:none;position:fixed;inset:0}.sidebar-overlay.active{display:block}.close-sidebar-btn{color:var(--text-muted);cursor:pointer;transition:var(--transition);background:0 0;border:none;border-radius:6px;margin-left:auto;padding:4px;display:none}.close-sidebar-btn:hover{background:var(--bg-card);color:var(--text-primary)}.sidebar{background:var(--bg-surface);border-right:1px solid var(--border);z-index:10;width:300px;transition:transform var(--transition-slow);flex-direction:column;flex-shrink:0;gap:28px;padding:24px 16px;display:flex;position:relative;overflow:hidden auto}.sidebar-logo{align-items:center;gap:12px;padding:0 8px;display:flex}.logo-icon{width:40px;height:40px;box-shadow:0 0 24px var(--accent-glow);background:linear-gradient(135deg,#7c3aed,#a855f7);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.logo-icon:after{content:"";background:linear-gradient(135deg,#ffffff26,#0000);position:absolute;inset:0}.logo-text{font-family:var(--font-display);letter-spacing:-.5px;background:linear-gradient(90deg,#f1f0ff,#a78bfa);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:20px;font-weight:700}.sidebar-divider{background:var(--border);height:1px;margin:0 8px}.sidebar-section{flex-direction:column;gap:10px;display:flex}.sidebar-label{letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);padding:0 8px;font-size:10.5px;font-weight:600}.upload-zone{border-radius:var(--radius-md);text-align:center;cursor:pointer;transition:var(--transition);background:#8b5cf60a;border:1.5px dashed #8b5cf64d;padding:22px 16px;position:relative;overflow:hidden}.upload-zone:before{content:"";opacity:0;transition:var(--transition);background:linear-gradient(135deg,#8b5cf60f,#0000);position:absolute;inset:0}.upload-zone:hover:before,.upload-zone.drag-over:before{opacity:1}.upload-zone:hover,.upload-zone.drag-over{border-color:var(--accent);box-shadow:0 0 28px #8b5cf626}.upload-zone.uploading{cursor:not-allowed;opacity:.7}.upload-zone.uploading:hover{box-shadow:none;border-color:#8b5cf64d}.upload-zone input[type=file]{opacity:0;cursor:pointer;width:100%;height:100%;position:absolute;inset:0}.upload-zone.uploading input[type=file]{cursor:not-allowed}.upload-icon{color:var(--accent-2);filter:drop-shadow(0 0 8px var(--accent-glow));margin-bottom:10px}.upload-text{color:var(--text-secondary);font-size:13px;line-height:1.5}.upload-text strong{color:var(--text-primary)}.upload-hint{color:var(--text-muted);margin-top:5px;font-size:11px}.upload-status{border-radius:var(--radius-sm);align-items:center;gap:8px;padding:10px 14px;font-size:12.5px;font-weight:500;animation:.25s slideInUp;display:flex}.upload-status.uploading{color:var(--accent-3);background:#8b5cf61f;border:1px solid #8b5cf633}.upload-status.success{color:#4ade80;background:#22c55e1a;border:1px solid #22c55e33}.upload-status.error{color:#f87171;background:#ef44441a;border:1px solid #ef444433}.doc-item{border-radius:var(--radius-sm);background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);word-break:break-all;transition:var(--transition);align-items:center;gap:10px;padding:10px 12px;font-size:12.5px;line-height:1.4;animation:.3s slideInUp;display:flex}.doc-item:hover{border-color:var(--border-hover);background:#8b5cf60f}.doc-item svg{color:var(--accent-2);flex-shrink:0}.sidebar-footer{flex-direction:column;gap:10px;margin-top:auto;padding:0 8px;display:flex}.tech-label{letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);font-size:10px;font-weight:600}.tech-badges{flex-wrap:wrap;gap:6px;display:flex}.tech-badge{border:1px solid var(--border);color:var(--text-muted);background:var(--bg-card);transition:var(--transition);border-radius:99px;padding:4px 9px;font-size:10.5px;font-weight:500}.tech-badge:hover{border-color:var(--border-hover);color:var(--accent-3)}.chat-area{z-index:1;flex-direction:column;flex:1;min-width:0;display:flex;position:relative}.chat-header{border-bottom:1px solid var(--border);background:var(--bg-glass);-webkit-backdrop-filter:blur(20px);z-index:2;align-items:center;gap:14px;padding:18px 28px;display:flex;position:relative}.menu-btn{color:var(--text-secondary);cursor:pointer;transition:var(--transition);background:0 0;border:none;border-radius:6px;flex-shrink:0;padding:4px;display:none}.menu-btn:hover{color:var(--text-primary);background:var(--bg-card)}.header-avatar{width:40px;height:40px;box-shadow:0 0 20px var(--accent-glow);background:linear-gradient(135deg,#7c3aed,#a855f7);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.header-info{flex:1;min-width:0}.header-title{font-family:var(--font-display);letter-spacing:-.3px;font-size:16px;font-weight:700}.header-sub{color:var(--text-muted);align-items:center;gap:6px;margin-top:2px;font-size:12px;display:flex}.status-dot{background:#4ade80;border-radius:50%;flex-shrink:0;width:7px;height:7px;animation:2s infinite pulse-dot;box-shadow:0 0 8px #4ade80}@keyframes pulse-dot{0%,to{opacity:1;box-shadow:0 0 8px #4ade80}50%{opacity:.5;box-shadow:0 0 3px #4ade80}}.header-badges{flex-shrink:0;gap:6px;display:flex}.header-badge{letter-spacing:.03em;border:1px solid;border-radius:99px;padding:4px 10px;font-size:10.5px;font-weight:600}.hb-purple{color:var(--accent-2);background:#8b5cf61a;border-color:#8b5cf666}.hb-teal{color:var(--teal);background:#06b6d41a;border-color:#06b6d466}.messages-container{flex-direction:column;flex:1;gap:20px;padding:32px 32px 16px;display:flex;overflow-y:auto}.welcome-screen{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:18px;padding:40px 20px;animation:.6s fadeIn;display:flex}.welcome-glow-ring{margin-bottom:4px;position:relative}.welcome-icon{z-index:1;background:linear-gradient(135deg,#7c3aed,#a855f7);border-radius:28px;justify-content:center;align-items:center;width:88px;height:88px;display:flex;position:relative;box-shadow:0 0 60px #8b5cf680,0 0 120px #8b5cf633}.welcome-icon:before{content:"";border:1px solid #8b5cf633;border-radius:38px;animation:3s ease-in-out infinite ring-pulse;position:absolute;inset:-12px}.welcome-icon:after{content:"";border:1px solid #8b5cf61a;border-radius:50px;animation:3s ease-in-out .5s infinite ring-pulse;position:absolute;inset:-24px}@keyframes ring-pulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.04)}}.welcome-title{font-family:var(--font-display);letter-spacing:-.8px;background:linear-gradient(135deg,#f1f0ff,#a78bfa,#c4b5fd);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:28px;font-weight:800;line-height:1.2}.welcome-sub{color:var(--text-secondary);max-width:440px;font-size:15px;line-height:1.7}.welcome-features{flex-wrap:wrap;justify-content:center;gap:12px;margin:4px 0;display:flex}.feat-pill{background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);transition:var(--transition);border-radius:99px;align-items:center;gap:7px;padding:7px 14px;font-size:12.5px;display:flex}.feat-pill:hover{border-color:var(--border-hover);color:var(--accent-3)}.feat-pill svg{color:var(--accent-2);flex-shrink:0}.suggestion-chips{flex-wrap:wrap;justify-content:center;gap:8px;margin-top:4px;display:flex}.chip{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;background:var(--bg-card);transition:var(--transition);font-size:13px;font-family:var(--font-body);border-radius:99px;padding:9px 18px}.chip:hover{border-color:var(--accent);color:var(--text-primary);background:#8b5cf61a;transform:translateY(-2px);box-shadow:0 4px 20px #8b5cf633}.message{gap:12px;max-width:820px;animation:.3s slideInUp;display:flex}.message.user{flex-direction:row-reverse;align-self:flex-end}.message.bot{align-self:flex-start}.msg-avatar{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;margin-top:2px;display:flex}.msg-avatar.user{box-shadow:0 0 14px var(--accent-glow);background:linear-gradient(135deg,#7c3aed,#a855f7)}.msg-avatar.bot{background:var(--bg-elevated);border:1px solid var(--border)}.msg-content{flex-direction:column;gap:5px;max-width:calc(100% - 48px);display:flex}.msg-bubble{border-radius:var(--radius-md);word-break:break-word;padding:13px 18px;font-size:14px;line-height:1.75}.message.user .msg-bubble{color:#fff;background:linear-gradient(135deg,#7c3aed,#a855f7);border-bottom-right-radius:4px;box-shadow:0 6px 28px #8b5cf666}.message.bot .msg-bubble{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border);border-bottom-left-radius:4px}.msg-time{color:var(--text-muted);padding:0 4px;font-size:10.5px}.message.user .msg-time{text-align:right}.markdown-body{overflow-wrap:anywhere;width:100%}.markdown-body>:first-child{margin-top:0}.markdown-body>:last-child{margin-bottom:0}.msg-bubble p{margin-bottom:10px}.msg-bubble p:last-child{margin-bottom:0}.msg-bubble code{color:var(--accent-3);background:#8b5cf61f;border:1px solid #8b5cf633;border-radius:5px;padding:2px 7px;font-family:Fira Code,Cascadia Code,monospace;font-size:12.5px}.msg-bubble pre{border:1px solid var(--border);border-radius:var(--radius-sm);background:#0000004d;margin:10px 0;padding:14px;overflow-x:auto}.msg-bubble pre code{color:var(--text-secondary);background:0 0;border:none;padding:0;font-size:13px}.msg-bubble ul,.msg-bubble ol{margin:6px 0;padding-left:20px}.msg-bubble li{margin-bottom:4px}.msg-bubble strong{color:var(--text-primary);font-weight:600}.msg-bubble h1,.msg-bubble h2,.msg-bubble h3{font-family:var(--font-display);margin:10px 0 6px}.msg-bubble h4,.msg-bubble h5,.msg-bubble h6{margin:8px 0 6px}.msg-bubble a{color:#93c5fd;text-underline-offset:3px;text-decoration:underline}.msg-bubble a:hover{color:#bfdbfe}.msg-bubble blockquote{border-left:3px solid var(--accent-2);color:var(--text-secondary);background:#8b5cf614;border-radius:8px;margin:10px 0;padding:8px 12px}.msg-bubble hr{border:none;border-top:1px solid var(--border);margin:12px 0}.msg-bubble table{border-collapse:collapse;width:100%;margin:10px 0;font-size:13px;display:block;overflow-x:auto}.msg-bubble thead{background:#8b5cf61f}.msg-bubble th,.msg-bubble td{border:1px solid var(--border);text-align:left;vertical-align:top;padding:8px 10px}.typing-bubble{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);border-bottom-left-radius:4px;align-items:center;gap:5px;padding:14px 18px;display:flex}.dot{background:var(--accent);border-radius:50%;width:7px;height:7px;animation:1.4s infinite bounce}.dot:nth-child(2){animation-delay:.2s}.dot:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,80%,to{opacity:.35;transform:translateY(0)}40%{opacity:1;transform:translateY(-7px)}}.input-area{background:var(--bg-glass);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border);padding:16px 32px 28px}.input-bar{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);transition:var(--transition);align-items:flex-end;gap:10px;padding:10px 10px 10px 20px;display:flex}.input-bar:focus-within{border-color:#8b5cf680;box-shadow:0 0 0 3px #8b5cf61f,0 0 30px #8b5cf61a}.msg-input{color:var(--text-primary);font-family:var(--font-body);resize:none;background:0 0;border:none;outline:none;flex:1;max-height:160px;padding:4px 0;font-size:14px;line-height:1.6}.msg-input::placeholder{color:var(--text-muted)}.send-btn{border-radius:var(--radius-sm);cursor:pointer;color:#fff;width:40px;height:40px;transition:var(--transition);background:linear-gradient(135deg,#7c3aed,#a855f7);border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex;box-shadow:0 4px 16px #8b5cf659}.send-btn:hover:not(:disabled){transform:scale(1.07)translateY(-1px);box-shadow:0 6px 24px #8b5cf68c}.send-btn:disabled{opacity:.35;cursor:not-allowed;box-shadow:none}.input-hint{text-align:center;color:var(--text-muted);margin-top:10px;font-size:11px}.toast-popup{background:var(--bg-elevated);color:#f1f0ff;border-radius:var(--radius-md);z-index:100;border:1px solid #ef44444d;align-items:center;gap:10px;padding:12px 20px;font-size:14px;font-weight:500;animation:.4s cubic-bezier(.175,.885,.32,1.275) slideInDownToast;display:flex;position:fixed;top:40px;left:50%;transform:translate(-50%);box-shadow:0 10px 40px #00000080}@keyframes slideInDownToast{0%{opacity:0;transform:translate(-50%,-20px)}to{opacity:1;transform:translate(-50%)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=900px){.header-badges{display:none}}@media (width<=768px){.sidebar{z-index:10;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%);box-shadow:4px 0 40px #00000080}.sidebar.open{transform:translate(0)}.menu-btn,.close-sidebar-btn{display:flex}.messages-container{padding:20px 16px 12px}.input-area{padding:12px 16px 20px}.chat-header{padding:14px 16px}.welcome-title{font-size:22px}.welcome-sub{font-size:14px}.welcome-features{gap:8px}.welcome-icon{border-radius:22px;width:72px;height:72px}}@media (width<=480px){.header-badge{display:none}.chip{padding:7px 14px;font-size:12px}}
