/* Variables
  **********************************/
@import url("variables.css");
/* ******************************* */

.region-header nav ul:not(.contextual-links) {
  display: flex;
  align-items: center;
  gap: 2rem;
}

#block-nav-main {
  width: 100%;
}

.main-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1.8rem;
  padding: 0;
  margin: 0;
}

.main-nav {
  flex-wrap: wrap;
  gap: 0 1.8rem;
}

.main-nav-item {
  list-style: none;
  position: relative;
  font-family: var(--overpass);
}

.main-nav-link {
  color: var(--amarillo);
  background: transparent;
  display: block;
  text-decoration: none;
  padding: 0.5rem 0;
  font-size: var(--text-general);
  font-weight: var(--light);
}

.main-nav-item--expanded > .main-nav-link:hover {
  color: var(--rosa);
}

.main-nav-link:hover {
  color: var(--rosa);
}

.main-nav-link.main-nav-link--active {
  position: relative;
}

.main-nav-item:hover > .main-nav-link {
  color: var(--rosa);
}

.main-nav-item:hover .main-nav-submenu .main-nav-link:hover {
  color: var(--gris);
  background: var(--amarillo-claro);
}

.main-nav-link.main-nav-link--active:hover {
  text-decoration-color: white;
}

.main-nav-submenu {
  padding: 0;
  margin: 0;
  position: absolute;
  top: 2.3rem;
  left: -12px;
  min-width: 350px;
  opacity: 0;
  transition: all 0.2s;
  pointer-events: none;
  z-index: -9;
  background: #030b0e;
  background: linear-gradient(0deg, rgba(3, 11, 14, 0.9) 36%, rgba(3, 11, 14, 0) 100%);
  padding: 3rem;
}

.main-nav-submenu .main-nav-link {
  display: block;
  text-transform: none;
  text-decoration: none;
  font-size: var(--text-general-small);
  padding: 0.5rem;
  border-radius: 8px;
  line-height: 1.2em;
}

.main-nav-item:hover .main-nav-submenu,
.main-nav-item:hover .main-nav-submenu:hover {
  opacity: 1;
  z-index: 9;
  pointer-events: all;
}

.main-nav-submenu .main-nav-link.main-nav-link--active::after {
  display: none;
}

.main-nav-item {
  flex: auto;
}

.main-nav-item.logo {
  flex: 7;
  text-align: center;
}

.main-nav-item.logo .main-nav-link {
  font-size: 0;
  display: inline-block;
}

.main-nav-item.logo .main-nav-link::before {
  content: "";
  background: url(/themes/custom/eclipse/logo.png) transparent center / contain no-repeat;
  width: 140px;
  aspect-ratio: 160 / 140;
  display: block;
}

.main-nav-item.servicios,
.main-nav-item.regala {
  text-align: right;
}

.main-nav-item.servicios {
  position: inherit;
}

.main-nav-item.servicios > .main-nav-submenu {
  top: 85px;
  left: 0;
  width: 100%;
  /* height: calc(60vh - 85px); */
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  grid-gap: 3rem;
  border-bottom: var(--border-base);
  padding-block-start: 10rem;
}

/* .main-nav-item.servicios > .main-nav-submenu::before {
  content: "";
  position: absolute;
  top: 2rem;
  left: 0;
  width: 100%;
  height: 1px;
  background: var(--linea);
} */

.main-nav-item.servicios > .main-nav-submenu > .main-nav-item {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: stretch;
  height: 100%;
}

.main-nav-item.servicios > .main-nav-submenu > .main-nav-item > .main-nav-link {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: center;
  gap: 2rem;
  height: 100%;
  padding-block: 2rem;
}

