/*
* ==============================================
CARD BADGE
* ==============================================
*/
.card-badge {
  font-size: 1rem;
  line-height: 1.1875;
  padding: 0.375rem 1rem 0.4375rem;
  background-color: rgba(2, 11, 26, 0.5);
  backdrop-filter: blur(20px) brightness(120%);
  font-weight: 500;
  border-radius: 999px;
  color: white;
}

/*
* ==============================================
HERO FULLSCREEN
* ==============================================
*/
section.hero.hero-fullscreen {
  height: 0;
  min-height: 100vh;
  min-height: 100svh;
  color: var(--c-white);
}

section.hero.hero-fullscreen[data-with-filters="true"] {
  min-height: 78vh;
  min-height: 78svh;
}

section.hero.hero-fullscreen .layers {
  height: 100%;
}

section.hero.hero-fullscreen .layers .layer.layer-bg::after {
  background: linear-gradient(to right, black, transparent);
  opacity: 0.6;
  max-width: 75%;
}

section.hero.hero-fullscreen .layers .layer.layer-bg .img-wrapper {
  height: 100%;
}

section.hero.hero-fullscreen .layers .layer.layer-fg .container {
  height: 100%;
}

section.hero.hero-fullscreen .layers .layer.layer-fg .text {
  height: 100%;
  display: grid;
  align-items: center;
}

section.hero.hero-fullscreen .layers .layer.layer-fg .text .text-wrapper {
  display: grid;
  gap: 0.75rem;
}

@media only screen and (max-width: 768px) {
  section.hero.hero-fullscreen[data-with-filters="true"] {
    min-height: 75vh;
    min-height: 75svh;
  }

  section.hero.hero-fullscreen[data-with-filters="true"] .layers .layer.layer-fg .text {
    align-items: end;
    padding-bottom: calc((-1 * var(--offer-filters-offset)) + 3.75rem);
  }

  section.hero.hero-fullscreen .layers .layer.layer-fg .text .text-wrapper {
    gap: 0.75rem;
    text-align: center;
  }
}

/*
* ==============================================
CARD OFFER
* ==============================================
*/

article.card.card-offer .card-offer-availability {
	margin-top: 0.75rem;
    margin-bottom: 0.45rem;
    text-transform: uppercase;
    font-size: 0.9375rem;
    font-weight: 500;
}

article.card.card-offer .card-offer-availability.red {
	color: #c00;
}

article.card.card-offer .card-offer-availability.orange {
	color: #C76E00
}

article.card.card-offer .card-offer-availability.yellow {
	color: #8B8000
}

article.card.card-offer .card-offer-availability.green {
	color: #008000
}

article.card.card-offer .card-offer-thumbnail {
  margin-bottom: 0.5rem;
  position: relative;
}

article.card.card-offer .card-offer-thumbnail .badges {
  display: flex;
  gap: 0.625rem;
  flex-wrap: wrap;
  position: absolute;
  top: 1.25rem;
  left: 1.25rem;
}

article.card.card-offer .card-offer-thumbnail .img-wrapper {
  padding-bottom: 113.924051%;
  border-radius: 1rem;
  display: block;
}

article.card.card-offer .card-offer-thumbnail .img-wrapper img {
  transition: transform 0.3s ease;
}

article.card.card-offer .card-offer-thumbnail .img-wrapper:hover img {
  transform: scale(1.05);
}

article.card.card-offer .card-offer-title {
  margin-bottom: 0.625rem;
}

article.card.card-offer .card-offer-departures {
  margin-bottom: 0.625rem;
}

/*
* ==============================================
CARDS SWIPER
* ==============================================
*/

section.cards-swiper .layers .layer.layer-bg .img-wrapper {
  height: 100%;
}

section.cards-swiper .layers .layer.layer-bg .img-wrapper > img {
  mask-image: linear-gradient(transparent 40%, black 65%);
}

section.cards-swiper .layers .layer.layer-fg {
  padding-top: 7.8rem;
  padding-bottom: 9.375rem;
}

section.cards-swiper .layers .layer.layer-fg .zones .zone.zone-head {
  text-align: center;
  margin-bottom: 3.125rem;
}

section.cards-swiper .layers .layer.layer-fg .zones .zone.zone-head .subtitle {
  margin-top: 0.625rem;
}

section.cards-swiper .layers .layer.layer-fg .zones .zone.zone-cards {
  position: relative;
}

section.cards-swiper .layers .layer.layer-fg .zones .zone.zone-cards .swiper {
  width: 0;
  min-width: 100%;
}

section.cards-swiper[data-card-type="offer"] .layers .layer.layer-fg .zones .zone.zone-cards {
  --slide-max-width: 14.8125rem;
  --slide-height: 16.875rem; /* used only to center arrows */
}

section.cards-swiper[data-card-type="inclusive"] .layers .layer.layer-fg .zones .zone.zone-cards {
  --slide-max-width: 18.875rem;
  --slide-height: 25rem; /* used only to center arrows */
}

section.cards-swiper[data-card-type="inclusive"] .layers .layer.layer-fg .zones .zone.zone-cards .swiper-slide {
  height: auto;
}

section.cards-swiper[data-card-type="inclusive"] .layers .layer.layer-fg .zones .zone.zone-cards .swiper-slide .card {
  height: 100%;
}

section.cards-swiper .layers .layer.layer-fg .zones .zone.zone-cards .swiper .swiper-wrapper .swiper-slide {
  max-width: var(--slide-max-width);
}

section.cards-swiper .layers .layer.layer-fg .zones .zone.zone-cards .swiper .swiper-pagination {
  --swiper-pagination-bullet-horizontal: 5px;
  --swiper-pagination-bullet-inactive-opacity: 0.3;
  --swiper-pagination-color: var(--c-black);
  --swiper-pagination-bullet-inactive-color: var(--c-black);
  line-height: 0;
  position: static;
  margin-top: 3rem;
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
  background-color: #f8f8f8;
  border-radius: 999px;
  padding: 6px;
}

section.cards-swiper .layers .layer.layer-fg .zones .zone.zone-cards .swiper .swiper-pagination > :first-child {
  margin-left: 0;
}

section.cards-swiper .layers .layer.layer-fg .zones .zone.zone-cards .swiper .swiper-pagination > :last-child {
  margin-right: 0;
}

section.cards-swiper .layers .layer.layer-fg .zones .zone.zone-cards .swiper-navigation {
  position: absolute;
  top: calc(var(--slide-height) / 2);
  left: 0;
  transform: translateY(-50%);
  display: flex;
  justify-content: space-between;
  z-index: 1;
  width: 100%;
  pointer-events: none;
}

@supports (width: min(100px, 80%)) {
  section.cards-swiper .layers .layer.layer-fg .zones .zone.zone-cards .swiper-navigation {
    width: min(90rem - 1.625rem, 100vw - (2 * var(--container-x-padding)));
    translate: -50%;
    left: 50%;
  }
}

section.cards-swiper .layers .layer.layer-fg .zones .zone.zone-cards .swiper-navigation > button {
  display: grid;
  place-items: center;
  pointer-events: auto;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 0.5rem;
  background-color: var(--c-accent);
  position: relative;
  margin: 0;
  inset: unset;
  transition: background-color 0.3s ease;
}

section.cards-swiper .layers .layer.layer-fg .zones .zone.zone-cards .swiper-navigation > button:disabled {
  background-color: var(--c-accent-light);
  opacity: 1;
}

section.cards-swiper .layers .layer.layer-fg .zones .zone.zone-cards .swiper-navigation > button svg {
  color: white;
  transition: color 0.3s ease;
  height: 0.625rem;
}

section.cards-swiper .layers .layer.layer-fg .zones .zone.zone-cards .swiper-navigation > button.swiper-button-next svg {
  transform: rotate(180deg);
}

section.cards-swiper .layers .layer.layer-fg .zones .zone.zone-cards .swiper-navigation > button:disabled svg {
  color: var(--c-accent);
}

section.cards-swiper .layers .layer.layer-fg .zones .zone.zone-cards .swiper-navigation > button::after {
  content: initial;
}

section.cards-swiper .layers .layer.layer-fg .zones .zone.zone-cta {
  margin-top: 3.125rem;
  width: 100%;
}

section.cards-swiper .layers .layer.layer-fg .zones .zone.zone-cta .cta {
  display: flex;
  align-items: center;
}

section.cards-swiper .layers .layer.layer-fg .zones .zone.zone-cta .cta .btn {
  margin-inline: auto;
}

@media (min-width: 768px) {
  section.cards-swiper[data-card-type="offer"].without-swiper .swiper-wrapper {
    justify-content: center;
    position: relative;
    right: -9px;
  }

  section.cards-swiper[data-card-type="offer"].without-swiper .swiper-navigation {
    display: none !important;
  }
}

@media only screen and (max-width: 768px) {
  section.cards-swiper {
    overflow: hidden;
  }

  section.cards-swiper .layers .layer.layer-fg {
    padding-block: 4rem;
  }

  section.cards-swiper .layers .layer.layer-fg .zones .zone.zone-head .title {
    text-wrap: balance;
  }

  section.cards-swiper .layers .layer.layer-fg .zones .zone.zone-head .subtitle {
    margin-top: 0.75rem;
  }

  section.cards-swiper .layers .layer.layer-fg .zones .zone.zone-cards .swiper-navigation {
    display: none;
  }

  section.cards-swiper[data-card-type] .layers .layer.layer-fg .zones .zone.zone-cards {
    --slide-max-width: none;
  }

  section.cards-swiper .layers .layer.layer-fg .zones .zone.zone-cta {
    margin-top: 3.125rem;
  }

  section.cards-swiper .layers .layer.layer-fg .zones .zone.zone-cards .swiper {
    overflow: visible;
  }

  section.cards-swiper .layers .layer.layer-fg .zones .zone.zone-cards .swiper .swiper-pagination {
    margin-top: 1.875rem;
  }
}

/*
* ==============================================
BANNER SWIPER
* ==============================================
*/
section.banner.banner-swiper {
  --pagination-height: 4.25rem;
  height: 0;
  min-height: 70vh;
  min-height: max(70vh, 600px);
}

section.banner.banner-swiper .layers,
section.banner.banner-swiper .layers .layer-bg .swiper,
section.banner.banner-swiper .layers .layer-bg .swiper .swiper-wrapper,
section.banner.banner-swiper .layers .layer-bg .swiper .swiper-wrapper .swiper-slide,
section.banner.banner-swiper .layers .layer-bg .swiper .swiper-wrapper .swiper-slide .img-wrapper,
section.banner.banner-swiper .layers .layer-bg {
  height: 100%;
}

section.banner.banner-swiper .layers .layer-bg {
  width: 100%;
}

section.banner.banner-swiper .layers .layer-bg .swiper {
  width: 0;
  min-width: 100%;
}

