// Utility function
function Util() {}

/* 
	class manipulation functions
*/
Util.hasClass = function (el, className) {
  if (el.classList) return el.classList.contains(className);
  else
    return !!el.className.match(new RegExp("(\\s|^)" + className + "(\\s|$)"));
};

Util.addClass = function (el, className) {
  var classList = className.split(" ");
  if (el.classList) el.classList.add(classList[0]);
  else if (!Util.hasClass(el, classList[0])) el.className += " " + classList[0];
  if (classList.length > 1) Util.addClass(el, classList.slice(1).join(" "));
};

Util.removeClass = function (el, className) {
  var classList = className.split(" ");
  if (el.classList) el.classList.remove(classList[0]);
  else if (Util.hasClass(el, classList[0])) {
    var reg = new RegExp("(\\s|^)" + classList[0] + "(\\s|$)");
    el.className = el.className.replace(reg, " ");
  }
  if (classList.length > 1) Util.removeClass(el, classList.slice(1).join(" "));
};

Util.toggleClass = function (el, className, bool) {
  if (bool) Util.addClass(el, className);
  else Util.removeClass(el, className);
};

Util.setAttributes = function (el, attrs) {
  for (var key in attrs) {
    el.setAttribute(key, attrs[key]);
  }
};

/* 
  DOM manipulation
*/
Util.getChildrenByClassName = function (el, className) {
  var children = el.children,
    childrenByClass = [];
  for (var i = 0; i < el.children.length; i++) {
    if (Util.hasClass(el.children[i], className))
      childrenByClass.push(el.children[i]);
  }
  return childrenByClass;
};

Util.is = function (elem, selector) {
  if (selector.nodeType) {
    return elem === selector;
  }

  var qa =
      typeof selector === "string"
        ? document.querySelectorAll(selector)
        : selector,
    length = qa.length,
    returnArr = [];

  while (length--) {
    if (qa[length] === elem) {
      return true;
    }
  }

  return false;
};

/* 
	Animate height of an element
*/
Util.setHeight = function (start, to, element, duration, cb) {
  var change = to - start,
    currentTime = null;

  var animateHeight = function (timestamp) {
    if (!currentTime) currentTime = timestamp;
    var progress = timestamp - currentTime;
    var val = parseInt((progress / duration) * change + start);
    element.style.height = val + "px";
    if (progress < duration) {
      window.requestAnimationFrame(animateHeight);
    } else {
      cb();
    }
  };

  //set the height of the element before starting animation -> fix bug on Safari
  element.style.height = start + "px";
  window.requestAnimationFrame(animateHeight);
};

/* 
	Smooth Scroll
*/

Util.scrollTo = function (final, duration, cb, scrollEl) {
  var element = scrollEl || window;
  var start = element.scrollTop || document.documentElement.scrollTop,
    currentTime = null;

  if (!scrollEl) start = window.scrollY || document.documentElement.scrollTop;

  var animateScroll = function (timestamp) {
    if (!currentTime) currentTime = timestamp;
    var progress = timestamp - currentTime;
    if (progress > duration) progress = duration;
    var val = Math.easeInOutQuad(progress, start, final - start, duration);
    element.scrollTo(0, val);
    if (progress < duration) {
      window.requestAnimationFrame(animateScroll);
    } else {
      cb && cb();
    }
  };

  window.requestAnimationFrame(animateScroll);
};

/* 
  Focus utility classes
*/

//Move focus to an element
Util.moveFocus = function (element) {
  if (!element) element = document.getElementsByTagName("body")[0];
  element.focus();
  if (document.activeElement !== element) {
    element.setAttribute("tabindex", "-1");
    element.focus();
  }
};

/* 
  Misc
*/

Util.getIndexInArray = function (array, el) {
  return Array.prototype.indexOf.call(array, el);
};

Util.cssSupports = function (property, value) {
  if ("CSS" in window) {
    return CSS.supports(property, value);
  } else {
    var jsProperty = property.replace(/-([a-z])/g, function (g) {
      return g[1].toUpperCase();
    });
    return jsProperty in document.body.style;
  }
};

// merge a set of user options into plugin defaults
// https://gomakethings.com/vanilla-javascript-version-of-jquery-extend/
Util.extend = function () {
  // Variables
  var extended = {};
  var deep = false;
  var i = 0;
  var length = arguments.length;

  // Check if a deep merge
  if (Object.prototype.toString.call(arguments[0]) === "[object Boolean]") {
    deep = arguments[0];
    i++;
  }

  // Merge the object into the extended object
  var merge = function (obj) {
    for (var prop in obj) {
      if (Object.prototype.hasOwnProperty.call(obj, prop)) {
        // If deep merge and property is an object, merge properties
        if (
          deep &&
          Object.prototype.toString.call(obj[prop]) === "[object Object]"
        ) {
          extended[prop] = extend(true, extended[prop], obj[prop]);
        } else {
          extended[prop] = obj[prop];
        }
      }
    }
  };

  // Loop through each object and conduct a merge
  for (; i < length; i++) {
    var obj = arguments[i];
    merge(obj);
  }

  return extended;
};

// Check if Reduced Motion is enabled
Util.osHasReducedMotion = function () {
  if (!window.matchMedia) return false;
  var matchMediaObj = window.matchMedia("(prefers-reduced-motion: reduce)");
  if (matchMediaObj) return matchMediaObj.matches;
  return false; // return false if not supported
};

/* 
	Polyfills
*/
//Closest() method
if (!Element.prototype.matches) {
  Element.prototype.matches =
    Element.prototype.msMatchesSelector ||
    Element.prototype.webkitMatchesSelector;
}

if (!Element.prototype.closest) {
  Element.prototype.closest = function (s) {
    var el = this;
    if (!document.documentElement.contains(el)) return null;
    do {
      if (el.matches(s)) return el;
      el = el.parentElement || el.parentNode;
    } while (el !== null && el.nodeType === 1);
    return null;
  };
}

//Custom Event() constructor
if (typeof window.CustomEvent !== "function") {
  function CustomEvent(event, params) {
    params = params || { bubbles: false, cancelable: false, detail: undefined };
    var evt = document.createEvent("CustomEvent");
    evt.initCustomEvent(
      event,
      params.bubbles,
      params.cancelable,
      params.detail
    );
    return evt;
  }

  CustomEvent.prototype = window.Event.prototype;

  window.CustomEvent = CustomEvent;
}

/* 
	Animation curves
*/
Math.easeInOutQuad = function (t, b, c, d) {
  t /= d / 2;
  if (t < 1) return (c / 2) * t * t + b;
  t--;
  return (-c / 2) * (t * (t - 2) - 1) + b;
};

Math.easeInQuart = function (t, b, c, d) {
  t /= d;
  return c * t * t * t * t + b;
};

Math.easeOutQuart = function (t, b, c, d) {
  t /= d;
  t--;
  return -c * (t * t * t * t - 1) + b;
};

Math.easeInOutQuart = function (t, b, c, d) {
  t /= d / 2;
  if (t < 1) return (c / 2) * t * t * t * t + b;
  t -= 2;
  return (-c / 2) * (t * t * t * t - 2) + b;
};

Math.easeOutElastic = function (t, b, c, d) {
  var s = 1.70158;
  var p = d * 0.7;
  var a = c;
  if (t == 0) return b;
  if ((t /= d) == 1) return b + c;
  if (!p) p = d * 0.3;
  if (a < Math.abs(c)) {
    a = c;
    var s = p / 4;
  } else var s = (p / (2 * Math.PI)) * Math.asin(c / a);
  return (
    a * Math.pow(2, -10 * t) * Math.sin(((t * d - s) * (2 * Math.PI)) / p) +
    c +
    b
  );
};

/* JS Utility Classes */
(function () {
  // make focus ring visible only for keyboard navigation (i.e., tab key)
  var focusTab = document.getElementsByClassName("js-tab-focus");
  function detectClick() {
    if (focusTab.length > 0) {
      resetFocusTabs(false);
      window.addEventListener("keydown", detectTab);
    }
    window.removeEventListener("mousedown", detectClick);
  }

  function detectTab(event) {
    if (event.keyCode !== 9) return;
    resetFocusTabs(true);
    window.removeEventListener("keydown", detectTab);
    window.addEventListener("mousedown", detectClick);
  }

  function resetFocusTabs(bool) {
    var outlineStyle = bool ? "" : "none";
    for (var i = 0; i < focusTab.length; i++) {
      focusTab[i].style.setProperty("outline", outlineStyle);
    }
  }
  window.addEventListener("mousedown", detectClick);
})();
// File#: _1_accordion
// Usage: codyhouse.co/license
(function () {
  var Accordion = function (element) {
    this.element = element;
    this.items = Util.getChildrenByClassName(
      this.element,
      "js-accordion__item"
    );
    this.version = this.element.getAttribute("data-version")
      ? "-" + this.element.getAttribute("data-version")
      : "";
    this.showClass = "accordion" + this.version + "__item--is-open";
    this.animateHeight = this.element.getAttribute("data-animation") == "on";
    this.multiItems = !(this.element.getAttribute("data-multi-items") == "off");
    this.initAccordion();
  };

  Accordion.prototype.initAccordion = function () {
    //set initial aria attributes
    for (var i = 0; i < this.items.length; i++) {
      var button = this.items[i].getElementsByTagName("button")[0],
        content = this.items[i].getElementsByClassName(
          "js-accordion__panel"
        )[0],
        isOpen = Util.hasClass(this.items[i], this.showClass)
          ? "true"
          : "false";
      Util.setAttributes(button, {
        "aria-expanded": isOpen,
        "aria-controls": "accordion-content-" + i,
        id: "accordion-header-" + i,
      });
      Util.addClass(button, "js-accordion__trigger");
      Util.setAttributes(content, {
        "aria-labelledby": "accordion-header-" + i,
        id: "accordion-content-" + i,
      });
    }

    //listen for Accordion events
    this.initAccordionEvents();
  };

  Accordion.prototype.initAccordionEvents = function () {
    var self = this;

    this.element.addEventListener("click", function (event) {
      var trigger = event.target.closest(".js-accordion__trigger");
      //check index to make sure the click didn't happen inside a children accordion
      if (
        trigger &&
        Util.getIndexInArray(self.items, trigger.parentElement) >= 0
      )
        self.triggerAccordion(trigger);
    });
  };

  Accordion.prototype.triggerAccordion = function (trigger) {
    var self = this;
    var bool = trigger.getAttribute("aria-expanded") === "true";

    this.animateAccordion(trigger, bool);
  };

  Accordion.prototype.animateAccordion = function (trigger, bool) {
    var self = this;
    var item = trigger.closest(".js-accordion__item"),
      content = item.getElementsByClassName("js-accordion__panel")[0],
      ariaValue = bool ? "false" : "true";

    if (!bool) Util.addClass(item, this.showClass);
    trigger.setAttribute("aria-expanded", ariaValue);
    self.resetContentVisibility(item, content, bool);

    if (!this.multiItems && !bool) this.closeSiblings(item);
  };

  Accordion.prototype.resetContentVisibility = function (item, content, bool) {
    Util.toggleClass(item, this.showClass, !bool);
    content.removeAttribute("style");
    if (bool && !this.multiItems) {
      // accordion item has been closed -> check if there's one open to move inside viewport
      this.moveContent();
    }
  };

  Accordion.prototype.closeSiblings = function (item) {
    //if only one accordion can be open -> search if there's another one open
    var index = Util.getIndexInArray(this.items, item);
    for (var i = 0; i < this.items.length; i++) {
      if (Util.hasClass(this.items[i], this.showClass) && i != index) {
        this.animateAccordion(
          this.items[i].getElementsByClassName("js-accordion__trigger")[0],
          true
        );
        return false;
      }
    }
  };

  Accordion.prototype.moveContent = function () {
    // make sure title of the accordion just opened is inside the viewport
    var openAccordion = this.element.getElementsByClassName(this.showClass);
    if (openAccordion.length == 0) return;
    var boundingRect = openAccordion[0].getBoundingClientRect();
    if (boundingRect.top < 0 || boundingRect.top > window.innerHeight) {
      var windowScrollTop =
        window.scrollY || document.documentElement.scrollTop;
      window.scrollTo(0, boundingRect.top + windowScrollTop);
    }
  };

  window.Accordion = Accordion;

  //initialize the Accordion objects
  var accordions = document.getElementsByClassName("js-accordion");
  if (accordions.length > 0) {
    for (var i = 0; i < accordions.length; i++) {
      (function (i) {
        new Accordion(accordions[i]);
      })(i);
    }
  }
})();

// File#: _1_alert
// Usage: codyhouse.co/license
(function () {
  var alertClose = document.getElementsByClassName("js-alert__close-btn");
  if (alertClose.length > 0) {
    for (var i = 0; i < alertClose.length; i++) {
      (function (i) {
        initAlertEvent(alertClose[i]);
      })(i);
    }
  }
})();

function initAlertEvent(element) {
  element.addEventListener("click", function (event) {
    event.preventDefault();
    Util.removeClass(element.closest(".js-alert"), "alert--is-visible");
  });
}

// File#: _1_choice-accordion
// Usage: codyhouse.co/license
(function () {
  var ChoiceAccordion = function (element) {
    this.element = element;
    this.btns = this.element.getElementsByClassName("js-choice-accordion__btn");
    this.inputs = getChoiceInput(this);
    this.contents = getChoiceContent(this);
    this.isRadio = this.inputs[0].type == "radio";
    this.animateHeight = this.element.getAttribute("data-animation") == "on";
    initAccordion(this);
    resetCheckedStatus(this, false); // set initial classes
    initChoiceAccordionEvent(this); // add listeners
  };

  function getChoiceInput(element) {
    // store input elements in an object property
    var inputs = [],
      fallbacks = element.element.getElementsByClassName(
        "js-choice-accordion__fallback"
      );
    for (var i = 0; i < fallbacks.length; i++) {
      inputs.push(fallbacks[i].getElementsByTagName("input")[0]);
    }
    return inputs;
  }

  function getChoiceContent(element) {
    // store content elements in an object property
    var contents = [];
    for (var i = 0; i < element.btns.length; i++) {
      var content = Util.getChildrenByClassName(
        element.btns[i].parentNode,
        "js-choice-accordion__panel"
      );
      if (content.length > 0) contents.push(content[0]);
      else contents.push(false);
    }
    return contents;
  }

  function initAccordion(element) {
    //set initial aria attributes
    for (var i = 0; i < element.inputs.length; i++) {
      if (!element.contents[i]) return; // no content to trigger
      var isOpen = element.inputs[i].checked,
        id = element.inputs[i].getAttribute("id");
      if (!id) id = "choice-accordion-header-" + i;

      Util.setAttributes(element.inputs[i], {
        "aria-expanded": isOpen,
        "aria-controls": "choice-accordion-content-" + i,
        id: id,
      });
      Util.setAttributes(element.contents[i], {
        "aria-labelledby": id,
        id: "choice-accordion-content-" + i,
      });
      Util.toggleClass(element.contents[i], "is-hidden", !isOpen);
    }
  }

  let lastAccordionPrice = 0;
  let lastSelecPrice = 0;
  function initChoiceAccordionEvent(choiceAcc) {
    choiceAcc.element.addEventListener("click", function (event) {

      console.log(choiceAcc);
      let accordionPrice = 0;
      let lensflowSubtotal = parseFloat(
        document.getElementById("lensflow_subtotal").innerText.split("$")[1]
      );
      for (let i = 0; i < choiceAcc.inputs.length; i++) {
        console.log(choiceAcc.inputs[0].checked);
      }
        if (event.target.tagName === "SPAN") {
          var priceText;
          var selectBox;
          if (event.target.classList.contains("lens_coating_tints_price")) {
            priceText = event.target.innerText;
            selectBox = event.target.parentNode.parentNode.parentNode;
          } else {
            priceText = event.target.childNodes[1].innerText;
            selectBox = event.target.parentNode.parentNode;
          }
          var isSelectOpen = selectBox.classList.contains(
            "accordion__item--is-open"
          );
          accordionPrice = parseFloat(priceText);
          if (isSelectOpen) {
            lensflowSubtotal =
              lensflowSubtotal + accordionPrice - lastSelecPrice;
            lastSelecPrice = accordionPrice;
          } else {
            lensflowSubtotal = lensflowSubtotal - accordionPrice;
            lastSelecPrice = 0;
          }
          document.getElementById("lensflow_subtotal").innerText =
            "$" + lensflowSubtotal.toFixed(2);
        } else if (event.target.tagName === "BUTTON") {
          priceText = event.target.childNodes[1].childNodes[1].innerText;
          var selectBox = event.target.parentNode;
          var isSelectOpen = selectBox.classList.contains(
            "accordion__item--is-open"
          );
          accordionPrice = parseFloat(priceText);
          if (isSelectOpen) {
            lensflowSubtotal =
              lensflowSubtotal + accordionPrice - lastSelecPrice;
            lastSelecPrice = accordionPrice;
          } else {
            lensflowSubtotal = lensflowSubtotal - accordionPrice;
            lastSelecPrice = 0;
          }
          document.getElementById("lensflow_subtotal").innerText =
            "$" + lensflowSubtotal.toFixed(2);
        }

        // update status on click
      if (Util.getIndexInArray(choiceAcc.inputs, event.target) > -1) return; // triggered by change in input element -> will be detected by the 'change' event
      var selectedBtn = event.target.closest(".js-choice-accordion__btn");
      if (!selectedBtn) return;
      var index = Util.getIndexInArray(choiceAcc.btns, selectedBtn);
      if (choiceAcc.inputs[0].id.includes("check")) {
        choiceAcc.inputs[index].checked = !choiceAcc.inputs[index].checked;
        choiceAcc.inputs[index].dispatchEvent(new CustomEvent("change")); // trigger change event
        choiceAcc.inputs[index].focus(); // move focus to input element
        var lensCheckBoxId = choiceAcc.inputs[index].id;
        var lens_coating_id =
          choiceAcc.inputs[index].getAttribute("data-lens_coating");
        if (lensCheckBoxId == "choice-accordion-check-1") {
          accordionPrice = 29.99;
        } else if (lensCheckBoxId == "choice-accordion-check-2") {
          accordionPrice = 19.99;
        } else if (lensCheckBoxId == "choice-accordion-check-3") {
          accordionPrice = 49.99;
        } else if (lensCheckBoxId == "choice-accordion-check-4") {
          accordionPrice = 39.99;
        } else if (lensCheckBoxId == "choice-accordion-check-5") {
          accordionPrice = 79.99;
        } else if (lensCheckBoxId == "choice-accordion-check-6") {
          accordionPrice = 119.0;
        } else if (lensCheckBoxId == "choice-accordion-check-7") {
          accordionPrice = 49.99;
        } else if (lensCheckBoxId == "choice-accordion-check-8") {
          accordionPrice = 49.99;
        } else {
          accordionPrice = 0;
        }
        if (
          selectedBtn &&
          selectedBtn.classList.contains("choice-accordion__btn--checked")
        ) {
          lensflowSubtotal = lensflowSubtotal + accordionPrice;
        } else {
          lensflowSubtotal = lensflowSubtotal - accordionPrice;
        }
        document.getElementById("lensflow_subtotal").innerText =
          "$" + lensflowSubtotal.toFixed(2);
        document
          .getElementById("lensflow_subtotal")
          .setAttribute("data-lens_coating", lens_coating_id);
        return;
      }

      if (choiceAcc.isRadio && choiceAcc.inputs[index].checked) {
        choiceAcc.inputs[index].checked = !choiceAcc.inputs[index].checked;
        choiceAcc.inputs[index].dispatchEvent(new CustomEvent("change")); // trigger change event
        choiceAcc.inputs[index].blur(); // Remove focus from the input element
        var lensRadioId = choiceAcc.inputs[index].id;
        if (lensRadioId == "choice-accordion-radio-0") {
          accordionPrice = 0;
        } else if (lensRadioId == "choice-accordion-radio-1") {
          accordionPrice = 0;
        } else if (lensRadioId == "choice-accordion-radio-2") {
          accordionPrice = 149.99;
        } else if (lensRadioId == "choice-accordion-radio-3") {
          accordionPrice = 149.99;
        } else if (lensRadioId == "choice-accordion-radio-4") {
          accordionPrice = 29.99;
        } else if (lensRadioId == "choice-accordion-radio-5") {
          accordionPrice = 0;
        } else if (lensRadioId == "choice-accordion-radio-6") {
          accordionPrice = 0;
        } else {
          accordionPrice = 0;
        }
        lastAccordionPrice = 0;

        lensflowSubtotal = lensflowSubtotal - accordionPrice;
        document.getElementById("lensflow_subtotal").innerText =
          "$" + lensflowSubtotal.toFixed(2);
        // radio input already checked
        // choiceAcc.inputs[index].focus(); // move focus to input element
        return;
      }

      var lensRadioId = choiceAcc.inputs[index].id;
      if (lensRadioId == "choice-accordion-radio-0") {
        accordionPrice = 0;
      } else if (lensRadioId == "choice-accordion-radio-1") {
        accordionPrice = 0;
      } else if (lensRadioId == "choice-accordion-radio-2") {
        accordionPrice = 149.99;
      } else if (lensRadioId == "choice-accordion-radio-3") {
        accordionPrice = 149.99;
      } else if (lensRadioId == "choice-accordion-radio-4") {
        accordionPrice = 29.99;
      } else if (lensRadioId == "choice-accordion-radio-5") {
        accordionPrice = 0;
      } else if (lensRadioId == "choice-accordion-radio-6") {
        accordionPrice = 0;
      } else {
        accordionPrice = 0;
      }
      lensflowSubtotal = lensflowSubtotal + accordionPrice - lastAccordionPrice;
      document.getElementById("lensflow_subtotal").innerText =
        "$" + lensflowSubtotal.toFixed(2);
      lastAccordionPrice = accordionPrice;
      choiceAcc.inputs[index].checked = !choiceAcc.inputs[index].checked;
      choiceAcc.inputs[index].dispatchEvent(new CustomEvent("change")); // trigger change event
      choiceAcc.inputs[index].focus(); // move focus to input element
    });

    for (var i = 0; i < choiceAcc.btns.length; i++) {
      (function (i) {
        // change + focus events
        choiceAcc.inputs[i].addEventListener("change", function (event) {
          choiceAcc.isRadio
            ? resetCheckedStatus(choiceAcc, true)
            : resetSingleStatus(choiceAcc, i, true);
        });

        choiceAcc.inputs[i].addEventListener("focus", function (event) {
          resetFocusStatus(choiceAcc, i, true);
        });

        choiceAcc.inputs[i].addEventListener("blur", function (event) {
          resetFocusStatus(choiceAcc, i, false);
        });
      })(i);
    }
  }

  function resetCheckedStatus(choiceAcc, bool) {
    for (var i = 0; i < choiceAcc.btns.length; i++) {
      resetSingleStatus(choiceAcc, i, bool);
    }
  }

  function resetSingleStatus(choiceAcc, index, bool) {
    // toggle .choice-accordion__btn--checked class
    Util.toggleClass(
      choiceAcc.btns[index],
      "choice-accordion__btn--checked",
      choiceAcc.inputs[index].checked
    );
    if (bool)
      resetSingleContent(choiceAcc, index, choiceAcc.inputs[index].checked); // no need to run this when component is initialized
  }

  function resetFocusStatus(choiceAcc, index, bool) {
    // toggle .choice-accordion__btn--focus class
    Util.toggleClass(
      choiceAcc.btns[index],
      "choice-accordion__btn--focus",
      bool
    );
  }

  function resetSingleContent(choiceAcc, index, bool) {
    // show accordion content
    var input = choiceAcc.inputs[index],
      content = choiceAcc.contents[index];

    if (bool && content) Util.removeClass(content, "is-hidden");
    input.setAttribute("aria-expanded", bool);

    if (choiceAcc.animateHeight && content) {
      //store initial and final height - animate accordion content height
      var initHeight = !bool ? content.offsetHeight : 0,
        finalHeight = !bool ? 0 : content.offsetHeight;
    }

    if (
      window.requestAnimationFrame &&
      choiceAcc.animateHeight &&
      !reducedMotion &&
      content
    ) {
      Util.setHeight(initHeight, finalHeight, content, 200, function () {
        resetContentVisibility(content, bool);
      });
    } else {
      resetContentVisibility(content, bool);
    }
  }

  function resetContentVisibility(content, bool) {
    if (!content) return;
    Util.toggleClass(content, "is-hidden", !bool);
    content.removeAttribute("style");
  }

  //initialize the ChoiceAccordions objects
  var choiceAccordion = document.getElementsByClassName("js-choice-accordion"),
    reducedMotion = Util.osHasReducedMotion();
  if (choiceAccordion.length > 0) {
    for (var i = 0; i < choiceAccordion.length; i++) {
      (function (i) {
        new ChoiceAccordion(choiceAccordion[i]);
      })(i);
    }
  }
})();

// File#: _1_choice-images
// Usage: codyhouse.co/license
(function () {
  var ChoiceImgs = function (element) {
    this.element = element;
    this.imgs = this.element.getElementsByClassName("js-choice-img");
    this.isRadio = this.imgs[0].getAttribute("role") == "radio";
    resetChoiceImgs(this); // set initial aria values
    initChoiceImgsEvent(this);
  };

  function initChoiceImgsEvent(choiceImgs) {
    // on click -> select new item
    choiceImgs.element.addEventListener("click", function (event) {
      var selectedImg = event.target.closest(".js-choice-img");
      if (!selectedImg) return;
      var index = Util.getIndexInArray(choiceImgs.imgs, selectedImg);
      if (choiceImgs.isRadio) {
        setRadio(choiceImgs, selectedImg, index);
      } else {
        setCheckbox(choiceImgs, selectedImg, index);
      }
    });

    // keyboard events
    choiceImgs.element.addEventListener("keydown", function (event) {
      var selectedImg = event.target.closest(".js-choice-img");
      if (!selectedImg) return;

      if (
        (event.keyCode && event.keyCode == 32) ||
        (event.key && event.key.toLowerCase() == " ")
      ) {
        // spacebar ->if this is a checkbox choice, toggle the state
        if (choiceImgs.isRadio) return;
        event.preventDefault();
        var index = Util.getIndexInArray(choiceImgs.imgs, selectedImg);
        setCheckbox(choiceImgs, selectedImg, index);
      } else if (
        (event.keyCode && (event.keyCode == 40 || event.keyCode == 39)) ||
        (event.key &&
          (event.key.toLowerCase() == "arrowdown" ||
            event.key.toLowerCase() == "arrowright"))
      ) {
        // arrow right/arrow down
        if (!choiceImgs.isRadio) return;
        event.preventDefault();
        navigateRadioImgs(choiceImgs, 1);
      } else if (
        (event.keyCode && (event.keyCode == 38 || event.keyCode == 37)) ||
        (event.key &&
          (event.key.toLowerCase() == "arrowup" ||
            event.key.toLowerCase() == "arrowleft"))
      ) {
        // arrow left/up down
        if (!choiceImgs.isRadio) return;
        event.preventDefault();
        navigateRadioImgs(choiceImgs, -1);
      }
    });
  }

  function setCheckbox(choiceImgs, selectedImg, index) {
    var check =
      selectedImg.getAttribute("aria-checked") == "false" ? "true" : "false";
    selectedImg.setAttribute("aria-checked", check);
    selectedImg.focus(); // move focus to input element
  }

  function setRadio(choiceImgs, selectedImg, index) {
    var check =
      selectedImg.getAttribute("aria-checked") == "false" ? "true" : "false";
    if (check == "true") {
      selectedImg.setAttribute("aria-checked", check);
      selectedImg.setAttribute("tabindex", "0");
      for (var i = 0; i < choiceImgs.imgs.length; i++) {
        if (i != index) {
          choiceImgs.imgs[i].setAttribute("aria-checked", "false");
          choiceImgs.imgs[i].removeAttribute("tabindex");
        }
      }
    }
    selectedImg.focus(); // move focus to input element
  }

  function navigateRadioImgs(choiceImgs, increment) {
    // navigate radio items with keyboard
    var selectedImg = choiceImgs.element.querySelector('[aria-checked="true"]');
    if (!selectedImg) return;
    var index = Util.getIndexInArray(choiceImgs.imgs, selectedImg);
    index = index + increment;
    if (index < 0) index = choiceImgs.imgs.length - 1;
    if (index >= choiceImgs.imgs.length) index = 0;
    setRadio(choiceImgs, choiceImgs.imgs[index], index);
  }

  function resetChoiceImgs(choiceImgs) {
    for (var i = 0; i < choiceImgs.imgs.length; i++) {
      var check = choiceImgs.imgs[i].getAttribute("aria-checked");
      if (check == "true") {
        choiceImgs.imgs[i].setAttribute("tabindex", "0"); // make it focusable
      } else {
        // if radio -> element not focusable
        // if checkbox -> element still focusable
        choiceImgs.isRadio
          ? choiceImgs.imgs[i].removeAttribute("tabindex")
          : choiceImgs.imgs[i].setAttribute("tabindex", "0");
      }
    }
  }

  //initialize the ChoiceImgs objects
  var choiceImg = document.getElementsByClassName("js-choice-imgs");
  if (choiceImg.length > 0) {
    for (var i = 0; i < choiceImg.length; i++) {
      (function (i) {
        new ChoiceImgs(choiceImg[i]);
      })(i);
    }
  }
})();

// File#: _1_color-swatches
// Usage: codyhouse.co/license
(function () {
  var ColorSwatches = function (element) {
    this.element = element;
    this.select = false;
    initCustomSelect(this); // replace <select> with custom <ul> list
    this.list = this.element.getElementsByClassName(
      "js-color-swatches__list"
    )[0];
    this.swatches = this.list.getElementsByClassName(
      "js-color-swatches__option"
    );
    this.labels = this.list.getElementsByClassName("js-color-swatch__label");
    this.selectedLabel = this.element.getElementsByClassName(
      "js-color-swatches__color"
    );
    this.focusOutId = false;
    initColorSwatches(this);
  };

  function initCustomSelect(element) {
    var select = element.element.getElementsByClassName(
      "js-color-swatches__select"
    );
    if (select.length == 0) return;
    element.select = select[0];
    var customContent = "";
    for (var i = 0; i < element.select.options.length; i++) {

      // var ariaChecked = i == element.select.selectedIndex ? "true" : "false",
      //   customClass =
      //     i == element.select.selectedIndex
      //       ? " color-swatches__item--selected"
      //       : "",
      //   customAttributes = getSwatchCustomAttr(element.select.options[i]);
      var ariaChecked = "false",
        customClass = "",
        customAttributes = getSwatchCustomAttr(element.select.options[i]);

      customContent =
        customContent +
        '<li class="color-swatches__item js-color-swatches__item' +
        customClass +
        '" role="radio" aria-checked="' +
        ariaChecked +
        '" data-value="' +
        element.select.options[i].value +
        '" data-lens_tints_and_transitions="' +
        element.select.options[i].getAttribute("data-lens_tints_and_transitions") +
        '"><span class="js-color-swatches__option js-tab-focus" tabindex="0"' +
        customAttributes +
        '><span class="sr-only js-color-swatch__label">' +
        element.select.options[i].text +
        '</span><span aria-hidden="true" style="' +
        element.select.options[i].getAttribute("data-style") +
        '" class="color-swatches__swatch"></span></span></li>';
    }

    var list = document.createElement("ul");
    Util.setAttributes(list, {
      class: "color-swatches__list js-color-swatches__list",
      role: "radiogroup",
    });

    list.innerHTML = customContent;
    element.element.insertBefore(list, element.select);
    Util.addClass(element.select, "is-hidden");
  }

  function initColorSwatches(element) {
    // detect focusin/focusout event - update selected color label
    element.list.addEventListener("focusin", function (event) {
      if (element.focusOutId) clearTimeout(element.focusOutId);
      updateSelectedLabel(element, document.activeElement);
    });
    element.list.addEventListener("focusout", function (event) {
      element.focusOutId = setTimeout(function () {
        resetSelectedLabel(element);
      }, 200);
    });

    // mouse move events
    for (var i = 0; i < element.swatches.length; i++) {
      handleHoverEvents(element, i);
    }

    // --select variation only
    if (element.select) {
      // click event - select new option
      element.list.addEventListener("click", function (event) {
        // update selected option
        resetSelectedOption(element, event.target);
      });

      // space key - select new option
      element.list.addEventListener("keydown", function (event) {
        if (
          (event.keyCode && event.keyCode == 32) ||
          (event.key && event.key == " ") ||
          (event.keyCode && event.keyCode == 13) ||
          (event.key && event.key.toLowerCase() == "enter")
        ) {
          // update selected option
          resetSelectedOption(element, event.target);
        }
      });
    }
  }

  function handleHoverEvents(element, index) {
    element.swatches[index].addEventListener("mouseenter", function (event) {
      updateSelectedLabel(element, element.swatches[index]);
    });
    element.swatches[index].addEventListener("mouseleave", function (event) {
      resetSelectedLabel(element);
    });
  }

  function resetSelectedOption(element, target) {
    // for --select variation only - new option selected
    console.log(element);
    console.log(target);
    var option = target.closest(".js-color-swatches__item");
    if (!option) return;
    var selectedSwatch = element.list.querySelector(
      ".color-swatches__item--selected"
    );
    if (selectedSwatch) {
      Util.removeClass(selectedSwatch, "color-swatches__item--selected");
      selectedSwatch.setAttribute("aria-checked", "false");
    }
    Util.addClass(option, "color-swatches__item--selected");
    option.setAttribute("aria-checked", "true");
    // update select element
    lens_tints_and_transitions_id = option.getAttribute(
      "data-lens_tints_and_transitions"
    );
    console.log(lens_tints_and_transitions_id);
    document
      .getElementById("lensflow_subtotal")
      .setAttribute(
        "data-lens_tints_and_transitions",
        lens_tints_and_transitions_id
      );
    updateNativeSelect(
      element.select,
      option.getAttribute("data-value")
    );
  }

  function resetSelectedLabel(element) {
    var selectedSwatch = element.list.getElementsByClassName(
      "color-swatches__item--selected"
    );
    if (selectedSwatch.length > 0)
      updateSelectedLabel(element, selectedSwatch[0]);
  }

  function updateSelectedLabel(element, swatch) {
    var newLabel = swatch.getElementsByClassName("js-color-swatch__label");
    if (newLabel.length == 0) return;
    element.selectedLabel[0].textContent = newLabel[0].textContent;
  }

  function updateNativeSelect(select, value) {
    console.log("CLicked");
    console.log(select);
    console.log(value);
    for (var i = 0; i < select.options.length; i++) {
      if (select.options[i].value == value) {
        select.selectedIndex = i; // set new value
        select.dispatchEvent(new CustomEvent("change")); // trigger change event
        break;
      }
    }
  }

  function getSwatchCustomAttr(swatch) {
    var customAttrArray = swatch.getAttribute("data-custom-attr");
    if (!customAttrArray) return "";
    var customAttr = " ",
      list = customAttrArray.split(",");
    for (var i = 0; i < list.length; i++) {
      var attr = list[i].split(":");
      customAttr = customAttr + attr[0].trim() + '="' + attr[1].trim() + '" ';
    }
    return customAttr;
  }

  //initialize the ColorSwatches objects
  var swatches = document.getElementsByClassName("js-color-swatches");
  if (swatches.length > 0) {
    for (var i = 0; i < swatches.length; i++) {
      new ColorSwatches(swatches[i]);
    }
  }
})();

// File#: _1_countdown
// Usage: codyhouse.co/license
(function () {
  var CountDown = function (element) {
    this.element = element;
    this.labels = this.element.getAttribute("data-labels")
      ? this.element.getAttribute("data-labels").split(",")
      : [];
    this.intervalId;
    //create countdown HTML
    this.createCountDown();
    //store time elements
    this.days = this.element.getElementsByClassName(
      "js-countdown__value--0"
    )[0];
    this.hours = this.element.getElementsByClassName(
      "js-countdown__value--1"
    )[0];
    this.mins = this.element.getElementsByClassName(
      "js-countdown__value--2"
    )[0];
    this.secs = this.element.getElementsByClassName(
      "js-countdown__value--3"
    )[0];
    this.endTime = this.getEndTime();
    //init counter
    this.initCountDown();
  };

  CountDown.prototype.createCountDown = function () {
    var wrapper = document.createElement("div");
    Util.setAttributes(wrapper, {
      "aria-hidden": "true",
      class: "countdown__timer",
    });

    for (var i = 0; i < 4; i++) {
      var timeItem = document.createElement("span"),
        timeValue = document.createElement("span"),
        timeLabel = document.createElement("span");

      timeItem.setAttribute("class", "countdown__item");
      timeValue.setAttribute(
        "class",
        "countdown__value countdown__value--" + i + " js-countdown__value--" + i
      );
      timeItem.appendChild(timeValue);

      if (this.labels && this.labels.length > 0) {
        timeLabel.textContent = this.labels[i].trim();
        timeLabel.setAttribute("class", "countdown__label");
        timeItem.appendChild(timeLabel);
      }

      wrapper.appendChild(timeItem);
    }
    // append new content to countdown element
    this.element.insertBefore(wrapper, this.element.firstChild);
    // this.element.appendChild(wrapper);
  };

  CountDown.prototype.getEndTime = function () {
    // get number of remaining seconds
    if (this.element.getAttribute("data-timer"))
      return (
        Number(this.element.getAttribute("data-timer")) * 1000 +
        new Date().getTime()
      );
    else if (this.element.getAttribute("data-countdown"))
      return Number(
        new Date(this.element.getAttribute("data-countdown")).getTime()
      );
  };

  CountDown.prototype.initCountDown = function () {
    var self = this;
    this.intervalId = setInterval(function () {
      self.updateCountDown(false);
    }, 1000);
    this.updateCountDown(true);
  };

  CountDown.prototype.updateCountDown = function (bool) {
    // original countdown function
    // https://gist.github.com/adriennetacke/f5a25c304f1b7b4a6fa42db70415bad2
    var time = parseInt((this.endTime - new Date().getTime()) / 1000),
      days = 0,
      hours = 0,
      mins = 0,
      seconds = 0;

    if (isNaN(time) || time < 0) {
      clearInterval(this.intervalId);
      this.emitEndEvent();
    } else {
      days = parseInt(time / 86400);
      time = time % 86400;
      hours = parseInt(time / 3600);
      time = time % 3600;
      mins = parseInt(time / 60);
      time = time % 60;
      seconds = parseInt(time);
    }

    // hide days/hours/mins if not available
    if (bool && days == 0) this.days.parentElement.style.display = "none";
    if (bool && days == 0 && hours == 0)
      this.hours.parentElement.style.display = "none";
    if (bool && days == 0 && hours == 0 && mins == 0)
      this.mins.parentElement.style.display = "none";

    this.days.textContent = days;
    this.hours.textContent = this.getTimeFormat(hours);
    this.mins.textContent = this.getTimeFormat(mins);
    this.secs.textContent = this.getTimeFormat(seconds);
  };

  CountDown.prototype.getTimeFormat = function (time) {
    return ("0" + time).slice(-2);
  };

  CountDown.prototype.emitEndEvent = function (time) {
    var event = new CustomEvent("countDownFinished");
    this.element.dispatchEvent(event);
  };

  //initialize the CountDown objects
  var countDown = document.getElementsByClassName("js-countdown");
  if (countDown.length > 0) {
    for (var i = 0; i < countDown.length; i++) {
      (function (i) {
        new CountDown(countDown[i]);
      })(i);
    }
  }
})();

// File#: _1_custom-select
// Usage: codyhouse.co/license
(function () {
  // NOTE: you need the js code only when using the --custom-dropdown variation of the Custom Select component. Default version does nor require JS.

  var CustomSelect = function (element) {
    this.element = element;
    this.select = this.element.getElementsByTagName("select")[0];
    this.optGroups = this.select.getElementsByTagName("optgroup");
    this.options = this.select.getElementsByTagName("option");
    this.selectedOption = getSelectedOptionText(this);
    this.selectId = this.select.getAttribute("id");
    this.trigger = false;
    this.dropdown = false;
    this.customOptions = false;
    this.arrowIcon = this.element.getElementsByTagName("svg");
    this.label = document.querySelector('[for="' + this.selectId + '"]');

    this.optionIndex = 0; // used while building the custom dropdown

    initCustomSelect(this); // init markup
    initCustomSelectEvents(this); // init event listeners
  };

  function initCustomSelect(select) {
    // create the HTML for the custom dropdown element
    select.element.insertAdjacentHTML(
      "beforeend",
      initButtonSelect(select) + initListSelect(select)
    );

    // save custom elements
    select.dropdown = select.element.getElementsByClassName(
      "js-select__dropdown"
    )[0];
    select.trigger =
      select.element.getElementsByClassName("js-select__button")[0];
    select.customOptions =
      select.dropdown.getElementsByClassName("js-select__item");

    // hide default select
    Util.addClass(select.select, "is-hidden");
    if (select.arrowIcon.length > 0) select.arrowIcon[0].style.display = "none";

    // place dropdown
    placeDropdown(select);
  }

  function initCustomSelectEvents(select) {
    // option selection in dropdown
    initSelection(select);

    // click events
    select.trigger.addEventListener("click", function () {
      toggleCustomSelect(select, false);
    });
    if (select.label) {
      // move focus to custom trigger when clicking on <select> label
      select.label.addEventListener("click", function () {
        Util.moveFocus(select.trigger);
      });
    }
    // keyboard navigation
    select.dropdown.addEventListener("keydown", function (event) {
      if (
        (event.keyCode && event.keyCode == 38) ||
        (event.key && event.key.toLowerCase() == "arrowup")
      ) {
        keyboardCustomSelect(select, "prev", event);
      } else if (
        (event.keyCode && event.keyCode == 40) ||
        (event.key && event.key.toLowerCase() == "arrowdown")
      ) {
        keyboardCustomSelect(select, "next", event);
      }
    });
    // native <select> element has been updated -> update custom select as well
    select.element.addEventListener("select-updated", function (event) {
      resetCustomSelect(select);
    });
  }

  function toggleCustomSelect(select, bool) {
    var ariaExpanded;
    if (bool) {
      ariaExpanded = bool;
    } else {
      ariaExpanded =
        select.trigger.getAttribute("aria-expanded") == "true"
          ? "false"
          : "true";
    }
    select.trigger.setAttribute("aria-expanded", ariaExpanded);
    if (ariaExpanded == "true") {
      var selectedOption = getSelectedOption(select);
      Util.moveFocus(selectedOption); // fallback if transition is not supported
      select.dropdown.addEventListener("transitionend", function cb() {
        Util.moveFocus(selectedOption);
        select.dropdown.removeEventListener("transitionend", cb);
      });
      placeDropdown(select); // place dropdown based on available space
    }
  }

  function placeDropdown(select) {
    // remove placement classes to reset position
    Util.removeClass(
      select.dropdown,
      "select__dropdown--right select__dropdown--up"
    );
    var triggerBoundingRect = select.trigger.getBoundingClientRect();
    Util.toggleClass(
      select.dropdown,
      "select__dropdown--right",
      document.documentElement.clientWidth - 5 <
        triggerBoundingRect.left + select.dropdown.offsetWidth
    );
    // check if there's enough space up or down
    var moveUp =
      window.innerHeight - triggerBoundingRect.bottom - 5 <
      triggerBoundingRect.top;
    Util.toggleClass(select.dropdown, "select__dropdown--up", moveUp);
    // check if we need to set a max width
    var maxHeight = moveUp
      ? triggerBoundingRect.top - 20
      : window.innerHeight - triggerBoundingRect.bottom - 20;
    // set max-height based on available space
    select.dropdown.setAttribute(
      "style",
      "max-height: " +
        maxHeight +
        "px; width: " +
        triggerBoundingRect.width +
        "px;"
    );
  }

  function keyboardCustomSelect(select, direction, event) {
    // navigate custom dropdown with keyboard
    event.preventDefault();
    var index = Util.getIndexInArray(
      select.customOptions,
      document.activeElement
    );
    index = direction == "next" ? index + 1 : index - 1;
    if (index < 0) index = select.customOptions.length - 1;
    if (index >= select.customOptions.length) index = 0;
    Util.moveFocus(select.customOptions[index]);
  }

  function initSelection(select) {
    // option selection
    select.dropdown.addEventListener("click", function (event) {
      var option = event.target.closest(".js-select__item");
      if (!option) return;
      selectOption(select, option);
    });
  }

  function selectOption(select, option) {
    if (
      option.hasAttribute("aria-selected") &&
      option.getAttribute("aria-selected") == "true"
    ) {
      // selecting the same option
      select.trigger.setAttribute("aria-expanded", "false"); // hide dropdown
    } else {
      var selectedOption = select.dropdown.querySelector(
        '[aria-selected="true"]'
      );
      if (selectedOption) selectedOption.setAttribute("aria-selected", "false");
      option.setAttribute("aria-selected", "true");
      select.trigger.getElementsByClassName("js-select__label")[0].textContent =
        option.textContent;
      select.trigger.setAttribute("aria-expanded", "false");
      // new option has been selected -> update native <select> element _ arai-label of trigger <button>
      updateNativeSelect(select, option.getAttribute("data-index"));
      updateTriggerAria(select);
    }
    // move focus back to trigger
    select.trigger.focus();
  }

  function updateNativeSelect(select, index) {
    select.select.selectedIndex = index;
    select.select.dispatchEvent(new CustomEvent("change", { bubbles: true })); // trigger change event
  }

  function updateTriggerAria(select) {
    select.trigger.setAttribute(
      "aria-label",
      select.options[select.select.selectedIndex].innerHTML +
        ", " +
        select.label.textContent
    );
  }

  function getSelectedOptionText(select) {
    // used to initialize the label of the custom select button
    var label = "";
    if ("selectedIndex" in select.select) {
      label = select.options[select.select.selectedIndex].text;
    } else {
      label = select.select.querySelector("option[selected]").text;
    }
    return label;
  }

  function initButtonSelect(select) {
    // create the button element -> custom select trigger
    // check if we need to add custom classes to the button trigger
    var customClasses = select.element.getAttribute("data-trigger-class")
      ? " " + select.element.getAttribute("data-trigger-class")
      : "";

    var label =
      select.options[select.select.selectedIndex].innerHTML +
      ", " +
      select.label.textContent;

    var button =
      '<button type="button" class="js-select__button select__button' +
      customClasses +
      '" aria-label="' +
      label +
      '" aria-expanded="false" aria-controls="' +
      select.selectId +
      '-dropdown"><span aria-hidden="true" class="js-select__label select__label">' +
      select.selectedOption +
      "</span>";
    if (select.arrowIcon.length > 0 && select.arrowIcon[0].outerHTML) {
      var clone = select.arrowIcon[0].cloneNode(true);
      Util.removeClass(clone, "select__icon");
      button = button + clone.outerHTML;
    }

    return button + "</button>";
  }

  function initListSelect(select) {
    // create custom select dropdown
    var list =
      '<div class="js-select__dropdown select__dropdown" aria-describedby="' +
      select.selectId +
      '-description" id="' +
      select.selectId +
      '-dropdown">';
    list = list + getSelectLabelSR(select);
    if (select.optGroups.length > 0) {
      for (var i = 0; i < select.optGroups.length; i++) {
        var optGroupList = select.optGroups[i].getElementsByTagName("option"),
          optGroupLabel =
            '<li><span class="select__item select__item--optgroup">' +
            select.optGroups[i].getAttribute("label") +
            "</span></li>";
        list =
          list +
          '<ul class="select__list" role="listbox">' +
          optGroupLabel +
          getOptionsList(select, optGroupList) +
          "</ul>";
      }
    } else {
      list =
        list +
        '<ul class="select__list" role="listbox">' +
        getOptionsList(select, select.options) +
        "</ul>";
    }
    return list;
  }

  function getSelectLabelSR(select) {
    if (select.label) {
      return (
        '<p class="sr-only" id="' +
        select.selectId +
        '-description">' +
        select.label.textContent +
        "</p>"
      );
    } else {
      return "";
    }
  }

  function resetCustomSelect(select) {
    // <select> element has been updated (using an external control) - update custom select
    var selectedOption = select.dropdown.querySelector(
      '[aria-selected="true"]'
    );
    if (selectedOption) selectedOption.setAttribute("aria-selected", "false");
    var option = select.dropdown.querySelector(
      '.js-select__item[data-index="' + select.select.selectedIndex + '"]'
    );
    option.setAttribute("aria-selected", "true");
    select.trigger.getElementsByClassName("js-select__label")[0].textContent =
      option.textContent;
    select.trigger.setAttribute("aria-expanded", "false");
    updateTriggerAria(select);
  }

  function getOptionsList(select, options) {
    var list = "";
    for (var i = 0; i < options.length; i++) {
      var selected = options[i].hasAttribute("selected")
        ? ' aria-selected="true"'
        : ' aria-selected="false"';
      list =
        list +
        '<li><button type="button" class="reset js-select__item select__item select__item--option" role="option" data-value="' +
        options[i].value +
        '" ' +
        selected +
        ' data-index="' +
        select.optionIndex +
        '">' +
        options[i].text +
        "</button></li>";
      select.optionIndex = select.optionIndex + 1;
    }
    return list;
  }

  function getSelectedOption(select) {
    var option = select.dropdown.querySelector('[aria-selected="true"]');
    if (option) return option;
    else return select.dropdown.getElementsByClassName("js-select__item")[0];
  }

  function moveFocusToSelectTrigger(select) {
    if (!document.activeElement.closest(".js-select")) return;
    select.trigger.focus();
  }

  function checkCustomSelectClick(select, target) {
    // close select when clicking outside it
    if (!select.element.contains(target)) toggleCustomSelect(select, "false");
  }

  //initialize the CustomSelect objects
  var customSelect = document.getElementsByClassName("js-select");
  if (customSelect.length > 0) {
    var selectArray = [];
    for (var i = 0; i < customSelect.length; i++) {
      (function (i) {
        selectArray.push(new CustomSelect(customSelect[i]));
      })(i);
    }

    // listen for key events
    window.addEventListener("keyup", function (event) {
      if (
        (event.keyCode && event.keyCode == 27) ||
        (event.key && event.key.toLowerCase() == "escape")
      ) {
        // close custom select on 'Esc'
        selectArray.forEach(function (element) {
          moveFocusToSelectTrigger(element); // if focus is within dropdown, move it to dropdown trigger
          toggleCustomSelect(element, "false"); // close dropdown
        });
      }
    });
    // close custom select when clicking outside it
    window.addEventListener("click", function (event) {
      selectArray.forEach(function (element) {
        checkCustomSelectClick(element, event.target);
      });
    });
  }
})();
// File#: _1_details
// Usage: codyhouse.co/license
(function () {
  var Details = function (element, index) {
    this.element = element;
    this.summary = this.element.getElementsByClassName(
      "js-details__summary"
    )[0];
    this.details = this.element.getElementsByClassName(
      "js-details__content"
    )[0];
    this.htmlElSupported = "open" in this.element;
    this.initDetails(index);
    this.initDetailsEvents();
  };

  Details.prototype.initDetails = function (index) {
    // init aria attributes
    if (window.innerWidth > 767) {
      Util.setAttributes(this.summary, {
        "aria-expanded": "true",
        "aria-controls": "details--" + index,
        role: "button",
      });
      Util.setAttributes(this.details, {
        "aria-hidden": "false",
        id: "details--" + index,
      });
    } else {
      this.element.removeAttribute("open");
    }
  };

  Details.prototype.initDetailsEvents = function () {
    var self = this;
    if (this.htmlElSupported) {
      // browser supports the <details> element
      this.element.addEventListener("toggle", function (event) {
        var ariaValues = self.element.open
          ? ["true", "false"]
          : ["false", "true"];
        // update aria attributes when details element status change (open/close)
        self.updateAriaValues(ariaValues);
      });
    } else {
      //browser does not support <details>
      this.summary.addEventListener("click", function (event) {
        event.preventDefault();
        var isOpen = self.element.getAttribute("open"),
          ariaValues = [];

        isOpen
          ? self.element.removeAttribute("open")
          : self.element.setAttribute("open", "true");
        ariaValues = isOpen ? ["false", "true"] : ["true", "false"];
        self.updateAriaValues(ariaValues);
      });
    }
  };

  Details.prototype.updateAriaValues = function (values) {
    this.summary.setAttribute("aria-expanded", values[0]);
    this.details.setAttribute("aria-hidden", values[1]);
  };

  //initialize the Details objects
  var detailsEl = document.getElementsByClassName("js-details");
  if (detailsEl.length > 0) {
    for (var i = 0; i < detailsEl.length; i++) {
      (function (i) {
        new Details(detailsEl[i], i);
      })(i);
    }
  }
})();

// File#: _1_diagonal-movement
// Usage: codyhouse.co/license
/*
  Modified version of the jQuery-menu-aim plugin
  https://github.com/kamens/jQuery-menu-aim
  - Replaced jQuery with Vanilla JS
  - Minor changes
*/
(function () {
  var menuAim = function (opts) {
    init(opts);
  };

  window.menuAim = menuAim;

  function init(opts) {
    var activeRow = null,
      mouseLocs = [],
      lastDelayLoc = null,
      timeoutId = null,
      options = Util.extend(
        {
          menu: "",
          rows: false, //if false, get direct children - otherwise pass nodes list
          submenuSelector: "*",
          submenuDirection: "right",
          tolerance: 75, // bigger = more forgivey when entering submenu
          enter: function () {},
          exit: function () {},
          activate: function () {},
          deactivate: function () {},
          exitMenu: function () {},
        },
        opts
      ),
      menu = options.menu;

    var MOUSE_LOCS_TRACKED = 3, // number of past mouse locations to track
      DELAY = 300; // ms delay when user appears to be entering submenu

    /**
     * Keep track of the last few locations of the mouse.
     */
    var mousemoveDocument = function (e) {
      mouseLocs.push({ x: e.pageX, y: e.pageY });

      if (mouseLocs.length > MOUSE_LOCS_TRACKED) {
        mouseLocs.shift();
      }
    };

    /**
     * Cancel possible row activations when leaving the menu entirely
     */
    var mouseleaveMenu = function () {
      if (timeoutId) {
        clearTimeout(timeoutId);
      }

      // If exitMenu is supplied and returns true, deactivate the
      // currently active row on menu exit.
      if (options.exitMenu(this)) {
        if (activeRow) {
          options.deactivate(activeRow);
        }

        activeRow = null;
      }
    };

    /**
     * Trigger a possible row activation whenever entering a new row.
     */
    var mouseenterRow = function () {
        if (timeoutId) {
          // Cancel any previous activation delays
          clearTimeout(timeoutId);
        }

        options.enter(this);
        possiblyActivate(this);
      },
      mouseleaveRow = function () {
        options.exit(this);
      };

    /*
     * Immediately activate a row if the user clicks on it.
     */
    var clickRow = function () {
      activate(this);
    };

    /**
     * Activate a menu row.
     */
    var activate = function (row) {
      if (row == activeRow) {
        return;
      }

      if (activeRow) {
        options.deactivate(activeRow);
      }

      options.activate(row);
      activeRow = row;
    };

    /**
     * Possibly activate a menu row. If mouse movement indicates that we
     * shouldn't activate yet because user may be trying to enter
     * a submenu's content, then delay and check again later.
     */
    var possiblyActivate = function (row) {
      var delay = activationDelay();

      if (delay) {
        timeoutId = setTimeout(function () {
          possiblyActivate(row);
        }, delay);
      } else {
        activate(row);
      }
    };

    /**
     * Return the amount of time that should be used as a delay before the
     * currently hovered row is activated.
     *
     * Returns 0 if the activation should happen immediately. Otherwise,
     * returns the number of milliseconds that should be delayed before
     * checking again to see if the row should be activated.
     */
    var activationDelay = function () {
      if (!activeRow || !Util.is(activeRow, options.submenuSelector)) {
        // If there is no other submenu row already active, then
        // go ahead and activate immediately.
        return 0;
      }

      function getOffset(element) {
        var rect = element.getBoundingClientRect();
        return {
          top: rect.top + window.pageYOffset,
          left: rect.left + window.pageXOffset,
        };
      }

      var offset = getOffset(menu),
        upperLeft = {
          x: offset.left,
          y: offset.top - options.tolerance,
        },
        upperRight = {
          x: offset.left + menu.offsetWidth,
          y: upperLeft.y,
        },
        lowerLeft = {
          x: offset.left,
          y: offset.top + menu.offsetHeight + options.tolerance,
        },
        lowerRight = {
          x: offset.left + menu.offsetWidth,
          y: lowerLeft.y,
        },
        loc = mouseLocs[mouseLocs.length - 1],
        prevLoc = mouseLocs[0];

      if (!loc) {
        return 0;
      }

      if (!prevLoc) {
        prevLoc = loc;
      }

      if (
        prevLoc.x < offset.left ||
        prevLoc.x > lowerRight.x ||
        prevLoc.y < offset.top ||
        prevLoc.y > lowerRight.y
      ) {
        // If the previous mouse location was outside of the entire
        // menu's bounds, immediately activate.
        return 0;
      }

      if (lastDelayLoc && loc.x == lastDelayLoc.x && loc.y == lastDelayLoc.y) {
        // If the mouse hasn't moved since the last time we checked
        // for activation status, immediately activate.
        return 0;
      }

      // Detect if the user is moving towards the currently activated
      // submenu.
      //
      // If the mouse is heading relatively clearly towards
      // the submenu's content, we should wait and give the user more
      // time before activating a new row. If the mouse is heading
      // elsewhere, we can immediately activate a new row.
      //
      // We detect this by calculating the slope formed between the
      // current mouse location and the upper/lower right points of
      // the menu. We do the same for the previous mouse location.
      // If the current mouse location's slopes are
      // increasing/decreasing appropriately compared to the
      // previous's, we know the user is moving toward the submenu.
      //
      // Note that since the y-axis increases as the cursor moves
      // down the screen, we are looking for the slope between the
      // cursor and the upper right corner to decrease over time, not
      // increase (somewhat counterintuitively).
      function slope(a, b) {
        return (b.y - a.y) / (b.x - a.x);
      }

      var decreasingCorner = upperRight,
        increasingCorner = lowerRight;

      // Our expectations for decreasing or increasing slope values
      // depends on which direction the submenu opens relative to the
      // main menu. By default, if the menu opens on the right, we
      // expect the slope between the cursor and the upper right
      // corner to decrease over time, as explained above. If the
      // submenu opens in a different direction, we change our slope
      // expectations.
      if (options.submenuDirection == "left") {
        decreasingCorner = lowerLeft;
        increasingCorner = upperLeft;
      } else if (options.submenuDirection == "below") {
        decreasingCorner = lowerRight;
        increasingCorner = lowerLeft;
      } else if (options.submenuDirection == "above") {
        decreasingCorner = upperLeft;
        increasingCorner = upperRight;
      }

      var decreasingSlope = slope(loc, decreasingCorner),
        increasingSlope = slope(loc, increasingCorner),
        prevDecreasingSlope = slope(prevLoc, decreasingCorner),
        prevIncreasingSlope = slope(prevLoc, increasingCorner);

      if (
        decreasingSlope < prevDecreasingSlope &&
        increasingSlope > prevIncreasingSlope
      ) {
        // Mouse is moving from previous location towards the
        // currently activated submenu. Delay before activating a
        // new menu row, because user may be moving into submenu.
        lastDelayLoc = loc;
        return DELAY;
      }

      lastDelayLoc = null;
      return 0;
    };

    /**
     * Hook up initial menu events
     */
    menu.addEventListener("mouseleave", mouseleaveMenu);
    var rows = options.rows ? options.rows : menu.children;
    if (rows.length > 0) {
      for (var i = 0; i < rows.length; i++) {
        (function (i) {
          rows[i].addEventListener("mouseenter", mouseenterRow);
          rows[i].addEventListener("mouseleave", mouseleaveRow);
          rows[i].addEventListener("click", clickRow);
        })(i);
      }
    }

    document.addEventListener("mousemove", function (event) {
      !window.requestAnimationFrame
        ? mousemoveDocument(event)
        : window.requestAnimationFrame(function () {
            mousemoveDocument(event);
          });
    });
  }
})();

// File#: _1_dialog
// Usage: codyhouse.co/license
(function () {
  var Dialog = function (element) {
    this.element = element;
    this.triggers = document.querySelectorAll(
      '[aria-controls="' + this.element.getAttribute("id") + '"]'
    );
    this.firstFocusable = null;
    this.lastFocusable = null;
    this.selectedTrigger = null;
    this.showClass = "dialog--is-visible";
    initDialog(this);
  };

  function initDialog(dialog) {
    if (dialog.triggers) {
      for (var i = 0; i < dialog.triggers.length; i++) {
        dialog.triggers[i].addEventListener("click", function (event) {
          event.preventDefault();
          dialog.selectedTrigger = event.target;
          showDialog(dialog);
          initDialogEvents(dialog);
        });
      }
    }

    // listen to the openDialog event -> open dialog without a trigger button
    dialog.element.addEventListener("openDialog", function (event) {
      if (event.detail) self.selectedTrigger = event.detail;
      showDialog(dialog);
      initDialogEvents(dialog);
    });
  }

  function showDialog(dialog) {
    Util.addClass(dialog.element, dialog.showClass);
    getFocusableElements(dialog);
    dialog.firstFocusable.focus();
    // wait for the end of transitions before moving focus
    dialog.element.addEventListener("transitionend", function cb(event) {
      dialog.firstFocusable.focus();
      dialog.element.removeEventListener("transitionend", cb);
    });
    emitDialogEvents(dialog, "dialogIsOpen");
  }

  function closeDialog(dialog) {
    Util.removeClass(dialog.element, dialog.showClass);
    dialog.firstFocusable = null;
    dialog.lastFocusable = null;
    if (dialog.selectedTrigger) dialog.selectedTrigger.focus();
    //remove listeners
    cancelDialogEvents(dialog);
    emitDialogEvents(dialog, "dialogIsClose");
  }

  function initDialogEvents(dialog) {
    //add event listeners
    dialog.element.addEventListener("keydown", handleEvent.bind(dialog));
    dialog.element.addEventListener("click", handleEvent.bind(dialog));
  }

  function cancelDialogEvents(dialog) {
    //remove event listeners
    dialog.element.removeEventListener("keydown", handleEvent.bind(dialog));
    dialog.element.removeEventListener("click", handleEvent.bind(dialog));
  }

  function handleEvent(event) {
    // handle events
    switch (event.type) {
      case "click": {
        initClick(this, event);
      }
      case "keydown": {
        initKeyDown(this, event);
      }
    }
  }

  function initKeyDown(dialog, event) {
    if (
      (event.keyCode && event.keyCode == 27) ||
      (event.key && event.key == "Escape")
    ) {
      //close dialog on esc
      closeDialog(dialog);
    } else if (
      (event.keyCode && event.keyCode == 9) ||
      (event.key && event.key == "Tab")
    ) {
      //trap focus inside dialog
      trapFocus(dialog, event);
    }
  }

  function initClick(dialog, event) {
    //close dialog when clicking on close button
    if (!event.target.closest(".js-dialog__close")) return;
    event.preventDefault();
    closeDialog(dialog);
  }

  function trapFocus(dialog, event) {
    if (dialog.firstFocusable == document.activeElement && event.shiftKey) {
      //on Shift+Tab -> focus last focusable element when focus moves out of dialog
      event.preventDefault();
      dialog.lastFocusable.focus();
    }
    if (dialog.lastFocusable == document.activeElement && !event.shiftKey) {
      //on Tab -> focus first focusable element when focus moves out of dialog
      event.preventDefault();
      dialog.firstFocusable.focus();
    }
  }

  function getFocusableElements(dialog) {
    //get all focusable elements inside the dialog
    var allFocusable = dialog.element.querySelectorAll(
      '[href], input:not([disabled]), select:not([disabled]), textarea:not([disabled]), button:not([disabled]), iframe, object, embed, [tabindex]:not([tabindex="-1"]), [contenteditable], audio[controls], video[controls], summary'
    );
    getFirstVisible(dialog, allFocusable);
    getLastVisible(dialog, allFocusable);
  }

  function getFirstVisible(dialog, elements) {
    //get first visible focusable element inside the dialog
    for (var i = 0; i < elements.length; i++) {
      if (
        elements[i].offsetWidth ||
        elements[i].offsetHeight ||
        elements[i].getClientRects().length
      ) {
        dialog.firstFocusable = elements[i];
        return true;
      }
    }
  }

  function getLastVisible(dialog, elements) {
    //get last visible focusable element inside the dialog
    for (var i = elements.length - 1; i >= 0; i--) {
      if (
        elements[i].offsetWidth ||
        elements[i].offsetHeight ||
        elements[i].getClientRects().length
      ) {
        dialog.lastFocusable = elements[i];
        return true;
      }
    }
  }

  function emitDialogEvents(dialog, eventName) {
    var event = new CustomEvent(eventName, { detail: dialog.selectedTrigger });
    dialog.element.dispatchEvent(event);
  }

  //initialize the Dialog objects
  var dialogs = document.getElementsByClassName("js-dialog");
  if (dialogs.length > 0) {
    for (var i = 0; i < dialogs.length; i++) {
      (function (i) {
        new Dialog(dialogs[i]);
      })(i);
    }
  }
})();

// File#: _1_drawer
// Usage: codyhouse.co/license
(function () {
  var Drawer = function (element) {
    this.element = element;
    this.content = document.getElementsByClassName("js-drawer__body")[0];
    this.triggers = document.querySelectorAll(
      '[aria-controls="' + this.element.getAttribute("id") + '"]'
    );
    this.firstFocusable = null;
    this.lastFocusable = null;
    this.selectedTrigger = null;
    this.isModal = Util.hasClass(this.element, "js-drawer--modal");
    this.showClass = "drawer--is-visible";
    this.initDrawer();
  };

  Drawer.prototype.initDrawer = function () {
    var self = this;
    //open drawer when clicking on trigger buttons
    if (this.triggers) {
      for (var i = 0; i < this.triggers.length; i++) {
        this.triggers[i].addEventListener("click", function (event) {
          event.preventDefault();
          if (Util.hasClass(self.element, self.showClass)) {
            self.closeDrawer(event.target);
            return;
          }
          self.selectedTrigger = event.target;
          self.showDrawer();
          self.initDrawerEvents();
        });
      }
    }

    // if drawer is already open -> we should initialize the drawer events
    if (Util.hasClass(this.element, this.showClass)) this.initDrawerEvents();
  };

  Drawer.prototype.showDrawer = function () {
    var self = this;
    this.content.scrollTop = 0;
    Util.addClass(this.element, this.showClass);
    this.getFocusableElements();
    Util.moveFocus(this.element);
    // wait for the end of transitions before moving focus
    this.element.addEventListener("transitionend", function cb(event) {
      Util.moveFocus(self.element);
      self.element.removeEventListener("transitionend", cb);
    });
    this.emitDrawerEvents("drawerIsOpen", this.selectedTrigger);
  };

  Drawer.prototype.closeDrawer = function (target) {
    Util.removeClass(this.element, this.showClass);
    this.firstFocusable = null;
    this.lastFocusable = null;
    if (this.selectedTrigger) this.selectedTrigger.focus();
    //remove listeners
    this.cancelDrawerEvents();
    this.emitDrawerEvents("drawerIsClose", target);
  };

  Drawer.prototype.initDrawerEvents = function () {
    //add event listeners
    this.element.addEventListener("keydown", this);
    this.element.addEventListener("click", this);
  };

  Drawer.prototype.cancelDrawerEvents = function () {
    //remove event listeners
    this.element.removeEventListener("keydown", this);
    this.element.removeEventListener("click", this);
  };

  Drawer.prototype.handleEvent = function (event) {
    switch (event.type) {
      case "click": {
        this.initClick(event);
      }
      case "keydown": {
        this.initKeyDown(event);
      }
    }
  };

  Drawer.prototype.initKeyDown = function (event) {
    if (
      (event.keyCode && event.keyCode == 27) ||
      (event.key && event.key == "Escape")
    ) {
      //close drawer window on esc
      this.closeDrawer(false);
    } else if (
      this.isModal &&
      ((event.keyCode && event.keyCode == 9) ||
        (event.key && event.key == "Tab"))
    ) {
      //trap focus inside drawer
      this.trapFocus(event);
    }
  };

  Drawer.prototype.initClick = function (event) {
    //close drawer when clicking on close button or drawer bg layer
    if (
      !event.target.closest(".js-drawer__close") &&
      !Util.hasClass(event.target, "js-drawer")
    )
      return;
    event.preventDefault();
    this.closeDrawer(event.target);
  };

  Drawer.prototype.trapFocus = function (event) {
    if (this.firstFocusable == document.activeElement && event.shiftKey) {
      //on Shift+Tab -> focus last focusable element when focus moves out of drawer
      event.preventDefault();
      this.lastFocusable.focus();
    }
    if (this.lastFocusable == document.activeElement && !event.shiftKey) {
      //on Tab -> focus first focusable element when focus moves out of drawer
      event.preventDefault();
      this.firstFocusable.focus();
    }
  };

  Drawer.prototype.getFocusableElements = function () {
    //get all focusable elements inside the drawer
    var allFocusable = this.element.querySelectorAll(
      '[href], input:not([disabled]), select:not([disabled]), textarea:not([disabled]), button:not([disabled]), iframe, object, embed, [tabindex]:not([tabindex="-1"]), [contenteditable], audio[controls], video[controls], summary'
    );
    this.getFirstVisible(allFocusable);
    this.getLastVisible(allFocusable);
  };

  Drawer.prototype.getFirstVisible = function (elements) {
    //get first visible focusable element inside the drawer
    for (var i = 0; i < elements.length; i++) {
      if (
        elements[i].offsetWidth ||
        elements[i].offsetHeight ||
        elements[i].getClientRects().length
      ) {
        this.firstFocusable = elements[i];
        return true;
      }
    }
  };

  Drawer.prototype.getLastVisible = function (elements) {
    //get last visible focusable element inside the drawer
    for (var i = elements.length - 1; i >= 0; i--) {
      if (
        elements[i].offsetWidth ||
        elements[i].offsetHeight ||
        elements[i].getClientRects().length
      ) {
        this.lastFocusable = elements[i];
        return true;
      }
    }
  };

  Drawer.prototype.emitDrawerEvents = function (eventName, target) {
    var event = new CustomEvent(eventName, { detail: target });
    this.element.dispatchEvent(event);
  };

  //initialize the Drawer objects
  var drawer = document.getElementsByClassName("js-drawer");
  if (drawer.length > 0) {
    for (var i = 0; i < drawer.length; i++) {
      (function (i) {
        new Drawer(drawer[i]);
      })(i);
    }
  }
})();
// File#: _1_modal-window
// Usage: codyhouse.co/license
(function () {
  var Modal = function (element) {
    this.element = element;
    this.triggers = document.querySelectorAll(
      '[aria-controls="' + this.element.getAttribute("id") + '"]'
    );
    this.firstFocusable = null;
    this.lastFocusable = null;
    this.moveFocusEl = null; // focus will be moved to this element when modal is open
    this.modalFocus = this.element.getAttribute("data-modal-first-focus")
      ? this.element.querySelector(
          this.element.getAttribute("data-modal-first-focus")
        )
      : null;
    this.selectedTrigger = null;
    this.preventScrollEl = this.getPreventScrollEl();
    this.showClass = "modal--is-visible";
    this.initModal();
  };

  Modal.prototype.getPreventScrollEl = function () {
    var scrollEl = false;
    var querySelector = this.element.getAttribute("data-modal-prevent-scroll");
    if (querySelector) scrollEl = document.querySelector(querySelector);
    return scrollEl;
  };

  Modal.prototype.initModal = function () {
    var self = this;
    //open modal when clicking on trigger buttons
    if (this.triggers) {
      for (var i = 0; i < this.triggers.length; i++) {
        this.triggers[i].addEventListener("click", function (event) {
          event.preventDefault();
          if (Util.hasClass(self.element, self.showClass)) {
            self.closeModal();
            return;
          }
          self.selectedTrigger = event.target;
          self.showModal();
          self.initModalEvents();
        });
      }
    }

    // listen to the openModal event -> open modal without a trigger button
    this.element.addEventListener("openModal", function (event) {
      if (event.detail) self.selectedTrigger = event.detail;
      self.showModal();
      self.initModalEvents();
    });

    // listen to the closeModal event -> close modal without a trigger button
    this.element.addEventListener("closeModal", function (event) {
      if (event.detail) self.selectedTrigger = event.detail;
      self.closeModal();
    });

    // if modal is open by default -> initialise modal events
    if (Util.hasClass(this.element, this.showClass)) this.initModalEvents();
  };

  Modal.prototype.showModal = function () {
    var self = this;
    Util.addClass(this.element, this.showClass);
    this.getFocusableElements();
    if (this.moveFocusEl) {
      this.moveFocusEl.focus();
      // wait for the end of transitions before moving focus
      this.element.addEventListener("transitionend", function cb(event) {
        self.moveFocusEl.focus();
        self.element.removeEventListener("transitionend", cb);
      });
    }
    this.emitModalEvents("modalIsOpen");
    // change the overflow of the preventScrollEl
    if (this.preventScrollEl) this.preventScrollEl.style.overflow = "hidden";
  };

  Modal.prototype.closeModal = function () {
    if (!Util.hasClass(this.element, this.showClass)) return;
    Util.removeClass(this.element, this.showClass);
    this.firstFocusable = null;
    this.lastFocusable = null;
    this.moveFocusEl = null;
    if (this.selectedTrigger) this.selectedTrigger.focus();
    //remove listeners
    this.cancelModalEvents();
    this.emitModalEvents("modalIsClose");
    // change the overflow of the preventScrollEl
    if (this.preventScrollEl) this.preventScrollEl.style.overflow = "";
  };

  Modal.prototype.initModalEvents = function () {
    //add event listeners
    this.element.addEventListener("keydown", this);
    this.element.addEventListener("click", this);
  };

  Modal.prototype.cancelModalEvents = function () {
    //remove event listeners
    this.element.removeEventListener("keydown", this);
    this.element.removeEventListener("click", this);
  };

  Modal.prototype.handleEvent = function (event) {
    switch (event.type) {
      case "click": {
        this.initClick(event);
      }
      case "keydown": {
        this.initKeyDown(event);
      }
    }
  };

  Modal.prototype.initKeyDown = function (event) {
    if (
      (event.keyCode && event.keyCode == 9) ||
      (event.key && event.key == "Tab")
    ) {
      //trap focus inside modal
      this.trapFocus(event);
    } else if (
      ((event.keyCode && event.keyCode == 13) ||
        (event.key && event.key == "Enter")) &&
      event.target.closest(".js-modal__close")
    ) {
      event.preventDefault();
      this.closeModal(); // close modal when pressing Enter on close button
    }
  };

  Modal.prototype.initClick = function (event) {
    //close modal when clicking on close button or modal bg layer
    if (
      !event.target.closest(".js-modal__close") &&
      !Util.hasClass(event.target, "js-modal")
    )
      return;
    event.preventDefault();
    this.closeModal();
  };

  Modal.prototype.trapFocus = function (event) {
    if (this.firstFocusable == document.activeElement && event.shiftKey) {
      //on Shift+Tab -> focus last focusable element when focus moves out of modal
      event.preventDefault();
      this.lastFocusable.focus();
    }
    if (this.lastFocusable == document.activeElement && !event.shiftKey) {
      //on Tab -> focus first focusable element when focus moves out of modal
      event.preventDefault();
      this.firstFocusable.focus();
    }
  };

  Modal.prototype.getFocusableElements = function () {
    //get all focusable elements inside the modal
    var allFocusable = this.element.querySelectorAll(focusableElString);
    this.getFirstVisible(allFocusable);
    this.getLastVisible(allFocusable);
    this.getFirstFocusable();
  };

  Modal.prototype.getFirstVisible = function (elements) {
    //get first visible focusable element inside the modal
    for (var i = 0; i < elements.length; i++) {
      if (isVisible(elements[i])) {
        this.firstFocusable = elements[i];
        break;
      }
    }
  };

  Modal.prototype.getLastVisible = function (elements) {
    //get last visible focusable element inside the modal
    for (var i = elements.length - 1; i >= 0; i--) {
      if (isVisible(elements[i])) {
        this.lastFocusable = elements[i];
        break;
      }
    }
  };

  Modal.prototype.getFirstFocusable = function () {
    if (!this.modalFocus || !Element.prototype.matches) {
      this.moveFocusEl = this.firstFocusable;
      return;
    }
    var containerIsFocusable = this.modalFocus.matches(focusableElString);
    if (containerIsFocusable) {
      this.moveFocusEl = this.modalFocus;
    } else {
      this.moveFocusEl = false;
      var elements = this.modalFocus.querySelectorAll(focusableElString);
      for (var i = 0; i < elements.length; i++) {
        if (isVisible(elements[i])) {
          this.moveFocusEl = elements[i];
          break;
        }
      }
      if (!this.moveFocusEl) this.moveFocusEl = this.firstFocusable;
    }
  };

  Modal.prototype.emitModalEvents = function (eventName) {
    var event = new CustomEvent(eventName, { detail: this.selectedTrigger });
    this.element.dispatchEvent(event);
  };

  function isVisible(element) {
    return (
      element.offsetWidth ||
      element.offsetHeight ||
      element.getClientRects().length
    );
  }

  //initialize the Modal objects
  var modals = document.getElementsByClassName("js-modal");
  // generic focusable elements string selector
  var focusableElString =
    '[href], input:not([disabled]), select:not([disabled]), textarea:not([disabled]), button:not([disabled]), iframe, object, embed, [tabindex]:not([tabindex="-1"]), [contenteditable], audio[controls], video[controls], summary';
  if (modals.length > 0) {
    var modalArrays = [];
    for (var i = 0; i < modals.length; i++) {
      (function (i) {
        modalArrays.push(new Modal(modals[i]));
      })(i);
    }

    window.addEventListener("keydown", function (event) {
      //close modal window on esc
      if (
        (event.keyCode && event.keyCode == 27) ||
        (event.key && event.key.toLowerCase() == "escape")
      ) {
        for (var i = 0; i < modalArrays.length; i++) {
          (function (i) {
            modalArrays[i].closeModal();
          })(i);
        }
      }
    });
  }
})();

// File#: _1_read-more
// Usage: codyhouse.co/license
(function () {
  var ReadMore = function (element) {
    this.element = element;
    this.moreContent = this.element.getElementsByClassName(
      "js-read-more__content"
    );
    this.count = this.element.getAttribute("data-characters") || 200;
    this.counting = 0;
    this.btnClasses = this.element.getAttribute("data-btn-class");
    this.ellipsis =
      this.element.getAttribute("data-ellipsis") &&
      this.element.getAttribute("data-ellipsis") == "off"
        ? false
        : true;
    this.btnShowLabel = "Read more";
    this.btnHideLabel = "Read less";
    this.toggleOff =
      this.element.getAttribute("data-toggle") &&
      this.element.getAttribute("data-toggle") == "off"
        ? false
        : true;
    if (this.moreContent.length == 0) splitReadMore(this);
    setBtnLabels(this);
    initReadMore(this);
  };

  function splitReadMore(readMore) {
    splitChildren(readMore.element, readMore); // iterate through children and hide content
  }

  function splitChildren(parent, readMore) {
    if (readMore.counting >= readMore.count) {
      Util.addClass(parent, "js-read-more__content");
      return parent.outerHTML;
    }
    var children = parent.childNodes;
    var content = "";
    for (var i = 0; i < children.length; i++) {
      if (children[i].nodeType == Node.TEXT_NODE) {
        content = content + wrapText(children[i], readMore);
      } else {
        content = content + splitChildren(children[i], readMore);
      }
    }
    parent.innerHTML = content;
    return parent.outerHTML;
  }

  function wrapText(element, readMore) {
    var content = element.textContent;
    if (content.replace(/\s/g, "").length == 0) return ""; // check if content is empty
    if (readMore.counting >= readMore.count) {
      return '<span class="js-read-more__content">' + content + "</span>";
    }
    if (readMore.counting + content.length < readMore.count) {
      readMore.counting = readMore.counting + content.length;
      return content;
    }
    var firstContent = content.substr(0, readMore.count - readMore.counting);
    firstContent = firstContent.substr(
      0,
      Math.min(firstContent.length, firstContent.lastIndexOf(" "))
    );
    var secondContent = content.substr(firstContent.length, content.length);
    readMore.counting = readMore.count;
    return (
      firstContent +
      '<span class="js-read-more__content">' +
      secondContent +
      "</span>"
    );
  }

  function setBtnLabels(readMore) {
    // set custom labels for read More/Less btns
    var btnLabels = readMore.element.getAttribute("data-btn-labels");
    if (btnLabels) {
      var labelsArray = btnLabels.split(",");
      readMore.btnShowLabel = labelsArray[0].trim();
      readMore.btnHideLabel = labelsArray[1].trim();
    }
  }

  function initReadMore(readMore) {
    // add read more/read less buttons to the markup
    readMore.moreContent = readMore.element.getElementsByClassName(
      "js-read-more__content"
    );
    if (readMore.moreContent.length == 0) {
      Util.addClass(readMore.element, "read-more--loaded");
      return;
    }
    var btnShow =
      ' <button class="js-read-more__btn ' +
      readMore.btnClasses +
      '">' +
      readMore.btnShowLabel +
      "</button>";
    var btnHide =
      ' <button class="js-read-more__btn is-hidden ' +
      readMore.btnClasses +
      '">' +
      readMore.btnHideLabel +
      "</button>";
    if (readMore.ellipsis) {
      btnShow =
        '<span class="js-read-more__ellipsis" aria-hidden="true">...</span>' +
        btnShow;
    }

    readMore.moreContent[readMore.moreContent.length - 1].insertAdjacentHTML(
      "afterend",
      btnHide
    );
    readMore.moreContent[0].insertAdjacentHTML("afterend", btnShow);
    resetAppearance(readMore);
    initEvents(readMore);
  }

  function resetAppearance(readMore) {
    // hide part of the content
    for (var i = 0; i < readMore.moreContent.length; i++)
      Util.addClass(readMore.moreContent[i], "is-hidden");
    Util.addClass(readMore.element, "read-more--loaded"); // show entire component
  }

  function initEvents(readMore) {
    // listen to the click on the read more/less btn
    readMore.btnToggle =
      readMore.element.getElementsByClassName("js-read-more__btn");
    readMore.ellipsis = readMore.element.getElementsByClassName(
      "js-read-more__ellipsis"
    );

    readMore.btnToggle[0].addEventListener("click", function (event) {
      event.preventDefault();
      updateVisibility(readMore, true);
    });
    readMore.btnToggle[1].addEventListener("click", function (event) {
      event.preventDefault();
      updateVisibility(readMore, false);
    });
  }

  function updateVisibility(readMore, visibile) {
    for (var i = 0; i < readMore.moreContent.length; i++)
      Util.toggleClass(readMore.moreContent[i], "is-hidden", !visibile);
    // reset btns appearance
    Util.toggleClass(readMore.btnToggle[0], "is-hidden", visibile);
    Util.toggleClass(readMore.btnToggle[1], "is-hidden", !visibile);
    if (readMore.ellipsis.length > 0)
      Util.toggleClass(readMore.ellipsis[0], "is-hidden", visibile);
    if (!readMore.toggleOff) Util.addClass(readMore.btn, "is-hidden");
    // move focus
    if (visibile) {
      var targetTabIndex = readMore.moreContent[0].getAttribute("tabindex");
      Util.moveFocus(readMore.moreContent[0]);
      resetFocusTarget(readMore.moreContent[0], targetTabIndex);
    } else {
      Util.moveFocus(readMore.btnToggle[0]);
    }
  }

  function resetFocusTarget(target, tabindex) {
    if (parseInt(target.getAttribute("tabindex")) < 0) {
      target.style.outline = "none";
      !tabindex && target.removeAttribute("tabindex");
    }
  }

  //initialize the ReadMore objects
  var readMore = document.getElementsByClassName("js-read-more");
  if (readMore.length > 0) {
    for (var i = 0; i < readMore.length; i++) {
      (function (i) {
        new ReadMore(readMore[i]);
      })(i);
    }
  }
})();

// File#: _1_responsive-sidebar
// Usage: codyhouse.co/license
(function () {
  var Sidebar = function (element) {
    this.element = element;
    this.triggers = document.querySelectorAll(
      '[aria-controls="' + this.element.getAttribute("id") + '"]'
    );
    this.firstFocusable = null;
    this.lastFocusable = null;
    this.selectedTrigger = null;
    this.showClass = "sidebar--is-visible";
    this.staticClass = "sidebar--static";
    this.customStaticClass = "";
    this.readyClass = "sidebar--loaded";
    this.layout = false; // this will be static or mobile
    getCustomStaticClass(this); // custom classes for static version
    initSidebar(this);
  };

  function getCustomStaticClass(element) {
    var customClasses = element.element.getAttribute("data-static-class");
    if (customClasses) element.customStaticClass = " " + customClasses;
  }

  function initSidebar(sidebar) {
    initSidebarResize(sidebar); // handle changes in layout -> mobile to static and viceversa

    if (sidebar.triggers) {
      // open sidebar when clicking on trigger buttons - mobile layout only
      for (var i = 0; i < sidebar.triggers.length; i++) {
        sidebar.triggers[i].addEventListener("click", function (event) {
          event.preventDefault();
          if (Util.hasClass(sidebar.element, sidebar.showClass)) {
            sidebar.selectedTrigger = event.target;
            closeSidebar(sidebar);
            return;
          }
          sidebar.selectedTrigger = event.target;
          showSidebar(sidebar);
          initSidebarEvents(sidebar);
        });
      }
    }
  }

  function showSidebar(sidebar) {
    // mobile layout only
    Util.addClass(sidebar.element, sidebar.showClass);
    getFocusableElements(sidebar);
    Util.moveFocus(sidebar.element);
  }

  function closeSidebar(sidebar) {
    // mobile layout only
    Util.removeClass(sidebar.element, sidebar.showClass);
    sidebar.firstFocusable = null;
    sidebar.lastFocusable = null;
    if (sidebar.selectedTrigger) sidebar.selectedTrigger.focus();
    sidebar.element.removeAttribute("tabindex");
    //remove listeners
    cancelSidebarEvents(sidebar);
  }

  function initSidebarEvents(sidebar) {
    // mobile layout only
    //add event listeners
    sidebar.element.addEventListener("keydown", handleEvent.bind(sidebar));
    sidebar.element.addEventListener("click", handleEvent.bind(sidebar));
  }

  function cancelSidebarEvents(sidebar) {
    // mobile layout only
    //remove event listeners
    sidebar.element.removeEventListener("keydown", handleEvent.bind(sidebar));
    sidebar.element.removeEventListener("click", handleEvent.bind(sidebar));
  }

  function handleEvent(event) {
    // mobile layout only
    switch (event.type) {
      case "click": {
        initClick(this, event);
      }
      case "keydown": {
        initKeyDown(this, event);
      }
    }
  }

  function initKeyDown(sidebar, event) {
    // mobile layout only
    if (
      (event.keyCode && event.keyCode == 27) ||
      (event.key && event.key == "Escape")
    ) {
      //close sidebar window on esc
      closeSidebar(sidebar);
    } else if (
      (event.keyCode && event.keyCode == 9) ||
      (event.key && event.key == "Tab")
    ) {
      //trap focus inside sidebar
      trapFocus(sidebar, event);
    }
  }

  function initClick(sidebar, event) {
    // mobile layout only
    //close sidebar when clicking on close button or sidebar bg layer
    if (
      !event.target.closest(".js-sidebar__close-btn") &&
      !Util.hasClass(event.target, "js-sidebar")
    )
      return;
    event.preventDefault();
    closeSidebar(sidebar);
  }

  function trapFocus(sidebar, event) {
    // mobile layout only
    if (sidebar.firstFocusable == document.activeElement && event.shiftKey) {
      //on Shift+Tab -> focus last focusable element when focus moves out of sidebar
      event.preventDefault();
      sidebar.lastFocusable.focus();
    }
    if (sidebar.lastFocusable == document.activeElement && !event.shiftKey) {
      //on Tab -> focus first focusable element when focus moves out of sidebar
      event.preventDefault();
      sidebar.firstFocusable.focus();
    }
  }

  function initSidebarResize(sidebar) {
    // custom event emitted when window is resized - detect only if the sidebar--static@{breakpoint} class was added
    var beforeContent = getComputedStyle(
      sidebar.element,
      ":before"
    ).getPropertyValue("content");
    if (beforeContent && beforeContent != "" && beforeContent != "none") {
      checkSidebarLayour(sidebar);

      sidebar.element.addEventListener("update-sidebar", function (event) {
        checkSidebarLayour(sidebar);
      });
    }
    Util.addClass(sidebar.element, sidebar.readyClass);
  }

  function checkSidebarLayour(sidebar) {
    var layout = getComputedStyle(sidebar.element, ":before")
      .getPropertyValue("content")
      .replace(/\'|"/g, "");
    if (layout == sidebar.layout) return;
    sidebar.layout = layout;
    if (layout != "static") Util.addClass(sidebar.element, "is-hidden");
    Util.toggleClass(
      sidebar.element,
      sidebar.staticClass + sidebar.customStaticClass,
      layout == "static"
    );
    if (layout != "static")
      setTimeout(function () {
        Util.removeClass(sidebar.element, "is-hidden");
      });
    // reset element role
    layout == "static"
      ? sidebar.element.removeAttribute("role", "alertdialog")
      : sidebar.element.setAttribute("role", "alertdialog");
    // reset mobile behaviour
    if (layout == "static" && Util.hasClass(sidebar.element, sidebar.showClass))
      closeSidebar(sidebar);
  }

  function getFocusableElements(sidebar) {
    //get all focusable elements inside the drawer
    var allFocusable = sidebar.element.querySelectorAll(
      '[href], input:not([disabled]), select:not([disabled]), textarea:not([disabled]), button:not([disabled]), iframe, object, embed, [tabindex]:not([tabindex="-1"]), [contenteditable], audio[controls], video[controls], summary'
    );
    getFirstVisible(sidebar, allFocusable);
    getLastVisible(sidebar, allFocusable);
  }

  function getFirstVisible(sidebar, elements) {
    //get first visible focusable element inside the sidebar
    for (var i = 0; i < elements.length; i++) {
      if (
        elements[i].offsetWidth ||
        elements[i].offsetHeight ||
        elements[i].getClientRects().length
      ) {
        sidebar.firstFocusable = elements[i];
        return true;
      }
    }
  }

  function getLastVisible(sidebar, elements) {
    //get last visible focusable element inside the sidebar
    for (var i = elements.length - 1; i >= 0; i--) {
      if (
        elements[i].offsetWidth ||
        elements[i].offsetHeight ||
        elements[i].getClientRects().length
      ) {
        sidebar.lastFocusable = elements[i];
        return true;
      }
    }
  }

  //initialize the Sidebar objects
  var sidebar = document.getElementsByClassName("js-sidebar");
  if (sidebar.length > 0) {
    for (var i = 0; i < sidebar.length; i++) {
      (function (i) {
        new Sidebar(sidebar[i]);
      })(i);
    }
    // switch from mobile to static layout
    var customEvent = new CustomEvent("update-sidebar");
    window.addEventListener("resize", function (event) {
      !window.requestAnimationFrame
        ? setTimeout(function () {
            resetLayout();
          }, 250)
        : window.requestAnimationFrame(resetLayout);
    });

    function resetLayout() {
      for (var i = 0; i < sidebar.length; i++) {
        (function (i) {
          sidebar[i].dispatchEvent(customEvent);
        })(i);
      }
    }
  }
})();

// File#: _1_smooth-scrolling
// Usage: codyhouse.co/license
(function () {
  var SmoothScroll = function (element) {
    this.element = element;
    this.scrollDuration =
      parseInt(this.element.getAttribute("data-duration")) || 300;
    this.dataElement =
      this.element.getAttribute("data-scrollable-element") ||
      this.element.getAttribute("data-element");
    this.scrollElement = this.dataElement
      ? document.querySelector(this.dataElement)
      : window;
    this.initScroll();
  };

  SmoothScroll.prototype.initScroll = function () {
    var self = this;

    //detect click on link
    this.element.addEventListener("click", function (event) {
      event.preventDefault();
      var targetId = event.target
          .closest(".js-smooth-scroll")
          .getAttribute("href")
          .replace("#", ""),
        target = document.getElementById(targetId),
        targetTabIndex = target.getAttribute("tabindex"),
        windowScrollTop =
          self.scrollElement.scrollTop || document.documentElement.scrollTop;

      if (!self.dataElement)
        windowScrollTop = window.scrollY || document.documentElement.scrollTop;

      var scrollElement = self.dataElement ? self.scrollElement : false;

      var fixedHeight = self.getFixedElementHeight(); // check if there's a fixed element on the page
      Util.scrollTo(
        target.getBoundingClientRect().top + windowScrollTop - fixedHeight,
        self.scrollDuration,
        function () {
          //move the focus to the target element - don't break keyboard navigation
          Util.moveFocus(target);
          history.pushState(false, false, "#" + targetId);
          self.resetTarget(target, targetTabIndex);
        },
        scrollElement
      );
    });
  };

  SmoothScroll.prototype.resetTarget = function (target, tabindex) {
    if (parseInt(target.getAttribute("tabindex")) < 0) {
      target.style.outline = "none";
      !tabindex && target.removeAttribute("tabindex");
    }
  };

  SmoothScroll.prototype.getFixedElementHeight = function () {
    var fixedElementDelta = parseInt(
      getComputedStyle(document.documentElement).getPropertyValue(
        "scroll-padding"
      )
    );
    if (isNaN(fixedElementDelta)) {
      // scroll-padding not supported
      fixedElementDelta = 0;
      var fixedElement = document.querySelector(
        this.element.getAttribute("data-fixed-element")
      );
      if (fixedElement)
        fixedElementDelta = parseInt(
          fixedElement.getBoundingClientRect().height
        );
    }
    return fixedElementDelta;
  };

  //initialize the Smooth Scroll objects
  var smoothScrollLinks = document.getElementsByClassName("js-smooth-scroll");
  if (
    smoothScrollLinks.length > 0 &&
    !Util.cssSupports("scroll-behavior", "smooth") &&
    window.requestAnimationFrame
  ) {
    // you need javascript only if css scroll-behavior is not supported
    for (var i = 0; i < smoothScrollLinks.length; i++) {
      (function (i) {
        new SmoothScroll(smoothScrollLinks[i]);
      })(i);
    }
  }
})();

// File#: _1_sticky-banner
// Usage: codyhouse.co/license
(function () {
  var StickyBanner = function (element) {
    this.element = element;
    this.offsetIn = 0;
    this.offsetOut = 0;
    this.targetIn = this.element.getAttribute("data-target-in")
      ? document.querySelector(this.element.getAttribute("data-target-in"))
      : false;
    this.targetOut = this.element.getAttribute("data-target-out")
      ? document.querySelector(this.element.getAttribute("data-target-out"))
      : false;
    this.reset = 0;
    getBannerOffsets(this);
    initBanner(this);
  };

  function getBannerOffsets(element) {
    // get offset in and offset out values
    // update offsetIn
    element.offsetIn = 0;
    if (element.targetIn) {
      var boundingClientRect = element.targetIn.getBoundingClientRect();
      element.offsetIn =
        boundingClientRect.top +
        document.documentElement.scrollTop +
        boundingClientRect.height;
    }
    var dataOffsetIn = element.element.getAttribute("data-offset-in");
    if (dataOffsetIn) {
      element.offsetIn = element.offsetIn + parseInt(dataOffsetIn);
    }
    // update offsetOut
    element.offsetOut = 0;
    if (element.targetOut) {
      var boundingClientRect = element.targetOut.getBoundingClientRect();
      element.offsetOut =
        boundingClientRect.top +
        document.documentElement.scrollTop -
        window.innerHeight;
    }
    var dataOffsetOut = element.element.getAttribute("data-offset-out");
    if (dataOffsetOut) {
      element.offsetOut = element.offsetOut + parseInt(dataOffsetOut);
    }
  }

  function initBanner(element) {
    resetBannerVisibility(element);

    element.element.addEventListener("resize-banner", function () {
      getBannerOffsets(element);
      resetBannerVisibility(element);
    });

    element.element.addEventListener("scroll-banner", function () {
      if (element.reset < 10) {
        getBannerOffsets(element);
        element.reset = element.reset + 1;
      }
      resetBannerVisibility(element);
    });
  }

  function resetBannerVisibility(element) {
    var scrollTop = document.documentElement.scrollTop,
      topTarget = false,
      bottomTarget = false;
    if (element.offsetIn < scrollTop) {
      topTarget = true;
    }
    if (element.offsetOut == 0 || scrollTop < element.offsetOut) {
      bottomTarget = true;
    }
    Util.toggleClass(
      element.element,
      "sticky-banner--visible",
      bottomTarget && topTarget
    );
  }

  //initialize the Sticky Banner objects
  var stckyBanner = document.getElementsByClassName("js-sticky-banner");
  if (stckyBanner.length > 0) {
    for (var i = 0; i < stckyBanner.length; i++) {
      (function (i) {
        new StickyBanner(stckyBanner[i]);
      })(i);
    }

    // init scroll/resize
    var resizingId = false,
      scrollingId = false,
      resizeEvent = new CustomEvent("resize-banner"),
      scrollEvent = new CustomEvent("scroll-banner");

    window.addEventListener("resize", function (event) {
      clearTimeout(resizingId);
      resizingId = setTimeout(function () {
        doneResizing(resizeEvent);
      }, 300);
    });

    window.addEventListener("scroll", function (event) {
      if (scrollingId) return;
      scrollingId = true;
      window.requestAnimationFrame
        ? window.requestAnimationFrame(function () {
            doneResizing(scrollEvent);
            scrollingId = false;
          })
        : setTimeout(function () {
            doneResizing(scrollEvent);
            scrollingId = false;
          }, 200);

      resizingId = setTimeout(function () {
        doneResizing(resizeEvent);
      }, 300);
    });

    function doneResizing(event) {
      for (var i = 0; i < stckyBanner.length; i++) {
        (function (i) {
          stckyBanner[i].dispatchEvent(event);
        })(i);
      }
    }
  }
})();

// File#: _1_swipe-content
(function () {
  var SwipeContent = function (element) {
    this.element = element;
    this.delta = [false, false];
    this.dragging = false;
    this.intervalId = false;
    initSwipeContent(this);
  };

  function initSwipeContent(content) {
    content.element.addEventListener("mousedown", handleEvent.bind(content));
    content.element.addEventListener("touchstart", handleEvent.bind(content));
  }

  function initDragging(content) {
    //add event listeners
    content.element.addEventListener("mousemove", handleEvent.bind(content));
    content.element.addEventListener("touchmove", handleEvent.bind(content));
    content.element.addEventListener("mouseup", handleEvent.bind(content));
    content.element.addEventListener("mouseleave", handleEvent.bind(content));
    content.element.addEventListener("touchend", handleEvent.bind(content));
  }

  function cancelDragging(content) {
    //remove event listeners
    if (content.intervalId) {
      !window.requestAnimationFrame
        ? clearInterval(content.intervalId)
        : window.cancelAnimationFrame(content.intervalId);
      content.intervalId = false;
    }
    content.element.removeEventListener("mousemove", handleEvent.bind(content));
    content.element.removeEventListener("touchmove", handleEvent.bind(content));
    content.element.removeEventListener("mouseup", handleEvent.bind(content));
    content.element.removeEventListener(
      "mouseleave",
      handleEvent.bind(content)
    );
    content.element.removeEventListener("touchend", handleEvent.bind(content));
  }

  function handleEvent(event) {
    switch (event.type) {
      case "mousedown":
      case "touchstart":
        startDrag(this, event);
        break;
      case "mousemove":
      case "touchmove":
        drag(this, event);
        break;
      case "mouseup":
      case "mouseleave":
      case "touchend":
        endDrag(this, event);
        break;
    }
  }

  function startDrag(content, event) {
    content.dragging = true;
    // listen to drag movements
    initDragging(content);
    content.delta = [
      parseInt(unify(event).clientX),
      parseInt(unify(event).clientY),
    ];
    // emit drag start event
    emitSwipeEvents(content, "dragStart", content.delta, event.target);
  }

  function endDrag(content, event) {
    cancelDragging(content);
    // credits: https://css-tricks.com/simple-swipe-with-vanilla-javascript/
    var dx = parseInt(unify(event).clientX),
      dy = parseInt(unify(event).clientY);

    // check if there was a left/right swipe
    if (content.delta && (content.delta[0] || content.delta[0] === 0)) {
      var s = getSign(dx - content.delta[0]);

      if (Math.abs(dx - content.delta[0]) > 30) {
        s < 0
          ? emitSwipeEvents(content, "swipeLeft", [dx, dy])
          : emitSwipeEvents(content, "swipeRight", [dx, dy]);
      }

      content.delta[0] = false;
    }
    // check if there was a top/bottom swipe
    if (content.delta && (content.delta[1] || content.delta[1] === 0)) {
      var y = getSign(dy - content.delta[1]);

      if (Math.abs(dy - content.delta[1]) > 30) {
        y < 0
          ? emitSwipeEvents(content, "swipeUp", [dx, dy])
          : emitSwipeEvents(content, "swipeDown", [dx, dy]);
      }

      content.delta[1] = false;
    }
    // emit drag end event
    emitSwipeEvents(content, "dragEnd", [dx, dy]);
    content.dragging = false;
  }

  function drag(content, event) {
    if (!content.dragging) return;
    // emit dragging event with coordinates
    !window.requestAnimationFrame
      ? (content.intervalId = setTimeout(function () {
          emitDrag.bind(content, event);
        }, 250))
      : (content.intervalId = window.requestAnimationFrame(
          emitDrag.bind(content, event)
        ));
  }

  function emitDrag(event) {
    emitSwipeEvents(this, "dragging", [
      parseInt(unify(event).clientX),
      parseInt(unify(event).clientY),
    ]);
  }

  function unify(event) {
    // unify mouse and touch events
    return event.changedTouches ? event.changedTouches[0] : event;
  }

  function emitSwipeEvents(content, eventName, detail, el) {
    var trigger = false;
    if (el) trigger = el;
    // emit event with coordinates
    var event = new CustomEvent(eventName, {
      detail: { x: detail[0], y: detail[1], origin: trigger },
    });
    content.element.dispatchEvent(event);
  }

  function getSign(x) {
    if (!Math.sign) {
      return (x > 0) - (x < 0) || +x;
    } else {
      return Math.sign(x);
    }
  }

  window.SwipeContent = SwipeContent;

  //initialize the SwipeContent objects
  var swipe = document.getElementsByClassName("js-swipe-content");
  if (swipe.length > 0) {
    for (var i = 0; i < swipe.length; i++) {
      (function (i) {
        new SwipeContent(swipe[i]);
      })(i);
    }
  }
})();

// File#: _1_tabs
// Usage: codyhouse.co/license
(function () {
  var Tab = function (element) {
    this.element = element;
    this.tabList = this.element.getElementsByClassName("js-tabs__controls")[0];
    this.listItems = this.tabList.getElementsByTagName("li");
    this.triggers = this.tabList.getElementsByTagName("a");
    this.panelsList = this.element.getElementsByClassName("js-tabs__panels")[0];
    this.panels = Util.getChildrenByClassName(
      this.panelsList,
      "js-tabs__panel"
    );
    this.hideClass = "is-hidden";
    this.customShowClass = this.element.getAttribute("data-show-panel-class")
      ? this.element.getAttribute("data-show-panel-class")
      : false;
    this.layout = this.element.getAttribute("data-tabs-layout")
      ? this.element.getAttribute("data-tabs-layout")
      : "horizontal";
    this.initTab();
  };

  Tab.prototype.initTab = function () {
    //set initial aria attributes
    this.tabList.setAttribute("role", "tablist");
    for (var i = 0; i < this.triggers.length; i++) {
      var bool = i == 0,
        panelId = this.panels[i].getAttribute("id");
      this.listItems[i].setAttribute("role", "presentation");
      Util.setAttributes(this.triggers[i], {
        role: "tab",
        "aria-selected": bool,
        "aria-controls": panelId,
        id: "tab-" + panelId,
      });
      Util.addClass(this.triggers[i], "js-tabs__trigger");
      Util.setAttributes(this.panels[i], {
        role: "tabpanel",
        "aria-labelledby": "tab-" + panelId,
      });
      Util.toggleClass(this.panels[i], this.hideClass, !bool);

      if (!bool) this.triggers[i].setAttribute("tabindex", "-1");
    }

    //listen for Tab events
    this.initTabEvents();
  };

  Tab.prototype.initTabEvents = function () {
    var self = this;
    //click on a new tab -> select content
    this.tabList.addEventListener("click", function (event) {
      if (event.target.closest(".js-tabs__trigger"))
        self.triggerTab(event.target.closest(".js-tabs__trigger"), event);
    });
    //arrow keys to navigate through tabs
    this.tabList.addEventListener("keydown", function (event) {
      if (!event.target.closest(".js-tabs__trigger")) return;
      if (tabNavigateNext(event, self.layout)) {
        event.preventDefault();
        self.selectNewTab("next");
      } else if (tabNavigatePrev(event, self.layout)) {
        event.preventDefault();
        self.selectNewTab("prev");
      }
    });
  };

  Tab.prototype.selectNewTab = function (direction) {
    var selectedTab = this.tabList.querySelector('[aria-selected="true"]'),
      index = Util.getIndexInArray(this.triggers, selectedTab);
    index = direction == "next" ? index + 1 : index - 1;
    //make sure index is in the correct interval
    //-> from last element go to first using the right arrow, from first element go to last using the left arrow
    if (index < 0) index = this.listItems.length - 1;
    if (index >= this.listItems.length) index = 0;
    this.triggerTab(this.triggers[index]);
    this.triggers[index].focus();
  };

  Tab.prototype.triggerTab = function (tabTrigger, event) {
    var self = this;
    event && event.preventDefault();
    var index = Util.getIndexInArray(this.triggers, tabTrigger);
    //no need to do anything if tab was already selected
    if (this.triggers[index].getAttribute("aria-selected") == "true") return;

    for (var i = 0; i < this.triggers.length; i++) {
      var bool = i == index;
      Util.toggleClass(this.panels[i], this.hideClass, !bool);
      if (this.customShowClass)
        Util.toggleClass(this.panels[i], this.customShowClass, bool);
      this.triggers[i].setAttribute("aria-selected", bool);
      bool
        ? this.triggers[i].setAttribute("tabindex", "0")
        : this.triggers[i].setAttribute("tabindex", "-1");
    }
  };

  function tabNavigateNext(event, layout) {
    if (
      layout == "horizontal" &&
      ((event.keyCode && event.keyCode == 39) ||
        (event.key && event.key == "ArrowRight"))
    ) {
      return true;
    } else if (
      layout == "vertical" &&
      ((event.keyCode && event.keyCode == 40) ||
        (event.key && event.key == "ArrowDown"))
    ) {
      return true;
    } else {
      return false;
    }
  }

  function tabNavigatePrev(event, layout) {
    if (
      layout == "horizontal" &&
      ((event.keyCode && event.keyCode == 37) ||
        (event.key && event.key == "ArrowLeft"))
    ) {
      return true;
    } else if (
      layout == "vertical" &&
      ((event.keyCode && event.keyCode == 38) ||
        (event.key && event.key == "ArrowUp"))
    ) {
      return true;
    } else {
      return false;
    }
  }

  //initialize the Tab objects
  var tabs = document.getElementsByClassName("js-tabs");
  if (tabs.length > 0) {
    for (var i = 0; i < tabs.length; i++) {
      (function (i) {
        new Tab(tabs[i]);
      })(i);
    }
  }
})();
// File#: _2_carousel
// Usage: codyhouse.co/license
(function () {
  var Carousel = function (opts) {
    this.options = Util.extend(Carousel.defaults, opts);
    this.element = this.options.element;
    this.listWrapper =
      this.element.getElementsByClassName("carousel__wrapper")[0];
    this.list = this.element.getElementsByClassName("carousel__list")[0];
    this.items = this.element.getElementsByClassName("carousel__item");
    this.initItems = []; // store only the original elements - will need this for cloning
    this.itemsNb = this.items.length; //original number of items
    this.visibItemsNb = 1; // tot number of visible items
    this.itemsWidth = 1; // this will be updated with the right width of items
    this.itemOriginalWidth = false; // store the initial width to use it on resize
    this.selectedItem = 0; // index of first visible item
    this.translateContainer = 0; // this will be the amount the container has to be translated each time a new group has to be shown (negative)
    this.containerWidth = 0; // this will be used to store the total width of the carousel (including the overflowing part)
    this.ariaLive = false;
    // navigation
    this.controls = this.element.getElementsByClassName("js-carousel__control");
    this.animating = false;
    // autoplay
    this.autoplayId = false;
    this.autoplayPaused = false;
    //drag
    this.dragStart = false;
    // resize
    this.resizeId = false;
    // used to re-initialize js
    this.cloneList = [];
    // store items min-width
    this.itemAutoSize = false;
    // store translate value (loop = off)
    this.totTranslate = 0;
    // modify loop option if navigation is on
    if (this.options.nav) this.options.loop = false;
    // store counter elements (if present)
    this.counter = this.element.getElementsByClassName("js-carousel__counter");
    this.counterTor = this.element.getElementsByClassName(
      "js-carousel__counter-tot"
    );
    initCarouselLayout(this); // get number visible items + width items
    setItemsWidth(this, true);
    insertBefore(this, this.visibItemsNb); // insert clones before visible elements
    updateCarouselClones(this); // insert clones after visible elements
    resetItemsTabIndex(this); // make sure not visible items are not focusable
    initAriaLive(this); // set aria-live region for SR
    initCarouselEvents(this); // listen to events
    initCarouselCounter(this);
    Util.addClass(this.element, "carousel--loaded");
  };

  //public carousel functions
  Carousel.prototype.showNext = function () {
    showNextItems(this);
  };

  Carousel.prototype.showPrev = function () {
    showPrevItems(this);
  };

  Carousel.prototype.startAutoplay = function () {
    startAutoplay(this);
  };

  Carousel.prototype.pauseAutoplay = function () {
    pauseAutoplay(this);
  };

  //private carousel functions
  function initCarouselLayout(carousel) {
    // evaluate size of single elements + number of visible elements
    var itemStyle = window.getComputedStyle(carousel.items[0]),
      containerStyle = window.getComputedStyle(carousel.listWrapper),
      itemWidth = parseFloat(itemStyle.getPropertyValue("width")),
      itemMargin = parseFloat(itemStyle.getPropertyValue("margin-right")),
      containerPadding = parseFloat(
        containerStyle.getPropertyValue("padding-left")
      ),
      containerWidth = parseFloat(containerStyle.getPropertyValue("width"));

    if (!carousel.itemAutoSize) {
      carousel.itemAutoSize = itemWidth;
    }

    // if carousel.listWrapper is hidden -> make sure to retrieve the proper width
    containerWidth = getCarouselWidth(carousel, containerWidth);

    if (!carousel.itemOriginalWidth) {
      // on resize -> use initial width of items to recalculate
      carousel.itemOriginalWidth = itemWidth;
    } else {
      itemWidth = carousel.itemOriginalWidth;
    }

    if (carousel.itemAutoSize) {
      carousel.itemOriginalWidth = parseInt(carousel.itemAutoSize);
      itemWidth = carousel.itemOriginalWidth;
    }
    // make sure itemWidth is smaller than container width
    if (containerWidth < itemWidth) {
      carousel.itemOriginalWidth = containerWidth;
      itemWidth = carousel.itemOriginalWidth;
    }
    // get proper width of elements
    carousel.visibItemsNb = parseInt(
      (containerWidth - 2 * containerPadding + itemMargin) /
        (itemWidth + itemMargin)
    );
    carousel.itemsWidth = parseFloat(
      (
        (containerWidth - 2 * containerPadding + itemMargin) /
          carousel.visibItemsNb -
        itemMargin
      ).toFixed(1)
    );
    carousel.containerWidth =
      (carousel.itemsWidth + itemMargin) * carousel.items.length;
    carousel.translateContainer =
      0 - (carousel.itemsWidth + itemMargin) * carousel.visibItemsNb;
    // flexbox fallback
    if (!flexSupported)
      carousel.list.style.width =
        (carousel.itemsWidth + itemMargin) * carousel.visibItemsNb * 3 + "px";

    // this is used when loop == off
    carousel.totTranslate =
      0 - carousel.selectedItem * (carousel.itemsWidth + itemMargin);
    if (carousel.items.length <= carousel.visibItemsNb)
      carousel.totTranslate = 0;

    centerItems(carousel); // center items if carousel.items.length < visibItemsNb
    alignControls(carousel); // check if controls need to be aligned to a different element
  }

  function setItemsWidth(carousel, bool) {
    for (var i = 0; i < carousel.items.length; i++) {
      carousel.items[i].style.width = carousel.itemsWidth + "px";
      if (bool) carousel.initItems.push(carousel.items[i]);
    }
  }

  function updateCarouselClones(carousel) {
    if (!carousel.options.loop) return;
    // take care of clones after visible items (needs to run after the update of clones before visible items)
    if (carousel.items.length < carousel.visibItemsNb * 3) {
      insertAfter(
        carousel,
        carousel.visibItemsNb * 3 - carousel.items.length,
        carousel.items.length - carousel.visibItemsNb * 2
      );
    } else if (carousel.items.length > carousel.visibItemsNb * 3) {
      removeClones(
        carousel,
        carousel.visibItemsNb * 3,
        carousel.items.length - carousel.visibItemsNb * 3
      );
    }
    // set proper translate value for the container
    setTranslate(carousel, "translateX(" + carousel.translateContainer + "px)");
  }

  function initCarouselEvents(carousel) {
    // listen for click on previous/next arrow
    // dots navigation
    if (carousel.options.nav) {
      carouselCreateNavigation(carousel);
      carouselInitNavigationEvents(carousel);
    }

    if (carousel.controls.length > 0) {
      carousel.controls[0].addEventListener("click", function (event) {
        event.preventDefault();
        showPrevItems(carousel);
        updateAriaLive(carousel);
      });
      carousel.controls[1].addEventListener("click", function (event) {
        event.preventDefault();
        showNextItems(carousel);
        updateAriaLive(carousel);
      });

      // update arrow visility -> loop == off only
      resetCarouselControls(carousel);
    }
    // autoplay
    if (carousel.options.autoplay) {
      startAutoplay(carousel);
      // pause autoplay if user is interacting with the carousel
      carousel.element.addEventListener("mouseenter", function (event) {
        pauseAutoplay(carousel);
        carousel.autoplayPaused = true;
      });
      carousel.element.addEventListener("focusin", function (event) {
        pauseAutoplay(carousel);
        carousel.autoplayPaused = true;
      });
      carousel.element.addEventListener("mouseleave", function (event) {
        carousel.autoplayPaused = false;
        startAutoplay(carousel);
      });
      carousel.element.addEventListener("focusout", function (event) {
        carousel.autoplayPaused = false;
        startAutoplay(carousel);
      });
    }
    // drag events
    if (carousel.options.drag && window.requestAnimationFrame) {
      //init dragging
      new SwipeContent(carousel.element);
      carousel.element.addEventListener("dragStart", function (event) {
        if (
          event.detail.origin &&
          event.detail.origin.closest(".js-carousel__control")
        )
          return;
        if (
          event.detail.origin &&
          event.detail.origin.closest(".js-carousel__navigation")
        )
          return;
        if (
          event.detail.origin &&
          !event.detail.origin.closest(".carousel__wrapper")
        )
          return;
        Util.addClass(carousel.element, "carousel--is-dragging");
        pauseAutoplay(carousel);
        carousel.dragStart = event.detail.x;
        animateDragEnd(carousel);
      });
      carousel.element.addEventListener("dragging", function (event) {
        if (!carousel.dragStart) return;
        if (
          carousel.animating ||
          Math.abs(event.detail.x - carousel.dragStart) < 10
        )
          return;
        var translate =
          event.detail.x - carousel.dragStart + carousel.translateContainer;
        if (!carousel.options.loop) {
          translate =
            event.detail.x - carousel.dragStart + carousel.totTranslate;
        }
        setTranslate(carousel, "translateX(" + translate + "px)");
      });
    }
    // reset on resize
    window.addEventListener("resize", function (event) {
      pauseAutoplay(carousel);
      clearTimeout(carousel.resizeId);
      carousel.resizeId = setTimeout(function () {
        resetCarouselResize(carousel);
        // reset dots navigation
        resetDotsNavigation(carousel);
        resetCarouselControls(carousel);
        setCounterItem(carousel);
        startAutoplay(carousel);
        centerItems(carousel); // center items if carousel.items.length < visibItemsNb
        alignControls(carousel);
      }, 250);
    });
  }

  function showPrevItems(carousel) {
    if (carousel.animating) return;
    carousel.animating = true;
    carousel.selectedItem = getIndex(
      carousel,
      carousel.selectedItem - carousel.visibItemsNb
    );
    animateList(carousel, "0", "prev");
  }

  function showNextItems(carousel) {
    if (carousel.animating) return;
    carousel.animating = true;
    carousel.selectedItem = getIndex(
      carousel,
      carousel.selectedItem + carousel.visibItemsNb
    );
    animateList(carousel, carousel.translateContainer * 2 + "px", "next");
  }

  function animateDragEnd(carousel) {
    // end-of-dragging animation
    carousel.element.addEventListener("dragEnd", function cb(event) {
      carousel.element.removeEventListener("dragEnd", cb);
      Util.removeClass(carousel.element, "carousel--is-dragging");
      if (event.detail.x - carousel.dragStart < -40) {
        carousel.animating = false;
        showNextItems(carousel);
      } else if (event.detail.x - carousel.dragStart > 40) {
        carousel.animating = false;
        showPrevItems(carousel);
      } else if (event.detail.x - carousel.dragStart == 0) {
        // this is just a click -> no dragging
        return;
      } else {
        // not dragged enought -> do not update carousel, just reset
        carousel.animating = true;
        animateList(carousel, carousel.translateContainer + "px", false);
      }
      carousel.dragStart = false;
    });
  }

  function animateList(carousel, translate, direction) {
    // takes care of changing visible items
    pauseAutoplay(carousel);
    Util.addClass(carousel.list, "carousel__list--animating");
    var initTranslate = carousel.totTranslate;
    if (!carousel.options.loop) {
      translate = noLoopTranslateValue(carousel, direction);
    }
    setTranslate(carousel, "translateX(" + translate + ")");
    if (transitionSupported) {
      carousel.list.addEventListener("transitionend", function cb(event) {
        if (event.propertyName && event.propertyName != "transform") return;
        Util.removeClass(carousel.list, "carousel__list--animating");
        carousel.list.removeEventListener("transitionend", cb);
        animateListCb(carousel, direction);
      });
    } else {
      animateListCb(carousel, direction);
    }
    if (!carousel.options.loop && initTranslate == carousel.totTranslate) {
      // translate value was not updated -> trigger transitionend event to restart carousel
      carousel.list.dispatchEvent(new CustomEvent("transitionend"));
    }
    resetCarouselControls(carousel);
    setCounterItem(carousel);
  }

  function noLoopTranslateValue(carousel, direction) {
    var translate = carousel.totTranslate;
    if (direction == "next") {
      translate = carousel.totTranslate + carousel.translateContainer;
    } else if (direction == "prev") {
      translate = carousel.totTranslate - carousel.translateContainer;
    } else if (direction == "click") {
      translate = carousel.selectedDotIndex * carousel.translateContainer;
    }
    if (translate > 0) {
      translate = 0;
      carousel.selectedItem = 0;
    }
    if (translate < -carousel.translateContainer - carousel.containerWidth) {
      translate = -carousel.translateContainer - carousel.containerWidth;
      carousel.selectedItem = carousel.items.length - carousel.visibItemsNb;
    }
    if (carousel.visibItemsNb > carousel.items.length) translate = 0;
    carousel.totTranslate = translate;
    return translate + "px";
  }

  function animateListCb(carousel, direction) {
    // reset actions after carousel has been updated
    if (direction) updateClones(carousel, direction);
    carousel.animating = false;
    // reset autoplay
    startAutoplay(carousel);
    // reset tab index
    resetItemsTabIndex(carousel);
  }

  function updateClones(carousel, direction) {
    if (!carousel.options.loop) return;
    // at the end of each animation, we need to update the clones before and after the visible items
    var index =
      direction == "next" ? 0 : carousel.items.length - carousel.visibItemsNb;
    // remove clones you do not need anymore
    removeClones(carousel, index, false);
    // add new clones
    direction == "next"
      ? insertAfter(carousel, carousel.visibItemsNb, 0)
      : insertBefore(carousel, carousel.visibItemsNb);
    //reset transform
    setTranslate(carousel, "translateX(" + carousel.translateContainer + "px)");
  }

  function insertBefore(carousel, nb, delta) {
    if (!carousel.options.loop) return;
    var clones = document.createDocumentFragment();
    var start = 0;
    if (delta) start = delta;
    for (var i = start; i < nb; i++) {
      var index = getIndex(carousel, carousel.selectedItem - i - 1),
        clone = carousel.initItems[index].cloneNode(true);
      Util.addClass(clone, "js-clone");
      clones.insertBefore(clone, clones.firstChild);
    }
    carousel.list.insertBefore(clones, carousel.list.firstChild);
    emitCarouselUpdateEvent(carousel);
  }

  function insertAfter(carousel, nb, init) {
    if (!carousel.options.loop) return;
    var clones = document.createDocumentFragment();
    for (var i = init; i < nb + init; i++) {
      var index = getIndex(
          carousel,
          carousel.selectedItem + carousel.visibItemsNb + i
        ),
        clone = carousel.initItems[index].cloneNode(true);
      Util.addClass(clone, "js-clone");
      clones.appendChild(clone);
    }
    carousel.list.appendChild(clones);
    emitCarouselUpdateEvent(carousel);
  }

  function removeClones(carousel, index, bool) {
    if (!carousel.options.loop) return;
    if (!bool) {
      bool = carousel.visibItemsNb;
    }
    for (var i = 0; i < bool; i++) {
      if (carousel.items[index])
        carousel.list.removeChild(carousel.items[index]);
    }
  }

  function resetCarouselResize(carousel) {
    // reset carousel on resize
    var visibleItems = carousel.visibItemsNb;
    // get new items min-width value
    resetItemAutoSize(carousel);
    initCarouselLayout(carousel);
    setItemsWidth(carousel, false);
    resetItemsWidth(carousel); // update the array of original items -> array used to create clones
    if (carousel.options.loop) {
      if (visibleItems > carousel.visibItemsNb) {
        removeClones(carousel, 0, visibleItems - carousel.visibItemsNb);
      } else if (visibleItems < carousel.visibItemsNb) {
        insertBefore(carousel, carousel.visibItemsNb, visibleItems);
      }
      updateCarouselClones(carousel); // this will take care of translate + after elements
    } else {
      // reset default translate to a multiple value of (itemWidth + margin)
      var translate = noLoopTranslateValue(carousel);
      setTranslate(carousel, "translateX(" + translate + ")");
    }
    resetItemsTabIndex(carousel); // reset focusable elements
  }

  function resetItemAutoSize(carousel) {
    if (!cssPropertiesSupported) return;
    // remove inline style
    carousel.items[0].removeAttribute("style");
    // get original item width
    carousel.itemAutoSize = getComputedStyle(
      carousel.items[0]
    ).getPropertyValue("width");
  }

  function resetItemsWidth(carousel) {
    for (var i = 0; i < carousel.initItems.length; i++) {
      carousel.initItems[i].style.width = carousel.itemsWidth + "px";
    }
  }

  function resetItemsTabIndex(carousel) {
    var carouselActive = carousel.items.length > carousel.visibItemsNb;
    var j = carousel.items.length;
    for (var i = 0; i < carousel.items.length; i++) {
      if (carousel.options.loop) {
        if (i < carousel.visibItemsNb || i >= 2 * carousel.visibItemsNb) {
          carousel.items[i].setAttribute("tabindex", "-1");
        } else {
          if (i < j) j = i;
          carousel.items[i].removeAttribute("tabindex");
        }
      } else {
        if (
          (i < carousel.selectedItem ||
            i >= carousel.selectedItem + carousel.visibItemsNb) &&
          carouselActive
        ) {
          carousel.items[i].setAttribute("tabindex", "-1");
        } else {
          if (i < j) j = i;
          carousel.items[i].removeAttribute("tabindex");
        }
      }
    }
    resetVisibilityOverflowItems(carousel, j);
  }

  function startAutoplay(carousel) {
    if (
      carousel.options.autoplay &&
      !carousel.autoplayId &&
      !carousel.autoplayPaused
    ) {
      carousel.autoplayId = setInterval(function () {
        showNextItems(carousel);
      }, carousel.options.autoplayInterval);
    }
  }

  function pauseAutoplay(carousel) {
    if (carousel.options.autoplay) {
      clearInterval(carousel.autoplayId);
      carousel.autoplayId = false;
    }
  }

  function initAriaLive(carousel) {
    // create an aria-live region for SR
    if (!carousel.options.ariaLive) return;
    // create an element that will be used to announce the new visible slide to SR
    var srLiveArea = document.createElement("div");
    Util.setAttributes(srLiveArea, {
      class: "sr-only js-carousel__aria-live",
      "aria-live": "polite",
      "aria-atomic": "true",
    });
    carousel.element.appendChild(srLiveArea);
    carousel.ariaLive = srLiveArea;
  }

  function updateAriaLive(carousel) {
    // announce to SR which items are now visible
    if (!carousel.options.ariaLive) return;
    carousel.ariaLive.innerHTML =
      "Item " +
      (carousel.selectedItem + 1) +
      " selected. " +
      carousel.visibItemsNb +
      " items of " +
      carousel.initItems.length +
      " visible";
  }

  function getIndex(carousel, index) {
    if (index < 0) index = getPositiveValue(index, carousel.itemsNb);
    if (index >= carousel.itemsNb) index = index % carousel.itemsNb;
    return index;
  }

  function getPositiveValue(value, add) {
    value = value + add;
    if (value > 0) return value;
    else return getPositiveValue(value, add);
  }

  function setTranslate(carousel, translate) {
    carousel.list.style.transform = translate;
    carousel.list.style.msTransform = translate;
  }

  function getCarouselWidth(carousel, computedWidth) {
    // retrieve carousel width if carousel is initially hidden
    var closestHidden = carousel.listWrapper.closest(".sr-only");
    if (closestHidden) {
      // carousel is inside an .sr-only (visually hidden) element
      Util.removeClass(closestHidden, "sr-only");
      computedWidth = carousel.listWrapper.offsetWidth;
      Util.addClass(closestHidden, "sr-only");
    } else if (isNaN(computedWidth)) {
      computedWidth = getHiddenParentWidth(carousel.element, carousel);
    }
    return computedWidth;
  }

  function getHiddenParentWidth(element, carousel) {
    var parent = element.parentElement;
    if (parent.tagName.toLowerCase() == "html") return 0;
    var style = window.getComputedStyle(parent);
    if (style.display == "none" || style.visibility == "hidden") {
      parent.setAttribute(
        "style",
        "display: block!important; visibility: visible!important;"
      );
      var computedWidth = carousel.listWrapper.offsetWidth;
      parent.style.display = "";
      parent.style.visibility = "";
      return computedWidth;
    } else {
      return getHiddenParentWidth(parent, carousel);
    }
  }

  function resetCarouselControls(carousel) {
    if (carousel.options.loop) return;
    // update arrows status
    if (carousel.controls.length > 0) {
      carousel.totTranslate == 0
        ? carousel.controls[0].setAttribute("disabled", true)
        : carousel.controls[0].removeAttribute("disabled");
      carousel.totTranslate ==
        -carousel.translateContainer - carousel.containerWidth ||
      carousel.items.length <= carousel.visibItemsNb
        ? carousel.controls[1].setAttribute("disabled", true)
        : carousel.controls[1].removeAttribute("disabled");
    }
    // update carousel dots
    if (carousel.options.nav) {
      var selectedDot = carousel.navigation.getElementsByClassName(
        carousel.options.navigationItemClass + "--selected"
      );
      if (selectedDot.length > 0)
        Util.removeClass(
          selectedDot[0],
          carousel.options.navigationItemClass + "--selected"
        );

      var newSelectedIndex = getSelectedDot(carousel);
      if (
        carousel.totTranslate ==
        -carousel.translateContainer - carousel.containerWidth
      ) {
        newSelectedIndex = carousel.navDots.length - 1;
      }
      Util.addClass(
        carousel.navDots[newSelectedIndex],
        carousel.options.navigationItemClass + "--selected"
      );
    }
  }

  function emitCarouselUpdateEvent(carousel) {
    carousel.cloneList = [];
    var clones = carousel.element.querySelectorAll(".js-clone");
    for (var i = 0; i < clones.length; i++) {
      Util.removeClass(clones[i], "js-clone");
      carousel.cloneList.push(clones[i]);
    }
    emitCarouselEvents(carousel, "carousel-updated", carousel.cloneList);
  }

  function carouselCreateNavigation(carousel) {
    if (
      carousel.element.getElementsByClassName("js-carousel__navigation")
        .length > 0
    )
      return;

    var navigation = document.createElement("ol"),
      navChildren = "";

    var navClasses =
      carousel.options.navigationClass + " js-carousel__navigation";
    if (carousel.items.length <= carousel.visibItemsNb) {
      navClasses = navClasses + " is-hidden";
    }
    navigation.setAttribute("class", navClasses);

    var dotsNr = Math.ceil(carousel.items.length / carousel.visibItemsNb),
      selectedDot = getSelectedDot(carousel),
      indexClass = carousel.options.navigationPagination ? "" : "sr-only";
    for (var i = 0; i < dotsNr; i++) {
      var className =
        i == selectedDot
          ? 'class="' +
            carousel.options.navigationItemClass +
            " " +
            carousel.options.navigationItemClass +
            '--selected js-carousel__nav-item"'
          : 'class="' +
            carousel.options.navigationItemClass +
            ' js-carousel__nav-item"';
      navChildren =
        navChildren +
        "<li " +
        className +
        '><button class="reset js-tab-focus" style="outline: none;"><span class="' +
        indexClass +
        '">' +
        (i + 1) +
        "</span></button></li>";
    }
    navigation.innerHTML = navChildren;
    carousel.element.appendChild(navigation);
  }

  function carouselInitNavigationEvents(carousel) {
    carousel.navigation = carousel.element.getElementsByClassName(
      "js-carousel__navigation"
    )[0];
    carousel.navDots = carousel.element.getElementsByClassName(
      "js-carousel__nav-item"
    );
    carousel.navIdEvent = carouselNavigationClick.bind(carousel);
    carousel.navigation.addEventListener("click", carousel.navIdEvent);
  }

  function carouselRemoveNavigation(carousel) {
    if (carousel.navigation) carousel.element.removeChild(carousel.navigation);
    if (carousel.navIdEvent)
      carousel.navigation.removeEventListener("click", carousel.navIdEvent);
  }

  function resetDotsNavigation(carousel) {
    if (!carousel.options.nav) return;
    carouselRemoveNavigation(carousel);
    carouselCreateNavigation(carousel);
    carouselInitNavigationEvents(carousel);
  }

  function carouselNavigationClick(event) {
    var dot = event.target.closest(".js-carousel__nav-item");
    if (!dot) return;
    if (this.animating) return;
    this.animating = true;
    var index = Util.getIndexInArray(this.navDots, dot);
    this.selectedDotIndex = index;
    this.selectedItem = index * this.visibItemsNb;
    animateList(this, false, "click");
  }

  function getSelectedDot(carousel) {
    return Math.ceil(carousel.selectedItem / carousel.visibItemsNb);
  }

  function initCarouselCounter(carousel) {
    if (carousel.counterTor.length > 0)
      carousel.counterTor[0].textContent = carousel.itemsNb;
    setCounterItem(carousel);
  }

  function setCounterItem(carousel) {
    if (carousel.counter.length == 0) return;
    var totalItems = carousel.selectedItem + carousel.visibItemsNb;
    if (totalItems > carousel.items.length) totalItems = carousel.items.length;
    carousel.counter[0].textContent = totalItems;
  }

  function centerItems(carousel) {
    if (!carousel.options.justifyContent) return;
    Util.toggleClass(
      carousel.list,
      "justify-center",
      carousel.items.length < carousel.visibItemsNb
    );
  }

  function alignControls(carousel) {
    if (carousel.controls.length < 1 || !carousel.options.alignControls) return;
    if (!carousel.controlsAlignEl) {
      carousel.controlsAlignEl = carousel.element.querySelector(
        carousel.options.alignControls
      );
    }
    if (!carousel.controlsAlignEl) return;
    var translate =
      carousel.element.offsetHeight - carousel.controlsAlignEl.offsetHeight;
    for (var i = 0; i < carousel.controls.length; i++) {
      carousel.controls[i].style.marginBottom = translate + "px";
    }
  }

  function emitCarouselEvents(carousel, eventName, eventDetail) {
    var event = new CustomEvent(eventName, { detail: eventDetail });
    carousel.element.dispatchEvent(event);
  }

  function resetVisibilityOverflowItems(carousel, j) {
    if (!carousel.options.overflowItems) return;
    var itemWidth = carousel.containerWidth / carousel.items.length,
      delta = (window.innerWidth - itemWidth * carousel.visibItemsNb) / 2,
      overflowItems = Math.ceil(delta / itemWidth);

    for (var i = 0; i < overflowItems; i++) {
      var indexPrev = j - 1 - i; // prev element
      if (indexPrev >= 0) carousel.items[indexPrev].removeAttribute("tabindex");
      var indexNext = j + carousel.visibItemsNb + i; // next element
      if (indexNext < carousel.items.length)
        carousel.items[indexNext].removeAttribute("tabindex");
    }
  }

  Carousel.defaults = {
    element: "",
    autoplay: false,
    autoplayInterval: 5000,
    loop: true,
    nav: false,
    navigationItemClass: "carousel__nav-item",
    navigationClass: "carousel__navigation",
    navigationPagination: false,
    drag: false,
    justifyContent: false,
    alignControls: false,
    overflowItems: false,
  };

  window.Carousel = Carousel;

  //initialize the Carousel objects
  var carousels = document.getElementsByClassName("js-carousel"),
    flexSupported = Util.cssSupports("align-items", "stretch"),
    transitionSupported = Util.cssSupports("transition"),
    cssPropertiesSupported =
      "CSS" in window && CSS.supports("color", "var(--color-var)");

  if (carousels.length > 0) {
    for (var i = 0; i < carousels.length; i++) {
      (function (i) {
        var autoplay =
            carousels[i].getAttribute("data-autoplay") &&
            carousels[i].getAttribute("data-autoplay") == "on"
              ? true
              : false,
          autoplayInterval = carousels[i].getAttribute("data-autoplay-interval")
            ? carousels[i].getAttribute("data-autoplay-interval")
            : 5000,
          drag =
            carousels[i].getAttribute("data-drag") &&
            carousels[i].getAttribute("data-drag") == "on"
              ? true
              : false,
          loop =
            carousels[i].getAttribute("data-loop") &&
            carousels[i].getAttribute("data-loop") == "off"
              ? false
              : true,
          nav =
            carousels[i].getAttribute("data-navigation") &&
            carousels[i].getAttribute("data-navigation") == "on"
              ? true
              : false,
          navigationItemClass = carousels[i].getAttribute(
            "data-navigation-item-class"
          )
            ? carousels[i].getAttribute("data-navigation-item-class")
            : "carousel__nav-item",
          navigationClass = carousels[i].getAttribute("data-navigation-class")
            ? carousels[i].getAttribute("data-navigation-class")
            : "carousel__navigation",
          navigationPagination =
            carousels[i].getAttribute("data-navigation-pagination") &&
            carousels[i].getAttribute("data-navigation-pagination") == "on"
              ? true
              : false,
          overflowItems =
            carousels[i].getAttribute("data-overflow-items") &&
            carousels[i].getAttribute("data-overflow-items") == "on"
              ? true
              : false,
          alignControls = carousels[i].getAttribute("data-align-controls")
            ? carousels[i].getAttribute("data-align-controls")
            : false,
          justifyContent =
            carousels[i].getAttribute("data-justify-content") &&
            carousels[i].getAttribute("data-justify-content") == "on"
              ? true
              : false;
        new Carousel({
          element: carousels[i],
          autoplay: autoplay,
          autoplayInterval: autoplayInterval,
          drag: drag,
          ariaLive: true,
          loop: loop,
          nav: nav,
          navigationItemClass: navigationItemClass,
          navigationPagination: navigationPagination,
          navigationClass: navigationClass,
          overflowItems: overflowItems,
          justifyContent: justifyContent,
          alignControls: alignControls,
        });
      })(i);
    }
  }
})();

// File#: _2_dropdown
// Usage: codyhouse.co/license
(function () {
  var Dropdown = function (element) {
    this.element = element;
    this.trigger = this.element.getElementsByClassName(
      "js-dropdown__trigger"
    )[0];
    this.dropdown = this.element.getElementsByClassName("js-dropdown__menu")[0];
    this.triggerFocus = false;
    this.dropdownFocus = false;
    this.hideInterval = false;
    // sublevels
    this.dropdownSubElements = this.element.getElementsByClassName(
      "js-dropdown__sub-wrapper"
    );
    this.prevFocus = false; // store element that was in focus before focus changed
    this.addDropdownEvents();
  };

  Dropdown.prototype.addDropdownEvents = function () {
    //place dropdown
    var self = this;
    this.placeElement();
    this.element.addEventListener("placeDropdown", function (event) {
      self.placeElement();
    });
    // init dropdown
    this.initElementEvents(this.trigger, this.triggerFocus); // this is used to trigger the primary dropdown
    this.initElementEvents(this.dropdown, this.dropdownFocus); // this is used to trigger the primary dropdown
    // init sublevels
    this.initSublevels(); // if there are additional sublevels -> bind hover/focus events
  };

  Dropdown.prototype.placeElement = function () {
    var triggerPosition = this.trigger.getBoundingClientRect(),
      isRight =
        window.innerWidth <
        triggerPosition.left +
          parseInt(getComputedStyle(this.dropdown).getPropertyValue("width"));

    var xPosition = isRight
      ? "right: 0px; left: auto;"
      : "left: 0px; right: auto;";
    this.dropdown.setAttribute("style", xPosition);
  };

  Dropdown.prototype.initElementEvents = function (element, bool) {
    var self = this;
    element.addEventListener("mouseenter", function () {
      bool = true;
      self.showDropdown();
    });
    element.addEventListener("focus", function () {
      self.showDropdown();
    });
    element.addEventListener("mouseleave", function () {
      bool = false;
      self.hideDropdown();
    });
    element.addEventListener("focusout", function () {
      self.hideDropdown();
    });
  };

  Dropdown.prototype.showDropdown = function () {
    if (this.hideInterval) clearInterval(this.hideInterval);
    this.showLevel(this.dropdown, true);
  };

  Dropdown.prototype.hideDropdown = function () {
    var self = this;
    if (this.hideInterval) clearInterval(this.hideInterval);
    this.hideInterval = setTimeout(function () {
      var dropDownFocus = document.activeElement.closest(".js-dropdown"),
        inFocus = dropDownFocus && dropDownFocus == self.element;
      // if not in focus and not hover -> hide
      if (!self.triggerFocus && !self.dropdownFocus && !inFocus) {
        self.hideLevel(self.dropdown);
        // make sure to hide sub/dropdown
        self.hideSubLevels();
        self.prevFocus = false;
      }
    }, 300);
  };

  Dropdown.prototype.initSublevels = function () {
    var self = this;
    var dropdownMenu = this.element.getElementsByClassName("js-dropdown__menu");
    for (var i = 0; i < dropdownMenu.length; i++) {
      var listItems = dropdownMenu[i].children;
      // bind hover
      new menuAim({
        menu: dropdownMenu[i],
        activate: function (row) {
          var subList = row.getElementsByClassName("js-dropdown__menu")[0];
          if (!subList) return;
          Util.addClass(row.querySelector("a"), "dropdown__item--hover");
          self.showLevel(subList);
        },
        deactivate: function (row) {
          var subList = row.getElementsByClassName("dropdown__menu")[0];
          if (!subList) return;
          Util.removeClass(row.querySelector("a"), "dropdown__item--hover");
          self.hideLevel(subList);
        },
        submenuSelector: ".js-dropdown__sub-wrapper",
      });
    }
    // store focus element before change in focus
    this.element.addEventListener("keydown", function (event) {
      if (
        (event.keyCode && event.keyCode == 9) ||
        (event.key && event.key == "Tab")
      ) {
        self.prevFocus = document.activeElement;
      }
    });
    // make sure that sublevel are visible when their items are in focus
    this.element.addEventListener("keyup", function (event) {
      if (
        (event.keyCode && event.keyCode == 9) ||
        (event.key && event.key == "Tab")
      ) {
        // focus has been moved -> make sure the proper classes are added to subnavigation
        var focusElement = document.activeElement,
          focusElementParent = focusElement.closest(".js-dropdown__menu"),
          focusElementSibling = focusElement.nextElementSibling;

        // if item in focus is inside submenu -> make sure it is visible
        if (
          focusElementParent &&
          !Util.hasClass(focusElementParent, "dropdown__menu--is-visible")
        ) {
          self.showLevel(focusElementParent);
        }
        // if item in focus triggers a submenu -> make sure it is visible
        if (
          focusElementSibling &&
          !Util.hasClass(focusElementSibling, "dropdown__menu--is-visible")
        ) {
          self.showLevel(focusElementSibling);
        }

        // check previous element in focus -> hide sublevel if required
        if (!self.prevFocus) return;
        var prevFocusElementParent =
            self.prevFocus.closest(".js-dropdown__menu"),
          prevFocusElementSibling = self.prevFocus.nextElementSibling;

        if (!prevFocusElementParent) return;

        // element in focus and element prev in focus are siblings
        if (
          focusElementParent &&
          focusElementParent == prevFocusElementParent
        ) {
          if (prevFocusElementSibling) self.hideLevel(prevFocusElementSibling);
          return;
        }

        // element in focus is inside submenu triggered by element prev in focus
        if (
          prevFocusElementSibling &&
          focusElementParent &&
          focusElementParent == prevFocusElementSibling
        )
          return;

        // shift tab -> element in focus triggers the submenu of the element prev in focus
        if (
          focusElementSibling &&
          prevFocusElementParent &&
          focusElementSibling == prevFocusElementParent
        )
          return;

        var focusElementParentParent =
          focusElementParent.parentNode.closest(".js-dropdown__menu");

        // shift tab -> element in focus is inside the dropdown triggered by a siblings of the element prev in focus
        if (
          focusElementParentParent &&
          focusElementParentParent == prevFocusElementParent
        ) {
          if (prevFocusElementSibling) self.hideLevel(prevFocusElementSibling);
          return;
        }

        if (
          prevFocusElementParent &&
          Util.hasClass(prevFocusElementParent, "dropdown__menu--is-visible")
        ) {
          self.hideLevel(prevFocusElementParent);
        }
      }
    });
  };

  Dropdown.prototype.hideSubLevels = function () {
    var visibleSubLevels = this.dropdown.getElementsByClassName(
      "dropdown__menu--is-visible"
    );
    if (visibleSubLevels.length == 0) return;
    while (visibleSubLevels[0]) {
      this.hideLevel(visibleSubLevels[0]);
    }
    var hoveredItems = this.dropdown.getElementsByClassName(
      "dropdown__item--hover"
    );
    while (hoveredItems[0]) {
      Util.removeClass(hoveredItems[0], "dropdown__item--hover");
    }
  };

  Dropdown.prototype.showLevel = function (level, bool) {
    if (bool == undefined) {
      //check if the sublevel needs to be open to the left
      Util.removeClass(level, "dropdown__menu--left");
      var boundingRect = level.getBoundingClientRect();
      if (
        window.innerWidth - boundingRect.right < 5 &&
        boundingRect.left + window.scrollX > 2 * boundingRect.width
      )
        Util.addClass(level, "dropdown__menu--left");
    }
    Util.addClass(level, "dropdown__menu--is-visible");
    Util.removeClass(level, "dropdown__menu--is-hidden");
  };

  Dropdown.prototype.hideLevel = function (level) {
    if (!Util.hasClass(level, "dropdown__menu--is-visible")) return;
    Util.removeClass(level, "dropdown__menu--is-visible");
    Util.addClass(level, "dropdown__menu--is-hidden");

    level.addEventListener("animationend", function cb() {
      level.removeEventListener("animationend", cb);
      Util.removeClass(level, "dropdown__menu--is-hidden dropdown__menu--left");
    });
  };

  window.Dropdown = Dropdown;

  var dropdown = document.getElementsByClassName("js-dropdown");
  if (dropdown.length > 0) {
    // init Dropdown objects
    for (var i = 0; i < dropdown.length; i++) {
      (function (i) {
        new Dropdown(dropdown[i]);
      })(i);
    }
  }
})();
// File#: _3_mega-site-navigation
// Usage: codyhouse.co/license
(function () {
  var MegaNav = function (element) {
    this.element = element;
    this.search = this.element.getElementsByClassName("js-mega-nav__search");
    this.searchActiveController = false;
    this.menu = this.element.getElementsByClassName("js-mega-nav__nav");
    this.menuItems = this.menu[0].getElementsByClassName("js-mega-nav__item");
    this.menuActiveController = false;
    this.itemExpClass = "mega-nav__item--expanded";
    this.classIconBtn = "mega-nav__icon-btn--state-b";
    this.classSearchVisible = "mega-nav__search--is-visible";
    this.classNavVisible = "mega-nav__nav--is-visible";
    this.classMobileLayout = "mega-nav--mobile";
    this.classDesktopLayout = "mega-nav--desktop";
    this.layout = "mobile";
    // store dropdown elements (if present)
    this.dropdown = this.element.getElementsByClassName("js-dropdown");
    // expanded class - added to header when subnav is open
    this.expandedClass = "mega-nav--expanded";
    initMegaNav(this);
  };

  function initMegaNav(megaNav) {
    setMegaNavLayout(megaNav); // switch between mobile/desktop layout
    initSearch(megaNav); // controll search navigation
    initMenu(megaNav); // control main menu nav - mobile only
    initSubNav(megaNav); // toggle sub navigation visibility

    megaNav.element.addEventListener("update-menu-layout", function (event) {
      setMegaNavLayout(megaNav); // window resize - update layout
    });
  }

  function setMegaNavLayout(megaNav) {
    var layout = getComputedStyle(megaNav.element, ":before")
      .getPropertyValue("content")
      .replace(/\'|"/g, "");
    if (layout == megaNav.layout) return;
    megaNav.layout = layout;
    Util.toggleClass(
      megaNav.element,
      megaNav.classDesktopLayout,
      megaNav.layout == "desktop"
    );
    Util.toggleClass(
      megaNav.element,
      megaNav.classMobileLayout,
      megaNav.layout != "desktop"
    );
    if (megaNav.layout == "desktop") {
      closeSubNav(megaNav, false);
      // if the mega navigation has dropdown elements -> make sure they are in the right position (viewport awareness)
      triggerDropdownPosition(megaNav);
    }
    closeSearch(megaNav, false);
    resetMegaNavOffset(megaNav); // reset header offset top value
    resetNavAppearance(megaNav); // reset nav expanded appearance
  }

  function resetMegaNavOffset(megaNav) {
    document.documentElement.style.setProperty(
      "--mega-nav-offset-y",
      megaNav.element.getBoundingClientRect().top + "px"
    );
  }

  function closeNavigation(megaNav) {
    // triggered by Esc key press
    // close search
    closeSearch(megaNav);
    // close nav
    if (Util.hasClass(megaNav.menu[0], megaNav.classNavVisible)) {
      toggleMenu(
        megaNav,
        megaNav.menu[0],
        "menuActiveController",
        megaNav.classNavVisible,
        megaNav.menuActiveController,
        true
      );
    }
    //close subnav
    closeSubNav(megaNav, false);
    resetNavAppearance(megaNav); // reset nav expanded appearance
  }

  function closeFocusNavigation(megaNav) {
    // triggered by Tab key pressed
    // close search when focus is lost
    if (
      Util.hasClass(megaNav.search[0], megaNav.classSearchVisible) &&
      !document.activeElement.closest(".js-mega-nav__search")
    ) {
      toggleMenu(
        megaNav,
        megaNav.search[0],
        "searchActiveController",
        megaNav.classSearchVisible,
        megaNav.searchActiveController,
        true
      );
    }
    // close nav when focus is lost
    if (
      Util.hasClass(megaNav.menu[0], megaNav.classNavVisible) &&
      !document.activeElement.closest(".js-mega-nav__nav")
    ) {
      toggleMenu(
        megaNav,
        megaNav.menu[0],
        "menuActiveController",
        megaNav.classNavVisible,
        megaNav.menuActiveController,
        true
      );
    }
    // close subnav when focus is lost
    for (var i = 0; i < megaNav.menuItems.length; i++) {
      if (!Util.hasClass(megaNav.menuItems[i], megaNav.itemExpClass)) continue;
      var parentItem = document.activeElement.closest(".js-mega-nav__item");
      if (parentItem && parentItem == megaNav.menuItems[i]) continue;
      closeSingleSubnav(megaNav, i);
    }
    resetNavAppearance(megaNav); // reset nav expanded appearance
  }

  function closeSearch(megaNav, bool) {
    if (megaNav.search.length < 1) return;
    if (Util.hasClass(megaNav.search[0], megaNav.classSearchVisible)) {
      toggleMenu(
        megaNav,
        megaNav.search[0],
        "searchActiveController",
        megaNav.classSearchVisible,
        megaNav.searchActiveController,
        bool
      );
    }
  }

  function initSearch(megaNav) {
    if (megaNav.search.length == 0) return;
    // toggle search
    megaNav.searchToggles = document.querySelectorAll(
      '[aria-controls="' + megaNav.search[0].getAttribute("id") + '"]'
    );
    for (var i = 0; i < megaNav.searchToggles.length; i++) {
      (function (i) {
        megaNav.searchToggles[i].addEventListener("click", function (event) {
          // toggle search
          toggleMenu(
            megaNav,
            megaNav.search[0],
            "searchActiveController",
            megaNav.classSearchVisible,
            megaNav.searchToggles[i],
            true
          );
          // close nav if it was open
          if (Util.hasClass(megaNav.menu[0], megaNav.classNavVisible)) {
            toggleMenu(
              megaNav,
              megaNav.menu[0],
              "menuActiveController",
              megaNav.classNavVisible,
              megaNav.menuActiveController,
              false
            );
          }
          // close subnavigation if open
          closeSubNav(megaNav, false);
          resetNavAppearance(megaNav); // reset nav expanded appearance
        });
      })(i);
    }
  }

  function initMenu(megaNav) {
    if (megaNav.menu.length == 0) return;
    // toggle nav
    megaNav.menuToggles = document.querySelectorAll(
      '[aria-controls="' + megaNav.menu[0].getAttribute("id") + '"]'
    );
    for (var i = 0; i < megaNav.menuToggles.length; i++) {
      (function (i) {
        megaNav.menuToggles[i].addEventListener("click", function (event) {
          // toggle nav
          toggleMenu(
            megaNav,
            megaNav.menu[0],
            "menuActiveController",
            megaNav.classNavVisible,
            megaNav.menuToggles[i],
            true
          );
          // close search if it was open
          if (Util.hasClass(megaNav.search[0], megaNav.classSearchVisible)) {
            toggleMenu(
              megaNav,
              megaNav.search[0],
              "searchActiveController",
              megaNav.classSearchVisible,
              megaNav.searchActiveController,
              false
            );
          }
          resetNavAppearance(megaNav); // reset nav expanded appearance
        });
      })(i);
    }
  }

  function toggleMenu(
    megaNav,
    element,
    controller,
    visibleClass,
    toggle,
    moveFocus
  ) {
    var menuIsVisible = Util.hasClass(element, visibleClass);
    Util.toggleClass(element, visibleClass, !menuIsVisible);
    Util.toggleClass(toggle, megaNav.classIconBtn, !menuIsVisible);
    menuIsVisible
      ? toggle.removeAttribute("aria-expanded")
      : toggle.setAttribute("aria-expanded", "true");
    if (menuIsVisible) {
      if (toggle && moveFocus) toggle.focus();
      megaNav[controller] = false;
    } else {
      if (toggle) megaNav[controller] = toggle;
      getFirstFocusable(element).focus(); // move focus to first focusable element
    }
  }

  function getFirstFocusable(element) {
    var focusableEle = element.querySelectorAll(
        '[href], input:not([disabled]), select:not([disabled]), textarea:not([disabled]), button:not([disabled]), iframe, object, embed, [tabindex]:not([tabindex="-1"]), [contenteditable], audio[controls], video[controls], summary'
      ),
      firstFocusable = false;
    for (var i = 0; i < focusableEle.length; i++) {
      if (
        focusableEle[i].offsetWidth ||
        focusableEle[i].offsetHeight ||
        focusableEle[i].getClientRects().length
      ) {
        firstFocusable = focusableEle[i];
        break;
      }
    }
    return firstFocusable;
  }

  function initSubNav(megaNav) {
    // toggle subnavigation visibility
    megaNav.element.addEventListener("click", function (event) {
      var triggerBtn = event.target.closest(".js-mega-nav__control");
      if (!triggerBtn) return;
      var mainItem = triggerBtn.closest(".js-mega-nav__item");
      if (!mainItem) return;
      var itemExpanded = Util.hasClass(mainItem, megaNav.itemExpClass);
      Util.toggleClass(mainItem, megaNav.itemExpClass, !itemExpanded);
      itemExpanded
        ? triggerBtn.removeAttribute("aria-expanded")
        : triggerBtn.setAttribute("aria-expanded", "true");
      if (megaNav.layout == "desktop" && !itemExpanded)
        closeSubNav(megaNav, mainItem);
      // close search if open
      closeSearch(megaNav, false);
      resetNavAppearance(megaNav); // reset nav expanded appearance
    });
  }

  function closeSubNav(megaNav, selectedItem) {
    // close subnav when a new sub nav element is open
    if (megaNav.menuItems.length == 0) return;
    for (var i = 0; i < megaNav.menuItems.length; i++) {
      if (megaNav.menuItems[i] != selectedItem) closeSingleSubnav(megaNav, i);
    }
  }

  function closeSingleSubnav(megaNav, index) {
    Util.removeClass(megaNav.menuItems[index], megaNav.itemExpClass);
    var triggerBtn = megaNav.menuItems[index].getElementsByClassName(
      "js-mega-nav__control"
    );
    if (triggerBtn.length > 0) triggerBtn[0].removeAttribute("aria-expanded");
  }

  function triggerDropdownPosition(megaNav) {
    // emit custom event to properly place dropdown elements - viewport awarness
    if (megaNav.dropdown.length == 0) return;
    for (var i = 0; i < megaNav.dropdown.length; i++) {
      megaNav.dropdown[i].dispatchEvent(new CustomEvent("placeDropdown"));
    }
  }

  function resetNavAppearance(megaNav) {
    (megaNav.element.getElementsByClassName(megaNav.itemExpClass).length > 0 &&
      megaNav.layout == "desktop") ||
    megaNav.element.getElementsByClassName(megaNav.classSearchVisible).length >
      0 ||
    (megaNav.element.getElementsByClassName(megaNav.classNavVisible).length >
      0 &&
      megaNav.layout == "mobile")
      ? Util.addClass(megaNav.element, megaNav.expandedClass)
      : Util.removeClass(megaNav.element, megaNav.expandedClass);
  }

  //initialize the MegaNav objects
  var megaNav = document.getElementsByClassName("js-mega-nav");
  if (megaNav.length > 0) {
    var megaNavArray = [];
    for (var i = 0; i < megaNav.length; i++) {
      (function (i) {
        megaNavArray.push(new MegaNav(megaNav[i]));
      })(i);
    }

    // key events
    window.addEventListener("keyup", function (event) {
      if (
        (event.keyCode && event.keyCode == 27) ||
        (event.key && event.key.toLowerCase() == "escape")
      ) {
        // listen for esc key events
        for (var i = 0; i < megaNavArray.length; i++) {
          (function (i) {
            closeNavigation(megaNavArray[i]);
          })(i);
        }
      }
      // listen for tab key
      if (
        (event.keyCode && event.keyCode == 9) ||
        (event.key && event.key.toLowerCase() == "tab")
      ) {
        // close search or nav if it looses focus
        for (var i = 0; i < megaNavArray.length; i++) {
          (function (i) {
            closeFocusNavigation(megaNavArray[i]);
          })(i);
        }
      }
    });

    window.addEventListener("click", function (event) {
      if (!event.target.closest(".js-mega-nav"))
        closeNavigation(megaNavArray[0]);
    });

    // resize - update menu layout
    var resizingId = false,
      customEvent = new CustomEvent("update-menu-layout");
    window.addEventListener("resize", function (event) {
      clearTimeout(resizingId);
      resizingId = setTimeout(doneResizing, 200);
    });

    function doneResizing() {
      for (var i = 0; i < megaNavArray.length; i++) {
        (function (i) {
          megaNavArray[i].element.dispatchEvent(customEvent);
        })(i);
      }
    }
  }
})();

/*! jQuery v3.4.1 | (c) JS Foundation and other contributors | jquery.org/license */
!(function (e, t) {
  "use strict";
  "object" == typeof module && "object" == typeof module.exports
    ? (module.exports = e.document
        ? t(e, !0)
        : function (e) {
            if (!e.document)
              throw new Error("jQuery requires a window with a document");
            return t(e);
          })
    : t(e);
})("undefined" != typeof window ? window : this, function (C, e) {
  "use strict";
  var t = [],
    E = C.document,
    r = Object.getPrototypeOf,
    s = t.slice,
    g = t.concat,
    u = t.push,
    i = t.indexOf,
    n = {},
    o = n.toString,
    v = n.hasOwnProperty,
    a = v.toString,
    l = a.call(Object),
    y = {},
    m = function (e) {
      return "function" == typeof e && "number" != typeof e.nodeType;
    },
    x = function (e) {
      return null != e && e === e.window;
    },
    c = { type: !0, src: !0, nonce: !0, noModule: !0 };
  function b(e, t, n) {
    var r,
      i,
      o = (n = n || E).createElement("script");
    if (((o.text = e), t))
      for (r in c)
        (i = t[r] || (t.getAttribute && t.getAttribute(r))) &&
          o.setAttribute(r, i);
    n.head.appendChild(o).parentNode.removeChild(o);
  }
  function w(e) {
    return null == e
      ? e + ""
      : "object" == typeof e || "function" == typeof e
      ? n[o.call(e)] || "object"
      : typeof e;
  }
  var f = "3.4.1",
    k = function (e, t) {
      return new k.fn.init(e, t);
    },
    p = /^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g;
  function d(e) {
    var t = !!e && "length" in e && e.length,
      n = w(e);
    return (
      !m(e) &&
      !x(e) &&
      ("array" === n ||
        0 === t ||
        ("number" == typeof t && 0 < t && t - 1 in e))
    );
  }
  (k.fn = k.prototype =
    {
      jquery: f,
      constructor: k,
      length: 0,
      toArray: function () {
        return s.call(this);
      },
      get: function (e) {
        return null == e
          ? s.call(this)
          : e < 0
          ? this[e + this.length]
          : this[e];
      },
      pushStack: function (e) {
        var t = k.merge(this.constructor(), e);
        return (t.prevObject = this), t;
      },
      each: function (e) {
        return k.each(this, e);
      },
      map: function (n) {
        return this.pushStack(
          k.map(this, function (e, t) {
            return n.call(e, t, e);
          })
        );
      },
      slice: function () {
        return this.pushStack(s.apply(this, arguments));
      },
      first: function () {
        return this.eq(0);
      },
      last: function () {
        return this.eq(-1);
      },
      eq: function (e) {
        var t = this.length,
          n = +e + (e < 0 ? t : 0);
        return this.pushStack(0 <= n && n < t ? [this[n]] : []);
      },
      end: function () {
        return this.prevObject || this.constructor();
      },
      push: u,
      sort: t.sort,
      splice: t.splice,
    }),
    (k.extend = k.fn.extend =
      function () {
        var e,
          t,
          n,
          r,
          i,
          o,
          a = arguments[0] || {},
          s = 1,
          u = arguments.length,
          l = !1;
        for (
          "boolean" == typeof a && ((l = a), (a = arguments[s] || {}), s++),
            "object" == typeof a || m(a) || (a = {}),
            s === u && ((a = this), s--);
          s < u;
          s++
        )
          if (null != (e = arguments[s]))
            for (t in e)
              (r = e[t]),
                "__proto__" !== t &&
                  a !== r &&
                  (l && r && (k.isPlainObject(r) || (i = Array.isArray(r)))
                    ? ((n = a[t]),
                      (o =
                        i && !Array.isArray(n)
                          ? []
                          : i || k.isPlainObject(n)
                          ? n
                          : {}),
                      (i = !1),
                      (a[t] = k.extend(l, o, r)))
                    : void 0 !== r && (a[t] = r));
        return a;
      }),
    k.extend({
      expando: "jQuery" + (f + Math.random()).replace(/\D/g, ""),
      isReady: !0,
      error: function (e) {
        throw new Error(e);
      },
      noop: function () {},
      isPlainObject: function (e) {
        var t, n;
        return (
          !(!e || "[object Object]" !== o.call(e)) &&
          (!(t = r(e)) ||
            ("function" ==
              typeof (n = v.call(t, "constructor") && t.constructor) &&
              a.call(n) === l))
        );
      },
      isEmptyObject: function (e) {
        var t;
        for (t in e) return !1;
        return !0;
      },
      globalEval: function (e, t) {
        b(e, { nonce: t && t.nonce });
      },
      each: function (e, t) {
        var n,
          r = 0;
        if (d(e)) {
          for (n = e.length; r < n; r++)
            if (!1 === t.call(e[r], r, e[r])) break;
        } else for (r in e) if (!1 === t.call(e[r], r, e[r])) break;
        return e;
      },
      trim: function (e) {
        return null == e ? "" : (e + "").replace(p, "");
      },
      makeArray: function (e, t) {
        var n = t || [];
        return (
          null != e &&
            (d(Object(e))
              ? k.merge(n, "string" == typeof e ? [e] : e)
              : u.call(n, e)),
          n
        );
      },
      inArray: function (e, t, n) {
        return null == t ? -1 : i.call(t, e, n);
      },
      merge: function (e, t) {
        for (var n = +t.length, r = 0, i = e.length; r < n; r++) e[i++] = t[r];
        return (e.length = i), e;
      },
      grep: function (e, t, n) {
        for (var r = [], i = 0, o = e.length, a = !n; i < o; i++)
          !t(e[i], i) !== a && r.push(e[i]);
        return r;
      },
      map: function (e, t, n) {
        var r,
          i,
          o = 0,
          a = [];
        if (d(e))
          for (r = e.length; o < r; o++)
            null != (i = t(e[o], o, n)) && a.push(i);
        else for (o in e) null != (i = t(e[o], o, n)) && a.push(i);
        return g.apply([], a);
      },
      guid: 1,
      support: y,
    }),
    "function" == typeof Symbol && (k.fn[Symbol.iterator] = t[Symbol.iterator]),
    k.each(
      "Boolean Number String Function Array Date RegExp Object Error Symbol".split(
        " "
      ),
      function (e, t) {
        n["[object " + t + "]"] = t.toLowerCase();
      }
    );
  var h = (function (n) {
    var e,
      d,
      b,
      o,
      i,
      h,
      f,
      g,
      w,
      u,
      l,
      T,
      C,
      a,
      E,
      v,
      s,
      c,
      y,
      k = "sizzle" + 1 * new Date(),
      m = n.document,
      S = 0,
      r = 0,
      p = ue(),
      x = ue(),
      N = ue(),
      A = ue(),
      D = function (e, t) {
        return e === t && (l = !0), 0;
      },
      j = {}.hasOwnProperty,
      t = [],
      q = t.pop,
      L = t.push,
      H = t.push,
      O = t.slice,
      P = function (e, t) {
        for (var n = 0, r = e.length; n < r; n++) if (e[n] === t) return n;
        return -1;
      },
      R =
        "checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",
      M = "[\\x20\\t\\r\\n\\f]",
      I = "(?:\\\\.|[\\w-]|[^\0-\\xa0])+",
      W =
        "\\[" +
        M +
        "*(" +
        I +
        ")(?:" +
        M +
        "*([*^$|!~]?=)" +
        M +
        "*(?:'((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\"|(" +
        I +
        "))|)" +
        M +
        "*\\]",
      $ =
        ":(" +
        I +
        ")(?:\\((('((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\")|((?:\\\\.|[^\\\\()[\\]]|" +
        W +
        ")*)|.*)\\)|)",
      F = new RegExp(M + "+", "g"),
      B = new RegExp("^" + M + "+|((?:^|[^\\\\])(?:\\\\.)*)" + M + "+$", "g"),
      _ = new RegExp("^" + M + "*," + M + "*"),
      z = new RegExp("^" + M + "*([>+~]|" + M + ")" + M + "*"),
      U = new RegExp(M + "|>"),
      X = new RegExp($),
      V = new RegExp("^" + I + "$"),
      G = {
        ID: new RegExp("^#(" + I + ")"),
        CLASS: new RegExp("^\\.(" + I + ")"),
        TAG: new RegExp("^(" + I + "|[*])"),
        ATTR: new RegExp("^" + W),
        PSEUDO: new RegExp("^" + $),
        CHILD: new RegExp(
          "^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\(" +
            M +
            "*(even|odd|(([+-]|)(\\d*)n|)" +
            M +
            "*(?:([+-]|)" +
            M +
            "*(\\d+)|))" +
            M +
            "*\\)|)",
          "i"
        ),
        bool: new RegExp("^(?:" + R + ")$", "i"),
        needsContext: new RegExp(
          "^" +
            M +
            "*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\(" +
            M +
            "*((?:-\\d)?\\d*)" +
            M +
            "*\\)|)(?=[^-]|$)",
          "i"
        ),
      },
      Y = /HTML$/i,
      Q = /^(?:input|select|textarea|button)$/i,
      J = /^h\d$/i,
      K = /^[^{]+\{\s*\[native \w/,
      Z = /^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,
      ee = /[+~]/,
      te = new RegExp("\\\\([\\da-f]{1,6}" + M + "?|(" + M + ")|.)", "ig"),
      ne = function (e, t, n) {
        var r = "0x" + t - 65536;
        return r != r || n
          ? t
          : r < 0
          ? String.fromCharCode(r + 65536)
          : String.fromCharCode((r >> 10) | 55296, (1023 & r) | 56320);
      },
      re = /([\0-\x1f\x7f]|^-?\d)|^-$|[^\0-\x1f\x7f-\uFFFF\w-]/g,
      ie = function (e, t) {
        return t
          ? "\0" === e
            ? "\ufffd"
            : e.slice(0, -1) +
              "\\" +
              e.charCodeAt(e.length - 1).toString(16) +
              " "
          : "\\" + e;
      },
      oe = function () {
        T();
      },
      ae = be(
        function (e) {
          return !0 === e.disabled && "fieldset" === e.nodeName.toLowerCase();
        },
        { dir: "parentNode", next: "legend" }
      );
    try {
      H.apply((t = O.call(m.childNodes)), m.childNodes),
        t[m.childNodes.length].nodeType;
    } catch (e) {
      H = {
        apply: t.length
          ? function (e, t) {
              L.apply(e, O.call(t));
            }
          : function (e, t) {
              var n = e.length,
                r = 0;
              while ((e[n++] = t[r++]));
              e.length = n - 1;
            },
      };
    }
    function se(t, e, n, r) {
      var i,
        o,
        a,
        s,
        u,
        l,
        c,
        f = e && e.ownerDocument,
        p = e ? e.nodeType : 9;
      if (
        ((n = n || []),
        "string" != typeof t || !t || (1 !== p && 9 !== p && 11 !== p))
      )
        return n;
      if (
        !r &&
        ((e ? e.ownerDocument || e : m) !== C && T(e), (e = e || C), E)
      ) {
        if (11 !== p && (u = Z.exec(t)))
          if ((i = u[1])) {
            if (9 === p) {
              if (!(a = e.getElementById(i))) return n;
              if (a.id === i) return n.push(a), n;
            } else if (f && (a = f.getElementById(i)) && y(e, a) && a.id === i)
              return n.push(a), n;
          } else {
            if (u[2]) return H.apply(n, e.getElementsByTagName(t)), n;
            if (
              (i = u[3]) &&
              d.getElementsByClassName &&
              e.getElementsByClassName
            )
              return H.apply(n, e.getElementsByClassName(i)), n;
          }
        if (
          d.qsa &&
          !A[t + " "] &&
          (!v || !v.test(t)) &&
          (1 !== p || "object" !== e.nodeName.toLowerCase())
        ) {
          if (((c = t), (f = e), 1 === p && U.test(t))) {
            (s = e.getAttribute("id"))
              ? (s = s.replace(re, ie))
              : e.setAttribute("id", (s = k)),
              (o = (l = h(t)).length);
            while (o--) l[o] = "#" + s + " " + xe(l[o]);
            (c = l.join(",")), (f = (ee.test(t) && ye(e.parentNode)) || e);
          }
          try {
            return H.apply(n, f.querySelectorAll(c)), n;
          } catch (e) {
            A(t, !0);
          } finally {
            s === k && e.removeAttribute("id");
          }
        }
      }
      return g(t.replace(B, "$1"), e, n, r);
    }
    function ue() {
      var r = [];
      return function e(t, n) {
        return (
          r.push(t + " ") > b.cacheLength && delete e[r.shift()],
          (e[t + " "] = n)
        );
      };
    }
    function le(e) {
      return (e[k] = !0), e;
    }
    function ce(e) {
      var t = C.createElement("fieldset");
      try {
        return !!e(t);
      } catch (e) {
        return !1;
      } finally {
        t.parentNode && t.parentNode.removeChild(t), (t = null);
      }
    }
    function fe(e, t) {
      var n = e.split("|"),
        r = n.length;
      while (r--) b.attrHandle[n[r]] = t;
    }
    function pe(e, t) {
      var n = t && e,
        r =
          n &&
          1 === e.nodeType &&
          1 === t.nodeType &&
          e.sourceIndex - t.sourceIndex;
      if (r) return r;
      if (n) while ((n = n.nextSibling)) if (n === t) return -1;
      return e ? 1 : -1;
    }
    function de(t) {
      return function (e) {
        return "input" === e.nodeName.toLowerCase() && e.type === t;
      };
    }
    function he(n) {
      return function (e) {
        var t = e.nodeName.toLowerCase();
        return ("input" === t || "button" === t) && e.type === n;
      };
    }
    function ge(t) {
      return function (e) {
        return "form" in e
          ? e.parentNode && !1 === e.disabled
            ? "label" in e
              ? "label" in e.parentNode
                ? e.parentNode.disabled === t
                : e.disabled === t
              : e.isDisabled === t || (e.isDisabled !== !t && ae(e) === t)
            : e.disabled === t
          : "label" in e && e.disabled === t;
      };
    }
    function ve(a) {
      return le(function (o) {
        return (
          (o = +o),
          le(function (e, t) {
            var n,
              r = a([], e.length, o),
              i = r.length;
            while (i--) e[(n = r[i])] && (e[n] = !(t[n] = e[n]));
          })
        );
      });
    }
    function ye(e) {
      return e && "undefined" != typeof e.getElementsByTagName && e;
    }
    for (e in ((d = se.support = {}),
    (i = se.isXML =
      function (e) {
        var t = e.namespaceURI,
          n = (e.ownerDocument || e).documentElement;
        return !Y.test(t || (n && n.nodeName) || "HTML");
      }),
    (T = se.setDocument =
      function (e) {
        var t,
          n,
          r = e ? e.ownerDocument || e : m;
        return (
          r !== C &&
            9 === r.nodeType &&
            r.documentElement &&
            ((a = (C = r).documentElement),
            (E = !i(C)),
            m !== C &&
              (n = C.defaultView) &&
              n.top !== n &&
              (n.addEventListener
                ? n.addEventListener("unload", oe, !1)
                : n.attachEvent && n.attachEvent("onunload", oe)),
            (d.attributes = ce(function (e) {
              return (e.className = "i"), !e.getAttribute("className");
            })),
            (d.getElementsByTagName = ce(function (e) {
              return (
                e.appendChild(C.createComment("")),
                !e.getElementsByTagName("*").length
              );
            })),
            (d.getElementsByClassName = K.test(C.getElementsByClassName)),
            (d.getById = ce(function (e) {
              return (
                (a.appendChild(e).id = k),
                !C.getElementsByName || !C.getElementsByName(k).length
              );
            })),
            d.getById
              ? ((b.filter.ID = function (e) {
                  var t = e.replace(te, ne);
                  return function (e) {
                    return e.getAttribute("id") === t;
                  };
                }),
                (b.find.ID = function (e, t) {
                  if ("undefined" != typeof t.getElementById && E) {
                    var n = t.getElementById(e);
                    return n ? [n] : [];
                  }
                }))
              : ((b.filter.ID = function (e) {
                  var n = e.replace(te, ne);
                  return function (e) {
                    var t =
                      "undefined" != typeof e.getAttributeNode &&
                      e.getAttributeNode("id");
                    return t && t.value === n;
                  };
                }),
                (b.find.ID = function (e, t) {
                  if ("undefined" != typeof t.getElementById && E) {
                    var n,
                      r,
                      i,
                      o = t.getElementById(e);
                    if (o) {
                      if ((n = o.getAttributeNode("id")) && n.value === e)
                        return [o];
                      (i = t.getElementsByName(e)), (r = 0);
                      while ((o = i[r++]))
                        if ((n = o.getAttributeNode("id")) && n.value === e)
                          return [o];
                    }
                    return [];
                  }
                })),
            (b.find.TAG = d.getElementsByTagName
              ? function (e, t) {
                  return "undefined" != typeof t.getElementsByTagName
                    ? t.getElementsByTagName(e)
                    : d.qsa
                    ? t.querySelectorAll(e)
                    : void 0;
                }
              : function (e, t) {
                  var n,
                    r = [],
                    i = 0,
                    o = t.getElementsByTagName(e);
                  if ("*" === e) {
                    while ((n = o[i++])) 1 === n.nodeType && r.push(n);
                    return r;
                  }
                  return o;
                }),
            (b.find.CLASS =
              d.getElementsByClassName &&
              function (e, t) {
                if ("undefined" != typeof t.getElementsByClassName && E)
                  return t.getElementsByClassName(e);
              }),
            (s = []),
            (v = []),
            (d.qsa = K.test(C.querySelectorAll)) &&
              (ce(function (e) {
                (a.appendChild(e).innerHTML =
                  "<a id='" +
                  k +
                  "'></a><select id='" +
                  k +
                  "-\r\\' msallowcapture=''><option selected=''></option></select>"),
                  e.querySelectorAll("[msallowcapture^='']").length &&
                    v.push("[*^$]=" + M + "*(?:''|\"\")"),
                  e.querySelectorAll("[selected]").length ||
                    v.push("\\[" + M + "*(?:value|" + R + ")"),
                  e.querySelectorAll("[id~=" + k + "-]").length || v.push("~="),
                  e.querySelectorAll(":checked").length || v.push(":checked"),
                  e.querySelectorAll("a#" + k + "+*").length ||
                    v.push(".#.+[+~]");
              }),
              ce(function (e) {
                e.innerHTML =
                  "<a href='' disabled='disabled'></a><select disabled='disabled'><option/></select>";
                var t = C.createElement("input");
                t.setAttribute("type", "hidden"),
                  e.appendChild(t).setAttribute("name", "D"),
                  e.querySelectorAll("[name=d]").length &&
                    v.push("name" + M + "*[*^$|!~]?="),
                  2 !== e.querySelectorAll(":enabled").length &&
                    v.push(":enabled", ":disabled"),
                  (a.appendChild(e).disabled = !0),
                  2 !== e.querySelectorAll(":disabled").length &&
                    v.push(":enabled", ":disabled"),
                  e.querySelectorAll("*,:x"),
                  v.push(",.*:");
              })),
            (d.matchesSelector = K.test(
              (c =
                a.matches ||
                a.webkitMatchesSelector ||
                a.mozMatchesSelector ||
                a.oMatchesSelector ||
                a.msMatchesSelector)
            )) &&
              ce(function (e) {
                (d.disconnectedMatch = c.call(e, "*")),
                  c.call(e, "[s!='']:x"),
                  s.push("!=", $);
              }),
            (v = v.length && new RegExp(v.join("|"))),
            (s = s.length && new RegExp(s.join("|"))),
            (t = K.test(a.compareDocumentPosition)),
            (y =
              t || K.test(a.contains)
                ? function (e, t) {
                    var n = 9 === e.nodeType ? e.documentElement : e,
                      r = t && t.parentNode;
                    return (
                      e === r ||
                      !(
                        !r ||
                        1 !== r.nodeType ||
                        !(n.contains
                          ? n.contains(r)
                          : e.compareDocumentPosition &&
                            16 & e.compareDocumentPosition(r))
                      )
                    );
                  }
                : function (e, t) {
                    if (t) while ((t = t.parentNode)) if (t === e) return !0;
                    return !1;
                  }),
            (D = t
              ? function (e, t) {
                  if (e === t) return (l = !0), 0;
                  var n =
                    !e.compareDocumentPosition - !t.compareDocumentPosition;
                  return (
                    n ||
                    (1 &
                      (n =
                        (e.ownerDocument || e) === (t.ownerDocument || t)
                          ? e.compareDocumentPosition(t)
                          : 1) ||
                    (!d.sortDetached && t.compareDocumentPosition(e) === n)
                      ? e === C || (e.ownerDocument === m && y(m, e))
                        ? -1
                        : t === C || (t.ownerDocument === m && y(m, t))
                        ? 1
                        : u
                        ? P(u, e) - P(u, t)
                        : 0
                      : 4 & n
                      ? -1
                      : 1)
                  );
                }
              : function (e, t) {
                  if (e === t) return (l = !0), 0;
                  var n,
                    r = 0,
                    i = e.parentNode,
                    o = t.parentNode,
                    a = [e],
                    s = [t];
                  if (!i || !o)
                    return e === C
                      ? -1
                      : t === C
                      ? 1
                      : i
                      ? -1
                      : o
                      ? 1
                      : u
                      ? P(u, e) - P(u, t)
                      : 0;
                  if (i === o) return pe(e, t);
                  n = e;
                  while ((n = n.parentNode)) a.unshift(n);
                  n = t;
                  while ((n = n.parentNode)) s.unshift(n);
                  while (a[r] === s[r]) r++;
                  return r
                    ? pe(a[r], s[r])
                    : a[r] === m
                    ? -1
                    : s[r] === m
                    ? 1
                    : 0;
                })),
          C
        );
      }),
    (se.matches = function (e, t) {
      return se(e, null, null, t);
    }),
    (se.matchesSelector = function (e, t) {
      if (
        ((e.ownerDocument || e) !== C && T(e),
        d.matchesSelector &&
          E &&
          !A[t + " "] &&
          (!s || !s.test(t)) &&
          (!v || !v.test(t)))
      )
        try {
          var n = c.call(e, t);
          if (
            n ||
            d.disconnectedMatch ||
            (e.document && 11 !== e.document.nodeType)
          )
            return n;
        } catch (e) {
          A(t, !0);
        }
      return 0 < se(t, C, null, [e]).length;
    }),
    (se.contains = function (e, t) {
      return (e.ownerDocument || e) !== C && T(e), y(e, t);
    }),
    (se.attr = function (e, t) {
      (e.ownerDocument || e) !== C && T(e);
      var n = b.attrHandle[t.toLowerCase()],
        r = n && j.call(b.attrHandle, t.toLowerCase()) ? n(e, t, !E) : void 0;
      return void 0 !== r
        ? r
        : d.attributes || !E
        ? e.getAttribute(t)
        : (r = e.getAttributeNode(t)) && r.specified
        ? r.value
        : null;
    }),
    (se.escape = function (e) {
      return (e + "").replace(re, ie);
    }),
    (se.error = function (e) {
      throw new Error("Syntax error, unrecognized expression: " + e);
    }),
    (se.uniqueSort = function (e) {
      var t,
        n = [],
        r = 0,
        i = 0;
      if (
        ((l = !d.detectDuplicates),
        (u = !d.sortStable && e.slice(0)),
        e.sort(D),
        l)
      ) {
        while ((t = e[i++])) t === e[i] && (r = n.push(i));
        while (r--) e.splice(n[r], 1);
      }
      return (u = null), e;
    }),
    (o = se.getText =
      function (e) {
        var t,
          n = "",
          r = 0,
          i = e.nodeType;
        if (i) {
          if (1 === i || 9 === i || 11 === i) {
            if ("string" == typeof e.textContent) return e.textContent;
            for (e = e.firstChild; e; e = e.nextSibling) n += o(e);
          } else if (3 === i || 4 === i) return e.nodeValue;
        } else while ((t = e[r++])) n += o(t);
        return n;
      }),
    ((b = se.selectors =
      {
        cacheLength: 50,
        createPseudo: le,
        match: G,
        attrHandle: {},
        find: {},
        relative: {
          ">": { dir: "parentNode", first: !0 },
          " ": { dir: "parentNode" },
          "+": { dir: "previousSibling", first: !0 },
          "~": { dir: "previousSibling" },
        },
        preFilter: {
          ATTR: function (e) {
            return (
              (e[1] = e[1].replace(te, ne)),
              (e[3] = (e[3] || e[4] || e[5] || "").replace(te, ne)),
              "~=" === e[2] && (e[3] = " " + e[3] + " "),
              e.slice(0, 4)
            );
          },
          CHILD: function (e) {
            return (
              (e[1] = e[1].toLowerCase()),
              "nth" === e[1].slice(0, 3)
                ? (e[3] || se.error(e[0]),
                  (e[4] = +(e[4]
                    ? e[5] + (e[6] || 1)
                    : 2 * ("even" === e[3] || "odd" === e[3]))),
                  (e[5] = +(e[7] + e[8] || "odd" === e[3])))
                : e[3] && se.error(e[0]),
              e
            );
          },
          PSEUDO: function (e) {
            var t,
              n = !e[6] && e[2];
            return G.CHILD.test(e[0])
              ? null
              : (e[3]
                  ? (e[2] = e[4] || e[5] || "")
                  : n &&
                    X.test(n) &&
                    (t = h(n, !0)) &&
                    (t = n.indexOf(")", n.length - t) - n.length) &&
                    ((e[0] = e[0].slice(0, t)), (e[2] = n.slice(0, t))),
                e.slice(0, 3));
          },
        },
        filter: {
          TAG: function (e) {
            var t = e.replace(te, ne).toLowerCase();
            return "*" === e
              ? function () {
                  return !0;
                }
              : function (e) {
                  return e.nodeName && e.nodeName.toLowerCase() === t;
                };
          },
          CLASS: function (e) {
            var t = p[e + " "];
            return (
              t ||
              ((t = new RegExp("(^|" + M + ")" + e + "(" + M + "|$)")) &&
                p(e, function (e) {
                  return t.test(
                    ("string" == typeof e.className && e.className) ||
                      ("undefined" != typeof e.getAttribute &&
                        e.getAttribute("class")) ||
                      ""
                  );
                }))
            );
          },
          ATTR: function (n, r, i) {
            return function (e) {
              var t = se.attr(e, n);
              return null == t
                ? "!=" === r
                : !r ||
                    ((t += ""),
                    "=" === r
                      ? t === i
                      : "!=" === r
                      ? t !== i
                      : "^=" === r
                      ? i && 0 === t.indexOf(i)
                      : "*=" === r
                      ? i && -1 < t.indexOf(i)
                      : "$=" === r
                      ? i && t.slice(-i.length) === i
                      : "~=" === r
                      ? -1 < (" " + t.replace(F, " ") + " ").indexOf(i)
                      : "|=" === r &&
                        (t === i || t.slice(0, i.length + 1) === i + "-"));
            };
          },
          CHILD: function (h, e, t, g, v) {
            var y = "nth" !== h.slice(0, 3),
              m = "last" !== h.slice(-4),
              x = "of-type" === e;
            return 1 === g && 0 === v
              ? function (e) {
                  return !!e.parentNode;
                }
              : function (e, t, n) {
                  var r,
                    i,
                    o,
                    a,
                    s,
                    u,
                    l = y !== m ? "nextSibling" : "previousSibling",
                    c = e.parentNode,
                    f = x && e.nodeName.toLowerCase(),
                    p = !n && !x,
                    d = !1;
                  if (c) {
                    if (y) {
                      while (l) {
                        a = e;
                        while ((a = a[l]))
                          if (
                            x
                              ? a.nodeName.toLowerCase() === f
                              : 1 === a.nodeType
                          )
                            return !1;
                        u = l = "only" === h && !u && "nextSibling";
                      }
                      return !0;
                    }
                    if (((u = [m ? c.firstChild : c.lastChild]), m && p)) {
                      (d =
                        (s =
                          (r =
                            (i =
                              (o = (a = c)[k] || (a[k] = {}))[a.uniqueID] ||
                              (o[a.uniqueID] = {}))[h] || [])[0] === S &&
                          r[1]) && r[2]),
                        (a = s && c.childNodes[s]);
                      while ((a = (++s && a && a[l]) || (d = s = 0) || u.pop()))
                        if (1 === a.nodeType && ++d && a === e) {
                          i[h] = [S, s, d];
                          break;
                        }
                    } else if (
                      (p &&
                        (d = s =
                          (r =
                            (i =
                              (o = (a = e)[k] || (a[k] = {}))[a.uniqueID] ||
                              (o[a.uniqueID] = {}))[h] || [])[0] === S && r[1]),
                      !1 === d)
                    )
                      while ((a = (++s && a && a[l]) || (d = s = 0) || u.pop()))
                        if (
                          (x
                            ? a.nodeName.toLowerCase() === f
                            : 1 === a.nodeType) &&
                          ++d &&
                          (p &&
                            ((i =
                              (o = a[k] || (a[k] = {}))[a.uniqueID] ||
                              (o[a.uniqueID] = {}))[h] = [S, d]),
                          a === e)
                        )
                          break;
                    return (d -= v) === g || (d % g == 0 && 0 <= d / g);
                  }
                };
          },
          PSEUDO: function (e, o) {
            var t,
              a =
                b.pseudos[e] ||
                b.setFilters[e.toLowerCase()] ||
                se.error("unsupported pseudo: " + e);
            return a[k]
              ? a(o)
              : 1 < a.length
              ? ((t = [e, e, "", o]),
                b.setFilters.hasOwnProperty(e.toLowerCase())
                  ? le(function (e, t) {
                      var n,
                        r = a(e, o),
                        i = r.length;
                      while (i--) e[(n = P(e, r[i]))] = !(t[n] = r[i]);
                    })
                  : function (e) {
                      return a(e, 0, t);
                    })
              : a;
          },
        },
        pseudos: {
          not: le(function (e) {
            var r = [],
              i = [],
              s = f(e.replace(B, "$1"));
            return s[k]
              ? le(function (e, t, n, r) {
                  var i,
                    o = s(e, null, r, []),
                    a = e.length;
                  while (a--) (i = o[a]) && (e[a] = !(t[a] = i));
                })
              : function (e, t, n) {
                  return (r[0] = e), s(r, null, n, i), (r[0] = null), !i.pop();
                };
          }),
          has: le(function (t) {
            return function (e) {
              return 0 < se(t, e).length;
            };
          }),
          contains: le(function (t) {
            return (
              (t = t.replace(te, ne)),
              function (e) {
                return -1 < (e.textContent || o(e)).indexOf(t);
              }
            );
          }),
          lang: le(function (n) {
            return (
              V.test(n || "") || se.error("unsupported lang: " + n),
              (n = n.replace(te, ne).toLowerCase()),
              function (e) {
                var t;
                do {
                  if (
                    (t = E
                      ? e.lang
                      : e.getAttribute("xml:lang") || e.getAttribute("lang"))
                  )
                    return (
                      (t = t.toLowerCase()) === n || 0 === t.indexOf(n + "-")
                    );
                } while ((e = e.parentNode) && 1 === e.nodeType);
                return !1;
              }
            );
          }),
          target: function (e) {
            var t = n.location && n.location.hash;
            return t && t.slice(1) === e.id;
          },
          root: function (e) {
            return e === a;
          },
          focus: function (e) {
            return (
              e === C.activeElement &&
              (!C.hasFocus || C.hasFocus()) &&
              !!(e.type || e.href || ~e.tabIndex)
            );
          },
          enabled: ge(!1),
          disabled: ge(!0),
          checked: function (e) {
            var t = e.nodeName.toLowerCase();
            return (
              ("input" === t && !!e.checked) || ("option" === t && !!e.selected)
            );
          },
          selected: function (e) {
            return (
              e.parentNode && e.parentNode.selectedIndex, !0 === e.selected
            );
          },
          empty: function (e) {
            for (e = e.firstChild; e; e = e.nextSibling)
              if (e.nodeType < 6) return !1;
            return !0;
          },
          parent: function (e) {
            return !b.pseudos.empty(e);
          },
          header: function (e) {
            return J.test(e.nodeName);
          },
          input: function (e) {
            return Q.test(e.nodeName);
          },
          button: function (e) {
            var t = e.nodeName.toLowerCase();
            return ("input" === t && "button" === e.type) || "button" === t;
          },
          text: function (e) {
            var t;
            return (
              "input" === e.nodeName.toLowerCase() &&
              "text" === e.type &&
              (null == (t = e.getAttribute("type")) ||
                "text" === t.toLowerCase())
            );
          },
          first: ve(function () {
            return [0];
          }),
          last: ve(function (e, t) {
            return [t - 1];
          }),
          eq: ve(function (e, t, n) {
            return [n < 0 ? n + t : n];
          }),
          even: ve(function (e, t) {
            for (var n = 0; n < t; n += 2) e.push(n);
            return e;
          }),
          odd: ve(function (e, t) {
            for (var n = 1; n < t; n += 2) e.push(n);
            return e;
          }),
          lt: ve(function (e, t, n) {
            for (var r = n < 0 ? n + t : t < n ? t : n; 0 <= --r; ) e.push(r);
            return e;
          }),
          gt: ve(function (e, t, n) {
            for (var r = n < 0 ? n + t : n; ++r < t; ) e.push(r);
            return e;
          }),
        },
      }).pseudos.nth = b.pseudos.eq),
    { radio: !0, checkbox: !0, file: !0, password: !0, image: !0 }))
      b.pseudos[e] = de(e);
    for (e in { submit: !0, reset: !0 }) b.pseudos[e] = he(e);
    function me() {}
    function xe(e) {
      for (var t = 0, n = e.length, r = ""; t < n; t++) r += e[t].value;
      return r;
    }
    function be(s, e, t) {
      var u = e.dir,
        l = e.next,
        c = l || u,
        f = t && "parentNode" === c,
        p = r++;
      return e.first
        ? function (e, t, n) {
            while ((e = e[u])) if (1 === e.nodeType || f) return s(e, t, n);
            return !1;
          }
        : function (e, t, n) {
            var r,
              i,
              o,
              a = [S, p];
            if (n) {
              while ((e = e[u]))
                if ((1 === e.nodeType || f) && s(e, t, n)) return !0;
            } else
              while ((e = e[u]))
                if (1 === e.nodeType || f)
                  if (
                    ((i =
                      (o = e[k] || (e[k] = {}))[e.uniqueID] ||
                      (o[e.uniqueID] = {})),
                    l && l === e.nodeName.toLowerCase())
                  )
                    e = e[u] || e;
                  else {
                    if ((r = i[c]) && r[0] === S && r[1] === p)
                      return (a[2] = r[2]);
                    if (((i[c] = a)[2] = s(e, t, n))) return !0;
                  }
            return !1;
          };
    }
    function we(i) {
      return 1 < i.length
        ? function (e, t, n) {
            var r = i.length;
            while (r--) if (!i[r](e, t, n)) return !1;
            return !0;
          }
        : i[0];
    }
    function Te(e, t, n, r, i) {
      for (var o, a = [], s = 0, u = e.length, l = null != t; s < u; s++)
        (o = e[s]) && ((n && !n(o, r, i)) || (a.push(o), l && t.push(s)));
      return a;
    }
    function Ce(d, h, g, v, y, e) {
      return (
        v && !v[k] && (v = Ce(v)),
        y && !y[k] && (y = Ce(y, e)),
        le(function (e, t, n, r) {
          var i,
            o,
            a,
            s = [],
            u = [],
            l = t.length,
            c =
              e ||
              (function (e, t, n) {
                for (var r = 0, i = t.length; r < i; r++) se(e, t[r], n);
                return n;
              })(h || "*", n.nodeType ? [n] : n, []),
            f = !d || (!e && h) ? c : Te(c, s, d, n, r),
            p = g ? (y || (e ? d : l || v) ? [] : t) : f;
          if ((g && g(f, p, n, r), v)) {
            (i = Te(p, u)), v(i, [], n, r), (o = i.length);
            while (o--) (a = i[o]) && (p[u[o]] = !(f[u[o]] = a));
          }
          if (e) {
            if (y || d) {
              if (y) {
                (i = []), (o = p.length);
                while (o--) (a = p[o]) && i.push((f[o] = a));
                y(null, (p = []), i, r);
              }
              o = p.length;
              while (o--)
                (a = p[o]) &&
                  -1 < (i = y ? P(e, a) : s[o]) &&
                  (e[i] = !(t[i] = a));
            }
          } else (p = Te(p === t ? p.splice(l, p.length) : p)), y ? y(null, t, p, r) : H.apply(t, p);
        })
      );
    }
    function Ee(e) {
      for (
        var i,
          t,
          n,
          r = e.length,
          o = b.relative[e[0].type],
          a = o || b.relative[" "],
          s = o ? 1 : 0,
          u = be(
            function (e) {
              return e === i;
            },
            a,
            !0
          ),
          l = be(
            function (e) {
              return -1 < P(i, e);
            },
            a,
            !0
          ),
          c = [
            function (e, t, n) {
              var r =
                (!o && (n || t !== w)) ||
                ((i = t).nodeType ? u(e, t, n) : l(e, t, n));
              return (i = null), r;
            },
          ];
        s < r;
        s++
      )
        if ((t = b.relative[e[s].type])) c = [be(we(c), t)];
        else {
          if ((t = b.filter[e[s].type].apply(null, e[s].matches))[k]) {
            for (n = ++s; n < r; n++) if (b.relative[e[n].type]) break;
            return Ce(
              1 < s && we(c),
              1 < s &&
                xe(
                  e
                    .slice(0, s - 1)
                    .concat({ value: " " === e[s - 2].type ? "*" : "" })
                ).replace(B, "$1"),
              t,
              s < n && Ee(e.slice(s, n)),
              n < r && Ee((e = e.slice(n))),
              n < r && xe(e)
            );
          }
          c.push(t);
        }
      return we(c);
    }
    return (
      (me.prototype = b.filters = b.pseudos),
      (b.setFilters = new me()),
      (h = se.tokenize =
        function (e, t) {
          var n,
            r,
            i,
            o,
            a,
            s,
            u,
            l = x[e + " "];
          if (l) return t ? 0 : l.slice(0);
          (a = e), (s = []), (u = b.preFilter);
          while (a) {
            for (o in ((n && !(r = _.exec(a))) ||
              (r && (a = a.slice(r[0].length) || a), s.push((i = []))),
            (n = !1),
            (r = z.exec(a)) &&
              ((n = r.shift()),
              i.push({ value: n, type: r[0].replace(B, " ") }),
              (a = a.slice(n.length))),
            b.filter))
              !(r = G[o].exec(a)) ||
                (u[o] && !(r = u[o](r))) ||
                ((n = r.shift()),
                i.push({ value: n, type: o, matches: r }),
                (a = a.slice(n.length)));
            if (!n) break;
          }
          return t ? a.length : a ? se.error(e) : x(e, s).slice(0);
        }),
      (f = se.compile =
        function (e, t) {
          var n,
            v,
            y,
            m,
            x,
            r,
            i = [],
            o = [],
            a = N[e + " "];
          if (!a) {
            t || (t = h(e)), (n = t.length);
            while (n--) (a = Ee(t[n]))[k] ? i.push(a) : o.push(a);
            (a = N(
              e,
              ((v = o),
              (m = 0 < (y = i).length),
              (x = 0 < v.length),
              (r = function (e, t, n, r, i) {
                var o,
                  a,
                  s,
                  u = 0,
                  l = "0",
                  c = e && [],
                  f = [],
                  p = w,
                  d = e || (x && b.find.TAG("*", i)),
                  h = (S += null == p ? 1 : Math.random() || 0.1),
                  g = d.length;
                for (
                  i && (w = t === C || t || i);
                  l !== g && null != (o = d[l]);
                  l++
                ) {
                  if (x && o) {
                    (a = 0), t || o.ownerDocument === C || (T(o), (n = !E));
                    while ((s = v[a++]))
                      if (s(o, t || C, n)) {
                        r.push(o);
                        break;
                      }
                    i && (S = h);
                  }
                  m && ((o = !s && o) && u--, e && c.push(o));
                }
                if (((u += l), m && l !== u)) {
                  a = 0;
                  while ((s = y[a++])) s(c, f, t, n);
                  if (e) {
                    if (0 < u) while (l--) c[l] || f[l] || (f[l] = q.call(r));
                    f = Te(f);
                  }
                  H.apply(r, f),
                    i &&
                      !e &&
                      0 < f.length &&
                      1 < u + y.length &&
                      se.uniqueSort(r);
                }
                return i && ((S = h), (w = p)), c;
              }),
              m ? le(r) : r)
            )).selector = e;
          }
          return a;
        }),
      (g = se.select =
        function (e, t, n, r) {
          var i,
            o,
            a,
            s,
            u,
            l = "function" == typeof e && e,
            c = !r && h((e = l.selector || e));
          if (((n = n || []), 1 === c.length)) {
            if (
              2 < (o = c[0] = c[0].slice(0)).length &&
              "ID" === (a = o[0]).type &&
              9 === t.nodeType &&
              E &&
              b.relative[o[1].type]
            ) {
              if (!(t = (b.find.ID(a.matches[0].replace(te, ne), t) || [])[0]))
                return n;
              l && (t = t.parentNode), (e = e.slice(o.shift().value.length));
            }
            i = G.needsContext.test(e) ? 0 : o.length;
            while (i--) {
              if (((a = o[i]), b.relative[(s = a.type)])) break;
              if (
                (u = b.find[s]) &&
                (r = u(
                  a.matches[0].replace(te, ne),
                  (ee.test(o[0].type) && ye(t.parentNode)) || t
                ))
              ) {
                if ((o.splice(i, 1), !(e = r.length && xe(o))))
                  return H.apply(n, r), n;
                break;
              }
            }
          }
          return (
            (l || f(e, c))(
              r,
              t,
              !E,
              n,
              !t || (ee.test(e) && ye(t.parentNode)) || t
            ),
            n
          );
        }),
      (d.sortStable = k.split("").sort(D).join("") === k),
      (d.detectDuplicates = !!l),
      T(),
      (d.sortDetached = ce(function (e) {
        return 1 & e.compareDocumentPosition(C.createElement("fieldset"));
      })),
      ce(function (e) {
        return (
          (e.innerHTML = "<a href='#'></a>"),
          "#" === e.firstChild.getAttribute("href")
        );
      }) ||
        fe("type|href|height|width", function (e, t, n) {
          if (!n) return e.getAttribute(t, "type" === t.toLowerCase() ? 1 : 2);
        }),
      (d.attributes &&
        ce(function (e) {
          return (
            (e.innerHTML = "<input/>"),
            e.firstChild.setAttribute("value", ""),
            "" === e.firstChild.getAttribute("value")
          );
        })) ||
        fe("value", function (e, t, n) {
          if (!n && "input" === e.nodeName.toLowerCase()) return e.defaultValue;
        }),
      ce(function (e) {
        return null == e.getAttribute("disabled");
      }) ||
        fe(R, function (e, t, n) {
          var r;
          if (!n)
            return !0 === e[t]
              ? t.toLowerCase()
              : (r = e.getAttributeNode(t)) && r.specified
              ? r.value
              : null;
        }),
      se
    );
  })(C);
  (k.find = h),
    (k.expr = h.selectors),
    (k.expr[":"] = k.expr.pseudos),
    (k.uniqueSort = k.unique = h.uniqueSort),
    (k.text = h.getText),
    (k.isXMLDoc = h.isXML),
    (k.contains = h.contains),
    (k.escapeSelector = h.escape);
  var T = function (e, t, n) {
      var r = [],
        i = void 0 !== n;
      while ((e = e[t]) && 9 !== e.nodeType)
        if (1 === e.nodeType) {
          if (i && k(e).is(n)) break;
          r.push(e);
        }
      return r;
    },
    S = function (e, t) {
      for (var n = []; e; e = e.nextSibling)
        1 === e.nodeType && e !== t && n.push(e);
      return n;
    },
    N = k.expr.match.needsContext;
  function A(e, t) {
    return e.nodeName && e.nodeName.toLowerCase() === t.toLowerCase();
  }
  var D = /^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i;
  function j(e, n, r) {
    return m(n)
      ? k.grep(e, function (e, t) {
          return !!n.call(e, t, e) !== r;
        })
      : n.nodeType
      ? k.grep(e, function (e) {
          return (e === n) !== r;
        })
      : "string" != typeof n
      ? k.grep(e, function (e) {
          return -1 < i.call(n, e) !== r;
        })
      : k.filter(n, e, r);
  }
  (k.filter = function (e, t, n) {
    var r = t[0];
    return (
      n && (e = ":not(" + e + ")"),
      1 === t.length && 1 === r.nodeType
        ? k.find.matchesSelector(r, e)
          ? [r]
          : []
        : k.find.matches(
            e,
            k.grep(t, function (e) {
              return 1 === e.nodeType;
            })
          )
    );
  }),
    k.fn.extend({
      find: function (e) {
        var t,
          n,
          r = this.length,
          i = this;
        if ("string" != typeof e)
          return this.pushStack(
            k(e).filter(function () {
              for (t = 0; t < r; t++) if (k.contains(i[t], this)) return !0;
            })
          );
        for (n = this.pushStack([]), t = 0; t < r; t++) k.find(e, i[t], n);
        return 1 < r ? k.uniqueSort(n) : n;
      },
      filter: function (e) {
        return this.pushStack(j(this, e || [], !1));
      },
      not: function (e) {
        return this.pushStack(j(this, e || [], !0));
      },
      is: function (e) {
        return !!j(this, "string" == typeof e && N.test(e) ? k(e) : e || [], !1)
          .length;
      },
    });
  var q,
    L = /^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]+))$/;
  ((k.fn.init = function (e, t, n) {
    var r, i;
    if (!e) return this;
    if (((n = n || q), "string" == typeof e)) {
      if (
        !(r =
          "<" === e[0] && ">" === e[e.length - 1] && 3 <= e.length
            ? [null, e, null]
            : L.exec(e)) ||
        (!r[1] && t)
      )
        return !t || t.jquery ? (t || n).find(e) : this.constructor(t).find(e);
      if (r[1]) {
        if (
          ((t = t instanceof k ? t[0] : t),
          k.merge(
            this,
            k.parseHTML(r[1], t && t.nodeType ? t.ownerDocument || t : E, !0)
          ),
          D.test(r[1]) && k.isPlainObject(t))
        )
          for (r in t) m(this[r]) ? this[r](t[r]) : this.attr(r, t[r]);
        return this;
      }
      return (
        (i = E.getElementById(r[2])) && ((this[0] = i), (this.length = 1)), this
      );
    }
    return e.nodeType
      ? ((this[0] = e), (this.length = 1), this)
      : m(e)
      ? void 0 !== n.ready
        ? n.ready(e)
        : e(k)
      : k.makeArray(e, this);
  }).prototype = k.fn),
    (q = k(E));
  var H = /^(?:parents|prev(?:Until|All))/,
    O = { children: !0, contents: !0, next: !0, prev: !0 };
  function P(e, t) {
    while ((e = e[t]) && 1 !== e.nodeType);
    return e;
  }
  k.fn.extend({
    has: function (e) {
      var t = k(e, this),
        n = t.length;
      return this.filter(function () {
        for (var e = 0; e < n; e++) if (k.contains(this, t[e])) return !0;
      });
    },
    closest: function (e, t) {
      var n,
        r = 0,
        i = this.length,
        o = [],
        a = "string" != typeof e && k(e);
      if (!N.test(e))
        for (; r < i; r++)
          for (n = this[r]; n && n !== t; n = n.parentNode)
            if (
              n.nodeType < 11 &&
              (a
                ? -1 < a.index(n)
                : 1 === n.nodeType && k.find.matchesSelector(n, e))
            ) {
              o.push(n);
              break;
            }
      return this.pushStack(1 < o.length ? k.uniqueSort(o) : o);
    },
    index: function (e) {
      return e
        ? "string" == typeof e
          ? i.call(k(e), this[0])
          : i.call(this, e.jquery ? e[0] : e)
        : this[0] && this[0].parentNode
        ? this.first().prevAll().length
        : -1;
    },
    add: function (e, t) {
      return this.pushStack(k.uniqueSort(k.merge(this.get(), k(e, t))));
    },
    addBack: function (e) {
      return this.add(null == e ? this.prevObject : this.prevObject.filter(e));
    },
  }),
    k.each(
      {
        parent: function (e) {
          var t = e.parentNode;
          return t && 11 !== t.nodeType ? t : null;
        },
        parents: function (e) {
          return T(e, "parentNode");
        },
        parentsUntil: function (e, t, n) {
          return T(e, "parentNode", n);
        },
        next: function (e) {
          return P(e, "nextSibling");
        },
        prev: function (e) {
          return P(e, "previousSibling");
        },
        nextAll: function (e) {
          return T(e, "nextSibling");
        },
        prevAll: function (e) {
          return T(e, "previousSibling");
        },
        nextUntil: function (e, t, n) {
          return T(e, "nextSibling", n);
        },
        prevUntil: function (e, t, n) {
          return T(e, "previousSibling", n);
        },
        siblings: function (e) {
          return S((e.parentNode || {}).firstChild, e);
        },
        children: function (e) {
          return S(e.firstChild);
        },
        contents: function (e) {
          return "undefined" != typeof e.contentDocument
            ? e.contentDocument
            : (A(e, "template") && (e = e.content || e),
              k.merge([], e.childNodes));
        },
      },
      function (r, i) {
        k.fn[r] = function (e, t) {
          var n = k.map(this, i, e);
          return (
            "Until" !== r.slice(-5) && (t = e),
            t && "string" == typeof t && (n = k.filter(t, n)),
            1 < this.length &&
              (O[r] || k.uniqueSort(n), H.test(r) && n.reverse()),
            this.pushStack(n)
          );
        };
      }
    );
  var R = /[^\x20\t\r\n\f]+/g;
  function M(e) {
    return e;
  }
  function I(e) {
    throw e;
  }
  function W(e, t, n, r) {
    var i;
    try {
      e && m((i = e.promise))
        ? i.call(e).done(t).fail(n)
        : e && m((i = e.then))
        ? i.call(e, t, n)
        : t.apply(void 0, [e].slice(r));
    } catch (e) {
      n.apply(void 0, [e]);
    }
  }
  (k.Callbacks = function (r) {
    var e, n;
    r =
      "string" == typeof r
        ? ((e = r),
          (n = {}),
          k.each(e.match(R) || [], function (e, t) {
            n[t] = !0;
          }),
          n)
        : k.extend({}, r);
    var i,
      t,
      o,
      a,
      s = [],
      u = [],
      l = -1,
      c = function () {
        for (a = a || r.once, o = i = !0; u.length; l = -1) {
          t = u.shift();
          while (++l < s.length)
            !1 === s[l].apply(t[0], t[1]) &&
              r.stopOnFalse &&
              ((l = s.length), (t = !1));
        }
        r.memory || (t = !1), (i = !1), a && (s = t ? [] : "");
      },
      f = {
        add: function () {
          return (
            s &&
              (t && !i && ((l = s.length - 1), u.push(t)),
              (function n(e) {
                k.each(e, function (e, t) {
                  m(t)
                    ? (r.unique && f.has(t)) || s.push(t)
                    : t && t.length && "string" !== w(t) && n(t);
                });
              })(arguments),
              t && !i && c()),
            this
          );
        },
        remove: function () {
          return (
            k.each(arguments, function (e, t) {
              var n;
              while (-1 < (n = k.inArray(t, s, n)))
                s.splice(n, 1), n <= l && l--;
            }),
            this
          );
        },
        has: function (e) {
          return e ? -1 < k.inArray(e, s) : 0 < s.length;
        },
        empty: function () {
          return s && (s = []), this;
        },
        disable: function () {
          return (a = u = []), (s = t = ""), this;
        },
        disabled: function () {
          return !s;
        },
        lock: function () {
          return (a = u = []), t || i || (s = t = ""), this;
        },
        locked: function () {
          return !!a;
        },
        fireWith: function (e, t) {
          return (
            a ||
              ((t = [e, (t = t || []).slice ? t.slice() : t]),
              u.push(t),
              i || c()),
            this
          );
        },
        fire: function () {
          return f.fireWith(this, arguments), this;
        },
        fired: function () {
          return !!o;
        },
      };
    return f;
  }),
    k.extend({
      Deferred: function (e) {
        var o = [
            [
              "notify",
              "progress",
              k.Callbacks("memory"),
              k.Callbacks("memory"),
              2,
            ],
            [
              "resolve",
              "done",
              k.Callbacks("once memory"),
              k.Callbacks("once memory"),
              0,
              "resolved",
            ],
            [
              "reject",
              "fail",
              k.Callbacks("once memory"),
              k.Callbacks("once memory"),
              1,
              "rejected",
            ],
          ],
          i = "pending",
          a = {
            state: function () {
              return i;
            },
            always: function () {
              return s.done(arguments).fail(arguments), this;
            },
            catch: function (e) {
              return a.then(null, e);
            },
            pipe: function () {
              var i = arguments;
              return k
                .Deferred(function (r) {
                  k.each(o, function (e, t) {
                    var n = m(i[t[4]]) && i[t[4]];
                    s[t[1]](function () {
                      var e = n && n.apply(this, arguments);
                      e && m(e.promise)
                        ? e
                            .promise()
                            .progress(r.notify)
                            .done(r.resolve)
                            .fail(r.reject)
                        : r[t[0] + "With"](this, n ? [e] : arguments);
                    });
                  }),
                    (i = null);
                })
                .promise();
            },
            then: function (t, n, r) {
              var u = 0;
              function l(i, o, a, s) {
                return function () {
                  var n = this,
                    r = arguments,
                    e = function () {
                      var e, t;
                      if (!(i < u)) {
                        if ((e = a.apply(n, r)) === o.promise())
                          throw new TypeError("Thenable self-resolution");
                        (t =
                          e &&
                          ("object" == typeof e || "function" == typeof e) &&
                          e.then),
                          m(t)
                            ? s
                              ? t.call(e, l(u, o, M, s), l(u, o, I, s))
                              : (u++,
                                t.call(
                                  e,
                                  l(u, o, M, s),
                                  l(u, o, I, s),
                                  l(u, o, M, o.notifyWith)
                                ))
                            : (a !== M && ((n = void 0), (r = [e])),
                              (s || o.resolveWith)(n, r));
                      }
                    },
                    t = s
                      ? e
                      : function () {
                          try {
                            e();
                          } catch (e) {
                            k.Deferred.exceptionHook &&
                              k.Deferred.exceptionHook(e, t.stackTrace),
                              u <= i + 1 &&
                                (a !== I && ((n = void 0), (r = [e])),
                                o.rejectWith(n, r));
                          }
                        };
                  i
                    ? t()
                    : (k.Deferred.getStackHook &&
                        (t.stackTrace = k.Deferred.getStackHook()),
                      C.setTimeout(t));
                };
              }
              return k
                .Deferred(function (e) {
                  o[0][3].add(l(0, e, m(r) ? r : M, e.notifyWith)),
                    o[1][3].add(l(0, e, m(t) ? t : M)),
                    o[2][3].add(l(0, e, m(n) ? n : I));
                })
                .promise();
            },
            promise: function (e) {
              return null != e ? k.extend(e, a) : a;
            },
          },
          s = {};
        return (
          k.each(o, function (e, t) {
            var n = t[2],
              r = t[5];
            (a[t[1]] = n.add),
              r &&
                n.add(
                  function () {
                    i = r;
                  },
                  o[3 - e][2].disable,
                  o[3 - e][3].disable,
                  o[0][2].lock,
                  o[0][3].lock
                ),
              n.add(t[3].fire),
              (s[t[0]] = function () {
                return (
                  s[t[0] + "With"](this === s ? void 0 : this, arguments), this
                );
              }),
              (s[t[0] + "With"] = n.fireWith);
          }),
          a.promise(s),
          e && e.call(s, s),
          s
        );
      },
      when: function (e) {
        var n = arguments.length,
          t = n,
          r = Array(t),
          i = s.call(arguments),
          o = k.Deferred(),
          a = function (t) {
            return function (e) {
              (r[t] = this),
                (i[t] = 1 < arguments.length ? s.call(arguments) : e),
                --n || o.resolveWith(r, i);
            };
          };
        if (
          n <= 1 &&
          (W(e, o.done(a(t)).resolve, o.reject, !n),
          "pending" === o.state() || m(i[t] && i[t].then))
        )
          return o.then();
        while (t--) W(i[t], a(t), o.reject);
        return o.promise();
      },
    });
  var $ = /^(Eval|Internal|Range|Reference|Syntax|Type|URI)Error$/;
  (k.Deferred.exceptionHook = function (e, t) {
    C.console &&
      C.console.warn &&
      e &&
      $.test(e.name) &&
      C.console.warn("jQuery.Deferred exception: " + e.message, e.stack, t);
  }),
    (k.readyException = function (e) {
      C.setTimeout(function () {
        throw e;
      });
    });
  var F = k.Deferred();
  function B() {
    E.removeEventListener("DOMContentLoaded", B),
      C.removeEventListener("load", B),
      k.ready();
  }
  (k.fn.ready = function (e) {
    return (
      F.then(e)["catch"](function (e) {
        k.readyException(e);
      }),
      this
    );
  }),
    k.extend({
      isReady: !1,
      readyWait: 1,
      ready: function (e) {
        (!0 === e ? --k.readyWait : k.isReady) ||
          ((k.isReady = !0) !== e && 0 < --k.readyWait) ||
          F.resolveWith(E, [k]);
      },
    }),
    (k.ready.then = F.then),
    "complete" === E.readyState ||
    ("loading" !== E.readyState && !E.documentElement.doScroll)
      ? C.setTimeout(k.ready)
      : (E.addEventListener("DOMContentLoaded", B),
        C.addEventListener("load", B));
  var _ = function (e, t, n, r, i, o, a) {
      var s = 0,
        u = e.length,
        l = null == n;
      if ("object" === w(n))
        for (s in ((i = !0), n)) _(e, t, s, n[s], !0, o, a);
      else if (
        void 0 !== r &&
        ((i = !0),
        m(r) || (a = !0),
        l &&
          (a
            ? (t.call(e, r), (t = null))
            : ((l = t),
              (t = function (e, t, n) {
                return l.call(k(e), n);
              }))),
        t)
      )
        for (; s < u; s++) t(e[s], n, a ? r : r.call(e[s], s, t(e[s], n)));
      return i ? e : l ? t.call(e) : u ? t(e[0], n) : o;
    },
    z = /^-ms-/,
    U = /-([a-z])/g;
  function X(e, t) {
    return t.toUpperCase();
  }
  function V(e) {
    return e.replace(z, "ms-").replace(U, X);
  }
  var G = function (e) {
    return 1 === e.nodeType || 9 === e.nodeType || !+e.nodeType;
  };
  function Y() {
    this.expando = k.expando + Y.uid++;
  }
  (Y.uid = 1),
    (Y.prototype = {
      cache: function (e) {
        var t = e[this.expando];
        return (
          t ||
            ((t = {}),
            G(e) &&
              (e.nodeType
                ? (e[this.expando] = t)
                : Object.defineProperty(e, this.expando, {
                    value: t,
                    configurable: !0,
                  }))),
          t
        );
      },
      set: function (e, t, n) {
        var r,
          i = this.cache(e);
        if ("string" == typeof t) i[V(t)] = n;
        else for (r in t) i[V(r)] = t[r];
        return i;
      },
      get: function (e, t) {
        return void 0 === t
          ? this.cache(e)
          : e[this.expando] && e[this.expando][V(t)];
      },
      access: function (e, t, n) {
        return void 0 === t || (t && "string" == typeof t && void 0 === n)
          ? this.get(e, t)
          : (this.set(e, t, n), void 0 !== n ? n : t);
      },
      remove: function (e, t) {
        var n,
          r = e[this.expando];
        if (void 0 !== r) {
          if (void 0 !== t) {
            n = (t = Array.isArray(t)
              ? t.map(V)
              : (t = V(t)) in r
              ? [t]
              : t.match(R) || []).length;
            while (n--) delete r[t[n]];
          }
          (void 0 === t || k.isEmptyObject(r)) &&
            (e.nodeType ? (e[this.expando] = void 0) : delete e[this.expando]);
        }
      },
      hasData: function (e) {
        var t = e[this.expando];
        return void 0 !== t && !k.isEmptyObject(t);
      },
    });
  var Q = new Y(),
    J = new Y(),
    K = /^(?:\{[\w\W]*\}|\[[\w\W]*\])$/,
    Z = /[A-Z]/g;
  function ee(e, t, n) {
    var r, i;
    if (void 0 === n && 1 === e.nodeType)
      if (
        ((r = "data-" + t.replace(Z, "-$&").toLowerCase()),
        "string" == typeof (n = e.getAttribute(r)))
      ) {
        try {
          n =
            "true" === (i = n) ||
            ("false" !== i &&
              ("null" === i
                ? null
                : i === +i + ""
                ? +i
                : K.test(i)
                ? JSON.parse(i)
                : i));
        } catch (e) {}
        J.set(e, t, n);
      } else n = void 0;
    return n;
  }
  k.extend({
    hasData: function (e) {
      return J.hasData(e) || Q.hasData(e);
    },
    data: function (e, t, n) {
      return J.access(e, t, n);
    },
    removeData: function (e, t) {
      J.remove(e, t);
    },
    _data: function (e, t, n) {
      return Q.access(e, t, n);
    },
    _removeData: function (e, t) {
      Q.remove(e, t);
    },
  }),
    k.fn.extend({
      data: function (n, e) {
        var t,
          r,
          i,
          o = this[0],
          a = o && o.attributes;
        if (void 0 === n) {
          if (
            this.length &&
            ((i = J.get(o)), 1 === o.nodeType && !Q.get(o, "hasDataAttrs"))
          ) {
            t = a.length;
            while (t--)
              a[t] &&
                0 === (r = a[t].name).indexOf("data-") &&
                ((r = V(r.slice(5))), ee(o, r, i[r]));
            Q.set(o, "hasDataAttrs", !0);
          }
          return i;
        }
        return "object" == typeof n
          ? this.each(function () {
              J.set(this, n);
            })
          : _(
              this,
              function (e) {
                var t;
                if (o && void 0 === e)
                  return void 0 !== (t = J.get(o, n))
                    ? t
                    : void 0 !== (t = ee(o, n))
                    ? t
                    : void 0;
                this.each(function () {
                  J.set(this, n, e);
                });
              },
              null,
              e,
              1 < arguments.length,
              null,
              !0
            );
      },
      removeData: function (e) {
        return this.each(function () {
          J.remove(this, e);
        });
      },
    }),
    k.extend({
      queue: function (e, t, n) {
        var r;
        if (e)
          return (
            (t = (t || "fx") + "queue"),
            (r = Q.get(e, t)),
            n &&
              (!r || Array.isArray(n)
                ? (r = Q.access(e, t, k.makeArray(n)))
                : r.push(n)),
            r || []
          );
      },
      dequeue: function (e, t) {
        t = t || "fx";
        var n = k.queue(e, t),
          r = n.length,
          i = n.shift(),
          o = k._queueHooks(e, t);
        "inprogress" === i && ((i = n.shift()), r--),
          i &&
            ("fx" === t && n.unshift("inprogress"),
            delete o.stop,
            i.call(
              e,
              function () {
                k.dequeue(e, t);
              },
              o
            )),
          !r && o && o.empty.fire();
      },
      _queueHooks: function (e, t) {
        var n = t + "queueHooks";
        return (
          Q.get(e, n) ||
          Q.access(e, n, {
            empty: k.Callbacks("once memory").add(function () {
              Q.remove(e, [t + "queue", n]);
            }),
          })
        );
      },
    }),
    k.fn.extend({
      queue: function (t, n) {
        var e = 2;
        return (
          "string" != typeof t && ((n = t), (t = "fx"), e--),
          arguments.length < e
            ? k.queue(this[0], t)
            : void 0 === n
            ? this
            : this.each(function () {
                var e = k.queue(this, t, n);
                k._queueHooks(this, t),
                  "fx" === t && "inprogress" !== e[0] && k.dequeue(this, t);
              })
        );
      },
      dequeue: function (e) {
        return this.each(function () {
          k.dequeue(this, e);
        });
      },
      clearQueue: function (e) {
        return this.queue(e || "fx", []);
      },
      promise: function (e, t) {
        var n,
          r = 1,
          i = k.Deferred(),
          o = this,
          a = this.length,
          s = function () {
            --r || i.resolveWith(o, [o]);
          };
        "string" != typeof e && ((t = e), (e = void 0)), (e = e || "fx");
        while (a--)
          (n = Q.get(o[a], e + "queueHooks")) &&
            n.empty &&
            (r++, n.empty.add(s));
        return s(), i.promise(t);
      },
    });
  var te = /[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source,
    ne = new RegExp("^(?:([+-])=|)(" + te + ")([a-z%]*)$", "i"),
    re = ["Top", "Right", "Bottom", "Left"],
    ie = E.documentElement,
    oe = function (e) {
      return k.contains(e.ownerDocument, e);
    },
    ae = { composed: !0 };
  ie.getRootNode &&
    (oe = function (e) {
      return (
        k.contains(e.ownerDocument, e) || e.getRootNode(ae) === e.ownerDocument
      );
    });
  var se = function (e, t) {
      return (
        "none" === (e = t || e).style.display ||
        ("" === e.style.display && oe(e) && "none" === k.css(e, "display"))
      );
    },
    ue = function (e, t, n, r) {
      var i,
        o,
        a = {};
      for (o in t) (a[o] = e.style[o]), (e.style[o] = t[o]);
      for (o in ((i = n.apply(e, r || [])), t)) e.style[o] = a[o];
      return i;
    };
  function le(e, t, n, r) {
    var i,
      o,
      a = 20,
      s = r
        ? function () {
            return r.cur();
          }
        : function () {
            return k.css(e, t, "");
          },
      u = s(),
      l = (n && n[3]) || (k.cssNumber[t] ? "" : "px"),
      c =
        e.nodeType &&
        (k.cssNumber[t] || ("px" !== l && +u)) &&
        ne.exec(k.css(e, t));
    if (c && c[3] !== l) {
      (u /= 2), (l = l || c[3]), (c = +u || 1);
      while (a--)
        k.style(e, t, c + l),
          (1 - o) * (1 - (o = s() / u || 0.5)) <= 0 && (a = 0),
          (c /= o);
      (c *= 2), k.style(e, t, c + l), (n = n || []);
    }
    return (
      n &&
        ((c = +c || +u || 0),
        (i = n[1] ? c + (n[1] + 1) * n[2] : +n[2]),
        r && ((r.unit = l), (r.start = c), (r.end = i))),
      i
    );
  }
  var ce = {};
  function fe(e, t) {
    for (var n, r, i, o, a, s, u, l = [], c = 0, f = e.length; c < f; c++)
      (r = e[c]).style &&
        ((n = r.style.display),
        t
          ? ("none" === n &&
              ((l[c] = Q.get(r, "display") || null),
              l[c] || (r.style.display = "")),
            "" === r.style.display &&
              se(r) &&
              (l[c] =
                ((u = a = o = void 0),
                (a = (i = r).ownerDocument),
                (s = i.nodeName),
                (u = ce[s]) ||
                  ((o = a.body.appendChild(a.createElement(s))),
                  (u = k.css(o, "display")),
                  o.parentNode.removeChild(o),
                  "none" === u && (u = "block"),
                  (ce[s] = u)))))
          : "none" !== n && ((l[c] = "none"), Q.set(r, "display", n)));
    for (c = 0; c < f; c++) null != l[c] && (e[c].style.display = l[c]);
    return e;
  }
  k.fn.extend({
    show: function () {
      return fe(this, !0);
    },
    hide: function () {
      return fe(this);
    },
    toggle: function (e) {
      return "boolean" == typeof e
        ? e
          ? this.show()
          : this.hide()
        : this.each(function () {
            se(this) ? k(this).show() : k(this).hide();
          });
    },
  });
  var pe = /^(?:checkbox|radio)$/i,
    de = /<([a-z][^\/\0>\x20\t\r\n\f]*)/i,
    he = /^$|^module$|\/(?:java|ecma)script/i,
    ge = {
      option: [1, "<select multiple='multiple'>", "</select>"],
      thead: [1, "<table>", "</table>"],
      col: [2, "<table><colgroup>", "</colgroup></table>"],
      tr: [2, "<table><tbody>", "</tbody></table>"],
      td: [3, "<table><tbody><tr>", "</tr></tbody></table>"],
      _default: [0, "", ""],
    };
  function ve(e, t) {
    var n;
    return (
      (n =
        "undefined" != typeof e.getElementsByTagName
          ? e.getElementsByTagName(t || "*")
          : "undefined" != typeof e.querySelectorAll
          ? e.querySelectorAll(t || "*")
          : []),
      void 0 === t || (t && A(e, t)) ? k.merge([e], n) : n
    );
  }
  function ye(e, t) {
    for (var n = 0, r = e.length; n < r; n++)
      Q.set(e[n], "globalEval", !t || Q.get(t[n], "globalEval"));
  }
  (ge.optgroup = ge.option),
    (ge.tbody = ge.tfoot = ge.colgroup = ge.caption = ge.thead),
    (ge.th = ge.td);
  var me,
    xe,
    be = /<|&#?\w+;/;
  function we(e, t, n, r, i) {
    for (
      var o,
        a,
        s,
        u,
        l,
        c,
        f = t.createDocumentFragment(),
        p = [],
        d = 0,
        h = e.length;
      d < h;
      d++
    )
      if ((o = e[d]) || 0 === o)
        if ("object" === w(o)) k.merge(p, o.nodeType ? [o] : o);
        else if (be.test(o)) {
          (a = a || f.appendChild(t.createElement("div"))),
            (s = (de.exec(o) || ["", ""])[1].toLowerCase()),
            (u = ge[s] || ge._default),
            (a.innerHTML = u[1] + k.htmlPrefilter(o) + u[2]),
            (c = u[0]);
          while (c--) a = a.lastChild;
          k.merge(p, a.childNodes), ((a = f.firstChild).textContent = "");
        } else p.push(t.createTextNode(o));
    (f.textContent = ""), (d = 0);
    while ((o = p[d++]))
      if (r && -1 < k.inArray(o, r)) i && i.push(o);
      else if (
        ((l = oe(o)), (a = ve(f.appendChild(o), "script")), l && ye(a), n)
      ) {
        c = 0;
        while ((o = a[c++])) he.test(o.type || "") && n.push(o);
      }
    return f;
  }
  (me = E.createDocumentFragment().appendChild(E.createElement("div"))),
    (xe = E.createElement("input")).setAttribute("type", "radio"),
    xe.setAttribute("checked", "checked"),
    xe.setAttribute("name", "t"),
    me.appendChild(xe),
    (y.checkClone = me.cloneNode(!0).cloneNode(!0).lastChild.checked),
    (me.innerHTML = "<textarea>x</textarea>"),
    (y.noCloneChecked = !!me.cloneNode(!0).lastChild.defaultValue);
  var Te = /^key/,
    Ce = /^(?:mouse|pointer|contextmenu|drag|drop)|click/,
    Ee = /^([^.]*)(?:\.(.+)|)/;
  function ke() {
    return !0;
  }
  function Se() {
    return !1;
  }
  function Ne(e, t) {
    return (
      (e ===
        (function () {
          try {
            return E.activeElement;
          } catch (e) {}
        })()) ==
      ("focus" === t)
    );
  }
  function Ae(e, t, n, r, i, o) {
    var a, s;
    if ("object" == typeof t) {
      for (s in ("string" != typeof n && ((r = r || n), (n = void 0)), t))
        Ae(e, s, n, r, t[s], o);
      return e;
    }
    if (
      (null == r && null == i
        ? ((i = n), (r = n = void 0))
        : null == i &&
          ("string" == typeof n
            ? ((i = r), (r = void 0))
            : ((i = r), (r = n), (n = void 0))),
      !1 === i)
    )
      i = Se;
    else if (!i) return e;
    return (
      1 === o &&
        ((a = i),
        ((i = function (e) {
          return k().off(e), a.apply(this, arguments);
        }).guid = a.guid || (a.guid = k.guid++))),
      e.each(function () {
        k.event.add(this, t, i, r, n);
      })
    );
  }
  function De(e, i, o) {
    o
      ? (Q.set(e, i, !1),
        k.event.add(e, i, {
          namespace: !1,
          handler: function (e) {
            var t,
              n,
              r = Q.get(this, i);
            if (1 & e.isTrigger && this[i]) {
              if (r.length)
                (k.event.special[i] || {}).delegateType && e.stopPropagation();
              else if (
                ((r = s.call(arguments)),
                Q.set(this, i, r),
                (t = o(this, i)),
                this[i](),
                r !== (n = Q.get(this, i)) || t ? Q.set(this, i, !1) : (n = {}),
                r !== n)
              )
                return (
                  e.stopImmediatePropagation(), e.preventDefault(), n.value
                );
            } else
              r.length &&
                (Q.set(this, i, {
                  value: k.event.trigger(
                    k.extend(r[0], k.Event.prototype),
                    r.slice(1),
                    this
                  ),
                }),
                e.stopImmediatePropagation());
          },
        }))
      : void 0 === Q.get(e, i) && k.event.add(e, i, ke);
  }
  (k.event = {
    global: {},
    add: function (t, e, n, r, i) {
      var o,
        a,
        s,
        u,
        l,
        c,
        f,
        p,
        d,
        h,
        g,
        v = Q.get(t);
      if (v) {
        n.handler && ((n = (o = n).handler), (i = o.selector)),
          i && k.find.matchesSelector(ie, i),
          n.guid || (n.guid = k.guid++),
          (u = v.events) || (u = v.events = {}),
          (a = v.handle) ||
            (a = v.handle =
              function (e) {
                return "undefined" != typeof k && k.event.triggered !== e.type
                  ? k.event.dispatch.apply(t, arguments)
                  : void 0;
              }),
          (l = (e = (e || "").match(R) || [""]).length);
        while (l--)
          (d = g = (s = Ee.exec(e[l]) || [])[1]),
            (h = (s[2] || "").split(".").sort()),
            d &&
              ((f = k.event.special[d] || {}),
              (d = (i ? f.delegateType : f.bindType) || d),
              (f = k.event.special[d] || {}),
              (c = k.extend(
                {
                  type: d,
                  origType: g,
                  data: r,
                  handler: n,
                  guid: n.guid,
                  selector: i,
                  needsContext: i && k.expr.match.needsContext.test(i),
                  namespace: h.join("."),
                },
                o
              )),
              (p = u[d]) ||
                (((p = u[d] = []).delegateCount = 0),
                (f.setup && !1 !== f.setup.call(t, r, h, a)) ||
                  (t.addEventListener && t.addEventListener(d, a))),
              f.add &&
                (f.add.call(t, c), c.handler.guid || (c.handler.guid = n.guid)),
              i ? p.splice(p.delegateCount++, 0, c) : p.push(c),
              (k.event.global[d] = !0));
      }
    },
    remove: function (e, t, n, r, i) {
      var o,
        a,
        s,
        u,
        l,
        c,
        f,
        p,
        d,
        h,
        g,
        v = Q.hasData(e) && Q.get(e);
      if (v && (u = v.events)) {
        l = (t = (t || "").match(R) || [""]).length;
        while (l--)
          if (
            ((d = g = (s = Ee.exec(t[l]) || [])[1]),
            (h = (s[2] || "").split(".").sort()),
            d)
          ) {
            (f = k.event.special[d] || {}),
              (p = u[(d = (r ? f.delegateType : f.bindType) || d)] || []),
              (s =
                s[2] &&
                new RegExp("(^|\\.)" + h.join("\\.(?:.*\\.|)") + "(\\.|$)")),
              (a = o = p.length);
            while (o--)
              (c = p[o]),
                (!i && g !== c.origType) ||
                  (n && n.guid !== c.guid) ||
                  (s && !s.test(c.namespace)) ||
                  (r && r !== c.selector && ("**" !== r || !c.selector)) ||
                  (p.splice(o, 1),
                  c.selector && p.delegateCount--,
                  f.remove && f.remove.call(e, c));
            a &&
              !p.length &&
              ((f.teardown && !1 !== f.teardown.call(e, h, v.handle)) ||
                k.removeEvent(e, d, v.handle),
              delete u[d]);
          } else for (d in u) k.event.remove(e, d + t[l], n, r, !0);
        k.isEmptyObject(u) && Q.remove(e, "handle events");
      }
    },
    dispatch: function (e) {
      var t,
        n,
        r,
        i,
        o,
        a,
        s = k.event.fix(e),
        u = new Array(arguments.length),
        l = (Q.get(this, "events") || {})[s.type] || [],
        c = k.event.special[s.type] || {};
      for (u[0] = s, t = 1; t < arguments.length; t++) u[t] = arguments[t];
      if (
        ((s.delegateTarget = this),
        !c.preDispatch || !1 !== c.preDispatch.call(this, s))
      ) {
        (a = k.event.handlers.call(this, s, l)), (t = 0);
        while ((i = a[t++]) && !s.isPropagationStopped()) {
          (s.currentTarget = i.elem), (n = 0);
          while ((o = i.handlers[n++]) && !s.isImmediatePropagationStopped())
            (s.rnamespace &&
              !1 !== o.namespace &&
              !s.rnamespace.test(o.namespace)) ||
              ((s.handleObj = o),
              (s.data = o.data),
              void 0 !==
                (r = (
                  (k.event.special[o.origType] || {}).handle || o.handler
                ).apply(i.elem, u)) &&
                !1 === (s.result = r) &&
                (s.preventDefault(), s.stopPropagation()));
        }
        return c.postDispatch && c.postDispatch.call(this, s), s.result;
      }
    },
    handlers: function (e, t) {
      var n,
        r,
        i,
        o,
        a,
        s = [],
        u = t.delegateCount,
        l = e.target;
      if (u && l.nodeType && !("click" === e.type && 1 <= e.button))
        for (; l !== this; l = l.parentNode || this)
          if (1 === l.nodeType && ("click" !== e.type || !0 !== l.disabled)) {
            for (o = [], a = {}, n = 0; n < u; n++)
              void 0 === a[(i = (r = t[n]).selector + " ")] &&
                (a[i] = r.needsContext
                  ? -1 < k(i, this).index(l)
                  : k.find(i, this, null, [l]).length),
                a[i] && o.push(r);
            o.length && s.push({ elem: l, handlers: o });
          }
      return (
        (l = this), u < t.length && s.push({ elem: l, handlers: t.slice(u) }), s
      );
    },
    addProp: function (t, e) {
      Object.defineProperty(k.Event.prototype, t, {
        enumerable: !0,
        configurable: !0,
        get: m(e)
          ? function () {
              if (this.originalEvent) return e(this.originalEvent);
            }
          : function () {
              if (this.originalEvent) return this.originalEvent[t];
            },
        set: function (e) {
          Object.defineProperty(this, t, {
            enumerable: !0,
            configurable: !0,
            writable: !0,
            value: e,
          });
        },
      });
    },
    fix: function (e) {
      return e[k.expando] ? e : new k.Event(e);
    },
    special: {
      load: { noBubble: !0 },
      click: {
        setup: function (e) {
          var t = this || e;
          return (
            pe.test(t.type) && t.click && A(t, "input") && De(t, "click", ke),
            !1
          );
        },
        trigger: function (e) {
          var t = this || e;
          return (
            pe.test(t.type) && t.click && A(t, "input") && De(t, "click"), !0
          );
        },
        _default: function (e) {
          var t = e.target;
          return (
            (pe.test(t.type) &&
              t.click &&
              A(t, "input") &&
              Q.get(t, "click")) ||
            A(t, "a")
          );
        },
      },
      beforeunload: {
        postDispatch: function (e) {
          void 0 !== e.result &&
            e.originalEvent &&
            (e.originalEvent.returnValue = e.result);
        },
      },
    },
  }),
    (k.removeEvent = function (e, t, n) {
      e.removeEventListener && e.removeEventListener(t, n);
    }),
    (k.Event = function (e, t) {
      if (!(this instanceof k.Event)) return new k.Event(e, t);
      e && e.type
        ? ((this.originalEvent = e),
          (this.type = e.type),
          (this.isDefaultPrevented =
            e.defaultPrevented ||
            (void 0 === e.defaultPrevented && !1 === e.returnValue)
              ? ke
              : Se),
          (this.target =
            e.target && 3 === e.target.nodeType
              ? e.target.parentNode
              : e.target),
          (this.currentTarget = e.currentTarget),
          (this.relatedTarget = e.relatedTarget))
        : (this.type = e),
        t && k.extend(this, t),
        (this.timeStamp = (e && e.timeStamp) || Date.now()),
        (this[k.expando] = !0);
    }),
    (k.Event.prototype = {
      constructor: k.Event,
      isDefaultPrevented: Se,
      isPropagationStopped: Se,
      isImmediatePropagationStopped: Se,
      isSimulated: !1,
      preventDefault: function () {
        var e = this.originalEvent;
        (this.isDefaultPrevented = ke),
          e && !this.isSimulated && e.preventDefault();
      },
      stopPropagation: function () {
        var e = this.originalEvent;
        (this.isPropagationStopped = ke),
          e && !this.isSimulated && e.stopPropagation();
      },
      stopImmediatePropagation: function () {
        var e = this.originalEvent;
        (this.isImmediatePropagationStopped = ke),
          e && !this.isSimulated && e.stopImmediatePropagation(),
          this.stopPropagation();
      },
    }),
    k.each(
      {
        altKey: !0,
        bubbles: !0,
        cancelable: !0,
        changedTouches: !0,
        ctrlKey: !0,
        detail: !0,
        eventPhase: !0,
        metaKey: !0,
        pageX: !0,
        pageY: !0,
        shiftKey: !0,
        view: !0,
        char: !0,
        code: !0,
        charCode: !0,
        key: !0,
        keyCode: !0,
        button: !0,
        buttons: !0,
        clientX: !0,
        clientY: !0,
        offsetX: !0,
        offsetY: !0,
        pointerId: !0,
        pointerType: !0,
        screenX: !0,
        screenY: !0,
        targetTouches: !0,
        toElement: !0,
        touches: !0,
        which: function (e) {
          var t = e.button;
          return null == e.which && Te.test(e.type)
            ? null != e.charCode
              ? e.charCode
              : e.keyCode
            : !e.which && void 0 !== t && Ce.test(e.type)
            ? 1 & t
              ? 1
              : 2 & t
              ? 3
              : 4 & t
              ? 2
              : 0
            : e.which;
        },
      },
      k.event.addProp
    ),
    k.each({ focus: "focusin", blur: "focusout" }, function (e, t) {
      k.event.special[e] = {
        setup: function () {
          return De(this, e, Ne), !1;
        },
        trigger: function () {
          return De(this, e), !0;
        },
        delegateType: t,
      };
    }),
    k.each(
      {
        mouseenter: "mouseover",
        mouseleave: "mouseout",
        pointerenter: "pointerover",
        pointerleave: "pointerout",
      },
      function (e, i) {
        k.event.special[e] = {
          delegateType: i,
          bindType: i,
          handle: function (e) {
            var t,
              n = e.relatedTarget,
              r = e.handleObj;
            return (
              (n && (n === this || k.contains(this, n))) ||
                ((e.type = r.origType),
                (t = r.handler.apply(this, arguments)),
                (e.type = i)),
              t
            );
          },
        };
      }
    ),
    k.fn.extend({
      on: function (e, t, n, r) {
        return Ae(this, e, t, n, r);
      },
      one: function (e, t, n, r) {
        return Ae(this, e, t, n, r, 1);
      },
      off: function (e, t, n) {
        var r, i;
        if (e && e.preventDefault && e.handleObj)
          return (
            (r = e.handleObj),
            k(e.delegateTarget).off(
              r.namespace ? r.origType + "." + r.namespace : r.origType,
              r.selector,
              r.handler
            ),
            this
          );
        if ("object" == typeof e) {
          for (i in e) this.off(i, t, e[i]);
          return this;
        }
        return (
          (!1 !== t && "function" != typeof t) || ((n = t), (t = void 0)),
          !1 === n && (n = Se),
          this.each(function () {
            k.event.remove(this, e, n, t);
          })
        );
      },
    });
  var je =
      /<(?!area|br|col|embed|hr|img|input|link|meta|param)(([a-z][^\/\0>\x20\t\r\n\f]*)[^>]*)\/>/gi,
    qe = /<script|<style|<link/i,
    Le = /checked\s*(?:[^=]|=\s*.checked.)/i,
    He = /^\s*<!(?:\[CDATA\[|--)|(?:\]\]|--)>\s*$/g;
  function Oe(e, t) {
    return (
      (A(e, "table") &&
        A(11 !== t.nodeType ? t : t.firstChild, "tr") &&
        k(e).children("tbody")[0]) ||
      e
    );
  }
  function Pe(e) {
    return (e.type = (null !== e.getAttribute("type")) + "/" + e.type), e;
  }
  function Re(e) {
    return (
      "true/" === (e.type || "").slice(0, 5)
        ? (e.type = e.type.slice(5))
        : e.removeAttribute("type"),
      e
    );
  }
  function Me(e, t) {
    var n, r, i, o, a, s, u, l;
    if (1 === t.nodeType) {
      if (
        Q.hasData(e) &&
        ((o = Q.access(e)), (a = Q.set(t, o)), (l = o.events))
      )
        for (i in (delete a.handle, (a.events = {}), l))
          for (n = 0, r = l[i].length; n < r; n++) k.event.add(t, i, l[i][n]);
      J.hasData(e) && ((s = J.access(e)), (u = k.extend({}, s)), J.set(t, u));
    }
  }
  function Ie(n, r, i, o) {
    r = g.apply([], r);
    var e,
      t,
      a,
      s,
      u,
      l,
      c = 0,
      f = n.length,
      p = f - 1,
      d = r[0],
      h = m(d);
    if (h || (1 < f && "string" == typeof d && !y.checkClone && Le.test(d)))
      return n.each(function (e) {
        var t = n.eq(e);
        h && (r[0] = d.call(this, e, t.html())), Ie(t, r, i, o);
      });
    if (
      f &&
      ((t = (e = we(r, n[0].ownerDocument, !1, n, o)).firstChild),
      1 === e.childNodes.length && (e = t),
      t || o)
    ) {
      for (s = (a = k.map(ve(e, "script"), Pe)).length; c < f; c++)
        (u = e),
          c !== p &&
            ((u = k.clone(u, !0, !0)), s && k.merge(a, ve(u, "script"))),
          i.call(n[c], u, c);
      if (s)
        for (l = a[a.length - 1].ownerDocument, k.map(a, Re), c = 0; c < s; c++)
          (u = a[c]),
            he.test(u.type || "") &&
              !Q.access(u, "globalEval") &&
              k.contains(l, u) &&
              (u.src && "module" !== (u.type || "").toLowerCase()
                ? k._evalUrl &&
                  !u.noModule &&
                  k._evalUrl(u.src, {
                    nonce: u.nonce || u.getAttribute("nonce"),
                  })
                : b(u.textContent.replace(He, ""), u, l));
    }
    return n;
  }
  function We(e, t, n) {
    for (var r, i = t ? k.filter(t, e) : e, o = 0; null != (r = i[o]); o++)
      n || 1 !== r.nodeType || k.cleanData(ve(r)),
        r.parentNode &&
          (n && oe(r) && ye(ve(r, "script")), r.parentNode.removeChild(r));
    return e;
  }
  k.extend({
    htmlPrefilter: function (e) {
      return e.replace(je, "<$1></$2>");
    },
    clone: function (e, t, n) {
      var r,
        i,
        o,
        a,
        s,
        u,
        l,
        c = e.cloneNode(!0),
        f = oe(e);
      if (
        !(
          y.noCloneChecked ||
          (1 !== e.nodeType && 11 !== e.nodeType) ||
          k.isXMLDoc(e)
        )
      )
        for (a = ve(c), r = 0, i = (o = ve(e)).length; r < i; r++)
          (s = o[r]),
            (u = a[r]),
            void 0,
            "input" === (l = u.nodeName.toLowerCase()) && pe.test(s.type)
              ? (u.checked = s.checked)
              : ("input" !== l && "textarea" !== l) ||
                (u.defaultValue = s.defaultValue);
      if (t)
        if (n)
          for (o = o || ve(e), a = a || ve(c), r = 0, i = o.length; r < i; r++)
            Me(o[r], a[r]);
        else Me(e, c);
      return (
        0 < (a = ve(c, "script")).length && ye(a, !f && ve(e, "script")), c
      );
    },
    cleanData: function (e) {
      for (var t, n, r, i = k.event.special, o = 0; void 0 !== (n = e[o]); o++)
        if (G(n)) {
          if ((t = n[Q.expando])) {
            if (t.events)
              for (r in t.events)
                i[r] ? k.event.remove(n, r) : k.removeEvent(n, r, t.handle);
            n[Q.expando] = void 0;
          }
          n[J.expando] && (n[J.expando] = void 0);
        }
    },
  }),
    k.fn.extend({
      detach: function (e) {
        return We(this, e, !0);
      },
      remove: function (e) {
        return We(this, e);
      },
      text: function (e) {
        return _(
          this,
          function (e) {
            return void 0 === e
              ? k.text(this)
              : this.empty().each(function () {
                  (1 !== this.nodeType &&
                    11 !== this.nodeType &&
                    9 !== this.nodeType) ||
                    (this.textContent = e);
                });
          },
          null,
          e,
          arguments.length
        );
      },
      append: function () {
        return Ie(this, arguments, function (e) {
          (1 !== this.nodeType &&
            11 !== this.nodeType &&
            9 !== this.nodeType) ||
            Oe(this, e).appendChild(e);
        });
      },
      prepend: function () {
        return Ie(this, arguments, function (e) {
          if (
            1 === this.nodeType ||
            11 === this.nodeType ||
            9 === this.nodeType
          ) {
            var t = Oe(this, e);
            t.insertBefore(e, t.firstChild);
          }
        });
      },
      before: function () {
        return Ie(this, arguments, function (e) {
          this.parentNode && this.parentNode.insertBefore(e, this);
        });
      },
      after: function () {
        return Ie(this, arguments, function (e) {
          this.parentNode && this.parentNode.insertBefore(e, this.nextSibling);
        });
      },
      empty: function () {
        for (var e, t = 0; null != (e = this[t]); t++)
          1 === e.nodeType && (k.cleanData(ve(e, !1)), (e.textContent = ""));
        return this;
      },
      clone: function (e, t) {
        return (
          (e = null != e && e),
          (t = null == t ? e : t),
          this.map(function () {
            return k.clone(this, e, t);
          })
        );
      },
      html: function (e) {
        return _(
          this,
          function (e) {
            var t = this[0] || {},
              n = 0,
              r = this.length;
            if (void 0 === e && 1 === t.nodeType) return t.innerHTML;
            if (
              "string" == typeof e &&
              !qe.test(e) &&
              !ge[(de.exec(e) || ["", ""])[1].toLowerCase()]
            ) {
              e = k.htmlPrefilter(e);
              try {
                for (; n < r; n++)
                  1 === (t = this[n] || {}).nodeType &&
                    (k.cleanData(ve(t, !1)), (t.innerHTML = e));
                t = 0;
              } catch (e) {}
            }
            t && this.empty().append(e);
          },
          null,
          e,
          arguments.length
        );
      },
      replaceWith: function () {
        var n = [];
        return Ie(
          this,
          arguments,
          function (e) {
            var t = this.parentNode;
            k.inArray(this, n) < 0 &&
              (k.cleanData(ve(this)), t && t.replaceChild(e, this));
          },
          n
        );
      },
    }),
    k.each(
      {
        appendTo: "append",
        prependTo: "prepend",
        insertBefore: "before",
        insertAfter: "after",
        replaceAll: "replaceWith",
      },
      function (e, a) {
        k.fn[e] = function (e) {
          for (var t, n = [], r = k(e), i = r.length - 1, o = 0; o <= i; o++)
            (t = o === i ? this : this.clone(!0)),
              k(r[o])[a](t),
              u.apply(n, t.get());
          return this.pushStack(n);
        };
      }
    );
  var $e = new RegExp("^(" + te + ")(?!px)[a-z%]+$", "i"),
    Fe = function (e) {
      var t = e.ownerDocument.defaultView;
      return (t && t.opener) || (t = C), t.getComputedStyle(e);
    },
    Be = new RegExp(re.join("|"), "i");
  function _e(e, t, n) {
    var r,
      i,
      o,
      a,
      s = e.style;
    return (
      (n = n || Fe(e)) &&
        ("" !== (a = n.getPropertyValue(t) || n[t]) ||
          oe(e) ||
          (a = k.style(e, t)),
        !y.pixelBoxStyles() &&
          $e.test(a) &&
          Be.test(t) &&
          ((r = s.width),
          (i = s.minWidth),
          (o = s.maxWidth),
          (s.minWidth = s.maxWidth = s.width = a),
          (a = n.width),
          (s.width = r),
          (s.minWidth = i),
          (s.maxWidth = o))),
      void 0 !== a ? a + "" : a
    );
  }
  function ze(e, t) {
    return {
      get: function () {
        if (!e()) return (this.get = t).apply(this, arguments);
        delete this.get;
      },
    };
  }
  !(function () {
    function e() {
      if (u) {
        (s.style.cssText =
          "position:absolute;left:-11111px;width:60px;margin-top:1px;padding:0;border:0"),
          (u.style.cssText =
            "position:relative;display:block;box-sizing:border-box;overflow:scroll;margin:auto;border:1px;padding:1px;width:60%;top:1%"),
          ie.appendChild(s).appendChild(u);
        var e = C.getComputedStyle(u);
        (n = "1%" !== e.top),
          (a = 12 === t(e.marginLeft)),
          (u.style.right = "60%"),
          (o = 36 === t(e.right)),
          (r = 36 === t(e.width)),
          (u.style.position = "absolute"),
          (i = 12 === t(u.offsetWidth / 3)),
          ie.removeChild(s),
          (u = null);
      }
    }
    function t(e) {
      return Math.round(parseFloat(e));
    }
    var n,
      r,
      i,
      o,
      a,
      s = E.createElement("div"),
      u = E.createElement("div");
    u.style &&
      ((u.style.backgroundClip = "content-box"),
      (u.cloneNode(!0).style.backgroundClip = ""),
      (y.clearCloneStyle = "content-box" === u.style.backgroundClip),
      k.extend(y, {
        boxSizingReliable: function () {
          return e(), r;
        },
        pixelBoxStyles: function () {
          return e(), o;
        },
        pixelPosition: function () {
          return e(), n;
        },
        reliableMarginLeft: function () {
          return e(), a;
        },
        scrollboxSize: function () {
          return e(), i;
        },
      }));
  })();
  var Ue = ["Webkit", "Moz", "ms"],
    Xe = E.createElement("div").style,
    Ve = {};
  function Ge(e) {
    var t = k.cssProps[e] || Ve[e];
    return (
      t ||
      (e in Xe
        ? e
        : (Ve[e] =
            (function (e) {
              var t = e[0].toUpperCase() + e.slice(1),
                n = Ue.length;
              while (n--) if ((e = Ue[n] + t) in Xe) return e;
            })(e) || e))
    );
  }
  var Ye = /^(none|table(?!-c[ea]).+)/,
    Qe = /^--/,
    Je = { position: "absolute", visibility: "hidden", display: "block" },
    Ke = { letterSpacing: "0", fontWeight: "400" };
  function Ze(e, t, n) {
    var r = ne.exec(t);
    return r ? Math.max(0, r[2] - (n || 0)) + (r[3] || "px") : t;
  }
  function et(e, t, n, r, i, o) {
    var a = "width" === t ? 1 : 0,
      s = 0,
      u = 0;
    if (n === (r ? "border" : "content")) return 0;
    for (; a < 4; a += 2)
      "margin" === n && (u += k.css(e, n + re[a], !0, i)),
        r
          ? ("content" === n && (u -= k.css(e, "padding" + re[a], !0, i)),
            "margin" !== n &&
              (u -= k.css(e, "border" + re[a] + "Width", !0, i)))
          : ((u += k.css(e, "padding" + re[a], !0, i)),
            "padding" !== n
              ? (u += k.css(e, "border" + re[a] + "Width", !0, i))
              : (s += k.css(e, "border" + re[a] + "Width", !0, i)));
    return (
      !r &&
        0 <= o &&
        (u +=
          Math.max(
            0,
            Math.ceil(
              e["offset" + t[0].toUpperCase() + t.slice(1)] - o - u - s - 0.5
            )
          ) || 0),
      u
    );
  }
  function tt(e, t, n) {
    var r = Fe(e),
      i =
        (!y.boxSizingReliable() || n) &&
        "border-box" === k.css(e, "boxSizing", !1, r),
      o = i,
      a = _e(e, t, r),
      s = "offset" + t[0].toUpperCase() + t.slice(1);
    if ($e.test(a)) {
      if (!n) return a;
      a = "auto";
    }
    return (
      ((!y.boxSizingReliable() && i) ||
        "auto" === a ||
        (!parseFloat(a) && "inline" === k.css(e, "display", !1, r))) &&
        e.getClientRects().length &&
        ((i = "border-box" === k.css(e, "boxSizing", !1, r)),
        (o = s in e) && (a = e[s])),
      (a = parseFloat(a) || 0) +
        et(e, t, n || (i ? "border" : "content"), o, r, a) +
        "px"
    );
  }
  function nt(e, t, n, r, i) {
    return new nt.prototype.init(e, t, n, r, i);
  }
  k.extend({
    cssHooks: {
      opacity: {
        get: function (e, t) {
          if (t) {
            var n = _e(e, "opacity");
            return "" === n ? "1" : n;
          }
        },
      },
    },
    cssNumber: {
      animationIterationCount: !0,
      columnCount: !0,
      fillOpacity: !0,
      flexGrow: !0,
      flexShrink: !0,
      fontWeight: !0,
      gridArea: !0,
      gridColumn: !0,
      gridColumnEnd: !0,
      gridColumnStart: !0,
      gridRow: !0,
      gridRowEnd: !0,
      gridRowStart: !0,
      lineHeight: !0,
      opacity: !0,
      order: !0,
      orphans: !0,
      widows: !0,
      zIndex: !0,
      zoom: !0,
    },
    cssProps: {},
    style: function (e, t, n, r) {
      if (e && 3 !== e.nodeType && 8 !== e.nodeType && e.style) {
        var i,
          o,
          a,
          s = V(t),
          u = Qe.test(t),
          l = e.style;
        if (
          (u || (t = Ge(s)), (a = k.cssHooks[t] || k.cssHooks[s]), void 0 === n)
        )
          return a && "get" in a && void 0 !== (i = a.get(e, !1, r)) ? i : l[t];
        "string" === (o = typeof n) &&
          (i = ne.exec(n)) &&
          i[1] &&
          ((n = le(e, t, i)), (o = "number")),
          null != n &&
            n == n &&
            ("number" !== o ||
              u ||
              (n += (i && i[3]) || (k.cssNumber[s] ? "" : "px")),
            y.clearCloneStyle ||
              "" !== n ||
              0 !== t.indexOf("background") ||
              (l[t] = "inherit"),
            (a && "set" in a && void 0 === (n = a.set(e, n, r))) ||
              (u ? l.setProperty(t, n) : (l[t] = n)));
      }
    },
    css: function (e, t, n, r) {
      var i,
        o,
        a,
        s = V(t);
      return (
        Qe.test(t) || (t = Ge(s)),
        (a = k.cssHooks[t] || k.cssHooks[s]) &&
          "get" in a &&
          (i = a.get(e, !0, n)),
        void 0 === i && (i = _e(e, t, r)),
        "normal" === i && t in Ke && (i = Ke[t]),
        "" === n || n
          ? ((o = parseFloat(i)), !0 === n || isFinite(o) ? o || 0 : i)
          : i
      );
    },
  }),
    k.each(["height", "width"], function (e, u) {
      k.cssHooks[u] = {
        get: function (e, t, n) {
          if (t)
            return !Ye.test(k.css(e, "display")) ||
              (e.getClientRects().length && e.getBoundingClientRect().width)
              ? tt(e, u, n)
              : ue(e, Je, function () {
                  return tt(e, u, n);
                });
        },
        set: function (e, t, n) {
          var r,
            i = Fe(e),
            o = !y.scrollboxSize() && "absolute" === i.position,
            a = (o || n) && "border-box" === k.css(e, "boxSizing", !1, i),
            s = n ? et(e, u, n, a, i) : 0;
          return (
            a &&
              o &&
              (s -= Math.ceil(
                e["offset" + u[0].toUpperCase() + u.slice(1)] -
                  parseFloat(i[u]) -
                  et(e, u, "border", !1, i) -
                  0.5
              )),
            s &&
              (r = ne.exec(t)) &&
              "px" !== (r[3] || "px") &&
              ((e.style[u] = t), (t = k.css(e, u))),
            Ze(0, t, s)
          );
        },
      };
    }),
    (k.cssHooks.marginLeft = ze(y.reliableMarginLeft, function (e, t) {
      if (t)
        return (
          (parseFloat(_e(e, "marginLeft")) ||
            e.getBoundingClientRect().left -
              ue(e, { marginLeft: 0 }, function () {
                return e.getBoundingClientRect().left;
              })) + "px"
        );
    })),
    k.each({ margin: "", padding: "", border: "Width" }, function (i, o) {
      (k.cssHooks[i + o] = {
        expand: function (e) {
          for (
            var t = 0, n = {}, r = "string" == typeof e ? e.split(" ") : [e];
            t < 4;
            t++
          )
            n[i + re[t] + o] = r[t] || r[t - 2] || r[0];
          return n;
        },
      }),
        "margin" !== i && (k.cssHooks[i + o].set = Ze);
    }),
    k.fn.extend({
      css: function (e, t) {
        return _(
          this,
          function (e, t, n) {
            var r,
              i,
              o = {},
              a = 0;
            if (Array.isArray(t)) {
              for (r = Fe(e), i = t.length; a < i; a++)
                o[t[a]] = k.css(e, t[a], !1, r);
              return o;
            }
            return void 0 !== n ? k.style(e, t, n) : k.css(e, t);
          },
          e,
          t,
          1 < arguments.length
        );
      },
    }),
    (((k.Tween = nt).prototype = {
      constructor: nt,
      init: function (e, t, n, r, i, o) {
        (this.elem = e),
          (this.prop = n),
          (this.easing = i || k.easing._default),
          (this.options = t),
          (this.start = this.now = this.cur()),
          (this.end = r),
          (this.unit = o || (k.cssNumber[n] ? "" : "px"));
      },
      cur: function () {
        var e = nt.propHooks[this.prop];
        return e && e.get ? e.get(this) : nt.propHooks._default.get(this);
      },
      run: function (e) {
        var t,
          n = nt.propHooks[this.prop];
        return (
          this.options.duration
            ? (this.pos = t =
                k.easing[this.easing](
                  e,
                  this.options.duration * e,
                  0,
                  1,
                  this.options.duration
                ))
            : (this.pos = t = e),
          (this.now = (this.end - this.start) * t + this.start),
          this.options.step &&
            this.options.step.call(this.elem, this.now, this),
          n && n.set ? n.set(this) : nt.propHooks._default.set(this),
          this
        );
      },
    }).init.prototype = nt.prototype),
    ((nt.propHooks = {
      _default: {
        get: function (e) {
          var t;
          return 1 !== e.elem.nodeType ||
            (null != e.elem[e.prop] && null == e.elem.style[e.prop])
            ? e.elem[e.prop]
            : (t = k.css(e.elem, e.prop, "")) && "auto" !== t
            ? t
            : 0;
        },
        set: function (e) {
          k.fx.step[e.prop]
            ? k.fx.step[e.prop](e)
            : 1 !== e.elem.nodeType ||
              (!k.cssHooks[e.prop] && null == e.elem.style[Ge(e.prop)])
            ? (e.elem[e.prop] = e.now)
            : k.style(e.elem, e.prop, e.now + e.unit);
        },
      },
    }).scrollTop = nt.propHooks.scrollLeft =
      {
        set: function (e) {
          e.elem.nodeType && e.elem.parentNode && (e.elem[e.prop] = e.now);
        },
      }),
    (k.easing = {
      linear: function (e) {
        return e;
      },
      swing: function (e) {
        return 0.5 - Math.cos(e * Math.PI) / 2;
      },
      _default: "swing",
    }),
    (k.fx = nt.prototype.init),
    (k.fx.step = {});
  var rt,
    it,
    ot,
    at,
    st = /^(?:toggle|show|hide)$/,
    ut = /queueHooks$/;
  function lt() {
    it &&
      (!1 === E.hidden && C.requestAnimationFrame
        ? C.requestAnimationFrame(lt)
        : C.setTimeout(lt, k.fx.interval),
      k.fx.tick());
  }
  function ct() {
    return (
      C.setTimeout(function () {
        rt = void 0;
      }),
      (rt = Date.now())
    );
  }
  function ft(e, t) {
    var n,
      r = 0,
      i = { height: e };
    for (t = t ? 1 : 0; r < 4; r += 2 - t)
      i["margin" + (n = re[r])] = i["padding" + n] = e;
    return t && (i.opacity = i.width = e), i;
  }
  function pt(e, t, n) {
    for (
      var r,
        i = (dt.tweeners[t] || []).concat(dt.tweeners["*"]),
        o = 0,
        a = i.length;
      o < a;
      o++
    )
      if ((r = i[o].call(n, t, e))) return r;
  }
  function dt(o, e, t) {
    var n,
      a,
      r = 0,
      i = dt.prefilters.length,
      s = k.Deferred().always(function () {
        delete u.elem;
      }),
      u = function () {
        if (a) return !1;
        for (
          var e = rt || ct(),
            t = Math.max(0, l.startTime + l.duration - e),
            n = 1 - (t / l.duration || 0),
            r = 0,
            i = l.tweens.length;
          r < i;
          r++
        )
          l.tweens[r].run(n);
        return (
          s.notifyWith(o, [l, n, t]),
          n < 1 && i
            ? t
            : (i || s.notifyWith(o, [l, 1, 0]), s.resolveWith(o, [l]), !1)
        );
      },
      l = s.promise({
        elem: o,
        props: k.extend({}, e),
        opts: k.extend(!0, { specialEasing: {}, easing: k.easing._default }, t),
        originalProperties: e,
        originalOptions: t,
        startTime: rt || ct(),
        duration: t.duration,
        tweens: [],
        createTween: function (e, t) {
          var n = k.Tween(
            o,
            l.opts,
            e,
            t,
            l.opts.specialEasing[e] || l.opts.easing
          );
          return l.tweens.push(n), n;
        },
        stop: function (e) {
          var t = 0,
            n = e ? l.tweens.length : 0;
          if (a) return this;
          for (a = !0; t < n; t++) l.tweens[t].run(1);
          return (
            e
              ? (s.notifyWith(o, [l, 1, 0]), s.resolveWith(o, [l, e]))
              : s.rejectWith(o, [l, e]),
            this
          );
        },
      }),
      c = l.props;
    for (
      !(function (e, t) {
        var n, r, i, o, a;
        for (n in e)
          if (
            ((i = t[(r = V(n))]),
            (o = e[n]),
            Array.isArray(o) && ((i = o[1]), (o = e[n] = o[0])),
            n !== r && ((e[r] = o), delete e[n]),
            (a = k.cssHooks[r]) && ("expand" in a))
          )
            for (n in ((o = a.expand(o)), delete e[r], o))
              (n in e) || ((e[n] = o[n]), (t[n] = i));
          else t[r] = i;
      })(c, l.opts.specialEasing);
      r < i;
      r++
    )
      if ((n = dt.prefilters[r].call(l, o, c, l.opts)))
        return (
          m(n.stop) &&
            (k._queueHooks(l.elem, l.opts.queue).stop = n.stop.bind(n)),
          n
        );
    return (
      k.map(c, pt, l),
      m(l.opts.start) && l.opts.start.call(o, l),
      l
        .progress(l.opts.progress)
        .done(l.opts.done, l.opts.complete)
        .fail(l.opts.fail)
        .always(l.opts.always),
      k.fx.timer(k.extend(u, { elem: o, anim: l, queue: l.opts.queue })),
      l
    );
  }
  (k.Animation = k.extend(dt, {
    tweeners: {
      "*": [
        function (e, t) {
          var n = this.createTween(e, t);
          return le(n.elem, e, ne.exec(t), n), n;
        },
      ],
    },
    tweener: function (e, t) {
      m(e) ? ((t = e), (e = ["*"])) : (e = e.match(R));
      for (var n, r = 0, i = e.length; r < i; r++)
        (n = e[r]),
          (dt.tweeners[n] = dt.tweeners[n] || []),
          dt.tweeners[n].unshift(t);
    },
    prefilters: [
      function (e, t, n) {
        var r,
          i,
          o,
          a,
          s,
          u,
          l,
          c,
          f = "width" in t || "height" in t,
          p = this,
          d = {},
          h = e.style,
          g = e.nodeType && se(e),
          v = Q.get(e, "fxshow");
        for (r in (n.queue ||
          (null == (a = k._queueHooks(e, "fx")).unqueued &&
            ((a.unqueued = 0),
            (s = a.empty.fire),
            (a.empty.fire = function () {
              a.unqueued || s();
            })),
          a.unqueued++,
          p.always(function () {
            p.always(function () {
              a.unqueued--, k.queue(e, "fx").length || a.empty.fire();
            });
          })),
        t))
          if (((i = t[r]), st.test(i))) {
            if (
              (delete t[r],
              (o = o || "toggle" === i),
              i === (g ? "hide" : "show"))
            ) {
              if ("show" !== i || !v || void 0 === v[r]) continue;
              g = !0;
            }
            d[r] = (v && v[r]) || k.style(e, r);
          }
        if ((u = !k.isEmptyObject(t)) || !k.isEmptyObject(d))
          for (r in (f &&
            1 === e.nodeType &&
            ((n.overflow = [h.overflow, h.overflowX, h.overflowY]),
            null == (l = v && v.display) && (l = Q.get(e, "display")),
            "none" === (c = k.css(e, "display")) &&
              (l
                ? (c = l)
                : (fe([e], !0),
                  (l = e.style.display || l),
                  (c = k.css(e, "display")),
                  fe([e]))),
            ("inline" === c || ("inline-block" === c && null != l)) &&
              "none" === k.css(e, "float") &&
              (u ||
                (p.done(function () {
                  h.display = l;
                }),
                null == l && ((c = h.display), (l = "none" === c ? "" : c))),
              (h.display = "inline-block"))),
          n.overflow &&
            ((h.overflow = "hidden"),
            p.always(function () {
              (h.overflow = n.overflow[0]),
                (h.overflowX = n.overflow[1]),
                (h.overflowY = n.overflow[2]);
            })),
          (u = !1),
          d))
            u ||
              (v
                ? "hidden" in v && (g = v.hidden)
                : (v = Q.access(e, "fxshow", { display: l })),
              o && (v.hidden = !g),
              g && fe([e], !0),
              p.done(function () {
                for (r in (g || fe([e]), Q.remove(e, "fxshow"), d))
                  k.style(e, r, d[r]);
              })),
              (u = pt(g ? v[r] : 0, r, p)),
              r in v ||
                ((v[r] = u.start), g && ((u.end = u.start), (u.start = 0)));
      },
    ],
    prefilter: function (e, t) {
      t ? dt.prefilters.unshift(e) : dt.prefilters.push(e);
    },
  })),
    (k.speed = function (e, t, n) {
      var r =
        e && "object" == typeof e
          ? k.extend({}, e)
          : {
              complete: n || (!n && t) || (m(e) && e),
              duration: e,
              easing: (n && t) || (t && !m(t) && t),
            };
      return (
        k.fx.off
          ? (r.duration = 0)
          : "number" != typeof r.duration &&
            (r.duration in k.fx.speeds
              ? (r.duration = k.fx.speeds[r.duration])
              : (r.duration = k.fx.speeds._default)),
        (null != r.queue && !0 !== r.queue) || (r.queue = "fx"),
        (r.old = r.complete),
        (r.complete = function () {
          m(r.old) && r.old.call(this), r.queue && k.dequeue(this, r.queue);
        }),
        r
      );
    }),
    k.fn.extend({
      fadeTo: function (e, t, n, r) {
        return this.filter(se)
          .css("opacity", 0)
          .show()
          .end()
          .animate({ opacity: t }, e, n, r);
      },
      animate: function (t, e, n, r) {
        var i = k.isEmptyObject(t),
          o = k.speed(e, n, r),
          a = function () {
            var e = dt(this, k.extend({}, t), o);
            (i || Q.get(this, "finish")) && e.stop(!0);
          };
        return (
          (a.finish = a),
          i || !1 === o.queue ? this.each(a) : this.queue(o.queue, a)
        );
      },
      stop: function (i, e, o) {
        var a = function (e) {
          var t = e.stop;
          delete e.stop, t(o);
        };
        return (
          "string" != typeof i && ((o = e), (e = i), (i = void 0)),
          e && !1 !== i && this.queue(i || "fx", []),
          this.each(function () {
            var e = !0,
              t = null != i && i + "queueHooks",
              n = k.timers,
              r = Q.get(this);
            if (t) r[t] && r[t].stop && a(r[t]);
            else for (t in r) r[t] && r[t].stop && ut.test(t) && a(r[t]);
            for (t = n.length; t--; )
              n[t].elem !== this ||
                (null != i && n[t].queue !== i) ||
                (n[t].anim.stop(o), (e = !1), n.splice(t, 1));
            (!e && o) || k.dequeue(this, i);
          })
        );
      },
      finish: function (a) {
        return (
          !1 !== a && (a = a || "fx"),
          this.each(function () {
            var e,
              t = Q.get(this),
              n = t[a + "queue"],
              r = t[a + "queueHooks"],
              i = k.timers,
              o = n ? n.length : 0;
            for (
              t.finish = !0,
                k.queue(this, a, []),
                r && r.stop && r.stop.call(this, !0),
                e = i.length;
              e--;

            )
              i[e].elem === this &&
                i[e].queue === a &&
                (i[e].anim.stop(!0), i.splice(e, 1));
            for (e = 0; e < o; e++)
              n[e] && n[e].finish && n[e].finish.call(this);
            delete t.finish;
          })
        );
      },
    }),
    k.each(["toggle", "show", "hide"], function (e, r) {
      var i = k.fn[r];
      k.fn[r] = function (e, t, n) {
        return null == e || "boolean" == typeof e
          ? i.apply(this, arguments)
          : this.animate(ft(r, !0), e, t, n);
      };
    }),
    k.each(
      {
        slideDown: ft("show"),
        slideUp: ft("hide"),
        slideToggle: ft("toggle"),
        fadeIn: { opacity: "show" },
        fadeOut: { opacity: "hide" },
        fadeToggle: { opacity: "toggle" },
      },
      function (e, r) {
        k.fn[e] = function (e, t, n) {
          return this.animate(r, e, t, n);
        };
      }
    ),
    (k.timers = []),
    (k.fx.tick = function () {
      var e,
        t = 0,
        n = k.timers;
      for (rt = Date.now(); t < n.length; t++)
        (e = n[t])() || n[t] !== e || n.splice(t--, 1);
      n.length || k.fx.stop(), (rt = void 0);
    }),
    (k.fx.timer = function (e) {
      k.timers.push(e), k.fx.start();
    }),
    (k.fx.interval = 13),
    (k.fx.start = function () {
      it || ((it = !0), lt());
    }),
    (k.fx.stop = function () {
      it = null;
    }),
    (k.fx.speeds = { slow: 600, fast: 200, _default: 400 }),
    (k.fn.delay = function (r, e) {
      return (
        (r = (k.fx && k.fx.speeds[r]) || r),
        (e = e || "fx"),
        this.queue(e, function (e, t) {
          var n = C.setTimeout(e, r);
          t.stop = function () {
            C.clearTimeout(n);
          };
        })
      );
    }),
    (ot = E.createElement("input")),
    (at = E.createElement("select").appendChild(E.createElement("option"))),
    (ot.type = "checkbox"),
    (y.checkOn = "" !== ot.value),
    (y.optSelected = at.selected),
    ((ot = E.createElement("input")).value = "t"),
    (ot.type = "radio"),
    (y.radioValue = "t" === ot.value);
  var ht,
    gt = k.expr.attrHandle;
  k.fn.extend({
    attr: function (e, t) {
      return _(this, k.attr, e, t, 1 < arguments.length);
    },
    removeAttr: function (e) {
      return this.each(function () {
        k.removeAttr(this, e);
      });
    },
  }),
    k.extend({
      attr: function (e, t, n) {
        var r,
          i,
          o = e.nodeType;
        if (3 !== o && 8 !== o && 2 !== o)
          return "undefined" == typeof e.getAttribute
            ? k.prop(e, t, n)
            : ((1 === o && k.isXMLDoc(e)) ||
                (i =
                  k.attrHooks[t.toLowerCase()] ||
                  (k.expr.match.bool.test(t) ? ht : void 0)),
              void 0 !== n
                ? null === n
                  ? void k.removeAttr(e, t)
                  : i && "set" in i && void 0 !== (r = i.set(e, n, t))
                  ? r
                  : (e.setAttribute(t, n + ""), n)
                : i && "get" in i && null !== (r = i.get(e, t))
                ? r
                : null == (r = k.find.attr(e, t))
                ? void 0
                : r);
      },
      attrHooks: {
        type: {
          set: function (e, t) {
            if (!y.radioValue && "radio" === t && A(e, "input")) {
              var n = e.value;
              return e.setAttribute("type", t), n && (e.value = n), t;
            }
          },
        },
      },
      removeAttr: function (e, t) {
        var n,
          r = 0,
          i = t && t.match(R);
        if (i && 1 === e.nodeType) while ((n = i[r++])) e.removeAttribute(n);
      },
    }),
    (ht = {
      set: function (e, t, n) {
        return !1 === t ? k.removeAttr(e, n) : e.setAttribute(n, n), n;
      },
    }),
    k.each(k.expr.match.bool.source.match(/\w+/g), function (e, t) {
      var a = gt[t] || k.find.attr;
      gt[t] = function (e, t, n) {
        var r,
          i,
          o = t.toLowerCase();
        return (
          n ||
            ((i = gt[o]),
            (gt[o] = r),
            (r = null != a(e, t, n) ? o : null),
            (gt[o] = i)),
          r
        );
      };
    });
  var vt = /^(?:input|select|textarea|button)$/i,
    yt = /^(?:a|area)$/i;
  function mt(e) {
    return (e.match(R) || []).join(" ");
  }
  function xt(e) {
    return (e.getAttribute && e.getAttribute("class")) || "";
  }
  function bt(e) {
    return Array.isArray(e) ? e : ("string" == typeof e && e.match(R)) || [];
  }
  k.fn.extend({
    prop: function (e, t) {
      return _(this, k.prop, e, t, 1 < arguments.length);
    },
    removeProp: function (e) {
      return this.each(function () {
        delete this[k.propFix[e] || e];
      });
    },
  }),
    k.extend({
      prop: function (e, t, n) {
        var r,
          i,
          o = e.nodeType;
        if (3 !== o && 8 !== o && 2 !== o)
          return (
            (1 === o && k.isXMLDoc(e)) ||
              ((t = k.propFix[t] || t), (i = k.propHooks[t])),
            void 0 !== n
              ? i && "set" in i && void 0 !== (r = i.set(e, n, t))
                ? r
                : (e[t] = n)
              : i && "get" in i && null !== (r = i.get(e, t))
              ? r
              : e[t]
          );
      },
      propHooks: {
        tabIndex: {
          get: function (e) {
            var t = k.find.attr(e, "tabindex");
            return t
              ? parseInt(t, 10)
              : vt.test(e.nodeName) || (yt.test(e.nodeName) && e.href)
              ? 0
              : -1;
          },
        },
      },
      propFix: { for: "htmlFor", class: "className" },
    }),
    y.optSelected ||
      (k.propHooks.selected = {
        get: function (e) {
          var t = e.parentNode;
          return t && t.parentNode && t.parentNode.selectedIndex, null;
        },
        set: function (e) {
          var t = e.parentNode;
          t && (t.selectedIndex, t.parentNode && t.parentNode.selectedIndex);
        },
      }),
    k.each(
      [
        "tabIndex",
        "readOnly",
        "maxLength",
        "cellSpacing",
        "cellPadding",
        "rowSpan",
        "colSpan",
        "useMap",
        "frameBorder",
        "contentEditable",
      ],
      function () {
        k.propFix[this.toLowerCase()] = this;
      }
    ),
    k.fn.extend({
      addClass: function (t) {
        var e,
          n,
          r,
          i,
          o,
          a,
          s,
          u = 0;
        if (m(t))
          return this.each(function (e) {
            k(this).addClass(t.call(this, e, xt(this)));
          });
        if ((e = bt(t)).length)
          while ((n = this[u++]))
            if (((i = xt(n)), (r = 1 === n.nodeType && " " + mt(i) + " "))) {
              a = 0;
              while ((o = e[a++]))
                r.indexOf(" " + o + " ") < 0 && (r += o + " ");
              i !== (s = mt(r)) && n.setAttribute("class", s);
            }
        return this;
      },
      removeClass: function (t) {
        var e,
          n,
          r,
          i,
          o,
          a,
          s,
          u = 0;
        if (m(t))
          return this.each(function (e) {
            k(this).removeClass(t.call(this, e, xt(this)));
          });
        if (!arguments.length) return this.attr("class", "");
        if ((e = bt(t)).length)
          while ((n = this[u++]))
            if (((i = xt(n)), (r = 1 === n.nodeType && " " + mt(i) + " "))) {
              a = 0;
              while ((o = e[a++]))
                while (-1 < r.indexOf(" " + o + " "))
                  r = r.replace(" " + o + " ", " ");
              i !== (s = mt(r)) && n.setAttribute("class", s);
            }
        return this;
      },
      toggleClass: function (i, t) {
        var o = typeof i,
          a = "string" === o || Array.isArray(i);
        return "boolean" == typeof t && a
          ? t
            ? this.addClass(i)
            : this.removeClass(i)
          : m(i)
          ? this.each(function (e) {
              k(this).toggleClass(i.call(this, e, xt(this), t), t);
            })
          : this.each(function () {
              var e, t, n, r;
              if (a) {
                (t = 0), (n = k(this)), (r = bt(i));
                while ((e = r[t++]))
                  n.hasClass(e) ? n.removeClass(e) : n.addClass(e);
              } else (void 0 !== i && "boolean" !== o) || ((e = xt(this)) && Q.set(this, "__className__", e), this.setAttribute && this.setAttribute("class", e || !1 === i ? "" : Q.get(this, "__className__") || ""));
            });
      },
      hasClass: function (e) {
        var t,
          n,
          r = 0;
        t = " " + e + " ";
        while ((n = this[r++]))
          if (1 === n.nodeType && -1 < (" " + mt(xt(n)) + " ").indexOf(t))
            return !0;
        return !1;
      },
    });
  var wt = /\r/g;
  k.fn.extend({
    val: function (n) {
      var r,
        e,
        i,
        t = this[0];
      return arguments.length
        ? ((i = m(n)),
          this.each(function (e) {
            var t;
            1 === this.nodeType &&
              (null == (t = i ? n.call(this, e, k(this).val()) : n)
                ? (t = "")
                : "number" == typeof t
                ? (t += "")
                : Array.isArray(t) &&
                  (t = k.map(t, function (e) {
                    return null == e ? "" : e + "";
                  })),
              ((r =
                k.valHooks[this.type] ||
                k.valHooks[this.nodeName.toLowerCase()]) &&
                "set" in r &&
                void 0 !== r.set(this, t, "value")) ||
                (this.value = t));
          }))
        : t
        ? (r = k.valHooks[t.type] || k.valHooks[t.nodeName.toLowerCase()]) &&
          "get" in r &&
          void 0 !== (e = r.get(t, "value"))
          ? e
          : "string" == typeof (e = t.value)
          ? e.replace(wt, "")
          : null == e
          ? ""
          : e
        : void 0;
    },
  }),
    k.extend({
      valHooks: {
        option: {
          get: function (e) {
            var t = k.find.attr(e, "value");
            return null != t ? t : mt(k.text(e));
          },
        },
        select: {
          get: function (e) {
            var t,
              n,
              r,
              i = e.options,
              o = e.selectedIndex,
              a = "select-one" === e.type,
              s = a ? null : [],
              u = a ? o + 1 : i.length;
            for (r = o < 0 ? u : a ? o : 0; r < u; r++)
              if (
                ((n = i[r]).selected || r === o) &&
                !n.disabled &&
                (!n.parentNode.disabled || !A(n.parentNode, "optgroup"))
              ) {
                if (((t = k(n).val()), a)) return t;
                s.push(t);
              }
            return s;
          },
          set: function (e, t) {
            var n,
              r,
              i = e.options,
              o = k.makeArray(t),
              a = i.length;
            while (a--)
              ((r = i[a]).selected =
                -1 < k.inArray(k.valHooks.option.get(r), o)) && (n = !0);
            return n || (e.selectedIndex = -1), o;
          },
        },
      },
    }),
    k.each(["radio", "checkbox"], function () {
      (k.valHooks[this] = {
        set: function (e, t) {
          if (Array.isArray(t))
            return (e.checked = -1 < k.inArray(k(e).val(), t));
        },
      }),
        y.checkOn ||
          (k.valHooks[this].get = function (e) {
            return null === e.getAttribute("value") ? "on" : e.value;
          });
    }),
    (y.focusin = "onfocusin" in C);
  var Tt = /^(?:focusinfocus|focusoutblur)$/,
    Ct = function (e) {
      e.stopPropagation();
    };
  k.extend(k.event, {
    trigger: function (e, t, n, r) {
      var i,
        o,
        a,
        s,
        u,
        l,
        c,
        f,
        p = [n || E],
        d = v.call(e, "type") ? e.type : e,
        h = v.call(e, "namespace") ? e.namespace.split(".") : [];
      if (
        ((o = f = a = n = n || E),
        3 !== n.nodeType &&
          8 !== n.nodeType &&
          !Tt.test(d + k.event.triggered) &&
          (-1 < d.indexOf(".") && ((d = (h = d.split(".")).shift()), h.sort()),
          (u = d.indexOf(":") < 0 && "on" + d),
          ((e = e[k.expando]
            ? e
            : new k.Event(d, "object" == typeof e && e)).isTrigger = r ? 2 : 3),
          (e.namespace = h.join(".")),
          (e.rnamespace = e.namespace
            ? new RegExp("(^|\\.)" + h.join("\\.(?:.*\\.|)") + "(\\.|$)")
            : null),
          (e.result = void 0),
          e.target || (e.target = n),
          (t = null == t ? [e] : k.makeArray(t, [e])),
          (c = k.event.special[d] || {}),
          r || !c.trigger || !1 !== c.trigger.apply(n, t)))
      ) {
        if (!r && !c.noBubble && !x(n)) {
          for (
            s = c.delegateType || d, Tt.test(s + d) || (o = o.parentNode);
            o;
            o = o.parentNode
          )
            p.push(o), (a = o);
          a === (n.ownerDocument || E) &&
            p.push(a.defaultView || a.parentWindow || C);
        }
        i = 0;
        while ((o = p[i++]) && !e.isPropagationStopped())
          (f = o),
            (e.type = 1 < i ? s : c.bindType || d),
            (l = (Q.get(o, "events") || {})[e.type] && Q.get(o, "handle")) &&
              l.apply(o, t),
            (l = u && o[u]) &&
              l.apply &&
              G(o) &&
              ((e.result = l.apply(o, t)),
              !1 === e.result && e.preventDefault());
        return (
          (e.type = d),
          r ||
            e.isDefaultPrevented() ||
            (c._default && !1 !== c._default.apply(p.pop(), t)) ||
            !G(n) ||
            (u &&
              m(n[d]) &&
              !x(n) &&
              ((a = n[u]) && (n[u] = null),
              (k.event.triggered = d),
              e.isPropagationStopped() && f.addEventListener(d, Ct),
              n[d](),
              e.isPropagationStopped() && f.removeEventListener(d, Ct),
              (k.event.triggered = void 0),
              a && (n[u] = a))),
          e.result
        );
      }
    },
    simulate: function (e, t, n) {
      var r = k.extend(new k.Event(), n, { type: e, isSimulated: !0 });
      k.event.trigger(r, null, t);
    },
  }),
    k.fn.extend({
      trigger: function (e, t) {
        return this.each(function () {
          k.event.trigger(e, t, this);
        });
      },
      triggerHandler: function (e, t) {
        var n = this[0];
        if (n) return k.event.trigger(e, t, n, !0);
      },
    }),
    y.focusin ||
      k.each({ focus: "focusin", blur: "focusout" }, function (n, r) {
        var i = function (e) {
          k.event.simulate(r, e.target, k.event.fix(e));
        };
        k.event.special[r] = {
          setup: function () {
            var e = this.ownerDocument || this,
              t = Q.access(e, r);
            t || e.addEventListener(n, i, !0), Q.access(e, r, (t || 0) + 1);
          },
          teardown: function () {
            var e = this.ownerDocument || this,
              t = Q.access(e, r) - 1;
            t
              ? Q.access(e, r, t)
              : (e.removeEventListener(n, i, !0), Q.remove(e, r));
          },
        };
      });
  var Et = C.location,
    kt = Date.now(),
    St = /\?/;
  k.parseXML = function (e) {
    var t;
    if (!e || "string" != typeof e) return null;
    try {
      t = new C.DOMParser().parseFromString(e, "text/xml");
    } catch (e) {
      t = void 0;
    }
    return (
      (t && !t.getElementsByTagName("parsererror").length) ||
        k.error("Invalid XML: " + e),
      t
    );
  };
  var Nt = /\[\]$/,
    At = /\r?\n/g,
    Dt = /^(?:submit|button|image|reset|file)$/i,
    jt = /^(?:input|select|textarea|keygen)/i;
  function qt(n, e, r, i) {
    var t;
    if (Array.isArray(e))
      k.each(e, function (e, t) {
        r || Nt.test(n)
          ? i(n, t)
          : qt(
              n + "[" + ("object" == typeof t && null != t ? e : "") + "]",
              t,
              r,
              i
            );
      });
    else if (r || "object" !== w(e)) i(n, e);
    else for (t in e) qt(n + "[" + t + "]", e[t], r, i);
  }
  (k.param = function (e, t) {
    var n,
      r = [],
      i = function (e, t) {
        var n = m(t) ? t() : t;
        r[r.length] =
          encodeURIComponent(e) + "=" + encodeURIComponent(null == n ? "" : n);
      };
    if (null == e) return "";
    if (Array.isArray(e) || (e.jquery && !k.isPlainObject(e)))
      k.each(e, function () {
        i(this.name, this.value);
      });
    else for (n in e) qt(n, e[n], t, i);
    return r.join("&");
  }),
    k.fn.extend({
      serialize: function () {
        return k.param(this.serializeArray());
      },
      serializeArray: function () {
        return this.map(function () {
          var e = k.prop(this, "elements");
          return e ? k.makeArray(e) : this;
        })
          .filter(function () {
            var e = this.type;
            return (
              this.name &&
              !k(this).is(":disabled") &&
              jt.test(this.nodeName) &&
              !Dt.test(e) &&
              (this.checked || !pe.test(e))
            );
          })
          .map(function (e, t) {
            var n = k(this).val();
            return null == n
              ? null
              : Array.isArray(n)
              ? k.map(n, function (e) {
                  return { name: t.name, value: e.replace(At, "\r\n") };
                })
              : { name: t.name, value: n.replace(At, "\r\n") };
          })
          .get();
      },
    });
  var Lt = /%20/g,
    Ht = /#.*$/,
    Ot = /([?&])_=[^&]*/,
    Pt = /^(.*?):[ \t]*([^\r\n]*)$/gm,
    Rt = /^(?:GET|HEAD)$/,
    Mt = /^\/\//,
    It = {},
    Wt = {},
    $t = "*/".concat("*"),
    Ft = E.createElement("a");
  function Bt(o) {
    return function (e, t) {
      "string" != typeof e && ((t = e), (e = "*"));
      var n,
        r = 0,
        i = e.toLowerCase().match(R) || [];
      if (m(t))
        while ((n = i[r++]))
          "+" === n[0]
            ? ((n = n.slice(1) || "*"), (o[n] = o[n] || []).unshift(t))
            : (o[n] = o[n] || []).push(t);
    };
  }
  function _t(t, i, o, a) {
    var s = {},
      u = t === Wt;
    function l(e) {
      var r;
      return (
        (s[e] = !0),
        k.each(t[e] || [], function (e, t) {
          var n = t(i, o, a);
          return "string" != typeof n || u || s[n]
            ? u
              ? !(r = n)
              : void 0
            : (i.dataTypes.unshift(n), l(n), !1);
        }),
        r
      );
    }
    return l(i.dataTypes[0]) || (!s["*"] && l("*"));
  }
  function zt(e, t) {
    var n,
      r,
      i = k.ajaxSettings.flatOptions || {};
    for (n in t) void 0 !== t[n] && ((i[n] ? e : r || (r = {}))[n] = t[n]);
    return r && k.extend(!0, e, r), e;
  }
  (Ft.href = Et.href),
    k.extend({
      active: 0,
      lastModified: {},
      etag: {},
      ajaxSettings: {
        url: Et.href,
        type: "GET",
        isLocal:
          /^(?:about|app|app-storage|.+-extension|file|res|widget):$/.test(
            Et.protocol
          ),
        global: !0,
        processData: !0,
        async: !0,
        contentType: "application/x-www-form-urlencoded; charset=UTF-8",
        accepts: {
          "*": $t,
          text: "text/plain",
          html: "text/html",
          xml: "application/xml, text/xml",
          json: "application/json, text/javascript",
        },
        contents: { xml: /\bxml\b/, html: /\bhtml/, json: /\bjson\b/ },
        responseFields: {
          xml: "responseXML",
          text: "responseText",
          json: "responseJSON",
        },
        converters: {
          "* text": String,
          "text html": !0,
          "text json": JSON.parse,
          "text xml": k.parseXML,
        },
        flatOptions: { url: !0, context: !0 },
      },
      ajaxSetup: function (e, t) {
        return t ? zt(zt(e, k.ajaxSettings), t) : zt(k.ajaxSettings, e);
      },
      ajaxPrefilter: Bt(It),
      ajaxTransport: Bt(Wt),
      ajax: function (e, t) {
        "object" == typeof e && ((t = e), (e = void 0)), (t = t || {});
        var c,
          f,
          p,
          n,
          d,
          r,
          h,
          g,
          i,
          o,
          v = k.ajaxSetup({}, t),
          y = v.context || v,
          m = v.context && (y.nodeType || y.jquery) ? k(y) : k.event,
          x = k.Deferred(),
          b = k.Callbacks("once memory"),
          w = v.statusCode || {},
          a = {},
          s = {},
          u = "canceled",
          T = {
            readyState: 0,
            getResponseHeader: function (e) {
              var t;
              if (h) {
                if (!n) {
                  n = {};
                  while ((t = Pt.exec(p)))
                    n[t[1].toLowerCase() + " "] = (
                      n[t[1].toLowerCase() + " "] || []
                    ).concat(t[2]);
                }
                t = n[e.toLowerCase() + " "];
              }
              return null == t ? null : t.join(", ");
            },
            getAllResponseHeaders: function () {
              return h ? p : null;
            },
            setRequestHeader: function (e, t) {
              return (
                null == h &&
                  ((e = s[e.toLowerCase()] = s[e.toLowerCase()] || e),
                  (a[e] = t)),
                this
              );
            },
            overrideMimeType: function (e) {
              return null == h && (v.mimeType = e), this;
            },
            statusCode: function (e) {
              var t;
              if (e)
                if (h) T.always(e[T.status]);
                else for (t in e) w[t] = [w[t], e[t]];
              return this;
            },
            abort: function (e) {
              var t = e || u;
              return c && c.abort(t), l(0, t), this;
            },
          };
        if (
          (x.promise(T),
          (v.url = ((e || v.url || Et.href) + "").replace(
            Mt,
            Et.protocol + "//"
          )),
          (v.type = t.method || t.type || v.method || v.type),
          (v.dataTypes = (v.dataType || "*").toLowerCase().match(R) || [""]),
          null == v.crossDomain)
        ) {
          r = E.createElement("a");
          try {
            (r.href = v.url),
              (r.href = r.href),
              (v.crossDomain =
                Ft.protocol + "//" + Ft.host != r.protocol + "//" + r.host);
          } catch (e) {
            v.crossDomain = !0;
          }
        }
        if (
          (v.data &&
            v.processData &&
            "string" != typeof v.data &&
            (v.data = k.param(v.data, v.traditional)),
          _t(It, v, t, T),
          h)
        )
          return T;
        for (i in ((g = k.event && v.global) &&
          0 == k.active++ &&
          k.event.trigger("ajaxStart"),
        (v.type = v.type.toUpperCase()),
        (v.hasContent = !Rt.test(v.type)),
        (f = v.url.replace(Ht, "")),
        v.hasContent
          ? v.data &&
            v.processData &&
            0 ===
              (v.contentType || "").indexOf(
                "application/x-www-form-urlencoded"
              ) &&
            (v.data = v.data.replace(Lt, "+"))
          : ((o = v.url.slice(f.length)),
            v.data &&
              (v.processData || "string" == typeof v.data) &&
              ((f += (St.test(f) ? "&" : "?") + v.data), delete v.data),
            !1 === v.cache &&
              ((f = f.replace(Ot, "$1")),
              (o = (St.test(f) ? "&" : "?") + "_=" + kt++ + o)),
            (v.url = f + o)),
        v.ifModified &&
          (k.lastModified[f] &&
            T.setRequestHeader("If-Modified-Since", k.lastModified[f]),
          k.etag[f] && T.setRequestHeader("If-None-Match", k.etag[f])),
        ((v.data && v.hasContent && !1 !== v.contentType) || t.contentType) &&
          T.setRequestHeader("Content-Type", v.contentType),
        T.setRequestHeader(
          "Accept",
          v.dataTypes[0] && v.accepts[v.dataTypes[0]]
            ? v.accepts[v.dataTypes[0]] +
                ("*" !== v.dataTypes[0] ? ", " + $t + "; q=0.01" : "")
            : v.accepts["*"]
        ),
        v.headers))
          T.setRequestHeader(i, v.headers[i]);
        if (v.beforeSend && (!1 === v.beforeSend.call(y, T, v) || h))
          return T.abort();
        if (
          ((u = "abort"),
          b.add(v.complete),
          T.done(v.success),
          T.fail(v.error),
          (c = _t(Wt, v, t, T)))
        ) {
          if (((T.readyState = 1), g && m.trigger("ajaxSend", [T, v]), h))
            return T;
          v.async &&
            0 < v.timeout &&
            (d = C.setTimeout(function () {
              T.abort("timeout");
            }, v.timeout));
          try {
            (h = !1), c.send(a, l);
          } catch (e) {
            if (h) throw e;
            l(-1, e);
          }
        } else l(-1, "No Transport");
        function l(e, t, n, r) {
          var i,
            o,
            a,
            s,
            u,
            l = t;
          h ||
            ((h = !0),
            d && C.clearTimeout(d),
            (c = void 0),
            (p = r || ""),
            (T.readyState = 0 < e ? 4 : 0),
            (i = (200 <= e && e < 300) || 304 === e),
            n &&
              (s = (function (e, t, n) {
                var r,
                  i,
                  o,
                  a,
                  s = e.contents,
                  u = e.dataTypes;
                while ("*" === u[0])
                  u.shift(),
                    void 0 === r &&
                      (r = e.mimeType || t.getResponseHeader("Content-Type"));
                if (r)
                  for (i in s)
                    if (s[i] && s[i].test(r)) {
                      u.unshift(i);
                      break;
                    }
                if (u[0] in n) o = u[0];
                else {
                  for (i in n) {
                    if (!u[0] || e.converters[i + " " + u[0]]) {
                      o = i;
                      break;
                    }
                    a || (a = i);
                  }
                  o = o || a;
                }
                if (o) return o !== u[0] && u.unshift(o), n[o];
              })(v, T, n)),
            (s = (function (e, t, n, r) {
              var i,
                o,
                a,
                s,
                u,
                l = {},
                c = e.dataTypes.slice();
              if (c[1])
                for (a in e.converters) l[a.toLowerCase()] = e.converters[a];
              o = c.shift();
              while (o)
                if (
                  (e.responseFields[o] && (n[e.responseFields[o]] = t),
                  !u && r && e.dataFilter && (t = e.dataFilter(t, e.dataType)),
                  (u = o),
                  (o = c.shift()))
                )
                  if ("*" === o) o = u;
                  else if ("*" !== u && u !== o) {
                    if (!(a = l[u + " " + o] || l["* " + o]))
                      for (i in l)
                        if (
                          (s = i.split(" "))[1] === o &&
                          (a = l[u + " " + s[0]] || l["* " + s[0]])
                        ) {
                          !0 === a
                            ? (a = l[i])
                            : !0 !== l[i] && ((o = s[0]), c.unshift(s[1]));
                          break;
                        }
                    if (!0 !== a)
                      if (a && e["throws"]) t = a(t);
                      else
                        try {
                          t = a(t);
                        } catch (e) {
                          return {
                            state: "parsererror",
                            error: a
                              ? e
                              : "No conversion from " + u + " to " + o,
                          };
                        }
                  }
              return { state: "success", data: t };
            })(v, s, T, i)),
            i
              ? (v.ifModified &&
                  ((u = T.getResponseHeader("Last-Modified")) &&
                    (k.lastModified[f] = u),
                  (u = T.getResponseHeader("etag")) && (k.etag[f] = u)),
                204 === e || "HEAD" === v.type
                  ? (l = "nocontent")
                  : 304 === e
                  ? (l = "notmodified")
                  : ((l = s.state), (o = s.data), (i = !(a = s.error))))
              : ((a = l), (!e && l) || ((l = "error"), e < 0 && (e = 0))),
            (T.status = e),
            (T.statusText = (t || l) + ""),
            i ? x.resolveWith(y, [o, l, T]) : x.rejectWith(y, [T, l, a]),
            T.statusCode(w),
            (w = void 0),
            g && m.trigger(i ? "ajaxSuccess" : "ajaxError", [T, v, i ? o : a]),
            b.fireWith(y, [T, l]),
            g &&
              (m.trigger("ajaxComplete", [T, v]),
              --k.active || k.event.trigger("ajaxStop")));
        }
        return T;
      },
      getJSON: function (e, t, n) {
        return k.get(e, t, n, "json");
      },
      getScript: function (e, t) {
        return k.get(e, void 0, t, "script");
      },
    }),
    k.each(["get", "post"], function (e, i) {
      k[i] = function (e, t, n, r) {
        return (
          m(t) && ((r = r || n), (n = t), (t = void 0)),
          k.ajax(
            k.extend(
              { url: e, type: i, dataType: r, data: t, success: n },
              k.isPlainObject(e) && e
            )
          )
        );
      };
    }),
    (k._evalUrl = function (e, t) {
      return k.ajax({
        url: e,
        type: "GET",
        dataType: "script",
        cache: !0,
        async: !1,
        global: !1,
        converters: { "text script": function () {} },
        dataFilter: function (e) {
          k.globalEval(e, t);
        },
      });
    }),
    k.fn.extend({
      wrapAll: function (e) {
        var t;
        return (
          this[0] &&
            (m(e) && (e = e.call(this[0])),
            (t = k(e, this[0].ownerDocument).eq(0).clone(!0)),
            this[0].parentNode && t.insertBefore(this[0]),
            t
              .map(function () {
                var e = this;
                while (e.firstElementChild) e = e.firstElementChild;
                return e;
              })
              .append(this)),
          this
        );
      },
      wrapInner: function (n) {
        return m(n)
          ? this.each(function (e) {
              k(this).wrapInner(n.call(this, e));
            })
          : this.each(function () {
              var e = k(this),
                t = e.contents();
              t.length ? t.wrapAll(n) : e.append(n);
            });
      },
      wrap: function (t) {
        var n = m(t);
        return this.each(function (e) {
          k(this).wrapAll(n ? t.call(this, e) : t);
        });
      },
      unwrap: function (e) {
        return (
          this.parent(e)
            .not("body")
            .each(function () {
              k(this).replaceWith(this.childNodes);
            }),
          this
        );
      },
    }),
    (k.expr.pseudos.hidden = function (e) {
      return !k.expr.pseudos.visible(e);
    }),
    (k.expr.pseudos.visible = function (e) {
      return !!(e.offsetWidth || e.offsetHeight || e.getClientRects().length);
    }),
    (k.ajaxSettings.xhr = function () {
      try {
        return new C.XMLHttpRequest();
      } catch (e) {}
    });
  var Ut = { 0: 200, 1223: 204 },
    Xt = k.ajaxSettings.xhr();
  (y.cors = !!Xt && "withCredentials" in Xt),
    (y.ajax = Xt = !!Xt),
    k.ajaxTransport(function (i) {
      var o, a;
      if (y.cors || (Xt && !i.crossDomain))
        return {
          send: function (e, t) {
            var n,
              r = i.xhr();
            if (
              (r.open(i.type, i.url, i.async, i.username, i.password),
              i.xhrFields)
            )
              for (n in i.xhrFields) r[n] = i.xhrFields[n];
            for (n in (i.mimeType &&
              r.overrideMimeType &&
              r.overrideMimeType(i.mimeType),
            i.crossDomain ||
              e["X-Requested-With"] ||
              (e["X-Requested-With"] = "XMLHttpRequest"),
            e))
              r.setRequestHeader(n, e[n]);
            (o = function (e) {
              return function () {
                o &&
                  ((o =
                    a =
                    r.onload =
                    r.onerror =
                    r.onabort =
                    r.ontimeout =
                    r.onreadystatechange =
                      null),
                  "abort" === e
                    ? r.abort()
                    : "error" === e
                    ? "number" != typeof r.status
                      ? t(0, "error")
                      : t(r.status, r.statusText)
                    : t(
                        Ut[r.status] || r.status,
                        r.statusText,
                        "text" !== (r.responseType || "text") ||
                          "string" != typeof r.responseText
                          ? { binary: r.response }
                          : { text: r.responseText },
                        r.getAllResponseHeaders()
                      ));
              };
            }),
              (r.onload = o()),
              (a = r.onerror = r.ontimeout = o("error")),
              void 0 !== r.onabort
                ? (r.onabort = a)
                : (r.onreadystatechange = function () {
                    4 === r.readyState &&
                      C.setTimeout(function () {
                        o && a();
                      });
                  }),
              (o = o("abort"));
            try {
              r.send((i.hasContent && i.data) || null);
            } catch (e) {
              if (o) throw e;
            }
          },
          abort: function () {
            o && o();
          },
        };
    }),
    k.ajaxPrefilter(function (e) {
      e.crossDomain && (e.contents.script = !1);
    }),
    k.ajaxSetup({
      accepts: {
        script:
          "text/javascript, application/javascript, application/ecmascript, application/x-ecmascript",
      },
      contents: { script: /\b(?:java|ecma)script\b/ },
      converters: {
        "text script": function (e) {
          return k.globalEval(e), e;
        },
      },
    }),
    k.ajaxPrefilter("script", function (e) {
      void 0 === e.cache && (e.cache = !1), e.crossDomain && (e.type = "GET");
    }),
    k.ajaxTransport("script", function (n) {
      var r, i;
      if (n.crossDomain || n.scriptAttrs)
        return {
          send: function (e, t) {
            (r = k("<script>")
              .attr(n.scriptAttrs || {})
              .prop({ charset: n.scriptCharset, src: n.url })
              .on(
                "load error",
                (i = function (e) {
                  r.remove(),
                    (i = null),
                    e && t("error" === e.type ? 404 : 200, e.type);
                })
              )),
              E.head.appendChild(r[0]);
          },
          abort: function () {
            i && i();
          },
        };
    });
  var Vt,
    Gt = [],
    Yt = /(=)\?(?=&|$)|\?\?/;
  k.ajaxSetup({
    jsonp: "callback",
    jsonpCallback: function () {
      var e = Gt.pop() || k.expando + "_" + kt++;
      return (this[e] = !0), e;
    },
  }),
    k.ajaxPrefilter("json jsonp", function (e, t, n) {
      var r,
        i,
        o,
        a =
          !1 !== e.jsonp &&
          (Yt.test(e.url)
            ? "url"
            : "string" == typeof e.data &&
              0 ===
                (e.contentType || "").indexOf(
                  "application/x-www-form-urlencoded"
                ) &&
              Yt.test(e.data) &&
              "data");
      if (a || "jsonp" === e.dataTypes[0])
        return (
          (r = e.jsonpCallback =
            m(e.jsonpCallback) ? e.jsonpCallback() : e.jsonpCallback),
          a
            ? (e[a] = e[a].replace(Yt, "$1" + r))
            : !1 !== e.jsonp &&
              (e.url += (St.test(e.url) ? "&" : "?") + e.jsonp + "=" + r),
          (e.converters["script json"] = function () {
            return o || k.error(r + " was not called"), o[0];
          }),
          (e.dataTypes[0] = "json"),
          (i = C[r]),
          (C[r] = function () {
            o = arguments;
          }),
          n.always(function () {
            void 0 === i ? k(C).removeProp(r) : (C[r] = i),
              e[r] && ((e.jsonpCallback = t.jsonpCallback), Gt.push(r)),
              o && m(i) && i(o[0]),
              (o = i = void 0);
          }),
          "script"
        );
    }),
    (y.createHTMLDocument =
      (((Vt = E.implementation.createHTMLDocument("").body).innerHTML =
        "<form></form><form></form>"),
      2 === Vt.childNodes.length)),
    (k.parseHTML = function (e, t, n) {
      return "string" != typeof e
        ? []
        : ("boolean" == typeof t && ((n = t), (t = !1)),
          t ||
            (y.createHTMLDocument
              ? (((r = (t =
                  E.implementation.createHTMLDocument("")).createElement(
                  "base"
                )).href = E.location.href),
                t.head.appendChild(r))
              : (t = E)),
          (o = !n && []),
          (i = D.exec(e))
            ? [t.createElement(i[1])]
            : ((i = we([e], t, o)),
              o && o.length && k(o).remove(),
              k.merge([], i.childNodes)));
      var r, i, o;
    }),
    (k.fn.load = function (e, t, n) {
      var r,
        i,
        o,
        a = this,
        s = e.indexOf(" ");
      return (
        -1 < s && ((r = mt(e.slice(s))), (e = e.slice(0, s))),
        m(t)
          ? ((n = t), (t = void 0))
          : t && "object" == typeof t && (i = "POST"),
        0 < a.length &&
          k
            .ajax({ url: e, type: i || "GET", dataType: "html", data: t })
            .done(function (e) {
              (o = arguments),
                a.html(r ? k("<div>").append(k.parseHTML(e)).find(r) : e);
            })
            .always(
              n &&
                function (e, t) {
                  a.each(function () {
                    n.apply(this, o || [e.responseText, t, e]);
                  });
                }
            ),
        this
      );
    }),
    k.each(
      [
        "ajaxStart",
        "ajaxStop",
        "ajaxComplete",
        "ajaxError",
        "ajaxSuccess",
        "ajaxSend",
      ],
      function (e, t) {
        k.fn[t] = function (e) {
          return this.on(t, e);
        };
      }
    ),
    (k.expr.pseudos.animated = function (t) {
      return k.grep(k.timers, function (e) {
        return t === e.elem;
      }).length;
    }),
    (k.offset = {
      setOffset: function (e, t, n) {
        var r,
          i,
          o,
          a,
          s,
          u,
          l = k.css(e, "position"),
          c = k(e),
          f = {};
        "static" === l && (e.style.position = "relative"),
          (s = c.offset()),
          (o = k.css(e, "top")),
          (u = k.css(e, "left")),
          ("absolute" === l || "fixed" === l) && -1 < (o + u).indexOf("auto")
            ? ((a = (r = c.position()).top), (i = r.left))
            : ((a = parseFloat(o) || 0), (i = parseFloat(u) || 0)),
          m(t) && (t = t.call(e, n, k.extend({}, s))),
          null != t.top && (f.top = t.top - s.top + a),
          null != t.left && (f.left = t.left - s.left + i),
          "using" in t ? t.using.call(e, f) : c.css(f);
      },
    }),
    k.fn.extend({
      offset: function (t) {
        if (arguments.length)
          return void 0 === t
            ? this
            : this.each(function (e) {
                k.offset.setOffset(this, t, e);
              });
        var e,
          n,
          r = this[0];
        return r
          ? r.getClientRects().length
            ? ((e = r.getBoundingClientRect()),
              (n = r.ownerDocument.defaultView),
              { top: e.top + n.pageYOffset, left: e.left + n.pageXOffset })
            : { top: 0, left: 0 }
          : void 0;
      },
      position: function () {
        if (this[0]) {
          var e,
            t,
            n,
            r = this[0],
            i = { top: 0, left: 0 };
          if ("fixed" === k.css(r, "position")) t = r.getBoundingClientRect();
          else {
            (t = this.offset()),
              (n = r.ownerDocument),
              (e = r.offsetParent || n.documentElement);
            while (
              e &&
              (e === n.body || e === n.documentElement) &&
              "static" === k.css(e, "position")
            )
              e = e.parentNode;
            e &&
              e !== r &&
              1 === e.nodeType &&
              (((i = k(e).offset()).top += k.css(e, "borderTopWidth", !0)),
              (i.left += k.css(e, "borderLeftWidth", !0)));
          }
          return {
            top: t.top - i.top - k.css(r, "marginTop", !0),
            left: t.left - i.left - k.css(r, "marginLeft", !0),
          };
        }
      },
      offsetParent: function () {
        return this.map(function () {
          var e = this.offsetParent;
          while (e && "static" === k.css(e, "position")) e = e.offsetParent;
          return e || ie;
        });
      },
    }),
    k.each(
      { scrollLeft: "pageXOffset", scrollTop: "pageYOffset" },
      function (t, i) {
        var o = "pageYOffset" === i;
        k.fn[t] = function (e) {
          return _(
            this,
            function (e, t, n) {
              var r;
              if (
                (x(e) ? (r = e) : 9 === e.nodeType && (r = e.defaultView),
                void 0 === n)
              )
                return r ? r[i] : e[t];
              r
                ? r.scrollTo(o ? r.pageXOffset : n, o ? n : r.pageYOffset)
                : (e[t] = n);
            },
            t,
            e,
            arguments.length
          );
        };
      }
    ),
    k.each(["top", "left"], function (e, n) {
      k.cssHooks[n] = ze(y.pixelPosition, function (e, t) {
        if (t)
          return (t = _e(e, n)), $e.test(t) ? k(e).position()[n] + "px" : t;
      });
    }),
    k.each({ Height: "height", Width: "width" }, function (a, s) {
      k.each(
        { padding: "inner" + a, content: s, "": "outer" + a },
        function (r, o) {
          k.fn[o] = function (e, t) {
            var n = arguments.length && (r || "boolean" != typeof e),
              i = r || (!0 === e || !0 === t ? "margin" : "border");
            return _(
              this,
              function (e, t, n) {
                var r;
                return x(e)
                  ? 0 === o.indexOf("outer")
                    ? e["inner" + a]
                    : e.document.documentElement["client" + a]
                  : 9 === e.nodeType
                  ? ((r = e.documentElement),
                    Math.max(
                      e.body["scroll" + a],
                      r["scroll" + a],
                      e.body["offset" + a],
                      r["offset" + a],
                      r["client" + a]
                    ))
                  : void 0 === n
                  ? k.css(e, t, i)
                  : k.style(e, t, n, i);
              },
              s,
              n ? e : void 0,
              n
            );
          };
        }
      );
    }),
    k.each(
      "blur focus focusin focusout resize scroll click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup contextmenu".split(
        " "
      ),
      function (e, n) {
        k.fn[n] = function (e, t) {
          return 0 < arguments.length
            ? this.on(n, null, e, t)
            : this.trigger(n);
        };
      }
    ),
    k.fn.extend({
      hover: function (e, t) {
        return this.mouseenter(e).mouseleave(t || e);
      },
    }),
    k.fn.extend({
      bind: function (e, t, n) {
        return this.on(e, null, t, n);
      },
      unbind: function (e, t) {
        return this.off(e, null, t);
      },
      delegate: function (e, t, n, r) {
        return this.on(t, e, n, r);
      },
      undelegate: function (e, t, n) {
        return 1 === arguments.length
          ? this.off(e, "**")
          : this.off(t, e || "**", n);
      },
    }),
    (k.proxy = function (e, t) {
      var n, r, i;
      if (("string" == typeof t && ((n = e[t]), (t = e), (e = n)), m(e)))
        return (
          (r = s.call(arguments, 2)),
          ((i = function () {
            return e.apply(t || this, r.concat(s.call(arguments)));
          }).guid = e.guid =
            e.guid || k.guid++),
          i
        );
    }),
    (k.holdReady = function (e) {
      e ? k.readyWait++ : k.ready(!0);
    }),
    (k.isArray = Array.isArray),
    (k.parseJSON = JSON.parse),
    (k.nodeName = A),
    (k.isFunction = m),
    (k.isWindow = x),
    (k.camelCase = V),
    (k.type = w),
    (k.now = Date.now),
    (k.isNumeric = function (e) {
      var t = k.type(e);
      return ("number" === t || "string" === t) && !isNaN(e - parseFloat(e));
    }),
    "function" == typeof define &&
      define.amd &&
      define("jquery", [], function () {
        return k;
      });
  var Qt = C.jQuery,
    Jt = C.$;
  return (
    (k.noConflict = function (e) {
      return C.$ === k && (C.$ = Jt), e && C.jQuery === k && (C.jQuery = Qt), k;
    }),
    e || (C.jQuery = C.$ = k),
    k
  );
});

/*!
 *
 *  js-cloudimage-360-view v2.4.1
 *  https://github.com/scaleflex/js-cloudimage-360-view
 *
 *  Copyright (c) 2019 scaleflex
 *  Released under the MIT license
 *
 *  Date: 2020-04-11T08:17:37.687Z
 *
 */ !(function (e) {
  var t = {};
  function i(n) {
    if (t[n]) return t[n].exports;
    var o = (t[n] = { i: n, l: !1, exports: {} });
    return e[n].call(o.exports, o, o.exports, i), (o.l = !0), o.exports;
  }
  (i.m = e),
    (i.c = t),
    (i.d = function (e, t, n) {
      i.o(e, t) || Object.defineProperty(e, t, { enumerable: !0, get: n });
    }),
    (i.r = function (e) {
      "undefined" != typeof Symbol &&
        Symbol.toStringTag &&
        Object.defineProperty(e, Symbol.toStringTag, { value: "Module" }),
        Object.defineProperty(e, "__esModule", { value: !0 });
    }),
    (i.t = function (e, t) {
      if ((1 & t && (e = i(e)), 8 & t)) return e;
      if (4 & t && "object" == typeof e && e && e.__esModule) return e;
      var n = Object.create(null);
      if (
        (i.r(n),
        Object.defineProperty(n, "default", { enumerable: !0, value: e }),
        2 & t && "string" != typeof e)
      )
        for (var o in e)
          i.d(
            n,
            o,
            function (t) {
              return e[t];
            }.bind(null, o)
          );
      return n;
    }),
    (i.n = function (e) {
      var t =
        e && e.__esModule
          ? function () {
              return e.default;
            }
          : function () {
              return e;
            };
      return i.d(t, "a", t), t;
    }),
    (i.o = function (e, t) {
      return Object.prototype.hasOwnProperty.call(e, t);
    }),
    (i.p = ""),
    i((i.s = 33));
})([
  function (e, t) {
    e.exports =
      "object" == typeof window && window && window.Math == Math
        ? window
        : "object" == typeof self && self && self.Math == Math
        ? self
        : Function("return this")();
  },
  function (e, t) {
    e.exports = function (e) {
      try {
        return !!e();
      } catch (e) {
        return !0;
      }
    };
  },
  function (e, t) {
    e.exports = function (e) {
      return "object" == typeof e ? null !== e : "function" == typeof e;
    };
  },
  function (e, t, i) {
    var n = i(10),
      o = i(26);
    e.exports = i(4)
      ? function (e, t, i) {
          return n.f(e, t, o(1, i));
        }
      : function (e, t, i) {
          return (e[t] = i), e;
        };
  },
  function (e, t, i) {
    e.exports = !i(1)(function () {
      return (
        7 !=
        Object.defineProperty({}, "a", {
          get: function () {
            return 7;
          },
        }).a
      );
    });
  },
  function (e, t) {
    var i = {}.hasOwnProperty;
    e.exports = function (e, t) {
      return i.call(e, t);
    };
  },
  function (e, t, i) {
    var n = i(0),
      o = i(9),
      s = n["__core-js_shared__"] || o("__core-js_shared__", {});
    (e.exports = function (e, t) {
      return s[e] || (s[e] = void 0 !== t ? t : {});
    })("versions", []).push({
      version: "3.0.0",
      mode: i(42) ? "pure" : "global",
      copyright: "© 2019 Denis Pushkarev (zloirock.ru)",
    });
  },
  function (e, t, i) {
    var n = i(2);
    e.exports = function (e) {
      if (!n(e)) throw TypeError(String(e) + " is not an object");
      return e;
    };
  },
  function (e, t, i) {
    var n = i(6)("wks"),
      o = i(27),
      s = i(0).Symbol,
      r = i(43);
    e.exports = function (e) {
      return n[e] || (n[e] = (r && s[e]) || (r ? s : o)("Symbol." + e));
    };
  },
  function (e, t, i) {
    var n = i(0),
      o = i(3);
    e.exports = function (e, t) {
      try {
        o(n, e, t);
      } catch (i) {
        n[e] = t;
      }
      return t;
    };
  },
  function (e, t, i) {
    var n = i(4),
      o = i(23),
      s = i(7),
      r = i(25),
      a = Object.defineProperty;
    t.f = n
      ? a
      : function (e, t, i) {
          if ((s(e), (t = r(t, !0)), s(i), o))
            try {
              return a(e, t, i);
            } catch (e) {}
          if ("get" in i || "set" in i)
            throw TypeError("Accessors not supported");
          return "value" in i && (e[t] = i.value), e;
        };
  },
  function (e, t, i) {
    var n = i(0),
      o = i(28).f,
      s = i(3),
      r = i(46),
      a = i(9),
      c = i(49),
      l = i(54);
    e.exports = function (e, t) {
      var i,
        u,
        h,
        d,
        f,
        v = e.target,
        p = e.global,
        y = e.stat;
      if ((i = p ? n : y ? n[v] || a(v, {}) : (n[v] || {}).prototype))
        for (u in t) {
          if (
            ((d = t[u]),
            (h = e.noTargetGet ? (f = o(i, u)) && f.value : i[u]),
            !l(p ? u : v + (y ? "." : "#") + u, e.forced) && void 0 !== h)
          ) {
            if (typeof d == typeof h) continue;
            c(d, h);
          }
          (e.sham || (h && h.sham)) && s(d, "sham", !0), r(i, u, d, e);
        }
    };
  },
  function (e, t, i) {
    var n = i(18),
      o = i(20);
    e.exports = function (e) {
      return n(o(e));
    };
  },
  function (e, t) {
    e.exports = {};
  },
  function (e, t) {
    e.exports = [
      "constructor",
      "hasOwnProperty",
      "isPrototypeOf",
      "propertyIsEnumerable",
      "toLocaleString",
      "toString",
      "valueOf",
    ];
  },
  function (e, t, i) {
    var n = i(0),
      o = i(17),
      s = Function.call;
    e.exports = function (e, t, i) {
      return o(s, n[e].prototype[t], i);
    };
  },
  function (e, t, i) {
    var n = i(17),
      o = i(18),
      s = i(39),
      r = i(21),
      a = i(40);
    e.exports = function (e, t) {
      var i = 1 == e,
        c = 2 == e,
        l = 3 == e,
        u = 4 == e,
        h = 6 == e,
        d = 5 == e || h,
        f = t || a;
      return function (t, a, v) {
        for (
          var p,
            y,
            g = s(t),
            m = o(g),
            w = n(a, v, 3),
            x = r(m.length),
            b = 0,
            I = i ? f(t, x) : c ? f(t, 0) : void 0;
          x > b;
          b++
        )
          if ((d || b in m) && ((y = w((p = m[b]), b, g)), e))
            if (i) I[b] = y;
            else if (y)
              switch (e) {
                case 3:
                  return !0;
                case 5:
                  return p;
                case 6:
                  return b;
                case 2:
                  I.push(p);
              }
            else if (u) return !1;
        return h ? -1 : l || u ? u : I;
      };
    };
  },
  function (e, t, i) {
    var n = i(38);
    e.exports = function (e, t, i) {
      if ((n(e), void 0 === t)) return e;
      switch (i) {
        case 0:
          return function () {
            return e.call(t);
          };
        case 1:
          return function (i) {
            return e.call(t, i);
          };
        case 2:
          return function (i, n) {
            return e.call(t, i, n);
          };
        case 3:
          return function (i, n, o) {
            return e.call(t, i, n, o);
          };
      }
      return function () {
        return e.apply(t, arguments);
      };
    };
  },
  function (e, t, i) {
    var n = i(1),
      o = i(19),
      s = "".split;
    e.exports = n(function () {
      return !Object("z").propertyIsEnumerable(0);
    })
      ? function (e) {
          return "String" == o(e) ? s.call(e, "") : Object(e);
        }
      : Object;
  },
  function (e, t) {
    var i = {}.toString;
    e.exports = function (e) {
      return i.call(e).slice(8, -1);
    };
  },
  function (e, t) {
    e.exports = function (e) {
      if (null == e) throw TypeError("Can't call method on " + e);
      return e;
    };
  },
  function (e, t, i) {
    var n = i(22),
      o = Math.min;
    e.exports = function (e) {
      return e > 0 ? o(n(e), 9007199254740991) : 0;
    };
  },
  function (e, t) {
    var i = Math.ceil,
      n = Math.floor;
    e.exports = function (e) {
      return isNaN((e = +e)) ? 0 : (e > 0 ? n : i)(e);
    };
  },
  function (e, t, i) {
    e.exports =
      !i(4) &&
      !i(1)(function () {
        return (
          7 !=
          Object.defineProperty(i(24)("div"), "a", {
            get: function () {
              return 7;
            },
          }).a
        );
      });
  },
  function (e, t, i) {
    var n = i(2),
      o = i(0).document,
      s = n(o) && n(o.createElement);
    e.exports = function (e) {
      return s ? o.createElement(e) : {};
    };
  },
  function (e, t, i) {
    var n = i(2);
    e.exports = function (e, t) {
      if (!n(e)) return e;
      var i, o;
      if (t && "function" == typeof (i = e.toString) && !n((o = i.call(e))))
        return o;
      if ("function" == typeof (i = e.valueOf) && !n((o = i.call(e)))) return o;
      if (!t && "function" == typeof (i = e.toString) && !n((o = i.call(e))))
        return o;
      throw TypeError("Can't convert object to primitive value");
    };
  },
  function (e, t) {
    e.exports = function (e, t) {
      return {
        enumerable: !(1 & e),
        configurable: !(2 & e),
        writable: !(4 & e),
        value: t,
      };
    };
  },
  function (e, t) {
    var i = 0,
      n = Math.random();
    e.exports = function (e) {
      return "Symbol(".concat(
        void 0 === e ? "" : e,
        ")_",
        (++i + n).toString(36)
      );
    };
  },
  function (e, t, i) {
    var n = i(4),
      o = i(45),
      s = i(26),
      r = i(12),
      a = i(25),
      c = i(5),
      l = i(23),
      u = Object.getOwnPropertyDescriptor;
    t.f = n
      ? u
      : function (e, t) {
          if (((e = r(e)), (t = a(t, !0)), l))
            try {
              return u(e, t);
            } catch (e) {}
          if (c(e, t)) return s(!o.f.call(e, t), e[t]);
        };
  },
  function (e, t, i) {
    e.exports = i(6)("native-function-to-string", Function.toString);
  },
  function (e, t, i) {
    var n = i(6)("keys"),
      o = i(27);
    e.exports = function (e) {
      return n[e] || (n[e] = o(e));
    };
  },
  function (e, t, i) {
    var n = i(5),
      o = i(12),
      s = i(32)(!1),
      r = i(13);
    e.exports = function (e, t) {
      var i,
        a = o(e),
        c = 0,
        l = [];
      for (i in a) !n(r, i) && n(a, i) && l.push(i);
      for (; t.length > c; ) n(a, (i = t[c++])) && (~s(l, i) || l.push(i));
      return l;
    };
  },
  function (e, t, i) {
    var n = i(12),
      o = i(21),
      s = i(52);
    e.exports = function (e) {
      return function (t, i, r) {
        var a,
          c = n(t),
          l = o(c.length),
          u = s(r, l);
        if (e && i != i) {
          for (; l > u; ) if ((a = c[u++]) != a) return !0;
        } else
          for (; l > u; u++)
            if ((e || u in c) && c[u] === i) return e || u || 0;
        return !e && -1;
      };
    };
  },
  function (e, t, i) {
    "use strict";
    i(34), i(55), i(59);
    var n,
      o = i(67),
      s = (n = o) && n.__esModule ? n : { default: n };
    function r() {
      var e = [],
        t = document.querySelectorAll(".cloudimage-360:not(.initialized)");
      [].slice.call(t).forEach(function (t) {
        e.push(new s.default(t));
      }),
        (window.CI360._viewers = e);
    }
    function a() {
      return !(window.CI360._viewers && window.CI360._viewers.length > 0);
    }
    (window.CI360 = window.CI360 || {}),
      (window.CI360.init = r),
      (window.CI360.destroy = function () {
        a() ||
          (window.CI360._viewers.forEach(function (e) {
            e.destroy();
          }),
          (window.CI360._viewers = []));
      }),
      (window.CI360.getActiveIndexByID = function (e) {
        if (!a()) {
          var t = window.CI360._viewers.filter(function (t) {
            return t.id === e;
          })[0];
          return t && t.activeImage - 1;
        }
      }),
      window.CI360.notInitOnLoad || r();
  },
  function (e, t, i) {
    e.exports = i(35);
  },
  function (e, t, i) {
    i(36), (e.exports = i(15)("Array", "forEach"));
  },
  function (e, t, i) {
    "use strict";
    var n = i(37);
    i(11)(
      { target: "Array", proto: !0, forced: [].forEach != n },
      { forEach: n }
    );
  },
  function (e, t, i) {
    "use strict";
    var n = [].forEach,
      o = i(16)(0),
      s = i(44)("forEach");
    e.exports = s
      ? function (e) {
          return o(this, e, arguments[1]);
        }
      : n;
  },
  function (e, t) {
    e.exports = function (e) {
      if ("function" != typeof e)
        throw TypeError(String(e) + " is not a function");
      return e;
    };
  },
  function (e, t, i) {
    var n = i(20);
    e.exports = function (e) {
      return Object(n(e));
    };
  },
  function (e, t, i) {
    var n = i(2),
      o = i(41),
      s = i(8)("species");
    e.exports = function (e, t) {
      var i;
      return (
        o(e) &&
          ("function" != typeof (i = e.constructor) ||
          (i !== Array && !o(i.prototype))
            ? n(i) && null === (i = i[s]) && (i = void 0)
            : (i = void 0)),
        new (void 0 === i ? Array : i)(0 === t ? 0 : t)
      );
    };
  },
  function (e, t, i) {
    var n = i(19);
    e.exports =
      Array.isArray ||
      function (e) {
        return "Array" == n(e);
      };
  },
  function (e, t) {
    e.exports = !1;
  },
  function (e, t, i) {
    e.exports = !i(1)(function () {
      String(Symbol());
    });
  },
  function (e, t, i) {
    "use strict";
    var n = i(1);
    e.exports = function (e, t) {
      var i = [][e];
      return (
        !i ||
        !n(function () {
          i.call(
            null,
            t ||
              function () {
                throw Error();
              },
            1
          );
        })
      );
    };
  },
  function (e, t, i) {
    "use strict";
    var n = {}.propertyIsEnumerable,
      o = Object.getOwnPropertyDescriptor,
      s = o && !n.call({ 1: 2 }, 1);
    t.f = s
      ? function (e) {
          var t = o(this, e);
          return !!t && t.enumerable;
        }
      : n;
  },
  function (e, t, i) {
    var n = i(0),
      o = i(3),
      s = i(5),
      r = i(9),
      a = i(29),
      c = i(47),
      l = c.get,
      u = c.enforce,
      h = String(a).split("toString");
    i(6)("inspectSource", function (e) {
      return a.call(e);
    }),
      (e.exports = function (e, t, i, a) {
        var c = !!a && !!a.unsafe,
          l = !!a && !!a.enumerable,
          d = !!a && !!a.noTargetGet;
        "function" == typeof i &&
          ("string" != typeof t || s(i, "name") || o(i, "name", t),
          (u(i).source = h.join("string" == typeof t ? t : ""))),
          e !== n
            ? (c ? !d && e[t] && (l = !0) : delete e[t],
              l ? (e[t] = i) : o(e, t, i))
            : l
            ? (e[t] = i)
            : r(t, i);
      })(Function.prototype, "toString", function () {
        return ("function" == typeof this && l(this).source) || a.call(this);
      });
  },
  function (e, t, i) {
    var n,
      o,
      s,
      r = i(48),
      a = i(2),
      c = i(3),
      l = i(5),
      u = i(30),
      h = i(13),
      d = i(0).WeakMap;
    if (r) {
      var f = new d(),
        v = f.get,
        p = f.has,
        y = f.set;
      (n = function (e, t) {
        return y.call(f, e, t), t;
      }),
        (o = function (e) {
          return v.call(f, e) || {};
        }),
        (s = function (e) {
          return p.call(f, e);
        });
    } else {
      var g = u("state");
      (h[g] = !0),
        (n = function (e, t) {
          return c(e, g, t), t;
        }),
        (o = function (e) {
          return l(e, g) ? e[g] : {};
        }),
        (s = function (e) {
          return l(e, g);
        });
    }
    e.exports = {
      set: n,
      get: o,
      has: s,
      enforce: function (e) {
        return s(e) ? o(e) : n(e, {});
      },
      getterFor: function (e) {
        return function (t) {
          var i;
          if (!a(t) || (i = o(t)).type !== e)
            throw TypeError("Incompatible receiver, " + e + " required");
          return i;
        };
      },
    };
  },
  function (e, t, i) {
    var n = i(29),
      o = i(0).WeakMap;
    e.exports = "function" == typeof o && /native code/.test(n.call(o));
  },
  function (e, t, i) {
    var n = i(5),
      o = i(50),
      s = i(28),
      r = i(10);
    e.exports = function (e, t) {
      for (var i = o(t), a = r.f, c = s.f, l = 0; l < i.length; l++) {
        var u = i[l];
        n(e, u) || a(e, u, c(t, u));
      }
    };
  },
  function (e, t, i) {
    var n = i(51),
      o = i(53),
      s = i(7),
      r = i(0).Reflect;
    e.exports =
      (r && r.ownKeys) ||
      function (e) {
        var t = n.f(s(e)),
          i = o.f;
        return i ? t.concat(i(e)) : t;
      };
  },
  function (e, t, i) {
    var n = i(31),
      o = i(14).concat("length", "prototype");
    t.f =
      Object.getOwnPropertyNames ||
      function (e) {
        return n(e, o);
      };
  },
  function (e, t, i) {
    var n = i(22),
      o = Math.max,
      s = Math.min;
    e.exports = function (e, t) {
      var i = n(e);
      return i < 0 ? o(i + t, 0) : s(i, t);
    };
  },
  function (e, t) {
    t.f = Object.getOwnPropertySymbols;
  },
  function (e, t, i) {
    var n = i(1),
      o = /#|\.prototype\./,
      s = function (e, t) {
        var i = a[r(e)];
        return i == l || (i != c && ("function" == typeof t ? n(t) : !!t));
      },
      r = (s.normalize = function (e) {
        return String(e).replace(o, ".").toLowerCase();
      }),
      a = (s.data = {}),
      c = (s.NATIVE = "N"),
      l = (s.POLYFILL = "P");
    e.exports = s;
  },
  function (e, t, i) {
    e.exports = i(56);
  },
  function (e, t, i) {
    i(57), (e.exports = i(15)("Array", "filter"));
  },
  function (e, t, i) {
    "use strict";
    var n = i(16)(2),
      o = i(58)("filter");
    i(11)(
      { target: "Array", proto: !0, forced: !o },
      {
        filter: function (e) {
          return n(this, e, arguments[1]);
        },
      }
    );
  },
  function (e, t, i) {
    var n = i(1),
      o = i(8)("species");
    e.exports = function (e) {
      return !n(function () {
        var t = [];
        return (
          ((t.constructor = {})[o] = function () {
            return { foo: 1 };
          }),
          1 !== t[e](Boolean).foo
        );
      });
    };
  },
  function (e, t, i) {
    e.exports = i(60);
  },
  function (e, t, i) {
    i(61), (e.exports = i(15)("Array", "includes"));
  },
  function (e, t, i) {
    "use strict";
    var n = i(32)(!0);
    i(11)(
      { target: "Array", proto: !0 },
      {
        includes: function (e) {
          return n(this, e, arguments.length > 1 ? arguments[1] : void 0);
        },
      }
    ),
      i(62)("includes");
  },
  function (e, t, i) {
    var n = i(8)("unscopables"),
      o = i(63),
      s = i(3),
      r = Array.prototype;
    null == r[n] && s(r, n, o(null)),
      (e.exports = function (e) {
        r[n][e] = !0;
      });
  },
  function (e, t, i) {
    var n = i(7),
      o = i(64),
      s = i(14),
      r = i(66),
      a = i(24),
      c = i(30)("IE_PROTO"),
      l = function () {},
      u = function () {
        var e,
          t = a("iframe"),
          i = s.length;
        for (
          t.style.display = "none",
            r.appendChild(t),
            t.src = String("javascript:"),
            (e = t.contentWindow.document).open(),
            e.write("<script>document.F=Object</script>"),
            e.close(),
            u = e.F;
          i--;

        )
          delete u.prototype[s[i]];
        return u();
      };
    (e.exports =
      Object.create ||
      function (e, t) {
        var i;
        return (
          null !== e
            ? ((l.prototype = n(e)),
              (i = new l()),
              (l.prototype = null),
              (i[c] = e))
            : (i = u()),
          void 0 === t ? i : o(i, t)
        );
      }),
      (i(13)[c] = !0);
  },
  function (e, t, i) {
    var n = i(4),
      o = i(10),
      s = i(7),
      r = i(65);
    e.exports = n
      ? Object.defineProperties
      : function (e, t) {
          s(e);
          for (var i, n = r(t), a = n.length, c = 0; a > c; )
            o.f(e, (i = n[c++]), t[i]);
          return e;
        };
  },
  function (e, t, i) {
    var n = i(31),
      o = i(14);
    e.exports =
      Object.keys ||
      function (e) {
        return n(e, o);
      };
  },
  function (e, t, i) {
    var n = i(0).document;
    e.exports = n && n.documentElement;
  },
  function (e, t, i) {
    "use strict";
    Object.defineProperty(t, "__esModule", { value: !0 });
    var n = (function () {
        function e(e, t) {
          for (var i = 0; i < t.length; i++) {
            var n = t[i];
            (n.enumerable = n.enumerable || !1),
              (n.configurable = !0),
              "value" in n && (n.writable = !0),
              Object.defineProperty(e, n.key, n);
          }
        }
        return function (t, i, n) {
          return i && e(t.prototype, i), n && e(t, n), t;
        };
      })(),
      o = i(68);
    var s = (function () {
      function e(t, i, n) {
        !(function (e, t) {
          if (!(e instanceof t))
            throw new TypeError("Cannot call a class as a function");
        })(this, e),
          (this.container = t),
          (this.activeImage = 1),
          (this.movementStart = 0),
          (this.isClicked = !1),
          (this.loadedImages = 0),
          (this.imagesLoaded = !1),
          (this.reversed = !1),
          (this.fullScreenView = !!i),
          (this.ratio = n),
          (this.images = []),
          (this.devicePixelRatio = Math.round(window.devicePixelRatio || 1)),
          (this.isMobile = !!(
            "ontouchstart" in window || navigator.msMaxTouchPoints
          )),
          (this.id = t.id),
          this.init(t);
      }
      return (
        n(e, [
          {
            key: "mousedown",
            value: function (e) {
              e.preventDefault(),
                this.imagesLoaded &&
                  (this.glass && this.closeMagnifier(),
                  this.view360Icon && this.remove360ViewIcon(),
                  (this.autoplay || this.loopTimeoutId) &&
                    (this.stop(), (this.autoplay = !1)),
                  (this.movementStart = e.pageX),
                  (this.isClicked = !0),
                  (this.container.style.cursor = "grabbing"));
            },
          },
          {
            key: "mouseup",
            value: function () {
              this.imagesLoaded &&
                ((this.movementStart = 0),
                (this.isClicked = !1),
                (this.container.style.cursor = "grab"),
                this.bottomCircle && this.show360ViewCircleIcon());
            },
          },
          {
            key: "mousemove",
            value: function (e) {
              this.isClicked && this.imagesLoaded && this.onMove(e.pageX);
            },
          },
          {
            key: "touchstart",
            value: function (e) {
              this.imagesLoaded &&
                (this.glass && this.closeMagnifier(),
                this.view360Icon && this.remove360ViewIcon(),
                (this.autoplay || this.loopTimeoutId) &&
                  (this.stop(), (this.autoplay = !1)),
                (this.movementStart = e.touches[0].clientX),
                (this.isClicked = !0));
            },
          },
          {
            key: "touchend",
            value: function () {
              this.imagesLoaded &&
                ((this.movementStart = 0),
                (this.isClicked = !1),
                this.bottomCircle && this.show360ViewCircleIcon());
            },
          },
          {
            key: "touchmove",
            value: function (e) {
              this.isClicked &&
                this.imagesLoaded &&
                this.onMove(e.touches[0].clientX);
            },
          },
          {
            key: "keydownGeneral",
            value: function () {
              this.imagesLoaded && this.glass && this.closeMagnifier();
            },
          },
          {
            key: "keydown",
            value: function (e) {
              this.imagesLoaded &&
                (this.glass && this.closeMagnifier(),
                -1 !== [37, 39].indexOf(e.keyCode) &&
                  (37 === e.keyCode
                    ? this.reversed
                      ? this.prev()
                      : this.next()
                    : 39 === e.keyCode &&
                      (this.reversed ? this.next() : this.prev()),
                  this.onSpin()));
            },
          },
          {
            key: "onSpin",
            value: function () {
              this.bottomCircle && this.hide360ViewCircleIcon(),
                this.view360Icon && this.remove360ViewIcon(),
                (this.autoplay || this.loopTimeoutId) &&
                  (this.stop(), (this.autoplay = !1));
            },
          },
          {
            key: "keyup",
            value: function (e) {
              this.imagesLoaded &&
                -1 !== [37, 39].indexOf(e.keyCode) &&
                this.onFinishSpin();
            },
          },
          {
            key: "onFinishSpin",
            value: function () {
              this.bottomCircle && this.show360ViewCircleIcon();
            },
          },
          {
            key: "onMove",
            value: function (e) {
              if (e - this.movementStart >= this.speedFactor) {
                var t =
                  Math.floor((e - this.movementStart) / this.speedFactor) || 1;
                (this.movementStart = e),
                  this.spinReverse
                    ? this.moveActiveIndexDown(t)
                    : this.moveActiveIndexUp(t),
                  this.bottomCircle && this.hide360ViewCircleIcon(),
                  this.update();
              } else if (this.movementStart - e >= this.speedFactor) {
                var i =
                  Math.floor((this.movementStart - e) / this.speedFactor) || 1;
                (this.movementStart = e),
                  this.spinReverse
                    ? this.moveActiveIndexUp(i)
                    : this.moveActiveIndexDown(i),
                  this.bottomCircle && this.hide360ViewCircleIcon(),
                  this.update();
              }
            },
          },
          {
            key: "moveActiveIndexUp",
            value: function (e) {
              var t = this.controlReverse
                ? !this.spinReverse
                : this.spinReverse;
              this.stopAtEdges
                ? this.activeImage + e >= this.amount
                  ? ((this.activeImage = this.amount),
                    (t ? this.prevElem : this.nextElem) &&
                      (0, o.addClass)(
                        t ? this.prevElem : this.nextElem,
                        "not-active"
                      ))
                  : ((this.activeImage += e),
                    this.nextElem &&
                      (0, o.removeClass)(this.nextElem, "not-active"),
                    this.prevElem &&
                      (0, o.removeClass)(this.prevElem, "not-active"))
                : (this.activeImage =
                    (this.activeImage + e) % this.amount || this.amount);
            },
          },
          {
            key: "moveActiveIndexDown",
            value: function (e) {
              var t = this.controlReverse
                ? !this.spinReverse
                : this.spinReverse;
              this.stopAtEdges
                ? this.activeImage - e <= 1
                  ? ((this.activeImage = 1),
                    (t ? this.nextElem : this.prevElem) &&
                      (0, o.addClass)(
                        t ? this.nextElem : this.prevElem,
                        "not-active"
                      ))
                  : ((this.activeImage -= e),
                    this.prevElem &&
                      (0, o.removeClass)(this.prevElem, "not-active"),
                    this.nextElem &&
                      (0, o.removeClass)(this.nextElem, "not-active"))
                : this.activeImage - e < 1
                ? (this.activeImage = this.amount + (this.activeImage - e))
                : (this.activeImage -= e);
            },
          },
          {
            key: "loop",
            value: function (e) {
              e ? this.prev() : this.next();
            },
          },
          {
            key: "next",
            value: function () {
              this.moveActiveIndexUp(1), this.update();
            },
          },
          {
            key: "prev",
            value: function () {
              this.moveActiveIndexDown(1), this.update();
            },
          },
          {
            key: "update",
            value: function () {
              var e = this.images[this.activeImage - 1],
                t = this.canvas.getContext("2d");
              if (
                (t.scale(this.devicePixelRatio, this.devicePixelRatio),
                this.fullScreenView)
              ) {
                (this.canvas.width = window.innerWidth * this.devicePixelRatio),
                  (this.canvas.style.width = window.innerWidth + "px"),
                  (this.canvas.height =
                    window.innerHeight * this.devicePixelRatio),
                  (this.canvas.style.height = window.innerHeight + "px");
                var i = (0, o.contain)(
                    this.canvas.width,
                    this.canvas.height,
                    e.width,
                    e.height
                  ),
                  n = i.offsetX,
                  s = i.offsetY,
                  r = i.width,
                  a = i.height;
                t.drawImage(e, n, s, r, a);
              } else
                (this.canvas.width =
                  this.container.offsetWidth * this.devicePixelRatio),
                  (this.canvas.style.width = this.container.offsetWidth + "px"),
                  (this.canvas.height =
                    ((this.container.offsetWidth * this.devicePixelRatio) /
                      e.width) *
                    e.height),
                  (this.canvas.style.height =
                    (this.container.offsetWidth / e.width) * e.height + "px"),
                  t.drawImage(e, 0, 0, this.canvas.width, this.canvas.height);
            },
          },
          {
            key: "updatePercentageInLoader",
            value: function (e) {
              this.loader && (this.loader.style.width = e + "%"),
                this.view360Icon && (this.view360Icon.innerText = e + "%");
            },
          },
          {
            key: "onAllImagesLoaded",
            value: function () {
              if (
                ((this.imagesLoaded = !0),
                (this.container.style.cursor = "grab"),
                this.removeLoader(),
                this.fullScreenView)
              ) {
                var e =
                    this.container.offsetHeight / this.container.offsetWidth,
                  t = this.container.offsetWidth;
                this.ratio > e &&
                  (t = this.container.offsetHeight / this.ratio),
                  (this.speedFactor =
                    Math.floor(
                      ((((this.dragSpeed / 150) * 36) / this.amount) * 25 * t) /
                        1500
                    ) || 1);
              } else
                this.speedFactor =
                  Math.floor(
                    ((((this.dragSpeed / 150) * 36) / this.amount) *
                      25 *
                      this.container.offsetWidth) /
                      1500
                  ) || 1;
              this.autoplay && this.play(),
                this.view360Icon &&
                  ((this.view360Icon.innerText = ""),
                  (0, o.setView360Icon)(this.view360Icon)),
                this.initControls();
            },
          },
          {
            key: "onFirstImageLoaded",
            value: function (e) {
              var t = this;
              if ((this.add360ViewIcon(), this.fullScreenView)) {
                (this.canvas.width = window.innerWidth * this.devicePixelRatio),
                  (this.canvas.style.width = window.innerWidth + "px"),
                  (this.canvas.height =
                    window.innerHeight * this.devicePixelRatio),
                  (this.canvas.style.height = window.innerHeight + "px");
                var i = this.canvas.getContext("2d"),
                  n = (0, o.contain)(
                    this.canvas.width,
                    this.canvas.height,
                    e.target.width,
                    e.target.height
                  ),
                  s = n.offsetX,
                  r = n.offsetY,
                  a = n.width,
                  c = n.height;
                i.drawImage(e.target, s, r, a, c);
              } else {
                (this.canvas.width =
                  this.container.offsetWidth * this.devicePixelRatio),
                  (this.canvas.style.width = this.container.offsetWidth + "px"),
                  (this.canvas.height =
                    ((this.container.offsetWidth * this.devicePixelRatio) /
                      e.target.width) *
                    e.target.height),
                  (this.canvas.style.height =
                    (this.container.offsetWidth / e.target.width) *
                      e.target.height +
                    "px"),
                  this.canvas
                    .getContext("2d")
                    .drawImage(
                      e.target,
                      0,
                      0,
                      this.canvas.width,
                      this.canvas.height
                    );
              }
              this.lazyload &&
                !this.fullScreenView &&
                this.images.forEach(function (e, i) {
                  0 !== i
                    ? e.getAttribute("data-src") &&
                      (e.src = e.getAttribute("data-src"))
                    : t.innerBox.removeChild(t.lazyloadInitImage);
                }),
                this.ratio && (this.container.style.minHeight = "auto"),
                this.magnifier && !this.fullScreenView && this.addMagnifier(),
                this.boxShadow && !this.fullScreenView && this.addBoxShadow(),
                this.bottomCircle &&
                  !this.fullScreenView &&
                  this.add360ViewCircleIcon(),
                this.fullScreen && !this.fullScreenView
                  ? this.addFullScreenIcon()
                  : this.fullScreenView && this.addCloseFullScreenView();
            },
          },
          {
            key: "onImageLoad",
            value: function (e, t) {
              var i = Math.round((this.loadedImages / this.amount) * 100);
              (this.loadedImages += 1),
                this.updatePercentageInLoader(i),
                this.loadedImages === this.amount
                  ? this.onAllImagesLoaded(t)
                  : 0 === e && this.onFirstImageLoaded(t);
            },
          },
          {
            key: "addCloseFullScreenView",
            value: function () {
              var e = document.createElement("div");
              (0, o.setCloseFullScreenViewStyles)(e),
                (e.onclick = this.closeFullScreenModal.bind(this)),
                this.innerBox.appendChild(e);
            },
          },
          {
            key: "add360ViewIcon",
            value: function () {
              var e = document.createElement("div");
              (0, o.set360ViewIconStyles)(e),
                (e.innerText = "0%"),
                (this.view360Icon = e),
                this.innerBox.appendChild(e);
            },
          },
          {
            key: "addFullScreenIcon",
            value: function () {
              var e = document.createElement("div");
              (0, o.setFullScreenIconStyles)(e),
                (e.onclick = this.openFullScreenModal.bind(this)),
                this.innerBox.appendChild(e);
            },
          },
          {
            key: "addMagnifier",
            value: function () {
              var e = document.createElement("div");
              (0, o.setMagnifyIconStyles)(e, this.fullScreen),
                (e.onclick = this.magnify.bind(this)),
                this.innerBox.appendChild(e);
            },
          },
          {
            key: "getOriginalSrc",
            value: function () {
              var e = this.images[this.activeImage - 1],
                t = e.src.lastIndexOf("//");
              return t > 10 ? e.src.slice(t) : e.src;
            },
          },
          {
            key: "magnify",
            value: function () {
              var e = this,
                t = new Image(),
                i = this.getOriginalSrc();
              (t.src = i),
                (t.onload = function () {
                  e.glass && (e.glass.style.cursor = "none");
                }),
                (this.glass = document.createElement("div")),
                (this.container.style.overflow = "hidden"),
                (0, o.magnify)(
                  this.container,
                  i,
                  this.glass,
                  this.magnifier || 3
                );
            },
          },
          {
            key: "closeMagnifier",
            value: function () {
              this.glass &&
                ((this.container.style.overflow = "visible"),
                this.container.removeChild(this.glass),
                (this.glass = null));
            },
          },
          {
            key: "openFullScreenModal",
            value: function () {
              var t = document.createElement("div");
              (0, o.setFullScreenModalStyles)(t);
              var i = this.container.cloneNode(),
                n = this.images[0],
                s = n.height / n.width;
              (i.style.height = "100%"),
                (i.style.maxHeight = "100%"),
                t.appendChild(i),
                window.document.body.appendChild(t),
                new e(i, !0, s);
            },
          },
          {
            key: "closeFullScreenModal",
            value: function () {
              document.body.removeChild(this.container.parentNode);
            },
          },
          {
            key: "add360ViewCircleIcon",
            value: function () {
              var e = new Image();
              (0, o.set360ViewCircleIconStyles)(e, this.bottomCircleOffset),
                (this.view360CircleIcon = e),
                this.innerBox.appendChild(e);
            },
          },
          {
            key: "hide360ViewCircleIcon",
            value: function () {
              this.view360CircleIcon &&
                (this.view360CircleIcon.style.opacity = "0");
            },
          },
          {
            key: "show360ViewCircleIcon",
            value: function () {
              this.view360CircleIcon &&
                (this.view360CircleIcon.style.opacity = "1");
            },
          },
          {
            key: "remove360ViewCircleIcon",
            value: function () {
              this.view360CircleIcon &&
                (this.innerBox.removeChild(this.view360CircleIcon),
                (this.view360CircleIcon = null));
            },
          },
          {
            key: "addLoader",
            value: function () {
              var e = document.createElement("div");
              (0, o.setLoaderStyles)(e),
                (this.loader = e),
                this.innerBox.appendChild(e);
            },
          },
          {
            key: "addBoxShadow",
            value: function () {
              var e = document.createElement("div");
              (0, o.setBoxShadowStyles)(e, this.boxShadow),
                this.innerBox.appendChild(e);
            },
          },
          {
            key: "removeLoader",
            value: function () {
              this.loader &&
                (this.innerBox.removeChild(this.loader), (this.loader = null));
            },
          },
          {
            key: "remove360ViewIcon",
            value: function () {
              this.view360Icon &&
                (this.innerBox.removeChild(this.view360Icon),
                (this.view360Icon = null));
            },
          },
          {
            key: "play",
            value: function () {
              var e = this;
              this.bottomCircle && this.hide360ViewCircleIcon(),
                this.remove360ViewIcon(),
                (this.loopTimeoutId = window.setInterval(function () {
                  e.loop(e.reversed);
                }, this.autoplaySpeed));
            },
          },
          {
            key: "stop",
            value: function () {
              this.bottomCircle && this.show360ViewCircleIcon(),
                window.clearTimeout(this.loopTimeoutId);
            },
          },
          {
            key: "getSrc",
            value: function (e, t, i, n, s) {
              var r = s.ciSize,
                a = s.ciToken,
                c = s.ciOperation,
                l = s.ciFilters,
                u = "" + i + n;
              if (e) {
                var h = t.offsetWidth;
                if (this.fullScreenView) {
                  var d = t.offsetHeight / t.offsetWidth;
                  this.ratio > d && (h = t.offsetHeight / this.ratio);
                }
                u =
                  "https://" +
                  a +
                  ".cloudimg.io/" +
                  c +
                  "/" +
                  (0, o.getSizeAccordingToPixelRatio)(
                    r || (0, o.getResponsiveWidthOfContainer)(h)
                  ) +
                  "/" +
                  l +
                  "/" +
                  u;
              }
              return u;
            },
          },
          {
            key: "preloadImages",
            value: function (e, t, i, n, s, r, a) {
              var c = this;
              if (this.imageList)
                try {
                  var l = JSON.parse(this.imageList);
                  (this.amount = l.length),
                    l.forEach(function (e, t) {
                      var o = /(http(s?)):\/\//gi.test(e) ? "" : c.folder,
                        l = c.getSrc(r, s, o, e, a);
                      c.addImage(l, i, n, t);
                    });
                } catch (e) {
                  console.error(
                    "Wrong format in image-list attribute: " + e.message
                  );
                }
              else
                []
                  .concat(
                    (function (e) {
                      if (Array.isArray(e)) {
                        for (var t = 0, i = Array(e.length); t < e.length; t++)
                          i[t] = e[t];
                        return i;
                      }
                      return Array.from(e);
                    })(new Array(e))
                  )
                  .map(function (e, s) {
                    var r = (0, o.pad)(s + 1, c.indexZeroBase),
                      a = t.replace("{index}", r);
                    c.addImage(a, i, n, s);
                  });
            },
          },
          {
            key: "addImage",
            value: function (e, t, i, n) {
              var o = new Image();
              t && !this.fullScreenView
                ? (o.setAttribute("data-src", e),
                  (o.className = o.className.length
                    ? o.className + " " + i
                    : i),
                  0 === n &&
                    ((this.lazyloadInitImage = o),
                    (o.style.position = "absolute"),
                    (o.style.top = "0"),
                    (o.style.left = "0"),
                    this.innerBox.appendChild(o)))
                : (o.src = e),
                (o.onload = this.onImageLoad.bind(this, n)),
                (o.onerror = this.onImageLoad.bind(this, n)),
                this.images.push(o);
            },
          },
          {
            key: "destroy",
            value: function () {
              stop();
              var e = this.container,
                t = e.cloneNode(!0),
                i = t.querySelector(".cloudimage-inner-box");
              (t.className = t.className.replace(" initialized", "")),
                (t.style.position = "relative"),
                (t.style.width = "100%"),
                (t.style.cursor = "default"),
                t.setAttribute("draggable", "false"),
                (t.style.minHeight = "auto"),
                t.removeChild(i),
                e.parentNode.replaceChild(t, e);
            },
          },
          {
            key: "initControls",
            value: function () {
              var e = this,
                t = this.controlReverse ? !this.spinReverse : this.spinReverse,
                i = this.container.querySelector(".cloudimage-360-prev"),
                n = this.container.querySelector(".cloudimage-360-next");
              if (i || n) {
                var s = function (t) {
                    t.stopPropagation(),
                      e.onSpin(),
                      e.prev(),
                      (e.loopTimeoutId = window.setInterval(
                        e.prev.bind(e),
                        e.autoplaySpeed
                      ));
                  },
                  r = function (t) {
                    t.stopPropagation(),
                      e.onSpin(),
                      e.next(),
                      (e.loopTimeoutId = window.setInterval(
                        e.next.bind(e),
                        e.autoplaySpeed
                      ));
                  },
                  a = function () {
                    e.onFinishSpin(), window.clearTimeout(e.loopTimeoutId);
                  },
                  c = function () {
                    e.onFinishSpin(), window.clearTimeout(e.loopTimeoutId);
                  };
                i &&
                  ((i.style.display = "block"),
                  i.addEventListener("mousedown", t ? r : s),
                  i.addEventListener("touchstart", t ? r : s),
                  i.addEventListener("mouseup", t ? c : a),
                  i.addEventListener("touchend", t ? c : a),
                  (this.prevElem = i)),
                  n &&
                    ((n.style.display = "block"),
                    n.addEventListener("mousedown", t ? s : r),
                    n.addEventListener("touchstart", t ? s : r),
                    n.addEventListener("mouseup", t ? a : c),
                    n.addEventListener("touchend", t ? a : c),
                    (this.nextElem = n)),
                  (t ? n : i) &&
                    this.stopAtEdges &&
                    (0, o.addClass)(t ? n : i, "not-active");
              }
            },
          },
          {
            key: "addInnerBox",
            value: function () {
              (this.innerBox = document.createElement("div")),
                (this.innerBox.className = "cloudimage-inner-box"),
                this.container.appendChild(this.innerBox);
            },
          },
          {
            key: "addCanvas",
            value: function () {
              (this.canvas = document.createElement("canvas")),
                (this.canvas.style.width = "100%"),
                (this.canvas.style.fontSize = "0"),
                this.ratio &&
                  ((this.container.style.minHeight =
                    this.container.offsetWidth * this.ratio + "px"),
                  (this.canvas.height = parseInt(
                    this.container.style.minHeight
                  ))),
                this.innerBox.appendChild(this.canvas);
            },
          },
          {
            key: "attachEvents",
            value: function (e, t, i) {
              e &&
                (this.container.addEventListener(
                  "mousedown",
                  this.mousedown.bind(this)
                ),
                this.container.addEventListener(
                  "mouseup",
                  this.mouseup.bind(this)
                ),
                this.container.addEventListener(
                  "mousemove",
                  this.mousemove.bind(this)
                )),
                t &&
                  (this.container.addEventListener(
                    "touchstart",
                    this.touchstart.bind(this),
                    { passive: !0 }
                  ),
                  this.container.addEventListener(
                    "touchend",
                    this.touchend.bind(this),
                    { passive: !0 }
                  ),
                  this.container.addEventListener(
                    "touchmove",
                    this.touchmove.bind(this)
                  )),
                i
                  ? (document.addEventListener(
                      "keydown",
                      this.keydown.bind(this)
                    ),
                    document.addEventListener("keyup", this.keyup.bind(this)))
                  : document.addEventListener(
                      "keydown",
                      this.keydownGeneral.bind(this)
                    );
            },
          },
          {
            key: "applyStylesToContainer",
            value: function () {
              (this.container.style.position = "relative"),
                (this.container.style.width = "100%"),
                (this.container.style.cursor = "wait"),
                this.container.setAttribute("draggable", "false"),
                (this.container.className =
                  this.container.className + " initialized");
            },
          },
          {
            key: "init",
            value: function (e) {
              var t = (0, o.get360ViewProps)(e),
                i = t.folder,
                n = t.filename,
                s = t.imageList,
                r = t.indexZeroBase,
                a = t.amount,
                c = t.draggable,
                l = void 0 === c || c,
                u = t.swipeable,
                h = void 0 === u || u,
                d = t.keys,
                f = t.bottomCircle,
                v = t.bottomCircleOffset,
                p = t.boxShadow,
                y = t.autoplay,
                g = t.speed,
                m = t.autoplayReverse,
                w = t.fullScreen,
                x = t.magnifier,
                b = t.ratio,
                I = t.responsive,
                S = t.ciToken,
                C = t.ciSize,
                k = t.ciOperation,
                E = t.ciFilters,
                L = t.lazyload,
                O = t.lazySelector,
                A = t.spinReverse,
                M = t.dragSpeed,
                P = t.stopAtEdges,
                V = t.controlReverse,
                R = { ciSize: C, ciToken: S, ciOperation: k, ciFilters: E };
              this.addInnerBox(),
                this.addLoader(),
                (this.folder = i),
                (this.filename = n),
                (this.imageList = s),
                (this.indexZeroBase = r),
                (this.amount = a),
                (this.bottomCircle = f),
                (this.bottomCircleOffset = v),
                (this.boxShadow = p),
                (this.autoplay = y && !this.isMobile),
                (this.speed = g),
                (this.reversed = m),
                (this.fullScreen = w),
                (this.magnifier = !(this.isMobile || !x) && x),
                (this.lazyload = L),
                (this.ratio = b),
                (this.spinReverse = A),
                (this.controlReverse = V),
                (this.dragSpeed = M),
                (this.autoplaySpeed = (36 * this.speed) / this.amount),
                (this.stopAtEdges = P),
                this.applyStylesToContainer(),
                this.addCanvas();
              var j = this.getSrc(I, e, i, n, R);
              this.preloadImages(a, j, L, O, e, I, R),
                this.attachEvents(l, h, d);
            },
          },
        ]),
        e
      );
    })();
    t.default = s;
  },
  function (e, t, i) {
    "use strict";
    Object.defineProperty(t, "__esModule", { value: !0 });
    var n,
      o = function (e, t) {
        var i = s(e, t),
          n = s(e, "data-" + t);
        return (null !== i && "false" !== i) || (null !== n && "false" !== n);
      },
      s = function (e, t) {
        return e.getAttribute(t);
      },
      r =
        ((n = !0),
        function (e, t, i, o) {
          var s =
              arguments.length > 4 && void 0 !== arguments[4]
                ? arguments[4]
                : 1,
            r =
              arguments.length > 5 && void 0 !== arguments[5]
                ? arguments[5]
                : 0.5,
            a =
              arguments.length > 6 && void 0 !== arguments[6]
                ? arguments[6]
                : 0.5,
            c = i / o,
            l = e / t,
            u = e * s,
            h = t * s;
          return (
            (n ? c > l : c < l) ? (h = u / c) : (u = h * c),
            { width: u, height: h, offsetX: (e - u) * r, offsetY: (t - h) * a }
          );
        });
    (t.get360ViewProps = function (e) {
      return {
        folder: s(e, "folder") || s(e, "data-folder") || "/",
        filename:
          s(e, "filename") || s(e, "data-filename") || "image-{index}.jpg",
        imageList: s(e, "image-list") || s(e, "data-image-list") || null,
        indexZeroBase: parseInt(
          s(e, "index-zero-base") || s(e, "data-index-zero-base") || 0,
          10
        ),
        amount: parseInt(s(e, "amount") || s(e, "data-amount") || 36, 10),
        speed: parseInt(s(e, "speed") || s(e, "data-speed") || 80, 10),
        dragSpeed: parseInt(
          s(e, "drag-speed") || s(e, "data-drag-speed") || 150,
          10
        ),
        keys: o(e, "keys"),
        boxShadow: s(e, "box-shadow") || s(e, "data-box-shadow"),
        autoplay: o(e, "autoplay"),
        autoplayReverse: o(e, "autoplay-reverse"),
        bottomCircle: o(e, "bottom-circle"),
        fullScreen: o(e, "full-screen"),
        magnifier:
          (null !== s(e, "magnifier") || null !== s(e, "data-magnifier")) &&
          parseInt(s(e, "magnifier") || s(e, "data-magnifier"), 10),
        bottomCircleOffset: parseInt(
          s(e, "bottom-circle-offset") ||
            s(e, "data-bottom-circle-offset") ||
            5,
          10
        ),
        ratio: parseFloat(s(e, "ratio") || s(e, "data-ratio") || 0) || !1,
        responsive: o(e, "responsive"),
        ciToken: s(e, "responsive") || s(e, "data-responsive") || "demo",
        ciSize: s(e, "size") || s(e, "data-size"),
        ciOperation: s(e, "operation") || s(e, "data-operation") || "width",
        ciFilters: s(e, "filters") || s(e, "data-filters") || "q35",
        lazyload: o(e, "lazyload"),
        lazySelector:
          s(e, "lazyload-selector") ||
          s(e, "data-lazyload-selector") ||
          "lazyload",
        spinReverse: o(e, "spin-reverse"),
        controlReverse: o(e, "control-reverse"),
        stopAtEdges: o(e, "stop-at-edges"),
      };
    }),
      (t.set360ViewIconStyles = function (e) {
        (e.style.position = "absolute"),
          (e.style.top = "0"),
          (e.style.bottom = "0"),
          (e.style.left = "0"),
          (e.style.right = "0"),
          (e.style.width = "100px"),
          (e.style.height = "100px"),
          (e.style.margin = "auto"),
          (e.style.backgroundColor = "rgba(255,255,255,0.8)"),
          (e.style.borderRadius = "50%"),
          (e.style.boxShadow = "rgb(255, 255, 255, 0.5) 0px 0px 4px"),
          (e.style.transition = "0.5s all"),
          (e.style.color = "rgb(80,80,80)"),
          (e.style.textAlign = "center"),
          (e.style.lineHeight = "100px"),
          (e.style.zIndex = "2");
      }),
      (t.set360ViewCircleIconStyles = function (e, t) {
        (e.src =
          "https://scaleflex.ultrafast.io/https://scaleflex.api.airstore.io/v1/get/_/2236d56f-914a-5a8b-a3ae-f7bde1c50000/360.svg"),
          (e.style.position = "absolute"),
          (e.style.top = "auto"),
          (e.style.bottom = t + "%"),
          (e.style.left = "0"),
          (e.style.right = "0"),
          (e.style.width = "80%"),
          (e.style.height = "auto"),
          (e.style.margin = "auto"),
          (e.style.transition = "0.5s all"),
          (e.style.zIndex = "2");
      }),
      (t.setLoaderStyles = function (e) {
        (e.className = "cloudimage-360-loader"),
          (e.style.position = "absolute"),
          (e.style.zIndex = "100"),
          (e.style.top = "0"),
          (e.style.left = "0"),
          (e.style.right = "0"),
          (e.style.width = "0%"),
          (e.style.height = "8px"),
          (e.style.background = "rgb(165,175,184)");
      }),
      (t.setBoxShadowStyles = function (e, t) {
        (e.className = "cloudimage-360-box-shadow"),
          (e.style.position = "absolute"),
          (e.style.zIndex = "99"),
          (e.style.top = "0"),
          (e.style.left = "0"),
          (e.style.right = "0"),
          (e.style.bottom = "0"),
          (e.style.boxShadow = t);
      }),
      (t.setView360Icon = function (e) {
        e.style.background =
          "rgba(255,255,255,0.8) url('https://scaleflex.ultrafast.io/https://scaleflex.airstore.io/filerobot/js-cloudimage-360-view/360_view.svg') 50% 50% / contain no-repeat";
      }),
      (t.magnify = function (e, t, i, n) {
        var o, s;
        function r(t) {
          var r,
            a = void 0,
            c = void 0;
          t.preventDefault(),
            (r = (function (t) {
              var i,
                n = 0,
                o = 0;
              return (
                (t = t || window.event),
                (i = e.getBoundingClientRect()),
                (n = t.pageX - i.left),
                (o = t.pageY - i.top),
                (n -= window.pageXOffset),
                (o -= window.pageYOffset),
                { x: n, y: o }
              );
            })(t)),
            (a = r.x),
            (c = r.y),
            a > e.offsetWidth - o / n && (a = e.offsetWidth - o / n),
            a < o / n && (a = o / n),
            c > e.offsetHeight - s / n && (c = e.offsetHeight - s / n),
            c < s / n && (c = s / n),
            (i.style.left = a - o + "px"),
            (i.style.top = c - s + "px"),
            (i.style.backgroundPosition =
              "-" + (a * n - o + 3) + "px -" + (c * n - s + 3) + "px");
        }
        i.setAttribute("class", "img-magnifier-glass"),
          e.prepend(i),
          (i.style.backgroundColor = "#fff"),
          (i.style.backgroundImage = "url('" + t + "')"),
          (i.style.backgroundRepeat = "no-repeat"),
          (i.style.backgroundSize =
            e.offsetWidth * n + "px " + e.offsetHeight * n + "px"),
          (i.style.position = "absolute"),
          (i.style.border = "3px solid #000"),
          (i.style.borderRadius = "50%"),
          (i.style.cursor = "wait"),
          (i.style.lineHeight = "200px"),
          (i.style.textAlign = "center"),
          (i.style.zIndex = "1000"),
          (i.style.width = "250px"),
          (i.style.height = "250px"),
          (i.style.top = "-75px"),
          (i.style.right = "-85px"),
          (o = i.offsetWidth / 2),
          (s = i.offsetHeight / 2),
          i.addEventListener("mousemove", r),
          e.addEventListener("mousemove", r),
          i.addEventListener("touchmove", r),
          e.addEventListener("touchmove", r);
      }),
      (t.setMagnifyIconStyles = function (e, t) {
        (e.style.position = "absolute"),
          (e.style.top = t ? "35px" : "5px"),
          (e.style.right = "5px"),
          (e.style.width = "25px"),
          (e.style.height = "25px"),
          (e.style.zIndex = "101"),
          (e.style.cursor = "pointer"),
          (e.style.background =
            "url('https://scaleflex.ultrafast.io/https://scaleflex.airstore.io/filerobot/js-cloudimage-360-view/loupe.svg') 50% 50% / cover no-repeat");
      }),
      (t.setFullScreenModalStyles = function (e) {
        (e.style.position = "fixed"),
          (e.style.top = "0"),
          (e.style.bottom = "0"),
          (e.style.left = "0"),
          (e.style.right = "0"),
          (e.style.width = "100%"),
          (e.style.height = "100%"),
          (e.style.zIndex = "999"),
          (e.style.background = "#fff");
      }),
      (t.setFullScreenIconStyles = function (e) {
        (e.style.position = "absolute"),
          (e.style.top = "5px"),
          (e.style.right = "5px"),
          (e.style.width = "25px"),
          (e.style.height = "25px"),
          (e.style.zIndex = "101"),
          (e.style.cursor = "pointer"),
          (e.style.background =
            "url('https://scaleflex.ultrafast.io/https://scaleflex.airstore.io/filerobot/js-cloudimage-360-view/full_screen.svg') 50% 50% / cover no-repeat");
      }),
      (t.setCloseFullScreenViewStyles = function (e) {
        (e.style.position = "absolute"),
          (e.style.top = "5px"),
          (e.style.right = "5px"),
          (e.style.width = "25px"),
          (e.style.height = "25px"),
          (e.style.zIndex = "101"),
          (e.style.cursor = "pointer"),
          (e.style.background =
            "url('https://scaleflex.ultrafast.io/https://scaleflex.airstore.io/filerobot/js-cloudimage-360-view/cross.svg') 50% 50% / cover no-repeat");
      }),
      (t.getResponsiveWidthOfContainer = function (e) {
        return (t = e) <= 25
          ? "25"
          : t <= 50
          ? "50"
          : (100 * Math.ceil(t / 100)).toString();
        var t;
      }),
      (t.getSizeAccordingToPixelRatio = function (e) {
        var t = e.toString().split("x"),
          i = [];
        return (
          [].forEach.call(t, function (e) {
            i.push(e * Math.round(window.devicePixelRatio || 1));
          }),
          i.join("x")
        );
      }),
      (t.contain = r),
      (t.addClass = function (e, t) {
        e.classList ? e.classList.add(t) : (e.className += " " + t);
      }),
      (t.removeClass = function (e, t) {
        e.classList
          ? e.classList.remove(t)
          : (e.className = e.className.replace(
              new RegExp("(^|\\b)" + t.split(" ").join("|") + "(\\b|$)", "gi"),
              " "
            ));
      }),
      (t.pad = function (e) {
        var t =
          arguments.length > 1 && void 0 !== arguments[1] ? arguments[1] : 0;
        return (e += "").length >= t
          ? e
          : new Array(t - e.length + 1).join("0") + e;
      });
  },
]);
/*
 Copyright (C) Federico Zivolo 2019
 Distributed under the MIT License (license terms are at http://opensource.org/licenses/MIT).
 */ (function (e, t) {
  "object" == typeof exports && "undefined" != typeof module
    ? (module.exports = t())
    : "function" == typeof define && define.amd
    ? define(t)
    : (e.Popper = t());
})(this, function () {
  "use strict";
  function e(e) {
    return e && "[object Function]" === {}.toString.call(e);
  }
  function t(e, t) {
    if (1 !== e.nodeType) return [];
    var o = e.ownerDocument.defaultView,
      n = o.getComputedStyle(e, null);
    return t ? n[t] : n;
  }
  function o(e) {
    return "HTML" === e.nodeName ? e : e.parentNode || e.host;
  }
  function n(e) {
    if (!e) return document.body;
    switch (e.nodeName) {
      case "HTML":
      case "BODY":
        return e.ownerDocument.body;
      case "#document":
        return e.body;
    }
    var i = t(e),
      r = i.overflow,
      p = i.overflowX,
      s = i.overflowY;
    return /(auto|scroll|overlay)/.test(r + s + p) ? e : n(o(e));
  }
  function i(e) {
    return e && e.referenceNode ? e.referenceNode : e;
  }
  function r(e) {
    return 11 === e ? re : 10 === e ? pe : re || pe;
  }
  function p(e) {
    if (!e) return document.documentElement;
    for (
      var o = r(10) ? document.body : null, n = e.offsetParent || null;
      n === o && e.nextElementSibling;

    )
      n = (e = e.nextElementSibling).offsetParent;
    var i = n && n.nodeName;
    return i && "BODY" !== i && "HTML" !== i
      ? -1 !== ["TH", "TD", "TABLE"].indexOf(n.nodeName) &&
        "static" === t(n, "position")
        ? p(n)
        : n
      : e
      ? e.ownerDocument.documentElement
      : document.documentElement;
  }
  function s(e) {
    var t = e.nodeName;
    return "BODY" !== t && ("HTML" === t || p(e.firstElementChild) === e);
  }
  function d(e) {
    return null === e.parentNode ? e : d(e.parentNode);
  }
  function a(e, t) {
    if (!e || !e.nodeType || !t || !t.nodeType) return document.documentElement;
    var o = e.compareDocumentPosition(t) & Node.DOCUMENT_POSITION_FOLLOWING,
      n = o ? e : t,
      i = o ? t : e,
      r = document.createRange();
    r.setStart(n, 0), r.setEnd(i, 0);
    var l = r.commonAncestorContainer;
    if ((e !== l && t !== l) || n.contains(i)) return s(l) ? l : p(l);
    var f = d(e);
    return f.host ? a(f.host, t) : a(e, d(t).host);
  }
  function l(e) {
    var t =
        1 < arguments.length && void 0 !== arguments[1] ? arguments[1] : "top",
      o = "top" === t ? "scrollTop" : "scrollLeft",
      n = e.nodeName;
    if ("BODY" === n || "HTML" === n) {
      var i = e.ownerDocument.documentElement,
        r = e.ownerDocument.scrollingElement || i;
      return r[o];
    }
    return e[o];
  }
  function f(e, t) {
    var o = 2 < arguments.length && void 0 !== arguments[2] && arguments[2],
      n = l(t, "top"),
      i = l(t, "left"),
      r = o ? -1 : 1;
    return (
      (e.top += n * r),
      (e.bottom += n * r),
      (e.left += i * r),
      (e.right += i * r),
      e
    );
  }
  function m(e, t) {
    var o = "x" === t ? "Left" : "Top",
      n = "Left" == o ? "Right" : "Bottom";
    return (
      parseFloat(e["border" + o + "Width"], 10) +
      parseFloat(e["border" + n + "Width"], 10)
    );
  }
  function h(e, t, o, n) {
    return ee(
      t["offset" + e],
      t["scroll" + e],
      o["client" + e],
      o["offset" + e],
      o["scroll" + e],
      r(10)
        ? parseInt(o["offset" + e]) +
            parseInt(n["margin" + ("Height" === e ? "Top" : "Left")]) +
            parseInt(n["margin" + ("Height" === e ? "Bottom" : "Right")])
        : 0
    );
  }
  function c(e) {
    var t = e.body,
      o = e.documentElement,
      n = r(10) && getComputedStyle(o);
    return { height: h("Height", t, o, n), width: h("Width", t, o, n) };
  }
  function g(e) {
    return le({}, e, { right: e.left + e.width, bottom: e.top + e.height });
  }
  function u(e) {
    var o = {};
    try {
      if (r(10)) {
        o = e.getBoundingClientRect();
        var n = l(e, "top"),
          i = l(e, "left");
        (o.top += n), (o.left += i), (o.bottom += n), (o.right += i);
      } else o = e.getBoundingClientRect();
    } catch (t) {}
    var p = {
        left: o.left,
        top: o.top,
        width: o.right - o.left,
        height: o.bottom - o.top,
      },
      s = "HTML" === e.nodeName ? c(e.ownerDocument) : {},
      d = s.width || e.clientWidth || p.width,
      a = s.height || e.clientHeight || p.height,
      f = e.offsetWidth - d,
      h = e.offsetHeight - a;
    if (f || h) {
      var u = t(e);
      (f -= m(u, "x")), (h -= m(u, "y")), (p.width -= f), (p.height -= h);
    }
    return g(p);
  }
  function b(e, o) {
    var i = 2 < arguments.length && void 0 !== arguments[2] && arguments[2],
      p = r(10),
      s = "HTML" === o.nodeName,
      d = u(e),
      a = u(o),
      l = n(e),
      m = t(o),
      h = parseFloat(m.borderTopWidth, 10),
      c = parseFloat(m.borderLeftWidth, 10);
    i && s && ((a.top = ee(a.top, 0)), (a.left = ee(a.left, 0)));
    var b = g({
      top: d.top - a.top - h,
      left: d.left - a.left - c,
      width: d.width,
      height: d.height,
    });
    if (((b.marginTop = 0), (b.marginLeft = 0), !p && s)) {
      var w = parseFloat(m.marginTop, 10),
        y = parseFloat(m.marginLeft, 10);
      (b.top -= h - w),
        (b.bottom -= h - w),
        (b.left -= c - y),
        (b.right -= c - y),
        (b.marginTop = w),
        (b.marginLeft = y);
    }
    return (
      (p && !i ? o.contains(l) : o === l && "BODY" !== l.nodeName) &&
        (b = f(b, o)),
      b
    );
  }
  function w(e) {
    var t = 1 < arguments.length && void 0 !== arguments[1] && arguments[1],
      o = e.ownerDocument.documentElement,
      n = b(e, o),
      i = ee(o.clientWidth, window.innerWidth || 0),
      r = ee(o.clientHeight, window.innerHeight || 0),
      p = t ? 0 : l(o),
      s = t ? 0 : l(o, "left"),
      d = {
        top: p - n.top + n.marginTop,
        left: s - n.left + n.marginLeft,
        width: i,
        height: r,
      };
    return g(d);
  }
  function y(e) {
    var n = e.nodeName;
    if ("BODY" === n || "HTML" === n) return !1;
    if ("fixed" === t(e, "position")) return !0;
    var i = o(e);
    return !!i && y(i);
  }
  function E(e) {
    if (!e || !e.parentElement || r()) return document.documentElement;
    for (var o = e.parentElement; o && "none" === t(o, "transform"); )
      o = o.parentElement;
    return o || document.documentElement;
  }
  function v(e, t, r, p) {
    var s = 4 < arguments.length && void 0 !== arguments[4] && arguments[4],
      d = { top: 0, left: 0 },
      l = s ? E(e) : a(e, i(t));
    if ("viewport" === p) d = w(l, s);
    else {
      var f;
      "scrollParent" === p
        ? ((f = n(o(t))),
          "BODY" === f.nodeName && (f = e.ownerDocument.documentElement))
        : "window" === p
        ? (f = e.ownerDocument.documentElement)
        : (f = p);
      var m = b(f, l, s);
      if ("HTML" === f.nodeName && !y(l)) {
        var h = c(e.ownerDocument),
          g = h.height,
          u = h.width;
        (d.top += m.top - m.marginTop),
          (d.bottom = g + m.top),
          (d.left += m.left - m.marginLeft),
          (d.right = u + m.left);
      } else d = m;
    }
    r = r || 0;
    var v = "number" == typeof r;
    return (
      (d.left += v ? r : r.left || 0),
      (d.top += v ? r : r.top || 0),
      (d.right -= v ? r : r.right || 0),
      (d.bottom -= v ? r : r.bottom || 0),
      d
    );
  }
  function x(e) {
    var t = e.width,
      o = e.height;
    return t * o;
  }
  function O(e, t, o, n, i) {
    var r = 5 < arguments.length && void 0 !== arguments[5] ? arguments[5] : 0;
    if (-1 === e.indexOf("auto")) return e;
    var p = v(o, n, r, i),
      s = {
        top: { width: p.width, height: t.top - p.top },
        right: { width: p.right - t.right, height: p.height },
        bottom: { width: p.width, height: p.bottom - t.bottom },
        left: { width: t.left - p.left, height: p.height },
      },
      d = Object.keys(s)
        .map(function (e) {
          return le({ key: e }, s[e], { area: x(s[e]) });
        })
        .sort(function (e, t) {
          return t.area - e.area;
        }),
      a = d.filter(function (e) {
        var t = e.width,
          n = e.height;
        return t >= o.clientWidth && n >= o.clientHeight;
      }),
      l = 0 < a.length ? a[0].key : d[0].key,
      f = e.split("-")[1];
    return l + (f ? "-" + f : "");
  }
  function L(e, t, o) {
    var n =
        3 < arguments.length && void 0 !== arguments[3] ? arguments[3] : null,
      r = n ? E(t) : a(t, i(o));
    return b(o, r, n);
  }
  function S(e) {
    var t = e.ownerDocument.defaultView,
      o = t.getComputedStyle(e),
      n = parseFloat(o.marginTop || 0) + parseFloat(o.marginBottom || 0),
      i = parseFloat(o.marginLeft || 0) + parseFloat(o.marginRight || 0),
      r = { width: e.offsetWidth + i, height: e.offsetHeight + n };
    return r;
  }
  function T(e) {
    var t = { left: "right", right: "left", bottom: "top", top: "bottom" };
    return e.replace(/left|right|bottom|top/g, function (e) {
      return t[e];
    });
  }
  function C(e, t, o) {
    o = o.split("-")[0];
    var n = S(e),
      i = { width: n.width, height: n.height },
      r = -1 !== ["right", "left"].indexOf(o),
      p = r ? "top" : "left",
      s = r ? "left" : "top",
      d = r ? "height" : "width",
      a = r ? "width" : "height";
    return (
      (i[p] = t[p] + t[d] / 2 - n[d] / 2),
      (i[s] = o === s ? t[s] - n[a] : t[T(s)]),
      i
    );
  }
  function D(e, t) {
    return Array.prototype.find ? e.find(t) : e.filter(t)[0];
  }
  function N(e, t, o) {
    if (Array.prototype.findIndex)
      return e.findIndex(function (e) {
        return e[t] === o;
      });
    var n = D(e, function (e) {
      return e[t] === o;
    });
    return e.indexOf(n);
  }
  function P(t, o, n) {
    var i = void 0 === n ? t : t.slice(0, N(t, "name", n));
    return (
      i.forEach(function (t) {
        t["function"] &&
          console.warn("`modifier.function` is deprecated, use `modifier.fn`!");
        var n = t["function"] || t.fn;
        t.enabled &&
          e(n) &&
          ((o.offsets.popper = g(o.offsets.popper)),
          (o.offsets.reference = g(o.offsets.reference)),
          (o = n(o, t)));
      }),
      o
    );
  }
  function k() {
    if (!this.state.isDestroyed) {
      var e = {
        instance: this,
        styles: {},
        arrowStyles: {},
        attributes: {},
        flipped: !1,
        offsets: {},
      };
      (e.offsets.reference = L(
        this.state,
        this.popper,
        this.reference,
        this.options.positionFixed
      )),
        (e.placement = O(
          this.options.placement,
          e.offsets.reference,
          this.popper,
          this.reference,
          this.options.modifiers.flip.boundariesElement,
          this.options.modifiers.flip.padding
        )),
        (e.originalPlacement = e.placement),
        (e.positionFixed = this.options.positionFixed),
        (e.offsets.popper = C(this.popper, e.offsets.reference, e.placement)),
        (e.offsets.popper.position = this.options.positionFixed
          ? "fixed"
          : "absolute"),
        (e = P(this.modifiers, e)),
        this.state.isCreated
          ? this.options.onUpdate(e)
          : ((this.state.isCreated = !0), this.options.onCreate(e));
    }
  }
  function W(e, t) {
    return e.some(function (e) {
      var o = e.name,
        n = e.enabled;
      return n && o === t;
    });
  }
  function B(e) {
    for (
      var t = [!1, "ms", "Webkit", "Moz", "O"],
        o = e.charAt(0).toUpperCase() + e.slice(1),
        n = 0;
      n < t.length;
      n++
    ) {
      var i = t[n],
        r = i ? "" + i + o : e;
      if ("undefined" != typeof document.body.style[r]) return r;
    }
    return null;
  }
  function H() {
    return (
      (this.state.isDestroyed = !0),
      W(this.modifiers, "applyStyle") &&
        (this.popper.removeAttribute("x-placement"),
        (this.popper.style.position = ""),
        (this.popper.style.top = ""),
        (this.popper.style.left = ""),
        (this.popper.style.right = ""),
        (this.popper.style.bottom = ""),
        (this.popper.style.willChange = ""),
        (this.popper.style[B("transform")] = "")),
      this.disableEventListeners(),
      this.options.removeOnDestroy &&
        this.popper.parentNode.removeChild(this.popper),
      this
    );
  }
  function A(e) {
    var t = e.ownerDocument;
    return t ? t.defaultView : window;
  }
  function M(e, t, o, i) {
    var r = "BODY" === e.nodeName,
      p = r ? e.ownerDocument.defaultView : e;
    p.addEventListener(t, o, { passive: !0 }),
      r || M(n(p.parentNode), t, o, i),
      i.push(p);
  }
  function F(e, t, o, i) {
    (o.updateBound = i),
      A(e).addEventListener("resize", o.updateBound, { passive: !0 });
    var r = n(e);
    return (
      M(r, "scroll", o.updateBound, o.scrollParents),
      (o.scrollElement = r),
      (o.eventsEnabled = !0),
      o
    );
  }
  function I() {
    this.state.eventsEnabled ||
      (this.state = F(
        this.reference,
        this.options,
        this.state,
        this.scheduleUpdate
      ));
  }
  function R(e, t) {
    return (
      A(e).removeEventListener("resize", t.updateBound),
      t.scrollParents.forEach(function (e) {
        e.removeEventListener("scroll", t.updateBound);
      }),
      (t.updateBound = null),
      (t.scrollParents = []),
      (t.scrollElement = null),
      (t.eventsEnabled = !1),
      t
    );
  }
  function U() {
    this.state.eventsEnabled &&
      (cancelAnimationFrame(this.scheduleUpdate),
      (this.state = R(this.reference, this.state)));
  }
  function Y(e) {
    return "" !== e && !isNaN(parseFloat(e)) && isFinite(e);
  }
  function V(e, t) {
    Object.keys(t).forEach(function (o) {
      var n = "";
      -1 !== ["width", "height", "top", "right", "bottom", "left"].indexOf(o) &&
        Y(t[o]) &&
        (n = "px"),
        (e.style[o] = t[o] + n);
    });
  }
  function j(e, t) {
    Object.keys(t).forEach(function (o) {
      var n = t[o];
      !1 === n ? e.removeAttribute(o) : e.setAttribute(o, t[o]);
    });
  }
  function q(e, t) {
    var o = e.offsets,
      n = o.popper,
      i = o.reference,
      r = $,
      p = function (e) {
        return e;
      },
      s = r(i.width),
      d = r(n.width),
      a = -1 !== ["left", "right"].indexOf(e.placement),
      l = -1 !== e.placement.indexOf("-"),
      f = t ? (a || l || s % 2 == d % 2 ? r : Z) : p,
      m = t ? r : p;
    return {
      left: f(1 == s % 2 && 1 == d % 2 && !l && t ? n.left - 1 : n.left),
      top: m(n.top),
      bottom: m(n.bottom),
      right: f(n.right),
    };
  }
  function K(e, t, o) {
    var n = D(e, function (e) {
        var o = e.name;
        return o === t;
      }),
      i =
        !!n &&
        e.some(function (e) {
          return e.name === o && e.enabled && e.order < n.order;
        });
    if (!i) {
      var r = "`" + t + "`";
      console.warn(
        "`" +
          o +
          "`" +
          " modifier is required by " +
          r +
          " modifier in order to work, be sure to include it before " +
          r +
          "!"
      );
    }
    return i;
  }
  function z(e) {
    return "end" === e ? "start" : "start" === e ? "end" : e;
  }
  function G(e) {
    var t = 1 < arguments.length && void 0 !== arguments[1] && arguments[1],
      o = he.indexOf(e),
      n = he.slice(o + 1).concat(he.slice(0, o));
    return t ? n.reverse() : n;
  }
  function _(e, t, o, n) {
    var i = e.match(/((?:\-|\+)?\d*\.?\d*)(.*)/),
      r = +i[1],
      p = i[2];
    if (!r) return e;
    if (0 === p.indexOf("%")) {
      var s;
      switch (p) {
        case "%p":
          s = o;
          break;
        case "%":
        case "%r":
        default:
          s = n;
      }
      var d = g(s);
      return (d[t] / 100) * r;
    }
    if ("vh" === p || "vw" === p) {
      var a;
      return (
        (a =
          "vh" === p
            ? ee(document.documentElement.clientHeight, window.innerHeight || 0)
            : ee(document.documentElement.clientWidth, window.innerWidth || 0)),
        (a / 100) * r
      );
    }
    return r;
  }
  function X(e, t, o, n) {
    var i = [0, 0],
      r = -1 !== ["right", "left"].indexOf(n),
      p = e.split(/(\+|\-)/).map(function (e) {
        return e.trim();
      }),
      s = p.indexOf(
        D(p, function (e) {
          return -1 !== e.search(/,|\s/);
        })
      );
    p[s] &&
      -1 === p[s].indexOf(",") &&
      console.warn(
        "Offsets separated by white space(s) are deprecated, use a comma (,) instead."
      );
    var d = /\s*,\s*|\s+/,
      a =
        -1 === s
          ? [p]
          : [
              p.slice(0, s).concat([p[s].split(d)[0]]),
              [p[s].split(d)[1]].concat(p.slice(s + 1)),
            ];
    return (
      (a = a.map(function (e, n) {
        var i = (1 === n ? !r : r) ? "height" : "width",
          p = !1;
        return e
          .reduce(function (e, t) {
            return "" === e[e.length - 1] && -1 !== ["+", "-"].indexOf(t)
              ? ((e[e.length - 1] = t), (p = !0), e)
              : p
              ? ((e[e.length - 1] += t), (p = !1), e)
              : e.concat(t);
          }, [])
          .map(function (e) {
            return _(e, i, t, o);
          });
      })),
      a.forEach(function (e, t) {
        e.forEach(function (o, n) {
          Y(o) && (i[t] += o * ("-" === e[n - 1] ? -1 : 1));
        });
      }),
      i
    );
  }
  function J(e, t) {
    var o,
      n = t.offset,
      i = e.placement,
      r = e.offsets,
      p = r.popper,
      s = r.reference,
      d = i.split("-")[0];
    return (
      (o = Y(+n) ? [+n, 0] : X(n, p, s, d)),
      "left" === d
        ? ((p.top += o[0]), (p.left -= o[1]))
        : "right" === d
        ? ((p.top += o[0]), (p.left += o[1]))
        : "top" === d
        ? ((p.left += o[0]), (p.top -= o[1]))
        : "bottom" === d && ((p.left += o[0]), (p.top += o[1])),
      (e.popper = p),
      e
    );
  }
  var Q = Math.min,
    Z = Math.floor,
    $ = Math.round,
    ee = Math.max,
    te =
      "undefined" != typeof window &&
      "undefined" != typeof document &&
      "undefined" != typeof navigator,
    oe = (function () {
      for (var e = ["Edge", "Trident", "Firefox"], t = 0; t < e.length; t += 1)
        if (te && 0 <= navigator.userAgent.indexOf(e[t])) return 1;
      return 0;
    })(),
    ne = te && window.Promise,
    ie = ne
      ? function (e) {
          var t = !1;
          return function () {
            t ||
              ((t = !0),
              window.Promise.resolve().then(function () {
                (t = !1), e();
              }));
          };
        }
      : function (e) {
          var t = !1;
          return function () {
            t ||
              ((t = !0),
              setTimeout(function () {
                (t = !1), e();
              }, oe));
          };
        },
    re = te && !!(window.MSInputMethodContext && document.documentMode),
    pe = te && /MSIE 10/.test(navigator.userAgent),
    se = function (e, t) {
      if (!(e instanceof t))
        throw new TypeError("Cannot call a class as a function");
    },
    de = (function () {
      function e(e, t) {
        for (var o, n = 0; n < t.length; n++)
          (o = t[n]),
            (o.enumerable = o.enumerable || !1),
            (o.configurable = !0),
            "value" in o && (o.writable = !0),
            Object.defineProperty(e, o.key, o);
      }
      return function (t, o, n) {
        return o && e(t.prototype, o), n && e(t, n), t;
      };
    })(),
    ae = function (e, t, o) {
      return (
        t in e
          ? Object.defineProperty(e, t, {
              value: o,
              enumerable: !0,
              configurable: !0,
              writable: !0,
            })
          : (e[t] = o),
        e
      );
    },
    le =
      Object.assign ||
      function (e) {
        for (var t, o = 1; o < arguments.length; o++)
          for (var n in ((t = arguments[o]), t))
            Object.prototype.hasOwnProperty.call(t, n) && (e[n] = t[n]);
        return e;
      },
    fe = te && /Firefox/i.test(navigator.userAgent),
    me = [
      "auto-start",
      "auto",
      "auto-end",
      "top-start",
      "top",
      "top-end",
      "right-start",
      "right",
      "right-end",
      "bottom-end",
      "bottom",
      "bottom-start",
      "left-end",
      "left",
      "left-start",
    ],
    he = me.slice(3),
    ce = {
      FLIP: "flip",
      CLOCKWISE: "clockwise",
      COUNTERCLOCKWISE: "counterclockwise",
    },
    ge = (function () {
      function t(o, n) {
        var i = this,
          r =
            2 < arguments.length && void 0 !== arguments[2] ? arguments[2] : {};
        se(this, t),
          (this.scheduleUpdate = function () {
            return requestAnimationFrame(i.update);
          }),
          (this.update = ie(this.update.bind(this))),
          (this.options = le({}, t.Defaults, r)),
          (this.state = { isDestroyed: !1, isCreated: !1, scrollParents: [] }),
          (this.reference = o && o.jquery ? o[0] : o),
          (this.popper = n && n.jquery ? n[0] : n),
          (this.options.modifiers = {}),
          Object.keys(le({}, t.Defaults.modifiers, r.modifiers)).forEach(
            function (e) {
              i.options.modifiers[e] = le(
                {},
                t.Defaults.modifiers[e] || {},
                r.modifiers ? r.modifiers[e] : {}
              );
            }
          ),
          (this.modifiers = Object.keys(this.options.modifiers)
            .map(function (e) {
              return le({ name: e }, i.options.modifiers[e]);
            })
            .sort(function (e, t) {
              return e.order - t.order;
            })),
          this.modifiers.forEach(function (t) {
            t.enabled &&
              e(t.onLoad) &&
              t.onLoad(i.reference, i.popper, i.options, t, i.state);
          }),
          this.update();
        var p = this.options.eventsEnabled;
        p && this.enableEventListeners(), (this.state.eventsEnabled = p);
      }
      return (
        de(t, [
          {
            key: "update",
            value: function () {
              return k.call(this);
            },
          },
          {
            key: "destroy",
            value: function () {
              return H.call(this);
            },
          },
          {
            key: "enableEventListeners",
            value: function () {
              return I.call(this);
            },
          },
          {
            key: "disableEventListeners",
            value: function () {
              return U.call(this);
            },
          },
        ]),
        t
      );
    })();
  return (
    (ge.Utils = ("undefined" == typeof window ? global : window).PopperUtils),
    (ge.placements = me),
    (ge.Defaults = {
      placement: "bottom",
      positionFixed: !1,
      eventsEnabled: !0,
      removeOnDestroy: !1,
      onCreate: function () {},
      onUpdate: function () {},
      modifiers: {
        shift: {
          order: 100,
          enabled: !0,
          fn: function (e) {
            var t = e.placement,
              o = t.split("-")[0],
              n = t.split("-")[1];
            if (n) {
              var i = e.offsets,
                r = i.reference,
                p = i.popper,
                s = -1 !== ["bottom", "top"].indexOf(o),
                d = s ? "left" : "top",
                a = s ? "width" : "height",
                l = {
                  start: ae({}, d, r[d]),
                  end: ae({}, d, r[d] + r[a] - p[a]),
                };
              e.offsets.popper = le({}, p, l[n]);
            }
            return e;
          },
        },
        offset: { order: 200, enabled: !0, fn: J, offset: 0 },
        preventOverflow: {
          order: 300,
          enabled: !0,
          fn: function (e, t) {
            var o = t.boundariesElement || p(e.instance.popper);
            e.instance.reference === o && (o = p(o));
            var n = B("transform"),
              i = e.instance.popper.style,
              r = i.top,
              s = i.left,
              d = i[n];
            (i.top = ""), (i.left = ""), (i[n] = "");
            var a = v(
              e.instance.popper,
              e.instance.reference,
              t.padding,
              o,
              e.positionFixed
            );
            (i.top = r), (i.left = s), (i[n] = d), (t.boundaries = a);
            var l = t.priority,
              f = e.offsets.popper,
              m = {
                primary: function (e) {
                  var o = f[e];
                  return (
                    f[e] < a[e] &&
                      !t.escapeWithReference &&
                      (o = ee(f[e], a[e])),
                    ae({}, e, o)
                  );
                },
                secondary: function (e) {
                  var o = "right" === e ? "left" : "top",
                    n = f[o];
                  return (
                    f[e] > a[e] &&
                      !t.escapeWithReference &&
                      (n = Q(
                        f[o],
                        a[e] - ("right" === e ? f.width : f.height)
                      )),
                    ae({}, o, n)
                  );
                },
              };
            return (
              l.forEach(function (e) {
                var t =
                  -1 === ["left", "top"].indexOf(e) ? "secondary" : "primary";
                f = le({}, f, m[t](e));
              }),
              (e.offsets.popper = f),
              e
            );
          },
          priority: ["left", "right", "top", "bottom"],
          padding: 5,
          boundariesElement: "scrollParent",
        },
        keepTogether: {
          order: 400,
          enabled: !0,
          fn: function (e) {
            var t = e.offsets,
              o = t.popper,
              n = t.reference,
              i = e.placement.split("-")[0],
              r = Z,
              p = -1 !== ["top", "bottom"].indexOf(i),
              s = p ? "right" : "bottom",
              d = p ? "left" : "top",
              a = p ? "width" : "height";
            return (
              o[s] < r(n[d]) && (e.offsets.popper[d] = r(n[d]) - o[a]),
              o[d] > r(n[s]) && (e.offsets.popper[d] = r(n[s])),
              e
            );
          },
        },
        arrow: {
          order: 500,
          enabled: !0,
          fn: function (e, o) {
            var n;
            if (!K(e.instance.modifiers, "arrow", "keepTogether")) return e;
            var i = o.element;
            if ("string" == typeof i) {
              if (((i = e.instance.popper.querySelector(i)), !i)) return e;
            } else if (!e.instance.popper.contains(i))
              return (
                console.warn(
                  "WARNING: `arrow.element` must be child of its popper element!"
                ),
                e
              );
            var r = e.placement.split("-")[0],
              p = e.offsets,
              s = p.popper,
              d = p.reference,
              a = -1 !== ["left", "right"].indexOf(r),
              l = a ? "height" : "width",
              f = a ? "Top" : "Left",
              m = f.toLowerCase(),
              h = a ? "left" : "top",
              c = a ? "bottom" : "right",
              u = S(i)[l];
            d[c] - u < s[m] && (e.offsets.popper[m] -= s[m] - (d[c] - u)),
              d[m] + u > s[c] && (e.offsets.popper[m] += d[m] + u - s[c]),
              (e.offsets.popper = g(e.offsets.popper));
            var b = d[m] + d[l] / 2 - u / 2,
              w = t(e.instance.popper),
              y = parseFloat(w["margin" + f], 10),
              E = parseFloat(w["border" + f + "Width"], 10),
              v = b - e.offsets.popper[m] - y - E;
            return (
              (v = ee(Q(s[l] - u, v), 0)),
              (e.arrowElement = i),
              (e.offsets.arrow = ((n = {}), ae(n, m, $(v)), ae(n, h, ""), n)),
              e
            );
          },
          element: "[x-arrow]",
        },
        flip: {
          order: 600,
          enabled: !0,
          fn: function (e, t) {
            if (W(e.instance.modifiers, "inner")) return e;
            if (e.flipped && e.placement === e.originalPlacement) return e;
            var o = v(
                e.instance.popper,
                e.instance.reference,
                t.padding,
                t.boundariesElement,
                e.positionFixed
              ),
              n = e.placement.split("-")[0],
              i = T(n),
              r = e.placement.split("-")[1] || "",
              p = [];
            switch (t.behavior) {
              case ce.FLIP:
                p = [n, i];
                break;
              case ce.CLOCKWISE:
                p = G(n);
                break;
              case ce.COUNTERCLOCKWISE:
                p = G(n, !0);
                break;
              default:
                p = t.behavior;
            }
            return (
              p.forEach(function (s, d) {
                if (n !== s || p.length === d + 1) return e;
                (n = e.placement.split("-")[0]), (i = T(n));
                var a = e.offsets.popper,
                  l = e.offsets.reference,
                  f = Z,
                  m =
                    ("left" === n && f(a.right) > f(l.left)) ||
                    ("right" === n && f(a.left) < f(l.right)) ||
                    ("top" === n && f(a.bottom) > f(l.top)) ||
                    ("bottom" === n && f(a.top) < f(l.bottom)),
                  h = f(a.left) < f(o.left),
                  c = f(a.right) > f(o.right),
                  g = f(a.top) < f(o.top),
                  u = f(a.bottom) > f(o.bottom),
                  b =
                    ("left" === n && h) ||
                    ("right" === n && c) ||
                    ("top" === n && g) ||
                    ("bottom" === n && u),
                  w = -1 !== ["top", "bottom"].indexOf(n),
                  y =
                    !!t.flipVariations &&
                    ((w && "start" === r && h) ||
                      (w && "end" === r && c) ||
                      (!w && "start" === r && g) ||
                      (!w && "end" === r && u)),
                  E =
                    !!t.flipVariationsByContent &&
                    ((w && "start" === r && c) ||
                      (w && "end" === r && h) ||
                      (!w && "start" === r && u) ||
                      (!w && "end" === r && g)),
                  v = y || E;
                (m || b || v) &&
                  ((e.flipped = !0),
                  (m || b) && (n = p[d + 1]),
                  v && (r = z(r)),
                  (e.placement = n + (r ? "-" + r : "")),
                  (e.offsets.popper = le(
                    {},
                    e.offsets.popper,
                    C(e.instance.popper, e.offsets.reference, e.placement)
                  )),
                  (e = P(e.instance.modifiers, e, "flip")));
              }),
              e
            );
          },
          behavior: "flip",
          padding: 5,
          boundariesElement: "viewport",
          flipVariations: !1,
          flipVariationsByContent: !1,
        },
        inner: {
          order: 700,
          enabled: !1,
          fn: function (e) {
            var t = e.placement,
              o = t.split("-")[0],
              n = e.offsets,
              i = n.popper,
              r = n.reference,
              p = -1 !== ["left", "right"].indexOf(o),
              s = -1 === ["top", "left"].indexOf(o);
            return (
              (i[p ? "left" : "top"] =
                r[o] - (s ? i[p ? "width" : "height"] : 0)),
              (e.placement = T(t)),
              (e.offsets.popper = g(i)),
              e
            );
          },
        },
        hide: {
          order: 800,
          enabled: !0,
          fn: function (e) {
            if (!K(e.instance.modifiers, "hide", "preventOverflow")) return e;
            var t = e.offsets.reference,
              o = D(e.instance.modifiers, function (e) {
                return "preventOverflow" === e.name;
              }).boundaries;
            if (
              t.bottom < o.top ||
              t.left > o.right ||
              t.top > o.bottom ||
              t.right < o.left
            ) {
              if (!0 === e.hide) return e;
              (e.hide = !0), (e.attributes["x-out-of-boundaries"] = "");
            } else {
              if (!1 === e.hide) return e;
              (e.hide = !1), (e.attributes["x-out-of-boundaries"] = !1);
            }
            return e;
          },
        },
        computeStyle: {
          order: 850,
          enabled: !0,
          fn: function (e, t) {
            var o = t.x,
              n = t.y,
              i = e.offsets.popper,
              r = D(e.instance.modifiers, function (e) {
                return "applyStyle" === e.name;
              }).gpuAcceleration;
            void 0 !== r &&
              console.warn(
                "WARNING: `gpuAcceleration` option moved to `computeStyle` modifier and will not be supported in future versions of Popper.js!"
              );
            var s,
              d,
              a = void 0 === r ? t.gpuAcceleration : r,
              l = p(e.instance.popper),
              f = u(l),
              m = { position: i.position },
              h = q(e, 2 > window.devicePixelRatio || !fe),
              c = "bottom" === o ? "top" : "bottom",
              g = "right" === n ? "left" : "right",
              b = B("transform");
            if (
              ((d =
                "bottom" == c
                  ? "HTML" === l.nodeName
                    ? -l.clientHeight + h.bottom
                    : -f.height + h.bottom
                  : h.top),
              (s =
                "right" == g
                  ? "HTML" === l.nodeName
                    ? -l.clientWidth + h.right
                    : -f.width + h.right
                  : h.left),
              a && b)
            )
              (m[b] = "translate3d(" + s + "px, " + d + "px, 0)"),
                (m[c] = 0),
                (m[g] = 0),
                (m.willChange = "transform");
            else {
              var w = "bottom" == c ? -1 : 1,
                y = "right" == g ? -1 : 1;
              (m[c] = d * w), (m[g] = s * y), (m.willChange = c + ", " + g);
            }
            var E = { "x-placement": e.placement };
            return (
              (e.attributes = le({}, E, e.attributes)),
              (e.styles = le({}, m, e.styles)),
              (e.arrowStyles = le({}, e.offsets.arrow, e.arrowStyles)),
              e
            );
          },
          gpuAcceleration: !0,
          x: "bottom",
          y: "right",
        },
        applyStyle: {
          order: 900,
          enabled: !0,
          fn: function (e) {
            return (
              V(e.instance.popper, e.styles),
              j(e.instance.popper, e.attributes),
              e.arrowElement &&
                Object.keys(e.arrowStyles).length &&
                V(e.arrowElement, e.arrowStyles),
              e
            );
          },
          onLoad: function (e, t, o, n, i) {
            var r = L(i, t, e, o.positionFixed),
              p = O(
                o.placement,
                r,
                t,
                e,
                o.modifiers.flip.boundariesElement,
                o.modifiers.flip.padding
              );
            return (
              t.setAttribute("x-placement", p),
              V(t, { position: o.positionFixed ? "fixed" : "absolute" }),
              o
            );
          },
          gpuAcceleration: void 0,
        },
      },
    }),
    ge
  );
});
//# sourceMappingURL=popper.min.js.map
let globalCartProductCount = 0;
let globalFavoriteProductCount = 0;

$(document).ready(function () {
  setCartTotalProducts(0);
  setFavoriteTotalProducts(0);
  getFavorites();
});

function setCartTotalProducts(count) {
  globalCartProductCount += count;
  $(".js-cartCount").html(globalCartProductCount);
}

function setCartSubtotal(subtotal) {
  $(".js-subtotalPrice").html(subtotal);
}

function setFavoriteTotalProducts(count) {
  globalFavoriteProductCount += count;
  $(".js-favoriteCount").html(globalFavoriteProductCount);
}

function setShippingText(text) {
  $(".js-shippingText").text(text);
}

/**====== CHECKOUT ===========**/
//this function is used on product index
function addToCartIndex(desired_quantity, product_color_id, size_id) {
  globalProductColorId = product_color_id;
  console.log(size_id);
  addToCart(desired_quantity,false,null, size_id);
}

function changeCartQuantity(element) {
  globalProductColorId = element.attr("data-productColorID");
  addToCart(
    element.attr("data-quantity"),
    true,
    element.attr("data-cart-item-id")
  );

  $("#quantity-" + globalProductColorId).val(element.attr("data-quantity"));
}

function lensFlowAddToCartIndex(desired_quantity, product_color_id) {
  globalProductColorId = product_color_id;
  lensFlowaddToCart(desired_quantity);
}

function lensFlowaddToCart(desired_quantity) {
  console.log(document.getElementById("lensflow_subtotal"));
  lensflowPrice = parseInt(
    document.getElementById("lensflow_subtotal").innerText.split("$")[1]
  );
  prescription = $("#prescription_id_input").val();
  var lens_type_id_html = document.getElementById("lensflow_subtotal").getAttribute("data-lens_package_id");
  var lens_bundle_id_html = document.getElementById("lensflow_subtotal").getAttribute("data-lens_type_id");
  var lens_coating_html = document.getElementById("lensflow_subtotal").getAttribute("data-lens_coating");
  var lens_tints_and_transitions_html = document.getElementById("lensflow_subtotal").getAttribute("data-lens_tints_and_transitions");
  if (lens_type_id_html == "null") {
    var lens_type_id = document
      .getElementById("lensflow_subtotal")
      .getAttribute("data-lens_type_id");
  } else {
    var lens_type_id = parseInt(
      document
        .getElementById("lensflow_subtotal")
        .getAttribute("data-lens_type_id")
    );
  }

  if (lens_bundle_id_html == "null") {
    var lens_bundle_id = document
      .getElementById("lensflow_subtotal")
      .getAttribute("data-lens_bundle_id");
  } else {
    var lens_bundle_id = parseInt(
      document
        .getElementById("lensflow_subtotal")
        .getAttribute("data-lens_bundle_id")
    );
  }

  if (lens_coating_html == "null") {
    var lens_coating = document
      .getElementById("lensflow_subtotal")
      .getAttribute("data-lens_coating");
  } else {
    var lens_coating = parseInt(
      document
        .getElementById("lensflow_subtotal")
        .getAttribute("data-lens_coating")
    );
  }

  if (lens_tints_and_transitions_html == "null") {
    var lens_tints_and_transitions = document
      .getElementById("lensflow_subtotal")
      .getAttribute("data-lens_tints_and_transitions");
  } else {
    var lens_tints_and_transitions = parseInt(
      document
        .getElementById("lensflow_subtotal")
        .getAttribute("data-lens_tints_and_transitions")
    );
  }


  var data = {
    product_color_id: globalProductColorId,
    _token: $('[name="_token"]').val(),
    desired_quantity: desired_quantity ? desired_quantity : 1,
    lens_flow_total: lensflowPrice,
    isLensFlow: true,
    prescription_id: prescription,
    lensTypeId: lens_type_id,
    lensBundleId: lens_bundle_id,
    lensCoating: lens_coating,
    lensTintsAndTransitions: lens_tints_and_transitions
  };
  console.log(data);

  $.ajax({
    url: "/cart/add",
    type: "POST",
    data: data,
    dataType: "json",
    success: function (data) {
      setCartTotalProducts(data.cart_count);
      setCartItems(data.cart_color_html);
      setCartSubtotal(data.subtotal);
      setShippingText(data.shipping_details);
      toggleCheckoutButtonEnabledState(data.subtotal);
    },
    error: function (request, error) {
      console.log(request.responseText);
    },
  });

  // Close LensFlow
  document.getElementById("lensFlowCloseButton").click();
  document.getElementById("cart-drawer").classList.add("drawer--is-visible");
}

function toggleCheckoutButtonEnabledState(subtotal) {
  let checkoutBtn = $("#sidebarCheckoutButton");
  if (subtotal == "$0.00") {
    checkoutBtn.attr("disabled", "disabled");
    checkoutBtn.attr("href", "#");
  } else {
    checkoutBtn.removeAttr("disabled");
    checkoutBtn.attr("href", globalCheckoutURL);
  }
}

function addToCart(desired_quantity, changeQuantity = false, cartId = null, size_id) {
  console.log(size_id);
  var data = {
    product_color_id: globalProductColorId,
    _token: $('[name="_token"]').val(),
    desired_quantity: desired_quantity ? desired_quantity : 1,
    changeQuantity: changeQuantity,
    cartId: cartId,
    sizeID: size_id,
  };
  console.log(data);

  $.ajax({
    url: "/cart/add",
    type: "POST",
    data: data,
    dataType: "json",
    success: function (data) {
      setCartTotalProducts(data.cart_count);
      setCartItems(data.cart_color_html);
      setCartSubtotal(data.subtotal);
      setShippingText(data.shipping_details);
      toggleCheckoutButtonEnabledState(data.subtotal);
    },
    error: function (request, error) {
      console.log(request.responseText);
    },
  });
}

function getCart() {
  var data = {
    _token: $('[name="_token"]').val(),
  };

  $.ajax({
    url: "/cart",
    type: "GET",
    data: data,
    dataType: "json",
    success: function (data) {
      setCartTotalProducts(data.cart_count);
      setCartItems(data.cart_color_html);
      setCartSubtotal(data.subtotal);
      setShippingText(data.shipping_details);
      toggleCheckoutButtonEnabledState(data.subtotal);
    },
    error: function (request, error) {
      console.log(request.responseText);
    },
  });
}

function addFavorite(product_color_id = null) {
  if (product_color_id !== null) {
    globalProductColorId = product_color_id;
  }

  var data = {
    product_color_id: globalProductColorId,
    _token: $('[name="_token"]').val(),
  };

  $.ajax({
    url: "/favorites/update",
    type: "POST",
    data: data,
    dataType: "json",
    success: function (data) {
      setFavoriteTotalProducts(data.favorite_color_items.length);
      setFavoritetems(data.favorite_html);
    },
    error: function (request, error) {
      console.log(request.responseText);
    },
  });
}

function removeFavorite(product_color_id) {
  var data = {
    product_color_id: product_color_id,
    remove_flg: "Y",
    _token: $('[name="_token"]').val(),
  };

  $.ajax({
    url: "/favorites/update",
    type: "POST",
    data: data,
    dataType: "json",
    success: function (data) {
      setFavoriteTotalProducts(data.favorite_color_items.length);
      setFavoritetems(data.favorite_html);
    },
    error: function (request, error) {
      console.log(request.responseText);
    },
  });
}

function getFavorites() {
  var data = {
    _token: $('[name="_token"]').val(),
  };

  $.ajax({
    url: "/favorites",
    type: "GET",
    data: data,
    dataType: "json",
    success: function (data) {
      setFavoriteTotalProducts(data.favorite_color_items.length);
      setFavoritetems(data.favorite_html);
    },
    error: function (request, error) {
      console.log(request.responseText);
    },
  });
}

function setCartItems(cart_color_items_html) {
  $(".js-CartItems").html(cart_color_items_html);
}

function setFavoritetems(favorite_color_items) {
  if (favorite_color_items === "") {
    $(".js-FavoriteItems").html("<p>No Favorites</p>");
  } else {
    $(".js-FavoriteItems").html(favorite_color_items);
  }
}

function removeFromCart() {
  setCartTotalProducts(-1);
}

function addToFavorites() {
  setFavoriteTotalProducts(1);
}

/**=========== BRAINTREE ==============**/
// var button = document.querySelector('#submit-button');
//
// braintree.dropin.create({
//     authorization: 'CLIENT_AUTHORIZATION',
//     container: '#dropin-container'
// }, function (createErr, instance) {
//     button.addEventListener('click', function () {
//         instance.requestPaymentMethod(function (requestPaymentMethodErr, payload) {
//             // Submit payload.nonce to your server
//         });
//     });
// });

/**=========== BRAINTREE END ==============**/

$(document).ready(function () {
  getCart();
});

(function ($) {
  $(function () {
    // 360 view
    $(".product__image--360").hide();
    $(".js-360-view").on("click", function () {
      $(".product__image--default").hide();
      window.CI360.init();
      $(".product__image--360").show();
    });

    // wishlist
    $(".js-addToFav").on("click", function () {
      $(this).toggleClass("loved");
    });

    // lens flow
    let $lf_prevStep = $(".js-prev-step"),
      $lf_step = $(".js-step"),
      $lf_step1 = $(".js-step1"),
      $lf_step2 = $(".js-step2"),
      $lf_step3 = $(".js-step3"),
      $lf_step4 = $(".js-step4"),
      $lf_stepContent = $(".js-step-content"),
      $lf_lensflowTitle = $(".js-lensflow-title"),
      $lf_addToCart = $(".lensflow .js-add-to-cart"),
      $lf_odAdd = $("#od_add"),
      $lf_osAdd = $("#os_add"),
      $lf_odCyl = $("#od_cyl"),
      $lf_osCyl = $("#os_cyl"),
      $lf_odAxis = $("#od_axis"),
      $lf_osAxis = $("#os_axis"),
      $lf_lensTypeItem = $(".js-lens-type .js-choice-img"),
      $lf_xAddSpecialty = $(".x-specialty-add"),
      $lf_singleVisionLensContent = $(".js-single-vision-lens-content"),
      $lf_bifocalLensContent = $(".js-bifocal-lens-content"),
      $lf_progressiveLensContent = $(".js-progressive-lens-content"),
      $lf_specialtyLensContent = $(".js-specialty-lens-content"),
      $lf_kidsSpecialtyLensContent = $(".js-kids-specialty-lens-content"),
      $lf_prescription = $(".js-prescription"),
      $lf_lensIndex = $(".js-lens-index"),
      $lf_lensAddons = $(".js-lens-addons"),
      $lf_lensIndexContent = $(".js-lens-index-content"),
      $lf_lensIndexItem = $(".js-lens-index .js-choice-img"),
      $lf_silverLensNormal = $(".js-silver-normal"),
      $lf_silverLensThinner = $(".js-silver-thinner"),
      $lf_silverLensVeryThin = $(".js-silver-very-thin"),
      $lf_silverLensUltraThin = $(".js-silver-ultra-thin"),
      $lf_goldLensNormal = $(".js-gold-normal"),
      $lf_goldLensThinner = $(".js-gold-thinner"),
      $lf_goldLensVeryThin = $(".js-gold-very-thin"),
      $lf_goldLensUltraThin = $(".js-gold-ultra-thin"),
      $lf_platinumLensNormal = $(".js-platinum-normal"),
      $lf_platinumLensThinner = $(".js-platinum-thinner"),
      $lf_platinumLensVeryThin = $(".js-platinum-very-thin"),
      $lf_platinumLensUltraThin = $(".js-platinum-ultra-thin"),
      $lf_hasTwoPD = $(".has-two-pd"),
      $lf_onePD = $(".one-pd"),
      $lf_twoPD = $(".two-pd"),
      $lf_addPrism = $(".js-add-prism"),
      $lf_prismContent = $(".js-prism-content"),
      $existingPrescriptionManualConfirmBtn = $("#existing_table_lens_flow"),
      $lf_prescriptionManualConfirmBtn = $(".js-prescription-manual-confirm"),
      $lf_prescriptionExistingManualConfirmBtn = $(".js-existing-prescription-manual-confirm"),
      $lf_prescriptionUploadConfirmBtn = $(".js-prescription-upload-confirm"),
      $lf_sendLater = $(".js-send-later"),
      $lf_solidTint = $(".js-solid-tint"),
      $lf_polarized = $(".js-polarized"),
      $lf_gradients = $(".js-gradients"),
      $lf_easyClean = $(".js-easy-clean"),
      $lf_blueProtect = $(".js-blue-protect"),
      $lf_transitions = $(".js-transitions"),
      $lf_photofusion = $(".js-photofusion"),
      $lf_silverCoatings = $(".js-silver-coatings"),
      $lf_goldCoatings = $(".js-gold-coatings"),
      $lf_platinumCoatings = $(".js-platinum-coatings"),
      $lf_coatingsContent = $(".js-coatings-content"),
      stepNum = 1,
      // stepName targets the steps classes and unhide the particular step
      stepName = "",
      isNonPrescription = false;

    // action on previous button click
    $lf_prevStep.on("click", function () {
      $lf_addToCart.addClass("hidden");
      stepNum--;
      switch (stepNum) {
        case 1:
          stepName = "js-lens-type";
          $lf_step.removeClass("step--current step--completed");
          $lf_step1.addClass("step--current");
          $lf_lensflowTitle.text("Lens Type");
          break;
        case 2:
          stepName = "js-prescription";
          $lf_step.removeClass("step--current step--completed");
          $lf_step1.addClass("step--completed");
          $lf_step2.addClass("step--current");
          $lf_lensflowTitle.text("Prescription");
          break;
        case 3:
          stepName = "js-lens-index";
          $lf_step.removeClass("step--current step--completed");
          $lf_step3.addClass("step--current");
          $lf_step1.addClass("step--completed");
          $lf_step2.addClass("step--completed");
          $lf_addToCart.addClass("is-hidden");
          $lf_lensflowTitle.text("Lenses Bundle");
          break;
        case 4:
          stepName = "js-lens-addons";
          $lf_lensflowTitle.text("Lens Add-ons");
          break;
      }
      if (stepNum > 0) {
        $lf_stepContent.addClass("is-hidden");
        $("." + stepName).removeClass("is-hidden");
      }
      if (isNonPrescription) {
        $lf_addToCart.addClass("is-hidden");
      }
      if (stepNum == 1) {
        $lf_prevStep.addClass("is-hidden");
      }
    });

    // Step 1

    let lensTypePrice = 0; 
    $lf_lensTypeItem.on("click", function () {
      let lens_price = 0;
      let lens_subtotal = parseInt(
        document.getElementById("lensflow_subtotal").innerText.split("$")[1]
      );
      let lensTypeLabel = $(this).attr("aria-label");
      // LENS Package ID
      let lensTypeId = $(this).attr("data-lens_package_id");
      let lensTypeChecked = $(this).attr("aria-checked");
      $lf_lensflowTitle.text("Prescription");
      $lf_stepContent.addClass("is-hidden");
      $lf_lensIndexContent.addClass("is-hidden");
      $lf_prescription.removeClass("is-hidden");
      $lf_step1.addClass("step--completed");
      $lf_step2.addClass("step--current");

      // enable ADD values
      $lf_xAddSpecialty.removeClass("is-hidden");
      $lf_xAddSpecialty.removeAttr("disabled");
      $lf_odAdd.prop("disabled", "");
      $lf_osAdd.prop("disabled", "");

      $lf_prevStep.removeClass("is-hidden");
      stepName = "js-lens-type";
      stepNum = 2;
      switch (lensTypeLabel) {
        case "Single Vision":
          $lf_singleVisionLensContent.removeClass("is-hidden");
          // $lf_odAdd.prop("disabled", "disabled");
          // $lf_osAdd.prop("disabled", "disabled");
          break;
        case "Bifocal":
          lens_price = parseInt(
            document
              .getElementsByClassName("lens_type_price")[1]
              .innerHTML.split("$")[1]
          );
          $lf_bifocalLensContent.removeClass("is-hidden");
          break;
        case "Progressive":
          lens_price = parseInt(
            document
              .getElementsByClassName("lens_type_price")[2]
              .innerHTML.split("$")[1]
          );
          $lf_progressiveLensContent.removeClass("is-hidden");
          break;
        case "Specialty":
          lens_price = parseInt(
            document
              .getElementsByClassName("lens_type_price")[3]
              .innerHTML.split("$")[1]
          );
          $lf_specialtyLensContent.removeClass("is-hidden");
          $lf_xAddSpecialty.addClass("is-hidden");
          $lf_xAddSpecialty.prop("disabled", "disabled");
          break;
        case "Kids Specialty Package":
          lens_price = parseInt(
            document
              .getElementsByClassName("lens_type_price")[4]
              .innerHTML.split("$")[1]
          );
          $lf_kidsSpecialtyLensContent.removeClass("is-hidden");
          // $lf_odAdd.prop("disabled", "disabled");
          // $lf_osAdd.prop("disabled", "disabled");
          break;
        case "Non-Prescription":
          $lf_prescription.addClass("is-hidden");
          $lf_lensIndex.removeClass("is-hidden");
          $lf_lensIndexContent.addClass("is-hidden");
          $lf_singleVisionLensContent.removeClass("is-hidden");
          $lf_step1.addClass("step--completed");
          $lf_step2.addClass("step--completed");
          $lf_step3.addClass("step--current");
          stepNum = 2;
          isNonPrescription = true;
          break;
      }
      if (lensTypePrice == 0){
        lens_subtotal = lens_subtotal + lens_price;
      } else {
          lens_subtotal = lens_subtotal + lens_price - lensTypePrice;
      }
      lensTypePrice = lens_price;
      document.getElementById("lensflow_subtotal").innerText =
        "$" + lens_subtotal.toString();
      document
        .getElementById("lensflow_subtotal")
        .setAttribute("data-lens_type_id", lensTypeId);

    });

    // Step 2
    // enable axis only when there is value inside Cyl
    $lf_odCyl.on("change", function () {
      let odCyl = $("#od_cyl option:selected").val();
      if (odCyl > 0 || odCyl < 0) {
        $lf_odAxis.removeAttr("disabled");
      } else {
        $lf_odAxis.prop("disabled", "disabled");
      }
    });
    $lf_osCyl.on("change", function () {
      let osCyl = $("#os_cyl option:selected").val();
      if (osCyl > 0 || osCyl < 0) {
        $lf_osAxis.removeAttr("disabled");
      } else {
        $lf_osAxis.prop("disabled", "disabled");
      }
    });

    $lf_prescriptionExistingManualConfirmBtn.on("click", function () {
      $lf_lensflowTitle.text("Lenses Bundle");
      $lf_stepContent.addClass("is-hidden");
      $lf_lensIndex.removeClass("is-hidden");
      $lf_step2.addClass("step--completed");
      $lf_step3.addClass("step--current");
      stepNum = 3;
      $lf_lensIndexItem.addClass("is-hidden");
      var prescription_id = $(this).data("value"); // Retrieve the value from the data attribute
      console.log(prescription_id);
      $("#prescription_id_input").val(prescription_id);
      let odSph = $("#SPH_OD").data("value") || 0;
      let osSph = $("#SPH_OS").data("value") || 0;
      let odCyl = $("#CYL_OD").data("value") || 0;
      let osCyl = $("#CYL_OS").data("value") || 0;

      if (
        odSph <= 2.5 &&
        odSph >= -2.5 &&
        osSph <= 2.5 &&
        osSph >= -2.5 &&
        odCyl <= 2.5 &&
        odCyl >= -2.5 &&
        osCyl <= 2.5 &&
        osCyl >= -2.5
      ) {
        console.log("less than 2.5");
        $lf_lensIndexItem.removeClass("is-hidden");
      } else if (
        odSph <= 4.5 &&
        odSph >= -4.5 &&
        osSph <= 4.5 &&
        osSph >= -4.5 &&
        odCyl <= 3 &&
        odCyl >= -3 &&
        osCyl <= 3 &&
        osCyl >= -3
      ) {
        console.log("greater than 2.5 and less than 4.5");
        $lf_lensIndexItem.removeClass("is-hidden");
        $lf_silverLensNormal.addClass("is-hidden");
        $lf_goldLensNormal.addClass("is-hidden");
        $lf_platinumLensNormal.addClass("is-hidden");
      } else if (
        odSph <= 8.5 &&
        odSph >= -8.5 &&
        osSph <= 8.5 &&
        osSph >= -8.5 &&
        odCyl <= 4.5 &&
        odCyl >= -4.5 &&
        osCyl <= 4.5 &&
        osCyl >= -4.5
      ) {
        $lf_lensIndexItem.removeClass("is-hidden");
        $lf_goldLensNormal.addClass("is-hidden");
        $lf_platinumLensNormal.addClass("is-hidden");
        $lf_silverLensThinner.addClass("is-hidden");
        $lf_goldLensThinner.addClass("is-hidden");
        $lf_platinumLensThinner.addClass("is-hidden");
        console.log("greater than 4.5 and less than 8.5");
      } else if (
        odSph <= 16 &&
        odSph >= -16 &&
        osSph <= 16 &&
        osSph >= -16 &&
        odCyl <= 6 &&
        odCyl >= -6 &&
        osCyl <= 6 &&
        osCyl >= -6
      ) {
        console.log("greater than 8.5 and less than 16");
        $lf_silverLensUltraThin.removeClass("is-hidden");
        $lf_goldLensUltraThin.removeClass("is-hidden");
        $lf_platinumLensUltraThin.removeClass("is-hidden");
      }
    });

    $lf_prescriptionManualConfirmBtn.on("click", function () {
      $lf_lensflowTitle.text("Lenses Bundle");
      $lf_stepContent.addClass("is-hidden");
      $lf_lensIndex.removeClass("is-hidden");
      $lf_step2.addClass("step--completed");
      $lf_step3.addClass("step--current");
      stepNum = 3;
      $lf_lensIndexItem.addClass("is-hidden");

      let odSph = $("#od_sph option:selected").val() || 0;
      let osSph = $("#os_sph option:selected").val() || 0;
      let odCyl = $("#od_cyl option:selected").val() || 0;
      let osCyl = $("#os_cyl option:selected").val() || 0;
      let odaxis = $("#od_axis option:selected").val() || 0;
      let osaxis = $("#os_axis option:selected").val() || 0;
      let odadd = $("#od_add option:selected").val() || 0;
      let osadd = $("#os_add option:selected").val() || 0;
      let bothPd = $("#pd_both option:selected").val() || 0;
      let rightPd = $("#pd_right option:selected").val() || 0;
      let leftPd = $("#pd_left option:selected").val() || 0;
      let odVP = $("#od_v_prism option:selected").val() || 0;
      let osVP = $("#os_v_prism option:selected").val() || 0;
      let odVBDP = $("#od_prismdir_v option:selected").val() || 0;
      let osVBDP = $("#os_prismdir_v option:selected").val() || 0;
      let odHP = $("#od_prismnum_h option:selected").val() || 0;
      let osHP = $("#os_prismnum_h option:selected").val() || 0;
      let odHBDP = $("#od_prismdir_h option:selected").val() || 0;
      let osHBDP = $("#os_prismdir_h option:selected").val() || 0;
      let prescriptionName = $("#prescription_name").val() || "Lens Flow Prescription";
      let prescriptionId = 0;
      const data = {
        odSph: odSph,
        osSph: osSph,
        odCyl: odCyl,
        osCyl: osCyl,
        odaxis: odaxis,
        osaxis: osaxis,
        odadd: odadd,
        osadd: osadd,
        bothPd: bothPd,
        rightPd: rightPd,
        leftPd: leftPd,
        odVP: odVP,
        osVP: osVP,
        odVBDP: odVBDP,
        osVBDP: osVBDP,
        odHP: odHP,
        osHP: osHP,
        odHBDP: odHBDP,
        osHBDP: osHBDP,
        prescriptionName: prescriptionName,
      };
      const csrfToken = document
        .querySelector("#csrf-token input")
        .getAttribute("data-csrf-token");
      $.ajax({
        url: "/storeLensFlowPrescription",
        method: "POST",
        headers: {
          "X-CSRF-TOKEN": csrfToken,
        },
        data: JSON.stringify(data),
        contentType: "application/json", 
        dataType: "json", 
        success: function (response) {
          const prescriptionId = response["prescription_id"];
          // Update the hidden input field with the prescriptionId
          $("#prescription_id_input").val(prescriptionId);

          // console.log("Response:", response["prescription_id"]);
        },
        error: function (error) {
          // Handle error (optional)
          console.log("ERROR: " + JSON.stringify(error));
        },
      });

      // var dialog = document.getElementsByClassName("js-dialog");
      // //open first dialog available in your page
      // openDialog(dialog[0]);
      // function openDialog(element) {
      //   var event = new CustomEvent("openDialog");
      //   element.dispatchEvent(event);
      // }

      // display different lens index based on what od or os was selected
      if (
        odSph <= 2.5 &&
        odSph >= -2.5 &&
        osSph <= 2.5 &&
        osSph >= -2.5 &&
        odCyl <= 2.5 &&
        odCyl >= -2.5 &&
        osCyl <= 2.5 &&
        osCyl >= -2.5
      ) {
        console.log("less than 2.5");
        $lf_lensIndexItem.removeClass("is-hidden");
      } else if (
        odSph <= 4.5 &&
        odSph >= -4.5 &&
        osSph <= 4.5 &&
        osSph >= -4.5 &&
        odCyl <= 3 &&
        odCyl >= -3 &&
        osCyl <= 3 &&
        osCyl >= -3
      ) {
        console.log("greater than 2.5 and less than 4.5");
        $lf_lensIndexItem.removeClass("is-hidden");
        $lf_silverLensNormal.addClass("is-hidden");
        $lf_goldLensNormal.addClass("is-hidden");
        $lf_platinumLensNormal.addClass("is-hidden");
      } else if (
        odSph <= 8.5 &&
        odSph >= -8.5 &&
        osSph <= 8.5 &&
        osSph >= -8.5 &&
        odCyl <= 4.5 &&
        odCyl >= -4.5 &&
        osCyl <= 4.5 &&
        osCyl >= -4.5
      ) {
        $lf_lensIndexItem.removeClass("is-hidden");
        $lf_goldLensNormal.addClass("is-hidden");
        $lf_platinumLensNormal.addClass("is-hidden");
        $lf_silverLensThinner.addClass("is-hidden");
        $lf_goldLensThinner.addClass("is-hidden");
        $lf_platinumLensThinner.addClass("is-hidden");
        console.log("greater than 4.5 and less than 8.5");
      } else if (
        odSph <= 16 &&
        odSph >= -16 &&
        osSph <= 16 &&
        osSph >= -16 &&
        odCyl <= 6 &&
        odCyl >= -6 &&
        osCyl <= 6 &&
        osCyl >= -6
      ) {
        console.log("greater than 8.5 and less than 16");
        $lf_silverLensUltraThin.removeClass("is-hidden");
        $lf_goldLensUltraThin.removeClass("is-hidden");
        $lf_platinumLensUltraThin.removeClass("is-hidden");
      }
    });

    $existingPrescriptionManualConfirmBtn.on("click", function () {
      $lf_lensflowTitle.text("Lenses Bundle");
      $lf_stepContent.addClass("is-hidden");
      $lf_lensIndex.removeClass("is-hidden");
      $lf_step2.addClass("step--completed");
      $lf_step3.addClass("step--current");
      stepNum = 3;
      $lf_lensIndexItem.addClass("is-hidden");

      let odSph = $("#SPH_OD").text();
      let odCyl = $("#CYL_OD").text();
      let odaxis = $("#Axis_OD").text();
      let odadd = $("#ADD_OD").text();
      let bothPd = $("#PD_Both").text();
      let osSph = $("#SPH_OS").text();
      let osCyl = $("#CYL_OS").text();
      let osaxis = $("#Axis_OS").text();
      let osadd = $("#ADD_OS").text();

      // var dialog = document.getElementsByClassName("js-dialog");
      // //open first dialog available in your page
      // openDialog(dialog[0]);
      // function openDialog(element) {
      //   var event = new CustomEvent("openDialog");
      //   element.dispatchEvent(event);
      // }

      // display different lens index based on what od or os was selected
      if (
        odSph <= 2.5 &&
        odSph >= -2.5 &&
        osSph <= 2.5 &&
        osSph >= -2.5 &&
        odCyl <= 2.5 &&
        odCyl >= -2.5 &&
        osCyl <= 2.5 &&
        osCyl >= -2.5
      ) {
        console.log("less than 2.5");
        $lf_lensIndexItem.removeClass("is-hidden");
      } else if (
        odSph <= 4.5 &&
        odSph >= -4.5 &&
        osSph <= 4.5 &&
        osSph >= -4.5 &&
        odCyl <= 3 &&
        odCyl >= -3 &&
        osCyl <= 3 &&
        osCyl >= -3
      ) {
        console.log("greater than 2.5 and less than 4.5");
        $lf_lensIndexItem.removeClass("is-hidden");
        $lf_silverLensNormal.addClass("is-hidden");
        $lf_goldLensNormal.addClass("is-hidden");
        $lf_platinumLensNormal.addClass("is-hidden");
      } else if (
        odSph <= 8.5 &&
        odSph >= -8.5 &&
        osSph <= 8.5 &&
        osSph >= -8.5 &&
        odCyl <= 4.5 &&
        odCyl >= -4.5 &&
        osCyl <= 4.5 &&
        osCyl >= -4.5
      ) {
        $lf_lensIndexItem.removeClass("is-hidden");
        $lf_goldLensNormal.addClass("is-hidden");
        $lf_platinumLensNormal.addClass("is-hidden");
        $lf_silverLensThinner.addClass("is-hidden");
        $lf_goldLensThinner.addClass("is-hidden");
        $lf_platinumLensThinner.addClass("is-hidden");
        console.log("greater than 4.5 and less than 8.5");
      } else if (
        odSph <= 16 &&
        odSph >= -16 &&
        osSph <= 16 &&
        osSph >= -16 &&
        odCyl <= 6 &&
        odCyl >= -6 &&
        osCyl <= 6 &&
        osCyl >= -6
      ) {
        console.log("greater than 8.5 and less than 16");
        $lf_silverLensUltraThin.removeClass("is-hidden");
        $lf_goldLensUltraThin.removeClass("is-hidden");
        $lf_platinumLensUltraThin.removeClass("is-hidden");
      }
    });

    $lf_hasTwoPD.on("click", function () {
      $lf_onePD.toggleClass("is-hidden");
      $lf_twoPD.toggleClass("is-hidden");
    });

    $lf_addPrism.on("click", function () {
      $lf_prismContent.toggleClass("is-hidden");
    });

    $lf_prescriptionUploadConfirmBtn
      .add($lf_sendLater)
      .on("click", function () {
        $("#prescription_id_input").val(0);
        $lf_lensflowTitle.text("Lenses Bundle");
        $lf_stepContent.addClass("is-hidden");
        $lf_lensIndex.removeClass("is-hidden");
        $lf_step2.addClass("step--completed");
        $lf_step3.addClass("step--current");
        stepNum = 3;
      });

    // step 3
    let lastLensBundlePrice = 0;
    $lf_lensIndexItem.on("click", function () {
      // parseInt(
      //   document
      //     .getElementsByClassName(
      //       "choice-img bg col-3@sm js-choice-img js-tab-focus js-silver-thinner"
      //     )[0]
      //     .children[0].children[4].innerHTML.split("$")[1]
      // );data-lens_type_id data-lensVal
      let lense_bundle_id = $(this).attr("data-lens_type_id");
      console.log(lense_bundle_id);
      let lensesBundlePrice = parseInt(
        $(this)[0].children[0].children[4].innerHTML.split("$")[1]
      );
      let lens_subtotal = parseInt(
        document.getElementById("lensflow_subtotal").innerText.split("$")[1]
      );
      if(lastLensBundlePrice == 0){
        lens_subtotal = lens_subtotal + lensesBundlePrice;
      }else{
        lens_subtotal = lens_subtotal + lensesBundlePrice - lastLensBundlePrice;
      }
      lastLensBundlePrice = lensesBundlePrice;
      document.getElementById("lensflow_subtotal").innerText =
        "$" + lens_subtotal.toString();
      document
        .getElementById("lensflow_subtotal")
        .setAttribute("data-lens_bundle_id", lense_bundle_id);
      $lf_addToCart.removeClass("is-hidden");
      $lf_stepContent.addClass("is-hidden");
      $lf_lensAddons.removeClass("is-hidden");
      $lf_step3.addClass("step--completed");
      $lf_step4.addClass("step--current");
      stepNum = 4;
      $lf_lensflowTitle.text("Lens Add-ons");
      let lensName = $(this).attr("aria-label");
      let lensIndex = $(this).data("lens-index");
      let lensCategory = $(this).data("lens-category");
      $lf_photofusion.addClass("is-hidden");
      $lf_coatingsContent.addClass("is-hidden");

      // show/hide lens addons based on what lens index was selected
      if (lensIndex == "thinner" || lensIndex == "very-thin") {
        $lf_transitions.removeClass("is-hidden");
        $lf_polarized.removeClass("is-hidden");
        $lf_solidTint.removeClass("is-hidden");
        $lf_gradients.removeClass("is-hidden");
        $lf_easyClean.removeClass("is-hidden");
        $lf_blueProtect.removeClass("is-hidden");
      } else if (lensIndex == "ultra-thin") {
        $lf_transitions.removeClass("is-hidden");
        $lf_easyClean.removeClass("is-hidden");
        $lf_polarized.addClass("is-hidden");
        $lf_solidTint.addClass("is-hidden");
        $lf_gradients.addClass("is-hidden");
        $lf_blueProtect.removeClass("is-hidden");
        if (lensCategory == "platinum") {
          $lf_transitions.addClass("is-hidden");
          $lf_photofusion.removeClass("is-hidden");
        }
      } else if (lensIndex == "normal") {
        $lf_transitions.addClass("is-hidden");
        $lf_polarized.addClass("is-hidden");
        $lf_solidTint.addClass("is-hidden");
        $lf_gradients.addClass("is-hidden");
        $lf_easyClean.addClass("is-hidden");
        $lf_blueProtect.removeClass("is-hidden");
      }
      if (lensCategory == "silver") {
        $lf_silverCoatings.removeClass("is-hidden");
      } else if (lensCategory == "gold") {
        $lf_goldCoatings.removeClass("is-hidden");
      } else {
        $lf_platinumCoatings.removeClass("is-hidden");
      }

      // order summary
      $(".js-user-lens-index").text(lensName);
    });
  });
})(jQuery);
