*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}#root{width:100%;height:100%;margin:0;padding:0}.app{width:100%;min-height:100vh;position:relative}.home-page{justify-content:center;align-items:center;width:100%;min-height:100vh;padding:20px;display:flex}.home-content{text-align:center;color:#fff;max-width:600px}.home-content h1{text-shadow:0 2px 10px #0003;margin-bottom:20px;font-size:3rem;font-weight:700}.home-content p{opacity:.9;text-shadow:0 1px 3px #0003;font-size:1.2rem}.chat-icon{color:#fff;cursor:pointer;z-index:999;background:#667eea;border:none;border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;transition:all .3s;display:flex;position:fixed;bottom:30px;right:30px;box-shadow:0 4px 12px #667eea66}.chat-icon:hover{background:#5568d3;transform:scale(1.1);box-shadow:0 6px 16px #667eea99}.chat-icon:active{transform:scale(.95)}.chat-icon svg{width:28px;height:28px}.chat-popup-overlay{z-index:1000;background:#00000080;justify-content:flex-end;align-items:flex-end;padding:20px;animation:.3s slideIn;display:flex;position:fixed;inset:0}@keyframes slideIn{0%{opacity:0}to{opacity:1}}.chat-popup{background:#fff;border-radius:12px;flex-direction:column;width:100%;max-width:400px;height:600px;animation:.3s popupSlideIn;display:flex;box-shadow:0 5px 40px #00000029}@keyframes popupSlideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.chat-header{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-bottom:1px solid #e5e5e5;border-radius:12px 12px 0 0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.header-content{align-items:center;gap:12px;display:flex}.bot-avatar{background:#fff3;border:2px solid #fff6;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:24px;display:flex}.chat-header h3{color:#fff;margin:0;font-size:1.1rem;font-weight:600}.close-btn{color:#fff;cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;width:32px;height:32px;padding:0;font-size:28px;transition:transform .2s;display:flex}.close-btn:hover{transform:scale(1.2)}.chat-messages{flex-direction:column;flex:1;gap:12px;padding:20px;display:flex;overflow-y:auto}.chat-welcome{color:#999;text-align:center;justify-content:center;align-items:center;height:100%;padding:20px;display:flex}.chat-welcome p{font-size:.95rem}.message{align-items:flex-end;gap:8px;margin-bottom:8px;animation:.3s messageSlide;display:flex}@keyframes messageSlide{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message.user{justify-content:flex-end}.message.response{justify-content:flex-start}.message-avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:18px;display:flex}.message.user .message-avatar{background:#667eea}.message.response .message-avatar{background:#f0f0f0}.message-bubble{word-wrap:break-word;border-radius:16px;max-width:80%;padding:12px 16px;font-size:.95rem;line-height:1.4}.message.user .message-bubble{color:#fff;background:#667eea;border-bottom-right-radius:4px}.message.response .message-bubble{color:#333;background:#f0f0f0;border-bottom-left-radius:4px}.chat-input-area{background:#fafafa;border-top:1px solid #e5e5e5;border-radius:0 0 12px 12px;align-items:center;gap:8px;padding:16px 20px;display:flex}.chat-input{resize:none;border:1px solid #ddd;border-radius:8px;flex:1;height:38px;padding:8px 12px;font-family:inherit;font-size:.95rem;line-height:1.5;transition:border-color .2s;overflow:hidden}.chat-input:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 2px #667eea1a}.send-btn{color:#fff;cursor:pointer;background:#667eea;border:none;border-radius:8px;justify-content:center;align-items:center;height:38px;padding:10px 20px;font-weight:600;transition:background .2s;display:flex}.send-btn:hover:not(:disabled){background:#5568d3}.send-btn:disabled{opacity:.5;cursor:not-allowed}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-track{background:0 0}.chat-messages::-webkit-scrollbar-thumb{background:#ddd;border-radius:3px}.chat-messages::-webkit-scrollbar-thumb:hover{background:#bbb}.chat-error{background:#fee;border:1px solid #fcc;border-radius:8px;margin-bottom:12px;padding:12px 20px}.chat-error p{color:#c33;margin:0;font-size:.9rem}.message-loading{align-items:center;padding:12px 18px;display:flex}.loading-dots{gap:4px;display:flex}.loading-dots span{background:#667eea;border-radius:50%;width:6px;height:6px;animation:1.4s infinite bounce}.loading-dots span:nth-child(2){animation-delay:.2s}.loading-dots span:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,80%,to{opacity:.3;transform:translateY(0)}40%{opacity:1;transform:translateY(-8px)}}@media (width<=480px){.chat-popup{border-radius:0;max-width:100%;height:100%}.chat-popup-overlay{justify-content:stretch;align-items:stretch;padding:0}.home-content h1{font-size:2rem}.home-content p{font-size:1rem}.chat-icon{width:50px;height:50px;bottom:20px;right:20px}}