section.banner.banner-swiper .layers .layer-bg::after {
  background: linear-gradient(transparent, #000000, transparent);
  opacity: 0.6;
  z-index: 2;
}

section.banner.banner-swiper .layers .layer-fg {
  pointer-events: none;
  color: var(--c-white);
  z-index: 3;
}

section.banner.banner-swiper .layers .layer-fg .container {
  height: 100%;
}

section.banner.banner-swiper .layers .layer-fg .contents {
  height: 100%;
  display: grid;
  grid-template-rows: var(--pagination-height) 1fr var(--pagination-height);
}

section.banner.banner-swiper .layers .layer-fg .contents .text {
  grid-row: 2;
  height: 100%;
  display: grid;
  text-align: center;
  align-content: center;
}

section.banner.banner-swiper .layers .layer-fg .contents .text .cta,
section.banner.banner-swiper .layers .layer-fg .contents .text .subtitle,
section.banner.banner-swiper .layers .layer-fg .contents .text .title {
  pointer-events: auto;
}

section.banner.banner-swiper .layers .layer-fg .contents .text .title {
  max-width: 22.5rem;
  margin-inline: auto;
}

section.banner.banner-swiper .layers .layer-fg .contents .text .subtitle {
  margin-top: 0.75rem;
}

section.banner.banner-swiper .layers .layer-fg .contents .text .cta {
  margin-top: 3.75rem;
}

section.banner.banner-swiper .layers .layer-fg .contents .swiper-pagination {
  --swiper-pagination-bullet-horizontal: 5px;
  --swiper-pagination-bullet-inactive-opacity: 0.3;
  --swiper-pagination-color: var(--c-white);
  --swiper-pagination-bullet-inactive-color: var(--c-white);
  line-height: 0;
  position: static;
  align-self: start;
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
  grid-row: 3;
  pointer-events: auto;
  align-self: center;
}

section.banner.banner-swiper .layers .layer-fg .contents .swiper-pagination > :first-child {
  margin-left: 0;
}

section.banner.banner-swiper .layers .layer-fg .contents .swiper-pagination > :last-child {
  margin-right: 0;
}

section.banner.banner-swiper .layers .layer-fg .swiper-navigation {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  display: flex;
  justify-content: space-between;
  z-index: 1;
  width: 100%;
  pointer-events: none;
}

@supports (width: min(100px, 80%)) {
  section.banner.banner-swiper .layers .layer-fg .swiper-navigation {
    width: min(90rem - 1.625rem, 100vw - (2 * var(--container-x-padding)));
    translate: -50%;
    left: 50%;
  }
}

@media only screen and (max-width: 768px) {
  section.banner.banner-swiper {
    --pagination-height: 6.25rem;
    min-height: 50vh;
    min-height: max(50vh, 420px);
  }

  section.banner.banner-swiper .layers .layer-fg .swiper-navigation {
    display: none;
  }

  section.banner.banner-swiper .layers .layer-fg .swiper-navigation {
    top: auto;
    bottom: 1.875rem;
    transform: none;
  }

  section.banner.banner-swiper .layers .layer-fg .contents .text .subtitle {
    margin-top: 1rem;
  }

  section.banner.banner-swiper .layers .layer-fg .contents .text .cta {
    margin-top: 1.875rem;
  }
}

section.banner.banner-swiper .layers .layer-fg .swiper-navigation > button {
  display: grid;
  place-items: center;
  pointer-events: auto;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 0.5rem;
  background-color: var(--c-accent);
  position: relative;
  margin: 0;
  inset: unset;
  transition: background-color 0.3s ease;
  backdrop-filter: blur(30px) brightness(115%);
}

section.banner.banner-swiper .layers .layer-fg .swiper-navigation > button:disabled {
  background-color: transparent;
  opacity: 1;
}

section.banner.banner-swiper .layers .layer-fg .swiper-navigation > button svg {
  color: white;
  transition: color 0.3s ease;
  height: 0.625rem;
}

section.banner.banner-swiper .layers .layer-fg .swiper-navigation > button.swiper-button-next svg {
  transform: rotate(180deg);
}

section.banner.banner-swiper .layers .layer-fg .swiper-navigation > button::after {
  content: initial;
}

/*
* ==============================================
CARD INCLUSIVE
* ==============================================
*/
article.card.card-inclusive {
  position: relative;
  border-radius: 1rem;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: 0 12px 30px #00000014;
}

article.card.card-inclusive > a {
  position: absolute;
  inset: 0;
  z-index: 2;
}

article.card.card-inclusive .badges {
  position: absolute;
  top: 1.25rem;
  left: 1.25rem;
  z-index: 1;
}

article.card.card-inclusive .card-inclusive-thumbnail .img-wrapper {
  padding-bottom: 82.781457%;
}

article.card.card-inclusive .card-inclusive-text {
  padding: 1.25rem;
  background-color: var(--c-white);
  flex-grow: 1;
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
}

article.card.card-inclusive .card-inclusive-text .price {
  margin-top: auto;
}

/*
* ==============================================
INFOS LISTER
* ==============================================
*/

section.banner-spaced {
  padding-bottom: 9.375rem;
}

section.infos-lister {
  padding-top: 7.9rem;
  padding-bottom: 9.375rem;
}

section.infos-lister .zones {
  display: grid;
  gap: 3.125rem;
  justify-items: center;
}

section.infos-lister .zones .zone.zone-infos {
  width: 100%;
}

section.infos-lister .zones .zone.zone-infos .infos-wrapper {
  display: flex;
  gap: 2rem;
  flex-wrap: wrap;
  justify-content: space-between;
}

section.infos-lister .zones .zone.zone-infos .infos-wrapper .info {
  flex-basis: 12.8125rem;
  display: flex;
  flex-direction: column;
  align-items: center;
}

section.infos-lister .zones .zone.zone-infos .infos-wrapper .info .thumbnail {
  margin-bottom: 1.25rem;
}

section.infos-lister .zones .zone.zone-infos .infos-wrapper .info .thumbnail .img-wrapper {
  width: 7.5rem;
  padding-bottom: 100%;
  border-radius: 50%;
}

section.infos-lister .zones .zone.zone-infos .infos-wrapper .info .text {
  text-align: center;
}

section.infos-lister .zones .zone.zone-infos .infos-wrapper .info .text .title {
  display: block;
}

@media only screen and (max-width: 768px) {
  section.infos-lister {
    padding-block: 4rem;
  }

  section.infos-lister .zones .zone.zone-infos .infos-wrapper {
    display: flex;
    flex-direction: column;
    gap: 3.125rem;
  }

  section.infos-lister .zones .zone.zone-infos .infos-wrapper .info .thumbnail {
    margin-bottom: 1.375rem;
  }

  section.infos-lister .zones .zone.zone-infos .infos-wrapper .info .text .title {
    margin-bottom: 0.625rem;
  }
}

/*
* ==============================================
BANNER SPACED
* ==============================================
*/
section.banner.banner-spaced .layers {
  min-height: 50vh;
  min-height: max(500px, 50vh);
  border-radius: 1rem;
  overflow: hidden;
}

section.banner.banner-spaced .layers .layer-bg::after {
  background-color: black;
  opacity: 0.4;
}

section.banner.banner-spaced .layers .layer-bg .img-wrapper {
  height: 100%;
}

section.banner.banner-spaced .layers .layer-fg .text {
  height: 100%;
  padding: 1.875rem 2.125rem;
  color: var(--c-white);
}

section.banner.banner-spaced .layers .layer-fg .text .text-wrapper {
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  justify-content: space-between;
}

@media (max-width: 767px) {
  section.banner.banner-spaced .layers {
    min-height: 35vh;
    min-height: max(420px, 35vh);
  }

  section.banner.banner-spaced .layers .layer-fg .text {
    padding: 2.5rem 2rem 3.5rem 2rem;
  }
}

/*
* ==============================================
HERO HALF
* ==============================================
*/
section.hero.hero-half .layers .layer-bg::after {
  background: linear-gradient(to right, black, transparent);
  opacity: 0.6;
  max-width: 50%;
}

section.hero.hero-half .layers .layer-bg .img-wrapper {
  height: 100%;
}

section.hero.hero-half .layers .layer-fg {
  padding-top: 1.875rem;
  padding-bottom: 1.875rem;
  color: white;
  min-height: 50vh;
  min-height: max(500px, 50vh);
}

section.hero.hero-half[data-with-filters="true"] .layers .layer-fg {
  padding-bottom: calc(-1 * var(--offer-filters-offset));
}

section.hero.hero-half .layers .layer-fg .container,
section.hero.hero-half .layers .layer-fg .container .text,
section.hero.hero-half .layers .layer-fg .container .text .text-wrapper {
  height: 100%;
}

section.hero.hero-half .layers .layer-fg .container .text .text-wrapper {
  display: grid;
  align-items: start;
  justify-items: start;
  grid-template-rows: auto 1fr auto;
}

section.hero.hero-half .layers .layer-fg .container .text .text-wrapper .breadcrumb {
  align-self: start;
}

section.hero.hero-half .layers .layer-fg .container .text .text-wrapper .title {
  align-self: center;
}

section.hero.hero-half .layers .layer-fg .container .text .text-wrapper .badges {
  align-self: end;
  display: flex;
  align-items: center;
  gap: 0.625rem;
}

section.hero.hero-half[data-with-filters="true"] .layers .layer-fg .container .text .text-wrapper .badges {
  display: none;
}

@media only screen and (max-width: 768px) {
  section.hero.hero-half .layers .layer-bg::after {
    max-width: none;
  }

  section.hero.hero-half .layers .layer-fg {
    min-height: 50vh;
    min-height: max(300px, 50vh);
    text-align: center;
  }

  body.post-type-archive-useful-link section.hero.hero-half .layers .layer-fg,
  body.page-template-contacts section.hero.hero-half .layers .layer-fg,
  body.single-product section.hero.hero-half .layers .layer-fg {
    text-align: left;
  }

  body.post-type-archive-useful-link section.hero.hero-half .layers .layer-fg,
  body.page-template-contacts section.hero.hero-half .layers .layer-fg {
    min-height: 21.875rem;
  }

  section.hero.hero-half .layers .layer-fg .container .text .text-wrapper .title {
    width: 100%;
  }
}

/*
* ==============================================
SINGLE OFFER
* ==============================================
*/
section.single-offer .offer-text-with-icon {
  display: flex;
  align-items: center;
  gap: 0.625rem;
}

section.single-offer .offer-text-with-icon svg {
  color: var(--c-accent);
}

section.single-offer .offer-head {
  padding-top: 3.125rem;
  padding-bottom: 3.125rem;
  display: grid;
  gap: 0.375rem;
  border-bottom: 1px solid rgba(173, 173, 173, 0.3);
}

section.single-offer .offer-head .title {
  display: flex;
  gap: 1rem;
  align-items: end;
}

section.single-offer .offer-head .title .id {
  font-weight: 500;
  margin-bottom: 0.2rem;
}

section.single-offer .offer-head .infos .zones {
  display: flex;
  justify-content: space-between;
  align-items: end;
}

section.single-offer .offer-head .infos .zones .zone-pills {
  display: flex;
  gap: 1rem;
}

section.single-offer .offer-head .infos .zones .zone-pills .pill:has(a svg) {
  padding-top: 0.1875rem;
  padding-bottom: 0.1875rem;
  padding-right: 0.1875rem;
}

section.single-offer .offer-head .infos .zones .zone-pills .pill:has(a svg) a {
  line-height: 0;
}

section.single-offer .offer-head .infos .zones .zone-pills .pill:has(a svg) a svg {
  height: 1.75rem;
  width: 1.75rem;
}

section.single-offer .offer-body {
  padding-top: 3.125rem;
  display: flex;
  justify-content: space-between;
  gap: 2rem;
}

section.single-offer .offer-body article {
  width: 100%;
  max-width: 47.0625rem;
}

section.single-offer .offer-body article .article-section {
  padding-top: 3.125rem;
  padding-bottom: 3.125rem;
  border-bottom: 1px solid rgba(173, 173, 173, 0.3);
}

section.single-offer .offer-body article .article-section:first-child {
  padding-top: 0;
}

section.single-offer .offer-body article .article-section .article-section-head {
  margin-bottom: 1.75rem;
}

section.single-offer .offer-body article .article-section.section-summary .article-section-body ul {
  display: flex;
  flex-direction: column;
  gap: 0.8125rem;
}

section.single-offer .offer-body article .article-section.section-summary .article-section-body ul li {
  display: flex;
  gap: 0.9375rem;
  align-items: center;
}

section.single-offer .offer-body article .article-section.section-summary .article-section-body ul li svg {
  color: var(--c-accent);
}

section.single-offer .offer-body article .article-section.section-on-sale .on-sale {
  padding: 1.875rem;
  border-radius: 1rem;
  background-color: #dfedff;
}

section.single-offer .offer-body article .article-section.section-features {
  display: grid;
  gap: 3.125rem;
}

section.single-offer .offer-body article .article-section.section-features .feature {
  display: flex;
  align-items: center;
  gap: 1.5rem;
}

section.single-offer .offer-body article .article-section.section-features .feature .feature-icon {
  background-color: #f8f8f8;
  border-radius: 1rem;
  display: grid;
  place-items: center;
  padding: 1rem;
  height: 5.125rem;
  width: 5.125rem;
  flex-shrink: 0;
}

section.single-offer .offer-body article .article-section.section-features .feature .feature-icon svg {
  color: var(--c-accent);
}

section.single-offer .offer-body article .article-section.section-features .feature .feature-text {
  display: grid;
  gap: 0.625rem;
}

section.single-offer .offer-body article .article-section.section-features .feature .feature-text .description {
  color: #8b8b8b;
}

section.single-offer .offer-body article .article-section.section-features .feature .feature-text .title {
}

section.single-offer .offer-body article .article-section.section-programs .programs-wrapper {
  display: grid;
  gap: 1.875rem;
}

section.single-offer .offer-body article .article-section.section-programs .programs-wrapper .program .title {
  font-weight: 700;
  text-transform: uppercase;
  margin-bottom: 0.2rem;
}

section.single-offer .offer-body article .article-section.section-infos .article-section-body .infos-wrapper ul {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

@supports (grid-template-columns: subgrid) {
  section.single-offer .offer-body article .article-section.section-infos .article-section-body .infos-wrapper ul {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
  }

  section.single-offer .offer-body article .article-section.section-infos .article-section-body .infos-wrapper ul li {
    grid-column: -1/1;
    display: grid;
    grid-template-columns: subgrid;
    gap: 1rem;
  }
}

@supports not (grid-template-columns: subgrid) {
  section.single-offer .offer-body article .article-section.section-infos .article-section-body .infos-wrapper ul li {
    display: flex;
    gap: 1rem;
  }
}

section.single-offer .offer-body article .article-section.section-infos .article-section-body .infos-wrapper ul li .title {
  text-transform: uppercase;
}

section.single-offer .offer-body article .article-section.section-services .article-section-body .services-wrapper {
  display: grid;
  gap: 1.875rem;
}

section.single-offer .offer-body article .article-section.section-services .article-section-body .services-wrapper .service {
  display: grid;
  gap: 1.25rem;
}

section.single-offer .offer-body article .article-section.section-services .article-section-body .services-wrapper .service .service-title {
  text-transform: uppercase;
}

section.single-offer .offer-body article .article-section.section-services .article-section-body .services-wrapper .service ul {
  display: grid;
  gap: 0.625rem;
}

section.single-offer .offer-body article .article-section.section-services .article-section-body .services-wrapper .service ul li {
  display: flex;
  gap: 0.75rem;
}

section.single-offer .offer-body article .article-section.section-services .article-section-body .services-wrapper .service ul li svg {
  margin-top: 0.1rem;
  flex-shrink: 0;
}

section.single-offer .offer-body article .article-section.section-services .article-section-body .services-wrapper .service.service-included ul li svg {
  color: var(--c-accent);
}

section.single-offer .offer-body article .article-section.section-services .article-section-body .services-wrapper .service.service-excluded ul li svg {
  color: #707070;
}

section.single-offer .offer-body aside {
  max-width: 25.5rem;
  width: 100%;
}

section.single-offer .offer-body aside .cta-sticky {
  display: none;
}

body:has(header.floating.floating-active) section.single-offer .offer-body aside .booking-wrapper,
section.single-offer .offer-body aside .booking-wrapper {
  top: calc(var(--header-height) + 2rem);
  position: sticky;
  transition: top 0.3s ease;
}

body:has(header.floating) section.single-offer .offer-body aside .booking-wrapper {
  top: calc(0px + 2rem);
}

body:has(header.floating.floating-active) section.single-offer .offer-body aside .booking-accordion .booking-accordion-wrapper .booking-accordion-content,
section.single-offer .offer-body aside .booking-accordion .booking-accordion-wrapper .booking-accordion-content {
  padding: 1.875rem;
  border-radius: 1rem;
  box-shadow: 0 12px 30px #00000014;
}

section.single-offer .offer-body aside .booking-accordion .booking-accordion-wrapper .booking-accordion-content {
  padding-bottom: 0.6rem;
}

section.single-offer .offer-body aside .booking-wrapper .booking-accordion .booking-accordion-wrapper .booking-accordion-content .badges {
  display: flex;
  gap: 0.625rem;
  font-weight: wrap;
  margin-bottom: 1.875rem;
}

section.single-offer .offer-body aside .booking-wrapper .booking-accordion .booking-accordion-wrapper .booking-accordion-content .date {
  margin-top: 1.0625rem;
}

section.single-offer .offer-body aside .booking-wrapper .booking-accordion .booking-accordion-wrapper .booking-accordion-content .price {
  margin-top: 0.9375rem;
  margin-bottom: 1.875rem;
}

section.single-offer .offer-body aside .booking-wrapper .booking-accordion .booking-accordion-wrapper .booking-accordion-content .date-selector-container label {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  font-size: 0.875rem;
  line-height: 1.214286;
}

section.single-offer .offer-body aside .booking-wrapper .booking-accordion .booking-accordion-wrapper .booking-accordion-content .date-selector-container select {
  font-size: 1rem;
  line-height: 1.1875;
  padding: 0.875rem 1.25rem 0.9375rem;
  outline: 1px solid #eaeaea;
  border: none;
  border-radius: 0.5rem;
}

section.single-offer .offer-body aside .booking-wrapper .booking-accordion .booking-accordion-wrapper .booking-accordion-content #members-form {
  padding-block: 1.5rem;
  border-top: 1px solid rgba(173, 173, 173, 0.3);
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  row-gap: 1.5rem;
  column-gap: 1rem;
}

section.single-offer .offer-body aside .booking-wrapper .booking-accordion .booking-accordion-wrapper .booking-accordion-content #members-form.variable {
  border-top: 0;
}

