:root{--bg: #0f1115;--bg-elev: #161922;--bg-elev-2: #1d2230;--border: #2a3142;--text: #e5e7eb;--text-dim: #9aa3b2;--accent: #6aa3ff;--accent-2: #8b5cf6;--danger: #ef4444;--good: #22c55e;--radius: 8px;--mono: ui-monospace, SFMono-Regular, "JetBrains Mono", Consolas, monospace;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color-scheme:dark}*{box-sizing:border-box}html,body{margin:0;padding:0;height:100%;background:var(--bg);color:var(--text);overflow:hidden}#app{display:grid;grid-template-columns:260px 1fr;grid-template-rows:100dvh;height:100dvh;position:relative;overflow:hidden}#model-pill{position:absolute;top:18px;right:64px;z-index:30;background:var(--bg-elev);border:1px solid var(--border);border-radius:999px;padding:4px 28px 4px 10px;font-size:12px;font-family:var(--mono);color:var(--text-dim);cursor:pointer;max-width:320px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path fill='none' stroke='%23888' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round' d='M1 1l4 4 4-4'/></svg>");background-repeat:no-repeat;background-position:right 10px center}#model-pill:hover{color:var(--text);border-color:var(--accent)}#model-pill.empty{color:var(--danger);border-color:var(--danger)}#model-pill option{font-family:var(--mono);font-size:12px;background:var(--bg-elev);color:var(--text)}#settings-gear{position:absolute;top:14px;right:16px;width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;background:var(--bg-elev);color:var(--text-dim);border:1px solid var(--border);border-radius:50%;cursor:pointer;z-index:30;transition:color .15s,border-color .15s,transform .2s}#settings-gear:hover{color:var(--accent);border-color:var(--accent);transform:rotate(45deg)}#settings-gear.active{color:var(--accent);border-color:var(--accent)}#sidebar{background:var(--bg-elev);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:12px;gap:8px;min-height:0;min-width:0;overflow:hidden}.brand{font-weight:700;font-size:16px;letter-spacing:.2px;padding:8px 6px 12px;border-bottom:1px solid var(--border);margin-bottom:8px}#project-bar{border-bottom:1px solid var(--border);padding-bottom:10px;margin-bottom:4px}#project-bar label{display:block;font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-dim);padding:0 4px 6px}#project-bar select{background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);padding:6px 8px;font:inherit;font-size:13px}#project-bar button{background:var(--bg-elev-2);color:var(--text-dim);border:1px solid var(--border);border-radius:var(--radius);padding:0 8px;cursor:pointer;font-size:14px;line-height:1;min-width:26px}#project-bar button:hover{color:var(--text)}#project-bar button#project-del:hover{color:var(--danger);border-color:var(--danger)}nav{display:flex;flex-direction:column;gap:4px}.nav-btn{background:transparent;color:var(--text-dim);border:1px solid transparent;padding:8px 10px;text-align:left;border-radius:var(--radius);cursor:pointer;font-size:14px}.nav-btn:hover{background:var(--bg-elev-2);color:var(--text)}.nav-btn.active{background:var(--bg-elev-2);color:var(--text);border-color:var(--border)}#history{flex:1;min-height:0;overflow-y:scroll;margin-top:10px;border-top:1px solid var(--border);padding-top:10px;display:flex;flex-direction:column;gap:2px;scrollbar-width:thin;scrollbar-color:var(--border) transparent}#history::-webkit-scrollbar{width:10px}#history::-webkit-scrollbar-track{background:transparent}#history::-webkit-scrollbar-thumb{background:var(--border);border-radius:5px;border:2px solid var(--bg-elev)}#history::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}#history .chat-row{display:flex;align-items:stretch;gap:2px;border-radius:var(--radius)}#history .chat-row.active,#history .chat-row:hover{background:var(--bg-elev-2)}#history .chat-link{flex:1;min-width:0;background:transparent;border:none;color:var(--text-dim);padding:6px 8px;border-radius:var(--radius);font-size:13px;text-align:left;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}#history .chat-row.active .chat-link,#history .chat-row:hover .chat-link{color:var(--text)}#history .chat-del{background:transparent;border:none;color:var(--text-dim);padding:0 8px;font-size:14px;line-height:1;cursor:pointer;border-radius:var(--radius);visibility:hidden}#history .chat-row:hover .chat-del,#history .chat-row.active .chat-del{visibility:visible}#history .chat-del:hover{color:var(--danger)}#new-chat{background:var(--accent);color:#0a0e17;border:none;padding:8px 10px;border-radius:var(--radius);cursor:pointer;font-weight:600;flex-shrink:0}#main{overflow:hidden;display:flex;flex-direction:column;min-height:0;min-width:0}.chat-view{display:flex;flex-direction:column;height:100%}.chat-messages{flex:1;min-height:0;overflow-y:scroll;padding:24px 32px;display:flex;flex-direction:column;gap:18px;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.chat-messages::-webkit-scrollbar{width:12px}.chat-messages::-webkit-scrollbar-track{background:transparent}.chat-messages::-webkit-scrollbar-thumb{background:var(--border);border-radius:6px;border:3px solid var(--bg)}.chat-messages::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}.msg{max-width:820px;width:100%;margin:0 auto;display:flex;flex-direction:column;gap:6px}.msg .role{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-dim);display:flex;align-items:center;gap:8px}.msg.user .role{color:var(--accent)}.msg .role .model-tag{font-size:10px;font-family:var(--mono);font-weight:500;letter-spacing:0;text-transform:none;color:var(--text-dim);background:var(--bg-elev-2);border:1px solid var(--border);border-radius:4px;padding:1px 6px;max-width:360px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.msg .body{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;white-space:pre-wrap;word-wrap:break-word;line-height:1.5}.msg .body.markdown{white-space:normal}.msg .body.markdown>:first-child{margin-top:0}.msg .body.markdown>:last-child{margin-bottom:0}.msg .body.markdown p,.msg .body.markdown ul,.msg .body.markdown ol,.msg .body.markdown blockquote{margin:.6em 0}.msg .body.markdown h1,.msg .body.markdown h2,.msg .body.markdown h3,.msg .body.markdown h4{margin:1em 0 .4em;font-weight:600;line-height:1.25}.msg .body.markdown h1{font-size:1.4em}.msg .body.markdown h2{font-size:1.2em}.msg .body.markdown h3{font-size:1.05em}.msg .body.markdown h4{font-size:1em}.msg .body.markdown ul,.msg .body.markdown ol{padding-left:1.5em}.msg .body.markdown li+li{margin-top:.25em}.msg .body.markdown blockquote{border-left:3px solid var(--border);padding:2px 12px;color:var(--text-dim)}.msg .body.markdown code{background:var(--bg-elev-2);padding:1px 5px;border-radius:4px;font-size:.92em}.msg .body.markdown pre{background:var(--bg-elev-2);border:1px solid var(--border);border-radius:var(--radius);padding:10px 12px;overflow-x:auto;font-size:.92em;line-height:1.45}.msg .body.markdown pre code{background:transparent;padding:0;border-radius:0;font-size:1em}.msg .body.markdown table{border-collapse:collapse;margin:.6em 0;font-size:.95em}.msg .body.markdown th,.msg .body.markdown td{border:1px solid var(--border);padding:5px 10px;text-align:left}.msg .body.markdown th{background:var(--bg-elev-2)}.msg .body.markdown a{color:var(--accent);text-decoration:underline}.msg .body.markdown hr{border:0;border-top:1px solid var(--border);margin:1em 0}.msg .body.markdown .cite-ref{display:inline-block;background:var(--bg-elev-2);border:1px solid var(--border);border-radius:4px;padding:0 4px;margin:0 1px;font-size:.85em;color:var(--accent);cursor:pointer}.msg .body.markdown .cite-ref:hover{border-color:var(--accent)}.msg.user .body{background:var(--bg-elev-2)}.citations{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}.cite{background:var(--bg-elev-2);border:1px solid var(--border);border-radius:999px;padding:2px 8px;font-size:12px;color:var(--text-dim);cursor:pointer}.cite:hover{color:var(--text);border-color:var(--accent)}.cite-popup{position:fixed;background:var(--bg-elev-2);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;max-width:540px;max-height:420px;overflow-y:auto;font-size:13.5px;line-height:1.55;color:var(--text);z-index:50;box-shadow:0 12px 32px #0000008c}.cite-popup .open-doc{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--accent);text-decoration:none;padding:8px 10px;background:var(--bg-elev);border:1px solid var(--border);border-radius:6px;transition:border-color .15s,background .15s,color .15s}.cite-popup .open-doc:hover{border-color:var(--accent);background:var(--bg)}.cite-popup .open-doc.disabled{color:var(--text-dim);background:transparent;pointer-events:none}.cite-popup .open-doc .open-icon{font-size:14px;line-height:1;flex-shrink:0}.cite-popup .open-doc .open-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cite-popup .sub{font-size:11px;font-family:var(--mono);color:var(--text-dim);margin:8px 2px 10px}.cite-popup .snippet{white-space:normal;word-wrap:break-word;font-size:13px;line-height:1.55;color:var(--text);padding-top:10px;margin-top:2px;border-top:1px solid var(--border)}.modal{background:var(--bg-elev);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);padding:0;max-width:640px;width:90vw;box-shadow:0 20px 50px #0009}.modal::backdrop{background:#0000008c}.modal-form{padding:20px 22px}.modal-form h3{margin:0 0 16px;font-size:16px}.modal-form .field{margin-bottom:14px}.modal-form input[type=text],.modal-form textarea{width:100%;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);padding:8px 10px;font-family:var(--mono);font-size:13px}.modal-form textarea{resize:vertical;line-height:1.5}.composer{border-top:1px solid var(--border);background:var(--bg-elev);padding:14px 32px;flex-shrink:0}.composer-row{max-width:820px;margin:0 auto;display:flex;gap:8px}.composer textarea{flex:1;resize:none;border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:var(--radius);padding:10px 12px;font:inherit;min-height:44px;max-height:200px}.composer button{background:var(--accent);color:#0a0e17;border:none;padding:0 16px;border-radius:var(--radius);cursor:pointer;font-weight:600}.composer button:disabled{opacity:.5;cursor:not-allowed}.docs-view{padding:24px 32px;overflow-y:auto}.dropzone{border:2px dashed var(--border);border-radius:var(--radius);padding:40px;text-align:center;color:var(--text-dim);cursor:pointer;transition:border-color .15s,background .15s}.dropzone.over{border-color:var(--accent);background:var(--bg-elev)}.doc-list{margin-top:24px;display:flex;flex-direction:column;gap:6px}.doc-row{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:12px;padding:10px 12px;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius)}.doc-row .doc-name{font-weight:500;word-break:break-word}.doc-row .doc-link{color:var(--accent);text-decoration:none}.doc-row .doc-link:hover{text-decoration:underline}.doc-row .doc-link:after{content:" ↗";font-size:.85em;color:var(--text-dim)}.doc-row .doc-name-disabled{color:var(--text-dim);cursor:not-allowed}.doc-row .meta{color:var(--text-dim);font-size:12px}.doc-row .del{background:transparent;border:1px solid var(--border);color:var(--text-dim);border-radius:var(--radius);padding:4px 8px;cursor:pointer;font-size:12px}.doc-row .del:hover{color:var(--danger);border-color:var(--danger)}.progress{margin-top:18px;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);padding:12px;font-size:13px;color:var(--text-dim)}.progress .bar{height:6px;background:var(--bg-elev-2);border-radius:999px;overflow:hidden;margin-top:8px}.progress .bar>div{height:100%;background:var(--accent);transition:width .15s}.settings-view{padding:24px 32px;max-width:640px}.field{margin-bottom:18px}.field label{display:block;font-size:13px;font-weight:600;margin-bottom:6px;color:var(--text-dim)}.field input,.field select{width:100%;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);padding:8px 10px;font:inherit}.field .hint{font-size:12px;color:var(--text-dim);margin-top:4px}.row{display:flex;gap:8px;align-items:center}.btn{background:var(--accent);color:#0a0e17;border:none;padding:8px 12px;border-radius:var(--radius);cursor:pointer;font-weight:600}.btn.secondary{background:var(--bg-elev-2);color:var(--text);border:1px solid var(--border)}.status-pill{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.status-pill.ok{background:#22c55e26;color:var(--good)}.status-pill.warn{background:#ef444426;color:var(--danger)}#unsupported{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:100}#unsupported[hidden]{display:none}#unsupported .card{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);padding:24px;max-width:420px}.muted{color:var(--text-dim)}h2{margin-top:0}code,pre{font-family:var(--mono)}.empty{color:var(--text-dim);text-align:center;padding:60px 20px}
