/**
 * Swiper 8.4.7
 * Most modern mobile touch slider and framework with hardware accelerated transitions
 * https://swiperjs.com
 *
 * Copyright 2014-2023 Vladimir Kharlampidi
 *
 * Released under the MIT License
 *
 * Released on: January 30, 2023
 */

@font-face {
  font-family: 'swiper-icons';
  src: url('data:application/font-woff;charset=utf-8;base64, d09GRgABAAAAAAZgABAAAAAADAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABGRlRNAAAGRAAAABoAAAAci6qHkUdERUYAAAWgAAAAIwAAACQAYABXR1BPUwAABhQAAAAuAAAANuAY7+xHU1VCAAAFxAAAAFAAAABm2fPczU9TLzIAAAHcAAAASgAAAGBP9V5RY21hcAAAAkQAAACIAAABYt6F0cBjdnQgAAACzAAAAAQAAAAEABEBRGdhc3AAAAWYAAAACAAAAAj//wADZ2x5ZgAAAywAAADMAAAD2MHtryVoZWFkAAABbAAAADAAAAA2E2+eoWhoZWEAAAGcAAAAHwAAACQC9gDzaG10eAAAAigAAAAZAAAArgJkABFsb2NhAAAC0AAAAFoAAABaFQAUGG1heHAAAAG8AAAAHwAAACAAcABAbmFtZQAAA/gAAAE5AAACXvFdBwlwb3N0AAAFNAAAAGIAAACE5s74hXjaY2BkYGAAYpf5Hu/j+W2+MnAzMYDAzaX6QjD6/4//Bxj5GA8AuRwMYGkAPywL13jaY2BkYGA88P8Agx4j+/8fQDYfA1AEBWgDAIB2BOoAeNpjYGRgYNBh4GdgYgABEMnIABJzYNADCQAACWgAsQB42mNgYfzCOIGBlYGB0YcxjYGBwR1Kf2WQZGhhYGBiYGVmgAFGBiQQkOaawtDAoMBQxXjg/wEGPcYDDA4wNUA2CCgwsAAAO4EL6gAAeNpj2M0gyAACqxgGNWBkZ2D4/wMA+xkDdgAAAHjaY2BgYGaAYBkGRgYQiAHyGMF8FgYHIM3DwMHABGQrMOgyWDLEM1T9/w8UBfEMgLzE////P/5//f/V/xv+r4eaAAeMbAxwIUYmIMHEgKYAYjUcsDAwsLKxc3BycfPw8jEQA/gZBASFhEVExcQlJKWkZWTl5BUUlZRVVNXUNTQZBgMAAMR+E+gAEQFEAAAAKgAqACoANAA+AEgAUgBcAGYAcAB6AIQAjgCYAKIArAC2AMAAygDUAN4A6ADyAPwBBgEQARoBJAEuATgBQgFMAVYBYAFqAXQBfgGIAZIBnAGmAbIBzgHsAAB42u2NMQ6CUAyGW568x9AneYYgm4MJbhKFaExIOAVX8ApewSt4Bic4AfeAid3VOBixDxfPYEza5O+Xfi04YADggiUIULCuEJK8VhO4bSvpdnktHI5QCYtdi2sl8ZnXaHlqUrNKzdKcT8cjlq+rwZSvIVczNiezsfnP/uznmfPFBNODM2K7MTQ45YEAZqGP81AmGGcF3iPqOop0r1SPTaTbVkfUe4HXj97wYE+yNwWYxwWu4v1ugWHgo3S1XdZEVqWM7ET0cfnLGxWfkgR42o2PvWrDMBSFj/IHLaF0zKjRgdiVMwScNRAoWUoH78Y2icB/yIY09An6AH2Bdu/UB+yxopYshQiEvnvu0dURgDt8QeC8PDw7Fpji3fEA4z/PEJ6YOB5hKh4dj3EvXhxPqH/SKUY3rJ7srZ4FZnh1PMAtPhwP6fl2PMJMPDgeQ4rY8YT6Gzao0eAEA409DuggmTnFnOcSCiEiLMgxCiTI6Cq5DZUd3Qmp10vO0LaLTd2cjN4fOumlc7lUYbSQcZFkutRG7g6JKZKy0RmdLY680CDnEJ+UMkpFFe1RN7nxdVpXrC4aTtnaurOnYercZg2YVmLN/d/gczfEimrE/fs/bOuq29Zmn8tloORaXgZgGa78yO9/cnXm2BpaGvq25Dv9S4E9+5SIc9PqupJKhYFSSl47+Qcr1mYNAAAAeNptw0cKwkAAAMDZJA8Q7OUJvkLsPfZ6zFVERPy8qHh2YER+3i/BP83vIBLLySsoKimrqKqpa2hp6+jq6RsYGhmbmJqZSy0sraxtbO3sHRydnEMU4uR6yx7JJXveP7WrDycAAAAAAAH//wACeNpjYGRgYOABYhkgZgJCZgZNBkYGLQZtIJsFLMYAAAw3ALgAeNolizEKgDAQBCchRbC2sFER0YD6qVQiBCv/H9ezGI6Z5XBAw8CBK/m5iQQVauVbXLnOrMZv2oLdKFa8Pjuru2hJzGabmOSLzNMzvutpB3N42mNgZGBg4GKQYzBhYMxJLMlj4GBgAYow/P/PAJJhLM6sSoWKfWCAAwDAjgbRAAB42mNgYGBkAIIbCZo5IPrmUn0hGA0AO8EFTQAA');
  font-weight: 400;
  font-style: normal;
}
:root {
  --swiper-theme-color: #007aff;
}
.swiper {
  margin-left: auto;
  margin-right: auto;
  position: relative;
  overflow: hidden;
  list-style: none;
  padding: 0;
  /* Fix of Webkit flickering */
  z-index: 1;
}
.swiper-vertical > .swiper-wrapper {
  flex-direction: column;
}
.swiper-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 1;
  display: flex;
  transition-property: transform;
  box-sizing: content-box;
}
.swiper-android .swiper-slide,
.swiper-wrapper {
  transform: translate3d(0px, 0, 0);
}
.swiper-pointer-events {
  touch-action: pan-y;
}
.swiper-pointer-events.swiper-vertical {
  touch-action: pan-x;
}
.swiper-slide {
  flex-shrink: 0;
  width: 100%;
  height: 100%;
  position: relative;
  transition-property: transform;
}
.swiper-slide-invisible-blank {
  visibility: hidden;
}
/* Auto Height */
.swiper-autoheight,
.swiper-autoheight .swiper-slide {
  height: auto;
}
.swiper-autoheight .swiper-wrapper {
  align-items: flex-start;
  transition-property: transform, height;
}
.swiper-backface-hidden .swiper-slide {
  transform: translateZ(0);
  backface-visibility: hidden;
}
/* 3D Effects */
.swiper-3d,
.swiper-3d.swiper-css-mode .swiper-wrapper {
  perspective: 1200px;
}
.swiper-3d .swiper-wrapper,
.swiper-3d .swiper-slide,
.swiper-3d .swiper-slide-shadow,
.swiper-3d .swiper-slide-shadow-left,
.swiper-3d .swiper-slide-shadow-right,
.swiper-3d .swiper-slide-shadow-top,
.swiper-3d .swiper-slide-shadow-bottom,
.swiper-3d .swiper-cube-shadow {
  transform-style: preserve-3d;
}
.swiper-3d .swiper-slide-shadow,
.swiper-3d .swiper-slide-shadow-left,
.swiper-3d .swiper-slide-shadow-right,
.swiper-3d .swiper-slide-shadow-top,
.swiper-3d .swiper-slide-shadow-bottom {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 10;
}
.swiper-3d .swiper-slide-shadow {
  background: rgba(0, 0, 0, 0.15);
}
.swiper-3d .swiper-slide-shadow-left {
  background-image: linear-gradient(to left, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}
.swiper-3d .swiper-slide-shadow-right {
  background-image: linear-gradient(to right, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}
.swiper-3d .swiper-slide-shadow-top {
  background-image: linear-gradient(to top, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}
.swiper-3d .swiper-slide-shadow-bottom {
  background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}
/* CSS Mode */
.swiper-css-mode > .swiper-wrapper {
  overflow: auto;
  scrollbar-width: none;
  /* For Firefox */
  -ms-overflow-style: none;
  /* For Internet Explorer and Edge */
}
.swiper-css-mode > .swiper-wrapper::-webkit-scrollbar {
  display: none;
}
.swiper-css-mode > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: start start;
}
.swiper-horizontal.swiper-css-mode > .swiper-wrapper {
  scroll-snap-type: x mandatory;
}
.swiper-vertical.swiper-css-mode > .swiper-wrapper {
  scroll-snap-type: y mandatory;
}
.swiper-centered > .swiper-wrapper::before {
  content: '';
  flex-shrink: 0;
  order: 9999;
}
.swiper-centered.swiper-horizontal > .swiper-wrapper > .swiper-slide:first-child {
  margin-inline-start: var(--swiper-centered-offset-before);
}
.swiper-centered.swiper-horizontal > .swiper-wrapper::before {
  height: 100%;
  min-height: 1px;
  width: var(--swiper-centered-offset-after);
}
.swiper-centered.swiper-vertical > .swiper-wrapper > .swiper-slide:first-child {
  margin-block-start: var(--swiper-centered-offset-before);
}
.swiper-centered.swiper-vertical > .swiper-wrapper::before {
  width: 100%;
  min-width: 1px;
  height: var(--swiper-centered-offset-after);
}
.swiper-centered > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: center center;
  scroll-snap-stop: always;
}
.swiper-virtual .swiper-slide {
  -webkit-backface-visibility: hidden;
  transform: translateZ(0);
}
.swiper-virtual.swiper-css-mode .swiper-wrapper::after {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  pointer-events: none;
}
.swiper-virtual.swiper-css-mode.swiper-horizontal .swiper-wrapper::after {
  height: 1px;
  width: var(--swiper-virtual-size);
}
.swiper-virtual.swiper-css-mode.swiper-vertical .swiper-wrapper::after {
  width: 1px;
  height: var(--swiper-virtual-size);
}
:root {
  --swiper-navigation-size: 44px;
  /*
  --swiper-navigation-color: var(--swiper-theme-color);
  */
}
.swiper-button-prev,
.swiper-button-next {
  position: absolute;
  top: 50%;
  width: calc(var(--swiper-navigation-size) / 44 * 27);
  height: var(--swiper-navigation-size);
  margin-top: calc(0px - (var(--swiper-navigation-size) / 2));
  z-index: 10;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--swiper-navigation-color, var(--swiper-theme-color));
}
.swiper-button-prev.swiper-button-disabled,
.swiper-button-next.swiper-button-disabled {
  opacity: 0.35;
  cursor: auto;
  pointer-events: none;
}
.swiper-button-prev.swiper-button-hidden,
.swiper-button-next.swiper-button-hidden {
  opacity: 0;
  cursor: auto;
  pointer-events: none;
}
.swiper-navigation-disabled .swiper-button-prev,
.swiper-navigation-disabled .swiper-button-next {
  display: none !important;
}
.swiper-button-prev:after,
.swiper-button-next:after {
  font-family: swiper-icons;
  font-size: var(--swiper-navigation-size);
  text-transform: none !important;
  letter-spacing: 0;
  font-variant: initial;
  line-height: 1;
}
.swiper-button-prev,
.swiper-rtl .swiper-button-next {
  left: 10px;
  right: auto;
}
.swiper-button-prev:after,
.swiper-rtl .swiper-button-next:after {
  content: 'prev';
}
.swiper-button-next,
.swiper-rtl .swiper-button-prev {
  right: 10px;
  left: auto;
}
.swiper-button-next:after,
.swiper-rtl .swiper-button-prev:after {
  content: 'next';
}
.swiper-button-lock {
  display: none;
}
:root {
  /*
  --swiper-pagination-color: var(--swiper-theme-color);
  --swiper-pagination-bullet-size: 8px;
  --swiper-pagination-bullet-width: 8px;
  --swiper-pagination-bullet-height: 8px;
  --swiper-pagination-bullet-inactive-color: #000;
  --swiper-pagination-bullet-inactive-opacity: 0.2;
  --swiper-pagination-bullet-opacity: 1;
  --swiper-pagination-bullet-horizontal-gap: 4px;
  --swiper-pagination-bullet-vertical-gap: 6px;
  */
}
.swiper-pagination {
  position: absolute;
  text-align: center;
  transition: 300ms opacity;
  transform: translate3d(0, 0, 0);
  z-index: 10;
}
.swiper-pagination.swiper-pagination-hidden {
  opacity: 0;
}
.swiper-pagination-disabled > .swiper-pagination,
.swiper-pagination.swiper-pagination-disabled {
  display: none !important;
}
/* Common Styles */
.swiper-pagination-fraction,
.swiper-pagination-custom,
.swiper-horizontal > .swiper-pagination-bullets,
.swiper-pagination-bullets.swiper-pagination-horizontal {
  bottom: 10px;
  left: 0;
  width: 100%;
}
/* Bullets */
.swiper-pagination-bullets-dynamic {
  overflow: hidden;
  font-size: 0;
}
.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transform: scale(0.33);
  position: relative;
}
.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active {
  transform: scale(1);
}
.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main {
  transform: scale(1);
}
.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev {
  transform: scale(0.66);
}
.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev {
  transform: scale(0.33);
}
.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next {
  transform: scale(0.66);
}
.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next {
  transform: scale(0.33);
}
.swiper-pagination-bullet {
  width: var(--swiper-pagination-bullet-width, var(--swiper-pagination-bullet-size, 8px));
  height: var(--swiper-pagination-bullet-height, var(--swiper-pagination-bullet-size, 8px));
  display: inline-block;
  border-radius: 50%;
  background: var(--swiper-pagination-bullet-inactive-color, #000);
  opacity: var(--swiper-pagination-bullet-inactive-opacity, 0.2);
}
button.swiper-pagination-bullet {
  border: none;
  margin: 0;
  padding: 0;
  box-shadow: none;
  -webkit-appearance: none;
          -moz-appearance: none;
       appearance: none;
}
.swiper-pagination-clickable .swiper-pagination-bullet {
  cursor: pointer;
}
.swiper-pagination-bullet:only-child {
  display: none !important;
}
.swiper-pagination-bullet-active {
  opacity: var(--swiper-pagination-bullet-opacity, 1);
  background: var(--swiper-pagination-color, var(--swiper-theme-color));
}
.swiper-vertical > .swiper-pagination-bullets,
.swiper-pagination-vertical.swiper-pagination-bullets {
  right: 10px;
  top: 50%;
  transform: translate3d(0px, -50%, 0);
}
.swiper-vertical > .swiper-pagination-bullets .swiper-pagination-bullet,
.swiper-pagination-vertical.swiper-pagination-bullets .swiper-pagination-bullet {
  margin: var(--swiper-pagination-bullet-vertical-gap, 6px) 0;
  display: block;
}
.swiper-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic,
.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
  top: 50%;
  transform: translateY(-50%);
  width: 8px;
}
.swiper-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,
.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  display: inline-block;
  transition: 200ms transform, 200ms top;
}
.swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet,
.swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 0 var(--swiper-pagination-bullet-horizontal-gap, 4px);
}
.swiper-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic,
.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;
}
.swiper-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,
.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transition: 200ms transform, 200ms left;
}
.swiper-horizontal.swiper-rtl > .swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transition: 200ms transform, 200ms right;
}
/* Progress */
.swiper-pagination-progressbar {
  background: rgba(0, 0, 0, 0.25);
  position: absolute;
}
.swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  background: var(--swiper-pagination-color, var(--swiper-theme-color));
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  transform: scale(0);
  transform-origin: left top;
}
.swiper-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  transform-origin: right top;
}
.swiper-horizontal > .swiper-pagination-progressbar,
.swiper-pagination-progressbar.swiper-pagination-horizontal,
.swiper-vertical > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite,
.swiper-pagination-progressbar.swiper-pagination-vertical.swiper-pagination-progressbar-opposite {
  width: 100%;
  height: 4px;
  left: 0;
  top: 0;
}
.swiper-vertical > .swiper-pagination-progressbar,
.swiper-pagination-progressbar.swiper-pagination-vertical,
.swiper-horizontal > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite,
.swiper-pagination-progressbar.swiper-pagination-horizontal.swiper-pagination-progressbar-opposite {
  width: 4px;
  height: 100%;
  left: 0;
  top: 0;
}
.swiper-pagination-lock {
  display: none;
}
/* Scrollbar */
.swiper-scrollbar {
  border-radius: 10px;
  position: relative;
  -ms-touch-action: none;
  background: rgba(0, 0, 0, 0.1);
}
.swiper-scrollbar-disabled > .swiper-scrollbar,
.swiper-scrollbar.swiper-scrollbar-disabled {
  display: none !important;
}
.swiper-horizontal > .swiper-scrollbar,
.swiper-scrollbar.swiper-scrollbar-horizontal {
  position: absolute;
  left: 1%;
  bottom: 3px;
  z-index: 50;
  height: 5px;
  width: 98%;
}
.swiper-vertical > .swiper-scrollbar,
.swiper-scrollbar.swiper-scrollbar-vertical {
  position: absolute;
  right: 3px;
  top: 1%;
  z-index: 50;
  width: 5px;
  height: 98%;
}
.swiper-scrollbar-drag {
  height: 100%;
  width: 100%;
  position: relative;
  background: rgba(0, 0, 0, 0.5);
  border-radius: 10px;
  left: 0;
  top: 0;
}
.swiper-scrollbar-cursor-drag {
  cursor: move;
}
.swiper-scrollbar-lock {
  display: none;
}
.swiper-zoom-container {
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
}
.swiper-zoom-container > img,
.swiper-zoom-container > svg,
.swiper-zoom-container > canvas {
  max-width: 100%;
  max-height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.swiper-slide-zoomed {
  cursor: move;
}
/* Preloader */
:root {
  /*
  --swiper-preloader-color: var(--swiper-theme-color);
  */
}
.swiper-lazy-preloader {
  width: 42px;
  height: 42px;
  position: absolute;
  left: 50%;
  top: 50%;
  margin-left: -21px;
  margin-top: -21px;
  z-index: 10;
  transform-origin: 50%;
  box-sizing: border-box;
  border: 4px solid var(--swiper-preloader-color, var(--swiper-theme-color));
  border-radius: 50%;
  border-top-color: transparent;
}
.swiper:not(.swiper-watch-progress) .swiper-lazy-preloader,
.swiper-watch-progress .swiper-slide-visible .swiper-lazy-preloader {
  animation: swiper-preloader-spin 1s infinite linear;
}
.swiper-lazy-preloader-white {
  --swiper-preloader-color: #fff;
}
.swiper-lazy-preloader-black {
  --swiper-preloader-color: #000;
}
@keyframes swiper-preloader-spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
/* a11y */
.swiper .swiper-notification {
  position: absolute;
  left: 0;
  top: 0;
  pointer-events: none;
  opacity: 0;
  z-index: -1000;
}
.swiper-free-mode > .swiper-wrapper {
  transition-timing-function: ease-out;
  margin: 0 auto;
}
.swiper-grid > .swiper-wrapper {
  flex-wrap: wrap;
}
.swiper-grid-column > .swiper-wrapper {
  flex-wrap: wrap;
  flex-direction: column;
}
.swiper-fade.swiper-free-mode .swiper-slide {
  transition-timing-function: ease-out;
}
.swiper-fade .swiper-slide {
  pointer-events: none;
  transition-property: opacity;
}
.swiper-fade .swiper-slide .swiper-slide {
  pointer-events: none;
}
.swiper-fade .swiper-slide-active,
.swiper-fade .swiper-slide-active .swiper-slide-active {
  pointer-events: auto;
}
.swiper-cube {
  overflow: visible;
}
.swiper-cube .swiper-slide {
  pointer-events: none;
  backface-visibility: hidden;
  z-index: 1;
  visibility: hidden;
  transform-origin: 0 0;
  width: 100%;
  height: 100%;
}
.swiper-cube .swiper-slide .swiper-slide {
  pointer-events: none;
}
.swiper-cube.swiper-rtl .swiper-slide {
  transform-origin: 100% 0;
}
.swiper-cube .swiper-slide-active,
.swiper-cube .swiper-slide-active .swiper-slide-active {
  pointer-events: auto;
}
.swiper-cube .swiper-slide-active,
.swiper-cube .swiper-slide-next,
.swiper-cube .swiper-slide-prev,
.swiper-cube .swiper-slide-next + .swiper-slide {
  pointer-events: auto;
  visibility: visible;
}
.swiper-cube .swiper-slide-shadow-top,
.swiper-cube .swiper-slide-shadow-bottom,
.swiper-cube .swiper-slide-shadow-left,
.swiper-cube .swiper-slide-shadow-right {
  z-index: 0;
  backface-visibility: hidden;
}
.swiper-cube .swiper-cube-shadow {
  position: absolute;
  left: 0;
  bottom: 0px;
  width: 100%;
  height: 100%;
  opacity: 0.6;
  z-index: 0;
}
.swiper-cube .swiper-cube-shadow:before {
  content: '';
  background: #000;
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  right: 0;
  filter: blur(50px);
}
.swiper-flip {
  overflow: visible;
}
.swiper-flip .swiper-slide {
  pointer-events: none;
  backface-visibility: hidden;
  z-index: 1;
}
.swiper-flip .swiper-slide .swiper-slide {
  pointer-events: none;
}
.swiper-flip .swiper-slide-active,
.swiper-flip .swiper-slide-active .swiper-slide-active {
  pointer-events: auto;
}
.swiper-flip .swiper-slide-shadow-top,
.swiper-flip .swiper-slide-shadow-bottom,
.swiper-flip .swiper-slide-shadow-left,
.swiper-flip .swiper-slide-shadow-right {
  z-index: 0;
  backface-visibility: hidden;
}
.swiper-creative .swiper-slide {
  backface-visibility: hidden;
  overflow: hidden;
  transition-property: transform, opacity, height;
}
.swiper-cards {
  overflow: visible;
}
.swiper-cards .swiper-slide {
  transform-origin: center bottom;
  backface-visibility: hidden;
  overflow: hidden;
}

.glightbox-container {
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 999999 !important;
  overflow: hidden;
  touch-action: none;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  text-size-adjust: 100%;
  backface-visibility: hidden;
  outline: none;
}

.glightbox-container.inactive {
  display: none;
}

.glightbox-container .gcontainer {
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 9999;
  overflow: hidden;
}

.glightbox-container .gslider {
  transition: transform 0.4s ease;
  height: 100%;
  left: 0;
  top: 0;
  width: 100%;
  position: relative;
  overflow: hidden;
  display: flex !important;
  justify-content: center;
  align-items: center;
  transform: translate3d(0, 0, 0);
}

.glightbox-container .gslide {
  width: 100%;
  position: absolute;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
}

.glightbox-container .gslide.current {
  opacity: 1;
  z-index: 99999;
  position: relative;
}

.glightbox-container .gslide.prev {
  opacity: 1;
  z-index: 9999;
}

.glightbox-container .gslide-inner-content {
  width: 100%;
}

.glightbox-container .ginner-container {
  position: relative;
  width: 100%;
  display: flex;
  justify-content: center;
  flex-direction: column;
  max-width: 100%;
  margin: auto;
  height: 100vh;
}

.glightbox-container .ginner-container.gvideo-container {
  width: 100%;
}

.glightbox-container .ginner-container.desc-bottom,
        .glightbox-container .ginner-container.desc-top {
  flex-direction: column;
}

.glightbox-container .ginner-container.desc-left,
        .glightbox-container .ginner-container.desc-right {
  max-width: 100% !important;
}

.gslide iframe,
    .gslide video {
  outline: none !important;
  border: none;
  min-height: 165px;
  -webkit-overflow-scrolling: touch;
  touch-action: auto;
}

.gslide:not(.current) {
  pointer-events: none;
}

.gslide-image {
  align-items: center;
}

.gslide-image img {
  max-height: 100vh;
  display: block;
  padding: 0;
  float: none;
  outline: none;
  border: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  max-width: 100vw;
  width: auto;
  height: auto;
  -o-object-fit: cover;
  object-fit: cover;
  touch-action: none;
  margin: auto;
  min-width: 200px;
}

.desc-top .gslide-image img,
        .desc-bottom .gslide-image img {
  width: auto;
}

.desc-left .gslide-image img,
        .desc-right .gslide-image img {
  width: auto;
  max-width: 100%;
}

.gslide-image img.zoomable {
  position: relative;
}

.gslide-image img.dragging {
  cursor: grabbing !important;
  transition: none;
}

.gslide-video {
  position: relative;
  max-width: 100vh;
  width: 100% !important;
}

.gslide-video .plyr__poster-enabled.plyr--loading .plyr__poster {
  display: none;
}

.gslide-video .gvideo-wrapper {
  width: 100%;
        /* max-width: 160vmin; */
  margin: auto;
}

.gslide-video::before {
  content: '';
  position: absolute;
  width: 100%;
  height: 100%;
  background: rgba(255, 0, 0, 0.34);
  display: none;
}

.gslide-video.playing::before {
  display: none;
}

.gslide-video.fullscreen {
  max-width: 100% !important;
  min-width: 100%;
  height: 75vh;
}

.gslide-video.fullscreen video {
  max-width: 100% !important;
  width: 100% !important;
}

.gslide-inline {
  background: #fff;
  text-align: left;
  max-height: calc(100vh - 40px);
  overflow: auto;
  max-width: 100%;
  margin: auto;
}

.gslide-inline .ginlined-content {
  padding: 20px;
  width: 100%;
}

.gslide-inline .dragging {
  cursor: grabbing !important;
  transition: none;
}

.ginlined-content {
  overflow: auto;
  display: block !important;
  opacity: 1;
}

.gslide-external {
  display: flex;
  width: 100%;
  min-width: 100%;
  background: #fff;
  padding: 0;
  overflow: auto;
  max-height: 75vh;
  height: 100%;
}

.gslide-media {
  display: flex;
  width: auto;
}

.zoomed .gslide-media {
  box-shadow: none !important;
}

.desc-top .gslide-media,
    .desc-bottom .gslide-media {
  margin: 0 auto;
  flex-direction: column;
}

.gslide-description {
  position: relative;
  flex: 1 0 100%;
}

.gslide-description.description-left,
    .gslide-description.description-right {
  max-width: 100%;
}

.gslide-description.description-bottom,
    .gslide-description.description-top {
  margin: 0 auto;
  width: 100%;
}

.gslide-description p {
  margin-bottom: 12px;
}

.gslide-description p:last-child {
  margin-bottom: 0;
}

.zoomed .gslide-description {
  display: none;
}

.glightbox-button-hidden {
  display: none;
}


/*
 * Description for mobiles
 * something like facebook does the description
 * for the photos
*/

.glightbox-mobile .glightbox-container .gslide-description {
  height: auto !important;
  width: 100%;
  position: absolute;
  bottom: 0;
  padding: 19px 11px;
  max-width: 100vw !important;
  order: 2 !important;
  max-height: 78vh;
  overflow: auto !important;
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.75) 100%);
  transition: opacity 0.3s linear;
  padding-bottom: 50px;
}