section.single-offer .offer-body aside .booking-wrapper .booking-accordion .booking-accordion-wrapper .booking-accordion-content #members-form.variable .room-selector-container {
  grid-column: span 2;
}

section.single-offer .offer-body aside .booking-wrapper .booking-accordion .booking-accordion-wrapper .booking-accordion-content #members-form label {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  font-size: 0.875rem;
  line-height: 1.214286;
}

section.single-offer .offer-body aside .booking-wrapper .booking-accordion .booking-accordion-wrapper .booking-accordion-content #members-form label input {
  width: 100%;
}

section.single-offer .offer-body aside .booking-wrapper .booking-accordion .booking-accordion-wrapper .booking-accordion-content #members-form button[type="submit"] {
  grid-column: -1/1;
}

section.single-offer .offer-body aside .booking-wrapper .booking-accordion .booking-accordion-wrapper .booking-accordion-content #members-form label.full:first-child {
  grid-column: unset;
}

section.single-offer .offer-body aside .booking-wrapper .booking-accordion .booking-accordion-wrapper .booking-accordion-content #open-offer-information-dialog {
  margin-bottom: 1.5rem;
  background-color: black;
  width: 100%;
}

section.single-offer .offer-body aside .booking-wrapper .booking-accordion .booking-accordion-wrapper .booking-accordion-content .cta .btn {
  width: 100%;
}

section.single-offer .offer-body aside .booking-wrapper .booking-accordion .booking-accordion-wrapper .booking-accordion-content .confirmation {
  margin-top: 1rem;
}

section.single-offer .offer-body aside .booking-wrapper .booking-accordion .booking-accordion-wrapper .booking-accordion-content .confirmation[data-confirmed="false"] svg {
  color: var(--c-gray);
}

section.single-offer .offer-body aside .booking-wrapper .booking-accordion .booking-accordion-wrapper .booking-accordion-content .confirmation p {
  justify-content: center;
}

section.single-offer .offer-footer .article-gallery {
  padding: 3.125rem 0;
}

section.single-offer .offer-footer .article-gallery .swiper-scrollbar {
  bottom: 0;
  transform: translateY(50%);
  background-color: rgba(173, 173, 173, 0.3);
  --swiper-scrollbar-size: 3px;
  width: 100%;
  left: 0;
}

section.single-offer .offer-footer .article-gallery .swiper-scrollbar .swiper-scrollbar-drag {
  --swiper-scrollbar-drag-size: 8px;
  height: var(--swiper-scrollbar-drag-size);
  background: var(--c-accent);
  margin-top: calc((var(--swiper-scrollbar-drag-size) / -2) + (var(--swiper-scrollbar-size) / 2));
}

section.single-offer .offer-footer .article-gallery .swiper-wrapper .swiper-slide {
  width: fit-content;
}

section.single-offer .offer-footer .article-gallery .swiper-wrapper .swiper-slide img {
  max-height: 21.875rem;
  width: auto;
  border-radius: 1rem;
  object-fit: cover;
}

section.single-offer .offer-footer .article-gallery {
  position: relative;
}

section.single-offer .offer-footer .article-gallery .swiper-navigation {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  display: flex;
  justify-content: space-between;
  z-index: 1;
  width: 100%;
  pointer-events: none;
}

@supports (width: min(100px, 80%)) {
  section.single-offer .offer-footer .article-gallery .swiper-navigation {
    width: min(90rem - 1.625rem, 100vw - var(--container-x-padding));
    translate: -50%;
    left: 50%;
  }
}

section.single-offer .offer-footer .article-gallery .swiper-navigation > button {
  display: grid;
  place-items: center;
  pointer-events: auto;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 0.5rem;
  background-color: var(--c-accent);
  position: relative;
  margin: 0;
  inset: unset;
  transition: background-color 0.3s ease;
}

section.single-offer .offer-footer .article-gallery .swiper-navigation > button:disabled {
  background-color: var(--c-accent-light);
  opacity: 1;
}

section.single-offer .offer-footer .article-gallery .swiper-navigation > button svg {
  color: white;
  transition: color 0.3s ease;
  height: 0.625rem;
}

section.single-offer .offer-footer .article-gallery .swiper-navigation > button.swiper-button-next svg {
  transform: rotate(180deg);
}

section.single-offer .offer-footer .article-gallery .swiper-navigation > button:disabled svg {
  color: var(--c-accent);
}

section.single-offer .offer-footer .article-gallery .swiper-navigation > button::after {
  content: initial;
}

section.single-offer .offer-head .infos .zones .zone.zone-info {
  display: none;
}

dialog.single-offer {
  margin: auto;
  border: none;
  max-width: 100%;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 9999;
  scale: 1;
  display: flex;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  background-color: transparent;
}

dialog.single-offer .overlay {
  background-color: rgba(0, 0, 0, 0.16);
  backdrop-filter: blur(8px);
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

dialog.single-offer.active {
  opacity: 1;
  visibility: visible;
}

dialog.single-offer .dialog-content {
  padding: 3.125rem;
  border-radius: 1rem;
  background-color: white;
  position: relative;
  max-width: min(45rem, 100% - 2rem);
  margin-top: 2rem;
  max-height: calc(100vh - 4rem);
  overflow: auto;
  box-shadow: 0px 12px 30px #00000014;
}

dialog.single-offer .dialog-content .dialog-closer {
  position: absolute;
  top: 1.25rem;
  right: 1.25rem;
  height: 2.25rem;
  width: 2.25rem;
  display: grid;
  place-items: center;
  background-color: #dfedff;
  border-radius: 99px;
  color: var(--c-accent);
}

dialog.single-offer .dialog-content .title {
  margin-bottom: 2.6875rem;
  text-align: center;
}

dialog.single-offer .dialog-content .form-wrapper p .wpcf7-spinner,
dialog.single-offer .dialog-content .form-wrapper p .wpcf7-response-output,
dialog.single-offer .dialog-content .form-wrapper p br {
  display: none;
}

dialog.single-offer .dialog-content .form-wrapper p {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  column-gap: 1rem;
  row-gap: 2rem;
}

dialog.single-offer .dialog-content .form-wrapper p label {
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
  font-size: 1rem;
  line-height: 1.1875rem;
  font-weight: 500;
}

dialog.single-offer .dialog-content .form-wrapper p > .wide {
  grid-column: -1/1;
}

dialog.single-offer .dialog-content .form-wrapper p label input:not([type="checkbox"]) {
  width: 100%;
}

dialog.single-offer .dialog-content .form-wrapper p label textarea,
dialog.single-offer .dialog-content .form-wrapper p label input {
  background-color: #f8f8f8;
  outline-color: transparent;
  font-weight: 400;
}

dialog.single-offer .dialog-content .form-wrapper p .wpcf7-form-control-wrap .wpcf7-form-control,
dialog.single-offer .dialog-content .form-wrapper p .wpcf7-form-control-wrap {
  display: block;
}

dialog.single-offer .dialog-content .form-wrapper p .wpcf7-form-control-wrap .wpcf7-acceptance .wpcf7-list-item {
  margin-left: 0;
  display: block;
}

dialog.single-offer .dialog-content .form-wrapper p .wpcf7-form-control-wrap .wpcf7-acceptance .wpcf7-list-item label {
  display: flex;
  align-items: center;
  flex-direction: row;
  align-items: center;
}

dialog.single-offer::backdrop {
  backdrop-filter: blur(10px);
  background-color: rgba(255, 255, 255, 0.1);
}

@media print {
  body.single-product section.single-offer ~ *,
  body.single-product section.single-offer .offer-head .infos .zones .zone-pills,
  body.single-product section.single-offer .offer-body aside,
  body.single-product section.single-offer .offer-footer,
  section.single-offer .offer-body article .article-section.section-on-sale,
  body.single-product header,
  body.single-product footer,
  body.single-product .hero {
    display: none;
  }

  body.single-product section.single-offer .offer-body article {
    max-width: none;
  }
}

@media only screen and (max-width: 768px) {
  dialog.single-offer .dialog-content {
    padding: 3.125rem 1.25rem;
  }

  dialog.single-offer .dialog-content .form-wrapper p {
    grid-template-columns: 1fr;
  }

  section.single-offer .offer-body aside .booking-wrapper .booking-accordion .booking-accordion-wrapper .booking-accordion-content .title {
    display: none;
  }

  section.single-offer .offer-body article .article-section {
    padding-top: 2.6rem;
    padding-bottom: 2.6rem;
  }

  dialog.single-offer .dialog-content .form-wrapper button[type="submit"] {
    width: 100%;
  }

  section.single-offer .offer-body article .article-section.section-features {
    display: grid;
    gap: 2.1rem;
  }

  section.single-offer .offer-head {
    padding-top: 3.125rem;
    padding-bottom: 2.625rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
  }

  section.single-offer .offer-head .title {
    display: flex;
    flex-direction: column-reverse;
    align-items: start;
    gap: 1rem;
  }

  section.single-offer .offer-head .title .id {
    margin-bottom: 0;
  }

  section.single-offer .offer-head .infos .zones .zone.zone-info,
  section.single-offer .offer-head .infos .zones .zone.zone-pills,
  section.single-offer .offer-head .infos .zones {
    display: flex;
    flex-direction: column;
    gap: 1.0625rem;
    align-items: start;
  }

  section.single-offer .offer-body article .article-section.section-summary {
    display: none;
  }

  section.single-offer .offer-head .infos .zones .zone.zone-pills {
    margin-top: 0.5rem;
  }

  section.single-offer .offer-head .infos .zones .zone.zone-pills .pill-outline {
    display: none;
  }

  section.single-offer .offer-body {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    padding-top: 0;
  }

  section.single-offer .offer-body aside {
    z-index: 99;
    max-width: none;
    position: fixed;
    bottom: 0;
    padding: 1.125rem var(--container-x-padding);
    background-color: var(--c-white);
    box-shadow: 0 12px 30px #00000014;
    left: 0;
    width: 100%;
  }

  section.single-offer .offer-body aside .booking-wrapper .booking-accordion {
    display: grid;
    grid-template-rows: 0px;
    transition: grid-template-rows 0.15s ease;
    align-content: end;
  }

  section.single-offer .offer-body aside input#booking-accordion:checked ~ .booking-wrapper .booking-accordion {
    grid-template-rows: calc(100svh - 5.125rem);
    grid-template-rows: calc(100dvh - 5.125rem);
  }

  html:has(section.single-offer .offer-body aside input#booking-accordion:checked) body {
    overflow: hidden;
    touch-action: none;
  }

  section.single-offer .offer-body aside .booking-wrapper .booking-accordion .booking-accordion-wrapper {
    overflow: hidden;
    display: grid;
  }

  body:has(header.floating.floating-active) section.single-offer .offer-body aside .booking-accordion .booking-accordion-wrapper .booking-accordion-content,
  section.single-offer .offer-body aside .booking-wrapper .booking-accordion .booking-accordion-wrapper .booking-accordion-content {
    margin-top: 1.125rem;
    border-top: 1px solid rgba(from #adadad r g b / 0.3);
    border-radius: 0;
    box-shadow: none;
    padding-left: 1px;
    padding-right: 1px;
    padding-bottom: 0;
    padding-top: 2rem;
    overflow: auto;
    display: flex;
    flex-direction: column;
  }

  section.single-offer .offer-body aside .booking-wrapper .booking-accordion .booking-accordion-wrapper .booking-accordion-content::-webkit-scrollbar {
    display: none;
  }

  section.single-offer .offer-body aside .booking-wrapper .booking-accordion .booking-accordion-wrapper .booking-accordion-content .badges {
    display: none;
  }

  section.single-offer .offer-body aside .booking-wrapper .booking-accordion .booking-accordion-wrapper .booking-accordion-content .date {
    display: none;
  }

  section.single-offer .offer-body aside .booking-wrapper .booking-accordion .booking-accordion-wrapper .booking-accordion-content .price {
    margin-top: 0rem;
    margin-bottom: 1.1rem;
  }

  section.single-offer .offer-body aside .booking-wrapper .booking-accordion .booking-accordion-wrapper .booking-accordion-content #members-form {
    padding-top: 2rem;
    padding-bottom: 1rem;
    grid-template-rows: auto auto 1fr;
    align-items: start;
    flex-grow: 1;
  }

  section.single-offer .offer-body aside .booking-wrapper .booking-accordion .booking-accordion-wrapper .booking-accordion-content #members-form .btn {
    margin-top: auto;
  }

  section.single-offer .offer-body aside .booking-wrapper .booking-accordion .booking-accordion-wrapper .booking-accordion-content .confirmation {
    margin-top: 0;
  }

  section.single-offer .offer-body aside .cta-sticky {
    display: block;
    position: sticky;
    bottom: 0;
  }

  section.single-offer .offer-body aside .cta-sticky .btn {
    width: 100%;
  }

  section.single-offer .offer-body aside .cta-sticky .btn .btn-icon {
    transform: rotate(90deg);
    transition: transform 0.3s ease;
  }

  section.single-offer .offer-body aside .cta-sticky .btn .btn-icon svg {
    max-height: 9px;
  }

  section.single-offer .offer-body aside input#booking-accordion:checked ~ .cta-sticky .btn .btn-icon {
    transform: rotate(-90deg);
  }

  section.single-offer .offer-body aside input#booking-accordion:checked ~ .cta-sticky .btn.only-closed {
    display: none;
  }

  section.single-offer .offer-body aside input#booking-accordion:not(:checked) ~ .cta-sticky .btn.only-open {
    display: none;
  }

  section.single-offer .offer-body article .article-section.section-on-sale .on-sale {
    padding: 1.25rem 1.875rem;
  }

  section.single-offer .offer-body article .article-section.section-features .feature .feature-icon {
    align-items: start;
  }

  section.single-offer .offer-body article .article-section.section-infos .article-section-body .infos-wrapper ul {
    row-gap: 1.875rem;
  }

  section.single-offer .offer-body article .article-section.section-infos .article-section-body .infos-wrapper ul li {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
  }

  section.single-offer .offer-footer .article-gallery .swiper-navigation {
    display: none;
  }

  section.single-offer .offer-footer .article-gallery .swiper-wrapper .swiper-slide {
    width: 100%;
    height: auto;
  }

  section.single-offer .offer-footer .article-gallery .swiper-wrapper .swiper-slide img {
    width: 100%;
    height: 100%;
  }
}

