@import "https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,600;9..144,700&family=Manrope:wght@400;500;600;700&display=swap";:root{color:#2f281f;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fdfaf6;font-family:Manrope,Avenir Next,Segoe UI,sans-serif}*{box-sizing:border-box}body{background:#fdfaf6;min-height:100vh;margin:0}#root{min-height:100vh}:root{--accent-500:#2fa4d7;--accent-600:#258fbc;--accent-700:#1f7da5;--accent-100:#e6f5fb;--accent-050:#f3fbff;--accent-border:#c9e8f5;--text-primary:#1f2937;--text-secondary:#5f6b7a;--line:#e6ebf2;--surface:#fff;--surface-soft:#f8fafc;--page-bg:#f4f8fb}.app-page{background:#fdfaf6;min-height:100svh;padding:8px}.app-shell{border:1px solid var(--line);background:var(--surface);border-radius:10px;flex-direction:column;width:100%;height:calc(100svh - 16px);min-height:calc(100svh - 16px);max-height:calc(100svh - 16px);margin:0 auto;display:flex;overflow:hidden;box-shadow:0 8px 28px #1118270f}.header{border-bottom:1px solid var(--line);background:var(--surface);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:14px;padding:14px 16px;display:flex}.title-wrap{align-self:center;align-items:center;gap:12px;display:flex}.title{letter-spacing:.01em;color:#162030;margin:0;font-family:Fraunces,Times New Roman,serif;font-size:30px;font-weight:700;line-height:1}.title-icon{color:#2f86af;flex-shrink:0}.title-text-block{flex-direction:column;gap:4px;display:flex}.title-subtitle{color:var(--text-secondary);margin:0;font-size:14px}.header-controls{flex-wrap:wrap;align-items:flex-start;gap:10px;display:flex}.header-main-controls{align-items:center;gap:12px;display:flex}.header-dropdown{position:relative}.header-dropdown-trigger{background:var(--surface);color:#4e6680;cursor:pointer;border:1px solid #d6dde8;border-radius:8px;align-items:center;gap:6px;height:34px;padding:0 10px;font-size:13px;font-weight:600;display:inline-flex}.header-dropdown-trigger:hover{border-color:var(--accent-border);background:var(--accent-050)}.header-dropdown-panel{z-index:30;background:var(--surface);border:1px solid #dbe4ef;border-radius:9px;min-width:320px;padding:10px;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 12px 28px #0f172a1f}.byok-dropdown-panel{width:340px}.usage-dropdown-panel{width:max-content;min-width:178px}.byok-toggle-row{align-items:center;gap:10px;padding:0 2px;display:inline-flex}.byok-toggle-label{color:#5f7690;font-size:12px}.switch{width:40px;height:22px;position:relative}.switch input{opacity:0;width:0;height:0}.slider{background:#edf3f9;border:1px solid #d2dee9;border-radius:999px;transition:background .2s;position:absolute;inset:0}.slider:before{content:"";background:#fff;border-radius:50%;width:16px;height:16px;transition:transform .2s;position:absolute;top:2px;left:2px;box-shadow:0 1px 2px #0f172a33}.switch input:checked+.slider{background:#dff3ff;border-color:#9cc9e4}.switch input:checked+.slider:before{background:#2f86af;transform:translate(18px)}.switch input:disabled+.slider{opacity:.7}.byok-forced-note{color:#85631a;background:#fff8e8;border:1px solid #f2deac;border-radius:8px;align-items:center;gap:6px;padding:6px 8px;font-size:12px;display:inline-flex}.byok-inline-error{color:#9a4f4f;margin:0;padding:0 2px;font-size:12px}.byok-section{background:0 0;border:none;border-radius:0;flex-direction:column;align-items:stretch;gap:10px;padding:0;display:flex}.byok-controls{flex-direction:column;align-items:flex-start;gap:10px;width:100%;display:flex}.byok-title{color:#4e6680;letter-spacing:.04em;text-transform:uppercase;white-space:nowrap;border-right:1px solid #e8eef6;justify-content:center;align-items:center;margin-bottom:0;padding:0 10px 0 2px;font-size:12px;font-weight:700;display:flex}.control-row{align-items:center;gap:8px;display:flex}.control-row-compact{width:fit-content}.panel-field-group{flex-direction:column;gap:6px;display:flex}.panel-label-row{justify-content:flex-start;align-items:center;gap:4px;display:flex}.field-label.field-label-stack{text-transform:none;letter-spacing:0;color:#5d7894;font-size:12px}.compact-input{width:220px;min-width:220px}.compact-input-wrap{width:190px;max-width:190px}.compact-input-key{width:190px;min-width:190px}.control-leading-icon{color:#5d7894;flex-shrink:0}.input-with-inline-action{flex:1;min-width:0;position:relative}.input-key-inline{width:100%;padding-right:38px}.inline-input-action{color:#7398b7;cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;width:24px;height:24px;display:inline-flex;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.inline-input-action:hover{color:var(--accent-700);background:var(--accent-050)}.header-reset-wrap{justify-content:center;align-items:stretch;display:flex}.reset-usage-stack{flex-direction:column;align-items:flex-start;gap:4px;display:flex}.usage-line{color:#5f6b7a;white-space:nowrap;font-size:13px;line-height:1.2}.reset-divider{border-top:1px dotted #cdd8e6;width:100%;margin:4px 0 2px}.field-group{flex-direction:column;gap:6px;display:flex}.key-group{min-width:250px}.field-label{color:#6684a1;letter-spacing:.04em;text-transform:uppercase;align-items:center;gap:6px;font-size:11px;display:inline-flex}.field-label-reset{justify-content:flex-end}.field-reset{align-items:flex-end;min-width:90px}.input{background:var(--surface);color:var(--text-primary);border:1px solid #d8dee8;border-radius:8px;padding:9px 12px;font-size:15px;transition:border-color .18s}.input:focus,.chat-input:focus{border-color:var(--accent-500);box-shadow:none;outline:none}.input-key{width:260px}.input-model{min-width:155px}.button{background:var(--surface);color:var(--text-primary);cursor:pointer;border:1px solid #d7deea;border-radius:8px;padding:8px 12px;font-size:14px}.button:hover{border-color:var(--accent-border);color:#1c3550}.button:disabled{opacity:.55;cursor:not-allowed}.button-reset{color:#b46868;background:0 0;border:none;font-weight:500}.button-reset:hover{color:#8b3f3f;background:#fdeeee}.button-text{color:var(--accent-700);background:0 0;border:none;padding:7px 5px;font-weight:600}.button-text:hover{color:var(--accent-600);background:0 0}.button-modal{border-color:var(--accent-500);background:var(--accent-500);color:#fff}.button-modal:hover{background:var(--accent-600);border-color:var(--accent-600)}.icon-button{background:var(--surface);color:#5b728a;cursor:pointer;border:1px solid #d6dde8;border-radius:8px;justify-content:center;align-items:center;width:30px;height:30px;display:inline-flex}.icon-button:hover{border-color:var(--accent-border);color:var(--accent-700);background:var(--accent-050)}.icon-button:disabled{opacity:.45;cursor:not-allowed}.icon-info{color:#7398b7;border:none;width:26px;height:26px}.chat-window{background:var(--surface);flex-direction:column;flex:1;gap:10px;min-height:0;padding:16px;display:flex;overflow-y:auto}.empty-state{text-align:center;width:min(700px,100%);color:var(--text-secondary);gap:8px;margin:auto;padding:12px 8px;display:grid}.empty-tagline{color:#192436;margin:0;font-size:22px;font-weight:700}.empty-subtitle{margin:0;font-size:15px}.empty-feature-row{flex-wrap:wrap;justify-content:center;align-items:center;gap:10px;margin:10px auto 0;display:flex}.empty-feature-item{color:#2f5e83;background:#f3fafe;border:1px solid #d7eaf6;border-radius:999px;align-items:center;gap:6px;padding:6px 10px;font-size:13px;font-weight:600;display:inline-flex}.empty-restriction-row{color:#b06f73;flex-wrap:wrap;justify-content:center;align-items:center;gap:0;margin:10px auto 0;font-size:13px;display:flex}.empty-restriction-row span{align-items:center;padding:0 2px;display:inline-flex}.empty-restriction-row span+span:before{content:"•";color:#d4a2a4;margin:0 7px}.empty-constraints{color:#5f7690;justify-content:center;align-items:center;gap:6px;margin-top:8px;font-size:13px;display:inline-flex}.system-message{color:#7d652e;align-self:flex-start;align-items:center;gap:7px;padding:2px 0;font-size:14px;display:inline-flex}.system-message:before{content:"";background:#d6b66c;border-radius:50%;flex-shrink:0;width:6px;height:6px}.system-message.system-ack{color:#7d652e}.system-message.system-ack:before{background:#d6b66c}.system-message.system-success{color:#397151}.system-message.system-success:before{background:#77b58f}.system-message.system-error{color:#9a4f4f}.system-message.system-error:before{background:#e6a1a1}.system-message.system-warning{color:#8e6f24}.system-message.system-warning:before{background:#e6cd8d}.system-thinking{margin:0}.thinking-dots{min-width:12px;display:inline-block}.processing-indicator{color:#5c6f84;align-self:flex-start;align-items:center;gap:9px;padding:4px 0 2px;font-size:14px;display:inline-flex}.processing-spinner{border:2px solid #d5e5f1;border-top-color:#2f86af;border-radius:50%;width:14px;height:14px;animation:.75s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.message-row{align-items:flex-start;gap:9px;display:flex}.message-row.user{justify-content:flex-end}.message-row.assistant{justify-content:flex-start}.message-main{flex-direction:column;gap:4px;max-width:min(90%,900px);display:flex}.message-main.user{align-items:flex-end}.message-main.assistant{align-items:flex-start}.message-head{color:#6f8194;font-size:13px;line-height:1}.message-author{font-weight:600}.message-avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;display:inline-flex}.message-avatar.user{color:#fff;background:#2fa4d7}.message-avatar.assistant{color:#2a7aa2;background:#e9f4fb;border:1px solid #d1e9f5}.message-bubble{border-radius:9px;max-width:100%;padding:10px 12px;font-size:15px;line-height:1.5}.message-bubble.user{color:#fff;background:#2fa4d7;border:1px solid #2fa4d7}.message-bubble.assistant{background:var(--surface-soft);color:var(--text-primary);border:1px solid #e8edf4}.message-bubble p{margin:0}.message-bubble ul,.message-bubble ol{margin:8px 0 0;padding-left:18px}.message-actions{width:100%;display:flex}.message-actions.user{justify-content:flex-end}.message-actions.assistant{justify-content:flex-start}.message-copy{color:#6f8194;cursor:pointer;background:0 0;border:none;align-items:center;gap:5px;padding:2px 0;font-size:13px;display:inline-flex}.message-copy:hover{color:#2a7aa2}.typing-cursor{vertical-align:text-bottom;background:var(--accent-500);border-radius:2px;width:7px;height:15px;margin-left:4px;animation:.9s step-end infinite cursor-blink;display:inline-block}@keyframes cursor-blink{0%,45%{opacity:1}46%,to{opacity:0}}.message-sources{color:var(--text-secondary);border-top:1px dashed #d5dfeb;margin-top:10px;padding-top:8px;font-size:13px}.sources-title{margin-bottom:4px;font-weight:600}.message-sources ul{margin:0;padding-left:18px}.input-bar{border-top:1px solid var(--line);background:var(--surface);flex-direction:column;gap:8px;padding:10px 14px 8px;display:flex}.composer-docs{gap:7px;padding:0 2px;display:grid}.composer-docs-title{color:#6788a9;letter-spacing:.04em;text-transform:uppercase;align-items:center;gap:6px;font-size:12px;display:flex}.attachment-list{flex-wrap:wrap;gap:7px;display:flex}.attachment-card{background:#fbfeff;border:1px solid #d4e7f3;border-radius:8px;align-items:stretch;width:min(280px,100%);display:flex;overflow:hidden}.attachment-type{color:#fff;letter-spacing:.06em;flex:0 0 20%;justify-content:center;align-items:center;width:20%;min-width:56px;font-size:11px;font-weight:700;display:flex}.attachment-type.type-pdf{background:#ca3838}.attachment-type.type-docx{background:#2f60bf}.attachment-type.type-md{background:#191919}.attachment-type.type-generic{background:#5b6f84}.attachment-name{color:#2b4058;white-space:nowrap;text-overflow:ellipsis;flex:1;padding:8px;font-size:13px;overflow:hidden}.attachment-remove{color:#6887a4;cursor:pointer;background:0 0;border:none;border-left:1px solid #d4e7f3;flex:none;justify-content:center;align-items:center;min-width:64px;padding:0 10px;font-size:12px;font-weight:600;display:inline-flex}.attachment-remove:hover{color:var(--accent-700);background:var(--accent-050)}.composer{background:var(--surface);border:1px solid #d6deea;border-radius:9px;align-items:flex-end;gap:8px;padding:6px;display:flex}.composer:focus-within{border-color:var(--accent-500);box-shadow:none}.chat-input:disabled{cursor:not-allowed}.composer-button{background:var(--accent-050);width:36px;height:36px;color:var(--accent-700);border-color:#0000;border-radius:7px}.composer-send{background:var(--accent-500);color:#fff}.composer-send:hover{background:var(--accent-600);color:#fff}.chat-input{resize:none;box-sizing:border-box;width:100%;max-height:160px;color:var(--text-primary);background:0 0;border:none;border-radius:7px;padding:7px 4px;font-size:15px;line-height:1.5}.chat-input::placeholder{color:#8ba2ba}.composer-meta{justify-content:space-between;align-items:center;gap:10px;padding:0 4px;display:flex}.composer-hint{color:#6a87a7;font-size:13px}.composer-user-id{white-space:nowrap;text-overflow:ellipsis;color:#7f93aa;max-width:42%;font-size:13px;overflow:hidden}.constraints-inline{color:#6a87a7;border-top:1px dashed #d8e8f3;padding:7px 14px 8px;font-size:13px}.inline-feedback{border-top:1px solid #e4edf5;padding:8px 14px;font-size:13px}.inline-feedback-warning{color:#8d6a1f;background:#fffaf0}.inline-feedback-error{color:#8e4545;background:#fff5f5}.inline-feedback-success{color:#2f6b47;background:#f3fbf7}.app-footer{color:#6e7e90;background:#fcfdfd;border-top:1px solid #e6ebf2;flex-shrink:0;grid-template-columns:1fr auto 1fr;align-items:center;gap:10px;min-height:36px;padding:8px 14px;font-size:12px;display:grid}.footer-left{justify-self:start}.footer-center{justify-self:center}.footer-right{justify-self:end;align-items:center;gap:6px;display:inline-flex}.footer-link{color:#5f7d9a;align-items:center;gap:4px;text-decoration:none;display:inline-flex}.footer-link:hover{color:#2f5e83;text-decoration:underline}.footer-dot{color:#9cb0c3}.legal-page{background:#f8fbfe;min-height:100svh;padding:16px}.legal-shell{background:#fff;border:1px solid #dbe4ef;border-radius:10px;gap:12px;width:min(900px,100%);margin:0 auto;padding:18px;display:grid}.legal-header{border-bottom:1px solid #e7edf4;padding-bottom:10px}.legal-header h1{color:#1a2a3b;margin:0 0 6px;font-family:Fraunces,Times New Roman,serif;font-size:30px}.legal-header p{color:#5f6f82;margin:0}.legal-meta{color:#7a8ca1;font-size:12px;margin-top:6px!important}.legal-back-row{justify-content:flex-start;display:flex}.legal-back-link{color:#2f5e83;align-items:center;gap:6px;padding:6px 12px;font-size:13px;font-weight:600;text-decoration:none;display:inline-flex}.legal-back-link:hover{cursor:pointer;text-decoration:underline}.legal-section{border:1px solid #e6eef6;border-radius:8px;gap:8px;padding:12px;display:grid}.legal-section h2{color:#2d4f6d;align-items:center;gap:8px;margin:0;font-size:16px;display:inline-flex}.legal-section p{color:#4f5f72;margin:0;line-height:1.6}.legal-section ul{color:#4f5f72;gap:6px;margin:0;padding-left:18px;display:grid}.modal-overlay{z-index:40;background:#0f172a47;place-items:center;padding:16px;display:grid;position:fixed;inset:0}.modal-card{background:var(--surface);border:1px solid #dbe4ef;border-radius:9px;width:min(530px,100%);box-shadow:0 14px 34px #0f172a2e}.modal-header{border-bottom:1px solid #e7edf4;justify-content:space-between;align-items:center;gap:8px;padding:14px 14px 10px;display:flex}.modal-header h2{color:#1b2736;margin:0;font-size:17px}.modal-body{color:#4f5f72;gap:10px;padding:14px;font-size:14px;line-height:1.6;display:grid}.modal-body p{margin:0}.modal-body ul{margin:0;padding-left:18px}.modal-footer{justify-content:flex-end;gap:8px;padding:0 14px 14px;display:flex}@media (width<=820px){.app-page{padding:6px}.app-shell{border-radius:8px;width:100%;height:calc(100svh - 16px);min-height:calc(100svh - 16px);max-height:calc(100svh - 16px)}.header{padding:12px}.header-controls{justify-content:stretch;width:100%}.header-main-controls{flex-wrap:wrap;align-items:center;width:100%}.header-dropdown{width:100%}.header-dropdown-trigger{justify-content:space-between;width:100%}.header-dropdown-panel{width:100%;min-width:0;margin-top:8px;position:static}.byok-dropdown-panel,.usage-dropdown-panel{width:100%}.header-reset-wrap{justify-content:flex-start;width:100%}.byok-section{flex-direction:row;gap:8px}.byok-controls,.control-row,.control-row-compact{width:100%}.compact-input{width:100%;min-width:0}.compact-input-wrap,.compact-input-key{width:100%;min-width:0;max-width:100%}.app-footer{grid-template-columns:1fr;align-items:flex-start;gap:6px}.footer-center,.footer-left,.footer-right{justify-self:start}.legal-page{padding:10px}.legal-shell{padding:14px}.legal-header h1{font-size:26px}.field-group,.key-group{align-items:stretch;width:100%}.input-key,.input-model{width:100%}.message-bubble{max-width:96%}.message-main{max-width:92%}.composer-meta{flex-direction:column;align-items:flex-start}.composer-user-id{max-width:100%}}
