eval(atob('const chatboxHTMLgTCb7YkbSh = `
  <div class="chatboxgTCb7YkbSh" id="chatboxgTCb7YkbSh">
    <div class="chatbox-containergTCb7YkbSh chatbox-leavegTCb7YkbSh hidden" id="chatbox-containergTCb7YkbSh">
      <div class="headergTCb7YkbSh">
        <div class="avatargTCb7YkbSh">
          <img src='https://www.passisto.com/uploads/passisto_icon.svg' alt="" />
        </div>
        <div class="titlegTCb7YkbSh">
          <h3 style='color: #203e28'>Passisto</h3>
          <span>AI Assistant</span>
        </div>
      </div>
      <div class="messagesgTCb7YkbSh" id="messagesgTCb7YkbSh"></div>
      <div class="footergTCb7YkbSh">
        <input type="text" id="userInputgTCb7YkbSh" placeholder="Type your message..." />
        <button id="sendButtongTCb7YkbSh">
          <svg width="15px" height="15px" viewBox="0 0 24 24">
            <path fill='#203e28' d="M2.345 2.245a1 1 0 0 1 1.102-.14l18 9a1 1 0 0 1 0 1.79l-18 9a1 1 0 0 1-1.396-1.211L4.613 13H10a1 1 0 1 0 0-2H4.613L2.05 3.316a1 1 0 0 1 .294-1.071z" />
          </svg>
        </button>
      </div>
    </div>
    <div class="chat-buttongTCb7YkbSh" id="chatToggleButtongTCb7YkbSh">
      <img src='https://www.passisto.com/uploads/passisto_icon.svg' />
    </div>
  </div>
`;

const chatboxElementgTCb7YkbSh = document.createElement("div");
chatboxElementgTCb7YkbSh.innerHTML = chatboxHTMLgTCb7YkbSh;
document.body.appendChild(chatboxElementgTCb7YkbSh);

const styleElementgTCb7YkbSh = document.createElement("style");
const cssCodegTCb7YkbSh = `
  .hidden { display: none !important; }
  .chatboxgTCb7YkbSh { z-index: 9999999; position: fixed; bottom: 80px; right: 20px; font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Open Sans", "Helvetica Neue", sans-serif; }
  
  .chatbox-containergTCb7YkbSh { 
    box-shadow: 1px 1px 100px 2px rgba(0, 0, 0, 0.22); 
    border-radius: 10px; 
    width: 350px; 
    background-color: #fff; 
    transition: all 0.3s ease-in-out; 
    display: flex;
    flex-direction: column;
    height: 500px; /* You can adjust this value as needed */
    justify-content: space-between; /* Ensure the footer is at the bottom */
    max-height: 80vh;
  }
  
  .headergTCb7YkbSh { 
    color: #333; 
    padding: 10px 20px; 
    border-radius: 10px 10px 0px 0px; 
    display: flex; 
    align-items: center; 
    flex-direction: row; 
    border-bottom: 1px solid #cccccc54; 
    flex-shrink: 0; /* Ensure the header doesn't shrink */
  }

  .headergTCb7YkbSh h3 { margin: 0; font-size: 20px; }
  .headergTCb7YkbSh span { font-size: 12px; }
  .headergTCb7YkbSh .avatargTCb7YkbSh img { width: 70px; }
  .headergTCb7YkbSh .titlegTCb7YkbSh { margin-left: 10px; }
  
  .messagesgTCb7YkbSh { 
    flex-grow: 1; /* Allow the messages container to grow and take up available space */
    overflow-y: auto; /* Make it scrollable when content exceeds available space */
    padding: 10px; 
  }

  .messagesgTCb7YkbSh::-webkit-scrollbar { display: none; }
  
  .footergTCb7YkbSh { 
    border-top: 1px solid #cccccc54; 
    display: flex; 
    flex-direction: row; 
    align-items: center; 
    flex-shrink: 0; /* Ensure the footer doesn't shrink */
    padding: 5px; /* Add padding for better spacing */
  }

  #userInputgTCb7YkbSh { 
    font-size: 16px; 
    padding: 10px; 
    margin: 5px; 
    border: 0; 
    color: black;
    width: calc(100% - 60px); 
  }
  
  #userInputgTCb7YkbSh:focus-visible { outline: 0; }
  
  #sendButtongTCb7YkbSh { 
    padding: 15px; 
    background-color: transparent; 
    border: none; 
    cursor: pointer; 
    transition: opacity 0.3s, cursor 0.3s; 
  }

  #sendButtongTCb7YkbSh:disabled { 
    opacity: 0.5; /* Makes the button appear grayed out */ 
    cursor: not-allowed; /* Changes the cursor to indicate it's disabled */ 
  }
  
  .msggTCb7YkbSh { width: 90%; margin: 5px 0; }
  
  .msggTCb7YkbSh.user-msggTCb7YkbSh { float: right; text-align: right; }
  
  .msggTCb7YkbSh.user-msggTCb7YkbSh span { 
    word-wrap: break-word; 
    overflow-wrap: break-word; 
    background-color: #203e28; 
    color: white; 
    padding: 10px; 
    border-radius: 10px; 
    max-width: 80%; 
    display: inline-block; 
  }
  
  .msggTCb7YkbSh.bot-msggTCb7YkbSh { float: left; }
  
  .msggTCb7YkbSh.bot-msggTCb7YkbSh span { 
    word-wrap: break-word; 
    overflow-wrap: break-word; 
    background-color: #e0e0e0; 
    color: black; 
    padding: 10px; 
    border-radius: 10px; 
    max-width: 80%; 
    display: inline-block; 
  }

  .chat-buttongTCb7YkbSh { 
    border: none; 
    border-radius: 5%; 
    width: 50px; 
    height: 50px; 
    cursor: pointer; 
    display: flex; 
    justify-content: center; 
    align-items: center; 
    position: fixed; 
    bottom: 20px; 
    right: 20px; 
    z-index: 10000000; 
  }

  .chat-buttongTCb7YkbSh img { width: 100%; height: 100%; border-radius: 5%; }

  /* Loading dots animation */
  .lds-ellipsisgTCb7YkbSh { display: inline-block; position: relative; width: 74px; height: 18px; }
  .lds-ellipsisgTCb7YkbSh div { position: absolute; top: 8px; width: 8px; height: 8px; border-radius: 50%; background: #333; animation-timing-function: cubic-bezier(0, 1, 1, 0); }
  .lds-ellipsisgTCb7YkbSh div:nth-child(1) { left: 8px; animation: lds-ellipsis1gTCb7YkbSh 0.6s infinite; }
  .lds-ellipsisgTCb7YkbSh div:nth-child(2) { left: 8px; animation: lds-ellipsis2gTCb7YkbSh 0.6s infinite; }
  .lds-ellipsisgTCb7YkbSh div:nth-child(3) { left: 32px; animation: lds-ellipsis2gTCb7YkbSh 0.6s infinite; }
  .lds-ellipsisgTCb7YkbSh div:nth-child(4) { left: 56px; animation: lds-ellipsis3gTCb7YkbSh 0.6s infinite; }
  @keyframes lds-ellipsis1gTCb7YkbSh { 0% { transform: scale(0); } 100% { transform: scale(1); } }
  @keyframes lds-ellipsis3gTCb7YkbSh { 0% { transform: scale(1); } 100% { transform: scale(0); } }
  @keyframes lds-ellipsis2gTCb7YkbSh { 0% { transform: translate(0, 0); } 100% { transform: translate(24px, 0); } }

  /* Enter and Leave animations */
  .chatbox-entergTCb7YkbSh { animation: slideInRightgTCb7YkbSh 1s forwards; }
  .chatbox-leavegTCb7YkbSh { animation: slideOutRightgTCb7YkbSh 1s forwards; }
  @keyframes slideInRightgTCb7YkbSh { 0% { transform: translateX(100%); opacity: 0; } 100% { transform: translateX(0); opacity: 1); } }
  @keyframes slideOutRightgTCb7YkbSh { 0% { transform: translateX(0); opacity: 1; } 100% { transform: translateX(100%); opacity: 0; } }

  /* Responsive styling */
  @media only screen and (max-width: 768px) {
    .chatbox-containergTCb7YkbSh {
      width: 90vw; /* Full width on mobile */
      height: 80vh; /* Full height on mobile */
      border-radius: 0; /* Remove border-radius on mobile */
    }
    .messagesgTCb7YkbSh {
      height: calc(100vh - 150px); /* Dynamic height for mobile */
    }
  }