/*
* ==============================================
TITLE AND CARDS
* ==============================================
*/
section.title-and-cards {
  padding-top: 9.375rem;
  padding-bottom: 9.375rem;
}

section.title-and-cards .zones {
  display: grid;
  gap: 3.125rem;
}

section.title-and-cards .zones .zone-title {
  text-align: center;
  display: grid;
  gap: 0.625rem;
}

section.title-and-cards .zones .zone-cards .cards-wrapper {
  display: grid;
  --grid-item-width: 13.8125rem;
  grid-template-columns: repeat(auto-fit, minmax(var(--grid-item-width), 1fr));
  grid-template-columns: repeat(auto-fit, minmax(min(var(--grid-item-width), 100%), 1fr));
  gap: 1.125rem;
}

@media only screen and (max-width: 768px) {
  section.title-and-cards {
    padding-block: 4rem;
  }

  section.title-and-cards .zones .zone-cards .cards-wrapper {
    display: flex;
    flex-wrap: nowrap;
    overflow: auto;
    width: 0;
    min-width: 100%;
  }

  section.title-and-cards .zones .zone-cards .cards-wrapper::-webkit-scrollbar {
    display: none;
  }

  section.title-and-cards .zones .zone-cards .cards-wrapper .card {
    flex-shrink: 0;
    max-width: 17rem;
  }

  section.single-offer .offer-body aside .booking-wrapper .booking-accordion .booking-accordion-wrapper .booking-accordion-content .date-selector-container {
    padding-top: 0.5rem;
  }

  section.single-offer .offer-body aside .booking-wrapper .booking-accordion .booking-accordion-wrapper .booking-accordion-content #members-form {
    row-gap: 1.25rem;
  }

  section.single-offer .offer-body aside .booking-wrapper .booking-accordion .booking-accordion-wrapper .booking-accordion-content #members-form {
    padding-top: 1.25rem;
  }
}

/*
* ==============================================
CARD USEFUL LINK
* ==============================================
*/
article.card.card-useful-link {
  position: relative;
}

article.card.card-useful-link[aria-hidden="true"] {
  display: none;
}

article.card.card-useful-link .badges {
  z-index: 1;
  position: absolute;
  top: 1.25rem;
  left: 1.25rem;
}

article.card.card-useful-link > a {
  position: absolute;
  inset: 0;
  z-index: 2;
}

article.card.card-useful-link .card-useful-link-thumbnail {
  margin-bottom: 1.25rem;
}

article.card.card-useful-link .card-useful-link-thumbnail .img-wrapper {
  padding-bottom: 61.27451%;
  border-radius: 1rem;
}

article.card.card-useful-link .card-useful-link-thumbnail .img-wrapper img {
  transition: transform 0.3s ease;
}

article.card.card-useful-link:hover .card-useful-link-thumbnail .img-wrapper img {
  transform: scale(1.05);
}

article.card.card-useful-link .card-useful-link-title {
  margin-bottom: 0.625rem;
}

article.card.card-useful-link .card-useful-link-link p {
  text-transform: uppercase;
  text-decoration: underline;
}

/*
* ==============================================
ARCHIVE USEFUL LINKS
* ==============================================
*/
section.archive-useful-links .filters {
  padding-top: 2.5rem;
  padding-bottom: 2.5rem;
  margin-bottom: 2.5rem;
  display: flex;
  justify-content: end;
  border-bottom: 1px solid #eaeaea;
}

section.archive-useful-links .useeful-links-wrapper {
  display: grid;
  gap: 1rem;
  row-gap: 5rem;
  --grid-item-width: 22.5rem;
  grid-template-columns: repeat(auto-fill, minmax(var(--grid-item-width), 1fr));
  grid-template-columns: repeat(auto-fill, minmax(min(var(--grid-item-width), 100%), 1fr));
}

section.archive-useful-links .select-wrapper {
  flex-grow: 1;
  max-width: 25.5rem;
}

section.archive-useful-links select {
  width: 100%;
  font-weight: 500;
}

@media only screen and (max-width: 768px) {
  section.archive-useful-links .useeful-links-wrapper {
    gap: 3.125rem;
  }
}

/*
* ==============================================
OFFER FILTERS
* ==============================================
*/

section.offer-filters {
  margin-top: var(--offer-filters-offset);
  position: relative;
  z-index: 1;
}

section.offer-filters .offer-filters-container .zones .zone-transport {
  display: flex;
  justify-content: space-between;
  align-items: end;
}

section.offer-filters .offer-filters-container .zones .zone-transport .transports {
  display: flex;
}

section.offer-filters .offer-filters-container .zones .zone-transport .transports .transport label {
  padding: 1.25rem 1.5rem;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 0.625rem;
  height: 100%;
  border-right: 1px solid #eaeaea;
  border-bottom: 1px solid #eaeaea;
  background-color: #f5f7fb;
  color: var(--c-gray);
  font-weight: 500;
  transition: color 0.15s ease, background-color 0.15s ease;
}

section.offer-filters .offer-filters-container .zones .zone-transport .transports .transport label .filter-name {
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}

section.offer-filters .offer-filters-container .zones .zone-transport .transports .transport input:focus-visible + label {
  position: relative; /* to bring it on top of its siblings, so the outline doesn't go under them */
}

section.offer-filters .offer-filters-container .zones .zone-transport .transports .transport:first-child label {
  border-top-left-radius: 1rem;
}

section.offer-filters .offer-filters-container .zones .zone-transport .transports .transport:last-child label,
section.offer-filters .offer-filters-container .zones .zone-transport .transports .transport.last-visible-transport label {
  border-top-right-radius: 1rem;
}

section.offer-filters .offer-filters-container .zones .zone-transport .transports .transport:last-child label {
  border-right: 0px solid transparent;
}

section.offer-filters .offer-filters-container .zones .zone-transport .transports .transport label:hover {
  color: var(--c-black);
}

section.offer-filters .offer-filters-container .zones .zone-transport .transports .transport input:checked + label {
  border-bottom: 1px solid var(--c-white);
  background-color: var(--c-white);
  color: var(--c-black);
}

section.offer-filters .offer-filters-container .zones .zone-transport .transports .transport label svg {
  flex-shrink: 0;
  height: 1.25rem;
}

section.offer-filters .offer-filters-container .zones .zone-transport .transports + a {
  line-height: 0;
}

section.offer-filters .offer-filters-container .zones .zone-filters {
  padding: 1.875rem;
  background-color: var(--c-white);
  border-radius: 1rem;
  border-top-left-radius: 0px;
  border-top-right-radius: 0px;
  display: flex;
  align-items: end;
  gap: 1.125rem;
  box-shadow: 0 12px 30px #00000014;
}

section.offer-filters .offer-filters-container .zones .zone-filters label {
  flex-grow: 1;
  flex-basis: 0;
  line-height: 0;
}

section.offer-filters .offer-filters-container .zones .zone-filters label span.label-name {
  display: inline-block;
  font-size: 0.875rem;
  line-height: 1.214286;
  margin-bottom: 0.5rem;
}

section.offer-filters .offer-filters-container .zones .zone-filters label .select-wrapper,
section.offer-filters .offer-filters-container .zones .zone-filters label .select-wrapper select {
  display: block;
  width: 100%;
}

section.offer-filters .offer-filters-container .zones .zone-filters label .select-wrapper select option[value="europa"],
section.offer-filters .offer-filters-container .zones .zone-filters label .select-wrapper select option[value="mondo"] {
  display: none;
}

section.offer-filters .offer-filters-container .zones .zone-filters button {
  display: flex;
  justify-content: space-between;
  gap: 1.375rem;
  background-color: var(--c-accent);
  padding: 0.25rem;
  padding-left: 1.625rem;
  align-items: center;
  font-size: 0.875rem;
  line-height: 1.214286;
  letter-spacing: 0.7px;
  color: var(--c-white);
  text-transform: uppercase;
  font-weight: 500;
  border-radius: 0.5rem;
}

section.offer-filters .offer-filters-container .zones .zone-filters button .icon {
  height: 2.5rem;
  width: 2.5rem;
  display: grid;
  place-items: center;
  background-color: rgba(255, 255, 255, 0.2);
  border-radius: 0.5rem;
}

section.offer-filters .offer-filters-container .zones .zone-filters .btn.btn-trenitalia {
  padding-block: 1.0625rem;
  background-color: #006a68;
}

section.offer-filters .offer-filters-container .zones .zone-filters button:active {
  transform: scale(0.98);
  background-color: #2973f2;
}

