.app{display:flex;flex-direction:column;height:100dvh;background:#f8f8fc;font-family:system-ui,-apple-system,sans-serif}.header{background:#fff;border-bottom:1px solid #ebebf5;padding:0 1.25rem;flex-shrink:0;box-shadow:0 1px 12px #6366f10f}.header-inner{max-width:760px;margin:0 auto;height:64px;display:flex;align-items:center;justify-content:space-between}.logo{display:flex;align-items:center;gap:.75rem}.logo-icon svg{width:36px;height:36px;display:block}.logo h1{font-size:1.05rem;font-weight:700;color:#18181b}.subtitle{font-size:.72rem;color:#71717a;margin-top:1px;letter-spacing:.02em}.status-badge{display:flex;align-items:center;gap:.4rem;background:#f0fdf4;color:#16a34a;font-size:.75rem;font-weight:600;padding:.3rem .7rem;border-radius:99px;border:1px solid #bbf7d0}.status-dot{width:7px;height:7px;border-radius:50%;background:#22c55e;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.chat-window{flex:1;overflow-y:auto;padding:1.5rem 1.25rem;scroll-behavior:smooth}.chat-window>*{max-width:760px;margin-left:auto;margin-right:auto}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;min-height:320px;text-align:center;gap:.75rem;padding:2rem;max-width:600px;margin:0 auto}.empty-icon svg{width:52px;height:52px}.empty-state h2{font-size:1.4rem;font-weight:700;color:#18181b}.empty-state p{font-size:.9rem;color:#71717a;max-width:380px}.suggestions{display:grid;grid-template-columns:1fr 1fr;gap:.6rem;margin-top:.5rem;width:100%;max-width:520px}.suggestion{background:#fff;border:1px solid #e4e4f0;border-radius:.75rem;padding:.65rem .9rem;font-size:.82rem;color:#3f3f7a;cursor:pointer;text-align:left;line-height:1.4;transition:border-color .15s,background .15s,transform .1s}.suggestion:hover{border-color:#a5b4fc;background:#f5f3ff;transform:translateY(-1px)}.message-row{display:flex;align-items:flex-end;gap:.6rem;margin-bottom:1rem}.message-row.user{flex-direction:row-reverse}.message-row.assistant{flex-direction:row}.bubble-wrap{display:flex;flex-direction:column;max-width:72%}.bubble{padding:.7rem 1rem;border-radius:1.2rem;font-size:.93rem;line-height:1.6;word-break:break-word}.bubble.user{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border-bottom-right-radius:.3rem;box-shadow:0 4px 14px #6366f140}.bubble.assistant{background:#fff;color:#18181b;border-bottom-left-radius:.3rem;border:1px solid #ebebf5;box-shadow:0 2px 8px #0000000d}.avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0}.avatar.user{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff}.avatar.assistant{background:#f0f0ff;color:#6366f1;border:1px solid #e0e0ff}.avatar.assistant svg{width:16px;height:16px}.typing-bubble{display:inline-flex!important;align-items:center;gap:.35rem;padding:.8rem 1rem!important;min-width:56px}.typing-bubble span{display:inline-block;width:8px;height:8px;border-radius:50%;background:#a5b4fc;animation:bounce .9s infinite}.typing-bubble span:nth-child(2){animation-delay:.15s}.typing-bubble span:nth-child(3){animation-delay:.3s}@keyframes bounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-6px)}}.error-banner{display:flex;align-items:center;gap:.5rem;background:#fef2f2;color:#dc2626;border:1px solid #fecaca;border-radius:.75rem;padding:.65rem 1rem;font-size:.85rem;margin-bottom:1rem}.input-bar{background:#fff;border-top:1px solid #ebebf5;padding:.875rem 1.25rem 1rem;flex-shrink:0;box-shadow:0 -1px 12px #6366f10a}.input-wrap{display:flex;align-items:flex-end;gap:.6rem;max-width:760px;margin:0 auto;background:#f4f4f9;border:1.5px solid #e4e4f0;border-radius:1rem;padding:.5rem .5rem .5rem .9rem;transition:border-color .15s,background .15s}.input-wrap:focus-within{border-color:#a5b4fc;background:#fff}.input-wrap textarea{flex:1;border:none;background:transparent;font-size:.93rem;font-family:inherit;line-height:1.5;resize:none;outline:none;color:#18181b;max-height:160px;overflow-y:auto;padding:.3rem 0}.input-wrap textarea::placeholder{color:#a1a1aa}.send-btn{width:38px;height:38px;border-radius:.75rem;border:none;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:opacity .15s,transform .1s}.send-btn:hover:not(:disabled){opacity:.9;transform:scale(1.05)}.send-btn:disabled{background:#e4e4f0;cursor:not-allowed}.send-btn:disabled svg{stroke:#a1a1aa}.send-btn svg{width:16px;height:16px}.input-hint{text-align:center;font-size:.7rem;color:#a1a1aa;margin-top:.4rem;max-width:760px;margin-left:auto;margin-right:auto}@media (max-width: 480px){.suggestions{grid-template-columns:1fr}.bubble-wrap{max-width:85%}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:system-ui,-apple-system,sans-serif;background:#f0f2f5;height:100dvh;display:flex;justify-content:center;align-items:stretch}#root{width:100%;max-width:800px}
