/*
 * Mega menu - Hoteles de la Villa Hermoza
 * Estructura esperada:
 * Rooms -> Standard room / Superior room -> habitaciones.
 */

#header-nav .ab-mega-menu-trigger {
  position: relative !important;
}

#header-nav .ab-mega-menu-panel {
  display: flex !important;
  align-items: stretch !important;
  width: 760px !important;
  min-width: 760px !important;
  max-width: calc(100vw - 48px) !important;
  min-height: 252px !important;
  margin-top: 0 !important;
  padding: 0 !important;
  gap: 0 !important;
  top: 100% !important;
  right: auto !important;
  left: 50% !important;
  translate: 0 0 !important;
  scale: 1 !important;
  transform: translateX(-50%) translateY(4px) !important;
  transform-origin: top center !important;
  border: 1px solid rgba(191, 153, 88, 0.34) !important;
  border-top: 3px solid #bf9958 !important;
  border-radius: 5px !important;
  background: #fff !important;
  box-shadow:
    0 28px 70px rgba(15, 23, 42, 0.22),
    0 10px 24px rgba(88, 48, 22, 0.10) !important;
  overflow: hidden !important;
  /* Prevent hover from triggering while the panel is invisible */
  pointer-events: none !important;
}

#header-nav .ab-mega-menu-panel::before,
#header-nav .ab-mega-menu-panel::after {
  display: none !important;
  content: none !important;
}

#header-nav .ab-mega-menu-trigger:hover > .ab-mega-menu-panel,
#header-nav .ab-mega-menu-trigger:focus-within > .ab-mega-menu-panel {
  opacity: 1 !important;
  visibility: visible !important;
  translate: 0 0 !important;
  scale: 1 !important;
  transform: translateX(-50%) translateY(0) !important;
  /* Restore pointer events when the panel is visible */
  pointer-events: auto !important;
}

/* Restore pointer-events on ALL children inside the visible panel
   (nested .sub-menu lists and their links inherit pointer-events:none
    from the generic main.css sub-menu rule — override that here) */
#header-nav .ab-mega-menu-trigger:hover > .ab-mega-menu-panel *,
#header-nav .ab-mega-menu-trigger:focus-within > .ab-mega-menu-panel * {
  pointer-events: auto !important;
}

#header-nav .ab-mega-menu-column {
  position: relative !important;
  display: flex !important;
  flex: 1 1 0 !important;
  flex-direction: column !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 24px 24px 22px !important;
  border-right: 1px solid rgba(191, 153, 88, 0.18) !important;
  background:
    linear-gradient(180deg, rgba(253, 249, 244, 0.78), rgba(255, 255, 255, 0.96)) !important;
}

#header-nav .ab-mega-menu-column > a {
  display: block !important;
  min-height: auto !important;
  margin: 0 0 14px !important;
  padding: 0 0 13px !important;
  border-bottom: 1px solid rgba(191, 153, 88, 0.30) !important;
  border-radius: 0 !important;
  color: #583016 !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  line-height: 1.2 !important;
  letter-spacing: 0.16em !important;
  text-transform: uppercase !important;
  background: transparent !important;
}

#header-nav .ab-mega-menu-column > a::before,
#header-nav .ab-mega-menu-column > a::after {
  display: none !important;
  content: none !important;
}

#header-nav .ab-mega-menu-items {
  position: static !important;
  display: flex !important;
  flex: 1 1 auto !important;
  flex-direction: column !important;
  justify-content: flex-start !important;
  width: 100% !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  gap: 2px !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  opacity: 1 !important;
  visibility: visible !important;
  top: auto !important;
  right: auto !important;
  bottom: auto !important;
  left: auto !important;
  translate: 0 0 !important;
  transform: none !important;
  scale: 1 !important;
  transition: none !important;
}

#header-nav .ab-mega-menu-items::before,
#header-nav .ab-mega-menu-items::after {
  display: none !important;
  content: none !important;
}

#header-nav .ab-mega-menu-link-item {
  position: static !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  translate: 0 0 !important;
  transform: none !important;
}

#header-nav .ab-mega-menu-link-item > a {
  position: relative !important;
  display: flex !important;
  align-items: center !important;
  width: 100% !important;
  min-height: 34px !important;
  padding: 8px 10px 8px 22px !important;
  border-radius: 4px !important;
  color: #263241 !important;
  font-size: 12.5px !important;
  font-weight: 500 !important;
  line-height: 1.3 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  background: transparent !important;
  border-bottom: 1px solid rgba(88, 48, 22, 0.06) !important;
  white-space: normal !important;
  overflow: visible !important;
  translate: 0 0 !important;
  transform: none !important;
  transition:
    color 0.2s ease,
    background 0.2s ease,
    padding-left 0.2s ease !important;
}

