body{margin:0;overflow-y:scroll;font-family:sans-serif;width:100vw}@media (max-width: 768px){body{width:100vw}}.chatbot-icon{align-items:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border:none;border-radius:50%;bottom:1.5em;box-shadow:0 .25em .375em -.0625em #0000001a,0 .125em .25em -.0625em #0000000f;cursor:pointer;display:flex;height:3.5em;justify-content:center;position:fixed;right:1.5em;transform-origin:center;transition:all .3s ease;width:3.5em;z-index:50}.chatbot-icon:hover{box-shadow:0 .625em .9375em -.1875em #0000001a,0 .25em .375em -.125em #0000000d}.chatbot-icon.open{transform:scale(0)}.chatbot-icon.closed{transform:scale(1)}.chatbot-icon svg{color:#fff;height:1.5em;width:1.5em}.chat-window{background:#fff;border-radius:.75em;bottom:3em;box-shadow:0 1.5625em 3.125em -.75em #00000040;display:flex;flex-direction:column;height:min(80vh,30em);position:fixed;right:1.5em;transform-origin:bottom right;transition:all .3s ease;width:min(90vw,22em);z-index:50}.chat-window.open{opacity:1;transform:scale(1)}.chat-window.closed{opacity:0;transform:scale(0)}.chat-header{align-items:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:.75em .75em 0 0;color:#fff;display:flex;flex-shrink:0;justify-content:space-between;padding:1em}.chat-header h3{font-size:1em;font-weight:600;margin:0}.chat-header p{color:#dbeafe;font-size:.75em;margin:0}.chat-close-button{align-items:center;background:#fff3;border:none;border-radius:50%;cursor:pointer;display:flex;justify-content:center;padding:.25em;transition:background-color .2s ease}.chat-close-button:hover{background:#ffffff4d}.chat-close-button svg{color:#fff;height:1.25em;width:1.25em}.messages-container{background:#f9fafb;flex:1;min-height:0;overflow-y:auto;padding:1em}.message-bubble{display:flex;margin-bottom:.75em}.message-bubble.user{justify-content:flex-end}.message-bubble.bot{justify-content:flex-start}.message-content{word-wrap:break-word;border-radius:1.125em;line-height:1.4;max-width:98%;padding:.625em .875em}.message-content.user{background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-bottom-right-radius:.375em;color:#fff}.message-content.bot{background:#f3f4f6;border-bottom-left-radius:.375em;color:#374151}.message-text{font-size:.875em;margin:0 0 .25em;white-space:pre-wrap}.message-time{font-size:.6875em;margin:0;opacity:.8}.message-time.user{color:#dbeafe}.message-time.bot{color:#6b7280}.typing-indicator{align-items:center;display:flex;margin-bottom:.5em;padding:.75em}.typing-dots{display:flex;margin-right:.5em}.typing-dot{animation:bounce 1.4s ease-in-out infinite;background:#9ca3af;border-radius:50%;height:.5em;margin-right:.25em;width:.5em}.typing-dot:first-child{animation-delay:-.32s}.typing-dot:nth-child(2){animation-delay:-.16s}.typing-dot:nth-child(3){margin-right:0}.typing-text{color:#6b7280;font-size:.8125em;margin:0}.message-text a{color:#00f;text-decoration:underline}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.input-container{align-items:center;background:#fff;border-radius:0 0 .75em .75em;border-top:1px solid #e5e7eb;display:flex;flex-shrink:0;gap:.5em;padding:1em}.message-input{border:1px solid #d1d5db;border-radius:1.5em;flex:1;font-size:.875em;max-height:6em;min-height:2.5em;outline:none;padding:.5em 1em;resize:none;transition:border-color .2s ease}.message-input:focus{border-color:#3b82f6}.message-input:disabled{cursor:not-allowed;opacity:.5}.send-button{align-items:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:2.5em;justify-content:center;padding:.5em;transition:all .2s ease;width:2.5em}.send-button:hover:not(:disabled){box-shadow:0 .25em .375em -.0625em #0000001a,0 .125em .25em -.0625em #0000000f}.send-button:disabled{cursor:not-allowed;opacity:.5}.send-button svg{height:1em;width:1em}@media (max-width:48em){.chat-window{bottom:5em;height:85vh;right:2.5vw;width:95vw}.chatbot-icon{bottom:1em;height:3em;right:1em;width:3em}.chatbot-icon svg{height:1.25em;width:1.25em}}@media (max-width:30em){.chat-window{bottom:4.5em;height:90vh;right:1vw;width:98vw}}