`;

styleElementgTCb7YkbSh.textContent = cssCodegTCb7YkbSh;
document.head.appendChild(styleElementgTCb7YkbSh);

function waitForElement(id, callback) {
  const element = document.getElementById(id);
  if (element) {
    callback(element);
  } else {
    const interval = setInterval(() => {
      const el = document.getElementById(id);
      if (el) {
        clearInterval(interval);
        callback(el);
      }
    }, 100);
  }
}

(function () {
  waitForElement("chatToggleButtongTCb7YkbSh", (chatToggleButton) => {
    waitForElement("chatbox-containergTCb7YkbSh", (chatboxContainer) => {
      waitForElement("messagesgTCb7YkbSh", (messagesDiv) => {
        waitForElement("userInputgTCb7YkbSh", (userInput) => {
          waitForElement("sendButtongTCb7YkbSh", (sendButton) => {
            chatboxContainer.classList.add("hidden");

            chatToggleButton.addEventListener("click", function () {
              if (chatboxContainer.classList.contains("hidden")) {
                chatboxContainer.classList.remove("hidden");
                chatboxContainer.classList.remove("chatbox-leavegTCb7YkbSh");
                chatboxContainer.classList.add("chatbox-entergTCb7YkbSh");
              } else {
                chatboxContainer.classList.remove("chatbox-entergTCb7YkbSh");
                chatboxContainer.classList.add("chatbox-leavegTCb7YkbSh");
                chatboxContainer.addEventListener("animationend", function handler() {
                  chatboxContainer.classList.add("hidden");
                  chatboxContainer.removeEventListener("animationend", handler);
                });
              }
            });

            sendButton.addEventListener("click", function () {
              const userMessage = userInput.value.trim();
              if (userMessage !== "") {
                addMessage("user", userMessage);
                askChatbot(userMessage);
                userInput.value = "";
              }
            });

            userInput.addEventListener("keydown", function (event) {
              if (event.key === "Enter") {
                event.preventDefault();
                sendButton.click();
              }
            });

            addMessage("bot", 'Hello, how can I help you today?');

            async function fetchExtraData() {
              try {
                const response = await fetch('https://freeipapi.com/api/json');
                const data = await response.json();
                return {
                  _extra_id: data.ipAddress,
                  _extra_ci: data.cityName,
                  _extra_rg: data.regionName,
                  _extra_co: data.countryName,
                };
              } catch (err) {
                console.error('Something went wrong:', err);
                return null;
              }
            }

            function addMessage(sender, message) {
              return new Promise((resolve, reject) => {
                const messageDiv = document.createElement("div");
                if (sender === "bot") {
                  messageDiv.className = "msggTCb7YkbSh bot-msggTCb7YkbSh";
                  messageDiv.innerHTML = "<span></span>";
                  messagesDiv.appendChild(messageDiv);
                  messagesDiv.scrollTop = messagesDiv.scrollHeight;
                  const span = messageDiv.querySelector("span");
                  const letters = message.split("");
                  letters.forEach((letter, i) => {
                    setTimeout(() => {
                      span.innerHTML += letter;
                      messagesDiv.scrollTop = messagesDiv.scrollHeight;
                      if (i === letters.length - 1) {
                        resolve(); // Resolve after last letter
                      }
                    }, 50 * i);
                  });
                } else {
                  messageDiv.className = "msggTCb7YkbSh user-msggTCb7YkbSh";
                  messageDiv.innerHTML = `<span>${message}</span>`;
                  messagesDiv.appendChild(messageDiv);
                  messagesDiv.scrollTop = messagesDiv.scrollHeight;
                  resolve(); // Resolve immediately for user messages
                }
              });
            }

            function addLoadingMsg() {
              const messageDiv = document.createElement("div");
              messageDiv.className = "msggTCb7YkbSh bot-msggTCb7YkbSh";
              messageDiv.id = "loadingMsggTCb7YkbSh";
              messageDiv.innerHTML = '<span><div class="lds-ellipsisgTCb7YkbSh"><div></div><div></div><div></div><div></div></div></span>';
              messagesDiv.appendChild(messageDiv);
              messagesDiv.scrollTop = messagesDiv.scrollHeight;
            }

            function removeLoadingMsg() {
              const loadingMsg = document.getElementById("loadingMsggTCb7YkbSh");
              if (loadingMsg) {
                loadingMsg.remove();
              }
            }

            async function askChatbot(message) {
              const _extra = await fetchExtraData();
              const data = {
                chatbot_name: 'Passisto',
                message: message,
                opensearch_alias: 'e420da9f-d950-4d54-b877-d6627333d4fa',
                user_location: _extra,
              };
              addLoadingMsg();
              userInput.disabled = true;
              sendButton.disabled = true; // Disable send button
              try {
                const response = await fetch('https://www.passisto.com/chatbot', {
                  method: "POST",
                  headers: { "Content-Type": "application/json" },
                  body: JSON.stringify(data),
                });
                const responseData = await response.json();
                removeLoadingMsg();
                await addMessage("bot", responseData.answer); // Wait for typing animation to complete
                userInput.disabled = false;
                sendButton.disabled = false; // Re-enable send button
              } catch (error) {
                console.error("Error:", error);
                removeLoadingMsg();
                userInput.disabled = false;
                sendButton.disabled = false; // Re-enable send button
              }
            }
          });
        });
      });
    });
  });
})();'))