*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:#f5f5f5}.chat-fab{position:fixed;bottom:24px;right:24px;z-index:9999;width:56px;height:56px;border-radius:50%;border:none;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #6366f166;transition:transform .2s ease,box-shadow .2s ease}.chat-fab:hover{transform:scale(1.08);box-shadow:0 6px 24px #6366f18c}.chat-fab--open{background:#4b5563;box-shadow:0 4px 12px #00000040}.chat-fab--open:hover{box-shadow:0 6px 18px #00000059}.chat-window{position:fixed;bottom:96px;right:24px;z-index:9998;width:380px;max-height:560px;border-radius:16px;background:#fff;box-shadow:0 8px 40px #00000026,0 0 0 1px #0000000a;display:flex;flex-direction:column;overflow:hidden;animation:chatSlideUp .25s ease-out}@keyframes chatSlideUp{0%{opacity:0;transform:translateY(16px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff}.chat-header__info{display:flex;align-items:center;gap:10px}.chat-header__avatar{width:34px;height:34px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px}.chat-header__title{font-size:15px;font-weight:600;line-height:1.2}.chat-header__subtitle{font-size:11px;opacity:.8;line-height:1.2}.chat-header__actions{display:flex;align-items:center;gap:4px}.chat-header__btn{background:#ffffff26;border:none;color:#fff;width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s}.chat-header__btn:hover{background:#ffffff4d}.chat-login{flex:1;display:flex;align-items:center;justify-content:center;padding:32px 24px}.chat-login form{width:100%;display:flex;flex-direction:column;gap:12px}.chat-login__prompt{font-size:13px;color:#6b7280;text-align:center;margin-bottom:4px}.chat-login input{padding:10px 14px;border:1px solid #e5e7eb;border-radius:10px;font-size:14px;color:#111827;background:#f9fafb;outline:none;transition:border-color .15s}.chat-login input:focus{border-color:#6366f1;background:#fff}.chat-login input::placeholder{color:#9ca3af}.chat-login__submit{padding:10px 16px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .15s}.chat-login__submit:hover{opacity:.9}.chat-login__submit:disabled{opacity:.5;cursor:not-allowed}.chat-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px;min-height:280px;max-height:380px;background:#fafafa}.chat-body::-webkit-scrollbar{width:4px}.chat-body::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.chat-msg{display:flex;align-items:flex-end;gap:8px}.chat-msg--user,.chat-msg--error{flex-direction:row-reverse}.chat-msg__avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}.chat-msg__bubble{max-width:75%;padding:10px 14px;border-radius:16px;font-size:13.5px;line-height:1.5;white-space:pre-wrap;word-break:break-word}.chat-msg__bubble--assistant{background:#fff;color:#1f2937;border:1px solid #e5e7eb;border-bottom-left-radius:4px}.chat-msg__bubble--user{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border-bottom-right-radius:4px}.chat-msg__bubble--error{background:#fef2f2;color:#dc2626;border:1px solid #fecaca;border-bottom-right-radius:4px;font-size:12.5px}.chat-typing{display:inline-flex;align-items:center;gap:4px;padding:4px 0}.chat-typing span{width:6px;height:6px;border-radius:50%;background:#9ca3af;animation:typingBounce 1.2s infinite}.chat-typing span:nth-child(2){animation-delay:.15s}.chat-typing span:nth-child(3){animation-delay:.3s}@keyframes typingBounce{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-4px);opacity:1}}.chat-input{display:flex;align-items:center;gap:8px;padding:12px 14px;border-top:1px solid #e5e7eb;background:#fff}.chat-input input{flex:1;padding:10px 14px;border:1px solid #e5e7eb;border-radius:24px;font-size:13.5px;color:#111827;background:#f9fafb;outline:none;transition:border-color .15s}.chat-input input:focus{border-color:#6366f1;background:#fff}.chat-input input::placeholder{color:#9ca3af}.chat-input button{width:38px;height:38px;border-radius:50%;border:none;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:opacity .15s,transform .15s}.chat-input button:hover:not(:disabled){transform:scale(1.05)}.chat-input button:disabled{opacity:.4;cursor:not-allowed}.chat-error{font-size:12.5px;color:#dc2626;text-align:center}@media (max-width: 440px){.chat-window{right:8px;left:8px;bottom:88px;width:auto;max-height:calc(100dvh - 120px)}.chat-fab{bottom:16px;right:16px}}