#header-nav .ab-mega-menu-link-item > a::before {
  content: "" !important;
  position: absolute !important;
  left: 6px !important;
  top: 50% !important;
  width: 8px !important;
  height: 1px !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: rgba(191, 153, 88, 0.78) !important;
  transform: translateY(-50%) !important;
  transition: background 0.2s ease, transform 0.2s ease !important;
}

#header-nav .ab-mega-menu-link-item > a::after {
  display: none !important;
  content: none !important;
}

#header-nav .ab-mega-menu-link-item > a:hover,
#header-nav .ab-mega-menu-link-item > a:focus {
  padding-left: 26px !important;
  color: #583016 !important;
  background: rgba(191, 153, 88, 0.12) !important;
}

#header-nav .ab-mega-menu-link-item > a:hover::before,
#header-nav .ab-mega-menu-link-item > a:focus::before {
  background: #bf9958 !important;
  transform: translateY(-50%) scaleX(1.35) !important;
}

#header-nav .mega-menu-image-col {
  position: relative !important;
  flex: 0 0 258px !important;
  min-width: 258px !important;
  min-height: 252px !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  overflow: hidden !important;
}

#header-nav .mega-menu-image-wrap {
  position: absolute !important;
  inset: 0 !important;
  display: flex !important;
  align-items: flex-end !important;
  padding: 24px !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
  background-size: cover !important;
  transform: scale(1.01) !important;
  transition: transform 0.45s ease, filter 0.45s ease !important;
}

#header-nav .mega-menu-image-wrap::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background:
    linear-gradient(180deg, rgba(15, 23, 42, 0.00) 35%, rgba(15, 23, 42, 0.54) 100%),
    linear-gradient(45deg, rgba(88, 48, 22, 0.20), transparent 55%) !important;
}

#header-nav .mega-menu-image-col:hover .mega-menu-image-wrap {
  filter: saturate(1.05) contrast(1.03) !important;
  transform: scale(1.05) !important;
}

@media (max-width: 1180px) {
  #header-nav .ab-mega-menu-panel {
    width: 700px !important;
    min-width: 700px !important;
  }

  #header-nav .ab-mega-menu-column {
    padding: 22px 20px !important;
  }

  #header-nav .mega-menu-image-col {
    flex-basis: 230px !important;
    min-width: 230px !important;
  }
}

/*
 * Polylang language dropdown.
 */
#header-nav .pll-parent-menu-item > .sub-menu,
#header-nav .menu-item-language > .sub-menu,
#header-nav .lang-item.menu-item-has-children > .sub-menu {
  width: 118px !important;
  min-width: 118px !important;
  margin-top: 14px !important;
  padding: 10px !important;
  border-radius: 6px !important;
  background: rgba(255, 255, 255, 0.98) !important;
  box-shadow: 0 18px 42px rgba(15, 23, 42, 0.18) !important;
}

/* Hover bridge to prevent closing when crossing the 14px gap */
#header-nav .pll-parent-menu-item > .sub-menu::after,
#header-nav .menu-item-language > .sub-menu::after,
#header-nav .lang-item.menu-item-has-children > .sub-menu::after {
  content: "" !important;
  position: absolute !important;
  top: -18px !important;
  left: 0 !important;
  right: 0 !important;
  height: 18px !important;
  background: transparent !important;
  z-index: 1 !important;
}

#header-nav .pll-parent-menu-item > .sub-menu .menu-item,
#header-nav .menu-item-language > .sub-menu .menu-item,
#header-nav .lang-item.menu-item-has-children > .sub-menu .menu-item {
  margin: 0 !important;
  padding: 0 !important;
}

#header-nav .pll-parent-menu-item > .sub-menu a,
#header-nav .menu-item-language > .sub-menu a,
#header-nav .lang-item.menu-item-has-children > .sub-menu a {
  display: flex !important;
  align-items: center !important;
  gap: 7px !important;
  min-height: 28px !important;
  padding: 6px 8px !important;
  border-radius: 4px !important;
  color: #263241 !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  white-space: nowrap !important;
}