.glightbox-mobile .glightbox-container .gslide-title {
  color: #fff;
  font-size: 1em;
}

.glightbox-mobile .glightbox-container .gslide-desc {
  color: #a1a1a1;
}

.glightbox-mobile .glightbox-container .gslide-desc a {
  color: #fff;
  font-weight: bold;
}

.glightbox-mobile .glightbox-container .gslide-desc * {
  color: inherit;
}

.glightbox-mobile .glightbox-container .gslide-desc .desc-more {
  color: #fff;
  opacity: 0.4;
}

.gdesc-open .gslide-media {
  transition: opacity 0.5s ease;
  opacity: 0.4;
}

.gdesc-open .gdesc-inner {
  padding-bottom: 30px;
}

.gdesc-closed .gslide-media {
  transition: opacity 0.5s ease;
  opacity: 1;
}

.greset {
  transition: all 0.3s ease;
}

.gabsolute {
  position: absolute;
}

.grelative {
  position: relative;
}

.glightbox-desc {
  display: none !important;
}

.glightbox-open {
  overflow: hidden;
}

.gloader {
  height: 25px;
  width: 25px;
  animation: lightboxLoader 0.8s infinite linear;
  border: 2px solid #fff;
  border-right-color: transparent;
  border-radius: 50%;
  position: absolute;
  display: block;
  z-index: 9999;
  left: 0;
  right: 0;
  margin: 0 auto;
  top: 47%;
}

.goverlay {
  width: 100%;
  height: calc(100vh + 1px);
  position: fixed;
  top: -1px;
  left: 0;
  background: #000;
  will-change: opacity;
}

.glightbox-mobile .goverlay {
  background: #000;
}

.gprev,
.gnext,
.gclose {
  z-index: 99999;
  cursor: pointer;
  width: 26px;
  height: 44px;
  border: none;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
}

.gprev svg,
.gnext svg,
.gclose svg {
  display: block;
  width: 25px;
  height: auto;
  margin: 0;
  padding: 0;
}

.gprev.disabled,
.gnext.disabled,
.gclose.disabled {
  opacity: 0.1;
}

.gprev .garrow,
.gnext .garrow,
.gclose .garrow {
  stroke: #fff;
}

.gbtn.focused {
  outline: 2px solid #0f3d81;
}

iframe.wait-autoplay {
  opacity: 0;
}

.glightbox-closing .gnext,
    .glightbox-closing .gprev,
    .glightbox-closing .gclose {
  opacity: 0 !important;
}


/*Skin */

.glightbox-clean .gslide-description {
  background: #fff;
}

.glightbox-clean .gdesc-inner {
  padding: 22px 20px;
}

.glightbox-clean .gslide-title {
  font-size: 1em;
  font-weight: normal;
  font-family: arial;
  color: #000;
  margin-bottom: 19px;
  line-height: 1.4em;
}

.glightbox-clean .gslide-desc {
  font-size: 0.86em;
  margin-bottom: 0;
  font-family: arial;
  line-height: 1.4em;
}

.glightbox-clean .gslide-video {
  background: #000;
}

.glightbox-clean .gprev,
    .glightbox-clean .gnext,
    .glightbox-clean .gclose {
  background-color: rgba(0, 0, 0, 0.75);
  border-radius: 4px;
}

.glightbox-clean .gprev path,
.glightbox-clean .gnext path,
.glightbox-clean .gclose path {
  fill: #fff;
}

.glightbox-clean .gprev {
  position: absolute;
  top: -100%;
  left: 30px;
  width: 40px;
  height: 50px;
}

.glightbox-clean .gnext {
  position: absolute;
  top: -100%;
  right: 30px;
  width: 40px;
  height: 50px;
}

.glightbox-clean .gclose {
  width: 35px;
  height: 35px;
  top: 15px;
  right: 10px;
  position: absolute;
}

.glightbox-clean .gclose svg {
  width: 18px;
  height: auto;
}

.glightbox-clean .gclose:hover {
  opacity: 1;
}


/*CSS Animations*/

.gfadeIn {
  animation: gfadeIn 0.5s ease;
}

.gfadeOut {
  animation: gfadeOut 0.5s ease;
}

.gslideOutLeft {
  animation: gslideOutLeft 0.3s ease;
}

.gslideInLeft {
  animation: gslideInLeft 0.3s ease;
}

.gslideOutRight {
  animation: gslideOutRight 0.3s ease;
}

.gslideInRight {
  animation: gslideInRight 0.3s ease;
}

.gzoomIn {
  animation: gzoomIn 0.5s ease;
}

.gzoomOut {
  animation: gzoomOut 0.5s ease;
}

@keyframes lightboxLoader {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

@keyframes gfadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@keyframes gfadeOut {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}

@keyframes gslideInLeft {
  from {
    opacity: 0;
    transform: translate3d(-60%, 0, 0);
  }
  to {
    visibility: visible;
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}

@keyframes gslideOutLeft {
  from {
    opacity: 1;
    visibility: visible;
    transform: translate3d(0, 0, 0);
  }
  to {
    transform: translate3d(-60%, 0, 0);
    opacity: 0;
    visibility: hidden;
  }
}

@keyframes gslideInRight {
  from {
    opacity: 0;
    visibility: visible;
    transform: translate3d(60%, 0, 0);
  }
  to {
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}

@keyframes gslideOutRight {
  from {
    opacity: 1;
    visibility: visible;
    transform: translate3d(0, 0, 0);
  }
  to {
    transform: translate3d(60%, 0, 0);
    opacity: 0;
  }
}

@keyframes gzoomIn {
  from {
    opacity: 0;
    transform: scale3d(0.3, 0.3, 0.3);
  }
  to {
    opacity: 1;
  }
}

@keyframes gzoomOut {
  from {
    opacity: 1;
  }
  50% {
    opacity: 0;
    transform: scale3d(0.3, 0.3, 0.3);
  }
  to {
    opacity: 0;
  }
}

@media (min-width: 769px) {
  .glightbox-container .ginner-container {
    width: auto;
    height: auto;
    flex-direction: row;
  }
  .glightbox-container .ginner-container.desc-top .gslide-description {
    order: 0;
  }
  .glightbox-container .ginner-container.desc-top .gslide-image,
                .glightbox-container .ginner-container.desc-top .gslide-image img {
    order: 1;
  }
  .glightbox-container .ginner-container.desc-left .gslide-description {
    order: 0;
  }
  .glightbox-container .ginner-container.desc-left .gslide-image {
    order: 1;
  }
  .gslide-image img {
    max-height: 97vh;
    max-width: 100%;
  }
  .gslide-image img.zoomable {
    cursor: zoom-in;
  }
  .zoomed .gslide-image img.zoomable {
    cursor: grab;
  }
  .gslide-inline {
    max-height: 95vh;
  }
  .gslide-external {
    max-height: 100vh;
  }
  .gslide-description.description-left,
    .gslide-description.description-right {
    max-width: 275px;
  }
  .glightbox-open {
    height: auto;
  }
  .goverlay {
    background: rgba(0, 0, 0, 0.92);
  }
  .glightbox-clean .gslide-media {
    box-shadow: 1px 2px 9px 0px rgba(0, 0, 0, 0.65);
  }
  .glightbox-clean .description-left .gdesc-inner,
.glightbox-clean .description-right .gdesc-inner {
    position: absolute;
    height: 100%;
    overflow-y: auto;
  }
  .glightbox-clean .gprev,
    .glightbox-clean .gnext,
    .glightbox-clean .gclose {
    background-color: rgba(0, 0, 0, 0.32);
  }
  .glightbox-clean .gprev:hover,
.glightbox-clean .gnext:hover,
.glightbox-clean .gclose:hover {
    background-color: rgba(0, 0, 0, 0.7);
  }
  .glightbox-clean .gprev {
    top: 45%;
  }
  .glightbox-clean .gnext {
    top: 45%;
  }
}

@media (min-width: 992px) {
  .glightbox-clean .gclose {
    opacity: 0.7;
    right: 20px;
  }
}

@media screen and (max-height: 420px) {
  .goverlay {
    background: #000;
  }
}

@charset "UTF-8";
/*
	Theme Name: Blueprint
	Theme URI: https://eightarms.co.uk/
	Author: Eight Arms
	Author URI: https://eightarms.co.uk/
	Description: Framework
	Version: 1
*/
/* Base                      --- */
h1 {
  font-size: 2.5rem;
  margin-bottom: 0.5em;
}

h2 {
  font-size: 2rem;
  margin-bottom: 0.5em;
}

h3 {
  font-size: 1.75rem;
  margin-bottom: 0.5em;
}

h4 {
  font-size: 1.5rem;
  margin-bottom: 0.5em;
}

h5 {
  font-size: 1.25rem;
  margin-bottom: 0.5em;
}

h6 {
  font-size: 1rem;
  margin-bottom: 0.5em;
}

/*! normalize.css v3.0.2 | MIT License | git.io/normalize */
/**
 * 1. Set default font family to sans-serif.
 * 2. Prevent iOS text size adjust after orientation change, without disabling
 *    user zoom.
 */
html {
  font-family: sans-serif; /* 1 */
  -ms-text-size-adjust: 100%; /* 2 */
  -webkit-text-size-adjust: 100%; /* 2 */
  scroll-behavior: smooth;
}

.wp-block-columns {
  margin: 0px !important;
}

* {
  box-sizing: border-box;
}

/**
 * Remove default margin.
 */
body {
  margin: 0;
}

/* HTML5 display definitions
   ========================================================================== */
/**
 * Correct `block` display not defined for any HTML5 element in IE 8/9.
 * Correct `block` display not defined for `details` or `summary` in IE 10/11
 * and Firefox.
 * Correct `block` display not defined for `main` in IE 11.
 */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
menu,
nav,
section,
summary {
  display: block;
}

/**
 * 1. Correct `inline-block` display not defined in IE 8/9.
 * 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera.
 */
audio,
canvas,
progress,
video {
  display: inline-block; /* 1 */
  vertical-align: baseline; /* 2 */
}

/**
 * Prevent modern browsers from displaying `audio` without controls.
 * Remove excess height in iOS 5 devices.
 */
audio:not([controls]) {
  display: none;
  height: 0;
}

/**
 * Address `[hidden]` styling not present in IE 8/9/10.
 * Hide the `template` element in IE 8/9/11, Safari, and Firefox < 22.
 */
[hidden],
template {
  display: none;
}

/* Links
   ========================================================================== */
/**
 * Remove the gray background color from active links in IE 10.
 */
a {
  background-color: transparent;
}

/**
 * Improve readability when focused and also mouse hovered in all browsers.
 */
a:active,
a:hover {
  outline: 0;
}

/* Text-level semantics
   ========================================================================== */
/**
 * Address styling not present in IE 8/9/10/11, Safari, and Chrome.
 */
abbr[title] {
  border-bottom: 1px dotted;
}

/**
 * Address style set to `bolder` in Firefox 4+, Safari, and Chrome.
 */
b,
strong {
  font-weight: bold;
}

/**
 * Address styling not present in Safari and Chrome.
 */
dfn {
  font-style: italic;
}

/**
 * Address variable `h1` font-size and margin within `section` and `article`
 * contexts in Firefox 4+, Safari, and Chrome.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

/**
 * Address styling not present in IE 8/9.
 */
mark {
  background: #ff0;
  color: #000;
}

/**
 * Address inconsistent and variable font size in all browsers.
 */
small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` affecting `line-height` in all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sup {
  top: -0.5em;
}

sub {
  bottom: -0.25em;
}

/* Embedded content
   ========================================================================== */
/**
 * Remove border when inside `a` element in IE 8/9/10.
 */
img {
  border: 0;
}

/**
 * Correct overflow not hidden in IE 9/10/11.
 */
svg:not(:root) {
  overflow: hidden;
}

/* Grouping content
   ========================================================================== */
/**
 * Address margin not present in IE 8/9 and Safari.
 */
figure {
  margin: 1em 40px;
}

/**
 * Address differences between Firefox and other browsers.
 */
hr {
  box-sizing: content-box;
  height: 0;
}

/**
 * Contain overflow in all browsers.
 */
pre {
  overflow: auto;
}

/**
 * Address odd `em`-unit font size rendering in all browsers.
 */
code,
kbd,
pre,
samp {
  font-family: monospace, monospace;
  font-size: 1em;
}

/* Forms
   ========================================================================== */
/**
 * Known limitation: by default, Chrome and Safari on OS X allow very limited
 * styling of `select`, unless a `border` property is set.
 */
/**
 * 1. Correct color not being inherited.
 *    Known issue: affects color of disabled elements.
 * 2. Correct font properties not being inherited.
 * 3. Address margins set differently in Firefox 4+, Safari, and Chrome.
 */
button,
input,
optgroup,
select,
textarea {
  color: inherit; /* 1 */
  font: inherit; /* 2 */
  margin: 0; /* 3 */
}

/**
 * Address `overflow` set to `hidden` in IE 8/9/10/11.
 */
button {
  overflow: visible;
}

/**
 * Address inconsistent `text-transform` inheritance for `button` and `select`.
 * All other form control elements do not inherit `text-transform` values.
 * Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera.
 * Correct `select` style inheritance in Firefox.
 */
button,
select {
  text-transform: none;
}

/**
 * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`
 *    and `video` controls.
 * 2. Correct inability to style clickable `input` types in iOS.
 * 3. Improve usability and consistency of cursor style between image-type
 *    `input` and others.
 */
button,
html input[type=button],
input[type=reset],
input[type=submit] {
  -webkit-appearance: button; /* 2 */
  cursor: pointer; /* 3 */
}

/**
 * Re-set default cursor for disabled elements.
 */
button[disabled],
html input[disabled] {
  cursor: default;
}

/**
 * Remove inner padding and border in Firefox 4+.
 */
button::-moz-focus-inner,
input::-moz-focus-inner {
  border: 0;
  padding: 0;
}

/**
 * Address Firefox 4+ setting `line-height` on `input` using `!important` in
 * the UA stylesheet.
 */
input {
  line-height: normal;
}

/**
 * It's recommended that you don't attempt to style these elements.
 * Firefox's implementation doesn't respect box-sizing, padding, or width.
 *
 * 1. Address box sizing set to `content-box` in IE 8/9/10.
 * 2. Remove excess padding in IE 8/9/10.
 */
input[type=checkbox],
input[type=radio] {
  box-sizing: border-box; /* 1 */
  padding: 0; /* 2 */
}

/**
 * Fix the cursor style for Chrome's increment/decrement buttons. For certain
 * `font-size` values of the `input`, it causes the cursor style of the
 * decrement button to change from `default` to `text`.
 */
input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * 1. Address `appearance` set to `searchfield` in Safari and Chrome.
 * 2. Address `box-sizing` set to `border-box` in Safari and Chrome
 *    (include `-moz` to future-proof).
 */
input[type=search] {
  -webkit-appearance: textfield; /* 1 */ /* 2 */
  box-sizing: content-box;
}

/**
 * Remove inner padding and search cancel button in Safari and Chrome on OS X.
 * Safari (but not Chrome) clips the cancel button when the search input has
 * padding (and `textfield` appearance).
 */
input[type=search]::-webkit-search-cancel-button,
input[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * Define consistent border, margin, and padding.
 */
fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em;
}

/**
 * 1. Correct `color` not being inherited in IE 8/9/10/11.
 * 2. Remove padding so people aren't caught out if they zero out fieldsets.
 */
legend {
  border: 0; /* 1 */
  padding: 0; /* 2 */
}

/**
 * Remove default vertical scrollbar in IE 8/9/10/11.
 */
textarea {
  overflow: auto;
}

/**
 * Don't inherit the `font-weight` (applied by a rule above).
 * NOTE: the default cannot safely be changed in Chrome and Safari on OS X.
 */
optgroup {
  font-weight: bold;
}

/* Tables
   ========================================================================== */
/**
 * Remove most spacing between table cells.
 */
table {
  border-collapse: collapse;
  border-spacing: 0;
}

td,
th {
  padding: 0;
}

[v-cloak] {
  display: none !important;
}

:root {
  --white: #fff;
  --black: #000;
  --atomicYellow: #dcff3c;
  --plum: #321432;
  --aluminium: #c8d2d2;
  --earth: #fafaf0;
  --blue: #008cff;
  --purple: #a54cff;
  --red: #e6284b;
  --orange: #ff8700;
  --green: #00dc00;
}

/* Only include woff2 for modern browsers. Add woff only if you need to support IE safari 13-, etc. */
@font-face {
  font-family: "Bauziet";
  src: url("../fonts/Bauziet-Regular.woff2") format("woff2"), url("../fonts/Bauziet-Regular.woff") format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
h1, .h1, h2, .h2, h3, .h3, h4, .h4, h1.wp-block-post-title, body#tinymce h2, h5, .h5, .centered-text-panel h2, .text-block h1,
.text-block h2, body#tinymce h3, h6, .h6, .text-block h3,
.text-block h4,
.text-block h5,
.text-block h6, .text-and-image-banner h1 + p, .hero-banner h1 + p, body#tinymce h5, body#tinymce h4, a, li, ul, span, button, p {
  font-family: "Bauziet", sans-serif !important;
  word-break: break-word;
}

a, button {
  cursor: pointer !important;
}

body {
  font-weight: 400;
  font-family: "Bauziet", sans-serif;
  color: var(--plum);
  background-color: var(--earth);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

h1,
.h1,
h2,
.h2,
h3,
.h3,
h4,
.h4,
h1.wp-block-post-title,
body#tinymce h2,
h5,
.h5,
.centered-text-panel h2,
.text-block h1,
.text-block h2,
body#tinymce h3,
h6,
.h6,
.text-block h3,
.text-block h4,
.text-block h5,
.text-block h6,
.text-and-image-banner h1 + p,
.hero-banner h1 + p,
body#tinymce h5,
body#tinymce h4 {
  margin-top: 30px;
  margin-bottom: 0;
  font-weight: 400;
  display: block;
  font-family: "Bauziet", "sans-serif";
}
h1 a,
.h1 a,
h2 a,
.h2 a,
h3 a,
.h3 a,
h4 a,
.h4 a,
h1.wp-block-post-title a,
body#tinymce h2 a,
h5 a,
.h5 a,
.centered-text-panel h2 a,
.text-block h1 a,
.text-block h2 a,
body#tinymce h3 a,
h6 a,
.h6 a,
.text-block h3 a,
.text-block h4 a,
.text-block h5 a,
.text-block h6 a,
.text-and-image-banner h1 + p a,
.hero-banner h1 + p a,
body#tinymce h5 a,
body#tinymce h4 a {
  border: 0;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.2em;
}

h2.wp-block-heading {
  margin-top: 60px !important;
}

h1,
.h1 {
  font-size: clamp(3rem, 1.01rem + 8.6vw, 8.75rem);
  line-height: clamp(3rem, 1.01rem + 8.6vw, 8.75rem);
}

h2,
.h2 {
  font-size: clamp(3rem, 2.3rem + 3vw, 5rem);
  line-height: clamp(3rem, 2.3rem + 3vw, 5rem);
  font-weight: 500;
}

h3,
.h3 {
  font-size: clamp(3.5rem, 3.39rem + 0.4vw, 3.75rem);
  line-height: clamp(3.5rem, 3.39rem + 0.4vw, 3.75rem);
  font-weight: 500;
}

h4,
.h4,
h1.wp-block-post-title,
body#tinymce h2 {
  font-size: clamp(2.5rem, 2.28rem + 0.8vw, 3rem);
  line-height: clamp(3.25rem, 3.14rem + 0.4vw, 3.5rem);
  font-weight: 600;
}

h5,
.h5,
.centered-text-panel h2,
.text-block h1,
.text-block h2,
body#tinymce h3 {
  font-size: clamp(2.25rem, 2.14rem + 0.4vw, 2.5rem);
  line-height: clamp(2.75rem, 2.64rem + 0.4vw, 3rem);
  font-weight: 400;
}

h6,
.h6,
.text-block h3,
.text-block h4,
.text-block h5,
.text-block h6,
.text-and-image-banner h1 + p,
.hero-banner h1 + p,
body#tinymce h5,
body#tinymce h4 {
  font-size: clamp(1.75rem, 1.64rem + 0.4vw, 2rem);
  line-height: clamp(2.25rem, 2.14rem + 0.4vw, 2.5rem);
  font-weight: 400;
}

.small-title, .hero-banner p, .large-intro > *:first-child {
  font-size: clamp(1.125rem, 0.96rem + 0.6vw, 1.5rem);
  line-height: clamp(1.625rem, 1.46rem + 0.6vw, 2rem);
  font-weight: 400;
}

.small-title--bold, .wysiwyg h1,
.wysiwyg h2,
.wysiwyg h3,
.wysiwyg h4,
.wysiwyg h5,
.wysiwyg h6, .post-navigation a {
  font-size: clamp(1.5rem, 1.5rem + 0vw, 1.5rem);
  line-height: clamp(2rem, 2rem + 0vw, 2rem);
  font-weight: 600;
}

p,
.p,
.testimonials cite,
.text-block li,
.single-post--content li,
.editor-styles-wrapper li.block-editor-block-list__block,
ol,
ul,
.wpcf7 form .wpcf7-response-output,
address {
  font-size: clamp(1.125rem, 1.07rem + 0.2vw, 1.25rem);
  line-height: clamp(1.5rem, 1.39rem + 0.4vw, 1.75rem);
  margin-top: clamp(1.5rem, 1.28rem + 0.8vw, 2rem);
  color: var(--plum);
  margin-bottom: 0;
}

