:root{font-family:Avenir Next,Segoe UI,sans-serif;color:#10202b;background:radial-gradient(circle at 20% 0%,#f4f9ff,#eaf3fb 42%,#ddebf8)}*{box-sizing:border-box}body{margin:0;height:100vh}#root{height:100%}.layout{display:grid;grid-template-columns:320px 1fr;gap:16px;padding:20px;height:100%;overflow:hidden;position:relative}.card{border:1px solid #c7d8eb;border-radius:12px;background:#fffc;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#10202b59;display:grid;place-items:center;padding:16px;z-index:20}.global-status-chip{position:fixed;top:16px;right:16px;max-width:min(380px,calc(100vw - 32px));border:1px solid #a7c3de;border-radius:999px;padding:6px 12px;background:#f6fbfff5;box-shadow:0 8px 20px #10202b29;z-index:15;font-size:.88rem;color:#28435b}.global-status-chip.is-busy{border-color:#8eb3d6;background:#e4f1fff5;color:#1c4e79}.global-status-chip.is-error{border-color:#d08ea3;background:#fdeff3f7;color:#8f1f3a}.global-status-chip p{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.toast-stack{position:fixed;top:64px;right:16px;width:min(360px,calc(100vw - 32px));display:grid;gap:8px;z-index:16}.toast-card{border:1px solid #8eb3d6;border-radius:10px;padding:10px;background:#f7fcfff7;box-shadow:0 8px 20px #10202b24}.toast-meta{margin-top:8px;display:flex;justify-content:space-between;align-items:center;gap:12px}.toast-meta small{color:#4d677f}.create-dialog{width:min(460px,100%);padding:18px;display:flex;flex-direction:column;gap:12px;background:#f8fbff}.create-dialog-form{display:flex;flex-direction:column;gap:12px}.create-dialog-input{width:100%;border:1px solid #a7c3de;border-radius:10px;padding:10px 12px;font:inherit;background:#fff}.create-dialog-input:focus-visible{outline:2px solid #2d6ea8;outline-offset:2px}.create-dialog-actions{display:flex;justify-content:flex-end;gap:8px}.sidebar{padding:16px;display:flex;flex-direction:column;gap:12px;min-height:0}.controls{display:flex;gap:8px}.provider-picker{display:flex;flex-direction:column;gap:6px}.auth-subject{margin:0;word-break:break-all}.auth-screen{min-height:100vh;display:grid;place-items:center;padding:20px}.auth-card{width:min(420px,100%);border:1px solid #c7d8eb;border-radius:12px;background:#ffffffe6;padding:18px;display:flex;flex-direction:column;gap:12px}.provider-picker label{font-size:.9rem;color:#4d677f}.provider-picker select{border:1px solid #8eb3d6;border-radius:8px;padding:8px 10px;background:#f6fbff;color:#10202b;font:inherit}.list{display:flex;flex-direction:column;gap:8px;overflow:auto}.conversation{border:1px solid #c2d2e4;background:#f5f9fd;border-radius:8px;text-align:left;padding:10px;display:flex;flex-direction:column;gap:4px;cursor:pointer}.conversation-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.conversation-delete{border:0;background:transparent;color:#4d677f;padding:0 4px;border-radius:6px;line-height:1}.conversation-delete:hover{background:#e3edf8}.conversation:focus-visible{outline:2px solid #2d6ea8;outline-offset:2px}.conversation.active{border-color:#2d6ea8;background:#deedfc}.conversation-name-input{border:1px solid #8eb3d6;border-radius:6px;padding:4px 6px;font:inherit;width:100%}.chat{padding:16px;display:grid;grid-template-rows:auto 1fr auto auto;gap:12px;min-height:0}.chat-header{display:flex;justify-content:space-between;align-items:center;gap:16px}.messages{border:1px solid #c7d8eb;border-radius:10px;padding:12px;overflow:auto;min-height:0;background:#fdfefe;display:flex;flex-direction:column;gap:10px}.message{border-radius:10px;padding:10px;max-width:75%}.message.user{align-self:flex-end;background:#d5e9ff}.message.assistant{align-self:flex-start;background:#ecf3fb}.message-markdown{white-space:normal}.message-markdown>*:first-child{margin-top:0}.message-markdown>*:last-child{margin-bottom:0}.message-markdown p,.message-markdown li,.message-markdown blockquote{white-space:pre-wrap;word-break:break-word}.message-markdown p,.message-markdown ul,.message-markdown ol,.message-markdown blockquote,.message-markdown pre{margin:0 0 8px}.message-markdown ul,.message-markdown ol{padding-left:20px}.message-markdown pre,.message-markdown code{font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace}.message-markdown pre{background:#10202b14;border-radius:8px;padding:8px;overflow:auto}.message-markdown code{background:#10202b14;border-radius:4px;padding:0 4px}.message-markdown pre code{background:transparent;padding:0}.message-markdown a{color:#1c4e79}.message-attachment-image{width:min(280px,100%);border-radius:10px;margin-top:8px;display:block;border:1px solid rgba(120,150,180,.35)}.message.pending{opacity:.75}.message.failed{border:1px solid #d08ea3}.message-meta{margin-top:6px;display:flex;align-items:center;gap:8px}.retry-button{padding:4px 8px}.composer{display:flex;flex-direction:column;gap:8px}.photo-input-hidden{display:none}.composer-photo-pill{display:flex;align-items:center;gap:10px;border:1px solid #c7d8eb;background:#f6fbff;border-radius:12px;padding:8px}.composer-photo-pill img{width:42px;height:42px;border-radius:8px;object-fit:cover;border:1px solid #b7cce3}.composer-photo-pill span{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#27435a;font-size:.9rem}.photo-remove{padding:6px 10px}.composer-row{display:grid;grid-template-columns:auto 1fr auto;gap:8px;align-items:end}.attach-button{align-self:end}.composer textarea{max-height:160px;resize:none;border:0;outline:none;box-shadow:none;border-radius:16px;background:#eef4fb;padding:10px 12px;font:inherit;line-height:1.4}.composer button{align-self:end}button{border:1px solid #8eb3d6;border-radius:8px;padding:8px 12px;background:#eff6fd;cursor:pointer;font:inherit}button:disabled{cursor:not-allowed;opacity:.6}.danger{border-color:#d08ea3;background:#fdeff3}.muted{color:#4d677f;margin:0}.error{color:#8f1f3a;margin:0}h1,h2,p{margin:0}@media(max-width:900px){.layout{grid-template-columns:1fr}.global-status-chip{top:12px;right:12px;max-width:calc(100vw - 24px)}.toast-stack{right:12px;width:calc(100vw - 24px)}.messages{min-height:260px}.composer-row{grid-template-columns:1fr;align-items:stretch}.attach-button,.composer button{width:100%}}