.main-nav-item.servicios > .main-nav-submenu > .main-nav-item > .main-nav-link::before {
  content: "";
  block-size: clamp(50px, 5vw, 100px);
  display: block;
  aspect-ratio: 1 / 1;
  background-color: transparent;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

.main-nav-item.servicios > .main-nav-submenu > .main-nav-item.circuito-banos > .main-nav-link::before {
  background-image: url(/sites/default/files/2025-10/icon-circuito-aguas.svg);
}

.main-nav-item.servicios > .main-nav-submenu > .main-nav-item.venus-25 > .main-nav-link::before {
  background-image: url(/sites/default/files/2025-10/icon-masaje-25.svg);
}

.main-nav-item.servicios > .main-nav-submenu > .main-nav-item.venus-40 > .main-nav-link::before {
  background-image: url(/sites/default/files/2025-10/icon-masaje-40.svg);
}

.main-nav-item.servicios > .main-nav-submenu > .main-nav-item.venus-55 > .main-nav-link::before {
  background-image: url(/sites/default/files/2025-10/icon-masaje-55.svg);
}

.main-nav-item.servicios > .main-nav-submenu > .main-nav-item.estrella > .main-nav-link::before {
  background-image: url(/sites/default/files/2025-10/icon-estrella.svg);
}

.main-nav-item.servicios > .main-nav-submenu > .main-nav-item.eclipse > .main-nav-link::before {
  background-image: url(/sites/default/files/2025-10/icon-eclipse.svg);
}

.main-nav-item.servicios > .main-nav-submenu > .main-nav-item.calypso > .main-nav-link::before {
  background-image: url(/sites/default/files/2025-10/icon-calypso.svg);
}

.main-nav-item.servicios > .main-nav-submenu > .main-nav-item.orion > .main-nav-link::before {
  background-image: url(/sites/default/files/2025-10/icon-orion.svg);
}

.main-nav-item.servicios > .main-nav-submenu > .main-nav-item.ceres > .main-nav-link::before {
  background-image: url(/sites/default/files/2025-10/icon-ceres.svg);
}

.main-nav-item.servicios > .main-nav-submenu > .main-nav-item.via-lactea > .main-nav-link::before {
  background-image: url(/sites/default/files/2025-10/icon-vialactea.svg);
}

/* Main nav responsive */

#block-main-nav-toggle {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  border: 1px solid transparent;
  font-size: 0;
  cursor: pointer;
  transition: all 0.2s;
  position: relative;
  display: none;
  position: absolute;
  top: var(--pm-block-blend);
  left: var(--pm-block-blend);
  z-index: 999;
}

#block-main-nav-toggle .nav-item,
#block-main-nav-toggle::before,
#block-main-nav-toggle::after {
  position: absolute;
  left: 50%;
  width: 50%;
  height: 2px;
  background: var(--barro);
}

#block-main-nav-toggle .nav-item {
  top: 50%;
  transform: translate(-50%, -50%);
}

#block-main-nav-toggle::before,
#block-main-nav-toggle::after {
  content: "";
  transform: translateX(-50%);
}

#block-main-nav-toggle::before {
  top: calc(100% / 3);
}

#block-main-nav-toggle::after {
  bottom: calc(100% / 3);
}

#block-main-nav-toggle.nav-toggle-active {
  border: 1px solid var(--barro);
  background: transparent;
  z-index: 99;
}

#block-main-nav-toggle.nav-toggle-active .nav-item {
  opacity: 0;
}

#block-main-nav-toggle.nav-toggle-active::before {
  top: 50%;
  transform: translate(-50%, -50%) rotate(45deg);
}

#block-main-nav-toggle.nav-toggle-active::after {
  top: 50%;
  transform: translate(-50%, -50%) rotate(-45deg);
}

.toggle-hidden #block-main-nav-toggle {
  display: none !important;
}

.overlay {
  position: fixed;
  background: var(--amarillo);
  inset: 100px 0 0 100%;
  visibility: hidden;
  pointer-events: none;
  opacity: 0;
  z-index: 99;
  overflow: auto;
  transition: inset 0.2s ease, opacity 0.2s ease;
  border-radius: 5vw 0 0 0;
  height: calc(100vh - 100px);
}

.overlay.nav-active {
  inset: 100px 0 0 0;
  visibility: visible;
  pointer-events: all;
  opacity: 1;
}

.overlay.nav-active a {
  pointer-events: auto;
}

/* Nav footer */

.nav-footer {
}

.nav-column .main-nav {
  flex-direction: column;
  align-items: flex-end;
  gap: 0.3rem;
}

.nav-footer .main-nav-link {
  color: white;
  background: transparent;
  padding: 0;
  font-size: calc(var(--text-general) - 0.3rem);
  text-decoration: none;
}

.nav-footer .main-nav-link:hover {
  color: var(--amarillo);
  background: transparent;
  text-decoration: none;
}

.nav-footer .main-nav-link::after {
  display: none;
}

/* Nav Clean & Nav Expand */

.nav-expand .main-nav-submenu {
  position: relative;
  top: inherit;
  left: 0;
  opacity: 1;
  pointer-events: all;
  z-index: inherit;
  min-width: auto;
}

.nav-expand .main-nav {
  align-items: flex-start;
}

.nav-clean .main-nav-link {
  color: white;
  background: transparent;
}

.nav-clean .main-nav-item > .main-nav-link {
  font-weight: var(--bold);
  font-size: calc(var(--text-general) - 0.2rem);
}

.nav-clean .main-nav-item:hover > .main-nav-link {
  color: white;
  background: transparent;
}

.nav-clean .main-nav-submenu .main-nav-link {
  font-size: calc(var(--text-general) - 0.2rem);
  font-weight: var(--medium);
}

.nav-clean .main-nav-item .main-nav-link:hover,
.nav-clean .main-nav-submenu .main-nav-link:hover {
  background: rgba(255, 255, 255, 0.1) !important;
}

/* Nav legal */

.nav-legal ul:not(.contextual-links) {
  display: flex;
  flex-wrap: nowrap;
  gap: 1rem;
}

/* Responsive */