section.offer-filters .offer-filters-container .zones .zone-filters .transport-label {
  display: none;
}

@media (min-width: 768px) {
  section.offer-filters .offer-filters-container .zones .zone-filters .btn.btn-trenitalia {
    display: none;
  }
}

@media only screen and (max-width: 768px) {
  section.offer-filters .offer-filters-container .zones .zone-transport {
    display: none;
  }

  section.offer-filters .offer-filters-container .zones .zone-filters {
    border-radius: 1rem;
    gap: 1.25rem;
    display: flex;
    flex-direction: column;
    align-items: stretch;
  }

  section.offer-filters .offer-filters-container .zones .zone-filters .transport-label {
    display: block;
  }

  section.offer-filters .offer-filters-container .zones .zone-filters button {
    padding-left: 1.25rem;
  }

  section.offer-filters .offer-filters-container .zones .zone-filters {
    padding: 1.8rem 1.25rem;
  }
}

/*
* ==============================================
ARCHIVE OFFERS
* ==============================================
*/

section.archive-offers .active-filters-bar {
  margin-top: 5rem;
  padding-bottom: 2.5rem;
  border-bottom: 1px solid rgba(173, 173, 173, 0.3);
  margin-bottom: 2.5rem;
  font-weight: 500;
  display: flex;
  justify-content: space-between;
  gap: 0.9375rem;
  flex-wrap: wrap;
}

section.archive-offers .active-filters-bar[aria-hidden="true"] {
  display: none;
}

section.archive-offers .active-filters-bar .active-filters {
  display: flex;
  gap: 0.9375rem;
  align-items: center;
  flex-wrap: wrap;
}

section.archive-offers .active-filters-bar .active-filters button {
  color: var(--c-accent);
  font-size: 1rem;
  line-height: 1.1875rem;
  background-color: #dfedff;
  border-radius: 0.5rem;
  padding: 0.25rem;
  padding-left: 0.625rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

section.archive-offers .active-filters-bar .active-filters button * {
  line-height: 0;
}

section.archive-offers .active-filters-bar .active-filters button .icon {
  height: 1.25rem;
  max-height: 1.25rem;
  display: flex;
  justify-content: center;
  align-items: center;
}

section.archive-offers .active-filters-bar .active-filters button .x {
  display: grid;
  place-items: center;
  height: 1.5rem;
  width: 1.5rem;
  background-color: #fff;
  border-radius: 0.5rem;
}

section.archive-offers .active-filters-bar #reset-filters {
  padding: 0.375rem 1.25rem 0.4375rem;
  border-radius: 0.5rem;
  background-color: var(--c-accent);
  color: var(--c-white);
  line-height: 1.1875;
}

section.archive-offers .active-filters-bar[aria-hidden="true"] + .cards {
  margin-top: 5rem;
}

section.archive-offers .cards {
  padding-bottom: 9.375rem;
  display: grid;
  --grid-item-width: 16.875rem;
  grid-template-columns: repeat(auto-fill, minmax(var(--grid-item-width), 1fr));
  grid-template-columns: repeat(auto-fill, minmax(min(var(--grid-item-width), 100%), 1fr));
  gap: 1.0625rem;
  row-gap: 4.875rem;
}

section.archive-offers .cards .no-results-message {
  grid-column: span 12;
  text-align: center;
  font-size: 1.25rem;
  line-height: 1.3;
  margin-top: 1.5rem;
}

@media only screen and (max-width: 768px) {
  section.archive-offers .cards {
    padding-bottom: 3.125rem;
    gap: 2.375rem;
  }

  section.archive-offers .active-filters-bar[aria-hidden="true"] + .cards {
    margin-top: 4rem;
  }

  section.archive-offers .active-filters-bar {
    margin-top: 3rem;
  }

  section.archive-offers .cards .no-results-message {
    grid-column: unset;
    margin-top: 0.3rem;
  }
}

/*
* ==============================================
CONTACT CARDS
* ==============================================
*/

section.contact-cards {
  padding-top: 6.25rem;
  padding-bottom: 6.25rem;
}

section.contact-cards .zones {
  display: grid;
  gap: 5rem;
}

section.contact-cards .zones .zone.zone-title {
  text-align: center;
  display: grid;
  gap: 1.875rem;
}

section.contact-cards .zones .zone.zone-cards .cards {
  display: grid;
  --grid-item-width: 17.5rem;
  grid-template-columns: repeat(auto-fit, minmax(var(--grid-item-width), 1fr));
  grid-template-columns: repeat(auto-fit, minmax(min(var(--grid-item-width), 100%), 1fr));
  gap: 1rem;
}

section.contact-cards .zones .zone.zone-cards .cards .card {
  background-color: #f8f8f8;
  border-radius: 1rem;
  padding: 1.875rem;
}

section.contact-cards .zones .zone.zone-cards .cards .card:nth-child(even) {
  background-color: #dfedff;
}

section.contact-cards .zones .zone.zone-cards .cards .card .card-head {
  padding-bottom: 1.875rem;
  margin-bottom: 1.875rem;
  border-bottom: 1px solid rgba(173, 173, 173, 0.3);
  display: flex;
  gap: 1rem;
  align-items: center;
}

section.contact-cards .zones .zone.zone-cards .cards .card .card-head svg {
  color: var(--c-accent);
}

section.contact-staff .layers .layer-bg .img-wrapper {
  height: 100%;
}

section.contact-staff .layers .layer-bg .img-wrapper img {
  mask-image: linear-gradient(transparent 40%, black 65%);
}

section.contact-staff .layers .layer-fg {
  padding-top: 3.125rem;
  padding-bottom: 9.375rem;
}

section.contact-staff .layers .layer-fg .title {
  text-align: center;
  margin-bottom: 5rem;
}

section.contact-staff .layers .layer-fg .roles-container {
  box-shadow: 0 12px 30px #00000014;
  padding: 2.5rem;
  background: var(--c-white);
  border-radius: 1rem;
  display: grid;
  column-gap: 4.125rem;
  grid-template-columns: repeat(2, 1fr);
}

section.contact-staff .layers .layer-fg .roles-container .role {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  padding-top: 2.5rem;
  padding-bottom: 2.5rem;
  border-bottom: 1px solid rgba(173, 173, 173, 0.3);
}

section.contact-staff .layers .layer-fg .roles-container .role:first-child {
  padding-top: 0;
}

section.contact-staff .layers .layer-fg .roles-container .role:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

section.contact-staff .layers .layer-fg .roles-container .role .people {
  display: grid;
  gap: 1.25rem;
}

section.contact-staff .layers .layer-fg .roles-container .role .people .person {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.25rem;
}

@media only screen and (max-width: 768px) {
  section.contact-cards .zones {
    gap: 6.25rem;
  }

  section.contact-staff .layers .layer-fg .title {
    margin-bottom: 6.25rem;
  }

  section.contact-cards .zones .zone.zone-cards .cards {
    gap: 2rem;
  }

  section.contact-staff .layers .layer-bg .img-wrapper img {
    mask-image: linear-gradient(transparent 6%, black 31%);
  }

  section.contact-staff .layers .layer-fg {
    padding-top: 0;
    padding-bottom: 3.125rem;
  }

  section.contact-staff .layers .layer-fg .roles-container {
    display: flex;
    flex-direction: column;
    padding: 1.25rem;
  }

  section.contact-staff .layers .layer-fg .roles-container .col-right .role:first-child {
    padding-top: 2.5rem;
  }

  section.contact-staff .layers .layer-fg .roles-container .col-left .role:last-child {
    padding-bottom: 2.5rem;
    border-bottom: 1px solid rgba(173, 173, 173, 0.3);
  }

  section.contact-staff .layers .layer-fg .roles-container .role .people .person {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
  }
}

#info-window {
  border-radius: 1rem;
  background-color: #fff;
  box-shadow: 0 12px 30px #adadad;
  padding: 1.875rem;
  text-align: center;
  font-size: 20px;
  font-family: var(--ff-sans);
  line-height: 1.5;
}

#info-window p:first-child {
  color: var(--c-accent);
  font-weight: 700;
}

.gm-style .gm-style-iw-c {
  padding-left: 0;
  background-color: transparent;
  overflow: visible;
  border-radius: 1rem;
}

.gm-style .gm-style-iw-c .gm-style-iw-chr {
  display: none;
}

.gm-style .gm-style-iw-d {
  overflow: visible !important;
  background-color: transparent;
  padding: 0;
}

.gm-style .gm-style-iw-tc {
  display: none;
}

/*
* ==============================================
BOOKING
* ==============================================
*/

section.booking,
section.terms-condition {
  padding-top: 1.875rem;
  padding-bottom: 9.375rem;
}

section.terms-condition h1 {
  padding: 1.6rem 0;
}

section.booking .zones .zone.zone-breadcrumb {
  margin-bottom: 6.25rem;
}

section.booking .zones .zone.zone-title {
  text-align: center;
  max-width: 38.75rem;
  margin-inline: auto;
  display: grid;
  gap: 2rem;
  margin-bottom: 5rem;
}

section.booking .zones .zone.zone-cards {
  display: grid;
  --grid-item-width: 36.25rem;
  grid-template-columns: repeat(auto-fit, minmax(var(--grid-item-width), 1fr));
  grid-template-columns: repeat(auto-fit, minmax(min(var(--grid-item-width), 100%), 1fr));
  gap: 1rem;
  row-gap: 1.875rem;
}

section.booking .zones .zone.zone-cards .card {
  border-radius: 1rem;
  background-color: #f8f8f8;
  padding: 3.125rem;
}

section.booking .zones .zone.zone-cards .card:nth-child(even) {
  background-color: #e0ecff;
}

section.booking .zones .zone.zone-cards .card .card-head {
  padding-bottom: 1.875rem;
  border-bottom: 1px solid #adadad;
  margin-bottom: 1.875rem;
  display: flex;
  gap: 1rem;
}

section.booking .zones .zone.zone-cards .card .card-head svg {
  color: var(--c-accent);
  line-height: 0;
}

@media only screen and (max-width: 768px) {
  section.booking,
  section.terms-condition {
    padding-top: 1.875rem;
    padding-bottom: 4rem;
  }

  section.booking .zones .zone.zone-title {
    margin-bottom: 4rem;
  }

  section.booking .zones .zone.zone-cards .card {
    padding: 1.875rem 1.25rem;
  }

  section.booking .zones .zone.zone-breadcrumb,
  section.booking .zones .zone.zone-title {
    margin-bottom: 4rem;
  }
}

/*
* ==============================================
ABOUT
* ==============================================
*/

#about-dotted-line-0,
#about-dotted-line-2,
#about-dotted-line-1 {
  position: relative;
  isolation: isolate;
}

#about-dotted-line-0 > svg,
#about-dotted-line-2 > svg,
#about-dotted-line-1 > svg {
  position: absolute;
  height: 100%;
  min-width: 100%;
  width: 0;
  z-index: -1;
  position: none;
}

#about-dotted-line-0 > svg {
  top: -20rem;
}

#about-dotted-line-2 > svg {
  top: 14.375rem;
}

@media only screen and (max-width: 768px) {
  #about-dotted-line-0 > svg {
    top: -9rem;
  }

  #about-dotted-line-1 > svg {
    height: auto;
    transform: translateY(-60%);
  }
}

section.about-hero .background {
  position: relative;
}

section.about-hero .background::before,
section.about-hero .background::after {
  content: "";
  position: absolute;
  height: 10rem;
  width: 100%;
  background: linear-gradient(transparent, white);
}

section.about-hero .background::before {
  top: 0;
  background: linear-gradient(white, transparent);
}

section.about-hero .background::after {
  bottom: 0;
}

section.about-hero .background .img-wrapper {
  height: 100%;
}

section.about-hero .title-container {
  padding-top: 6.25rem;
  padding-bottom: 11.25rem;
  text-align: center;
}

@media only screen and (max-width: 768px) {
  section.about-hero .background::before,
  section.about-hero .background::after {
    content: initial;
  }

  section.about-hero .title-container {
    padding-top: 4rem;
    padding-bottom: 4rem;
  }
}

section.scotched-img {
  --container-x-padding: 3.5rem;
  --scotched-top-color: transparent;
  --scotched-bottom-color: transparent;
  --scotched-img-rotation: 4;
  background-image: linear-gradient(var(--scotched-top-color) 50%, var(--scotched-bottom-color) 50%);
}

section.scotched-img#story-img {
  --scotched-top-color: var(--c-beige);
  --scotched-img-rotation: -4;
}

section.scotched-img .img-container {
  container-type: inline-size;
}

section.scotched-img .img-container .img-padder {
  --abs-angle: calc(1deg * sqrt(pow(var(--scotched-img-rotation), 2)));
  padding-block: calc(((100cqw * sin(var(--abs-angle))) - ((100cqw * (var(--image-height) / var(--image-width))) * (1 - cos(var(--abs-angle))))) / 2);
}

section.scotched-img .img-wrapper {
  position: relative;
  transform: rotate(calc(1deg * var(--scotched-img-rotation)));
}

