@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}:root{--su-red:#c8102e;--su-red-dark:#a00e26;--su-red-hover:#b50e28;--su-red-light:#fff0f2;--su-red-mid:#ffd6dc;--bg:#f7f7f8;--surface:#fff;--border:#e5e7eb;--border-soft:#f0f0f2;--text-primary:#111827;--text-secondary:#4b5563;--text-muted:#9ca3af;--radius-sm:6px;--radius-md:14px;--radius-lg:20px;--radius-xl:999px;--shadow-sm:0 1px 3px #00000012, 0 1px 2px #0000000a;--shadow-lg:0 8px 32px #0000001a, 0 2px 8px #0000000f}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);height:100dvh;color:var(--text-primary);-webkit-font-smoothing:antialiased;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.app{background:var(--surface);max-width:780px;height:100dvh;box-shadow:var(--shadow-lg);flex-direction:column;margin:0 auto;display:flex}.app-header{background:var(--su-red);z-index:10;flex-shrink:0;align-items:center;height:62px;padding:0 20px;display:flex;position:relative}.header-brand{flex:1;align-items:center;gap:12px;min-width:0;display:flex}.header-logo-btn{cursor:pointer;background:0 0;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;padding:0;transition:opacity .15s;display:flex}.header-logo-btn:hover{opacity:.85}.header-logo-btn img{object-fit:contain;width:100%;height:100%}.header-logo-fallback{color:#fff;letter-spacing:.04em;border:2px solid #fff9;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-family:Georgia,serif;font-size:.82rem;font-weight:800;display:flex}.header-text h1{color:#fff;white-space:nowrap;text-overflow:ellipsis;font-size:.92rem;font-weight:700;line-height:1.2;overflow:hidden}.header-text p{color:#ffffffa6;margin-top:1px;font-size:.71rem}.header-status{color:#ffffffa6;flex-shrink:0;align-items:center;gap:6px;margin-left:auto;font-size:.71rem;display:flex}.status-dot{background:#6ee7b7;border-radius:50%;flex-shrink:0;width:7px;height:7px}.chat-container{scrollbar-width:thin;scrollbar-color:var(--border) transparent;flex-direction:column;flex:1;padding:24px 20px 12px;display:flex;overflow-y:auto}.chat-container::-webkit-scrollbar{width:4px}.chat-container::-webkit-scrollbar-track{background:0 0}.chat-container::-webkit-scrollbar-thumb{background:var(--border);border-radius:10px}.messages-list{flex-direction:column;flex:1;gap:18px;display:flex}.message{align-items:flex-end;gap:9px;animation:.2s ease-out msgIn;display:flex}.message.user{flex-direction:row-reverse}@keyframes msgIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.avatar{letter-spacing:.03em;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:.6rem;font-weight:700;display:flex;overflow:hidden}.bot-avatar{background:var(--su-red);padding:5px}.bot-avatar img{object-fit:contain;width:100%;height:100%}.bot-avatar-fallback{background:var(--su-red);color:#fff;letter-spacing:.04em;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-family:Georgia,serif;font-size:.58rem;font-weight:800;display:flex}.user-avatar{color:#fffc;letter-spacing:.04em;background:#374151;font-size:.6rem;font-weight:700}.bubble-wrapper{flex-direction:column;gap:5px;max-width:75%;display:flex}.message.user .bubble-wrapper{align-items:flex-end}.bubble{border-radius:var(--radius-lg);word-break:break-word;padding:11px 16px;font-size:.88rem;line-height:1.6}.message.bot .bubble{background:var(--surface);color:var(--text-primary);border:1px solid var(--border);border-bottom-left-radius:var(--radius-sm);box-shadow:var(--shadow-sm)}.message.user .bubble{background:var(--su-red);color:#fff;border-bottom-right-radius:var(--radius-sm);box-shadow:0 2px 8px #c8102e40}.markdown-body{font-size:.88rem;line-height:1.6}.markdown-body h1,.markdown-body h2,.markdown-body h3{color:var(--su-red-dark);margin:11px 0 4px;font-size:.87rem;font-weight:700}.markdown-body h1:first-child,.markdown-body h2:first-child,.markdown-body h3:first-child{margin-top:0}.markdown-body p{margin:0 0 8px}.markdown-body p:last-child{margin-bottom:0}.markdown-body ul,.markdown-body ol{margin:3px 0 8px;padding-left:18px}.markdown-body li{margin-bottom:3px}.markdown-body strong{color:var(--text-primary);font-weight:700}.markdown-body em{font-style:italic}.markdown-body code{color:var(--su-red-dark);background:#f3f4f6;border:1px solid #e5e7eb;border-radius:4px;padding:1px 5px;font-family:Menlo,Consolas,monospace;font-size:.82em}.markdown-body hr{border:none;border-top:1px solid var(--border-soft);margin:8px 0}.citations{flex-wrap:wrap;align-items:center;gap:5px;display:flex}.citations-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;font-size:.68rem;font-weight:600}.citation-tag{background:var(--su-red-light);color:var(--su-red-dark);cursor:default;white-space:nowrap;border:1px solid var(--su-red-mid);border-radius:999px;padding:2px 9px;font-size:.7rem;font-weight:500;transition:background .12s}.citation-tag:hover{background:var(--su-red-mid)}.typing-bubble{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);border-bottom-left-radius:var(--radius-sm);box-shadow:var(--shadow-sm);align-items:center;gap:5px;width:fit-content;padding:13px 17px;display:flex}.typing-bubble span{background:#d1d5db;border-radius:50%;width:7px;height:7px;animation:1.3s ease-in-out infinite bounce}.typing-bubble span:nth-child(2){animation-delay:.18s}.typing-bubble span:nth-child(3){animation-delay:.36s}@keyframes bounce{0%,80%,to{opacity:.4;transform:scale(.7)}40%{opacity:1;transform:scale(1)}}.welcome-screen{flex-direction:column;align-items:center;padding:12px 0 28px;animation:.28s fadeUp;display:flex}@keyframes fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.welcome-logo-wrap{background:var(--su-red);border-radius:18px;justify-content:center;align-items:center;width:72px;height:72px;margin-bottom:18px;padding:14px;display:flex;box-shadow:0 4px 20px #c8102e38}.welcome-logo-wrap img{object-fit:contain;width:100%;height:100%}.welcome-logo-text{color:#fff;letter-spacing:.04em;font-family:Georgia,serif;font-size:1.4rem;font-weight:800}.welcome-title{color:var(--text-primary);letter-spacing:-.01em;text-align:center;margin-bottom:7px;font-size:1.1rem;font-weight:700}.welcome-sub{color:var(--text-secondary);text-align:center;max-width:360px;margin-bottom:28px;font-size:.84rem;line-height:1.55}.suggestions-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;text-align:center;margin-bottom:11px;font-size:.7rem;font-weight:600}.suggestions-grid{grid-template-columns:repeat(2,1fr);gap:8px;width:100%;max-width:510px;display:grid}.suggestion-btn{background:var(--surface);border:1.5px solid var(--border);color:var(--text-primary);border-radius:var(--radius-md);cursor:pointer;text-align:left;padding:12px 15px;font-family:inherit;font-size:.83rem;line-height:1.4;transition:border-color .12s,background .12s,box-shadow .12s,transform .1s}.suggestion-btn:hover{background:var(--su-red-light);border-color:var(--su-red-mid);transform:translateY(-1px);box-shadow:0 2px 8px #c8102e17}.suggestion-btn:active{transform:translateY(0)}.input-footer{border-top:1px solid var(--border-soft);background:var(--surface);flex-shrink:0;padding:12px 16px 16px}.chat-input-form{border:1.5px solid var(--border);border-radius:var(--radius-xl);background:#f9fafb;align-items:flex-end;gap:8px;padding:6px 6px 6px 16px;transition:border-color .15s,box-shadow .15s,background .15s;display:flex}.chat-input-form:focus-within{border-color:var(--su-red);background:var(--surface);box-shadow:0 0 0 3px #c8102e17}.chat-textarea{resize:none;max-height:110px;color:var(--text-primary);scrollbar-width:thin;background:0 0;border:none;outline:none;flex:1;padding:7px 0;font-family:inherit;font-size:.88rem;line-height:1.5;overflow-y:auto}.chat-textarea::placeholder{color:var(--text-muted)}.send-button{background:var(--su-red);color:#fff;cursor:pointer;border:none;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;width:36px;min-width:36px;height:36px;transition:background .14s,transform .1s;display:flex}.send-button svg{width:15px;height:15px}.send-button:hover:not(:disabled){background:var(--su-red-dark);transform:scale(1.06)}.send-button:active:not(:disabled){transform:scale(.97)}.send-button:disabled{cursor:not-allowed;background:#f0b8c0}.input-hint{color:var(--text-muted);text-align:center;margin-top:7px;font-size:.67rem}@media (width<=600px){.app{max-width:100%;box-shadow:none}.suggestions-grid{grid-template-columns:1fr}.bubble-wrapper{max-width:86%}.chat-container{padding:16px 14px 10px}.app-header{padding:0 16px}.input-footer{padding:10px 12px 14px}}