@media all and (max-width: 900px) {
  .nav-grid .main-nav {
    display: flex !important;
    flex-direction: column;
    gap: 1rem !important;
  }

  #header-template-two {
    display: flex !important;
    flex-direction: column;
    align-items: flex-start !important;
    justify-content: flex-start;
    grid-gap: 1rem !important;
  }

  #block-main-nav-toggle {
    display: block !important;
  }

  .nav-expand #block-main-nav-toggle {
    display: none !important;
  }

  .main-nav .main-nav-link {
    /* color: white; */
    background-color: rgba(255, 255, 255, 0);
  }

  .main-nav.nav-active {
    display: block;
    padding: 2rem 0 100px 1rem;
  }

  .main-nav.nav-active > .main-nav-item {
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  }

  .main-nav.nav-active .main-nav-item:hover > .main-nav-link,
  .main-nav.nav-active .main-nav-link {
    color: var(--gris);
    text-decoration: none;
    background: transparent;
  }

  .main-nav.nav-active .main-nav-link {
    -webkit-tap-highlight-color: transparent;
    /* quita el resaltado azul de iOS */
    touch-action: manipulation;
    /* mejora la respuesta táctil */
    background-color: rgba(255, 255, 255, 0);
    transition: background-color 0.2s ease, transform 0.2s ease;
    font-size: calc(var(--text-general) + 0.3rem);
    padding: 0.8rem 1rem;
  }

  .main-nav.nav-active .main-nav-link:hover,
  .main-nav.nav-active .main-nav-link:focus,
  .main-nav.nav-active .main-nav-link:active {
    background: var(--amarillo-claro) !important;
    border-radius: 15px 0 0 15px;
  }

  .overlay .main-nav-link.main-nav-link--active.is-active {
    background: var(--amarillo-light) !important;
    border-radius: 15px 0 0 15px;
  }

  .main-nav.nav-active .main-nav-submenu {
    position: relative;
    top: inherit;
    left: 0;
    opacity: 1;
    pointer-events: all;
    z-index: inherit;
    min-width: auto;
    padding: 1rem 0 1rem 1rem;
    /* width: 100vw; */
    background: var(--amarillo-claro);
  }

  .main-nav.nav-active .main-nav-submenu .main-nav-link {
    font-size: var(--text-general);
    padding-right: 2em;
    padding-left: 0;
  }

  .main-nav-link.main-nav-link--active::after,
  .main-nav-item.main-nav-item--expanded > .main-nav-link.main-nav-link--active::after {
    display: none;
  }

  .nav-grid .main-nav .main-nav-item .main-nav-link {
    gap: 3rem;
  }
}

/* Enlaces con iconos */

.nav-icons .contextual {
  display: none !important;
}

.nav-icons {
  max-width: var(--width-medium);
  margin-inline: auto;
}

.nav-icons ul {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  justify-content: space-between;
  align-items: stretch;
  gap: 3rem;
  counter-reset: section;
}

.nav-icons ul li {
  border: 1px solid var(--gris);
  border-radius: 50px;
  position: relative;
  margin-bottom: 0;
  transition: all 0.2s;
  height: clamp(330px, 15vw, 400px);
}

.nav-icons ul li > div,
.nav-icons ul li > div .enlace-icono,
.nav-icons ul li > div .enlace-icono a {
  height: 100%;
}

.nav-icons ul li:hover {
  border: 1px solid var(--amarillo);
  background: var(--amarillo);
}

.enlace-icono a {
  text-decoration: none;
  font-family: var(--overpass);
  font-size: var(--text-general);
  padding: var(--pm-block-blend);
  font-weight: var(--bold);
  height: 100%;
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: flex-start;
  gap: 6rem;
}

.enlace-icono a::before {
  position: absolute;
  top: var(--pm-block-blend);
  right: var(--pm-block-blend);
  counter-increment: section;
  content: counter(section);
  font-size: var(--text-general);
  font-weight: var(--bold);
  background: var(--amarillo);
  color: var(--gris);
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50px;
  width: 50px;
  aspect-ratio: 1 / 1;
}

.nav-icons ul li:hover .enlace-icono a::before {
  color: var(--amarillo);
  background: var(--gris);
}

.nav-icon {
  position: absolute;
  top: var(--pm-block-blend);
  left: var(--pm-block-blend);
  width: auto;
  height: clamp(50px, 6vw, 100px);
}

.nav-icon .image-svg {
  overflow: hidden;
  display: block;
  width: auto;
  height: clamp(50px, 6vw, 100px);
}

.nav-icon .image-svg img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: contain;
  object-position: left;
}

@media all and (max-width: 1460px) {
}

@media all and (max-width: 1024px) {
  .nav-icons ul {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media all and (max-width: 780px) {
  .nav-icons ul {
    display: flex;
    flex-direction: column;
    gap: 1rem;
  }
}

@media all and (max-width: 480px) {
}