section.scotched-img .img-wrapper img:first-child {
  border-radius: 1rem;
}

section.scotched-img .img-wrapper .scotch {
  --scotch-factor: 1;
  position: absolute;
  bottom: 0;
  left: 0;
  transform: translateX(calc(-50% * (var(--scotch-factor) * 1))) translateY(calc(50% * (var(--scotch-factor) * 1))) scaleX(var(--scotch-factor)) rotate(calc(45deg * var(--scotch-factor)));
  max-width: 8.25rem;
  max-width: min(8.25rem, 15vw);
}

section.scotched-img .img-wrapper .scotch:last-child {
  --scotch-factor: -1;
  bottom: auto;
  top: 0;
  left: auto;
  right: 0;
}

@media only screen and (max-width: 768px) {
  section.scotched-img {
    overflow-x: clip;
  }
}

section.about-text {
  padding-top: 9.375rem;
  padding-bottom: 9.375rem;
  text-align: center;
}

@media only screen and (max-width: 768px) {
  section.about-text {
    padding-top: 4rem;
    padding-bottom: 4rem;
  }
}

section.about-gallery {
  overflow: hidden;
  background-image: linear-gradient(transparent 50%, #f8f6f5 50%);
}

section.about-gallery .images {
  display: flex;
  gap: 1rem;
  height: 24.0625rem;
  justify-content: center;
}

section.about-gallery .images .img-wrapper {
  overflow: hidden;
  border-radius: 1rem;
}

section.about-gallery .images .img-wrapper img {
  height: 100%;
  object-fit: cover;
}

@media only screen and (max-width: 768px) {
  section.about-gallery .images {
    padding-inline: var(--container-x-padding);
    overflow: auto;
    justify-content: start;
  }

  section.about-gallery .images::-webkit-scrollbar {
    display: none;
  }

  section.about-gallery .images .img-wrapper {
    flex-shrink: 0;
  }
}

section.about-title {
  text-align: center;
  padding-top: 9.375rem;
  padding-bottom: 8.1875rem;
}

section.about-description {
  padding-block: 9.375rem;
  text-align: center;
}

@media only screen and (max-width: 768px) {
  #about-dotted-line-2 section.about-description {
    padding-top: 0;
  }

  section.about-description {
    padding-block: 4rem;
  }

  section.about-title {
    padding-top: 4rem;
    padding-bottom: 4rem;
  }
}

section.about-description .container {
  display: grid;
  gap: 1.875rem;
}

section.about-tailored {
  padding-block: 9.375rem;
  padding-bottom: 0;
}

section.about-tailored .zones {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--container-gap);
  align-items: center;
}

section.about-tailored .zones .zone {
  max-width: 100%;
}

section.about-tailored .zones .zone.zone-img .img-wrapper {
  overflow: hidden;
  border-radius: 1rem;
}

section.about-tailored .zones .zone.zone-text .description ul {
  font-size: 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
  padding-left: 1.75rem;
}

section.about-tailored .zones .zone.zone-text .rich-text ul li::before {
  background: unset;
  background-image: url("data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMjAiIGhlaWdodD0iMjAiIHZpZXdCb3g9IjAgMCAyMCAyMCIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZD0iTTEwIDIwQzE1LjUyMjggMjAgMjAgMTUuNTIyOCAyMCAxMEMyMCA0LjQ3NzE1IDE1LjUyMjggMCAxMCAwQzQuNDc3MTUgMCAwIDQuNDc3MTUgMCAxMEMwIDE1LjUyMjggNC40NzcxNSAyMCAxMCAyMFoiIGZpbGw9IiMyOTg3ZjIiIG9wYWNpdHk9IjAuMiIvPgo8cGF0aCBkPSJNNi40OTk5NCA5LjM3OTAzTDkuNDExMDcgMTIuMjlMMTQuMjAxMSA3LjUwMDk4IiBzdHJva2U9IiMyOTg3ZjIiIHN0cm9rZS13aWR0aD0iMiIgc3Ryb2tlLWxpbmVjYXA9InJvdW5kIiBzdHJva2UtbGluZWpvaW49InJvdW5kIi8+Cjwvc3ZnPgoK");
  background-size: 100%;
  width: 1.25rem;
  height: 1.25rem;
  left: -1.8rem;
  top: 0;
}

@media only screen and (max-width: 768px) {
  section.about-tailored {
    padding-block: 4rem;
  }

  section.about-tailored .zones {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 3.125rem;
  }

  section.about-tailored .zones .zone {
    max-width: none;
  }
}

section.about-img.about-stamp .img-wrapper {
  max-width: 13.6875rem;
  margin-inline: auto;
}

section.about-img.img-wrapper-pill {
  padding-bottom: 9.375rem;
}

section.about-img.img-wrapper-pill .img-wrapper {
  border-radius: 999px;
  overflow: hidden;
}

@media only screen and (max-width: 768px) {
  section.about-img.img-wrapper-pill {
    padding-bottom: 5.5rem;
  }
}

section.about-specialization {
  padding-top: 9.375rem;
  padding-bottom: 9.375rem;
}

section.about-specialization .zones {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--container-gap);
}