#header-nav .pll-parent-menu-item > .sub-menu a::before,
#header-nav .menu-item-language > .sub-menu a::before,
#header-nav .lang-item.menu-item-has-children > .sub-menu a::before {
  display: none !important;
  content: none !important;
}

#header-nav .pll-parent-menu-item > .sub-menu a:hover,
#header-nav .menu-item-language > .sub-menu a:hover,
#header-nav .lang-item.menu-item-has-children > .sub-menu a:hover {
  padding-left: 8px !important;
  color: #583016 !important;
  background: rgba(191, 153, 88, 0.12) !important;
}

#header-nav .pll-parent-menu-item > .sub-menu img,
#header-nav .menu-item-language > .sub-menu img,
#header-nav .lang-item.menu-item-has-children > .sub-menu img {
  display: inline-block !important;
  width: 16px !important;
  height: auto !important;
  margin: 0 !important;
  flex: 0 0 auto !important;
}

/*
 * Live room search overlay.
 */
.room-live-search-results {
  display: none;
  width: 100%;
  margin-top: 22px;
  border: 1px solid rgba(255, 255, 255, 0.10);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.07);
  backdrop-filter: blur(18px);
  overflow: hidden;
}

.room-live-search-results.is-visible {
  display: block;
}

.room-live-search-item {
  display: grid;
  grid-template-columns: 72px minmax(0, 1fr) auto;
  align-items: center;
  gap: 16px;
  padding: 14px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  color: #fff;
  transition: background 0.2s ease, transform 0.2s ease;
}

.room-live-search-item:last-child {
  border-bottom: 0;
}

.room-live-search-item:hover,
.room-live-search-item:focus {
  background: rgba(191, 153, 88, 0.14);
}

.room-live-search-thumb {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 72px;
  height: 56px;
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.10);
  overflow: hidden;
  color: #bf9958;
}

.room-live-search-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.room-live-search-copy {
  min-width: 0;
}

.room-live-search-copy strong {
  display: block;
  margin-bottom: 4px;
  color: #fff;
  font-size: 14px;
  font-weight: 800;
  line-height: 1.2;
}

