*{margin:0;padding:0;box-sizing:border-box}html,body{margin:0;padding:0;width:100%;height:100%;overflow:hidden;background:transparent}#root{width:100%;height:100%}.floating-btn{position:fixed;bottom:20px;right:20px;width:60px;height:60px;background:none;border:none;border-radius:50%;padding:0;box-shadow:none;cursor:pointer;z-index:1000;display:flex;align-items:center;justify-content:center}.floating-btn img{width:60px;height:60px;border-radius:50%;object-fit:cover;box-shadow:0 4px 12px #0003}.floating-btn:hover img{transform:scale(1.05);transition:transform .2s ease}.chat-popup-section{padding:1rem;position:relative}.chat-popup{position:fixed;bottom:10px;right:10px;width:300px;max-width:100%;height:calc(100vh - 40px);background-color:#4285f4;color:#000;border-radius:14px;box-shadow:0 4px 15px #0000004d;font-family:Segoe UI,sans-serif;display:flex;flex-direction:column;z-index:1001;overflow:hidden;animation:slideInUp .4s ease}@keyframes slideInUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.chat-header-bar{display:flex;align-items:center;justify-content:space-between;padding:10px;background:linear-gradient(135deg,#04404f,#022833);width:100%;box-sizing:border-box;position:relative;min-height:40px;font-family:Segoe UI,sans-serif}.chat-title{position:absolute;left:50%;transform:translate(-50%);font-size:1.4rem;font-weight:500;color:#f1ebeb;pointer-events:none;font-family:Playfair Display,serif;transition:all .3s ease}.chat-title.shrink{font-size:.9rem;transform:translate(-67%) translateY(-1px);opacity:1;font-weight:600;letter-spacing:.2px;line-height:1.3}.bot-avatar{width:180px;height:auto;display:block;margin:0 auto;object-fit:contain;border-radius:8px}@media (max-width: 480px){.bot-avatar{width:230px}}.header-btns{display:flex;align-items:center;gap:3px;margin-left:8px;bottom:3px}.chat-popup:not(.expanded) .header-btns{position:relative;top:2px}.expand-btn{background:#fff;width:32px;height:32px;border-radius:5px;border:none;font-size:18px;display:inline-block;position:relative;cursor:pointer}.reset-btn,.close-btn{background:#fff;width:32px;height:32px;border-radius:5px;border:none;font-size:18px;display:inline-block;position:relative;flex-shrink:0;cursor:pointer}.bot-intro{background-color:#fff3;padding:6px 12px;border-radius:12px;text-align:left;font-size:.8rem;font-weight:500;color:#fff;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);box-shadow:0 4px 4px #0000001a;max-width:350px;margin:1rem 0}.bot-intro p{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-header{text-align:center;margin-top:30px}.chat-header img{margin-bottom:12px}.profile{width:4rem;height:2.5rem}.chat-header h2{font-weight:400;font-size:1rem;line-height:1.4;margin:0}.chat-header .green{color:#b6ad92}.chat-scrollable{flex:1;display:flex;flex-direction:column;overflow-y:auto;margin:10px 0;padding:10px;min-height:200px}.chat-scrollable::-webkit-scrollbar{width:6px}.chat-scrollable::-webkit-scrollbar-thumb{background-color:#ffffff4d;border-radius:4px}.suggestion-area{background:#ffffff1f;border-radius:8px;padding:12px;display:flex;flex-direction:column;gap:10px}.suggestion-card{display:flex;justify-content:space-between;align-items:center;background:#e9edff;color:#1c1c1c;border-radius:8px;padding:10px 14px;font-size:14px;cursor:pointer;transition:background .2s ease}.suggestion-card:hover{background-color:#e9edff}.suggestion-card img{width:25px;height:25px}.suggestion-text{color:#1c1c1c;font-size:13px}.suggestion-card span{font-size:.7rem}.chat-message-wrapper{display:flex;margin:6px 0;position:relative}.user-wrapper{justify-content:flex-end}.bot-wrapper{justify-content:flex-start}.chat-message{max-width:80%;padding:10px 14px;border-radius:14px;font-size:.8rem;line-height:1.4;word-wrap:break-word;margin:6px 0;position:relative}.user-message{background-color:#ccccffb5;align-self:flex-end;color:#fff;border-top-right-radius:0;border:1px solid black}.bot-message{background-color:#e6e6e69e;align-self:flex-start;color:#fff;border-top-left-radius:0;padding:7px;display:flex;flex-direction:column;align-items:flex-start;position:relative;border:1px solid black}.sender-label{font-size:.8rem;font-weight:600;margin-bottom:4px}.bot-label,.user-label{color:#000}.message-text{color:#312121;font-size:12px}.bot-wrapper{display:flex;flex-direction:column;align-items:flex-start}.message.bot-message{position:relative}.message-text-with-copy{padding-right:24px;word-break:break-word;white-space:pre-wrap}.copy-btn-inside{position:absolute;top:4px;right:8px;background:none;border:none;cursor:pointer;padding:2px;z-index:10}.copy-icon{width:14px;height:14px;opacity:.7;transition:opacity .2s ease}.copy-btn-inside:hover .copy-icon{opacity:1}.chat-input-wrapper{padding:10px}.chat-input{display:flex;align-items:flex-end;position:relative;background:#fff;border-radius:8px;padding:6px 10px;border:1px solid #ddd;gap:8px;min-height:40px;max-height:300px}.chat-input textarea{display:block;width:100%;box-sizing:border-box;border:none;outline:none;resize:none;font-family:Segoe UI,sans-serif;font-size:.9rem;line-height:1.4;background:linear-gradient(135deg,#04404f,#022833);color:#fff;padding:10px 50px 10px 12px;max-height:120px;overflow-y:auto;-webkit-overflow-scrolling:touch}.chat-input textarea::-webkit-scrollbar{width:8px}.chat-input textarea::-webkit-scrollbar-thumb{background:#04404f;border-radius:10px}.chat-input textarea::-webkit-scrollbar-track{background:#e6e6e6}.chat-input textarea{scrollbar-width:thin;scrollbar-color:#e6e6e6}.chat-input textarea::placeholder{color:#fff;font-weight:400}.chat-input button{right:15px;bottom:11px;color:#fff;border:none;border-radius:8px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s ease,transform .2s ease}.chat-input button:hover{background-color:#e6e6e69e}.btn-box{position:absolute;right:10px;bottom:10px;display:flex;gap:8px}.send-btn{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:none;color:#fff;cursor:pointer;transform:translate(-6px)}.send-btn:active{transform:translate(-6px) scale(.85);box-shadow:0 2px 4px #0003}.send-btn:hover{background-color:#e6e6e69e}.voice-btn{border-radius:50%;width:36px;height:36px;padding:0;display:flex;align-items:center;justify-content:center;color:#fff;border:none;cursor:pointer;font-size:18px}.voice-btn:disabled{background-color:#e6e6e69e;cursor:not-allowed}.mic-icon{font-size:18px;color:#444;transition:color .3s,transform .3s}.mic-icon.idle:hover{color:#403d3d;transform:scale(1.2)}.mic-icon.listening{color:#e6e6e69e;animation:pulse 1s infinite}@keyframes pulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.6}to{transform:scale(1);opacity:1}}.speaker-below-wrapper{margin-top:4px;display:flex;justify-content:flex-start}.speaker-btn{background:none;border:none;cursor:pointer;padding:4px;color:#000;transition:transform .2s ease,color .2s ease}.speaker-btn.active{color:#e6e6e69e}.speaker-btn:hover{transform:scale(1.2)}.chat-popup.expanded{width:98%;height:calc(100vh - 20px);max-width:100%;position:relative;margin:0 auto;inset:10px auto;cursor:pointer}.chat-popup.expanded .chat-input{position:relative;display:flex;align-items:center;padding:12px 16px;background:#fff;border-radius:10px;border:1px solid #ccc}.chat-popup.hidden{display:none}.chat-popup.expanded .chat-input textarea{flex:1;font-size:.9rem;min-height:45px;max-height:100px;padding:10px 90px 10px 12px;border:none;outline:none;resize:none;background:linear-gradient(135deg,#04404f,#022833);color:#fff;border-radius:8px;line-height:1.4;overflow-y:auto}.chat-popup.expanded .btn-box{position:absolute;right:16px;bottom:50%;transform:translateY(50%)}chat-popup.expanded .voice-btn{position:absolute;right:82px;bottom:50%;transform:translateY(50%);border-radius:50%;width:36px;height:36px;padding:0;display:flex;align-items:center;justify-content:center;color:#fff;background:#7aa0b8;border:none;cursor:pointer;font-size:18px}.chat-popup.expanded .send-btn{right:2px;bottom:50%;width:30px;height:33px;padding:0;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center}.chat-popup.expanded .voice-btn:hover,.chat-popup.expanded .send-btn:hover{filter:brightness(1.1)}@media (max-width: 920px){.chat-popup{height:calc(100vh - 50px)}}@media (max-width: 768px){html,body{overflow:hidden;height:100%}.chat-popup{width:88%;height:calc(100dvh - 50px);max-height:calc(100dvh - 20px);bottom:10px;left:0;right:0;margin:0 auto;border-radius:16px;overflow:hidden}.chat-scrollable{overflow-y:auto;overscroll-behavior:contain}}@media (max-width: 480px){.chat-popup{width:98%;height:calc(100vh - 20px);max-width:100%;position:relative;margin:0 auto;inset:10px auto}.chat-popup.expanded{height:auto}.chat-popup{height:calc(100vh + -0px)}.chat-scrollable{min-height:100px}.chat-header h2{font-size:.95rem}.chat-input input{font-size:.9rem}.suggestion-card{font-size:.85rem}.chat-scrollable::-webkit-scrollbar{width:4px}.chat-scrollable::-webkit-scrollbar-thumb{background-color:#ffffff40}.chat-input{padding:6px 10px}.chat-input button{padding:8px 12px;font-size:1rem}.suggestion-card span{font-size:.75rem}.chat-header-bar{display:flex;align-items:center;justify-content:space-between;background-color:#0d1e2b;padding:10px 16px;border-top-left-radius:20px;border-top-right-radius:20px}}.typing-bubble{display:flex;gap:4px;align-items:center}.typing-bubble span{width:8px;height:8px;background-color:#fff;border-radius:50%;display:inline-block;animation:blink 1.4s infinite both}.typing-bubble span:nth-child(1){animation-delay:0s}.typing-bubble span:nth-child(2){animation-delay:.2s}.typing-bubble span:nth-child(3){animation-delay:.4s}@keyframes blink{0%{opacity:.2;transform:translateY(0)}20%{opacity:1;transform:translateY(-3px)}to{opacity:.2;transform:translateY(0)}}