p.small-para,
.small-para,
.header-message,
.small-para p,
.header-message p,
span.small-para,
a.small-para {
  font-size: clamp(0.75rem, 0.75rem + 0vw, 0.75rem);
  line-height: clamp(1.25rem, 1.25rem + 0vw, 1.25rem);
}

address {
  font-style: normal;
  position: relative;
}

body#tinymce {
  color: #000 !important;
}
body#tinymce p {
  color: #000;
}
.snug {
  margin-top: 0;
}

.snug-child > *:first-child {
  margin-top: 0;
}

.text-center {
  text-align: center;
}

.text-right {
  text-align: right;
}

.text-left {
  text-align: left;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}

hr {
  border: 0;
  border-top: 1px solid;
  border-color: #f8eeff;
  margin-top: 40px;
}

img.alignright {
  float: right;
  margin-left: 15px;
  margin-bottom: 15px;
}

img.alignleft {
  float: left;
  margin-right: 15px;
  margin-bottom: 15px;
}

img.alignnone {
  width: 100%;
  height: auto;
  margin: 0 auto;
}

.white-text {
  color: var(--earth);
}
.white-text h1,
.white-text h2 {
  color: var(--atomicYellow);
}
.white-text h3,
.white-text h4,
.white-text h5,
.white-text h6 {
  color: var(--white);
}
.white-text p,
.white-text ul,
.white-text ol,
.white-text li,
.white-text a:not(.blueprint--button) {
  color: var(--earth);
}
.white-text span {
  color: var(--earth);
}

.white-bg {
  background-color: var(--earth);
}

.yellow-bg {
  background-color: var(--atomicYellow);
}

.aluminium-bg {
  background-color: var(--aluminium);
}

.earth-bg {
  background-color: var(--earth);
}

.plum-bg {
  background-color: var(--plum);
}

main {
  position: relative;
}

.content-panel.team:before,
main:before {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-repeat: repeat-y;
  background-size: 100%;
  z-index: 1;
}

main.plum-bg:before {
  content: "";
  background-image: url(../img/plum-bg-image.webp);
  opacity: 0.1;
}
main.plum-bg .content-panel.plum-bg {
  background-color: transparent;
}

main.earth-bg:before {
  content: "";
  background-image: url(../img/plum-bg-image.webp);
  opacity: 1;
}

.team.aluminium-bg:before,
main.aluminium-bg:before {
  content: "";
  background-image: url(../img/plum-bg-image.webp);
  opacity: 1;
}

.flexible-content-panels {
  position: relative;
  z-index: 2;
}

@keyframes fadeInUp {
  0% {
    transform: translateY(40px);
    opacity: 0;
  }
  100% {
    transform: translateY(0);
    opacity: 1;
  }
}
@keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.fade-in {
  opacity: 0;
}

.fade-in.in-view {
  animation: fadeIn;
  animation-duration: 1s;
  animation-fill-mode: both;
}

.fade-up {
  opacity: 0;
  transform: translateY(40px);
}

.fade-up.in-view {
  animation: fadeInUp;
  animation-duration: 1s;
  animation-fill-mode: both;
}

@keyframes growCircle {
  0%, 80%, 100% {
    transform: scale(1);
  }
  90% {
    transform: scale(calc(0.7 - var(--y) * 0.3));
  }
}
@keyframes growCircleSlow {
  0%, 40%, 100% {
    transform: scale(1);
  }
  70% {
    transform: scale(calc(0.7 - var(--y) * 0.3));
  }
}
circle {
  transform-box: fill-box;
  transform-origin: center center;
  animation: growCircle 9s infinite;
  animation-delay: calc(var(--x) * -0.04s - 5s);
}

svg.pattern-a {
  width: 100%;
  height: 80px;
  display: block;
}
svg.pattern-a.flipped {
  transform: rotate(180deg);
}
svg.pattern-a.flipped circle {
  animation-direction: reverse;
}

.pattern-a.is-yellow {
  color: var(--atomicYellow);
  background-color: var(--plum);
}

.pattern-a.is-aluminium {
  color: var(--aluminium);
  background-color: var(--plum);
}

.pattern-a.is-red {
  color: red;
}

.pattern-a.is-on-grey {
  color: rgba(50, 20, 50, 0.05);
}
.pattern-a.is-on-grey circle {
  animation-name: growCircleSlow;
}

html :where(.wp-block) {
  max-width: 100% !important;
  margin: 0 !important;
}

.edit-post-visual-editor__post-title-wrapper {
  margin-bottom: 30px !important;
  text-align: center;
}

html :where(.wp-block) .fade-in,
html :where(.wp-block) .fade-up {
  opacity: 1;
}

@media (min-width: 782px) {
  .interface-complementary-area {
    width: 480px;
  }
}
body#tinymce {
  background-color: transparent;
  padding: 1em;
  padding-top: 0;
}

/* Elements                  --- */
a {
  color: var(--plum);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.2em;
  font-weight: 600;
}
a:hover {
  color: var(--plum);
}
a.no-ul {
  text-decoration: none;
}

a.block-link {
  display: block;
  color: inherit;
  border: 0;
}
a.block-link:hover {
  text-decoration: none;
}

.blueprint--button {
  font-weight: 600;
  display: inline-flex;
  gap: 10px;
  align-items: center;
  justify-content: center;
  height: auto;
  padding: 16px 24px;
  border-radius: 100px;
  line-height: 20px;
  border: 1px solid var(--atomicYellow);
  font-size: clamp(0.938rem, 0.855rem + 0.3vw, 1.125rem);
  outline: none;
  transition: color 0.3s ease-in-out, background-color 0.3s ease-in-out, border-color 0.3s ease-in-out;
  background-color: var(--atomicYellow);
  color: var(--plum);
  text-decoration: none;
}
.blueprint--button.hover, .blueprint--button:hover, .blueprint--button:active {
  background-color: var(--plum);
  border-color: var(--plum);
  color: #fff;
}
.blueprint--button.is-plum {
  border: 1px solid var(--plum);
}

.white-text .blueprint--button:hover,
.white-text .blueprint--button:active {
  border-color: var(--earth);
  color: var(--earth);
}

.plum-bg .blueprint--button:hover,
.plum-bg .blueprint--button:active {
  border-color: var(--earth);
  color: var(--earth);
}

button.hamburger {
  display: flex;
  align-items: center;
  gap: 10px;
  border: 0;
  background-color: transparent;
  display: none;
  font-weight: 500;
}
@media (max-width: 991px) {
  button.hamburger {
    display: flex;
    justify-content: center;
    align-items: center;
  }
}

.search-mobile-button {
  background-color: transparent;
  border: none;
}

.search-mobile-button span {
  display: flex;
}

span.hamburger--icon {
  position: relative;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background-color: var(--plum);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  outline: none;
  border: 0;
}

.menu-button {
  display: none;
  gap: 0rem;
  justify-content: center;
  align-items: center;
}
@media (max-width: 991px) {
  .menu-button {
    display: flex;
  }
}

.inline-tag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: var(--lightPurple);
  height: 32px;
  padding: 0 10px;
  text-decoration: none;
  border: 0;
  border-radius: 3px;
}
.inline-tag:hover, .inline-tag:active, .inline-tag:focus {
  text-decoration: none;
  border: 0;
}

.blueprint--form form {
  /* Removes awkward default styles on some inputs for iOS */
}
.blueprint--form form input:-webkit-autofill,
.blueprint--form form input:-webkit-autofill:hover,
.blueprint--form form input:-webkit-autofill:focus,
.blueprint--form form input:-webkit-autofill:active {
  -webkit-box-shadow: 0 0 0 30px white inset !important;
}
.blueprint--form form input[type=email],
.blueprint--form form input[type=number],
.blueprint--form form input[type=search],
.blueprint--form form input[type=text],
.blueprint--form form input[type=tel],
.blueprint--form form input[type=url],
.blueprint--form form input[type=password],
.blueprint--form form input[type=file],
.blueprint--form form textarea,
.blueprint--form form select {
  height: clamp(2.375rem, 2.155rem + 0.8vw, 2.875rem);
  padding: 0 clamp(1.125rem, 0.885rem + 1.1vw, 1.875rem);
  border: 0;
  border-radius: 3px;
  border: 1px solid var(--black);
  border-radius: 100px;
  color: var(--black);
  box-shadow: none;
  box-sizing: border-box;
  width: 100%;
  font-weight: 400;
  font-size: clamp(0.75rem, 0.6675rem + 0.3vw, 0.938rem);
  line-height: clamp(1.125rem, 0.96rem + 0.6vw, 1.5rem);
  margin-top: 0;
  margin-top: 3px;
  background-color: var(--lightPurple);
  font-family: "Roboto Flex", sans-serif;
}
.blueprint--form form input[type=email]::-webkit-input-placeholder,
.blueprint--form form input[type=number]::-webkit-input-placeholder,
.blueprint--form form input[type=search]::-webkit-input-placeholder,
.blueprint--form form input[type=text]::-webkit-input-placeholder,
.blueprint--form form input[type=tel]::-webkit-input-placeholder,
.blueprint--form form input[type=url]::-webkit-input-placeholder,
.blueprint--form form input[type=password]::-webkit-input-placeholder,
.blueprint--form form input[type=file]::-webkit-input-placeholder,
.blueprint--form form textarea::-webkit-input-placeholder,
.blueprint--form form select::-webkit-input-placeholder {
  color: rgba(var(--blue), 0.5);
}
.blueprint--form form input[type=email]:-moz-placeholder,
.blueprint--form form input[type=number]:-moz-placeholder,
.blueprint--form form input[type=search]:-moz-placeholder,
.blueprint--form form input[type=text]:-moz-placeholder,
.blueprint--form form input[type=tel]:-moz-placeholder,
.blueprint--form form input[type=url]:-moz-placeholder,
.blueprint--form form input[type=password]:-moz-placeholder,
.blueprint--form form input[type=file]:-moz-placeholder,
.blueprint--form form textarea:-moz-placeholder,
.blueprint--form form select:-moz-placeholder {
  color: rgba(var(--blue), 0.5);
}
.blueprint--form form input[type=email]::-moz-placeholder,
.blueprint--form form input[type=number]::-moz-placeholder,
.blueprint--form form input[type=search]::-moz-placeholder,
.blueprint--form form input[type=text]::-moz-placeholder,
.blueprint--form form input[type=tel]::-moz-placeholder,
.blueprint--form form input[type=url]::-moz-placeholder,
.blueprint--form form input[type=password]::-moz-placeholder,
.blueprint--form form input[type=file]::-moz-placeholder,
.blueprint--form form textarea::-moz-placeholder,
.blueprint--form form select::-moz-placeholder {
  color: rgba(var(--blue), 0.5);
}
.blueprint--form form input[type=email]:-ms-input-placeholder,
.blueprint--form form input[type=number]:-ms-input-placeholder,
.blueprint--form form input[type=search]:-ms-input-placeholder,
.blueprint--form form input[type=text]:-ms-input-placeholder,
.blueprint--form form input[type=tel]:-ms-input-placeholder,
.blueprint--form form input[type=url]:-ms-input-placeholder,
.blueprint--form form input[type=password]:-ms-input-placeholder,
.blueprint--form form input[type=file]:-ms-input-placeholder,
.blueprint--form form textarea:-ms-input-placeholder,
.blueprint--form form select:-ms-input-placeholder {
  color: rgba(var(--blue), 0.5);
}
.blueprint--form form input[type=email]:focus,
.blueprint--form form input[type=number]:focus,
.blueprint--form form input[type=search]:focus,
.blueprint--form form input[type=text]:focus,
.blueprint--form form input[type=tel]:focus,
.blueprint--form form input[type=url]:focus,
.blueprint--form form input[type=password]:focus,
.blueprint--form form input[type=file]:focus,
.blueprint--form form textarea:focus,
.blueprint--form form select:focus {
  outline: 0;
}
.blueprint--form form textarea {
  border-radius: 20px;
}
.blueprint--form form input[type=file]:not(:-moz-placeholder) {
  background-color: transparent;
  border: 0;
  padding-left: 0;
  border-radius: 0;
  font-size: clamp(0.75rem, 0.6675rem + 0.3vw, 0.938rem);
}
.blueprint--form form input[type=file]:not(:placeholder-shown) {
  background-color: transparent;
  border: 0;
  padding-left: 0;
  border-radius: 0;
  font-size: clamp(0.75rem, 0.6675rem + 0.3vw, 0.938rem);
}
.blueprint--form form input[type=submit] {
  margin-top: 30px;
  background-color: var(--blue);
  color: var(--white);
  border-color: var(--blue);
}
.blueprint--form form input:disabled {
  opacity: 0.3;
}
.blueprint--form form input[type=email],
.blueprint--form form input[type=number],
.blueprint--form form input[type=search],
.blueprint--form form input[type=text],
.blueprint--form form input[type=tel],
.blueprint--form form input[type=url],
.blueprint--form form input[type=password],
.blueprint--form form textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
.blueprint--form form textarea {
  height: 120px;
  min-height: 120px;
  border-radius: 3px;
  padding: 15px;
}
.blueprint--form form select {
  background-color: #f7faf4;
  -moz-appearance: none; /* Firefox */
  -webkit-appearance: none; /* Safari and Chrome */
  appearance: none;
  background-image: url(../img/select.svg);
  background-repeat: no-repeat;
  background-position: center right 15px;
  padding-right: 50px;
}
.blueprint--form form label,
.blueprint--form form legend {
  margin-top: 20px;
  display: block;
  font-size: clamp(0.75rem, 0.6675rem + 0.3vw, 0.938rem);
  line-height: clamp(1.125rem, 0.96rem + 0.6vw, 1.5rem);
  color: var(--black);
  font-weight: 400;
}
.blueprint--form form fieldset {
  padding: 0;
  border-width: 0;
}
.blueprint--form form input[type=checkbox],
.blueprint--form form input[type=radio] {
  display: inline;
}
.blueprint--form form label > .label-body {
  display: inline-block;
  margin-left: 0.5rem;
  font-weight: normal;
}
.blueprint--form form .select-wrap {
  position: relative;
}
.blueprint--form form .select-wrap:after {
  content: "";
  display: block;
  position: absolute;
  width: 17px;
  height: 10px;
  background-image: url(../img/down-arrow.svg);
  top: 50%;
  right: 15px;
  transform: translateY(-50%);
  pointer-events: none;
}
.blueprint--form form .wpcf7-list-item label {
  display: flex;
  align-items: center;
  letter-spacing: 0;
  text-transform: none;
  font-size: 12px;
  line-height: 18px;
}
.blueprint--form form .wpcf7-list-item label a {
  border-bottom: 1px solid var(--black);
}
.blueprint--form form .wpcf7-list-item label input {
  margin-top: 0;
  margin-right: 10px;
}
.blueprint--form form .wpcf7-radio {
  display: flex;
}
.blueprint--form form .wpcf7-radio label {
  margin-top: 5px;
}
.blueprint--form form .wpcf7-list-item + .wpcf7-list-item {
  margin-left: 30px;
}
.blueprint--form form .select-wrap select {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background-color: transparent;
}
.blueprint--form form input,
.blueprint--form form .styled-select,
.blueprint--form form .select-wrap,
.blueprint--form form textarea {
  margin-top: 7px;
}

.wpcf7 .screen-reader-response {
  position: absolute;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
  height: 1px;
  width: 1px;
  margin: 0;
  padding: 0;
  border: 0;
}

.wpcf7 form .wpcf7-response-output {
  margin: 60px 0 0 0;
  padding: 30px;
  border: 0; /* Blue */
  text-align: center;
  background-color: var(--blue);
  color: var(--lightPurple);
  text-transform: none;
  letter-spacing: 0;
}

.wpcf7 form.init .wpcf7-response-output,
.wpcf7 form.resetting .wpcf7-response-output,
.wpcf7 form.submitting .wpcf7-response-output {
  display: none;
}

.wpcf7 form.sent .wpcf7-response-output {
  border-color: #46b450; /* Green */
}

.wpcf7 form.failed .wpcf7-response-output,
.wpcf7 form.aborted .wpcf7-response-output {
  border-color: #dc3232; /* Red */
}

.wpcf7 form.spam .wpcf7-response-output {
  border-color: #f56e28; /* Orange */
}

.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output {
  border-color: #ffb900; /* Yellow */
}

.wpcf7-form-control-wrap {
  position: relative;
}

.wpcf7-not-valid-tip {
  color: #dc3232; /* Red */
  font-size: 12px;
  font-weight: normal;
  display: block;
  letter-spacing: 0;
  text-transform: none;
  left: 0;
  margin-top: 2px;
  text-transform: none;
  letter-spacing: 0;
}

.use-floating-validation-tip .wpcf7-not-valid-tip {
  position: relative;
  top: -2ex;
  left: 1em;
  z-index: 100;
  border: 1px solid #dc3232;
  background: #fff;
  padding: 0.2em 0.8em;
  width: 24em;
}

.wpcf7-list-item {
  margin: 0;
}

.wpcf7-list-item-label::before,
.wpcf7-list-item-label::after {
  content: " ";
}

.wpcf7 .wpcf7-spinner {
  visibility: hidden;
  display: inline-block;
  background-color: var(--blue); /* Dark Gray 800 */
  opacity: 1;
  width: 24px;
  height: 24px;
  border: none;
  border-radius: 100%;
  padding: 0;
  margin: 0 24px;
  position: relative;
  top: 6px;
}

.wpcf7 form.submitting .wpcf7-spinner {
  visibility: visible;
}

.wpcf7 .wpcf7-spinner::before {
  content: "";
  position: absolute;
  background-color: #fbfbfc; /* Light Gray 100 */
  top: 4px;
  left: 4px;
  width: 6px;
  height: 6px;
  border: none;
  border-radius: 100%;
  transform-origin: 8px 8px;
  animation-name: spin;
  animation-duration: 1000ms;
  animation-timing-function: linear;
  animation-iteration-count: infinite;
}