.room-live-search-copy small {
  display: -webkit-box;
  color: rgba(255, 255, 255, 0.58);
  font-size: 12px;
  line-height: 1.35;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.room-live-search-price {
  color: #bf9958;
  font-size: 13px;
  font-weight: 800;
  white-space: nowrap;
}

.room-live-search-loading,
.room-live-search-empty {
  padding: 18px;
  color: rgba(255, 255, 255, 0.64);
  text-align: center;
  font-size: 13px;
}

.room-live-search-empty span {
  display: block;
  color: #fff;
  font-weight: 800;
}

.room-live-search-empty small {
  display: block;
  margin-top: 4px;
  color: rgba(255, 255, 255, 0.50);
}

@media (max-width: 640px) {
  .room-live-search-item {
    grid-template-columns: 58px minmax(0, 1fr);
    gap: 12px;
    padding: 12px;
  }

  .room-live-search-thumb {
    width: 58px;
    height: 48px;
  }

  .room-live-search-price {
    grid-column: 2;
    margin-top: -4px;
  }
}

/*
 * Mobile menu drawer.
 */
@media (max-width: 1023px) {
  #mobile-menu-panel {
    width: min(100vw, 430px) !important;
    background: #fff !important;
    color: #2f3337 !important;
  }

  #mobile-menu-panel .mobile-menu-topbar {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    min-height: 72px !important;
    padding: 12px 14px 12px 18px !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.10) !important;
    background: #0f172a !important;
    box-shadow: 0 14px 34px rgba(15, 23, 42, 0.18) !important;
  }

  #mobile-menu-panel .mobile-menu-logo {
    display: block !important;
    flex: 1 1 auto !important;
    min-width: 0 !important;
  }

  #mobile-menu-panel .mobile-menu-logo img,
  #mobile-menu-panel .mobile-menu-logo-img {
    width: auto !important;
    height: 48px !important;
    max-width: 170px !important;
    object-fit: contain !important;
    filter: drop-shadow(0 10px 18px rgba(0, 0, 0, 0.22)) !important;
  }

  #mobile-menu-panel .mobile-menu-actions {
    display: flex !important;
    align-items: center !important;
    gap: 0 !important;
    flex: 0 0 auto !important;
  }

  #mobile-menu-panel .mobile-menu-actions a,
  #mobile-menu-panel .mobile-menu-actions button,
  #mobile-menu-panel .mobile-menu-close-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 34px !important;
    height: 38px !important;
    border-left: 1px solid rgba(255, 255, 255, 0.12) !important;
    color: #bf9958 !important;
    font-size: 16px !important;
    line-height: 1 !important;
    background: transparent !important;
  }

  #mobile-menu-panel .mobile-menu-actions a:nth-child(2) {
    color: #20a942 !important;
    font-size: 18px !important;
  }

  #mobile-menu-panel .mobile-menu-close-btn {
    color: #ffffff !important;
    font-size: 24px !important;
  }

  #mobile-menu-panel .mobile-menu-content {
    flex: 1 1 auto !important;
    overflow-y: auto !important;
    padding: 26px 18px 38px !important;
    background:
      linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(250,248,244,0.78) 100%) !important;
  }

  #mobile-menu-panel .mobile-menu-nav-wrap {
    width: 100% !important;
  }

  #mobile-menu-panel .mobile-nav > ul {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  #mobile-menu-panel .mobile-nav > ul > li {
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
  }

  #mobile-menu-panel .mobile-nav li a {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 45px !important;
    padding: 11px 38px !important;
    color: #858585 !important;
    font-size: 16px !important;
    font-weight: 800 !important;
    line-height: 1.15 !important;
    letter-spacing: 0.02em !important;
    text-align: center !important;
    text-transform: uppercase !important;
    background: transparent !important;
  }

  #mobile-menu-panel .mobile-nav li.current-menu-item > a,
  #mobile-menu-panel .mobile-nav li.current-menu-ancestor > a,
  #mobile-menu-panel .mobile-nav .menu-item-has-children.active > a {
    color: #583016 !important;
  }

  #mobile-menu-panel .mobile-nav .menu-item-has-children > a {
    position: relative !important;
  }

  #mobile-menu-panel .mobile-nav .menu-item-has-children > a::after {
    position: absolute !important;
    right: 8px !important;
    top: 50% !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 26px !important;
    height: 26px !important;
    margin: 0 !important;
    color: #858585 !important;
    font-size: 11px !important;
    background: transparent !important;
    transform: translateY(-50%) !important;
  }

  #mobile-menu-panel .mobile-nav .menu-item-has-children.active > a::after {
    color: #bf9958 !important;
    transform: translateY(-50%) rotate(180deg) !important;
  }

  #mobile-menu-panel .mobile-nav .sub-menu {
    max-height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    opacity: 0 !important;
    overflow: hidden !important;
    background: rgba(191, 153, 88, 0.06) !important;
  }

  #mobile-menu-panel .mobile-nav .menu-item-has-children.active > .sub-menu {
    max-height: 760px !important;
    padding: 4px 0 8px !important;
    opacity: 1 !important;
  }

  #mobile-menu-panel .mobile-nav .sub-menu li {
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
  }

  #mobile-menu-panel .mobile-nav .sub-menu a {
    min-height: 36px !important;
    padding: 9px 42px !important;
    color: #5f6670 !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    letter-spacing: 0.02em !important;
    text-transform: none !important;
  }

  #mobile-menu-panel .mobile-nav .sub-menu .menu-item-has-children > a {
    color: #583016 !important;
    font-size: 13px !important;
    text-transform: uppercase !important;
    pointer-events: none !important;
  }

  #mobile-menu-panel .mobile-nav .sub-menu .sub-menu {
    max-height: none !important;
    margin: 0 0 8px !important;
    padding: 0 0 8px !important;
    opacity: 1 !important;
    overflow: visible !important;
    background: rgba(255, 255, 255, 0.56) !important;
  }

  #mobile-menu-panel .mobile-nav > ul > .menu-item-has-children.active > .sub-menu > .menu-item-has-children > .sub-menu {
    display: block !important;
    max-height: none !important;
    opacity: 1 !important;
  }

  #mobile-menu-panel .mobile-nav > ul > .menu-item-has-children.active > .sub-menu > .menu-item-has-children > a::after {
    display: none !important;
    content: none !important;
  }

  #mobile-menu-panel .mobile-nav .sub-menu .sub-menu a {
    min-height: 32px !important;
    padding: 8px 36px !important;
    color: #6b7280 !important;
    font-size: 12px !important;
    font-weight: 600 !important;
  }

  #mobile-menu-panel .mobile-nav .pll-parent-menu-item > .sub-menu,
  #mobile-menu-panel .mobile-nav .menu-item-language > .sub-menu,
  #mobile-menu-panel .mobile-nav .lang-item.menu-item-has-children > .sub-menu {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 6px !important;
    padding: 8px 18px 12px !important;
  }

  #mobile-menu-panel .mobile-nav .pll-parent-menu-item.active > .sub-menu,
  #mobile-menu-panel .mobile-nav .menu-item-language.active > .sub-menu,
  #mobile-menu-panel .mobile-nav .lang-item.menu-item-has-children.active > .sub-menu {
    display: grid !important;
  }

  #mobile-menu-panel .mobile-nav .pll-parent-menu-item > .sub-menu a,
  #mobile-menu-panel .mobile-nav .menu-item-language > .sub-menu a,
  #mobile-menu-panel .mobile-nav .lang-item.menu-item-has-children > .sub-menu a {
    justify-content: center !important;
    gap: 7px !important;
    min-height: 34px !important;
    padding: 8px 10px !important;
    border: 1px solid rgba(88, 48, 22, 0.08) !important;
    border-radius: 4px !important;
    background: #fff !important;
    font-size: 11px !important;
    letter-spacing: 0.10em !important;
    text-transform: uppercase !important;
  }

  #mobile-menu-panel .mobile-nav img {
    display: inline-block !important;
    width: 16px !important;
    height: auto !important;
    margin: 0 !important;
  }
}

