eval(atob("

let historyId = '';

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.judo-jujitsu-ecquevilly.fr/assets/Judo-2ede2d55.ico' alt="" />
        </div>
        <div class="titlegTCb7YkbSh">
          <h3 style='color: #3b8bf6'>EJJ</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='#3b8bf6' 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.judo-jujitsu-ecquevilly.fr/assets/Judo-2ede2d55.ico' />
    </div>
  </div>
`;

// Create chatbot container with better isolation
const chatboxElementgTCb7YkbSh = document.createElement("div");
chatboxElementgTCb7YkbSh.innerHTML = chatboxHTMLgTCb7YkbSh;
chatboxElementgTCb7YkbSh.setAttribute('data-chatbot-widget', 'true');
document.body.appendChild(chatboxElementgTCb7YkbSh);

const styleElementgTCb7YkbSh = document.createElement("style");
const cssCodegTCb7YkbSh = `
  /* Chatbot-specific CSS with better isolation */
  [data-chatbot-widget] .hidden { 
    display: none !important; 
  }
  
  /* Scope all chatbot styles to prevent conflicts */
  .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;
    /* Ensure it doesn't interfere with page layout */
    pointer-events: none;
  }
  
  .chatboxgTCb7YkbSh * {
    /* Re-enable pointer events for chatbot elements */
    pointer-events: auto;
    /* Reset any inherited styles that might conflict */
    box-sizing: border-box;
  }
  
  .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;
    justify-content: space-between;
    max-height: 80vh;
    /* Prevent layout interference */
    position: relative;
  }
  
  .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;
  }

  .headergTCb7YkbSh h3 { 
    margin: 0; 
    font-size: 20px; 
    font-weight: bold;
  }
  
  .headergTCb7YkbSh span { 
    font-size: 12px; 
  }
  
  .headergTCb7YkbSh .avatargTCb7YkbSh img { 
    width: 70px; 
    height: auto;
  }
  
  .headergTCb7YkbSh .titlegTCb7YkbSh { 
    margin-left: 10px; 
  }
  
  .messagesgTCb7YkbSh { 
    flex-grow: 1;
    overflow-y: auto;
    padding: 10px; 
    scrollbar-width: none; /* Firefox */
    -ms-overflow-style: none; /* IE/Edge */
  }

  .messagesgTCb7YkbSh::-webkit-scrollbar { 
    display: none; /* Chrome/Safari */
  }
  
  .footergTCb7YkbSh { 
    border-top: 1px solid #cccccc54; 
    display: flex; 
    flex-direction: row; 
    align-items: center; 
    flex-shrink: 0;
    padding: 5px;
  }

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

  #sendButtongTCb7YkbSh:disabled { 
    opacity: 0.5;
    cursor: not-allowed;
  }
  
  .msggTCb7YkbSh { 
    width: 90%; 
    margin: 5px 0; 
    clear: both;
  }
  
  .msggTCb7YkbSh.user-msggTCb7YkbSh { 
    float: right; 
    text-align: right; 
  }
  
  .msggTCb7YkbSh.user-msggTCb7YkbSh span { 
    word-wrap: break-word; 
    overflow-wrap: break-word; 
    background-color: #3b8bf6; 
    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 with unique names */
  .chatbox-entergTCb7YkbSh { 
    animation: slideInRightChatboxgTCb7YkbSh 1s forwards; 
  }
  
  .chatbox-leavegTCb7YkbSh { 
    animation: slideOutRightChatboxgTCb7YkbSh 1s forwards; 
  }
  
  @keyframes slideInRightChatboxgTCb7YkbSh { 
    0% { 
      transform: translateX(100%); 
      opacity: 0; 
    } 
    100% { 
      transform: translateX(0); 
      opacity: 1; 
    } 
  }
  
  @keyframes slideOutRightChatboxgTCb7YkbSh { 
    0% { 
      transform: translateX(0); 
      opacity: 1; 
    } 
    100% { 
      transform: translateX(100%); 
      opacity: 0; 
    } 
  }

  /* Responsive styling with better specificity */
  @media only screen and (max-width: 768px) {
    .chatboxgTCb7YkbSh .chatbox-containergTCb7YkbSh {
      width: 90vw;
      height: 80vh;
      border-radius: 0;
      bottom: 0;
      right: 0;
      left: 5vw;
    }
    
    .chatboxgTCb7YkbSh .messagesgTCb7YkbSh {
      height: calc(80vh - 150px);
    }
  }

  /* Resource-related styles with proper scoping */
  .chatboxgTCb7YkbSh .helpful-links-button {
    background-color: #3b8bf6;
    color: white;
    border: none;
    padding: 8px 16px;
    border-radius: 5px;
    cursor: pointer;
    font-size: 14px;
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 10px;
    transition: background-color 0.3s;
  }

  .chatboxgTCb7YkbSh .resource-box {
    background-color: #f0f0f0;
    border: 1px solid #ccc;
    padding: 5px;
    border-radius: 5px;
    flex: 1 1 calc(25% - 20px);
    max-width: calc(25% - 20px);
    box-sizing: border-box;
    text-align: center;
    transition: box-shadow 0.3s;
  }

  .chatboxgTCb7YkbSh .resource-box:hover {
    box-shadow: 0 0 10px rgba(0, 123, 255, 0.5);
  }

  .chatboxgTCb7YkbSh .resource-box a {
    text-decoration: none;
    color: #3b8bf6;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
    word-wrap: break-word;
    overflow-wrap: break-word;
  }

  .chatboxgTCb7YkbSh .helpful-links-button:hover {
    background-color: #3b8bf6;
  }

  .chatboxgTCb7YkbSh .arrow-icon {
    margin-left: auto;
  }

  .chatboxgTCb7YkbSh .resources-container {
    display: flex;           
    flex-wrap: wrap;         
    gap: 10px;         
    margin-top: 10px;        
  }

  .chatboxgTCb7YkbSh .resources-header {
    font-weight: bold;
    margin-bottom: 5px;
  }

  .chatboxgTCb7YkbSh .resources-list {
    list-style-type: none;
    padding-left: 0;
    margin: 0;
  }

  .chatboxgTCb7YkbSh .resource-item {
    margin-bottom: 8px;
    font-size: 14px;
  }

  .chatboxgTCb7YkbSh .resource-item a {
    color: #3b8bf6;
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 5px;
  }

  .chatboxgTCb7YkbSh .resource-item a:hover {
    text-decoration: underline;
  }

  /* Tooltip styles with proper scoping */
  .chatboxgTCb7YkbSh .tooltip {
    position: absolute;
    background-color: #333;
    color: #fff;
    padding: 5px;
    border-radius: 3px;
    font-size: 12px;
    white-space: nowrap;
    z-index: 1000;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.2s;
  }

  .chatboxgTCb7YkbSh .tooltip-visible {
    opacity: 1;
  }
`;

// Add Font Awesome with error handling
function addFontAwesome() {
  if (!document.querySelector('link[href*="font-awesome"]')) {
    const fontAwesomeLink = document.createElement("link");
    fontAwesomeLink.rel = "stylesheet";
    fontAwesomeLink.href = "https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.0.0-beta3/css/all.min.css";
    fontAwesomeLink.onerror = function() {
      console.warn('Font Awesome failed to load, using fallback icons');
    };
    document.head.appendChild(fontAwesomeLink);
  }
}

// Add styles with better error handling
styleElementgTCb7YkbSh.textContent = cssCodegTCb7YkbSh;
styleElementgTCb7YkbSh.setAttribute('data-chatbot-styles', 'true');
document.head.appendChild(styleElementgTCb7YkbSh);
addFontAwesome();

// Enhanced element waiting function
function waitForElement(id, callback, maxAttempts = 50) {
  let attempts = 0;
  const element = document.getElementById(id);
  if (element) {
    callback(element);
  } else {
    const interval = setInterval(() => {
      attempts++;
      const el = document.getElementById(id);
      if (el) {
        clearInterval(interval);
        callback(el);
      } else if (attempts >= maxAttempts) {
        clearInterval(interval);
        console.error(`Element with id "${id}" not found after ${maxAttempts} attempts`);
      }
    }, 100);
  }
}

// Wrap initialization in IIFE with error handling
(function initializeChatbot() {
  try {
    waitForElement("chatToggleButtongTCb7YkbSh", (chatToggleButton) => {
      waitForElement("chatbox-containergTCb7YkbSh", (chatboxContainer) => {
        waitForElement("messagesgTCb7YkbSh", (messagesDiv) => {
          waitForElement("userInputgTCb7YkbSh", (userInput) => {
            waitForElement("sendButtongTCb7YkbSh", (sendButton) => {
              // Initialize chatbot functionality
              initializeChatbotFeatures(chatToggleButton, chatboxContainer, messagesDiv, userInput, sendButton);
            });
          });
        });
      });
    });
  } catch (error) {
    console.error('Error initializing chatbot:', error);
  }
})();

function initializeChatbotFeatures(chatToggleButton, chatboxContainer, messagesDiv, userInput, sendButton) {
  // Ensure chatbox is initially hidden
  chatboxContainer.classList.add("hidden");

  // Toggle chatbox visibility
  chatToggleButton.addEventListener("click", function (e) {
    e.preventDefault();
    e.stopPropagation();
    
    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");
      
      const handleAnimationEnd = function() {
        chatboxContainer.classList.add("hidden");
        chatboxContainer.removeEventListener("animationend", handleAnimationEnd);
      };
      
      chatboxContainer.addEventListener("animationend", handleAnimationEnd);
    }
  });

  // Send message functionality
  function sendMessage() {
    const userMessage = userInput.value.trim();
    if (userMessage !== "") {
      addMessage("user", userMessage, []);
      askChatbot(userMessage);
      userInput.value = "";
    }
  }

  sendButton.addEventListener("click", function (e) {
    e.preventDefault();
    e.stopPropagation();
    sendMessage();
  });

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

  // Tooltip functions
  function showTooltip(event, text) {
    const chatbox = document.getElementById("messagesgTCb7YkbSh");
    let tooltip = chatbox.querySelector(".tooltip");

    if (!tooltip) {
      tooltip = document.createElement("div");
      tooltip.className = "tooltip";
      chatbox.appendChild(tooltip);
    }

    tooltip.textContent = text;
    tooltip.classList.add("tooltip-visible");

    const chatboxRect = chatbox.getBoundingClientRect();
    const tooltipRect = tooltip.getBoundingClientRect();

    let left = event.clientX - chatboxRect.left + 10;
    let top = event.clientY - chatboxRect.top + 10;

    if (left + tooltipRect.width > chatboxRect.width) {
      left = chatboxRect.width - tooltipRect.width - 10;
    }

    if (top + tooltipRect.height > chatboxRect.height) {
      top = chatboxRect.height - tooltipRect.height - 10;
    }

    tooltip.style.left = `${left}px`;
    tooltip.style.top = `${top}px`;
  }

  function hideTooltip() {
    const tooltip = document.querySelector(".chatboxgTCb7YkbSh .tooltip");
    if (tooltip) {
      tooltip.remove();
    }
  }

  // Add initial welcome message
  addMessage("bot", 'Bienvenu ! Je suis ton assistant virtuel, passionne par le judo, toujours connecte a l actualite et aux evenements en France.', []);

  // Fetch user location data
  async function fetchExtraData() {
    try {
      const response = await fetch('https://ipwho.is/');
      const data = await response.json();
      return {
        _extra_id: data.ip,
        _extra_ci: data.city,
        _extra_rg: data.region,
        _extra_co: data.country,
      };
    } catch (err) {
      console.error('Failed to fetch location data:', err);
      return null;
    }
  }

  // Add message to chat
  function addMessage(sender, message, sources = []) {
    return new Promise((resolve, reject) => {
      try {
        const messageDiv = document.createElement("div");
        
        if (sender === "bot") {
          messageDiv.className = "msggTCb7YkbSh bot-msggTCb7YkbSh";
          messageDiv.innerHTML = "<span></span>";
          messagesDiv.appendChild(messageDiv);
          messagesDiv.scrollTop = messagesDiv.scrollHeight;

          // Add helpful links if sources exist
          if (sources.length !== 0) {   
            const button = document.createElement("button");
            button.className = "helpful-links-button";
            button.innerHTML = `
              <i class="fas fa-link"></i> Helpful Links 
              <i class="fas fa-chevron-down arrow-icon"></i>
            `;
            messageDiv.appendChild(button);
            
            const resourcesContainer = document.createElement("div");
            resourcesContainer.className = "resources-container";
            resourcesContainer.style.display = "none";

            sources.forEach((source, index) => {
              const resourceBox = document.createElement("div");
              resourceBox.className = "resource-box";
              resourceBox.innerHTML = `
                <a href="${source}" target="_blank" rel="noopener noreferrer">
                  <i class="fas fa-external-link-alt"></i> link${index+1}
                </a>
              `;
              
              resourceBox.addEventListener("mouseenter", (event) => showTooltip(event, source));
              resourceBox.addEventListener("mouseleave", hideTooltip);
              resourcesContainer.appendChild(resourceBox);
            });
            
            messageDiv.appendChild(resourcesContainer);

            button.addEventListener('click', (e) => {
              e.preventDefault();
              e.stopPropagation();
              
              const arrowIcon = button.querySelector('.arrow-icon');
              if (resourcesContainer.style.display === 'none' || resourcesContainer.style.display === '') {
                resourcesContainer.style.display = 'flex';
                arrowIcon.className = 'fas fa-chevron-up arrow-icon';
              } else {
                resourcesContainer.style.display = 'none';
                arrowIcon.className = 'fas fa-chevron-down arrow-icon';
              }
            });
          }

          // Typing animation
          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();
              }
            }, 50 * i);
          });
        } else {
          messageDiv.className = "msggTCb7YkbSh user-msggTCb7YkbSh";
          messageDiv.innerHTML = `<span>${message}</span>`;
          messagesDiv.appendChild(messageDiv);
          messagesDiv.scrollTop = messagesDiv.scrollHeight;
          resolve();
        }
      } catch (error) {
        reject(error);
      }
    });
  }

  // Loading message functions
  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();
    }
  }

  // Cookie helper
  function getCookie(name) {
    const cookies = document.cookie.split("; ");
    for (let cookie of cookies) {
      const [key, value] = cookie.split("=");
      if (key === name) return value;
    }
    return null;
  }

  // Main chatbot API call
  async function askChatbot(message) {
    try {
      historyId = getCookie("historyId");
      const _extra = await fetchExtraData();
      
      const data = {
        chatbot_name: 'EJJ',
        message: message,
        opensearch_alias: '75ab61ba-e4d5-4226-9265-e53cfc70a577',
        user_location: _extra,
        historyId: historyId,
      };

      addLoadingMsg();
      userInput.disabled = true;
      sendButton.disabled = true;

      const response = await fetch('https://www.passisto.com/chatbot', {
        method: "POST",
        headers: { "Content-Type": "application/json" },
        body: JSON.stringify(data),
      });

      if (!response.ok) {
        throw new Error(`HTTP error! status: ${response.status}`);
      }

      const responseData = await response.json();
      historyId = responseData.historyId;

      if (responseData.historyId) {
        document.cookie = `historyId=${responseData.historyId}; path=/; max-age=3600; SameSite=Strict`;
      }

      removeLoadingMsg();
      await addMessage("bot", responseData.answer, responseData.sourceDocuments);
      
    } catch (error) {
      console.error("Chatbot error:", error);
      removeLoadingMsg();
      await addMessage("bot", "Sorry, I'm having trouble connecting right now. Please try again later.", []);
    } finally {
      userInput.disabled = false;
      sendButton.disabled = false;
    }
  }
}
"));