@media (prefers-reduced-motion: reduce) {
  .wpcf7 .wpcf7-spinner::before {
    animation-name: blink;
    animation-duration: 2000ms;
  }
}
@keyframes spin {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}
@keyframes blink {
  from {
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
.wpcf7 input[type=file] {
  cursor: pointer;
}

.wpcf7 input[type=file]:disabled {
  cursor: default;
}

.wpcf7 .wpcf7-submit:disabled {
  cursor: not-allowed;
}

.wpcf7 input[type=url],
.wpcf7 input[type=email],
.wpcf7 input[type=tel] {
  direction: ltr;
}

ul {
  list-style: disc outside;
}

ol {
  list-style: decimal outside;
}

ol,
ul {
  margin-bottom: 0;
}

ul ul,
ul ol,
ol ol,
ol ul {
  margin: 1.5rem 0 1.5rem 3rem;
  font-size: 90%;
}

li {
  margin-bottom: 1rem;
}

.tick-list ul li {
  list-style: none;
  position: relative;
  padding-left: 30px;
  line-height: 1.3;
}
.tick-list ul li:before {
  content: "";
  display: block;
  width: 17px;
  height: 13px;
  background: url(../img/custom-bullet.svg);
  position: absolute;
  background-size: 80%;
  background-repeat: no-repeat;
  background-position: center center;
  top: 0.5em;
  left: 0;
}
@media (max-width: 767px) {
  .tick-list ul li:before {
    width: 13px;
    height: 9px;
  }
}

code {
  padding: 0.2rem 0.5rem;
  margin: 0 0.2rem;
  font-size: 90%;
  white-space: nowrap;
  background: #f1f1f1;
  border: 1px solid #e1e1e1;
  border-radius: 4px;
}

pre > code {
  display: block;
  padding: 1rem 1.5rem;
  white-space: pre;
}

.container {
  margin-right: auto;
  margin-left: auto;
  width: 100%;
  max-width: 1440px;
  padding-inline: 32px;
}

.container.is-wide {
  padding-inline: 32px;
}

/* Plugins                --- */
@keyframes splide-loading {
  0% {
    transform: rotate(0);
  }
  to {
    transform: rotate(1turn);
  }
}
.splide__track--draggable {
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -moz-user-select: none;
       user-select: none;
}

.splide__track--fade > .splide__list > .splide__slide {
  margin: 0 !important;
  opacity: 0;
  z-index: 0;
}

.splide__track--fade > .splide__list > .splide__slide.is-active {
  opacity: 1;
  z-index: 1;
}

.splide--rtl {
  direction: rtl;
}

.splide__track--ttb > .splide__list {
  display: block;
}

.splide__container {
  box-sizing: border-box;
  position: relative;
}

.splide__list {
  backface-visibility: hidden;
  display: flex;
  height: 100%;
  margin: 0 !important;
  padding: 0 !important;
}

.splide.is-initialized:not(.is-active) .splide__list {
  display: block;
}

.splide__pagination {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin: 0;
  pointer-events: none;
}

.splide__pagination li {
  display: inline-block;
  line-height: 1;
  list-style-type: none;
  margin: 0;
  pointer-events: auto;
}

.splide:not(.is-overflow) .splide__pagination {
  display: none;
}

.splide__progress__bar {
  width: 0;
}

.splide {
  position: relative;
  visibility: hidden;
}

.splide.is-initialized, .splide.is-rendered {
  visibility: visible;
}

.splide__slide {
  backface-visibility: hidden;
  box-sizing: border-box;
  flex-shrink: 0;
  list-style-type: none !important;
  margin: 0;
  position: relative;
}

.splide__slide img {
  vertical-align: bottom;
}

.splide__spinner {
  animation: splide-loading 1s linear infinite;
  border: 2px solid #999;
  border-left-color: transparent;
  border-radius: 50%;
  bottom: 0;
  contain: strict;
  display: inline-block;
  height: 20px;
  left: 0;
  margin: auto;
  position: absolute;
  right: 0;
  top: 0;
  width: 20px;
}

.splide__sr {
  clip: rect(0 0 0 0);
  border: 0;
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}

.splide__toggle.is-active .splide__toggle__play, .splide__toggle__pause {
  display: none;
}

.splide__toggle.is-active .splide__toggle__pause {
  display: inline;
}

.splide__track {
  overflow: hidden;
  position: relative;
  z-index: 0;
}

/* Sections                --- */
.announcement-modal {
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  background-color: rgba(var(--black), 0.85);
  z-index: 999999;
  overflow: auto;
  display: flex;
  padding: 30px;
  display: none;
  opacity: 0;
  transition: opacity 0.3s ease-in-out;
}

.announcement-modal button {
  z-index: 300;
}

.announcement-modal .container {
  margin: auto;
}

.announcement-modal .white-bg {
  position: relative;
  position: relative;
  max-width: 88.8888%;
  margin-inline: auto;
}
@media (max-width: 991px) {
  .announcement-modal .white-bg {
    max-width: 100%;
  }
}

.announcement-modal--grid {
  display: flex;
}
@media (max-width: 991px) {
  .announcement-modal--grid {
    flex-direction: column-reverse;
  }
}

.announcement-modal--text,
.announcement-modal--image {
  width: 50%;
}
@media (max-width: 991px) {
  .announcement-modal--text,
  .announcement-modal--image {
    width: 100%;
  }
}

.announcement-modal--text {
  padding: clamp(0.938rem, 0.615rem + 1.4vw, 1.875rem);
  padding-bottom: clamp(1.875rem, -0.15rem + 8.5vw, 7.5rem);
}

.announcement-modal--image {
  position: relative;
}
@media (max-width: 991px) {
  .announcement-modal--image {
    aspect-ratio: 16/9;
  }
}
.announcement-modal--image img {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 100%;
}

.site-header {
  z-index: 2000;
  position: fixed;
  top: 0;
  width: 100%;
  transition: transform 0.3s ease-in-out, background 0.3s ease-in-out, -webkit-backdrop-filter 0.3s;
  transition: transform 0.3s ease-in-out, background 0.3s ease-in-out, backdrop-filter 0.3s;
  transition: transform 0.3s ease-in-out, background 0.3s ease-in-out, backdrop-filter 0.3s, -webkit-backdrop-filter 0.3s;
  background: transparent;
  -webkit-backdrop-filter: blur(0px);
          backdrop-filter: blur(0px);
  backface-visibility: hidden;
}
.site-header.header-bg {
  background: rgba(245, 245, 245, 0.26);
  -webkit-backdrop-filter: blur(6px);
          backdrop-filter: blur(6px);
}
@media (max-width: 991px) {
  body.menu-open .site-header {
    height: 100%;
  }
}

@media (min-width: 992px) {
  .site-header.hide {
    transform: translateY(-100%);
  }
}

.site-header--container {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-block: clamp(0.75rem, 0.16rem + 2.6vw, 2.5rem);
  transition: padding 0.3s ease-in-out;
  position: relative;
}
.site-header.header-bg .site-header--container {
  padding-block: clamp(0.75rem, 0.51rem + 1.1vw, 1.5rem);
}

.site-header--home-link {
  display: block;
  height: auto;
  border: 0;
  position: relative;
  z-index: 100;
}
.site-header--home-link:hover {
  border: 0;
}
@media (max-width: 991px) {
  .site-header--home-link {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
}

.site-header--home-link a {
  display: block;
  border: 0;
}

.site-header--home-link svg {
  width: clamp(5rem, 3.36rem + 7.1vw, 9.75rem);
  height: auto;
}

.animated-hubexo-logo {
  color: var(--plum);
}

body:has(.hero-banner.plum-bg) .site-header.header-bg {
  background: rgba(50, 20, 50, 0.1333333333);
}
body:has(.hero-banner.plum-bg) .animated-hubexo-logo {
  color: var(--atomicYellow);
}

@keyframes animateLogoPath {
  0%, 100% {
    stroke-dasharray: var(--length) var(--length) var(--length) var(--length);
  }
  50% {
    stroke-dasharray: 0 var(--length) var(--length) var(--length);
  }
}
@keyframes animateLogoPathReverse {
  0%, 100% {
    stroke-dasharray: 0 0 var(--length) var(--length);
  }
  50% {
    stroke-dasharray: 0 var(--length) var(--length) var(--length);
  }
}
.animated-hubexo-logo.animating .animated-path {
  animation: animateLogoPath 2s;
}
.animated-hubexo-logo.animating .animated-path.reverse {
  animation-name: animateLogoPathReverse;
}

body.blog {
  background-color: var(--aluminium);
}

.blog-post-grid {
  display: grid;
  -moz-column-gap: clamp(1rem, 0.8425rem + 0.8vw, 1.563rem);
       column-gap: clamp(1rem, 0.8425rem + 0.8vw, 1.563rem);
  row-gap: clamp(1rem, 0.65rem + 1.5vw, 2rem);
  grid-template-columns: repeat(3, 1fr);
}
@media (max-width: 1199px) {
  .blog-post-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 767px) {
  .blog-post-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 575px) {
  .blog-post-grid {
    grid-template-columns: repeat(1, 1fr);
  }
}

.blog-post-block {
  background-color: var(--earth);
  position: relative;
  height: 505px;
}
.blog-post-block .blueprint--button {
  position: absolute;
  bottom: 24px;
  left: 24px;
  opacity: 0;
  transition: opacity 0.3s;
}
.blog-post-block:hover {
  background-color: var(--atomicYellow);
}
.blog-post-block:hover .blog-post-block--title {
  text-decoration: underline;
}
.blog-post-block:hover .blueprint--button {
  opacity: 1;
}

.blog-post-block--text {
  padding: 24px;
  height: 222px;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  background-color: var(--earth);
  transition: all 0.2s;
}

.blog-post-block:hover .blog-post-block--text {
  height: 100%;
  background-color: var(--atomicYellow);
}

.blog-post-block a {
  text-decoration: none;
}
.blog-post-block a:after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.blog-post-block h3 {
  margin-top: 24px;
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.blog-post-block--meta {
  display: flex;
  opacity: 0.5;
  font-size: 16px;
  line-height: 1.2;
  align-items: center;
  gap: 10px;
  font-weight: 500;
  flex-direction: start;
}

.blog-post-block--meta-locations:before {
  content: "•";
  display: inline-block;
  margin-right: 10px;
}

.blog-post-block .image-wrap {
  width: 100%;
  height: 0;
  height: 280px;
  position: absolute;
  overflow: hidden;
  transition: padding-bottom 0.3s ease-in-out;
  top: 0;
  left: 0;
}

.blog-post-block .image-wrap img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  transition: transform 0.6s ease-in-out;
  backface-visibility: hidden;
}

.navigation.pagination {
  grid-column-start: 1;
  grid-column-end: 4;
  text-align: center;
  display: none;
}

.nav-links {
  display: flex;
  justify-content: center;
  gap: 10px;
  align-items: center;
}

.blog-post--grid-title {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.blog-post--grid-title p,
.blog-post--grid-title p a {
  margin-top: 0rem;
}

.single-post-title {
  max-width: 776px;
}

.single-post-banner {
  position: relative;
  z-index: 2;
}

.single-post--content {
  max-width: 776px;
  position: relative;
  z-index: 2;
}

.single-post--content .location-card p {
  margin-top: 0;
  word-wrap: break-word;
}

.blog-post-contact {
  margin-top: 16px;
  max-width: 375px;
}
@media (max-width: 767px) {
  .blog-post-contact {
    max-width: 100%;
  }
}

@media (max-width: 991px) {
  .content-panel.blog-content {
    padding-bottom: 0;
  }
}

.blog-content.content-panel {
  padding-top: 60px;
}

.single-post--content p,
.single-post--content figure,
.single-post--content ul {
  margin-top: 60px;
}

.single-post--content ul,
.editor-styles-wrapper ul {
  padding: 0;
  list-style: none;
}

.single-post--content li,
.editor-styles-wrapper li.block-editor-block-list__block {
  margin-top: 25px !important;
  position: relative;
  display: flex;
  gap: 10px;
  align-items: flex-start;
}
.single-post--content li:first-child,
.editor-styles-wrapper li.block-editor-block-list__block:first-child {
  margin-top: 0;
}
.single-post--content li:before,
.editor-styles-wrapper li.block-editor-block-list__block:before {
  content: "–";
  top: 0;
  left: 0;
}

.single-post--content li:first-child,
.editor-styles-wrapper li.block-editor-block-list__block:first-child {
  margin-top: 0 !important;
}

.single-post--content .wp-embed-aspect-16-9 .wp-block-embed__wrapper {
  width: 100%;
  aspect-ratio: 16/9;
  position: relative;
}
.single-post--content .wp-embed-aspect-16-9 .wp-block-embed__wrapper iframe {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 100%;
}

.single-post--content img {
  display: block;
  width: 100%;
  height: auto;
}

.single-post--content figure {
  padding: 0;
  margin: 0;
  margin-top: 60px;
}

.single-post-container img {
  display: block;
  width: 100%;
  height: auto;
}

.single-post--footer {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 20px;
  margin-top: 30px;
}

.editor-styles-wrapper p.wp-block-paragraph,
.editor-styles-wrapper .wp-block-image,
.editor-styles-wrapper ul.wp-block-list {
  margin-top: 60px !important;
}

.editor-styles-wrapper figure.wp-embed-aspect-16-9 .wp-block-embed__wrapper {
  width: 100%;
  aspect-ratio: 16/9;
  position: relative;
}
.editor-styles-wrapper figure.wp-embed-aspect-16-9 .wp-block-embed__wrapper iframe {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 100%;
}

.editor-styles-wrapper figure {
  margin: 0;
  margin-top: 60px;
}

.site-footer {
  padding-top: clamp(3.75rem, 2.46rem + 5.6vw, 7.5rem);
  background-color: var(--plum);
  position: relative;
  z-index: 2;
}

.site-footer .pattern-a {
  transform: rotate(180deg);
  display: block;
  margin-top: clamp(1.75rem, 0.755rem + 4.3vw, 4.625rem);
}

.site-footer--logo svg {
  width: clamp(5rem, 3.36rem + 7.1vw, 9.75rem);
  height: auto;
}

.site-footer--logo svg path {
  fill: var(--atomicYellow);
}

.site-footer--logos {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.site-footer--social ul {
  list-style: none;
  display: flex;
  gap: 20px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.site-footer--social li {
  margin: 0;
}

.site-footer--social a {
  display: block;
}

.site-footer--grid {
  display: flex;
  justify-content: space-between;
  color: var(--earth);
  align-items: start;
  margin-top: 60px;
}
.site-footer--grid span {
  font-size: 16px;
}
@media (max-width: 1199px) {
  .site-footer--grid {
    flex-direction: column;
    align-items: flex-start;
    row-gap: 48px;
  }
}

.site-footer--grid span {
  font-size: 1.2rem;
}

:root {
  --header-pad: clamp(6.5rem, 18rem + 5.4vw, 14rem) !important;
  --header-pad-two: clamp(6.5rem, 18rem + 5.4vw, 10rem) !important;
}

.header-pad-two {
  padding-top: var(--header-pad-two);
}
@media (max-width: 767px) {
  .header-pad-two {
    padding-top: clamp(6.5rem, 16rem + 5.4vw, 10rem) !important;
  }
}

.search-results-page.header-pad-searchbar {
  padding-top: clamp(6.5rem, 16rem + 5.4vw, 16rem) !important;
  transition: all 0.3s ease;
}
@media (max-width: 767px) {
  .search-results-page.header-pad-searchbar {
    padding-top: clamp(6.5rem, 16rem + 5.4vw, 16rem) !important;
  }
}

.search-results-page.header-pad-searchbar.header-searchbar,
.hero-banner.plum-bg.header-pad-two.shorted {
  padding-top: clamp(6.5rem, 4rem + 5.4vw, 4rem) !important;
  transition: all 0.3s ease;
}

.header-pad-two.shorted {
  padding-top: clamp(6.5rem, 10rem + 5.4vw, 10rem) !important;
  transition: all 0.3s ease;
}

.page-title {
  font-size: 3.5em;
  font-weight: 600;
  line-height: normal;
  color: var(--plum);
}

.page-description {
  margin-top: 1.5em;
  color: var(--plum);
}

.page-description p {
  margin-top: 0.4em;
  font-size: 1em;
}

.list-category-career {
  margin-top: 2.5em;
  display: flex;
  gap: 1em;
  width: -moz-fit-content;
  width: fit-content;
}
@media (max-width: 1023px) {
  .list-category-career {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1em;
  }
}
@media (max-width: 991px) {
  .list-category-career {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1em;
  }
}
@media (max-width: 767px) {
  .list-category-career {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1em;
  }
}
@media (max-width: 564px) {
  .list-category-career {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1em;
  }
}

.btn-category-item {
  font-size: 1em;
  padding: 0.5em 1em;
  background-color: transparent;
  border: 1px solid var(--plum);
  border-radius: 100em;
  font-weight: 500;
  min-height: 3.8rem;
}

.btn-category-item:hover {
  background-color: var(--plum);
  color: var(--earth);
  transition: all 0.3s ease;
}

.btn-category-item.active {
  background-color: var(--plum);
  color: var(--earth);
  transition: all 0.3s ease;
}

.career-list-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.career-list-head h4 {
  font-size: 1.5em;
  font-weight: 600;
  color: var(--plum);
  line-height: normal;
  margin-top: 0em;
}

.career-list-head a {
  font-size: 1.5em;
  font-weight: 600;
  color: var(--plum);
  line-height: normal;
  text-decoration: none;
}

.career-list-container {
  border-top: 1px solid var(--plum);
  padding: 1.5em 0em;
}

.career-list-category {
  display: flex;
  gap: 1em;
  align-items: center;
}

.career-list-body {
  margin-top: 1.5em;
}

.career-list-body p {
  margin-top: 0.4em;
}

.career-list-category {
  margin-top: 1.5em;
}

.career-list-category button {
  display: flex;
  align-items: center;
  gap: 0.5em;
  font-size: 1em;
  padding: 0.5em 0.5em;
  background-color: transparent;
  border: 1px solid var(--plum);
  border-radius: 100em;
  font-weight: 500;
}

.career-list-category button:hover,
.career-list-category button svg:hover {
  background-color: var(--plum);
  color: var(--earth);
  transition: all 0.3s ease;
  fill: var(--earth);
}

.career-list-category button:hover svg {
  fill: var(--earth) !important;
}

.career-list-category button:hover img {
  filter: brightness(0) invert(1);
}

.container-job-list {
  margin-top: 2.5rem;
}

/* Blocks                --- */
.homepage-banner {
  background-color: var(--atomicYellow);
  position: relative;
  overflow: hidden;
}

.homepage-banner--content {
  min-height: calc(100vh - var(--header-pad));
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding-bottom: clamp(6.5rem, 5.265rem + 5.4vw, 10.125rem);
}

.homepage-banner svg.pattern-a {
  z-index: 10;
  position: relative;
}

.homepage-banner h1 {
  max-width: 10ch;
  word-break: break-word;
}

.homepage-banner--text {
  background-color: var(--earth);
  width: 50%;
  padding: 24px;
  margin-top: 80px;
}
@media (max-width: 991px) {
  .homepage-banner--text {
    width: 100%;
    max-width: 570px;
  }
}

.homepage-banner--header-wrap {
  animation: fadeInUp;
  animation-duration: 1s;
  animation-fill-mode: both;
  animation-delay: 0.5s;
}

.homepage-banner--text {
  animation: fadeInUp;
  animation-duration: 1s;
  animation-fill-mode: both;
  animation-delay: 2s;
}

.homepage-banner--text .blueprint--button {
  margin-top: 30px;
}

.homepage-banner .stat-blocks {
  position: relative;
  z-index: 2;
  padding-bottom: clamp(3.75rem, 2.46rem + 5.6vw, 7.5rem);
}

.editor-styles-wrapper .homepage-banner svg {
  display: none;
}

#hero-circles {
  background: #dcff3c;
  display: block;
  width: max(100vw, 100vh);
  height: max(100vw, 100vh);
}

.hero-wrap {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
}

.hero-inner-wrap {
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
}

.hero-banner {
  position: relative;
  padding-bottom: clamp(1.875rem, 1.23rem + 2.8vw, 3.75rem);
}

.hero-banner.has-pattern {
  position: relative;
  overflow: hidden;
  padding-bottom: 128px;
  background: var(--plum) url(../img/quote-bg.svg);
  background-repeat: no-repeat;
  background-size: min(70%, 1200px) auto;
  background-position: bottom right;
}

.hero-banner.error-404 {
  padding-bottom: 128px;
  min-height: 100vh;
}

img.animation-404 {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 70%;
  height: auto;
}

.hero-banner svg.quote-pattern {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  width: auto;
  height: 100%;
  opacity: 0;
  animation: fadeIn;
  animation-duration: 1s;
  animation-fill-mode: both;
}
@media (max-width: 991px) {
  .hero-banner svg.quote-pattern {
    top: auto;
    bottom: 0;
    height: auto;
    width: 60%;
    transform: translateY(60%);
  }
}
@media (max-width: 767px) {
  .hero-banner svg.quote-pattern {
    height: auto;
  }
}

.hero-banner p {
  color: #fff;
}

.hero-banner .container {
  position: relative;
  z-index: 10;
}

.hero-banner svg.pattern-a {
  margin-top: 60px;
}

.hero-banner h1 {
  max-width: 15ch;
  color: var(--atomicYellow);
}

.hero-banner h1 + p {
  max-width: 27ch;
}

.hero-banner.has-pattern h1 + p {
  max-width: 30ch;
}

.hero-banner p {
  max-width: 36ch;
}

.hero-banner h1,
.hero-banner p {
  opacity: 0;
  animation: fadeInUp;
  animation-duration: 0.5s;
  animation-fill-mode: both;
}

.hero-banner p {
  animation-delay: 0.2s;
}

.hero-banner p.hero-banner--button-wrap {
  animation-delay: 0.4s;
}

.hero-banner--image {
  z-index: 1;
  position: absolute;
  top: 0;
  right: 0;
  height: 100%;
  width: 50%;
}
.hero-banner--image:after {
  content: "";
  position: absolute;
  height: 100%;
  width: 100%;
  top: 0;
  left: 0;
}
.hero-banner--image img {
  -webkit-mask-repeat: repeat;
  mask-repeat: repeat;
  -webkit-mask-size: auto 100%;
          mask-size: auto 100%;
  -webkit-mask-position: bottom left;
          mask-position: bottom left;
  position: absolute;
  right: 0;
  top: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center center;
     object-position: center center;
}
.hero-banner--image.use-mask img {
  -webkit-mask-image: url(../img/masks/luma-mask.png);
  mask-image: url(../img/masks/luma-mask.png);
  mask-mode: luminance;
  animation: fadeIn 0.5s;
  animation-delay: 1s;
  animation-fill-mode: both;
}

@media (max-width: 991px) {
  .hero-banner--image {
    display: none;
    position: relative;
    aspect-ratio: 3/2;
    width: 100%;
    margin-top: 30px;
  }
  .hero-banner--image img {
    width: auto;
    aspect-ratio: 1225/1238;
    height: 100%;
  }
}
body.has-promo-banner .header-pad {
  padding-top: clamp(23rem, 24rem + 2.3vw, 24rem) !important;
}

body.has-promo-banner .header-pad.shorted {
  padding-top: clamp(10rem, 14rem + 2.3vw, 14rem) !important;
  transition: all ease-in 0.3s;
}

.homepage-banner.header-pad-two.short {
  padding-top: 10rem !important;
}

.text-and-image-banner {
  display: flex;
  flex-direction: column;
  position: relative;
  overflow: hidden;
}

.text-and-image-banner .container {
  position: relative;
}

.text-and-image-banner--bg-wrap {
  position: relative;
  padding-bottom: 144px;
}

.text-and-image-banner--bg {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center right;
     object-position: center right;
}
@media (max-width: 991px) {
  .text-and-image-banner--bg {
    transform: translateX(20%);
  }
}
@media (max-width: 767px) {
  .text-and-image-banner--bg {
    height: 65%;
    top: auto;
    bottom: 0;
  }
}

.text-and-image-banner h1 {
  max-width: 15ch;
}

.text-and-image-banner h1 + p {
  max-width: 35ch;
}

.text-and-image-banner h1,
.text-and-image-banner p {
  opacity: 0;
  animation: fadeInUp;
  animation-duration: 0.5s;
  animation-fill-mode: both;
}

.text-and-image-banner p {
  animation-delay: 0.2s;
}

.text-and-image-banner p.text-and-image-banner--button-wrap {
  animation-delay: 0.4s;
}

.title-banner {
  padding-bottom: clamp(3.75rem, 3.29rem + 1.9vw, 5rem);
  position: relative;
  z-index: 2;
}

main.aluminium-bg .title-banner,
main.earth-bg .title-banner {
  padding-bottom: clamp(1.875rem, 0.31rem + 6.6vw, 6.25rem);
}

main.plum-bg .title-banner {
  color: var(--atomicYellow);
}

.text-block--text {
  width: 66.666%;
}
@media (max-width: 991px) {
  .text-block--text {
    width: 100%;
  }
}
.text-block--text p {
  max-width: 46ch;
}

.text-block ul {
  padding: 0;
  list-style: none;
}

.text-block li {
  margin-top: 25px !important;
  position: relative;
  display: flex;
  gap: 10px;
  align-items: flex-start;
}
.text-block li:first-child {
  margin-top: 0;
}
.text-block li:before {
  content: "–";
  top: 0;
  left: 0;
}

.text-block--text.snug-child.text-block-with--shortcode.center-form {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 4rem;
}

.text-block--text.snug-child.text-block-with--shortcode.right-form,
.text-block--text.snug-child.text-block-with--shortcode.left-form {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  align-items: start;
  gap: 2rem;
  width: 100%;
}
@media (max-width: 767px) {
  .text-block--text.snug-child.text-block-with--shortcode.right-form,
  .text-block--text.snug-child.text-block-with--shortcode.left-form {
    gap: 1rem;
    grid-template-columns: repeat(1, 1fr);
  }
}

.text-block--text.snug-child.text-block-with--shortcode .text-content p {
  max-width: 100%;
}

.plum-bg .text-block--text.snug-child.text-block-with--shortcode .gfield_label {
  color: var(--earth);
  font-size: 1.4rem;
  font-weight: 500;
}

.earth-bg .gform_title {
  color: var(--plum);
}

.earth-bg .text-block--text.snug-child.text-block-with--shortcode .gfield_label {
  color: var(--plum);
  font-size: 1.4rem;
  font-weight: 500;
}

.plum-bg .text-block--text.snug-child.text-block-with--shortcode .ginput_container span label,
.plum-bg .text-block--text.snug-child.text-block-with--shortcode .gfield_description {
  color: var(--earth);
  font-size: 1rem;
  font-weight: 500;
}

.earth-bg .text-block--text.snug-child.text-block-with--shortcode .ginput_container span label,
.earth-bg .text-block--text.snug-child.text-block-with--shortcode .gfield_description {
  color: var(--plum);
  font-size: 1rem;
  font-weight: 500;
}

.text-block--text.snug-child.text-block-with--shortcode .text-content {
  order: 2;
}
@media (max-width: 767px) {
  .text-block--text.snug-child.text-block-with--shortcode .text-content {
    order: 1;
  }
}

.text-block--text.snug-child.text-block-with--shortcode .block-shortcode {
  order: 1;
}
@media (max-width: 767px) {
  .text-block--text.snug-child.text-block-with--shortcode .block-shortcode {
    order: 2;
  }
}

.text-block--text.snug-child.text-block-with--shortcode.left-form .text-content {
  order: 1;
}
@media (max-width: 767px) {
  .text-block--text.snug-child.text-block-with--shortcode.left-form .text-content {
    order: 2;
  }
}

.text-block--text.snug-child.text-block-with--shortcode.left-form .block-shortcode {
  order: 2;
}
@media (max-width: 767px) {
  .text-block--text.snug-child.text-block-with--shortcode.left-form .block-shortcode {
    order: 1;
  }
}

.plum-bg .text-block--text.snug-child.text-block-with--shortcode .block-shortcode .gform-footer.gform_footer.top_label input {
  font-weight: 600;
  display: inline-flex;
  gap: 10px;
  align-items: center;
  justify-content: center;
  height: auto;
  padding: 16px 24px;
  border-radius: 100px;
  line-height: 20px;
  border: 1px solid var(--atomicYellow);
  font-size: clamp(0.938rem, 0.855rem + 0.3vw, 1.125rem);
  outline: none;
  transition: color 0.3sease-in-out, background-color 0.3sease-in-out, border-color 0.3sease-in-out;
  background-color: var(--atomicYellow);
  color: var(--plum);
  text-decoration: none;
}

.earth-bg .text-block--text.snug-child.text-block-with--shortcode .block-shortcode .gform-footer.gform_footer.top_label input {
  font-weight: 600;
  display: inline-flex;
  gap: 10px;
  align-items: center;
  justify-content: center;
  height: auto;
  padding: 16px 24px;
  border-radius: 100px;
  line-height: 20px;
  border: 1px solid var(--plum);
  font-size: clamp(0.938rem, 0.855rem + 0.3vw, 1.125rem);
  outline: none;
  transition: color 0.3sease-in-out, background-color 0.3sease-in-out, border-color 0.3sease-in-out;
  background-color: transparent;
  color: var(--plum);
  text-decoration: none;
}

.plum-bg .text-block--text.snug-child.text-block-with--shortcode .block-shortcode .gform-footer.gform_footer.top_label input:hover {
  background-color: transparent;
  color: var(--earth);
  border-color: var(--earth);
  transition: color 0.3sease-in-out, background-color 0.3sease-in-out, border-color 0.3sease-in-out;
}

.earth-bg .text-block--text.snug-child.text-block-with--shortcode .block-shortcode .gform-footer.gform_footer.top_label input:hover {
  background-color: var(--plum);
  color: var(--earth);
  border-color: var(--plum);
  transition: color 0.3sease-in-out, background-color 0.3sease-in-out, border-color 0.3sease-in-out;
}

.white-text.earth-bg p,
.white-text.earth-bg a,
.white-text.earth-bg li,
.white-text.earth-bg h1,
.white-text.earth-bg h2,
.white-text.earth-bg h3,
.white-text.earth-bg h4,
.white-text.earth-bg h5,
.white-text.earth-bg h6 {
  color: var(--plum);
}

.hs-fieldtype-text label span {
  color: var(--earth) !important;
}

.text-content p {
  margin: 0px;
}

.text-block-with--shortcode {
  margin-top: 48px;
}

.stat-blocks {
  display: flex;
  justify-content: space-between;
}
@media (max-width: 767px) {
  .stat-blocks {
    flex-direction: column;
    gap: 40px;
  }
}

.stat-block {
  width: 23%;
}
@media (max-width: 767px) {
  .stat-block {
    width: 55%;
    margin-inline: auto;
  }
}

.stat-block svg {
  width: 55px;
  height: auto;
}

.stat-block--number {
  font-size: clamp(3.75rem, 2.83rem + 3.8vw, 6.25rem);
  line-height: clamp(4.125rem, 4.125rem + 0vw, 4.125rem);
  font-weight: 500;
  display: block;
  margin-top: clamp(0rem, -0.57rem + 2.3vw, 1.5rem);
}

.stat-block--title {
  font-size: clamp(1.25rem, 1.14rem + 0.4vw, 1.5rem);
  line-height: clamp(1.75rem, 1.64rem + 0.4vw, 2rem);
  display: block;
  margin-top: clamp(0rem, -0.57rem + 2.3vw, 1.5rem);
}

:root {
  --header-pad: clamp(6.5rem, 5.265rem + 5.4vw, 10.125rem);
}

body.has-promo-banner .header-pad {
  padding-top: clamp(11rem, 10.43rem + 2.3vw, 12.5rem);
}

.header-pad {
  padding-top: var(--header-pad);
}

.fullscreen-banner + .content-panel {
  padding-top: clamp(1.875rem, 1.23rem + 2.8vw, 3.75rem);
}

.content-panel {
  padding: clamp(3.75rem, 2.46rem + 5.6vw, 7.5rem) 0;
}

.content-panel.half-space {
  padding: clamp(1.875rem, 1.23rem + 2.8vw, 3.75rem) 0;
}

.content-panel.double-space {
  padding: clamp(3.75rem, 2.46rem + 5.6vw, 7.5rem) 0;
}

.content-panel.no-bg + .content-panel.no-bg {
  padding-top: 0;
}

.content-panel.no-bg + .content-panel.no-bg.double-space {
  padding-top: clamp(1.875rem, 1.23rem + 2.8vw, 3.75rem);
}

.content-panel.text-block + .content-panel.link-list {
  padding-top: 48px;
}

.content-panel.text-block:has(+ .link-list) {
  padding-bottom: 0;
}

.content-panel.link-list:has(+ .icon-blocks) {
  padding-bottom: 0;
}

.content-panel.text-block + .content-panel.stats {
  padding-top: 0;
}

.content-panel.stats + .content-panel.text-block {
  padding-top: 0;
}

.link-list {
  position: relative;
  overflow: hidden;
}

.link-list h2 {
  margin-bottom: clamp(1.75rem, 1.29rem + 1.9vw, 3rem);
}

@media (max-width: 1000px) {
  .link-list .h2 {
    font-size: clamp(1.375rem, 0.05rem + 6.6vw, 4.175rem);
  }
}

.link-list ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.link-list svg {
  width: clamp(1.5rem, 0.69rem + 3.4vw, 3.75rem);
  height: auto;
  position: relative;
  z-index: 2;
}

.link-list svg rect {
  transition: fill 0.8s ease;
}

.link-list li {
  margin: 0;
  padding-top: clamp(1.5rem, 0.9575rem + 2.2vw, 2.938rem);
  position: relative;
}
@media (max-width: 1000px) {
  .link-list li {
    padding-top: 40px;
  }
}

.link-list li .container {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  padding-inline: clamp(1rem, 0.65rem + 1.5vw, 2rem);
}

.link-list svg {
  flex-shrink: 0;
}

.link-list a,
.link-list .no-link {
  text-decoration: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  -moz-column-gap: 15px;
       column-gap: 15px;
}

.editor-styles-wrapper .link-list a {
  pointer-events: none;
}

.link-list hr {
  flex: 1;
  flex-basis: 100%;
  margin: 0;
  margin-top: clamp(1.5rem, 0.9575rem + 2.2vw, 2.938rem);
  border: 0;
  border-bottom: 1px solid var(--earth);
  display: block;
  width: 100%;
  backface-visibility: hidden;
}
@media (max-width: 1000px) {
  .link-list hr {
    margin-top: 40px;
  }
}

.link-list .link-list--overlay {
  position: absolute;
  top: -1px;
  bottom: -1px;
  left: 0;
  right: 0;
  width: 100%;
  height: auto;
  background-color: var(--earth);
  z-index: 1;
  opacity: 0;
  transition: opacity 0.3s ease;
  padding: clamp(0rem, -0.7275rem + 3.1vw, 2.063rem) 0px;
}
.link-list .link-list--overlay h1,
.link-list .link-list--overlay h2,
.link-list .link-list--overlay h3,
.link-list .link-list--overlay h4,
.link-list .link-list--overlay h5,
.link-list .link-list--overlay h6,
.link-list .link-list--overlay p {
  color: var(--plum);
}
.link-list .link-list--overlay p {
  margin-top: 20px;
  max-width: 762px;
  font-weight: 400;
}
.link-list .link-list--overlay .container {
  display: block;
  opacity: 0;
  transition: opacity 0.3s ease-in-out;
}
@media (max-width: 991px) {
  .link-list .link-list--overlay {
    display: flex;
    align-items: center;
  }
  .link-list .link-list--overlay .h6, .link-list .link-list--overlay body#tinymce h4, body#tinymce .link-list .link-list--overlay h4, .link-list .link-list--overlay body#tinymce h5, body#tinymce .link-list .link-list--overlay h5, .link-list .link-list--overlay .hero-banner h1 + p, .hero-banner .link-list .link-list--overlay h1 + p, .link-list .link-list--overlay .text-and-image-banner h1 + p, .text-and-image-banner .link-list .link-list--overlay h1 + p, .link-list .link-list--overlay .text-block h3, .text-block .link-list .link-list--overlay h3,
  .link-list .link-list--overlay .text-block h4,
  .text-block .link-list .link-list--overlay h4,
  .link-list .link-list--overlay .text-block h5,
  .text-block .link-list .link-list--overlay h5,
  .link-list .link-list--overlay .text-block h6,
  .text-block .link-list .link-list--overlay h6 {
    font-size: clamp(1.5rem, 1.5rem + 0vw, 1.5rem);
    line-height: clamp(2rem, 2rem + 0vw, 2rem);
    font-weight: 600;
  }
  .link-list .link-list--overlay p {
    font-size: 14px;
    line-height: 1.2;
    margin-top: 1em;
    padding-right: 32px;
  }
}

.link-list--trigger {
  opacity: 0;
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  display: none;
}
@media (pointer: coarse) {
  .link-list--trigger {
    display: block;
  }
}

.link-list li.hovered .link-list--overlay,
.link-list li:hover .link-list--overlay {
  opacity: 1;
}

.link-list li.hovered .link-list--overlay .container,
.link-list li:hover .link-list--overlay .container {
  opacity: 1;
}

.link-list li.hovered .link-list--arrow rect,
.link-list li:hover .link-list--arrow rect {
  fill: var(--plum);
}

.link-list li.hovered .link-list--arrow path,
.link-list li:hover .link-list--arrow path {
  stroke: #fff;
}

.link-list .pattern-a {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100vw;
  height: auto;
  opacity: 1;
  pointer-events: none;
}

.link-list--title {
  opacity: 0;
  transition: opacity 1s;
  transition-delay: calc(0.2s * var(--n));
}
.link-list.in-view .link-list--title {
  opacity: 1;
}

.editor-styles-wrapper .link-list--title {
  opacity: 1;
}

.h2.snug.link-list--title.with-icon {
  display: flex;
  justify-content: space-between;
  width: 100%;
}

.h2.snug.link-list--title.with-icon img {
  width: 2.5rem;
}
@media (max-width: 767px) {
  .h2.snug.link-list--title.with-icon img {
    width: 1.8rem;
  }
}

.icon-size-medium,
.icon-size-default {
  -o-object-fit: contain;
     object-fit: contain;
  -o-object-position: center;
     object-position: center;
}

.icon-size-default {
  width: 64px;
  height: 64px;
}

.icon-size-medium {
  width: 32px;
  height: 32px;
}

.icon-blocks {
  position: relative;
  overflow: hidden;
}

.icon-blocks .fade-in {
  position: relative;
  z-index: 2;
}

.icon-blocks--background {
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  width: auto;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  z-index: 1;
}
@media (max-width: 991px) {
  .icon-blocks--background {
    height: 40%;
    top: auto;
    bottom: 0;
  }
}
@media (max-width: 767px) {
  .icon-blocks--background {
    height: 50%;
  }
}

.has-image .icon-blocks--background {
  height: 60%;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  top: auto;
  bottom: 0;
}

.icon-blocks--grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 48px;
  -ms-overflow-style: none;
  scrollbar-width: none;
  position: relative;
  z-index: 2;
}
@media (max-width: 991px) {
  .icon-blocks--grid {
    grid-template-columns: repeat(1, 1fr);
  }
}
@media (max-width: 767px) {
  .icon-blocks--grid {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(1, 1fr);
    overflow: auto;
    flex-wrap: nowrap;
  }
}

.icon-blocks--grid::-webkit-scrollbar {
  display: none;
}

.icon-blocks--grid.is-two {
  grid-template-columns: repeat(2, 1fr);
}
@media (max-width: 991px) {
  .icon-blocks--grid.is-two {
    grid-template-columns: repeat(1, 1fr);
  }
}

.icon-block {
  background-color: var(--earth);
  padding: 24px;
}
@media (min-width: 900px) {
  .icon-block {
    --transition-duration: 1s;
    opacity: 0;
    transform: translateX(50px);
    transition: transform var(--transition-duration), opacity var(--transition-duration);
    transition-delay: calc(0.1s + var(--n) * 0.2s);
  }
  .editor-styles-wrapper .icon-block {
    opacity: 1;
    transform: translateX(0px);
  }
  .icon-block.in-view {
    opacity: 1;
    transform: translateX(0px);
  }
}
@media (max-width: 767px) {
  .icon-block {
    min-width: auto;
  }
}

.icon-block img,
.icon-block svg {
  margin-bottom: 48px;
}

.icon-block p {
  margin-top: 10px;
}

.icon-block-description {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
  -webkit-line-clamp: 5;
  line-clamp: 5;
  min-height: 7em;
}

.blueprint--button svg {
  margin: 0rem !important;
}

.blueprint--button.icon-blocks--button {
  background-color: var(--plum);
  border: 1px solid var(--plum);
  color: var(--earth);
  margin-top: 1rem;
}
.blueprint--button.icon-blocks--button:hover {
  background-color: var(--atomicYellow);
  border: 1px solid var(--atomicYellow);
  color: var(--plum);
}

.blueprint--button.icon-blocks--button.plum-bg.outline-button {
  background-color: transparent;
  color: var(--plum);
}

.blueprint--button.icon-blocks--button.plum-bg.outline-button:hover {
  background-color: var(--plum);
  color: var(--earth);
  border: 1px solid var(--plum);
}

.blueprint--button.icon-blocks--button.plum-bg.text-button {
  border: none;
  background-color: transparent;
  color: var(--plum);
  padding: 0rem;
  font-size: 1.2rem;
}

.blueprint--button.icon-blocks--button.plum-bg.text-button svg {
  display: none;
}

.blueprint--button.icon-blocks--button.plum-bg.text-button:hover {
  border: none;
  background-color: transparent;
  color: var(--plum);
  text-decoration: underline;
}

.blueprint--button.icon-blocks--button.solid-button {
  background-color: var(--plum);
  border: none;
  color: var(--earth);
  margin-top: 1rem;
  min-width: -moz-fit-content;
  min-width: fit-content;
  transition: all 0.3s ease;
}
.blueprint--button.icon-blocks--button.solid-button:hover {
  background-color: transparent;
  border: 1px solid var(--plum);
  color: var(--plum);
  transition: all 0.3s ease;
}

.blueprint--button.icon-blocks--button.solid-button svg {
  color: var(--earth);
  transition: all 0.3s ease;
}

.blueprint--button.icon-blocks--button.solid-button:hover svg {
  color: var(--plum);
  transition: all 0.3s ease;
}

.title-icon--block {
  min-height: 3em;
}

.logo-slider {
  margin-top: clamp(3.75rem, 3.29rem + 1.9vw, 5rem);
}

.logo-slider ul {
  align-items: center;
}

.logo-slider img {
  display: block;
  height: clamp(10.625rem, 9.52rem + 4.7vw, 13.75rem);
  width: auto;
}

.logo-slider.logo-slider li {
  padding: 0 30px;
  width: auto;
}

.logo-slider.logo-slider.has-titles li {
  padding: clamp(0.938rem, 0.615rem + 1.4vw, 1.875rem) 8px;
  position: relative;
  padding-top: 0;
}
.logo-slider.logo-slider.has-titles li .logo-title {
  display: block;
  white-space: nowrap;
  padding-bottom: clamp(0.938rem, 0.615rem + 1.4vw, 1.875rem);
  font-weight: 600;
}

.logo-slider.logo-slider.has-titles li.has-title {
  border-left: 1px solid #c8d2d2;
  padding-left: 20px;
}

.editor-styles-wrapper .logo-slider {
  visibility: visible;
}

.editor-styles-wrapper .logo-slider .splide__list {
  display: flex;
  overflow: scroll;
}

.editor-styles-wrapper .logo-slider .splide__list li {
  width: 200px;
}

.center-title {
  text-align: center;
}

.splide__slide.grid {
  padding: 10px 15px !important;
}

.splide__slide.grid img {
  width: 180px;
  height: auto;
}

.splide__track.grid {
  padding-top: 20px;
  padding-bottom: 20px;
}

.splide__slide ul {
  box-shadow: 0px 2px 11px 14px rgba(0, 0, 0, 0.1);
  -webkit-box-shadow: 0px 2px 11px 14px rgba(0, 0, 0, 0.1);
  -moz-box-shadow: 0px 2px 11px 14px rgba(0, 0, 0, 0.1);
  margin: 0px 0px 3rem !important;
}

.logo-slider.logo-slider li {
  padding: 0 1rem !important;
}

.image-cta {
  position: relative;
  overflow: hidden;
}
@media (max-width: 767px) {
  .image-cta {
    padding-top: 0;
  }
}

svg.cta-mask-desktop {
  position: absolute;
  top: -1px;
  bottom: -1px;
  width: auto;
  right: calc(50% - 2px);
  z-index: 10;
  height: calc(100% + 2px);
}
@media (max-width: 767px) {
  svg.cta-mask-desktop {
    display: none;
  }
}

@media (max-width: 767px) {
  .image-cta--image-wrap {
    position: relative;
  }
}

svg.cta-mask-mobile {
  display: none;
}
@media (max-width: 767px) {
  svg.cta-mask-mobile {
    display: block;
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 100%;
    height: auto;
  }
}

.image-cta img {
  display: block;
  position: absolute;
  width: 50%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  top: 0;
  left: 0;
  bottom: 0;
}
@media (max-width: 767px) {
  .image-cta img {
    display: block;
    width: 100%;
    height: auto;
    position: static;
    aspect-ratio: 375/430;
  }
}

.image-cta .container {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-template-rows: 1fr;
  grid-column-gap: 0px;
  grid-row-gap: 0px;
}
@media (max-width: 767px) {
  .image-cta .container {
    display: flex;
    flex-direction: column;
  }
}

.image-cta--text {
  grid-area: 1/8/2/12;
}
@media (max-width: 1199px) {
  .image-cta--text {
    grid-area: 1/8/2/13;
  }
}
@media (max-width: 767px) {
  .image-cta--text {
    padding-top: 30px;
  }
}

.image-cta h3 {
  font-size: clamp(2.5rem, 2.04rem + 1.9vw, 3.75rem);
  line-height: clamp(3.438rem, 3.3rem + 0.5vw, 3.75rem);
  font-weight: 500;
  max-width: 10ch;
}

.image-and-text-cta {
  position: relative;
  background-color: #e5e5e5;
  overflow: hidden;
}
@media (max-width: 767px) {
  .image-and-text-cta {
    padding-top: 260px;
  }
}

.image-and-text-cta img {
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center right;
     object-position: center right;
}

.image-and-text-cta .container {
  position: relative;
}

.image-and-text-cta h2 {
  max-width: 15ch;
  font-size: clamp(2.25rem, 1.68rem + 2.3vw, 3.75rem);
  line-height: clamp(2.75rem, 2.4rem + 1.5vw, 3.75rem);
}

.image-and-text-cta p {
  max-width: 43ch;
}

@media (max-width: 767px) {
  .image-and-text-cta--image-wrap {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: clamp(24.5rem, 24.4175rem + 0.3vw, 24.688rem);
  }
}

.index-container {
  margin-top: 1.5em;
}

.index-post-item.fade-in {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}

.index-post-item.fade-in.in-view {
  opacity: 1;
  transform: translateY(0);
}

.index-post-list--text {
  display: grid;
  align-items: top;
  justify-content: space-between;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.index-post-list--text h3,
.index-post-list--text p,
.index-post-list--text a {
  font-size: 18px;
  font-weight: 500;
  line-height: normal;
  margin: 0px;
  display: flex;
}
@media (max-width: 767px) {
  .index-post-list--text h3,
  .index-post-list--text p,
  .index-post-list--text a {
    font-size: 14px;
  }
}

.index-post-list--title {
  justify-content: center;
}

.index-post-list--name-website {
  justify-content: start;
}

.index-post-list--date {
  justify-content: end;
}

.index-post-item {
  position: relative;
  padding: 14px 0px;
  margin: 0px;
  border-bottom: 1px solid var(--plum);
}

.index-post-button--read-more {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  height: 100%;
  background-color: var(--plum);
  color: var(--white) !important;
  font-size: 18px;
  font-weight: 500;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  transition: all ease-in-out 0.3s;
  opacity: 0;
  visibility: hidden;
  z-index: -1;
}

.index-post-button--read-more:hover {
  color: var(--white) !important;
}

.testimonials {
  background: var(--plum) url(../img/quote-bg.svg);
  background-position: bottom right;
  background-repeat: no-repeat;
  background-size: min(70%, 1200px) auto;
}

.testimonials .container {
  position: relative;
  z-index: 10;
}

.testimonials blockquote {
  padding: 0;
  margin: 0;
  margin-top: 40px;
}

.testimonials blockquote p {
  font-size: clamp(1.5rem, 1.15rem + 1.5vw, 2.5rem);
  line-height: clamp(2rem, 1.65rem + 1.5vw, 3rem);
  padding-inline: clamp(1.875rem, 1.23rem + 2.8vw, 3.75rem);
  margin-inline: auto;
}

.testimonials cite {
  font-style: normal;
  display: block;
  color: var(--atomicYellow);
  margin-bottom: 40px;
}

svg.testimonial-pattern {
  width: 100%;
  height: auto;
  position: relative;
  top: -90px;
  margin-bottom: -90px;
}

.testimonial-image {
  width: clamp(4.25rem, 3.735rem + 2.1vw, 5.625rem);
  height: clamp(4.25rem, 3.735rem + 2.1vw, 5.625rem);
  border-radius: 50%;
  margin-inline: auto;
  position: relative;
  z-index: 10;
  overflow: hidden;
  margin-top: auto;
  background-color: transparent;
}

.testimonial-image img {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.testimonials-slider {
  z-index: 10;
}

.testimonials-slider li {
  display: flex;
  flex-direction: column;
}

.splide__arrows {
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  transform: translateY(-50%);
  display: flex;
  justify-content: space-between;
  z-index: 30;
}

.splide__arrows button {
  width: clamp(1.5rem, 0.69rem + 3.4vw, 3.75rem);
  height: clamp(1.5rem, 0.69rem + 3.4vw, 3.75rem);
  border-radius: 50%;
  border: 0;
  background-color: transparent;
  background-image: url(../img/carousel-arrow.svg);
  background-size: contain;
  padding: 0;
  display: flex;
}
.splide__arrows button svg {
  opacity: 0;
}

.splide__arrows button + button {
  transform: rotate(180deg);
}

.testimonials-slider button:disabled {
  display: none;
}

.editor-styles-wrapper .testimonials-slider {
  visibility: visible;
}

.editor-styles-wrapper .testimonials-slider li {
  width: 100%;
}

.editor-styles-wrapper .testimonials-slider .splide__list {
  display: flex;
  flex-direction: column;
  gap: 60px;
}

.team {
  overflow: hidden;
  position: relative;
}

.team .container {
  position: relative;
  z-index: 1;
}

.team .grid {
  margin-top: 48px;
}

.editor-styles-wrapper .team .grid {
  display: grid;
  gap: 24px;
  grid-template-columns: repeat(2, 1fr);
}

.team-member {
  background-color: var(--earth);
  padding: 24px;
  margin-bottom: 24px;
}

.grid-sizer,
.team-member {
  width: calc(50% - 12px);
}
@media (max-width: 991px) {
  .grid-sizer,
  .team-member {
    width: 100%;
  }
}

.editor-styles-wrapper .grid-sizer {
  display: none;
}

.editor-styles-wrapper .team-member {
  width: auto;
}

.team-member--meta {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: clamp(1.5rem, 1.04rem + 1.9vw, 2.75rem);
}

.team-member--meta p {
  font-size: 16px;
  line-height: 24px;
  max-width: 24ch;
}

.team-member--image {
  width: 90px;
  height: 90px;
  border-radius: 50%;
  flex-shrink: 0;
  position: relative;
  overflow: hidden;
}

.team-member--image img {
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  -o-object-fit: cover;
     object-fit: cover;
}

.team-member--bio {
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.team-member.active .team-member--bio {
  display: block;
}

button.team-member--button {
  border: 0;
  padding: 0;
  background: transparent;
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 27px;
  margin-bottom: 24px;
  font-size: 17px;
  font-weight: 500;
}

.team-member.active button.team-member--button svg {
  transform: rotate(180deg);
}

.team-member .blueprint--button {
  display: none;
}

.team-member.active .blueprint--button {
  display: inline-flex;
}

/** team two css */
.position-teams {
  display: flex;
  gap: 1em;
  align-items: center;
  justify-content: start;
  margin-top: 3em;
}

.position-teams p {
  margin-top: 0em;
  cursor: pointer;
}

.img-content {
  position: relative;
  height: 100%;
  width: 100%;
}

.image-teams {
  position: relative;
  aspect-ratio: 1/1;
  width: 100%;
  height: 100%;
  background-color: #2b2b2b;
  z-index: 10;
}

.block-teams {
  position: relative;
}

.front-content {
  position: absolute;
  bottom: 0;
  z-index: -1000;
  background-color: rgba(250, 250, 240, 0.6);
  width: 100%;
  padding: 0.5em;
  opacity: 0;
  transition: all 0.3s ease;
}

.front-content.active,
.front-content.clicked {
  opacity: 1;
  z-index: 1000;
  transition: all 0.3s ease;
}

.front-content p,
.head-detail-content p {
  margin-top: 0.4em;
  line-height: normal;
  font-size: 0.8em;
}

.front-content p:first-child {
  margin-top: 0em;
  font-size: 1em;
}

.title-team,
.view-btn p:first-child {
  font-size: 0.8em !important;
  margin-top: 0.4em;
}

.detail-content {
  display: none;
  transition: all 0.3s ease;
}

.list-teams {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1em;
  margin-top: 3em;
  position: relative;
}
@media (max-width: 991px) {
  .list-teams {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 767px) {
  .list-teams {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 524px) {
  .list-teams {
    grid-template-columns: repeat(1, 1fr);
  }
}

.detail-content.active {
  display: block;
  position: absolute;
  top: 0;
  background: #f0f0f0;
  z-index: 10000;
  left: 36px;
  width: 90vw;
  height: 90vh;
  margin-left: auto;
  margin-top: 2.5em;
  padding: 1.5em 1.5em 2.5em 1.5em;
  overflow: scroll;
  transition: all 0.3s ease;
}

.team-item.hide {
  display: none;
}

.social-media {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.5em;
  margin-top: 0.5em;
  max-width: -moz-fit-content;
  max-width: fit-content;
}

.social-media a img {
  width: 1.5em;
  height: auto;
}

.team-item {
  width: 100%;
}

.jobs-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(1rem, 0.8425rem + 0.8vw, 1.563rem);
  margin-top: 48px;
  row-gap: clamp(2rem, 1.78rem + 0.8vw, 2.5rem);
}
@media (max-width: 991px) {
  .jobs-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 767px) {
  .jobs-grid {
    grid-template-columns: repeat(1, 1fr);
  }
}

.job-card {
  background-color: var(--earth);
  padding: 24px;
}
@media (min-width: 900px) {
  .job-card {
    --transition-duration: 1s;
    opacity: 0;
    transform: translateX(50px);
    transition: transform var(--transition-duration), opacity var(--transition-duration);
    transition-delay: calc(0.1s + var(--n) * 0.2s);
  }
  .job-card.in-view {
    opacity: 1;
    transform: translateX(0px);
  }
}

.job-card h3 {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.editor-styles-wrapper .job-card {
  opacity: 1;
  transform: none;
}

.centered-text-panel {
  background-image: url(../img/yellow-bg-pattern.webp);
  background-size: 100%;
  background-repeat: no-repeat;
  background-position: center bottom;
}
@media (max-width: 991px) {
  .centered-text-panel {
    background-size: 200%;
  }
}

.centered-text-panel h2 {
  max-width: 37ch;
  margin-inline: auto;
}

.centered-text-panel p {
  max-width: 40ch;
  margin-inline: auto;
}

.content-panel.map {
  padding: clamp(0.938rem, 0.615rem + 1.4vw, 1.875rem) 0;
}

.map .map--image {
  display: block;
  width: 100%;
  height: auto;
}

.locations {
  position: relative;
  top: -180px;
  margin-bottom: -180px;
}
@media (max-width: 991px) {
  .locations {
    top: -160px;
    margin-bottom: -160px;
  }
}
@media (max-width: 767px) {
  .locations {
    top: -120px;
    margin-bottom: -120px;
  }
}

.locations-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(1rem, 0.8425rem + 0.8vw, 1.563rem);
  margin-top: 48px;
  row-gap: clamp(2rem, 1.78rem + 0.8vw, 2.5rem);
  position: relative;
}
@media (max-width: 991px) {
  .locations-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 767px) {
  .locations-grid {
    grid-template-columns: repeat(1, 1fr);
  }
}

.location-card {
  background-color: var(--aluminium);
  padding: 24px;
}
@media (min-width: 900px) {
  .location-card {
    --transition-duration: 1s;
    opacity: 0;
    transform: translateX(50px);
    transition: transform var(--transition-duration), opacity var(--transition-duration);
    transition-delay: calc(0.1s + var(--n) * 0.2s);
  }
  .location-card.in-view {
    opacity: 1;
    transform: translateX(0px);
  }
  .editor-styles-wrapper .location-card {
    opacity: 1;
    transform: translateX(0px);
  }
}

.location-card h3 {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.location-card h3 svg {
  flex-shrink: 0;
}

.locations-grid.is-yellow .location-card,
.location-card.is-yellow {
  background-color: var(--atomicYellow);
}

.locations-grid.is-yellow .location-card h3,
.location-card.is-yellow h3 {
  font-size: 16px;
  line-height: 20px;
  margin-bottom: 12px;
}
.locations-grid.is-yellow .location-card h3 span,
.location-card.is-yellow h3 span {
  opacity: 0.5;
}

.locations-grid.is-yellow a,
.location-card.is-yellow a {
  text-decoration: none;
  word-break: break-all;
}

main.plum-bg .contacts h2 {
  color: var(--atomicYellow);
}

.featured-post--grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-template-rows: 1fr;
  grid-column-gap: 26px;
  grid-row-gap: 0px;
  align-items: center;
}
@media (max-width: 991px) {
  .featured-post--grid {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
  }
}

.news-feature {
  position: relative;
  overflow: hidden;
}

.featured-post--image {
  grid-area: 1/1/2/8;
  aspect-ratio: 673/597;
  position: relative;
  width: 100%;
}
@media (max-width: 575px) {
  .featured-post--image {
    width: 100vw;
    position: relative;
    right: clamp(2rem, -0.21rem + 9.4vw, 8.25rem);
  }
}

.featured-post--image img {
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  -o-object-fit: cover;
     object-fit: cover;
}

.featured-post--title {
  text-decoration-thickness: 1px;
  text-underline-offset: 2px;
}

.featured-post--text {
  grid-area: 1/6/2/13;
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
}
@media (max-width: 991px) {
  .featured-post--text {
    width: 100%;
  }
}
.featured-post--text .earth-bg {
  transition: background 0.3s;
}
.featured-post--text:has(a:hover) .earth-bg {
  background: var(--atomicYellow);
}
.featured-post--text:has(a:hover) .featured-post--title {
  text-decoration: underline;
}

.featured-post--text a.blueprint--button:after {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
}

.featured-post--text .earth-bg {
  width: 100%;
  padding: clamp(2rem, 1.65rem + 1.5vw, 3rem) clamp(1.5rem, 0.93rem + 2.3vw, 3rem);
}
@media (max-width: 991px) {
  .featured-post--text .earth-bg {
    width: calc(100% - 60px);
    margin-inline: auto;
    position: relative;
    top: -120px;
    margin-bottom: -120px;
  }
}
@media (max-width: 575px) {
  .featured-post--text .earth-bg {
    width: 100%;
  }
}

.three-column--grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(1rem, 0.8425rem + 0.8vw, 1.563rem);
  margin-top: 48px;
  row-gap: clamp(2rem, 1.78rem + 0.8vw, 2.5rem);
}
@media (max-width: 767px) {
  .three-column--grid {
    grid-template-columns: repeat(1, 1fr);
  }
}

.fpn-blocks--grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  align-items: center;
  justify-content: center;
  gap: 1rem;
  margin-top: 3rem;
}
@media (max-width: 1199px) {
  .fpn-blocks--grid {
    margin-top: 2rem;
    grid-template-columns: repeat(5, 1fr);
  }
}
@media (max-width: 1023px) {
  .fpn-blocks--grid {
    margin-top: 2rem;
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (max-width: 767px) {
  .fpn-blocks--grid {
    margin-top: 1.5rem;
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 565px) {
  .fpn-blocks--grid {
    margin-top: 1.5rem;
    grid-template-columns: repeat(2, 1fr);
  }
}

.item-column {
  width: 100%;
  padding: 0.5rem;
  aspect-ratio: 1/1;
  position: relative;
  background-color: var(--earth);
}

.item-column.plum-bg {
  background-color: var(--plum);
  transition: all ease-in-out 0.3s;
  aspect-ratio: 3/4;
}

.icon-item {
  display: flex;
  justiy-content: start;
}

.icon-item img {
  width: 30px;
}
@media (max-width: 767px) {
  .icon-item img {
    width: 1.2rem;
  }
}

.icon-item img.filter-white {
  filter: brightness(0) invert(1);
  transition: all ease-in-out 0.3s;
}

.item-content {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.item-content,
.item-content a {
  text-decoration: none;
  text-align: center;
  display: flex;
  flex-direction: column;
  font-size: 1.2rem;
}
@media (max-width: 767px) {
  .item-content,
  .item-content a {
    font-size: 1rem;
  }
}

.item-content .filter-white,
.item-content a.filter-white {
  color: var(--white);
  transition: all ease-in-out 0.3s;
  display: inherit;
}

.item-content a.filter-white.hidden {
  display: none;
}

.hover-description {
  display: none;
  opacity: 0;
}

.hover-description h6 {
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--earth);
  line-height: normal;
  margin: 0;
}

.hover-description p {
  font-size: 1rem;
  font-weight: 400;
  color: var(--earth);
  line-height: normal;
  margin: 0;
}

.hover-description.visible {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  opacity: 1;
  transition: opacity 0.3s ease;
}

.text-block--text {
  width: 66.666%;
}
@media (max-width: 991px) {
  .text-block--text {
    width: 100%;
  }
}
.text-block--text p {
  max-width: 46ch;
}

.text-block ul {
  padding: 0;
  list-style: none;
}

.text-block li {
  margin-top: 25px !important;
  position: relative;
  display: flex;
  gap: 10px;
  align-items: flex-start;
}
.text-block li:first-child {
  margin-top: 0;
}
.text-block li:before {
  content: "–";
  top: 0;
  left: 0;
}

.content-block--text {
  width: 100%;
}

.text-block--image {
  display: grid;
  gap: 14px;
  grid-template-columns: 50% 50%;
  justify-items: center;
  align-items: center;
  padding: 20px 0px;
}
@media (max-width: 1199px) {
  .text-block--image {
    align-items: center;
  }
}
@media (max-width: 767px) {
  .text-block--image {
    grid-template-columns: repeat(1, 1fr);
    gap: 32px;
  }
}

.logo-block--text {
  display: flex;
}

.logo-block--text img {
  height: auto;
  width: 24rem;
}
@media (max-width: 1199px) {
  .logo-block--text img {
    width: 18rem;
  }
}
@media (max-width: 767px) {
  .logo-block--text img {
    width: 16rem;
  }
}

.image-block--details {
  position: relative;
}

.image-block--details img {
  width: 100%;
  height: auto;
  z-index: 100;
  position: relative;
}
@media (max-width: 767px) {
  .image-block--details img {
    width: 100%;
  }
}

.block-yellow {
  position: absolute;
  height: 110%;
  width: 80%;
  background-color: #e3fd66;
  top: -25px;
  right: -5%;
  z-index: 5;
  overflow: hidden;
}
@media (max-width: 1199px) {
  .block-yellow {
    top: -15px;
  }
}
@media (max-width: 767px) {
  .block-yellow {
    top: 20px;
    right: 0%;
    width: 100%;
  }
}

.block-yellow.with-bg--image {
  background-color: transparent;
  position: absolute;
  bottom: -10%;
  right: -100px;
  width: 85%;
  z-index: 10;
  top: inherit;
}
@media (max-width: 767px) {
  .block-yellow.with-bg--image {
    bottom: -20%;
    width: 100%;
  }
}

.text-block-image {
  overflow-x: hidden;
}

.content-panel.text-block-image {
  padding: clamp(3.75rem, 4.46rem + 5.6vw, 9.5rem) 0;
}
@media (max-width: 767px) {
  .content-panel.text-block-image {
    padding: clamp(3.75rem, 7.46rem + 5.6vw, 9.5rem) 0;
  }
}

.blueprint--button.outline-btn {
  border: 1px solid var(--earth);
  font-size: clamp(0.938rem, 0.855rem + 0.3vw, 1.125rem);
  outline: none;
  background-color: transparent;
  color: var(--earth);
}

.blueprint--button.outline-btn svg path {
  stroke: var(--earth);
}

.blueprint--button.outline-btn:hover {
  background-color: var(--earth);
  border: 1px solid var(--earth);
  color: var(--plum);
}

.blueprint--button.outline-btn:hover svg path {
  stroke: var(--plum);
}

.image-block--details img {
  aspect-ratio: 16/9;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}

.card-text-content {
  display: grid;
  gap: 14px;
  padding: 16px;
}

.card-text-content h5,
.card-text-content p {
  margin: 0px;
}

.text-block--text {
  width: 66.666%;
}
@media (max-width: 991px) {
  .text-block--text {
    width: 100%;
  }
}
.text-block--text p {
  max-width: 46ch;
}

.text-block ul {
  padding: 0;
  list-style: none;
}

.text-block li {
  margin-top: 25px !important;
  position: relative;
  display: flex;
  gap: 10px;
  align-items: flex-start;
}
.text-block li:first-child {
  margin-top: 0;
}
.text-block li:before {
  content: "–";
  top: 0;
  left: 0;
}

.content-block--text {
  width: 100%;
}

.text-block--image {
  display: grid;
  gap: 14px;
  grid-template-columns: 50% 50%;
  justify-items: center;
  align-items: center;
  padding: 20px 0px;
}
@media (max-width: 1199px) {
  .text-block--image {
    align-items: center;
  }
}
@media (max-width: 767px) {
  .text-block--image {
    grid-template-columns: repeat(1, 1fr);
    gap: 32px;
  }
}

.logo-block--text {
  display: flex;
}

.logo-block--text img {
  height: auto;
  width: 24rem;
}
@media (max-width: 1199px) {
  .logo-block--text img {
    width: 18rem;
  }
}
@media (max-width: 767px) {
  .logo-block--text img {
    width: 16rem;
  }
}

.image-block--details {
  position: relative;
}

.image-block--details img {
  width: 100%;
  height: auto;
  z-index: 100;
  position: relative;
}
@media (max-width: 767px) {
  .image-block--details img {
    width: 100%;
  }
}

.block-yellow-two {
  position: absolute;
  height: 110%;
  width: 100%;
  background-color: #e3fd66;
  top: -25px;
  right: -25%;
  z-index: 5;
  overflow: hidden;
}
@media (max-width: 1199px) {
  .block-yellow-two {
    top: -15px;
  }
}
@media (max-width: 767px) {
  .block-yellow-two {
    top: 20px;
    right: 0%;
  }
}

.text-block-image {
  overflow-x: hidden;
}

.content-panel.text-block-image {
  padding: clamp(3.75rem, 4.46rem + 5.6vw, 9.5rem) 0;
}
@media (max-width: 767px) {
  .content-panel.text-block-image {
    padding: clamp(3.75rem, 7.46rem + 5.6vw, 9.5rem) 0;
  }
}

.container-overflowhidden {
  overflow: hidden;
}

.title-item {
  font-size: 2rem;
  color: var(--plum);
  font-weight: 500;
}

.title-item.text-white {
  color: var(--earth);
}

.title-content {
  font-size: 4rem;
  color: var(--plum);
}
@media (max-width: 767px) {
  .title-content {
    font-size: 3rem;
  }
}

.title-content.text-white {
  color: var(--earth);
}

.text-area--content {
  font-size: 1.6rem;
  color: var(--plum);
  margin-top: 1rem;
}
@media (max-width: 767px) {
  .text-area--content {
    font-size: 1rem;
  }
}

.title-content {
  text-align: center;
}

.text-area--content {
  text-align: center;
  max-width: 80%;
  margin-left: auto;
  margin-right: auto;
  margin-top: 2rem;
}
@media (max-width: 991px) {
  .text-area--content {
    max-width: 100%;
  }
}

.text-area--content.text-white {
  color: var(--earth);
}

.card-button--with-column {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
  margin-top: 3rem;
}
@media (max-width: 767px) {
  .card-button--with-column {
    grid-template-columns: repeat(1, 1fr);
  }
}

.conten-with--cards {
  animation: fadeInUp;
  animation-duration: 1s;
  animation-fill-mode: both;
  animation-delay: 2s;
  width: 100%;
  margin-top: 1rem;
}

.card-content--item img {
  width: 100%;
  aspect-ratio: 16/9;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}

.card-content--item a {
  text-decoration: none;
}

.card-content--item.with-image {
  background-color: var(--earth);
}

.card-button--with-column.card--image {
  grid-template-columns: repeat(3, 1fr);
}
@media (max-width: 767px) {
  .card-button--with-column.card--image {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 565px) {
  .card-button--with-column.card--image {
    grid-template-columns: repeat(1, 1fr);
  }
}

.content-panel.map.map-office {
  padding: clamp(4.938rem, 0.615rem + 1.4vw, 1.875rem) 0;
}

.office--content {
  display: grid;
  grid-template-columns: 50% 50%;
  gap: 2rem;
}

.list-office--item {
  text-decoration: none;
  list-style: none;
  height: -moz-fit-content;
  height: fit-content;
  border-bottom: 1px solid var(--plum);
  margin-bottom: 0rem;
}

.location-card__content {
  margin-top: 1.6rem;
}

.location-card__content p,
.location-card__content a,
.location-card__content li {
  margin-top: 0rem;
  font-size: clamp(1.125rem, 1.07rem + 0.2vw, 1.25rem);
  font-weight: 500;
}

.office-name {
  position: relative;
}

.office-name svg {
  position: absolute;
  right: 0;
  top: 20px;
}

.office-name h5 {
  margin: 0;
  font-size: 2rem;
}

.office-open-name {
  width: 100%;
  padding: 1.5rem 0rem;
}

.office-name-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  width: -moz-max-content;
  width: max-content;
  gap: 1.5rem;
}

.sub-office-name p {
  margin-top: 0rem;
  font-weight: 600;
  font-size: 1.4rem;
}

.office-location--details .address-office {
  margin-top: 1rem;
  font-weight: 400;
}

.sub-office-name {
  width: 20rem;
}

.location-card-center p {
  margin-top: 0rem;
}

.loopnumb {
  margin-top: 1.6rem;
}

.phone-numb {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.phone-numb p {
  margin-top: 0rem;
}

.phone-numb p a {
  margin-top: 0;
  font-size: clamp(1.125rem, 1.07rem + 0.2vw, 1.25rem);
  font-weight: 500;
  text-decoration: inherit;
}
.phone-numb p a:hover {
  text-decoration: underline;
}

.locations.map-none {
  position: relative;
  top: 0px;
  margin-bottom: 0px;
}

.mail--button {
  min-width: 180px;
}

.address-with-icon {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
}

@media screen and (max-width: 767px) {
  .blueprint--button {
    padding: 1em 2em;
    min-width: 130px;
  }
}

.main-office-list p,
.main-office-list svg,
.main-office-list a {
  color: var(--earth);
  text-decoration: none;
  margin-top: 0rem;
}

.main-office-list svg {
  font-size: 18px;
  color: var(--earth);
}

.main-office-content {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.main-office-content p {
  font-weight: 600;
}

.container-office {
  padding: 0rem;
  margin: 0rem;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2rem;
}
@media (max-width: 991px) {
  .container-office {
    grid-template-columns: 1fr;
  }
}

.container-office li {
  text-decoration: none;
  list-style: none;
}

.main-office-list {
  padding: 2rem 1rem;
  border-bottom: 1px solid var(--earth);
  cursor: pointer;
  transition: all 0.3s ease;
  margin-bottom: 0rem;
}

.main-office-list:hover,
.main-office-list:focus,
.main-office-list:active {
  background-color: var(--earth);
  transition: all 0.3s ease;
  color: var(--plum);
}

.main-office-list:hover .sub-office,
.main-office-list:focus .sub-office,
.main-office-list:active .sub-office,
.main-office-list:hover a,
.main-office-list:focus a,
.main-office-list:active a,
.main-office-list:hover span,
.main-office-list:focus span,
.main-office-list:active span {
  color: var(--plum) !important;
}

.main-office-list:hover img,
.main-office-list:focus img,
.main-office-list:active img {
  filter: brightness(1) invert(0);
}

.main-office-list img,
.main-office-list img,
.main-office-list img {
  filter: brightness(0) invert(1);
}

.main-office-list:hover p,
.main-office-list:focus p,
.main-office-list:active p {
  color: var(--plum);
}

.main-office-list:hover svg,
.main-office-list:focus svg,
.main-office-list:active svg {
  color: var(--plum);
}

.sub-office-list {
  /* display: none; */
  opacity: 0;
  max-height: 0;
  overflow: hidden;
  transition: opacity 0.3s ease, max-height 0.3s ease;
}

.sub-office-list.show {
  display: contents;
  opacity: 1;
  max-height: 100px;
  transition: opacity 0.3s ease, max-height 0.3s ease;
}

.sub-office {
  margin-top: 1.5rem;
  /* padding: 1.2rem 1rem; */
  /* border-bottom: 1px solid var(--earth); */
  cursor: pointer;
  transition: all 0.3s ease;
}

.sub-office:hover,
.sub-office:focus,
.sub-office:active {
  transition: all 0.3s ease;
  color: var(--plum);
}

.sub-office:hover p,
.sub-office:focus p,
.sub-office:active p {
  color: var(--plum);
}

.sub-office:hover svg,
.sub-office:focus svg,
.sub-office:active svg {
  color: var(--plum);
}

.sub-office-content {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.address-office {
  display: none;
  opacity: 0;
  max-height: 0;
  overflow: hidden;
  transition: opacity 0.3s ease, max-height 0.3s ease;
  margin-top: 1rem;
}

.address-office.show {
  display: block;
  opacity: 1;
  max-height: 100%;
  transition: opacity 0.3s ease, max-height 0.3s ease;
  margin-top: 1rem;
}

.yellow-title--section {
  margin-bottom: 2rem;
}

.swiper-item {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 14rem 0rem 0rem 0rem;
  flex-direction: column;
}
@media (max-width: 767px) {
  .swiper-item {
    padding: 8rem 0rem 0rem 0rem;
  }
}

.pagination-item {
  top: 0 !important;
  height: -moz-fit-content;
  height: fit-content;
}

.mySwiper {
  height: 25rem;
  margin-top: 4rem;
}
@media (max-width: 767px) {
  .mySwiper {
    height: 18rem;
    margin-top: 4rem;
  }
}

.swiper-pagination-bullet {
  width: 200px !important;
  height: 200px !important;
  background-color: var(--plum) !important;
  color: var(--atomicYellow) !important;
  border: 2px solid var(--atomicYellow) !important;
  opacity: 1 !important;
}
@media (max-width: 767px) {
  .swiper-pagination-bullet {
    width: 100px !important;
    height: 100px !important;
  }
}

.swiper-pagination-bullet.swiper-pagination-bullet-active.swiper-pagination-bullet-active-main {
  width: 200px !important;
  height: 200px !important;
  background-color: var(--atomicYellow) !important;
  color: var(--plum) !important;
}
@media (max-width: 767px) {
  .swiper-pagination-bullet.swiper-pagination-bullet-active.swiper-pagination-bullet-active-main {
    width: 100px !important;
    height: 100px !important;
  }
}

.line-yellow {
  position: absolute;
  top: 100px;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  height: 2px;
  border-bottom: 2px solid var(--atomicYellow);
}
@media (max-width: 767px) {
  .line-yellow {
    top: 50px;
  }
}

.title-journey,
.subtitle-journey,
.swiper-item {
  color: var(--earth);
}

.year {
  margin-top: 5rem !important;
  font-size: 1.4rem !important;
}
@media (max-width: 767px) {
  .year {
    margin-top: 2.4rem !important;
    font-size: 1rem !important;
  }
}

.swiper-button-prev.button-prev {
  left: 0px;
}

.swiper-button-next.button-next {
  right: 0px;
}

.swiper-button-next.button-next, .swiper-button-prev.button-prev {
  top: 90px;
  background-color: var(--atomicYellow);
  padding: 2rem;
  color: var(--plum);
  border-radius: 4px;
  z-index: 1000;
}
@media (max-width: 1023px) {
  .swiper-button-next.button-next, .swiper-button-prev.button-prev {
    padding: 1.4rem;
    top: 100px;
  }
}
@media (max-width: 767px) {
  .swiper-button-next.button-next, .swiper-button-prev.button-prev {
    padding: 1rem;
    top: 50px;
  }
}

.swiper-button-next.button-next.swiper-button-disabled, .swiper-button-prev.button-prev.swiper-button-disabled {
  opacity: 1;
  background-color: #b9d733;
}

.swiper-button-next.button-next::after, .swiper-button-prev.button-prev::after {
  font-size: 1.8rem;
}
@media (max-width: 1023px) {
  .swiper-button-next.button-next::after, .swiper-button-prev.button-prev::after {
    font-size: 1.4rem;
  }
}
@media (max-width: 767px) {
  .swiper-button-next.button-next::after, .swiper-button-prev.button-prev::after {
    font-size: 1rem;
  }
}

.swiper-item-content {
  text-align: center;
  width: 75%;
  color: var(--earth);
  max-height: 160px;
}

.swiper-item-content a,
.swiper-item-content p,
.swiper-item-content h1,
.swiper-item-content h2,
.swiper-item-content h3,
.swiper-item-content h4,
.swiper-item-content h5 {
  color: var(--earth);
  margin: inherit;
}

.text-for-scroll {
  font-size: 0.8rem;
  color: var(--earth);
}

.head-journey h2 {
  color: var(--earth);
}

.icon-size-medium,
.icon-size-default {
  -o-object-fit: contain;
     object-fit: contain;
  -o-object-position: center;
     object-position: center;
}

.icon-size-default {
  width: 64px;
  height: 64px;
}

.icon-size-medium {
  width: 32px;
  height: 32px;
}

.icon-blocks {
  position: relative;
  overflow: hidden;
}

.icon-blocks .fade-in {
  position: relative;
  z-index: 2;
}

.icon-blocks--background {
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  width: auto;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  z-index: 1;
}
@media (max-width: 991px) {
  .icon-blocks--background {
    height: 40%;
    top: auto;
    bottom: 0;
  }
}
@media (max-width: 767px) {
  .icon-blocks--background {
    height: 50%;
  }
}

.has-image .icon-blocks--background {
  height: 60%;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  top: auto;
  bottom: 0;
}

.icon-blocks--grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 48px;
  -ms-overflow-style: none;
  scrollbar-width: none;
  position: relative;
  z-index: 2;
}
@media (max-width: 991px) {
  .icon-blocks--grid {
    grid-template-columns: repeat(1, 1fr);
  }
}
@media (max-width: 767px) {
  .icon-blocks--grid {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(1, 1fr);
    overflow: auto;
    flex-wrap: nowrap;
  }
}

.icon-blocks--grid::-webkit-scrollbar {
  display: none;
}

.icon-blocks--grid.is-two {
  grid-template-columns: repeat(2, 1fr);
}
@media (max-width: 991px) {
  .icon-blocks--grid.is-two {
    grid-template-columns: repeat(1, 1fr);
  }
}

.icon-block {
  background-color: var(--earth);
  padding: 24px;
}
@media (min-width: 900px) {
  .icon-block {
    --transition-duration: 1s;
    opacity: 0;
    transform: translateX(50px);
    transition: transform var(--transition-duration), opacity var(--transition-duration);
    transition-delay: calc(0.1s + var(--n) * 0.2s);
  }
  .editor-styles-wrapper .icon-block {
    opacity: 1;
    transform: translateX(0px);
  }
  .icon-block.in-view {
    opacity: 1;
    transform: translateX(0px);
  }
}
@media (max-width: 767px) {
  .icon-block {
    min-width: 311px;
  }
}

.icon-block img,
.icon-block svg {
  margin-bottom: 48px;
}

.icon-block p {
  margin-top: 10px;
}

.title--number {
  font-size: 5rem;
  height: 100%;
  width: 100%;
  line-height: normal;
}

.number-block {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
}

.hero-banner .container.right {
  display: grid;
  justify-content: end;
  text-align: left;
}

.hero-banner--image.right {
  right: inherit;
  left: 0;
}

.text-block-with--image {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2rem;
}
@media (max-width: 767px) {
  .text-block-with--image {
    grid-template-columns: 1fr;
  }
}

.text-block-with--image p,
.text-block-with--image a,
.text-block-with--image li,
.text-block-with--image h2 {
  margin-top: 0rem;
}

.text-content {
  order: 1;
}
@media (max-width: 767px) {
  .text-content {
    order: 2;
  }
}

.text-content h2 {
  margin-bottom: 1.25rem;
}

.text-content div {
  margin-top: 1.5rem;
}

.image-content {
  order: 2;
}
@media (max-width: 767px) {
  .image-content {
    order: 1;
  }
}

.image-content img {
  width: 100%;
  height: auto;
}

.image-content video {
  width: 100%;
  height: auto;
}

.image-content iframe {
  width: 100%;
}

.galleries-items.three {
  grid-template-columns: repeat(3, 1fr);
  display: grid;
  gap: 2rem;
}
@media (max-width: 767px) {
  .galleries-items.three {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 575px) {
  .galleries-items.three {
    grid-template-columns: repeat(1, 1fr);
  }
}

.galleries-items.four {
  grid-template-columns: repeat(4, 1fr);
  display: grid;
  gap: 2rem;
}
@media (max-width: 991px) {
  .galleries-items.four {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (max-width: 767px) {
  .galleries-items.four {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 575px) {
  .galleries-items.four {
    grid-template-columns: repeat(1, 1fr);
  }
}

.galleries-items.five {
  grid-template-columns: repeat(5, 1fr);
  display: grid;
  gap: 2rem;
}
@media (max-width: 1199px) {
  .galleries-items.five {
    grid-template-columns: repeat(4, 1fr);
  }
}
@media (max-width: 991px) {
  .galleries-items.five {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (max-width: 767px) {
  .galleries-items.five {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 575px) {
  .galleries-items.five {
    grid-template-columns: repeat(1, 1fr);
  }
}

.galleries-items img {
  width: 100%;
}

.plum-bg .text-content p,
.plum-bg .text-content a,
.plum-bg .text-content li {
  color: var(--earth);
  margin-top: 0.4rem;
}

.plum-bg .text-content h1,
.plum-bg .text-content h2,
.plum-bg .text-content h3,
.plum-bg .text-content h4,
.plum-bg .text-content h5,
.plum-bg .text-content h6 {
  margin-top: 0.4rem;
}

.plum-bg .text-block-with--image .blueprint--button {
  margin-top: 0rem;
  color: var(--plum);
}

.plum-bg .text-block-with--image .blueprint--button:hover {
  color: var(--earth);
}

.block-galleries {
  margin-top: 4rem;
}
@media (max-width: 767px) {
  .block-galleries {
    margin-top: 2rem;
  }
}

select {
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
}

.select-article-button {
  position: relative;
}

.sort-date,
.sort-by-page {
  position: absolute;
  content: "";
  top: 50%;
  right: 1.2rem;
  width: 14px;
  height: 14px;
  transform: translateY(-50%);
  background-image: url("https://apac.hubexo.com/wp-content/uploads/2025/03/drop-chevron.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  border: none;
}

.nav-article {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 2rem;
  padding-bottom: 2rem;
  border-bottom: 1px solid var(--plum);
}
@media (max-width: 991px) {
  .nav-article {
    flex-direction: column;
    gap: 2rem;
    justify-content: start;
    align-items: baseline;
  }
}

.article-nav-next-prev {
  display: flex;
  gap: 0.5rem;
}

.article-nav-next-prev button {
  padding: 8px 16px;
  cursor: pointer;
  border-radius: 4px;
  display: flex;
  align-items: center;
  gap: 8px;
  background: transparent;
  border: 1px solid var(--plum);
  font-weight: 400;
  font-size: 1rem;
  color: var(--plum);
  transition: all ease 0.3s;
}

.article-nav-next-prev button:hover {
  background: var(--plum);
  color: var(--earth);
  transition: all ease 0.3s;
}

.sort-by select {
  padding: 6px 40px 6px 12px;
  border: 1px solid var(--plum);
  border-radius: 4px;
  margin: 0 8px;
  background: transparent;
}

.result-page select {
  padding: 6px 30px 6px 12px;
  border-radius: 4px;
  margin: 0 8px;
  border: 1px solid var(--plum);
  background: transparent;
}

.article-sortby {
  display: flex;
  align-items: center;
  gap: 20px;
}
@media (max-width: 991px) {
  .article-sortby {
    flex-direction: column;
    gap: 2rem;
    justify-content: start;
    align-items: baseline;
  }
}

.sort-by,
.result-page {
  display: flex;
  align-items: center;
  position: relative;
}

.article-nav-next-prev button[disabled] {
  opacity: 0.5;
  cursor: not-allowed;
}

.article-nav-next-prev button[disabled]:hover {
  background: transparent;
  color: var(--plum);
}

.source-link {
  font-weight: 600;
}

.source-link a {
  text-decoration: none;
  font-weight: 400;
}

.source-link a:hover {
  text-decoration: underline;
  font-weight: 600;
}

.sec-post-grid {
  padding: 4rem 0rem;
}
@media (max-width: 767px) {
  .sec-post-grid {
    padding: 2rem 0rem;
  }
}

.content-excerpt {
  margin-top: 0.5rem;
  font-weight: 400;
  display: -webkit-box;
  -webkit-line-clamp: 4; /* Adjust the number of lines you want to display */
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}

.plum-color .blog-post-block--text .blog-post-block--meta,
.plum-color .blog-post-block--text .small-title--bold.blog-post-block--title,
.plum-color .blog-post-block--text .wysiwyg h1.blog-post-block--title,
.wysiwyg .plum-color .blog-post-block--text h1.blog-post-block--title,
.plum-color .blog-post-block--text .wysiwyg h2.blog-post-block--title,
.wysiwyg .plum-color .blog-post-block--text h2.blog-post-block--title,
.plum-color .blog-post-block--text .wysiwyg h3.blog-post-block--title,
.wysiwyg .plum-color .blog-post-block--text h3.blog-post-block--title,
.plum-color .blog-post-block--text .wysiwyg h4.blog-post-block--title,
.wysiwyg .plum-color .blog-post-block--text h4.blog-post-block--title,
.plum-color .blog-post-block--text .wysiwyg h5.blog-post-block--title,
.wysiwyg .plum-color .blog-post-block--text h5.blog-post-block--title,
.plum-color .blog-post-block--text .wysiwyg h6.blog-post-block--title,
.wysiwyg .plum-color .blog-post-block--text h6.blog-post-block--title,
.plum-color .blog-post-block--text .post-navigation a.blog-post-block--title,
.post-navigation .plum-color .blog-post-block--text a.blog-post-block--title,
.plum-color .blog-post-block--text .content-excerpt {
  color: var(--plum);
}

.blog-post-block {
  min-height: 540px;
}

.blog-post-block--text {
  height: 260px;
}

.card-news {
  padding-top: 4rem;
}

.card-news.plum-color {
  background-color: var(--plum);
}

.title-news.plum-color {
  color: var(--earth);
}

.blueprint--button.icon-blocks--button.plum-bg.outline-button.plum-color {
  color: var(--earth);
  border: 1px solid var(--earth);
  transition: all 0.3s ease;
}

.blueprint--button.icon-blocks--button.plum-bg.outline-button.plum-color:hover {
  color: var(--plum);
  border: 1px solid var(--earth);
  background-color: var(--earth);
  transition: all 0.3s ease;
}

.card-news.earth-color {
  background-color: var(--earth);
}

.title-news.earth-color {
  color: var(--plum);
}

.blueprint--button.icon-blocks--button.plum-bg.outline-button.earth-color {
  color: var(--plum);
  border: 1px solid var(--plum);
  transition: all 0.3s ease;
}

.blueprint--button.icon-blocks--button.plum-bg.outline-button.earth-color:hover {
  background-color: var(--plum);
  color: var(--earth);
  border: 1px solid var(--plum);
  transition: all 0.3s ease;
}

.blueprint--button.icon-blocks--button.blog-post-grid-one.plum-bg.outline-button.earth-color {
  color: var(--plum);
  border: none;
  transition: all 0.3s ease;
}

.blueprint--button.icon-blocks--button.blog-post-grid-one.plum-bg.outline-button.earth-color:hover {
  background-color: var(--plum);
  color: var(--earth);
  border: none;
  transition: all 0.3s ease;
}

.title-page--custom {
  margin-bottom: 4rem;
}

.blueprint--button.icon-blocks--button.blog-post-grid-one.plum-bg.outline-button.plum-color {
  color: var(--earth);
  transition: all 0.3s ease;
  border: none;
}

.blueprint--button.icon-blocks--button.blog-post-grid-one.plum-bg.outline-button.plum-color:hover {
  color: var(--plum);
  background-color: var(--earth);
  transition: all 0.3s ease;
}

.blueprint--button.icon-blocks--button.blog-post-grid-one.plum-bg.outline-button svg {
  rotate: -90deg;
  width: 24px;
  height: auto;
}

.blueprint--button.icon-blocks--button.blog-post-grid-one.plum-bg.outline-button svg path {
  stroke: var(--plum);
}

.blueprint--button.icon-blocks--button.blog-post-grid-one.plum-bg.outline-button:hover svg path {
  stroke: var(--plum);
}

.blueprint--button.icon-blocks--button.blog-post-grid-one.plum-bg.outline-button.earth-color svg path {
  stroke: var(--plum);
}

.blueprint--button.icon-blocks--button.blog-post-grid-one.plum-bg.outline-button.earth-color:hover svg path {
  stroke: var(--earth);
}

blog-post-block--meta {
  font-size: 0.8rem;
  font-weight: 500;
}

.blog-post-list--text a {
  text-decoration: none;
}

.blog-post-list--title {
  font-size: 1.8rem;
  font-weight: 600;
  margin-top: 0.4rem;
  line-height: normal;
}

.blog-post-item.blog-item-list {
  padding: 2rem 0rem;
  border-bottom: 1px solid rgba(50, 20, 50, 0.2901960784);
}

.blog-post-item.blog-item-list:last-child {
  border-bottom: none;
}

.load-more-wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 2rem;
}

.load-more-button {
  background-color: transparent;
  border: 1px solid var(--plum);
  padding: 1rem 1.4rem;
  border-radius: 10rem;
}

.posts-container {
  margin-top: 2.5rem;
}

.content-panel.plum-color {
  background-color: var(--plum);
  color: var(--earth);
}
.content-panel.plum-color .blog-post-item {
  border-bottom: 1px solid var(--earth);
}
.content-panel.plum-color .blog-post-item:last-child {
  border-bottom: none;
}
.content-panel.plum-color .blog-post-list--title {
  color: var(--earth);
}
.content-panel.plum-color .load-more-button {
  border: 1px solid var(--earth);
  font-weight: 600;
  transition: all 0.3s ease;
}
.content-panel.plum-color .load-more-button:hover {
  background-color: var(--earth);
  color: var(--plum);
  font-weight: 600;
  transition: all 0.3s ease;
}

.blog-post-block--meta.hide,
.blog-post-block--meta .hide {
  display: none;
}

.map-shortcode {
  margin-top: 2rem;
}

.map .map--image {
  border: 1px solid var(--earth);
}

/* Components                --- */
.header-message {
  background-color: var(--plum);
  color: var(--white);
  padding-top: 16px;
  padding-bottom: 16px;
  position: relative;
  z-index: 11;
  display: none;
  color: #fff;
}

.header-message p,
.header-message a {
  color: #fff;
}

.header-message p {
  padding: 0 20px;
}

.header-message .container-fluid {
  position: relative;
  padding: 0 80px;
}

.header-message button {
  background: transparent;
  width: 20px;
  height: 20px;
  background: transparent;
  padding: 0;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 40px;
  line-height: 1;
  border: 0;
}
@media (max-width: 767px) {
  .header-message button {
    right: 20px;
  }
}

.header-message button svg path,
.header-message button svg circle {
  stroke: var(--white);
}

@media screen and (min-width: 768px) and (max-width: 991px) {
  .select-items div,
  .select-selected {
    padding: 0.5rem 2.5rem 0.5rem 1rem;
  }
  .select-selected:after {
    right: 0.8rem;
  }
  .button-continue {
    padding: 0.5rem 2rem 0.5rem 2rem;
  }
}
@media screen and (min-width: 320px) and (max-width: 767px) {
  .bar-container {
    display: flex;
    flex-direction: column;
  }
  .select-selected {
    font-size: 0.8rem;
    padding: 0.5rem 2.4rem 0.5rem 1.4rem !important;
    border-radius: 40px;
    height: 3rem;
  }
  .select-selected:after {
    content: "";
    top: 50%;
    right: 1rem;
    width: 14px;
    height: 14px;
    transform: translateY(-50%);
    background-image: url(https://apac.hubexo.com/wp-content/uploads/2025/03/drop-chevron.png);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    border: none;
  }
  .button-continue {
    padding: 1rem 1rem 1rem 1rem !important;
    width: -moz-max-content;
    width: max-content;
    height: 3rem;
    font-size: 1rem;
  }
  .title-and-icon svg {
    width: 1.2rem;
  }
  .close-button {
    display: none !important;
  }
  .close-button--at-mobile {
    display: flex !important;
    right: 0.6rem;
    top: 0.6rem;
  }
  .region-bar {
    padding: 1rem 0rem 1rem 0rem !important;
  }
}
/*the container must be positioned relative:*/
.custom-select {
  position: relative;
}

.custom-select select {
  display: none;
  /*hide original SELECT element:*/
}

.select-selected {
  background-color: var(--earth);
}

/*style the arrow inside the select element:*/
.select-selected:after {
  position: absolute;
  content: "";
  top: 50%;
  right: 1rem;
  width: 14px;
  height: 14px;
  transform: translateY(-50%);
  background-image: url(https://apac.hubexo.com/wp-content/uploads/2025/03/drop-chevron.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  border: none;
}

/*point the arrow upwards when the select box is open (active):*/
.select-selected.select-arrow-active:after {
  transform: translateY(-50%) rotate(180deg);
  top: 50%;
  border: none;
}

.select-items div:hover,
.same-as-selected {
  background-color: rgba(0, 0, 0, 0.1);
}

.select-selected.select-arrow-active,
.select-items div:hover {
  background-color: var(--atomicYellow) !important;
}

/*style the items (options), including the selected item:*/
.select-items div,
.select-selected {
  color: var(--plum);
  padding: 0.4rem 2.8rem 0.4rem 1.4rem;
  border: 1px solid transparent;
  /* border-color: transparent transparent rgba(0, 0, 0, 0.1) transparent; */
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  width: -moz-max-content;
  width: max-content;
  height: 3rem;
  display: flex;
  align-items: center;
  font-size: 0.8rem;
  font-weight: 600;
}

.select-selected {
  border-radius: 1000px;
}

.wrap-card {
  position: absolute;
  top: 120%;
  bottom: inherit;
  background-color: var(--earth);
  right: -145px;
  border-radius: 1.5rem;
  padding: 0.4rem;
  width: -moz-max-content;
  width: max-content;
  z-index: 999;
}
@media (max-width: 991px) {
  .wrap-card {
    right: -185px;
  }
}
@media (max-width: 767px) {
  .wrap-card {
    right: inherit;
  }
}

/*style items (options):*/
.select-items {
  position: relative;
  background-color: var(--earth);
  min-width: -moz-max-content;
  min-width: max-content;
  overflow: scroll;
  width: -moz-fit-content;
  width: fit-content;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0.5rem;
  padding: 0.4rem 0rem;
  border-top: 1px solid #cacaca;
}
@media (max-width: 1439px) {
  .select-items {
    grid-template-columns: repeat(5, 1fr);
    height: -moz-max-content;
    height: max-content;
    overflow: scroll;
  }
}
@media (max-width: 1199px) {
  .select-items {
    grid-template-columns: repeat(4, 1fr);
    height: -moz-max-content;
    height: max-content;
    overflow: scroll;
  }
}
@media (max-width: 991px) {
  .select-items {
    grid-template-columns: repeat(3, 1fr);
    height: 50vh;
    overflow: scroll;
  }
}
@media (max-width: 767px) {
  .select-items {
    left: 0;
    grid-template-columns: repeat(2, 1fr);
    padding: 1rem;
    gap: 0.5rem;
    width: 100%;
    height: 40vh;
    overflow: scroll;
  }
}

.select-items div img {
  width: 22px;
  height: auto;
}

.select-items::-webkit-scrollbar {
  display: none;
}

/*hide the items when the select box is closed:*/
.select-hide {
  display: none;
}

.select-items div {
  width: 100%;
  display: flex;
  justify-content: start;
  gap: 0.4rem;
  padding: 0.4rem;
  font-size: 0.8rem;
  border-radius: 0.6rem;
}

.bar-container {
  display: flex;
  gap: 1rem;
  align-items: center;
  justify-content: space-between;
}

.button-continue {
  padding: 1rem 1rem 1rem 1rem;
  width: -moz-max-content;
  width: max-content;
  height: 3rem;
  font-size: 1rem;
  background-color: var(--atomicYellow);
}

.button-continue .submit-button {
  font-size: 0.8rem;
}

.button-continue svg {
  width: 0.8rem;
}

.button-continue:hover {
  border: 1px solid var(--earth);
}

.submit-button {
  background: none;
  border: none;
}

.button-container {
  align-items: center;
  display: flex;
  gap: 0.8rem;
  justify-content: end;
  width: 100%;
}
@media (max-width: 767px) {
  .button-container {
    justify-content: start;
  }
}

.global-top--region {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  color: var(--plum);
  font-weight: 600;
  justify-content: center;
  padding: 0.2rem 0rem;
  margin-bottom: 0.4rem;
  cursor: pointer;
  border-radius: 1.2rem;
}

.global-top--region:hover {
  background-color: var(--atomicYellow);
}

.global-top--region img {
  width: 22px;
}

.global-top--region p {
  margin-top: 0rem;
  color: var(--plum);
  font-weight: 600;
  font-size: 0.8rem;
}

.region-bar {
  min-height: -moz-fit-content;
  min-height: fit-content;
  background-color: var(--plum);
  position: relative;
  bottom: 0;
  z-index: 90010;
  width: 100%;
  justify-content: center;
  align-items: center;
  padding: 1rem 0rem;
  transition: display 0.3s ease-out;
  display: block;
}

.region-bar.hidden {
  display: none;
}

.region-bar[style*="display: none"] {
  opacity: 0;
}

/* Optional: Add a fade-in animation */
@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
.region-bar.fade-in {
  animation: fadeIn 0.3s ease-in;
}

.region-bar.close-bar {
  bottom: -1000%;
  transition: all ease-in-out 0.3s;
}

.title-and-icon {
  display: flex;
  gap: 0.8rem;
  align-items: center;
  justify-content: start;
}

.title-and-icon img {
  width: 30px;
  height: auto;
}

.title-content--bar {
  font-size: 1.2rem;
  color: var(--atomicYellow);
  margin: 0rem;
  font-weight: 600;
  text-align: start;
}
@media (max-width: 767px) {
  .title-content--bar {
    font-size: 1rem;
  }
}

.description-banner a,
.description-banner p {
  font-size: 1rem;
  color: var(--earth);
  margin: 0rem;
}
@media (max-width: 767px) {
  .description-banner a,
  .description-banner p {
    font-size: 0.8rem;
  }
}

.title-and-icon svg path {
  fill: var(--atomicYellow);
}

.description-banner {
  margin-top: 1rem;
}

.close-button {
  padding: 0.45rem;
  border: 1px solid var(--earth);
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 1000px;
  cursor: pointer;
}

.close-button--at-mobile {
  padding: 0.5rem;
  border: 1px solid var(--earth);
  display: none;
  justify-content: center;
  align-items: center;
  border-radius: 1000px;
  cursor: pointer;
  right: 1.6rem;
  position: absolute;
  bottom: 1.5rem;
  top: inherit;
}
@media (max-width: 767px) {
  .close-button--at-mobile {
    right: 2rem;
  }
}

.close-button svg,
.close-button--at-mobile svg {
  width: 0.6rem;
  height: 0.6rem;
  fill: var(--earth);
}

.close-button svg path,
.close-button--at-mobile svg path {
  fill: var(--earth);
  stroke: var(--earth);
  stroke-width: 3px;
}

@media (max-width: 1023px) {
  #menu-item-1759 {
    display: none;
  }
}

@media (max-width: 767px) {
  .menu-open .site-header .region-bar .header-nav ul {
    padding-top: 360px;
  }
}

/*the container must be positioned relative:*/
.lang-custom-select {
  position: relative;
}

.lang-custom-select select {
  display: none;
  /*hide original SELECT element:*/
}

.lang-select-selected:after {
  position: absolute;
  content: "";
  top: 45%;
  right: 1.2rem;
  width: 0;
  height: 0;
  border: 8px solid transparent;
  border-color: var(--earth) transparent transparent transparent;
}

.lang-select-selected:hover:after {
  border-color: var(--plum) transparent transparent transparent;
  color: var(--plum);
}

/*point the arrow upwards when the select box is open (active):*/
.lang-select-selected.select-arrow-active:hover:after,
.lang-select-selected.select-arrow-active:focus:after {
  border-color: transparent transparent var(--plum) transparent;
}

.lang-select-selected.select-arrow-active:after {
  border-color: transparent transparent var(--earth) transparent;
  top: 30%;
}

/*style the items (options), including the selected item:*/
.lang-select-items div,
.lang-select-selected {
  color: var(--plum);
  padding: 0.5rem 1rem 0.5rem 1rem;
  /* border: 1px solid var(--earth); */
  /* border-color: transparent transparent rgba(0, 0, 0, 0.1) transparent; */
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  width: 20rem;
  height: 4rem;
  display: flex;
  align-items: center;
  font-size: 1rem;
  font-weight: 600;
}

.lang-select-selected {
  border-radius: 1000px;
  justify-self: center;
}

/*style items (options):*/
.lang-select-items {
  position: absolute;
  background-color: var(--earth);
  bottom: 120%;
  left: 0;
  right: 0;
  z-index: 99;
  border-radius: 1rem;
}

/*hide the items when the select box is closed:*/
.select-hide {
  display: none;
}

.lang-select-items div {
  padding: 0.5rem 2rem;
  width: 100%;
}

.lang-select-items div:hover,
.same-as-selected {
  background-color: rgba(0, 0, 0, 0.1);
}

.lang-select-items div span svg {
  width: 10px;
  height: 10px;
}

.bar-container {
  display: flex;
  gap: 1rem;
  align-items: center;
  justify-content: space-between;
}

.button-continue {
  padding: 0.5rem 1rem 0.5rem 1rem;
  width: -moz-max-content;
  width: max-content;
  height: 3rem;
  font-size: 1rem;
  background-color: var(--atomicYellow);
}

.button-continue:hover {
  border: 1px solid var(--earth);
}

.submit-button {
  background: none;
  border: none;
}

.button-container {
  align-items: center;
  display: flex;
  gap: 0.8rem;
}

.language-bar {
  min-height: 10rem;
  background-color: var(--plum);
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 2rem 0rem;
  transition: all ease-in-out 0.3s;
}

.language-bar.close-bar {
  top: -120%;
  transition: all ease-in-out 0.3s;
}

.title-and-icon {
  display: flex;
  gap: 0.8rem;
  align-items: center;
  justify-content: start;
}

.title-content--bar {
  font-size: 1.2rem;
  color: var(--atomicYellow);
  margin: 0rem;
  font-weight: 600;
  text-align: start;
}

.description-banner a,
.description-banner p {
  font-size: 1rem;
  color: var(--earth);
  margin: 0rem;
}

.title-and-icon svg path {
  fill: var(--atomicYellow);
}

.title-and-icon img {
  width: 30px;
}

.description-banner {
  margin-top: 1rem;
}

.close-button {
  padding: 0.25rem;
  border: 1px solid var(--earth);
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 1000px;
  cursor: pointer;
}

.close-button svg {
  width: 0.6rem;
  height: 0.6rem;
  fill: var(--earth);
}

.close-button svg path {
  fill: var(--earth);
  stroke: var(--earth);
}

.site-footer--social {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 2em;
}
@media (max-width: 767px) {
  .site-footer--social {
    flex-direction: column;
  }
}

.lang-select-selected {
  background-color: transparent;
  border: 1px solid var(--earth);
  color: var(--earth);
  transition: all ease-in-out 0.3s;
}

.lang-select-selected:hover,
.lang-select-selected:focus {
  background-color: var(--earth);
  border: 1px solid var(--earth);
  transition: all ease-in-out 0.3s;
  color: var(--plum);
}

.lang-select-selected span svg {
  height: 10px;
  width: 10px;
}

@media screen and (min-width: 768px) and (max-width: 991px) {
  .lang-select-items div, .lang-select-selected {
    padding: 0.5rem 1rem 0.5rem 1rem;
  }
  .button-container {
    gap: 1rem;
  }
  .button-continue {
    padding: 0.5rem 2rem 0.5rem 2rem;
  }
  .trp-ls-shortcode-current-language {
    min-width: 158px !important;
  }
}
@media screen and (min-width: 768px) {
  .language-bar--mobile {
    display: none;
  }
  .country-selector-selected {
    min-width: 168px !important;
  }
}
@media screen and (max-width: 767px) {
  .language-bar {
    display: none;
  }
  .language-bar--mobile {
    margin-top: 2em;
  }
  .bar-container.footer-lang {
    flex-direction: row;
    width: 100%;
  }
  .bar-container.footer-lang .trp_language_switcher_shortcode,
  .bar-container.footer-lang .site-footer--dropdown {
    width: 50%;
  }
  .country-selector-container,
  .trp-language-switcher,
  .trp-ls-shortcode-current-language {
    width: 100% !important;
  }
}
.search-bar {
  display: none;
  opacity: 0;
  position: absolute;
  z-index: 900;
  width: 100%;
  height: 105%;
  left: 0px;
  top: 50%;
  transform: translate(0, -50%);
  border: none;
  padding: 10px 10px;
  transition: all 0.3s ease;
}

.search-bar-mobile {
  display: none;
  opacity: 0;
  position: absolute;
  z-index: 900;
  width: 100%;
  height: 98px;
  left: 0px;
  border: none;
  padding: 1.2rem 1rem;
  transition: all 0.3sease;
  background-color: var(--earth);
  top: 0px;
  border-radius: 0rem 0rem 0rem 1rem;
}
@media (max-width: 991px) {
  .search-bar-mobile {
    display: none;
    opacity: 0;
  }
}

#searchBar.active {
  display: block;
  opacity: 1;
  transition: all 0.3s ease;
}
@media (max-width: 991px) {
  #searchBar.active {
    display: none;
    opacity: 0;
    transition: all 0.3s ease;
  }
}

@media (max-width: 991px) {
  #searchBarMobile.active {
    display: block;
    opacity: 1;
  }
}

.input-search:focus-visible {
  outline: none;
}

.input-search--content {
  height: 100%;
}

.input-search--content form {
  height: 100%;
  position: relative;
}

.input-search {
  width: 90%;
  height: 100%;
  border-radius: 100px;
  padding: 0rem 2rem;
  border: 1px solid var(--plum);
  color: var(--plum);
  background-color: var(--earth);
}

.submit-search {
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translate(0, -48%);
  height: 75%;
  padding: 0px 20px;
  background-color: var(--plum);
  color: var(--earth);
  border: none;
  border-radius: 100px;
}

.search-bar-mobile .submit-search-mobile {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translate(0, -50%);
  height: 40px;
  padding: 0px 10px;
  background-color: var(--plum);
  color: var(--earth);
  border: none;
  border-radius: 1000px;
  display: flex;
  justify-content: center;
  align-items: center;
}

.search-bar-mobile .input-search {
  width: 80%;
  height: 100%;
  border-radius: 100px;
  padding: 0rem 2rem;
  border: 1px solid var(--plum);
  color: var(--plum);
  background-color: var(--earth);
}
@media (max-width: 991px) {
  .search-bar-mobile .input-search {
    width: 91%;
  }
}
@media (max-width: 767px) {
  .search-bar-mobile .input-search {
    width: 89%;
  }
}
@media (max-width: 568px) {
  .search-bar-mobile .input-search {
    width: 82%;
  }
}

.submit-search svg {
  width: 20px;
  height: auto;
}

.submit-search-mobile svg {
  width: 20px;
  height: auto;
}

.close-search--btn {
  position: absolute;
  width: 40px;
  height: 40px;
  z-index: 909090;
  background-color: var(--earth);
  left: -50px;
  border-radius: 1000px;
  display: flex;
  justify-content: center;
  align-items: center;
  top: 50%;
  transform: translate(0px, -50%);
  cursor: pointer;
}

.close-search--btn-mobile {
  position: absolute;
  width: 26px;
  height: 26px;
  z-index: 909090;
  background-color: var(--earth);
  left: 25px;
  border-radius: 1000px;
  display: flex;
  justify-content: center;
  align-items: center;
  bottom: -38px;
  cursor: pointer;
}

.location--search {
  position: absolute;
  bottom: -60px;
  transition: all 0.3s ease;
  display: flex;
  right: 0;
  background-color: var(--plum);
  padding: 10px 20px;
  gap: 0.5rem;
  align-items: center;
  justify-content: center;
  border-radius: 1000px;
}
@media (max-width: 991px) {
  .location--search {
    position: absolute;
    bottom: -40px;
    transition: all 0.3s ease;
    display: flex;
    right: 0;
    background-color: var(--plum);
    padding: 10px 20px;
    gap: 0.5rem;
    align-items: center;
    justify-content: center;
    border-radius: 0px 0px 30px 10px;
  }
}
@media (max-width: 767px) {
  .location--search {
    position: absolute;
    bottom: -50px;
    transition: all 0.3s ease;
    display: flex;
    right: 0;
    background-color: var(--plum);
    padding: 10px 20px;
    gap: 0.5rem;
    align-items: center;
    justify-content: center;
    border-radius: 0px 0px 30px 10px;
  }
}

.location--search:hover {
  cursor: pointer;
}

.location--search.on-button {
  position: fixed;
  bottom: -1000px;
  z-index: 909190;
  transition: all 0.3s ease;
  display: flex;
  width: -moz-min-content;
  width: min-content;
  padding: 10px 10px;
  right: 30px;
  border-radius: 1000px;
  height: 3rem;
}

.location--icon {
  display: flex;
  border-radius: 100px;
  width: -moz-max-content;
  width: max-content;
  padding: 10px 10px;
  gap: 0.5rem;
  align-items: center;
  justify-content: center;
}

.search-loading {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px 10px;
}

.search-loading-mobile {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px 10px;
}

.location--search.on-button.active {
  bottom: 20px;
  transition: all 0.3s ease;
}

.location--search img {
  width: 30px;
}

.location--search p {
  color: var(--earth);
  font-size: 0.8rem;
  font-weight: 500;
  margin-top: 0px;
}

.close-search--btn svg,
.close-search--btn--at-mobile svg {
  width: 1.8rem;
  height: 1.8rem;
  fill: var(--plum);
  padding: 6px;
  border: 1px solid var(--plum);
  border-radius: 100px;
}

.close-search--btn svg path,
.close-search--btn--at-mobile svg path {
  fill: var(--plum);
  stroke: var(--plum);
}

.close-search--btn-mobile svg,
.close-search--btn--at-mobile svg {
  width: 1.2rem;
  height: 1.2rem;
  fill: var(--plum);
  padding: 2px;
  border: 1px solid var(--plum);
  border-radius: 100px;
}

.close-search--btn-mobile svg path,
.close-search--btn--at-mobile svg path {
  fill: var(--plum);
  stroke: var(--plum);
}

.show--card-content {
  background-color: var(--earth);
  margin-top: 1rem;
  padding: 1rem;
  border-radius: 10px;
  z-index: 909099;
  position: absolute;
  height: -moz-max-content;
  height: max-content;
  display: none;
  opacity: 0;
  transition: all 0.3s ease;
  min-width: 100%;
  width: -moz-fit-content;
  width: fit-content;
  right: 0;
}
@media (max-width: 991px) {
  .show--card-content {
    margin-top: 2rem;
  }
}

.show--card-content.active {
  display: flex;
  justify-content: center;
  align-items: center;
  opacity: 1;
  transition: all 0.3s ease;
}
@media (max-width: 991px) {
  .show--card-content.active {
    height: 80vh;
    overflow: scroll;
  }
}

.show--card-content-mobile {
  background-color: var(--earth);
  margin-top: 1rem;
  padding: 1rem;
  border-radius: 10px;
  z-index: 909099;
  position: relative;
  height: -moz-max-content;
  height: max-content;
  display: none;
  opacity: 0;
  transition: all 0.3s ease;
}
@media (max-width: 991px) {
  .show--card-content-mobile {
    margin-top: 2rem;
  }
}

.show--card-content-mobile.active {
  display: block;
  opacity: 1;
  transition: all 0.3s ease;
}
@media (max-width: 991px) {
  .show--card-content-mobile.active {
    height: 60vh;
    overflow: scroll;
  }
}

.list--content-update {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
}
@media (max-width: 991px) {
  .list--content-update {
    grid-template-columns: repeat(2, 1fr);
  }
}

.list--content-update-mobile {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
}
@media (max-width: 991px) {
  .list--content-update-mobile {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (max-width: 767px) {
  .list--content-update-mobile {
    grid-template-columns: repeat(2, 1fr);
  }
}

.list--item-link {
  text-decoration: none !important;
}

.link--title {
  text-decoration: none;
}

.link--title h6,
.link--title p {
  text-decoration: none;
}

.list--item {
  padding: 0rem;
  /* border: solid .5px var(--plum); */
  border-radius: 8px;
  transform: scale(1);
}

.list--item:hover,
.list--item:focus {
  transform: scale(1.05);
}

.list--item-mobile {
  padding: 0rem;
  /* border: solid .5px var(--plum); */
  border-radius: 8px;
  transform: scale(1);
}

.list--item-mobile:hover,
.list--item-mobile:focus {
  transform: scale(1.05);
}

.hover--thumbnail {
  aspect-ratio: 4/3;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center;
     object-position: center;
  width: 146px;
}

.hover--thumbnail-mobile {
  width: 100%;
  aspect-ratio: 4/3;
  -o-object-fit: cover;
     object-fit: cover;
}

.search-results-page {
  padding-bottom: 4rem;
}

.link--title,
.link--title-mobile {
  text-decoration: none;
  transition: all 0.3s ease;
}

.link--title:hover,
.link--title-mobile:hover {
  text-decoration: none;
  transition: all 0.3s ease;
}

.title--search {
  font-size: 1rem;
  font-weight: 600;
  margin-top: 0rem;
  line-height: normal;
  text-decoration: none;
  text-underline: none;
}

.title--search-mobile {
  font-size: 1rem;
  font-weight: 600;
  margin-top: 0rem;
  line-height: normal;
  text-decoration: none;
}

.desc--search {
  font-size: 0.8rem;
  font-weight: 400;
  letter-spacing: 0px;
  margin-top: 0.5rem;
  line-height: normal;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 3; /* Limits to 3 lines */
  -webkit-box-orient: vertical;
  text-decoration: none;
}

.desc--search-mobile {
  font-size: 0.8rem;
  font-weight: 400;
  letter-spacing: 0px;
  margin-top: 0.5rem;
  line-height: normal;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 3; /* Limits to 3 lines */
  -webkit-box-orient: vertical;
  text-decoration: none;
}

.search-results-grid {
  display: grid;
  gap: 2rem;
  margin-top: 2rem;
  position: relative;
  z-index: 1000;
}

.page-header .page-title {
  font-size: 2rem;
  font-weight: 600;
  text-decoration: none;
  line-height: normal;
}
@media (max-width: 767px) {
  .page-header .page-title {
    font-size: 1.5rem;
  }
}

.page-header .page-title-searchbar {
  font-size: 2rem;
  font-weight: 400;
  text-decoration: none;
  line-height: normal;
}
@media (max-width: 767px) {
  .page-header .page-title-searchbar {
    font-size: 1.5rem;
  }
}

.page-header .page-title-searchbar span {
  font-weight: 600;
}

.search-result-content {
  display: grid;
  grid-template-columns: 40% 50% repeat(2, 1fr);
  gap: 3rem;
  width: 100%;
}
@media (max-width: 767px) {
  .search-result-content {
    grid-template-columns: 1fr;
    gap: 1rem;
  }
}

.search-thumbnail img {
  width: 100%;
  max-width: 320px;
  height: auto;
  -o-object-fit: cover;
  object-fit: cover;
  aspect-ratio: 16/9;
  object-fit: cover;
}

.entry-header .entry-title,
.entry-header .entry-title a {
  font-size: 2rem;
  line-height: normal;
  margin-top: 0;
  text-decoration: none;
}
@media (max-width: 767px) {
  .entry-header .entry-title,
  .entry-header .entry-title a {
    line-height: normal;
    font-size: 1.8rem;
  }
}

.entry-header .entry-title a:hover {
  text-decoration: underline;
}

.post-meta {
  display: flex;
  gap: 0.8rem;
  margin-top: 1rem;
}

.post-type-label {
  font-size: 1rem;
  font-weight: 600;
  margin-bottom: 0.5rem;
}
@media (max-width: 767px) {
  .post-type-label {
    font-size: 1rem;
  }
}

.post-date {
  font-size: 1rem;
  font-weight: 600;
  margin-bottom: 0.5rem;
}
@media (max-width: 767px) {
  .post-date {
    font-size: 1rem;
  }
}

.entry-summary p {
  margin-top: 1rem;
  font-size: 1rem;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
}

.pagination-search {
  display: block;
  margin-top: 2rem;
  position: relative;
  z-index: 1000;
}

.nav-links {
  gap: 1rem;
}

.nav-links .page-numbers {
  font-size: 1rem;
  text-decoration: none;
  font-weight: 600;
}

.page-numbers.current {
  font-weight: 400;
}

.next.page-numbers {
  font-weight: 600;
}

.no-results-message p {
  margin-top: 0.4rem;
}

.header-nav {
  display: flex;
  flex-direction: column;
  height: 72px;
  border-radius: 36px;
  padding: 12px;
  display: flex;
  justify-content: center;
  position: relative;
  background-color: var(--earth);
  border: 1px solid var(--earth);
}

body:has(main.earth-bg) .header-nav,
body:has(main.earth-bg) .sub-menu:before,
body:has(main.earth-bg) .sub-menu {
  border: 1px solid var(--plum);
  transition: 0.3s ease-in-out;
}

body:has(main.earth-bg) .header-bg .header-nav {
  border-color: transparent;
}

body:has(main.earth-bg) .sub-menu:after {
  width: 40px;
  height: 15px;
  position: absolute;
  top: 0;
  left: 10%;
  width: 80%;
}

@media (max-width: 991px) {
  body.menu-open .header-nav {
    display: flex;
  }
  body.menu-open .site-header--home-link svg path {
    fill: var(--atomicYellow);
  }
}
.header-nav ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  gap: 5px;
  align-items: center;
}
@media (max-width: 991px) {
  .header-nav ul {
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: 100%;
    background-color: var(--plum);
    z-index: -1;
    flex-direction: column;
    padding-top: 153px;
    display: block;
    padding-inline: clamp(2rem, -0.21rem + 9.4vw, 8.25rem);
    opacity: 0;
    pointer-events: none;
  }
}

@media (max-width: 991px) {
  .menu-open .header-nav ul {
    opacity: 1;
    pointer-events: all;
  }
}

.header-nav li {
  margin: 0;
  position: relative;
}

@media (min-width: 992px) {
  .header-nav li.menu-item-has-children:after {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background-color: red;
    height: 90px;
    opacity: 0;
    pointer-events: none;
  }
}
@media (min-width: 992px) {
  .header-nav li.menu-item-has-children:hover ul {
    opacity: 1;
    pointer-events: all;
    transform: translateY(calc(100% + 40px)) translateX(-50%);
  }
}
.header-nav li.menu-item-has-children:hover:after {
  pointer-events: all;
}

@media (max-width: 991px) {
  .header-nav li.menu-item-has-children > a {
    pointer-events: none;
    gap: 20px;
  }
  .header-nav li.menu-item-has-children > a span:first-child {
    flex: 1;
  }
  .header-nav li.menu-item-has-children > a span {
    display: block;
  }
  .header-nav li.menu-item-has-children > a span.mobile-button {
    display: flex;
    justify-content: center;
    width: 24px;
    height: 24px;
    margin-top: 6px;
  }
}

@media (max-width: 991px) {
  .menu-open li.menu-item-has-children > a span {
    pointer-events: all;
  }
}

.header-nav li a {
  position: relative;
  z-index: 90001;
  border: 0;
  font-size: 16px;
  font-weight: 500;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: transparent;
  padding: 0 20px;
  color: var(--plum);
  border-radius: 24px;
  transition: all 0.3s ease-in-out;
  text-decoration: none;
}
.header-nav li a span.mobile-button {
  display: none;
}
@media (max-width: 991px) {
  .header-nav li a {
    color: var(--earth);
    display: block;
    padding: 16px 0;
    height: auto;
    font-size: clamp(1.75rem, 1.64rem + 0.4vw, 2rem);
    line-height: clamp(2.25rem, 2.14rem + 0.4vw, 2.5rem);
    font-weight: 400;
    border-bottom: 1px solid var(--earth);
    border-radius: 0;
    display: flex;
    justify-content: space-between;
  }
}

.header-nav li:hover a {
  background-color: var(--plum);
  color: var(--white);
}

@media (min-width: 992px) {
  .header-nav li.current-menu-item a,
  .header-nav li.current-menu-parent a,
  .header-nav li.current_page_parent a {
    background-color: var(--plum);
    color: var(--white);
  }
}

.header-nav ul.sub-menu {
  position: absolute;
  display: block;
  background-color: var(--earth);
  width: 236px;
  bottom: 0;
  left: 50%;
  border-radius: 8px;
  padding: 20px;
  transform: translateY(calc(100% + 60px)) translateX(-50%);
  opacity: 0;
  pointer-events: none;
  transition: all 0.3s ease-in-out;
}
@media (min-width: 992px) {
  .header-nav ul.sub-menu:before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translate3d(-50%, -50%, 0) rotate(45deg);
    background-color: var(--earth);
    width: 12px;
    height: 12px;
  }
}
@media (max-width: 991px) {
  .header-nav ul.sub-menu {
    position: static;
    opacity: 1;
    transform: none;
    background-color: transparent;
    width: 100%;
    padding: 0;
    margin-bottom: 20px;
    display: none;
    pointer-events: all;
  }
}
.header-nav ul.sub-menu a:hover,
.header-nav ul.sub-menu .current-menu-item a:hover,
.header-nav ul.sub-menu .current-menu-item a:focus {
  text-decoration: underline;
}

@media (max-width: 991px) {
  .header-nav .active ul.sub-menu {
    display: block;
  }
}
.header-nav ul.sub-menu li {
  margin-top: 12px;
}
.header-nav ul.sub-menu li:first-child {
  margin-top: 0;
}
@media (max-width: 991px) {
  .header-nav ul.sub-menu li {
    margin-top: 0;
  }
  .header-nav ul.sub-menu li:last-child a {
    border-bottom: 0;
  }
}

.header-nav ul.sub-menu li a {
  padding: 0;
  background-color: transparent;
  border-radius: 0;
  color: var(--plum);
  height: auto;
  display: block;
}
@media (max-width: 991px) {
  .header-nav ul.sub-menu li a {
    color: var(--earth);
    padding: 20px 0;
    font-size: 16px;
    font-weight: 600;
  }
}

@media (min-width: 992px) {
  .menu-header-container {
    z-index: 10;
  }
}
@media (max-width: 991px) {
  .menu-header-container {
    z-index: -1;
  }
}

.bg-diamond {
  position: relative;
}

.bg-diamond::before {
  content: "";
  background-image: url(../img/plum-bg-image.webp);
  opacity: 1;
}

.bg-diamond::before {
  display: block;
  position: absolute;
  top: -105px;
  left: 0;
  width: 100%;
  height: 100%;
  background-repeat: repeat-y;
  background-size: 100%;
  z-index: 1;
}

.with-bg-diamond {
  z-index: 100;
  position: relative;
}

.post-navigation {
  display: flex;
  justify-content: space-between;
  border-top: 1px solid var(--plum);
  padding-top: 24px;
  padding-bottom: clamp(1.5rem, 0.69rem + 3.4vw, 3.75rem);
  position: relative;
  z-index: 2;
}

.post-navigation a {
  text-decoration: none;
  display: flex;
  align-items: center;
}
.post-navigation a svg {
  margin-right: 24px;
}
@media (max-width: 767px) {
  .post-navigation a span {
    display: none;
  }
}

.post-navigation .next-post a svg {
  margin-right: 0;
  margin-left: 24px;
}

.footer-nav ul {
  margin: 0;
  padding: 0;
  display: flex;
  list-style: none;
  gap: clamp(0rem, -1.565rem + 6.6vw, 4.375rem);
}
@media (max-width: 767px) {
  .footer-nav ul {
    flex-direction: column;
    gap: 20px;
  }
}

.footer-nav li {
  margin: 0;
  font-size: 16px;
}

.footer-nav a {
  color: var(--earth);
  text-decoration: none;
}

#menu-footer li ul {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  align-items: space-around;
  gap: 12px;
  margin-top: 1rem;
  position: relative;
}
#menu-footer li ul:hover {
  text-decoration: underline;
}

#menu-footer li a {
  font-size: 1.2rem;
}

#menu-footer li ul li a {
  font-size: 1rem;
  font-weight: 400;
}

#menu-footer-addon,
#menu-footer-addon-1 {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-top: 2rem;
  width: -moz-max-content;
  width: max-content;
  text-decoration: none;
  padding: 0rem;
  color: var(--earth);
}

#menu-footer-addon li,
#menu-footer-addon-1 li {
  text-decoration: none;
  list-style: none;
  display: flex;
  margin-bottom: 0rem;
}

#menu-footer-addon li a,
#menu-footer-addon-1 li a {
  font-size: 1rem;
  font-weight: 400;
  color: var(--earth);
  text-decoration: none;
}

#menu-footer-addon li a:hover,
#menu-footer-addon li a:active,
#menu-footer-addon-1 li a:hover,
#menu-footer-addon-1 li a:active {
  text-decoration: underline;
}

.menu-bottom--footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 0em;
  position: relative;
}

.footer-addon-nav {
  display: block;
  margin-top: 4em;
}

.footer-addon-nav #menu-footer-addon li a,
.footer-addon-nav #menu-footer-addon-1 li a {
  font-size: 0.6rem;
}

.footer-addon-nav.on-mobile {
  display: none;
}

.title:hover, .link--title-mobile:hover {
  text-decoration: none;
}

/* Responsive              --- */
@media (max-width: 767px) {
  .blueprint--button {
    padding: 0.5em 1em;
  }
  .blog-post-block--meta {
    flex-direction: column;
  }
  .svg.cta-mask-mobile {
    bottom: -40px;
  }
  .location-card h3 {
    gap: 1em;
  }
  .blog-post--grid-title {
    gap: 1em;
  }
  .blog-post-block--meta {
    align-items: flex-start;
  }
}