/* =====================================================
 * Current page indicator — Desktop nav
 * WordPress adds .current-menu-item, .current-menu-parent
 * .current-menu-ancestor to the <li> automatically.
 * ===================================================== */

/* Top-level link base: position needed for the underline */
#header-nav > ul > li > a {
  position: relative;
}

/* Gold animated underline for active top-level item */
#header-nav > ul > li.current-menu-item > a,
#header-nav > ul > li.current-menu-parent > a,
#header-nav > ul > li.current-menu-ancestor > a {
  color: #bf9958 !important;
}

#header-nav > ul > li.current-menu-item > a::after,
#header-nav > ul > li.current-menu-parent > a::after,
#header-nav > ul > li.current-menu-ancestor > a::after {
  content: '' !important;
  display: block !important;
  position: absolute !important;
  bottom: -4px !important;
  left: 0 !important;
  width: 100% !important;
  height: 2px !important;
  background: #bf9958 !important;
  border-radius: 2px !important;
  transform-origin: left center !important;
  animation: menu-underline-in 0.35s ease forwards !important;
}

@keyframes menu-underline-in {
  from { transform: scaleX(0); opacity: 0; }
  to   { transform: scaleX(1); opacity: 1; }
}

/* Current item inside mega-menu sub-items */
#header-nav .ab-mega-menu-link-item.current-menu-item > a,
#header-nav .ab-mega-menu-link-item.current-menu-item > a:hover {
  color: #bf9958 !important;
  font-weight: 800 !important;
}

#header-nav .ab-mega-menu-link-item.current-menu-item > a::before {
  background: #bf9958 !important;
  transform: scaleX(1) !important;
}

/* =====================================================
 * Current page indicator — Mobile nav (improvement)
 * ===================================================== */
@media (max-width: 1023px) {
  #mobile-menu-panel .mobile-nav li.current-menu-item > a,
  #mobile-menu-panel .mobile-nav li.current-menu-parent > a,
  #mobile-menu-panel .mobile-nav li.current-menu-ancestor > a {
    color: #bf9958 !important;
    position: relative !important;
  }

  /* Subtle left accent bar for active item */
  #mobile-menu-panel .mobile-nav > ul > li.current-menu-item > a::before,
  #mobile-menu-panel .mobile-nav > ul > li.current-menu-parent > a::before,
  #mobile-menu-panel .mobile-nav > ul > li.current-menu-ancestor > a::before {
    content: '' !important;
    position: absolute !important;
    left: 14px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    width: 3px !important;
    height: 18px !important;
    background: #bf9958 !important;
    border-radius: 2px !important;
  }

  /* Active sub-menu link */
  #mobile-menu-panel .mobile-nav .sub-menu li.current-menu-item > a {
    color: #bf9958 !important;
    font-weight: 800 !important;
  }
}

/* Prevent horizontal viewport overflow on mobile devices (under 768px) */
@media (max-width: 767px) {
  html,
  body {
    overflow-x: hidden !important;
  }
}