section.about-specialization .zones .zone.zone-text {
  max-width: 25.5rem;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

section.about-specialization .zones .zone.zone-img .img-wrapper {
  height: 100%;
  border-radius: 1rem;
  min-height: 21.375rem;
}

@media only screen and (max-width: 768px) {
  section.about-specialization {
    padding-block: 4rem;
  }

  section.about-specialization .zones {
    gap: 4rem;
    display: flex;
    flex-direction: column;
  }

  section.about-specialization .zones .zone.zone-img {
    width: 100%;
  }

  section.about-specialization .zones .zone.zone-img .img-wrapper {
    min-height: unset;
    height: auto;
  }

  section.about-specialization .zones .zone.zone-img .img-wrapper img {
    position: static;
  }

  section.about-specialization .zones .zone.zone-text {
    max-width: none;
    text-align: center;
  }
}

footer {
  padding-top: 0rem;
}

footer .zones .zone-logo {
  padding-bottom: 3.125rem;
}

footer .zones .zone-logo .img-wrapper {
  max-width: 10.0625rem;
  margin-inline: auto;
}

footer .zones .zone-menu {
  padding-block: 3.125rem;
  border-block: 1px solid #1b17421a;
  display: flex;
  justify-content: space-between;
  gap: 2rem;
}

footer .zones .zone-menu .left-wrapper {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 1rem;
  max-width: 18.875rem;
}

footer .zones .zone-menu .left-wrapper .intro-text-wrapper,
footer .zones .zone-menu .left-wrapper .newsletter-wrapper {
  display: grid;
  gap: 1.875rem;
}

footer .zones .zone-menu .menu-voices {
  flex-grow: 1;
  max-width: 45.375rem;
}

footer .zones .zone-menu .menu-voices ul.first-level {
  display: flex;
  gap: 1rem;
  justify-content: space-between;
}

footer .zones .zone-menu .menu-voices ul.first-level .first-level.menu-name {
  font-weight: 500;
  color: var(--c-accent);
  font-size: 1.25rem;
  line-height: 1.2;
  margin-bottom: 1.5rem;
  display: block;
}

footer .zones .zone-menu .menu-voices ul.first-level .description p {
  margin-bottom: 0;
}

footer .zones .zone-menu .menu-voices ul.first-level .description p,
footer .zones .zone-menu .menu-voices ul.first-level li ul {
  line-height: 2.25;
}

footer .zones .zone-menu .menu-voices ul.first-level li {
  color: var(--c-gray);
}

footer .zones .zone-menu .menu-voices ul.first-level li a {
  transition: color 0.15s ease;
  display: inline-block;
}

footer .zones .zone-menu .menu-voices ul.first-level li a:hover {
  color: var(--c-black);
}

footer .zones .zone-copyright {
  padding-block: 1.875rem;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 1rem;
  align-items: center;
}

footer .zones .zone-copyright .socials {
  line-height: 0;
  display: flex;
  align-items: center;
  gap: 0.625rem;
}

footer .zones .zone-copyright > :last-child {
  justify-self: end;
}

footer .zones .zone-copyright .btn-top {
  display: flex;
  align-items: center;
  gap: 1.25rem;
}

footer .zones .zone-copyright .btn-top .arrow-btn {
  background-color: var(--c-accent);
  border-radius: 0.5rem;
  display: grid;
  place-items: center;
  color: white;
  height: 2.5rem;
  width: 2.5rem;
}

footer .zones .zone-copyright .btn-top .arrow-btn svg {
  transform: rotate(-90deg);
  transition: transform 0.15s ease;
}

footer .zones .zone-copyright .btn-top:hover .arrow-btn svg {
  transform: translateY(-30%) rotate(-90deg);
}

footer .eg-wpcf7 br,
footer .eg-wpcf7 .wpcf7-spinner {
  display: none;
}

footer .eg-wpcf7 {
  position: relative;
}

footer .eg-wpcf7 input[type="email"] {
  padding-right: 2.9375rem;
  width: 100%;
}

footer .eg-wpcf7 input[type="submit"] {
  position: absolute;
  top: 0.25rem;
  right: 0.4375rem;
  border-radius: 0.5rem;
  appearance: none;
  height: 2.5rem;
  width: 2.5rem;
  background-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNC44MTYiIGhlaWdodD0iMTQuODE2IiB2aWV3Qm94PSIwIDAgMTQuODE2IDE0LjgxNiI+CiAgPHBhdGggaWQ9IlZlY3RvciIgZD0iTTEwLjQ2OCwxMC40NjhWMS4zSDguOFY3LjU1MUwxLjI1LDAsMCwxLjI1LDcuNTUxLDguOEgxLjMxOXYxLjY2N2g5LjE0OVoiIHRyYW5zZm9ybT0idHJhbnNsYXRlKDAgNy40MTQpIHJvdGF0ZSgtNDUpIiBmaWxsPSIjMjk4N2YyIi8+Cjwvc3ZnPgo=");
  color: transparent;
  background-repeat: no-repeat;
  background-size: 0.92625rem 0.92625rem;
  background-position: center center;
  padding: 0;
  background-color: transparent;
}

@media only screen and (max-width: 768px) {
  section.banner-spaced {
    padding-bottom: 4rem;
  }

  footer .zones .zone-logo .img-wrapper {
    max-width: 8.375rem;
  }

  footer .zones .zone-menu {
    display: flex;
    flex-direction: column;
  }

  footer .zones .zone-menu .left-wrapper {
    max-width: none;
  }

  footer .zones .zone-menu .menu-voices ul.first-level {
    display: flex;
    flex-direction: column;
  }

  footer .zones .zone-copyright {
    display: flex;
    flex-direction: column;
    text-align: center;
    gap: 1.875rem;
  }
}

/*
* ==============================================
CARD LOCATION
* ==============================================
*/

article.card.card-location {
  border-radius: 1rem;
  overflow: hidden;
  min-height: 20.625rem;
  height: 0;
}

article.card.card-location .layers {
  height: 100%;
}

article.card.card-location .layer-bg::after {
  background: linear-gradient(transparent 50%, transparent 50%, black);
  opacity: 0.8;
}

article.card.card-location .layer-bg .img-wrapper {
  height: 100%;
}

article.card.card-location .layer-bg .img-wrapper img {
  transition: transform 0.3s ease;
}

article.card.card-location .layers .layer-bg .img-wrapper img {
  transition: transform 0.3s ease;
}

article.card.card-location .layers:where(:focus-visible, :hover) .layer-bg .img-wrapper img {
  transform: scale(1.1);
}

article.card.card-location .layer-fg {
  padding: 1.875rem;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

article.card.card-location .layer-fg .badges {
  align-self: start;
}

article.card.card-location .layer-fg .text .text-wrapper {
  display: grid;
}

article.card.card-location .layer-fg .text .text-wrapper .title {
  max-width: 13.375rem;
  text-wrap: balance;
}

article.card.card-location .layers:focus-visible .layer-fg .text .text-wrapper .title {
  text-decoration: underline;
}

article.card.card-location .layer-fg .text .text-wrapper .bottom {
  margin-top: -0.3125rem;
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: end;
}

article.card.card-location .layer-fg .text .text-wrapper .bottom .arrow-btn {
  height: 2.5rem;
  width: 2.5rem;
  backdrop-filter: blur(30px) brightness(115%);
  border-radius: 0.5rem;
  display: grid;
  place-items: center;
}

article.card.card-location .layer-fg .text .text-wrapper .bottom .arrow-btn svg {
  color: var(--c-white);
  transition: transform 0.3s ease;
}

article.card.card-location .layers:where(:focus-visible, :hover) .layer-fg .text .text-wrapper .bottom .arrow-btn svg {
  transform: translate(25%, -25%);
}

@media only screen and (max-width: 768px) {
  article.card.card-location .layer-bg::after {
    background: linear-gradient(transparent 50%, transparent 50%, black);
    opacity: 0.6;
  }
}

/*
* ==============================================
FEATURED LOCATIONS
* ==============================================
*/
section.featured-locations {
  padding-block: 9.375rem;
}

section.featured-locations .locations-wrapper {
  display: grid;
  grid-template-columns: 5fr 7fr;
  grid-template-rows: 1fr 1fr;
  grid-template-areas:
    "a b"
    "a c";
  gap: 1rem;
  row-gap: 1.125rem;
}

section.featured-locations .locations-wrapper > :nth-child(1) {
  grid-area: a;
  height: 100%;
}

section.featured-locations .locations-wrapper > :nth-child(2) {
  grid-area: b;
}

section.featured-locations .locations-wrapper > :nth-child(3) {
  grid-area: c;
}

@media only screen and (max-width: 768px) {
  section.featured-locations {
    padding-block: 4rem;
  }

  section.featured-locations .locations-wrapper {
    display: flex;
    flex-direction: column;
    row-gap: 1.875rem;
  }

  section.featured-locations .locations-wrapper > :nth-child(1) {
    grid-area: a;
    height: 0;
  }

  article.card.card-location .layer-fg .text .text-wrapper .bottom {
    margin-top: -0.3125rem;
  }
}

/*
* ==============================================
HEADER
* ==============================================
*/

header.egloo {
  --header-bar-bg-color: var(--c-white);
  --header-bar-fg-color: var(--c-black);
  --header-menu-gap: 1.875rem;
  z-index: 9999;
}

header.egloo[data-style="transparent"] {
  --header-bar-bg-color: transparent;
  --header-bar-fg-color: var(--c-white);
  margin-bottom: calc(-1 * var(--header-height));
}

header.egloo[data-style="transparent"]:not(.floating) {
  top: calc(-1 * var(--header-height));
}

header.egloo[data-style="transparent"]:not(.floating) .header-bar {
  border-bottom: 0;
}

header.egloo[data-style="transparent"] .header-bar {
  isolation: isolate;
}

header.egloo[data-style="transparent"] .header-bar::after {
  content: "";
  position: absolute;
  height: 100%;
  width: 100%;
  background-image: linear-gradient(#000000, #00000000);
  opacity: 0.6;
  top: 0;
  left: 0;
  z-index: -1;
  pointer-events: none;
  transition: opacity 0.3s ease 0.3s;
}

header.egloo[data-style="transparent"]:where(.floating, :hover, :focus-visible, :focus-within) .header-bar::after {
  opacity: 0;
  transition: opacity 0.3s ease;
}

header.egloo[data-style="transparent"]:not(.floating) .header-bar .header-bar-wrapper-mobile .header-logo .logo,
header.egloo[data-style="transparent"]:not(.floating) .header-bar .header-bar-wrapper .header-logo .logo {
  opacity: 0;
}

header.egloo[data-style="transparent"].floating .header-bar .header-bar-wrapper-mobile .header-logo .logo-white,
header.egloo:not([data-style="transparent"]) .header-bar .header-bar-wrapper-mobile .header-logo .logo-white,
header.egloo[data-style="transparent"].floating .header-bar .header-bar-wrapper .header-logo .logo-white,
header.egloo:not([data-style="transparent"]) .header-bar .header-bar-wrapper .header-logo .logo-white {
  opacity: 0;
}

header.egloo {
  position: sticky;
  background-color: var(--header-bar-bg-color);
  color: var(--header-bar-fg-color);
  z-index: 99;
  top: 0;
  transition: transform 0.3s ease, color 0.3s ease 0.3s, top 0.3s ease 0.3s, background-color 0.3s ease 0.3s;
}

header.egloo.floating {
  background-color: var(--c-white);
  color: var(--c-black);
  transform: translateY(-100%);
}

header.egloo.floating.floating-active {
  transform: translateY(0%);
}

header.egloo .header-bar {
  border-bottom: 1px solid rgba(173, 173, 173, 0.3);
}

header.egloo .header-bar .header-bar-wrapper {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
}

header.egloo .header-bar .header-bar-wrapper > .menu-container > ul {
  display: flex;
  align-items: center;
}

header.egloo .header-bar .header-bar-wrapper > .menu-container.menu-right > ul {
  justify-content: end;
}

header.egloo .header-bar .header-bar-wrapper > .menu-container > ul > li:not(:first-child) {
  padding-left: calc(var(--header-menu-gap) / 2);
}

header.egloo .header-bar .header-bar-wrapper > .menu-container > ul > li:not(:last-child) {
  padding-right: calc(var(--header-menu-gap) / 2);
}

header.egloo .header-bar .header-bar-wrapper ul.first-level > li:not(.socials-container) a.first-level,
header.egloo .header-bar .header-bar-wrapper ul.first-level > li:not(.socials-container) > span,
header.egloo .header-bar .header-bar-wrapper ul.first-level > li > a {
  display: block;
  padding-block: 3.125rem;
  line-height: 1.1875rem;
}

header.egloo .header-bar .header-bar-wrapper ul.first-level > li .menu-btn {
  color: var(--c-accent);
  background-color: #dfedff;
  border-radius: 0.5rem;
  padding: 0.875rem 1.25rem 0.9375rem;
  display: inline-block;
}

header.egloo .header-bar .header-bar-wrapper ul.first-level > li .menu-btn .socials {
  display: none;
}

header.egloo .header-bar .header-bar-wrapper ul.first-level > li a:where(:hover, :focus-visible).first-level,
header.egloo .header-bar .header-bar-wrapper ul.first-level > li > a:where(:hover, :focus-visible) {
  text-decoration: underline var(--c-accent);
}

header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-body {
  display: grid;
  grid-template-rows: 0fr;
  overflow: hidden;
  transition: grid-template-rows 0.3s ease;
}

body::after {
  content: "";
  pointer-events: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 98;
  transition: backdrop-filter 0.3s ease;
}

@media (hover: hover) {
  body:has(.header-bar .header-bar-wrapper .menu-accordion .menu-accordion-body:focus-within) header.egloo,
  body:has(.header-bar .header-bar-wrapper .menu-accordion .menu-accordion-head:focus-within + .menu-accordion-body) header.egloo,
  body:has(.header-bar .header-bar-wrapper .menu-accordion .menu-accordion-body:hover) header.egloo,
  body:has(.header-bar .header-bar-wrapper .menu-accordion .menu-accordion-head:hover + .menu-accordion-body) header.egloo {
    background-color: var(--c-white);
    color: var(--c-black);
    transition: transform 0.3s ease, color 0.3s ease, top 0.3s ease 0.3s, background-color 0.3s ease;
  }

  body:has(.header-bar .header-bar-wrapper .menu-accordion .menu-accordion-body:focus-within)::after,
  body:has(.header-bar .header-bar-wrapper .menu-accordion .menu-accordion-head:focus-within + .menu-accordion-body)::after,
  body:has(.header-bar .header-bar-wrapper .menu-accordion .menu-accordion-body:hover)::after,
  body:has(.header-bar .header-bar-wrapper .menu-accordion .menu-accordion-head:hover + .menu-accordion-body)::after {
    backdrop-filter: blur(10px);
  }

  header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-body:focus-within,
  header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-head:focus-within + .menu-accordion-body,
  header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-body:hover,
  header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-head:hover + .menu-accordion-body {
    grid-template-rows: 1fr;
    box-shadow: 0 3px 6px #0000000f;
  }

  header.egloo .header-bar .header-bar-wrapper .menu-accordion:has(.menu-accordion-body:focus-within) .menu-accordion-head svg,
  header.egloo .header-bar .header-bar-wrapper .menu-accordion:has(.menu-accordion-body:hover) .menu-accordion-head svg,
  header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-head:focus-within svg,
  header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-head:hover svg {
    transform: translateY(2px) rotate(-180deg);
  }
}

header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-head .menu-title {
  display: flex;
  align-items: center;
  gap: 0.3125rem;
}

header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-head svg {
  transform: translateY(2px);
  transition: transform 0.3s ease;
}

header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-body > div {
  min-height: 0;
}

header.egloo .header-bar .header-bar-wrapper .header-logo {
  max-width: 7.0625rem;
  display: grid;
}

header.egloo .header-bar .header-bar-wrapper .header-logo img {
  grid-column: -1/1;
  grid-row: -1/1;
  transition: opacity 0.3s ease 0.3s;
}

header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-body {
  position: absolute;
  top: 100%;
  left: 0;
  width: 100%;
  background-color: white;
  z-index: 1;
}

header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-body .menu-accordion-content .zones {
  display: flex;
  justify-content: space-between;
}

header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-body .menu-accordion-content {
  padding-top: 2.5rem;
  padding-bottom: 3.5rem;
}

header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-body .menu-accordion-content .zones .zone.zone-menu .dropdown-title {
  margin-bottom: 3.125rem;
  display: block;
}

header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-body .menu-accordion-content .zones .zone.zone-menu ul {
  display: flex;
  flex-direction: column;
  gap: 1.0625rem;
}

header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-body .menu-accordion-content .zones .zone.zone-menu ul li a {
  display: flex;
  align-items: center;
  gap: 1.25rem;
  border-radius: 0.5rem;
  transition: background-color 0.3s ease;
  padding-right: 1.25rem;
}

header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-body .menu-accordion-content .zones .zone.zone-menu ul li a:focus-visible,
header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-body .menu-accordion-content .zones .zone.zone-menu ul li a:hover {
  background-color: rgba(var(--c-accent-raw) / 0.05);
}

header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-body .menu-accordion-content .zones .zone.zone-menu ul li a .sub-item-title {
  font-size: 1.25rem;
  line-height: 1.2;
  font-weight: 500;
}

header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-body .menu-accordion-content .zones .zone.zone-menu ul li a .icon-wrapper {
  border-radius: 0.5rem;
  display: grid;
  place-items: center;
  background-color: #f8f8f8;
  height: 2.625rem;
  width: 2.625rem;
}

header.egloo .header-bar .header-bar-wrapper ul li:nth-child(2) .menu-accordion .menu-accordion-body .menu-accordion-content .zones .zone.zone-menu ul li:nth-child(1) a .icon-wrapper img {
  max-width: 1.8rem;
}

header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-body .menu-accordion-content .zones .zone.zone-menu ul li a .icon-wrapper img {
  max-width: 1.25rem;
  max-height: 1.25rem;
}

header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-body .menu-accordion-content .zones .zone.zone-cards .see-all {
  color: var(--c-accent);
  text-decoration: underline;
  font-weight: 0.875rem;
  line-height: 1.214286;
  margin-bottom: 3.5rem;
  text-align: right;
  display: block;
  font-weight: 500;
}

header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-body .menu-accordion-content .zones .zone.zone-cards .cards-wrapper {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 195px));
  gap: 0.875rem;
}

header.egloo .header-bar .header-bar-wrapper ul li:nth-child(2) .menu-accordion .menu-accordion-body .menu-accordion-content .zones .zone.zone-cards .cards-wrapper .card {
  grid-column: span 3;
}

header.egloo .header-bar .header-bar-wrapper ul li:nth-child(2) .menu-accordion .menu-accordion-body .menu-accordion-content .zones .zone.zone-cards .cards-wrapper .card .img-wrapper {
  padding-bottom: 58%;
}

header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-body .menu-accordion-content .zones .zone.zone-cards .cards-wrapper .card {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-body .menu-accordion-content .zones .zone.zone-cards .cards-wrapper .card .img-wrapper {
  padding-bottom: 110.25641%;
  border-radius: 1rem;
}

header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-body .menu-accordion-content .zones .zone.zone-cards .cards-wrapper .card .img-wrapper img {
  transition: transform 0.3s ease;
}

header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-body .menu-accordion-content .zones .zone.zone-cards .cards-wrapper .card:hover .img-wrapper img {
  transform: scale(1.1);
}

header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-body .menu-accordion-content .zones .zone.zone-cards .cards-wrapper .card span {
  font-size: 1.25rem;
  line-height: 1.1;
  font-weight: 500;
}

header.egloo .header-bar .header-bar-wrapper-mobile {
  display: none;
}

header.egloo .header-bar .header-bar-wrapper > .login-buttons {
  display: none;
}

header.egloo .header-bar .socials {
  display: none;
}

@media only screen and (max-width: 768px) {
  body:not(.mobile-menu-open) header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-body {
    transition: grid-template-rows 0.3s ease 0.3s;
  }

  header.egloo {
    --header-height: 6.25rem;
    transition-delay: 0s, 0s, 0s, 0s;
  }

  header.egloo .header-bar .header-bar-wrapper {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    height: 100svh;
    transform: translateX(100%);
    background: white;
    transition: transform 0.3s ease;
    display: flex;
    flex-direction: column;
    padding-top: var(--header-height);
    align-items: stretch;
    overflow: auto;
  }

  header.egloo .header-bar .header-bar-wrapper ul.first-level > li:not(.socials-container) a.first-level,
  header.egloo .header-bar .header-bar-wrapper ul.first-level > li:not(.socials-container) > span,
  header.egloo .header-bar .header-bar-wrapper ul.first-level > li:not(.socials-container) > a {
    padding-block: 0;
  }

  header.egloo .header-bar .header-bar-wrapper > .header-logo {
    display: none;
  }

  header.egloo .header-bar .header-bar-wrapper > .login-buttons {
    display: block;
  }

  header.egloo .header-bar .header-bar-wrapper > .login-buttons .wrapper {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    column-gap: 0.625rem;
    padding-inline: 1.5rem;
    padding-top: 3.125rem;
    padding-bottom: 1.5625rem;
  }

  header.egloo .header-bar .header-bar-wrapper > :nth-child(3) {
    display: block;
  }

  header.egloo .header-bar .header-bar-wrapper > .menu-container > ul.first-level {
    flex-direction: column;
    align-items: start;
  }

  header.egloo .header-bar .header-bar-wrapper > .menu-container:first-child {
    padding-block-start: 1.5625rem;
  }

  header.egloo .header-bar .header-bar-wrapper > .menu-container > ul.first-level > li {
    padding-block: 1.2rem;
    padding-inline: 1.5rem;
    width: 100%;
  }

  header.egloo .header-bar .header-bar-wrapper > .menu-container > ul.first-level > li.egloo-cart,
  header.egloo .header-bar .header-bar-wrapper > .menu-container > ul.first-level > li.egloo-account {
    display: none;
  }

  header.egloo .header-bar .header-bar-wrapper > .header-logo {
    display: none;
  }

  header.egloo .header-bar .header-bar-wrapper > .menu-container.menu-right {
    flex-grow: 1;
  }

  header.egloo .header-bar .header-bar-wrapper > .menu-container.menu-right > ul {
    height: 100%;
  }

  header.egloo .header-bar .header-bar-wrapper > .menu-container.menu-right > ul > li:last-child {
    margin-top: auto;
    padding-block-end: 1.875rem;
    padding-top: 2.2rem;
  }

  header.egloo .header-bar .header-bar-wrapper ul.first-level > li .menu-title-text:not(.menu-btn) {
    font-size: 1.625rem;
    line-height: 1.153846;
    font-weight: 400;
  }

  header.egloo .header-bar .header-bar-wrapper ul.first-level > li.socials-container .menu-title {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--container-gap);
    align-items: center;
    justify-items: center;
  }

  header.egloo .header-bar .header-bar-wrapper ul.first-level > li.socials-container .socials {
    display: flex;
    align-items: center;
    gap: 0.5rem;
  }

  header.egloo .header-bar .header-bar-wrapper ul.first-level > li.socials-container .menu-title .menu-btn {
    width: 100%;
    text-align: center;
  }

  header.egloo .header-bar .header-bar-wrapper ul.first-level > li.socials-container .menu-title .socials *,
  header.egloo .header-bar .header-bar-wrapper ul.first-level > li.socials-container .menu-title .socials {
    line-height: 0;
  }

  header.egloo .header-bar .header-bar-wrapper ul.first-level > li.socials-container .menu-title .socials svg {
    color: #7c7c7c;
  }

  header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-head .menu-title {
    justify-content: space-between;
  }

  header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-head .menu-title svg {
    height: 2.125rem;
    width: 2.125rem;
    padding: 10px;
    margin-right: -10px;
  }

  header.egloo .header-bar .header-bar-wrapper-mobile {
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: relative;
    z-index: 2;
    height: var(--header-height);
    margin-inline: calc(-1 * var(--container-x-padding));
    padding-inline: var(--container-x-padding);
  }

  header.egloo .header-bar .header-bar-wrapper-mobile .buttons-wrapper {
    display: flex;
    gap: 0.75rem;
  }

  header.egloo .header-bar .header-bar-wrapper-mobile .buttons-wrapper > a {
    height: 2.25rem;
    width: 2.25rem;
    border-radius: 50%;
    border: 1px solid #eaeaea;
    background-color: var(--c-white);
    display: grid;
    place-items: center;
    transition: transform 150ms ease, opacity 150ms ease;
    transform: scale(0);
    opacity: 0;
    position: relative;
  }

  header.egloo .header-bar .header-bar-wrapper-mobile .buttons-wrapper > a > .cart-contents-count {
    position: absolute;
    top: 0;
    right: 0;
    box-shadow: 0 0 0 2px var(--c-danger);
    background: var(--c-danger);
    border-radius: 53rem;
    display: grid;
    line-height: 1;
    place-items: center;
    font-weight: 600;
    font-size: 14px;
    color: white;
    transform: translateX(29%) translateY(-36%);
    padding-inline: 0.3rem;
  }

  body.mobile-menu-open header.egloo .header-bar .header-bar-wrapper-mobile .buttons-wrapper > a {
    opacity: 1;
    transform: scale(1);
  }

  header.egloo .header-bar .header-bar-wrapper-mobile .buttons-wrapper #header-mobile-toggle {
    height: 2.25rem;
    width: 2.25rem;
    border-radius: 50%;
    background-color: #dfedff;
    display: grid;
    place-items: center;
  }

  header.egloo .header-bar .header-bar-wrapper-mobile .buttons-wrapper #header-mobile-toggle span {
    line-height: 0;
  }

  header.egloo .header-bar .header-bar-wrapper-mobile .buttons-wrapper #header-mobile-toggle span svg {
    color: var(--c-accent);
    max-width: 0.9375rem;
  }

  body.mobile-menu-open header.egloo .header-bar .header-bar-wrapper-mobile .buttons-wrapper #header-mobile-toggle .opener,
  body:not(.mobile-menu-open) header.egloo .header-bar .header-bar-wrapper-mobile .buttons-wrapper #header-mobile-toggle .closer {
    display: none;
  }

  header.egloo .header-bar .header-bar-wrapper-mobile .header-logo {
    display: grid;
    max-width: 5.9375rem;
  }

  header.egloo .header-bar .header-bar-wrapper-mobile .header-logo img {
    grid-column: -1/1;
    grid-row: -1/1;
    transition: opacity 0.3s ease 0.3s;
  }

  header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-body {
    position: static;
  }

  header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-head.menu-open + .menu-accordion-body {
    grid-template-rows: 1fr;
  }

  header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-body .menu-accordion-content {
    padding: 0;
    padding-top: 1.875rem;
  }

  header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-body .menu-accordion-content .zones {
    display: flex;
    flex-direction: column;
    gap: 3.125rem;
  }

  header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-body .menu-accordion-content .zones .zone.zone-menu .dropdown-title {
    display: none;
  }

  header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-body .menu-accordion-content .zones .zone.zone-menu ul {
    gap: 1.875rem;
  }

  header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-body .menu-accordion-content .zones .zone.zone-cards .see-all {
    display: none;
  }

  header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-body .menu-accordion-content .zones .zone.zone-cards .cards-wrapper {
    display: flex;
    flex-direction: column;
    gap: 1.875rem;
  }

  header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-body .menu-accordion-content .zones .zone.zone-cards .cards-wrapper .card .img-wrapper {
    padding-bottom: 43.8596%;
  }

  header.egloo .header-bar .header-bar-wrapper ul.first-level > li .menu-btn {
  }

  body.mobile-menu-open {
    overflow: hidden;
  }

  body.mobile-menu-open header.egloo {
    --header-bar-fg-color: var(--c-black);
  }

  body.mobile-menu-open header.egloo .header-bar-wrapper-mobile {
    background-color: var(--c-white);
    border-bottom: 1px solid rgba(173, 173, 173, 0.3);
  }

  header.egloo .header-bar .header-bar-wrapper-mobile .header-logo img {
    transition-delay: 0s;
  }

  body.mobile-menu-open header.egloo .header-bar {
  }

  body.mobile-menu-open header.egloo .header-bar .header-bar-wrapper-mobile .header-logo .logo {
    opacity: 1 !important;
  }

  body.mobile-menu-open header.egloo .header-bar .header-bar-wrapper-mobile .header-logo .logo-white {
    opacity: 0 !important;
  }

  body.mobile-menu-open header.egloo .header-bar .header-bar-wrapper {
    transform: translateX(0%);
  }

  header.egloo .header-bar .header-bar-wrapper .menu-accordion .menu-accordion-head.menu-open svg {
    transform: translateY(2px) rotate(-180deg);
  }
}

