:root{--bg: #0d0f14;--surface: rgba(255,255,255,.03);--border: rgba(255,255,255,.08);--accent: #8b5cf6;--accent-glow: rgba(139,92,246,.4);--accent2: #0ea5e9;--text: #e2e8f0;--muted: #94a3b8}*{box-sizing:border-box;margin:0;padding:0}html{background:var(--bg);color:var(--text);font-family:Inter,system-ui,sans-serif;line-height:1.6;height:100%}body{min-height:100vh;display:flex;flex-direction:column}.orbs{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}.orb{position:absolute;border-radius:50%;filter:blur(60px);opacity:.15;will-change:transform;transform:translateZ(0)}.orb-1{width:500px;height:500px;background:radial-gradient(circle,#8b5cf6,transparent 70%);top:-120px;left:-80px;animation:drift 18s ease-in-out infinite alternate}.orb-2{width:400px;height:400px;background:radial-gradient(circle,#0ea5e9,transparent 70%);bottom:-80px;right:-60px;animation:drift 22s ease-in-out infinite alternate-reverse}@keyframes drift{0%{transform:translate(0)}to{transform:translate(30px,20px)}}header{position:sticky;top:0;z-index:100;padding:1rem 2rem;background:#0d0f14d9;backdrop-filter:blur(8px);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.logo{font-weight:700;font-size:1rem;background:linear-gradient(to right,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;text-decoration:none}.by{font-size:.85rem;color:var(--muted)}.by a{color:var(--accent);text-decoration:none}.by a:hover{text-decoration:underline}main{flex:1;z-index:1;position:relative;max-width:760px;margin:0 auto;padding:2.5rem 1.5rem;width:100%;display:flex;flex-direction:column}.hero{text-align:center;margin-bottom:2rem}.badge{display:inline-flex;align-items:center;gap:.4rem;padding:.3rem .9rem;border-radius:2rem;font-size:.8rem;font-weight:600;background:#8b5cf61a;border:1px solid rgba(139,92,246,.3);color:var(--accent);margin-bottom:1rem}h1{font-size:2rem;line-height:1.2;margin-bottom:.5rem;letter-spacing:-.02em}.gradient{background:linear-gradient(to right,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.subtitle{color:var(--muted);font-size:.95rem}.upload-card{background:var(--surface);border:1px solid var(--border);border-radius:1rem;padding:2.5rem 2rem;display:flex;flex-direction:column;align-items:center;contain:layout style paint;transform:translateZ(0)}.drop-zone{width:100%;border:2px dashed var(--border);border-radius:.75rem;padding:2.5rem 1.5rem;text-align:center;cursor:pointer;transition:border-color .2s,background .2s}.drop-zone.dragover{border-color:var(--accent);background:#8b5cf60d}.drop-icon{font-size:2.2rem;margin-bottom:.75rem}.drop-label{font-size:.95rem;color:var(--text);margin-bottom:.35rem}.drop-sub{font-size:.82rem;color:var(--muted)}.drop-sub span{color:var(--accent)}.file-input{display:none}.file-chosen{margin-top:1.25rem;font-size:.88rem;color:var(--muted);display:flex;align-items:center;gap:.5rem;min-height:1.4rem}.file-chosen .file-name{color:var(--text);font-weight:500}.upload-btn{margin-top:1.5rem;padding:.7rem 2rem;background:var(--accent);border:none;border-radius:.6rem;color:#fff;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;opacity:.4;pointer-events:none}.upload-btn.ready{opacity:1;pointer-events:all}.upload-btn.ready:hover{background:#7c3aed;box-shadow:0 0 16px var(--accent-glow)}.upload-status{margin-top:1rem;font-size:.85rem;color:var(--muted);min-height:1.4rem;text-align:center}.upload-status.error{color:#f87171}.upload-status.success{color:#10b981}.chat-card{background:var(--surface);border:1px solid var(--border);border-radius:1rem;display:none;flex-direction:column;height:540px;overflow:hidden;contain:layout style paint;transform:translateZ(0)}.chat-toolbar{display:flex;align-items:center;justify-content:space-between;padding:.9rem 1.2rem;border-bottom:1px solid var(--border);flex-shrink:0}.doc-info{display:flex;align-items:center;gap:.55rem}.doc-icon{font-size:1rem}.doc-name{font-weight:600;font-size:.92rem;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.doc-chunks{font-size:.75rem;color:var(--muted)}.new-doc-btn{background:none;border:1px solid var(--border);color:var(--muted);padding:.35rem .8rem;border-radius:.4rem;font-size:.8rem;cursor:pointer;transition:all .2s}.new-doc-btn:hover{border-color:var(--accent);color:var(--accent)}.messages{flex:1;overflow-y:scroll;padding:1.2rem;display:flex;flex-direction:column;gap:1rem;will-change:scroll-position;overscroll-behavior:contain}.messages::-webkit-scrollbar{width:4px}.messages::-webkit-scrollbar-track{background:transparent}.messages::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.message{display:flex;flex-direction:column;max-width:80%}.message.user{align-self:flex-end;align-items:flex-end}.message.assistant{align-self:flex-start;align-items:flex-start}.bubble{padding:.85rem 1.1rem;border-radius:1rem;font-size:.93rem;line-height:1.7;word-break:break-word}.message.user .bubble{background:var(--accent);color:#fff;border-bottom-right-radius:.25rem}.message.assistant .bubble{background:#ffffff17;border:1px solid rgba(255,255,255,.14);color:var(--text);border-bottom-left-radius:.25rem}.bubble p{margin:0 0 .75rem}.bubble p:last-child{margin-bottom:0}.bubble h1,.bubble h2,.bubble h3{font-size:1rem;font-weight:700;margin:.9rem 0 .4rem;color:var(--text)}.bubble h1:first-child,.bubble h2:first-child,.bubble h3:first-child{margin-top:0}.bubble ul,.bubble ol{padding-left:1.3rem;margin:.5rem 0 .75rem}.bubble li{margin-bottom:.35rem}.bubble li:last-child{margin-bottom:0}.bubble strong{font-weight:700;color:#f1f5f9}.bubble em{font-style:italic;color:var(--muted)}.bubble hr{border:none;border-top:1px solid var(--border);margin:.75rem 0}.bubble code{font-family:Courier New,monospace;font-size:.87em;background:#0000004d;padding:.1em .4em;border-radius:.3rem}.msg-time{font-size:.72rem;color:#475569;margin-top:.3rem;padding:0 .25rem}.sources{margin-top:.4rem;font-size:.8rem;max-width:100%}.sources summary{color:#475569;cursor:pointer;padding:.2rem .25rem;user-select:none}.sources summary:hover{color:var(--accent)}.source-snippet{background:#00000040;border-left:2px solid rgba(139,92,246,.4);padding:.4rem .7rem;margin:.3rem 0;border-radius:.3rem;color:var(--muted);font-style:italic;line-height:1.5}.typing-bubble{display:none;align-self:flex-start;padding:.7rem 1rem;background:#ffffff0f;border:1px solid var(--border);border-radius:1rem 1rem 1rem .25rem}.typing-dots{display:flex;gap:.3rem;align-items:center}.typing-dots span{width:7px;height:7px;border-radius:50%;background:var(--muted);opacity:.4;animation:blink 1.2s ease-in-out infinite}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}@keyframes blink{0%,80%,to{opacity:.4}40%{opacity:1}}.chat-welcome{align-self:center;text-align:center;padding:2rem 1rem;color:var(--muted)}.chat-welcome-icon{font-size:2rem;margin-bottom:.75rem}.chat-welcome p{font-size:.9rem;max-width:320px;margin:0 auto}.chat-welcome strong{color:var(--text)}.q-counter{font-size:.75rem;color:#475569;padding:0 1.2rem .5rem;text-align:right;flex-shrink:0}.q-counter.warning{color:#f59e0b}.limit-banner{display:none;margin:0 1.2rem 1rem;background:#8b5cf614;border:1px solid rgba(139,92,246,.25);border-radius:.75rem;padding:1rem 1.2rem;text-align:center}.limit-banner p{font-size:.88rem;color:var(--muted);margin-bottom:.6rem}.limit-banner a{display:inline-block;padding:.45rem 1.2rem;background:var(--accent);color:#fff;border-radius:.5rem;font-size:.85rem;font-weight:600;text-decoration:none;transition:background .2s}.limit-banner a:hover{background:#7c3aed}.input-bar{padding:1rem 1.2rem;border-top:1px solid var(--border);display:flex;gap:.75rem;align-items:flex-end;flex-shrink:0}.input-wrap{flex:1;position:relative}textarea#msg-input{width:100%;min-height:44px;max-height:120px;resize:none;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none;background:#0000004d;border:1px solid var(--border);border-radius:.6rem;padding:.65rem .9rem;color:var(--text);font-family:inherit;font-size:.93rem;line-height:1.5;transition:border-color .2s}textarea#msg-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #8b5cf61f}textarea#msg-input::placeholder{color:#475569}.send-btn{width:44px;height:44px;flex-shrink:0;background:var(--accent);border:none;border-radius:.6rem;color:#fff;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.send-btn:hover:not(:disabled){background:#7c3aed;box-shadow:0 0 16px var(--accent-glow)}.send-btn:disabled{opacity:.45;cursor:not-allowed}.send-btn svg{width:18px;height:18px}.hint{text-align:center;font-size:.75rem;color:#475569;margin-top:1rem}footer{z-index:1;position:relative;padding:1.5rem 2rem;text-align:center;border-top:1px solid var(--border);font-size:.85rem;color:#475569}footer a{color:var(--accent);text-decoration:none}footer a:hover{text-decoration:underline}@media(max-width:600px){h1{font-size:1.6rem}.chat-card{height:480px}.drop-zone{padding:2rem 1rem}}