#skip-to-content {
  position: fixed;
  top: 2rem;
  left: 2rem;
  z-index: 100;
}

#skip-to-content:not(:focus-visible) {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}

/*
* ==============================================
CONTACT FORM
* ==============================================
*/

section.contact-form .layers .layer.layer-bg::after {
  background-image: linear-gradient(transparent 40%, var(--c-white) 65%);
}

section.contact-form .layers .layer.layer-bg .img-wrapper {
  height: 100%;
}

section.contact-form .layers .layer.layer-fg {
  max-width: calc(45rem + (var(--container-x-padding) * 2));
  padding-block: 9.375rem;
  padding-inline: var(--container-x-padding);
  margin-inline: auto;
  width: 100%;
}

section.contact-form .layers .layer.layer-fg .form-container {
  background-color: var(--c-white);
  border-radius: 1rem;
  box-shadow: 0 12px 30px #00000014;
  padding: 3.125rem;
  display: grid;
  gap: 2.6875rem;
}

section.contact-form .layers .layer.layer-fg .form-container .form-title {
  text-align: center;
}

section.contact-form .layers .layer.layer-fg .form-container .form-wrapper br {
  display: none;
}

section.contact-form .layers .layer.layer-fg .form-container .form-wrapper .label-name {
  display: block;
  font-weight: 500;
  margin-bottom: 0.625rem;
}

section.contact-form .layers .layer.layer-fg .form-container .form-wrapper label:has(:required, [aria-required="true"]) span.label-name::after {
  content: " *";
  color: var(--c-accent);
}

section.contact-form .layers .layer.layer-fg .form-container .form-wrapper textarea,
section.contact-form .layers .layer.layer-fg .form-container .form-wrapper input {
  outline: none;
  background-color: #f8f8f8;
}

section.contact-form .layers .layer.layer-fg .form-container .form-wrapper textarea,
section.contact-form .layers .layer.layer-fg .form-container .form-wrapper input:not([type="checkbox"]) {
  width: 100%;
}

section.contact-form .layers .layer.layer-fg .form-container .form-wrapper form {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
  row-gap: 2rem;
}

section.contact-form .layers .layer.layer-fg .form-container .form-wrapper form > .wpcf7-response-output,
section.contact-form .layers .layer.layer-fg .form-container .form-wrapper form > :nth-child(8),
section.contact-form .layers .layer.layer-fg .form-container .form-wrapper form > :nth-child(9),
section.contact-form .layers .layer.layer-fg .form-container .form-wrapper form > :nth-child(10),
section.contact-form .layers .layer.layer-fg .form-container .form-wrapper form > :nth-child(11) {
  grid-column: -1/1;
}

section.contact-form .layers .layer.layer-fg .form-container .form-wrapper form > .wpcf7-response-output {
  margin: 0;
  border-radius: 0.5rem;
  padding: 1rem 2rem;
  text-align: center;
}

section.contact-form .layers .layer.layer-fg .form-container .form-wrapper form .wpcf7-list-item {
  margin: 0;
}

section.contact-form .layers .layer.layer-fg .form-container .form-wrapper form .wpcf7-list-item label {
  display: flex;
  align-items: center;
  gap: 0.625rem;
}

section.contact-form .layers .layer.layer-fg .form-container .form-wrapper form .wpcf7-spinner {
  display: none;
}

section.contact-form .layers .layer.layer-fg .form-container .form-wrapper form p:has(small) {
  margin-top: -1rem;
}

section.contact-form .layers .layer.layer-fg .form-container .form-wrapper form p small {
  font-style: italic;
  color: var(--c-accent);
  font-size: 1rem;
  line-height: 1.1875;
}

section.contact-form .layers .layer.layer-fg .form-container .form-wrapper .btn {
  width: 100%;
  max-width: 18.875rem;
}

@media only screen and (max-width: 768px) {
  section.contact-form .layers .layer.layer-bg {
    max-height: 50vh;
  }

  section.contact-form .layers .layer.layer-fg .form-container .form-wrapper form {
    row-gap: 1.25rem;
  }

  section.contact-form .layers .layer.layer-fg {
    padding-top: 15.625rem;
    padding-bottom: 4rem;
  }

  section.contact-form .layers .layer.layer-fg .form-container .form-wrapper form {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
  }

  section.contact-form .layers .layer.layer-fg .form-container .form-wrapper .btn {
    max-width: none;
  }

  section.contact-form .layers .layer.layer-fg .form-container {
    padding: 3.125rem 1rem;
  }
}

/*
* ==============================================
BREADCRUMB
* ==============================================
*/

#breadcrumbs {
  --breadcrumb-gap: 1rem;
  display: flex;
  gap: var(--breadcrumb-gap);
  font-size: 0.875rem;
  line-height: 1.214286;
}

#breadcrumbs li {
  color: #8b8b8b;
  opacity: 0.6;
}

.hero.hero-half #breadcrumbs li {
  color: #ffffff;
}

#breadcrumbs li:last-child {
  opacity: 1;
  font-weight: 700;
}

#breadcrumbs li:not(:last-child) {
  position: relative;
}

#breadcrumbs li:not(:last-child)::after {
  content: "|";
  position: absolute;
  right: calc((-1 * var(--breadcrumb-gap) / 2));
  transform: translateX(50%) translateY(-5%);
}
