/* ==========================================================================
   HOROH GRAND HOTEL | MAIN.CSS REVISADO
   Objetivo:
   - Consolidar variáveis e regras repetidas.
   - Remover customizações da barra de rolagem nativa.
   - Harmonizar header, hero, booking, modal e GTranslate.
   ========================================================================== */

/* ==========================================================================
   0. VARIÁVEIS GLOBAIS
   ========================================================================== */

:root {
  --horoh-bg: #002816;
  --horoh-gold: #d4b06a;
  --horoh-text: #f4efe7;
  --horoh-surface: #f7f2ea;
  --horoh-body: #1d1f1f;
  --horoh-dark: #050807;
  --horoh-max: 1320px;

  --horoh-header-height: 96px;
  --horoh-header-height-scrolled: 68px;
  --horoh-anchor-offset: 120px;

  --horoh-header-sticky-bg: #002816;
  --horoh-header-sticky-bg-strong: #002816;
  --horoh-header-sticky-border: rgba(0, 40, 22, 0.16);

  --horoh-font-logo: "Afrah Light", "Aboreto", serif;
  --horoh-font-title: "Afrah Light", "Aboreto", serif;
  --horoh-font-body: "RNS Sanz", "RNSSanz-Light", Arial, sans-serif;
}

/* ==========================================================================
   1. BASE / RESET
   ========================================================================== */

html {
  box-sizing: border-box;
  scroll-behavior: smooth;
  scroll-padding-top: var(--horoh-anchor-offset);
  overflow-x: hidden;
  background: var(--horoh-dark);
}

*,
*::before,
*::after {
  box-sizing: inherit;
}

html,
body {
  margin: 0;
  padding: 0;
  max-width: 100%;
}

body {
  width: 100%;
  overflow-x: hidden !important;
  font-family: var(--horoh-font-body);
  color: var(--horoh-body);
  background: #ffffff;
}

img,
video,
iframe,
svg {
  max-width: 100%;
}

img {
  height: auto;
  display: block;
}

a {
  text-decoration: none;
}

.horoh-shell a,
.horoh-slider-container a,
.horoh-taxonomias a {
  color: inherit;
  text-decoration: none;
}

#page,
.site,
.site-main,
.site-content {
  max-width: 100%;
  overflow-x: hidden;
}

.site-main {
  min-height: 40vh;
}

.site-content {
  min-height: 50vh;
  padding-top: var(--horoh-header-height);
}

.horoh-shell {
  width: min(100% - 32px, var(--horoh-max));
  margin: 0 auto;
}

.screen-reader-text {
  position: absolute !important;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  border: 0;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
  clip-path: inset(50%);
  word-wrap: normal !important;
}

/*
   IMPORTANTE:
   A barra de rolagem foi devolvida ao comportamento nativo do navegador.
   Este arquivo não define aparência, largura, cor ou trilho da barra.
*/

/* ==========================================================================
   2. HEADER NATIVO DO TEMA
   ========================================================================== */

.admin-bar .horoh-header {
  top: 32px;
}

.horoh-header {
  position: fixed;
  inset: 0 0 auto 0;
  width: 100%;
  z-index: 1000;
  background: linear-gradient(
    to bottom,
    rgba(35, 45, 43, 0.96),
    rgba(35, 45, 43, 0.82)
  );
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  transition:
    background 0.28s ease,
    box-shadow 0.28s ease,
    transform 0.28s ease;
}

.horoh-header.is-scrolled {
  background: rgba(35, 45, 43, 0.92);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.14);
}

.horoh-header__inner {
  min-height: var(--horoh-header-height);
  display: grid;
  grid-template-columns: 220px 1fr 220px;
  gap: 24px;
  align-items: center;
  transition:
    min-height 0.28s ease,
    gap 0.28s ease,
    padding 0.28s ease;
}

.horoh-header.is-scrolled .horoh-header__inner {
  min-height: var(--horoh-header-height-scrolled);
  gap: 18px;
}

.horoh-header__logo,
.horoh-header__nav,
.horoh-header__cta {
  display: flex;
  align-items: center;
}

.horoh-header__logo {
  justify-content: flex-start;
}

.horoh-header__nav {
  justify-content: center;
}

.horoh-header__cta {
  justify-content: flex-end;
}

.custom-logo-link,
.custom-logo-link img,
.horoh-site-title {
  display: inline-flex;
  align-items: center;
}

.custom-logo-link img,
.horoh-site-title {
  max-height: 72px;
  color: #ffffff;
  transition:
    max-height 0.28s ease,
    transform 0.28s ease,
    font-size 0.28s ease;
}

.horoh-site-title {
  font-family: var(--horoh-font-logo);
  font-size: 30px;
  letter-spacing: 0.08em;
}

.horoh-header.is-scrolled .custom-logo-link img,
.horoh-header.is-scrolled .horoh-site-title {
  max-height: 52px;
}

.horoh-header.is-scrolled .horoh-site-title {
  font-size: 24px;
}

/* ==========================================================================
   3. CONTEÚDO PADRÃO / FOOTER
   ========================================================================== */

.horoh-content-card {
  padding: 48px 0;
}

.horoh-entry {
  background: #ffffff;
  border: 1px solid rgba(35, 45, 43, 0.08);
  padding: 24px;
}

.entry-title {
  margin: 0 0 18px;
  color: var(--horoh-bg);
  font-family: var(--horoh-font-title);
  font-size: clamp(32px, 5vw, 56px);
}

.entry-content {
  line-height: 1.7;
}

.horoh-hero-fallback {
  min-height: 68vh;
  display: flex;
  align-items: center;
  color: #ffffff;
  background: linear-gradient(135deg, #002816 0%, #3d433f 100%);
}

.horoh-kicker {
  color: var(--horoh-gold);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-size: 12px;
}

.horoh-footer {
  background: var(--horoh-bg);
  color: #ffffff;
  padding: 24px 0;
}

.horoh-footer__inner {
  display: flex;
  justify-content: space-between;
  gap: 20px;
  align-items: center;
}

/* ==========================================================================
   4. ELEMENTOR THEME BUILDER / HEADER #HorohHeader
   ========================================================================== */

.elementor-location-header,
.elementor-location-header .elementor-element,
.elementor-location-header .e-con,
.elementor-location-header .e-con-inner {
  box-sizing: border-box;
}

.elementor-location-header,
.elementor-location-header > .elementor-element,
#HorohHeader,
#HorohHeader.elementor-sticky,
#HorohHeader.elementor-sticky--active,
#HorohHeader.elementor-sticky--effects {
  z-index: 999999 !important;
}

.elementor-location-header {
  position: relative;
}

body.elementor-editor-active .elementor-location-header,
body.elementor-editor-preview .elementor-location-header {
  z-index: 999999 !important;
}

#HorohHeader {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  max-width: 100% !important;
  padding-top: clamp(12px, 1.05vw, 20px) !important;
  padding-bottom: clamp(12px, 1.05vw, 20px) !important;
  background: linear-gradient(
    to bottom,
    rgba(32, 43, 42, 0.7) 0%,
    rgba(32, 43, 42, 0.2) 62%,
    rgba(32, 43, 42, 0) 100%
  ) !important;
  transition:
    background 0.5s cubic-bezier(0.25, 0.8, 0.25, 1),
    padding 0.5s cubic-bezier(0.25, 0.8, 0.25, 1),
    box-shadow 0.5s cubic-bezier(0.25, 0.8, 0.25, 1) !important;
}

#HorohHeader > .elementor-container,
#HorohHeader > .e-con-inner,
#HorohHeader .elementor-container,
#HorohHeader .e-con-inner,
#HorohHeader .elementor-widget-wrap {
  max-width: 100% !important;
  display: flex !important;
  align-items: center !important;
  flex-wrap: nowrap !important;
}

#HorohHeader > .elementor-container,
#HorohHeader > .e-con-inner,
#HorohHeader .elementor-container {
  width: 100% !important;
  justify-content: space-between !important;
  gap: clamp(10px, 1.15vw, 30px) !important;
  padding-left: clamp(28px, 3.1vw, 78px) !important;
  padding-right: clamp(28px, 3.1vw, 78px) !important;
}

#HorohHeader .elementor-column,
#HorohHeader .elementor-widget,
#HorohHeader .elementor-element {
  min-width: 0;
}

#HorohHeader .elementor-widget-wrap:has(.gtranslate_wrapper),
#HorohHeader .elementor-element:has(.gtranslate_wrapper) {
  flex: 0 0 auto !important;
}

/* Logo */
#HorohHeader .elementor-widget-theme-site-logo,
#HorohHeader .elementor-widget-image {
  flex: 0 0 auto !important;
  padding: 10px 0 10px 0;
}

#HorohHeader img {
  width: auto !important;
  max-height: clamp(58px, 4.2vw, 80px) !important;
  max-width: clamp(120px, 10vw, 210px) !important;
  transition: all 0.5s cubic-bezier(0.25, 0.8, 0.25, 1) !important;
}

/* Evita texto residual acima/atrás da logo */
#HorohHeader .site-title,
#HorohHeader .site-description,
#HorohHeader .elementor-widget-theme-site-title,
#HorohHeader .elementor-widget-theme-site-title a,
#HorohHeader .elementor-widget-site-title,
#HorohHeader .elementor-widget-site-title a {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  width: 0 !important;
  height: 0 !important;
  overflow: hidden !important;
  pointer-events: none !important;
}

/* Sticky
   v1.8.3:
   O tema mantém apenas comportamento/posição do sticky.
   Cor, imagem de fundo, blur, borda e sombra ficam livres para o Elementor Theme Builder controlar.
*/
#HorohHeader.elementor-sticky--effects {
  position: fixed !important;
  inset: 0 0 auto 0 !important;
  width: 100% !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

#HorohHeader.elementor-sticky--effects img {
  max-height: clamp(50px, 3.6vw, 70px) !important;
}

/* ==========================================================================
   7. HERO / SLIDER / YOUTUBE
   ========================================================================== */

body:not(.elementor-editor-active):not(.elementor-editor-preview)
  .elementor-location-single,
body:not(.elementor-editor-active):not(.elementor-editor-preview)
  .elementor-location-archive,
body:not(.elementor-editor-active):not(.elementor-editor-preview)
  .elementor-section-wrap {
  max-width: 100%;
  overflow-x: hidden;
}

.elementor-widget-container:has(.horoh-slider-container),
.elementor-widget-shortcode:has(.horoh-slider-container),
.elementor-element:has(.horoh-slider-container),
.e-con:has(.horoh-slider-container),
.elementor-section:has(.horoh-slider-container),
.elementor-top-section:has(.horoh-slider-container) {
  width: 100% !important;
  max-width: 100% !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  overflow: hidden !important;
}

.horoh-slider-container {
  position: relative !important;
  isolation: isolate;
  width: 100% !important;
  max-width: 100% !important;
  min-width: 100% !important;
  height: 100vh !important;
  height: 100svh !important;
  left: 0 !important;
  right: auto !important;
  transform: none !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
  background: var(--horoh-dark) !important;
  z-index: 1 !important;
}

.horoh-slide {
  position: absolute;
  inset: 0;
  width: 100% !important;
  max-width: 100% !important;
  min-width: 100% !important;
  height: 100%;
  opacity: 0;
  visibility: hidden;
  transition:
    opacity 2.1s cubic-bezier(0.22, 1, 0.36, 1),
    visibility 2.1s linear;
  z-index: 1;
  will-change: opacity;
}

.horoh-slide.active {
  opacity: 1;
  visibility: visible;
  z-index: 2;
}

.horoh-slide-bg,
.yt-placeholder {
  position: absolute;
  inset: 0;
  z-index: 1;
  width: 100% !important;
  max-width: 100% !important;
  min-width: 100% !important;
  height: 100%;
  overflow: hidden !important;
}

.horoh-slide-bg img,
.horoh-slide-bg video {
  position: absolute !important;
  inset: 0 !important;
  display: block !important;
  width: 100% !important;
  min-width: 100% !important;
  max-width: 100% !important;
  height: 100% !important;
  min-height: 100% !important;
  object-fit: cover !important;
  object-position: center center !important;
  border: 0 !important;
  transition:
    transform 2.2s ease,
    opacity 2.2s ease;
  will-change: transform, opacity;
}

.horoh-slide.active .horoh-slide-bg img {
  animation: horohKenBurns 12s ease-out forwards;
}

@keyframes horohKenBurns {
  0% {
    transform: scale(1);
  }

  100% {
    transform: scale(1.1);
  }
}

.horoh-slide-overlay {
  position: absolute;
  inset: 0;
  z-index: 2;
  background: rgba(0, 0, 0, 0.45);
  transition: opacity 1.8s ease;
}

.horoh-media-shield {
  position: absolute;
  inset: 0;
  z-index: 9;
  display: block;
  background: transparent;
  cursor: default;
  pointer-events: auto;
  user-select: none;
  -webkit-user-select: none;
  touch-action: none;
}

.horoh-slide-content {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 10;
  width: 85%;
  max-width: 1100px;
  text-align: center;
  color: #ffffff;
  opacity: 0;
  transform: translate(-50%, calc(-50% + 18px));
  transition:
    opacity 1.05s ease,
    transform 1.35s cubic-bezier(0.22, 1, 0.36, 1);
  will-change: opacity, transform;
}

.horoh-slide.active .horoh-slide-content {
  opacity: 1;
  transform: translate(-50%, -50%);
}

.slide-subtitle {
  display: block;
  margin-bottom: 15px;
  font-family: var(--horoh-font-title) !important;
  font-size: clamp(14px, 2vw, 18px);
  text-transform: uppercase;
  letter-spacing: 4px;
  color: var(--horoh-gold);
}

.slide-title {
  margin: 0 0 20px;
  font-family: var(--horoh-font-title) !important;
  font-size: clamp(32px, 7vw, 65px);
  font-weight: 400;
  line-height: 1.1;
}

.slide-support-text {
  max-width: 750px;
  margin: 0 auto;
  font-family: var(--horoh-font-body) !important;
  font-size: clamp(16px, 1.5vw, 20px);
  line-height: 1.6;
  opacity: 0.9;
}

/* YouTube como background decorativo */
#home .horoh-slider-container iframe[src*="youtube.com/embed"],
#home .horoh-slider-container iframe[src*="youtube-nocookie.com/embed"],
#home .horoh-slide-bg iframe[src*="youtube.com/embed"],
#home .horoh-slide-bg iframe[src*="youtube-nocookie.com/embed"],
#home .yt-placeholder iframe[src*="youtube.com/embed"],
#home .yt-placeholder iframe[src*="youtube-nocookie.com/embed"],
.yt-placeholder iframe {
  pointer-events: none !important;
  user-select: none !important;
  -webkit-user-select: none !important;
}

.yt-placeholder iframe {
  position: absolute !important;
  top: 50% !important;
  left: 50% !important;
  width: 100vw !important;
  height: 56.25vw !important;
  min-height: 100vh !important;
  min-width: 177.77vh !important;
  max-width: none !important;
  transform: translate(-50%, -50%) scale(1.06) !important;
  border: 0 !important;
}

.horoh-slider-container .swiper-button-prev,
.horoh-slider-container .swiper-button-next,
.horoh-slider-container .elementor-swiper-button,
.horoh-slider-container .swiper-pagination {
  display: none !important;
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

.horoh-slider-container .horoh-nav {
  position: absolute;
  top: 50%;
  z-index: 120 !important;
  width: 48px;
  height: 72px;
  padding: 0;
  border: 0;
  background: transparent;
  color: rgba(255, 255, 255, 0.42);
  cursor: pointer;
  transform: translateY(-50%);
  pointer-events: auto !important;
  transition:
    color 0.25s ease,
    opacity 0.25s ease;
}

.horoh-slider-container .horoh-nav:hover,
.horoh-slider-container .horoh-nav:focus {
  color: rgba(255, 255, 255, 0.82);
  outline: none;
}

.horoh-slider-container .horoh-nav svg {
  display: block;
  width: 24px;
  height: 56px;
  margin: auto;
}

.horoh-slider-container .horoh-nav path {
  fill: none;
  stroke: currentColor;
  stroke-width: 1.4;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.horoh-slider-container .nav-prev {
  left: clamp(12px, 2vw, 32px);
}

.horoh-slider-container .nav-next {
  right: clamp(12px, 2vw, 32px);
}

.horoh-slider-container .horoh-progress-container {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 80;
  width: 100%;
  height: 2px;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.25);
  pointer-events: none;
}

.horoh-slider-container .horoh-progress-bar {
  width: 0;
  height: 100%;
  background: var(--horoh-gold);
}

.horoh-slide-bg video,
.horoh-slider-container video {
  pointer-events: none !important;
  -webkit-user-select: none !important;
  user-select: none !important;
}

.horoh-slide-bg video::-webkit-media-controls,
.horoh-slide-bg video::-webkit-media-controls-enclosure,
.horoh-slide-bg video::-webkit-media-controls-panel,
.horoh-slide-bg video::-webkit-media-controls-play-button,
.horoh-slide-bg video::-webkit-media-controls-start-playback-button,
.horoh-slide-bg video::-webkit-media-controls-overlay-play-button,
.horoh-slide-bg video::-webkit-media-controls-timeline,
.horoh-slide-bg video::-webkit-media-controls-current-time-display,
.horoh-slide-bg video::-webkit-media-controls-time-remaining-display,
.horoh-slide-bg video::-webkit-media-controls-mute-button,
.horoh-slide-bg video::-webkit-media-controls-volume-slider,
.horoh-slide-bg video::-webkit-media-controls-fullscreen-button,
.horoh-slider-container video::-webkit-media-controls,
.horoh-slider-container video::-webkit-media-controls-enclosure,
.horoh-slider-container video::-webkit-media-controls-panel,
.horoh-slider-container video::-webkit-media-controls-play-button,
.horoh-slider-container video::-webkit-media-controls-start-playback-button,
.horoh-slider-container video::-webkit-media-controls-overlay-play-button,
.horoh-slider-container video::-webkit-media-controls-timeline,
.horoh-slider-container video::-webkit-media-controls-current-time-display,
.horoh-slider-container video::-webkit-media-controls-time-remaining-display,
.horoh-slider-container video::-webkit-media-controls-mute-button,
.horoh-slider-container video::-webkit-media-controls-volume-slider,
.horoh-slider-container video::-webkit-media-controls-fullscreen-button {
  display: none !important;
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

/* MediaElement / WordPress video */
.horoh-slider-container .mejs-container,
.horoh-slider-container .mejs-inner,
.horoh-slider-container .mejs-mediaelement,
.horoh-slider-container .mejs-layers,
.horoh-slider-container .mejs-overlay,
.horoh-slider-container .mejs-poster {
  width: 100% !important;
  height: 100% !important;
}

.horoh-slider-container .mejs-controls,
.horoh-slider-container .mejs-overlay-button,
.horoh-slider-container .mejs-overlay-play,
.horoh-slider-container .mejs-overlay-loading,
.horoh-slider-container .wp-video-shortcode + .mejs-controls {
  display: none !important;
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

/* ==========================================================================
   8. MOTOR DE RESERVAS / BOOKING
   ========================================================================== */

#home .elementor-element-8aa2106 .hbb-booking-section,
#home .elementor-element-8aa2106 .hbb-booking-form,
#home .elementor-element-8aa2106 .hbb-field,
#home .elementor-element-8aa2106 .hbb-field input,
#home .elementor-element-8aa2106 .hbb-field select {
  box-sizing: border-box;
  min-width: 0;
}

.horoh-booking,
.horoh-booking-form,
.hbook-search-form,
.booking-form,
form[action*="Booking"],
form[action*="booking"] {
  width: min(100%, 940px) !important;
  max-width: 940px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.horoh-slider-container .horoh-booking,
.horoh-slider-container .horoh-booking-form,
.horoh-slider-container .hbook-search-form,
.horoh-slider-container .booking-form,
.horoh-slider-container form[action*="Booking"],
.horoh-slider-container form[action*="booking"],
.horoh-slider-container .elementor-widget-container:has(.horoh-booking),
.horoh-slider-container .elementor-widget-container:has(.horoh-booking-form),
.horoh-slider-container .elementor-widget-container:has(.hbook-search-form),
.horoh-slider-container .elementor-widget-container:has(.booking-form),
.horoh-slider-container .elementor-widget-shortcode:has(.horoh-booking),
.horoh-slider-container .elementor-widget-shortcode:has(.horoh-booking-form),
.horoh-slider-container .elementor-widget-shortcode:has(.hbook-search-form),
.horoh-slider-container .elementor-widget-shortcode:has(.booking-form) {
  position: absolute !important;
  left: 50% !important;
  right: auto !important;
  bottom: clamp(56px, 7vh, 96px) !important;
  top: auto !important;
  transform: translateX(-50%) !important;
  z-index: 30 !important;
  width: min(92vw, 1120px) !important;
  max-width: 1120px !important;
  margin: 0 !important;
}

/* ==========================================================================
   9. EXPERIÊNCIAS / ACCORDION
   ========================================================================== */

@media (min-width: 768px) {
  .horoh-exp-stage {
    height: 100vh;
    min-height: 100vh;
    overflow: hidden;
  }

  .horoh-exp-loop {
    height: 100%;
    min-height: 100%;
  }

  .horoh-exp-loop .e-loop__container,
  .horoh-exp-loop .elementor-loop-container {
    display: flex !important;
    flex-direction: column !important;
    flex-wrap: nowrap !important;
    height: 100% !important;
    min-height: 100% !important;
    gap: 0 !important;
    overflow: hidden !important;
  }

  .horoh-exp-loop .e-loop-item {
    position: relative !important;
    flex: 1 1 0 !important;
    min-height: 84px !important;
    overflow: hidden !important;
    transition:
      flex-grow 0.35s ease,
      flex-basis 0.35s ease,
      filter 0.28s ease,
      opacity 0.28s ease !important;
  }

  .horoh-exp-loop:not(:hover) .e-loop-item,
  .horoh-exp-loop:not(:hover).has-active .e-loop-item,
  .horoh-exp-loop:not(:hover) .e-loop-item.is-active {
    flex: 1 1 0 !important;
    flex-grow: 1 !important;
    flex-basis: 0 !important;
  }

  .horoh-exp-loop:hover .e-loop-item {
    flex-grow: 0.85 !important;
    flex-basis: 0 !important;
  }

  .horoh-exp-loop:hover .e-loop-item:hover,
  .horoh-exp-loop:hover .e-loop-item.is-active {
    flex-grow: 3.6 !important;
  }

  .horoh-exp-loop .e-loop-item > div,
  .horoh-exp-loop .e-loop-item > div > div,
  .horoh-exp-loop .e-loop-item .elementor,
  .horoh-exp-loop .e-loop-item .e-con {
    height: 100% !important;
    min-height: 100% !important;
  }

  .horoh-exp-card {
    position: relative !important;
    isolation: isolate;
    width: 100% !important;
    height: 100% !important;
    min-height: 100% !important;
    overflow: hidden !important;
    background-size: cover !important;
    background-position: center center !important;
    background-repeat: no-repeat !important;
  }

  .horoh-exp-card::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    background: linear-gradient(
      90deg,
      rgba(0, 0, 0, 0.08) 0%,
      rgba(0, 0, 0, 0.22) 42%,
      rgba(0, 0, 0, 0.72) 100%
    );
    transition: background 0.28s ease;
  }

  .horoh-exp-loop .e-loop-item.is-active .horoh-exp-card::before,
  .horoh-exp-loop .e-loop-item:hover .horoh-exp-card::before {
    background: linear-gradient(
      90deg,
      rgba(0, 0, 0, 0.05) 0%,
      rgba(0, 0, 0, 0.16) 34%,
      rgba(0, 0, 0, 0.8) 100%
    );
  }

  .horoh-exp-meta {
    position: relative;
    z-index: 3;
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
    transform: translateY(10px) !important;
    transition:
      opacity 0.25s ease,
      transform 0.25s ease,
      visibility 0.25s ease !important;
  }

  .horoh-exp-loop .e-loop-item:hover .horoh-exp-meta,
  .horoh-exp-loop .e-loop-item:focus-within .horoh-exp-meta {
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
    transform: translateY(0) !important;
  }

  .horoh-exp-title {
    margin: 0;
  }

  .horoh-exp-title .elementor-heading-title {
    margin: 0;
    color: #e7c675;
    line-height: 1.04;
    text-shadow: 0 2px 14px rgba(0, 0, 0, 0.35);
  }

  .horoh-exp-cta {
    margin: 0;
  }
}

/* ==========================================================================
   10. MODAL DE VÍDEO
   ========================================================================== */

.horoh-video-modal {
  position: fixed;
  inset: 0;
  z-index: 999999;
  display: none;
}

.horoh-video-modal.is-open {
  display: block;
}

.horoh-video-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.78);
  backdrop-filter: blur(4px);
}

.horoh-video-modal__dialog {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 2;
  width: min(1100px, calc(100vw - 40px));
  transform: translate(-50%, -50%);
}

.horoh-video-modal__frame-wrap {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
  background: #000000;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.35);
}

.horoh-video-modal__frame-wrap iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.horoh-video-modal__close {
  position: absolute;
  top: -44px;
  right: 0;
  z-index: 3;
  width: 38px;
  height: 38px;
  border: 0px solid rgba(255, 255, 255, 0.6);
  background: rgba(0, 0, 0, 0.35);
  color: #ffffff;
  font-size: 24px;
  line-height: 1;
  cursor: pointer;
  transition: all 0.25s ease;
}

.horoh-video-modal__close:hover {
  background: rgba(255, 255, 255, 0.12);
  border-color: 0px solid #ffffff;
}

body.horoh-video-lock {
  overflow: hidden;
}

/* ==========================================================================
   12. TAXONOMIAS / ÍCONES
   ========================================================================== */

.horoh-term-icon {
  width: 28px;
  height: 28px;
  display: block;
  object-fit: contain;
}

.horoh-taxonomias a {
  pointer-events: none;
  cursor: default;
  text-decoration: none;
  color: inherit;
}

.horoh-taxonomias a:hover,
.horoh-taxonomias a:focus {
  text-decoration: none;
  color: inherit;
}

/* ==========================================================================
   13. ÂNCORAS / MENU STICKY
   ========================================================================== */

.site-main > section[id],
.site-main > div[id],
.site-main > main[id],
.site-main > article[id],
.horoh-shell [id],
[class*="horoh-"][id],
.elementor-element:has([class*="horoh-"])[id],
.elementor-section:has([class*="horoh-"])[id],
.elementor-top-section:has([class*="horoh-"])[id] {
  scroll-margin-top: var(--horoh-anchor-offset);
}

.elementor-menu-anchor {
  position: relative;
  top: calc(var(--horoh-anchor-offset) * -1);
  visibility: hidden;
  pointer-events: none;
}

/* ==========================================================================
   14. GTRANSLATE
   ========================================================================== */

#HorohHeader .gtranslate_wrapper,
#HorohHeader .gt_switcher_wrapper,
.gtranslate_wrapper {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  line-height: 1 !important;
  vertical-align: middle !important;
  flex: 0 0 auto !important;
  white-space: nowrap !important;
}

.gtranslate_wrapper a,
.gtranslate_wrapper .glink {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  outline: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
  text-decoration: none !important;
  line-height: 1 !important;
}

.gtranslate_wrapper img {
  display: inline-block !important;
  border: 0 !important;
  outline: 0 !important;
  box-shadow: none !important;
  opacity: 0.72 !important;
  filter: grayscale(100%) !important;
  transition:
    filter 0.25s ease,
    opacity 0.25s ease,
    transform 0.25s ease !important;
}

.gtranslate_wrapper a:hover img,
.gtranslate_wrapper .glink:hover img {
  filter: grayscale(0%) !important;
  opacity: 1 !important;
  transform: translateY(-1px) !important;
  border: 0 !important;
  outline: 0 !important;
  box-shadow: none !important;
}

.gtranslate_wrapper a.gt-current-lang,
.gtranslate_wrapper a.is-active,
.gtranslate_wrapper .glink.gt-current-lang,
.gtranslate_wrapper .glink.is-active,
.gtranslate_wrapper a[aria-current="true"],
.gtranslate_wrapper a[aria-current="page"],
.gtranslate_wrapper .gt-current-lang,
.gtranslate_wrapper .is-active {
  border: 0 !important;
  outline: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
}

.gtranslate_wrapper a.gt-current-lang img,
.gtranslate_wrapper a.is-active img,
.gtranslate_wrapper .glink.gt-current-lang img,
.gtranslate_wrapper .glink.is-active img,
.gtranslate_wrapper a[aria-current="true"] img,
.gtranslate_wrapper a[aria-current="page"] img,
.gtranslate_wrapper .gt-current-lang img,
.gtranslate_wrapper .is-active img {
  filter: grayscale(0%) !important;
  opacity: 1 !important;
  border: 0 !important;
  outline: 0 !important;
  box-shadow: none !important;
}

/* ==========================================================================
   15. RESPONSIVO
   ========================================================================== */

@media (min-width: 1025px) and (max-width: 1440px) {
  #HorohHeader > .elementor-container,
  #HorohHeader > .e-con-inner,
  #HorohHeader .elementor-container {
    gap: 10px !important;
    padding-left: 28px !important;
    padding-right: 28px !important;
  }

  #HorohHeader img {
    max-height: 64px !important;
    max-width: 145px !important;
  }

  .horoh-booking,
  .horoh-booking-form,
  .hbook-search-form,
  .booking-form,
  form[action*="Booking"],
  form[action*="booking"] {
    width: min(100%, 735px) !important;
    max-width: 735px !important;
  }
}

@media (min-width: 1025px) and (max-width: 1280px) {
  #HorohHeader > .elementor-container,
  #HorohHeader > .e-con-inner,
  #HorohHeader .elementor-container {
    padding-left: 20px !important;
    padding-right: 20px !important;
    gap: 8px !important;
  }

  #HorohHeader img {
    max-height: 56px !important;
    max-width: 124px !important;
  }
}

@media (max-width: 1024px) {
  :root {
    --horoh-header-height: 86px;
    --horoh-header-height-scrolled: 64px;
    --horoh-anchor-offset: 95px;
  }

  .horoh-header__inner {
    grid-template-columns: 1fr auto;
  }

  .horoh-header__nav {
    grid-column: 1 / -1;
    justify-content: flex-start;
  }

  .custom-logo-link img,
  .horoh-site-title {
    max-height: 56px;
  }

  #HorohHeader > .elementor-container,
  #HorohHeader > .e-con-inner,
  #HorohHeader .elementor-container {
    padding-left: 20px !important;
    padding-right: 20px !important;
    gap: 12px !important;
  }

  #HorohHeader img {
    max-height: 58px !important;
    max-width: 132px !important;
  }

  .horoh-booking,
  .horoh-booking-form,
  .hbook-search-form,
  .booking-form,
  form[action*="Booking"],
  form[action*="booking"] {
    width: calc(100% - 40px) !important;
    max-width: calc(100% - 40px) !important;
  }
}

@media (max-width: 782px) {
  .admin-bar .horoh-header {
    top: 46px;
  }
}

@media (max-width: 767px) {
  :root {
    --horoh-header-height: 78px;
    --horoh-header-height-scrolled: 60px;
    --horoh-anchor-offset: 80px;
  }

  .horoh-shell {
    width: min(100% - 24px, var(--horoh-max));
  }

  .horoh-header__inner {
    grid-template-columns: 1fr;
    gap: 12px;
    padding: 10px 0;
  }

  .horoh-header__nav,
  .horoh-header__cta {
    justify-content: flex-start;
  }

  .custom-logo-link img,
  .horoh-site-title {
    max-height: 42px;
    font-size: 22px;
  }

  .horoh-header.is-scrolled .custom-logo-link img,
  .horoh-header.is-scrolled .horoh-site-title {
    max-height: 36px;
  }

  .horoh-footer__inner {
    flex-direction: column;
    align-items: flex-start;
  }

  .horoh-slider-container .horoh-booking,
  .horoh-slider-container .horoh-booking-form,
  .horoh-slider-container .hbook-search-form,
  .horoh-slider-container .booking-form,
  .horoh-slider-container form[action*="Booking"],
  .horoh-slider-container form[action*="booking"] {
    position: absolute !important;
    bottom: 28px !important;
    width: calc(100vw - 32px) !important;
    max-width: calc(100vw - 32px) !important;
  }

  .horoh-exp-stage,
  .horoh-exp-loop,
  .horoh-exp-loop .e-loop__container,
  .horoh-exp-loop .elementor-loop-container {
    height: auto !important;
    min-height: auto !important;
  }

  .horoh-exp-loop .e-loop__container,
  .horoh-exp-loop .elementor-loop-container {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 8px !important;
  }

  .horoh-exp-loop .e-loop-item {
    min-height: 22vh !important;
    overflow: hidden !important;
  }

  .horoh-exp-card {
    position: relative !important;
    min-height: 22vh !important;
    overflow: hidden !important;
  }

  .horoh-exp-meta {
    position: absolute !important;
    right: 16px !important;
    bottom: 16px !important;
    z-index: 3 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-end !important;
    gap: 10px !important;
    opacity: 1 !important;
    visibility: visible !important;
    transform: none !important;
    pointer-events: auto !important;
  }

  .horoh-exp-title {
    text-align: right !important;
    margin: 0 !important;
  }

  .horoh-exp-title .elementor-heading-title {
    color: #e7c675 !important;
    margin: 0 !important;
    white-space: normal !important;
    line-height: 1.08 !important;
  }

  .horoh-video-modal__dialog {
    width: calc(100vw - 24px);
  }

  .horoh-video-modal__close {
    top: -40px;
  }

  .horoh-contact-newsletter .elementor-form-fields-wrapper,
  form.elementor-form[aria-label="Newsletter"] .elementor-form-fields-wrapper,
  form.elementor-form[name="Newsletter"] .elementor-form-fields-wrapper {
    flex-wrap: wrap !important;
  }

  .horoh-contact-newsletter .elementor-field-type-email,
  .horoh-contact-newsletter .elementor-field-type-submit,
  form.elementor-form[aria-label="Newsletter"] .elementor-field-group-email,
  form.elementor-form[name="Newsletter"] .elementor-field-group-email,
  form.elementor-form[aria-label="Newsletter"] .elementor-field-type-submit,
  form.elementor-form[name="Newsletter"] .elementor-field-type-submit {
    width: 100% !important;
    flex: 0 0 100% !important;
  }
}

/* =========================================================
   HOROH - Hook de Reserva / Ajuste visual
   ========================================================= */

.hgh-reservation-hook {
  width: 100%;
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 24px 28px;
  box-sizing: border-box;
  z-index: 30;
}

.hgh-reservation-hook form,
.hgh-reservation-hook .booking-form,
.hgh-reservation-hook .reservation-form {
  width: 100%;
  display: flex;
  align-items: flex-end;
  gap: 10px;
  flex-wrap: nowrap;
}

.hgh-reservation-hook label {
  display: block;
  margin: 0 0 6px;
  font-size: 9px;
  line-height: 1;
  font-weight: 400;
  letter-spacing: 0.22em;
  color: #ffffff;
  text-transform: uppercase;
}

.hgh-reservation-hook input,
.hgh-reservation-hook select,
.hgh-reservation-hook button,
.hgh-reservation-hook .button,
.hgh-reservation-hook input[type="submit"] {
  height: 38px;
  min-height: 38px;
  border: 1px solid rgba(255, 255, 255, 0.75);
  border-radius: 0;
  background: rgba(35, 45, 43, 0.16);
  color: #ffffff;
  font-size: 10px;
  line-height: 1;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  box-shadow: none;
  outline: none;
  box-sizing: border-box;
}

.hgh-reservation-hook input,
.hgh-reservation-hook select {
  width: 100%;
  padding: 0 34px 0 13px;
}

.hgh-reservation-hook select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  cursor: pointer;
}

.hgh-reservation-hook option {
  background: #162320;
  color: #ffffff;
  font-size: 14px;
  letter-spacing: normal;
  text-transform: none;
}

.hgh-reservation-hook button,
.hgh-reservation-hook .button,
.hgh-reservation-hook input[type="submit"] {
  min-width: 210px;
  padding: 0 26px;
  background: transparent;
  cursor: pointer;
  transition:
    background-color 0.22s ease,
    color 0.22s ease,
    border-color 0.22s ease;
}

.hgh-reservation-hook button:hover,
.hgh-reservation-hook .button:hover,
.hgh-reservation-hook input[type="submit"]:hover {
  background: #ffffff;
  color: #002816;
  border-color: #ffffff;
}

/* Campos */
.hgh-reservation-hook .field,
.hgh-reservation-hook .form-field,
.hgh-reservation-hook .booking-field {
  flex: 1 1 150px;
  min-width: 120px;
}

.hgh-reservation-hook .field-submit,
.hgh-reservation-hook .submit,
.hgh-reservation-hook .booking-submit {
  flex: 0 0 auto;
}

/* =========================================================
   HOROH - RESERVA / BOOKING BAR
   Versão refinada e mais agressiva
   ========================================================= */

.hgh-reservation-hook,
.hgh-reservation-hook * {
  box-sizing: border-box;
}

.hgh-reservation-hook {
  width: 100%;
  max-width: 1160px;
  margin: 0 auto;
  padding: 0 40px 34px;
  position: relative;
  z-index: 50;
}

.hgh-reservation-hook form,
.hgh-reservation-hook .booking-form,
.hgh-reservation-hook .reservation-form,
.hgh-reservation-hook .hbook-form,
.hgh-reservation-hook .hb-search-form {
  width: 100%;
  display: grid !important;
  grid-template-columns: 1fr 1fr 0.82fr 0.82fr 1.65fr;
  gap: 12px;
  align-items: end;
}

/* Campo */
.hgh-reservation-hook .field,
.hgh-reservation-hook .form-field,
.hgh-reservation-hook .booking-field,
.hgh-reservation-hook .hb-form-field,
.hgh-reservation-hook p {
  margin: 0 !important;
  min-width: 0;
}

/* Labels */
.hgh-reservation-hook label {
  display: block !important;
  margin: 0 0 7px !important;
  padding: 0 !important;
  color: #ffffff !important;
  font-size: 9px !important;
  line-height: 1 !important;
  font-weight: 400 !important;
  letter-spacing: 0.24em !important;
  text-transform: uppercase !important;
  white-space: nowrap !important;
  opacity: 0.96;
}

/* Inputs / Selects */
.hgh-reservation-hook input,
.hgh-reservation-hook select {
  width: 100% !important;
  height: 40px !important;
  min-height: 40px !important;
  margin: 0 !important;
  padding: 0 36px 0 14px !important;
  border: 1px solid rgba(255, 255, 255, 0.72) !important;
  border-radius: 0 !important;
  background-color: rgba(16, 28, 26, 0.18) !important;
  color: #ffffff !important;
  font-size: 10px !important;
  line-height: 40px !important;
  font-weight: 400 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  outline: none !important;
  box-shadow: none !important;
}

/* Select */
.hgh-reservation-hook select {
  cursor: pointer !important;
  appearance: none !important;
  -webkit-appearance: none !important;
  -moz-appearance: none !important;

  background-image:
    linear-gradient(45deg, transparent 50%, #ffffff 50%),
    linear-gradient(135deg, #ffffff 50%, transparent 50%) !important;
  background-position:
    calc(100% - 18px) 17px,
    calc(100% - 12px) 17px !important;
  background-size:
    6px 6px,
    6px 6px !important;
  background-repeat: no-repeat !important;
}

.hgh-reservation-hook select option {
  background: #162320 !important;
  color: #ffffff !important;
  font-size: 14px !important;
  line-height: 1.4 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
}

/* Botão */
.hgh-reservation-hook button,
.hgh-reservation-hook .button,
.hgh-reservation-hook input[type="submit"],
.hgh-reservation-hook a.button {
  width: 100% !important;
  height: 40px !important;
  min-height: 40px !important;
  margin: 0 !important;
  padding: 0 22px !important;
  border: 1px solid rgba(255, 255, 255, 0.82) !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: #ffffff !important;
  font-size: 10px !important;
  line-height: 38px !important;
  font-weight: 400 !important;
  letter-spacing: 0.22em !important;
  text-transform: uppercase !important;
  text-align: center !important;
  white-space: nowrap !important;
  cursor: pointer !important;
  box-shadow: none !important;
  transition:
    background-color 0.2s ease,
    color 0.2s ease,
    border-color 0.2s ease;
}

.hgh-reservation-hook button:hover,
.hgh-reservation-hook .button:hover,
.hgh-reservation-hook input[type="submit"]:hover,
.hgh-reservation-hook a.button:hover {
  background: #ffffff !important;
  color: #002816 !important;
  border-color: #ffffff !important;
}

/* Ícones do calendário dentro dos inputs */
.hgh-reservation-hook .ui-datepicker-trigger,
.hgh-reservation-hook img.ui-datepicker-trigger {
  position: absolute !important;
  right: 12px !important;
  bottom: 12px !important;
  width: 14px !important;
  height: 14px !important;
  opacity: 0.85 !important;
}

/* =========================================================
   JQUERY UI DATEPICKER - HOROH REFINADO
   ========================================================= */

#ui-datepicker-div.ui-datepicker {
  width: 292px !important;
  padding: 15px 12px 12px !important;
  border: 1px solid rgba(255, 255, 255, 0.18) !important;
  border-radius: 0 !important;
  background: #162320 !important;
  color: #ffffff !important;
  font-family: inherit !important;
  box-shadow: 0 22px 55px rgba(0, 0, 0, 0.42) !important;
  position: absolute !important;
  z-index: 999999 !important;
}

/* Cabeçalho */
#ui-datepicker-div .ui-datepicker-header {
  position: relative !important;
  height: 30px !important;
  padding: 0 38px 10px !important;
  border: 0 !important;
  background: transparent !important;
  color: #ffffff !important;
}

#ui-datepicker-div .ui-datepicker-title {
  margin: 0 !important;
  padding: 0 !important;
  color: #ffffff !important;
  font-size: 12px !important;
  line-height: 28px !important;
  font-weight: 400 !important;
  letter-spacing: 0.16em !important;
  text-align: center !important;
  text-transform: uppercase !important;
}

/* Botões anterior/próximo */
#ui-datepicker-div .ui-datepicker-prev,
#ui-datepicker-div .ui-datepicker-next {
  position: absolute !important;
  top: 0 !important;
  width: 30px !important;
  height: 28px !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  cursor: pointer !important;
  overflow: hidden !important;
}

#ui-datepicker-div .ui-datepicker-prev {
  left: 0 !important;
}

#ui-datepicker-div .ui-datepicker-next {
  right: 0 !important;
}

#ui-datepicker-div .ui-datepicker-prev span,
#ui-datepicker-div .ui-datepicker-next span {
  display: block !important;
  position: static !important;
  width: 30px !important;
  height: 28px !important;
  margin: 0 !important;
  padding: 0 !important;
  background: none !important;
  color: transparent !important;
  font-size: 0 !important;
  line-height: 0 !important;
  text-indent: 0 !important;
  overflow: hidden !important;
}

#ui-datepicker-div .ui-datepicker-prev span::before,
#ui-datepicker-div .ui-datepicker-next span::before {
  display: block !important;
  color: #ffffff !important;
  font-size: 28px !important;
  line-height: 25px !important;
  font-weight: 300 !important;
  text-align: center !important;
}

#ui-datepicker-div .ui-datepicker-prev span::before {
  content: "‹";
}

#ui-datepicker-div .ui-datepicker-next span::before {
  content: "›";
}

#ui-datepicker-div .ui-datepicker-prev:hover,
#ui-datepicker-div .ui-datepicker-next:hover {
  background: rgba(255, 255, 255, 0.08) !important;
}

/* Tabela */
#ui-datepicker-div table.ui-datepicker-calendar {
  width: 100% !important;
  margin: 8px 0 0 !important;
  border-collapse: collapse !important;
  table-layout: fixed !important;
  background: transparent !important;
}

#ui-datepicker-div .ui-datepicker-calendar th {
  height: 27px !important;
  padding: 0 !important;
  border: 0 !important;
  color: #ffffff !important;
  font-size: 9px !important;
  line-height: 27px !important;
  font-weight: 400 !important;
  letter-spacing: 0.12em !important;
  text-align: center !important;
  text-transform: uppercase !important;
}

#ui-datepicker-div .ui-datepicker-calendar td {
  width: 14.285% !important;
  height: 34px !important;
  padding: 0 !important;
  border: 1px solid rgba(255, 255, 255, 0.055) !important;
  background: transparent !important;
}

#ui-datepicker-div .ui-datepicker-calendar td a,
#ui-datepicker-div .ui-datepicker-calendar td span {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  height: 34px !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  color: #ffffff !important;
  font-size: 12px !important;
  line-height: 1 !important;
  font-weight: 400 !important;
  text-align: center !important;
  text-decoration: none !important;
}

#ui-datepicker-div .ui-datepicker-calendar td a:hover {
  background: rgba(255, 255, 255, 0.09) !important;
}

#ui-datepicker-div .ui-datepicker-calendar .ui-datepicker-today a,
#ui-datepicker-div .ui-datepicker-calendar .ui-datepicker-current-day a {
  background: #d8b958 !important;
  color: #002816 !important;
}

#ui-datepicker-div .ui-datepicker-unselectable span,
#ui-datepicker-div .ui-state-disabled span {
  color: rgba(255, 255, 255, 0.18) !important;
}

/* Rodapé do datepicker */
#ui-datepicker-div .ui-datepicker-buttonpane {
  display: flex !important;
  justify-content: space-between !important;
  gap: 10px !important;
  margin: 12px 0 0 !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
}

#ui-datepicker-div .ui-datepicker-buttonpane button {
  width: auto !important;
  min-width: 88px !important;
  height: 30px !important;
  min-height: 30px !important;
  margin: 0 !important;
  padding: 0 12px !important;
  border: 1px solid rgba(255, 255, 255, 0.42) !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: #ffffff !important;
  font-size: 9px !important;
  line-height: 28px !important;
  font-weight: 400 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  opacity: 1 !important;
  cursor: pointer !important;
}

#ui-datepicker-div .ui-datepicker-buttonpane button:hover {
  background: #ffffff !important;
  color: #002816 !important;
}

/* =========================================================
   RESPONSIVO
   ========================================================= */

@media (max-width: 1180px) {
  .hgh-reservation-hook {
    padding-right: 28px;
    padding-left: 28px;
  }

  .hgh-reservation-hook form,
  .hgh-reservation-hook .booking-form,
  .hgh-reservation-hook .reservation-form,
  .hgh-reservation-hook .hbook-form,
  .hgh-reservation-hook .hb-search-form {
    grid-template-columns: 1fr 1fr 0.75fr 0.75fr 1.45fr;
    gap: 10px;
  }
}

@media (max-width: 900px) {
  .hgh-reservation-hook form,
  .hgh-reservation-hook .booking-form,
  .hgh-reservation-hook .reservation-form,
  .hgh-reservation-hook .hbook-form,
  .hgh-reservation-hook .hb-search-form {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .hgh-reservation-hook button,
  .hgh-reservation-hook .button,
  .hgh-reservation-hook input[type="submit"],
  .hgh-reservation-hook a.button {
    grid-column: 1 / -1;
  }
}

@media (max-width: 560px) {
  .hgh-reservation-hook {
    padding: 0 16px 24px;
  }

  .hgh-reservation-hook form,
  .hgh-reservation-hook .booking-form,
  .hgh-reservation-hook .reservation-form,
  .hgh-reservation-hook .hbook-form,
  .hgh-reservation-hook .hb-search-form {
    grid-template-columns: 1fr;
  }

  #ui-datepicker-div.ui-datepicker {
    width: calc(100vw - 32px) !important;
    max-width: 306px !important;
  }
}

.btn-planta-baixa .elementor-button-content-wrapper {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 12px !important;
}

.btn-planta-baixa .elementor-button-icon {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 24px !important;
  min-width: 24px !important;
  height: 24px !important;
  line-height: 0 !important;
}

.btn-planta-baixa .elementor-button-icon svg,
.btn-planta-baixa .elementor-button-icon img {
  width: 24px !important;
  min-width: 24px !important;
  max-width: none !important;
  height: 24px !important;
  object-fit: contain !important;
  display: block !important;
}

.horoh-diferenciais {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 28px 36px;
  align-items: center;
  width: 100%;
}

.horoh-diferenciais__item {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.horoh-diferenciais .horoh-diferenciais__icon,
.horoh-diferenciais img.horoh-diferenciais__icon,
.horoh-diferenciais svg.horoh-diferenciais__icon,
.horoh-diferenciais__item img,
.horoh-diferenciais__item svg {
  width: 24px !important;
  min-width: 24px !important;
  max-width: 24px !important;
  height: 24px !important;
  min-height: 24px !important;
  max-height: 24px !important;
  flex: 0 0 24px !important;
  object-fit: contain !important;
  display: block !important;
}

.horoh-diferenciais__text {
  display: block;
  font-size: 0.7rem;
  line-height: 1.45;
  font-weight: 400;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #101c1e;
  max-width: 180px;
}
@media (max-width: 1200px) {
  .horoh-diferenciais {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 24px 30px;
  }
}

@media (max-width: 900px) {
  .horoh-diferenciais {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 22px 26px;
  }
}

@media (max-width: 640px) {
  .horoh-diferenciais {
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .horoh-diferenciais__icon {
    width: 30px;
    height: 30px;
    flex-basis: 30px;
  }

  .horoh-diferenciais__text {
    font-size: 0.68rem;
  }
}
.horoh-diferenciais__item {
  transition: transform 0.35s ease;
}

.horoh-diferenciais__icon {
  transition:
    transform 0.35s ease,
    filter 0.35s ease;
  transform-origin: center;
  will-change: transform;
}

.horoh-diferenciais__item:hover .horoh-diferenciais__icon {
  transform: scale(1.18);
}

/* HOROH - remover espaçamento somente da galeria ACF */
.horoh-galeria-acf {
  line-height: 0;
  font-size: 0;
}

.horoh-galeria-acf .gallery {
  gap: 0 !important;
  row-gap: 0 !important;
  column-gap: 0 !important;
  margin: 0 !important;
}

.horoh-galeria-acf .gallery-item {
  margin: 0 !important;
  padding: 0 !important;
}

.horoh-galeria-acf .gallery-icon {
  margin: 0 !important;
  padding: 0 !important;
}

.horoh-galeria-acf .gallery-icon a {
  margin: 0 !important;
  padding: 0 !important;
}

.horoh-galeria-acf .gallery img {
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
}

.horoh-contato-section {
  color: #12332d;
}

.horoh-form-contato {
  width: 100%;
  font-family: "RNS Sanz", Arial, sans-serif;
  color: #12332d;
}

.horoh-form-contato p {
  margin: 0;
}

.horoh-form-required {
  margin-bottom: 34px !important;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: #12332d;
}

.horoh-form-contato label {
  display: block;
  width: 100%;
  margin-bottom: 18px;
  font-family: "RNS Sanz", Arial, sans-serif;
  font-size: 0.78rem;
  font-weight: 800;
  line-height: 1.2;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: #12332d;
}

.horoh-form-contato input,
.horoh-form-contato select,
.horoh-form-contato textarea {
  width: 100%;
  min-height: 50px;
  margin-top: 10px;
  padding: 14px 18px;
  font-family: "RNS Sanz", Arial, sans-serif;
  font-size: 0.9rem;
  font-weight: 400;
  color: #12332d;
  background: #ffffff;
  border: 1px solid rgba(18, 51, 45, 0.15);
  border-radius: 0;
  outline: none;
  box-shadow: none;
}

.horoh-form-contato select {
  appearance: none;
  background-image:
    linear-gradient(45deg, transparent 50%, #12332d 50%),
    linear-gradient(135deg, #12332d 50%, transparent 50%);
  background-position:
    calc(100% - 22px) 22px,
    calc(100% - 16px) 22px;
  background-size:
    6px 6px,
    6px 6px;
  background-repeat: no-repeat;
}

.horoh-form-contato textarea {
  min-height: 160px;
  resize: vertical;
}

.horoh-form-contato input:focus,
.horoh-form-contato select:focus,
.horoh-form-contato textarea:focus {
  border-color: #12332d;
  background: #ffffff;
}

.horoh-form-grid {
  display: grid;
  gap: 26px;
}

.horoh-form-grid-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.horoh-form-message-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 10px;
}

.horoh-form-message-head label {
  margin: 0;
}

.horoh-form-message-head span {
  margin-bottom: 2px;
  font-family: "RNS Sanz", Arial, sans-serif;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  color: #12332d;
}

.horoh-form-privacy {
  margin-top: 26px;
  margin-bottom: 26px;
  font-family: "RNS Sanz", Arial, sans-serif;
  font-size: 0.82rem;
  font-weight: 400;
  color: #12332d;
}

.horoh-form-privacy .wpcf7-list-item {
  margin: 0;
}

.horoh-form-privacy label {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 0;
  font-size: 0.82rem;
  font-weight: 400;
  line-height: 1.4;
  letter-spacing: 0.01em;
  text-transform: none;
}

.horoh-form-privacy input[type="checkbox"] {
  width: 26px;
  min-width: 26px;
  height: 26px;
  min-height: 26px;
  margin: 0;
  padding: 0;
  border: 1px solid rgba(18, 51, 45, 0.18);
}

.horoh-form-privacy a {
  color: #12332d;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.horoh-form-submit {
  margin-top: 8px;
}

.horoh-form-contato input[type="submit"] {
  width: auto;
  min-width: 92px;
  min-height: 42px;
  padding: 13px 22px;
  font-family: "RNS Sanz", Arial, sans-serif;
  font-size: 0.58rem;
  font-weight: 700;
  letter-spacing: 0.34em;
  text-transform: uppercase;
  color: #ffffff;
  background: #172520;
  border: 1px solid #172520;
  cursor: pointer;
  transition: all 0.25s ease;
}

.horoh-form-contato input[type="submit"]:hover {
  color: #172520;
  background: transparent;
}

.horoh-form-contato .wpcf7-not-valid-tip {
  margin-top: 6px;
  font-size: 0.72rem;
  font-weight: 400;
  color: #9b1c1c;
  text-transform: none;
}

.horoh-form-contato .wpcf7-response-output {
  margin: 24px 0 0;
  padding: 14px 18px;
  font-size: 0.82rem;
  border-radius: 0;
}

/* Coluna lateral */

.horoh-contato-info {
  font-family: "RNS Sanz", Arial, sans-serif;
  color: #12332d;
}

.horoh-contato-info-item {
  margin-bottom: 48px;
}

.horoh-contato-info h3 {
  margin: 0 0 18px;
  font-family: "RNS Sanz", Arial, sans-serif;
  font-size: 0.95rem;
  font-weight: 800;
  line-height: 1.2;
  text-transform: uppercase;
  color: #12332d;
}

.horoh-contato-info p {
  margin: 0 0 18px;
  font-family: "RNS Sanz", Arial, sans-serif;
  font-size: 0.92rem;
  font-weight: 400;
  line-height: 1.45;
  color: #12332d;
}

.horoh-contato-info strong {
  font-weight: 800;
}

.horoh-contato-map {
  font-weight: 700;
  text-decoration: underline !important;
  text-underline-offset: 4px;
}

/* Responsivo */

@media (max-width: 1024px) {
  .horoh-form-grid-2 {
    gap: 20px;
  }
}

@media (max-width: 767px) {
  .horoh-form-grid-2 {
    grid-template-columns: 1fr;
    gap: 0;
  }

  .horoh-form-message-head {
    display: block;
  }

  .horoh-form-message-head span {
    display: block;
    margin-top: 6px;
  }

  .horoh-form-contato input[type="submit"] {
    width: 100%;
  }

  .horoh-contato-info {
    margin-top: 48px;
  }

  .horoh-contato-info-item {
    margin-bottom: 36px;
  }
}
.horoh-form-contato .horoh-form-privacy {
  margin-top: 26px;
  margin-bottom: 18px;
  font-family: "RNS Sanz", Arial, sans-serif;
  color: #12332d;
}

.horoh-form-contato .horoh-form-privacy .wpcf7-form-control-wrap,
.horoh-form-contato .horoh-form-privacy .wpcf7-acceptance,
.horoh-form-contato .horoh-form-privacy .wpcf7-list-item {
  display: block;
  margin: 0;
}

.horoh-form-contato .horoh-form-privacy label {
  display: flex;
  align-items: center;
  gap: 14px;
  margin: 0;
  font-family: "RNS Sanz", Arial, sans-serif;
  font-size: 0.92rem;
  font-weight: 400;
  line-height: 1.4;
  letter-spacing: 0;
  text-transform: none;
  color: #12332d;
}

.horoh-form-contato .horoh-form-privacy input[type="checkbox"] {
  appearance: none;
  -webkit-appearance: none;
  width: 34px;
  min-width: 34px;
  height: 34px;
  min-height: 34px;
  margin: 0;
  padding: 0;
  background: #f7f7f4;
  border: 1px solid rgba(18, 51, 45, 0.45);
  border-radius: 2px;
  cursor: pointer;
}

.horoh-form-contato .horoh-form-privacy input[type="checkbox"]:checked {
  background: #172520;
  border-color: #172520;
  box-shadow: inset 0 0 0 7px #f7f7f4;
}

.horoh-form-contato .horoh-form-privacy a {
  text-decoration-thickness: auto;
  text-underline-offset: 4px;
}

/* ==========================================================================
   HOROH | DIFERENCIAIS DO POST
   Shortcode: [horoh_diferenciais_post]
   ========================================================================== */

.horoh-diferenciais {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  align-items: stretch;
  margin: 0;
  padding: 0;
}

.horoh-diferenciais,
.horoh-diferenciais * {
  font-family: var(
    --horoh-font-body,
    "RNS Sanz",
    "RNSSanz-Light",
    Arial,
    sans-serif
  );
  letter-spacing: 0;
  word-spacing: 0;
}

.horoh-diferenciais__item {
  display: flex;
  align-items: center;
  gap: 14px;
  min-width: 0;
  min-height: 72px;
  padding: 16px 18px;
  background: #f4f1eb;
  border: 1px solid rgba(35, 45, 43, 0.08);
  color: #12332d;
  transition:
    background-color 0.28s ease,
    border-color 0.28s ease,
    transform 0.28s ease;
}

.horoh-diferenciais__item:hover {
  background: #ffffff;
  border-color: rgba(35, 45, 43, 0.18);
  transform: translateY(-2px);
}

.horoh-diferenciais__icon,
.horoh-diferenciais img.horoh-diferenciais__icon,
.horoh-diferenciais svg.horoh-diferenciais__icon,
.horoh-diferenciais__item img,
.horoh-diferenciais__item svg {
  width: 30px !important;
  min-width: 30px !important;
  max-width: 30px !important;
  height: 30px !important;
  min-height: 30px !important;
  max-height: 30px !important;
  flex: 0 0 30px !important;
  object-fit: contain !important;
  display: block !important;
  color: #12332d;
  transition:
    transform 0.28s ease,
    opacity 0.28s ease;
}

.horoh-diferenciais__item:hover .horoh-diferenciais__icon,
.horoh-diferenciais__item:hover img,
.horoh-diferenciais__item:hover svg {
  transform: scale(1.08);
}

.horoh-diferenciais__text {
  display: block;
  min-width: 0;
  max-width: none;
  font-family: var(
    --horoh-font-body,
    "RNS Sanz",
    "RNSSanz-Light",
    Arial,
    sans-serif
  );
  font-size: 1rem;
  line-height: 1;
  font-weight: 400;
  letter-spacing: 0;
  word-spacing: 0;
  text-transform: none;
  color: #12332d;
}

@media (max-width: 1200px) {
  .horoh-diferenciais {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .horoh-diferenciais {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
  }

  .horoh-diferenciais__item {
    min-height: 68px;
    padding: 14px 16px;
  }
}

@media (max-width: 640px) {
  .horoh-diferenciais {
    grid-template-columns: 1fr;
  }

  .horoh-diferenciais__item {
    min-height: 64px;
    padding: 14px;
  }

  .horoh-diferenciais__icon,
  .horoh-diferenciais img.horoh-diferenciais__icon,
  .horoh-diferenciais svg.horoh-diferenciais__icon,
  .horoh-diferenciais__item img,
  .horoh-diferenciais__item svg {
    width: 28px !important;
    min-width: 28px !important;
    max-width: 28px !important;
    height: 28px !important;
    min-height: 28px !important;
    max-height: 28px !important;
    flex-basis: 28px !important;
  }

  .horoh-diferenciais__text {
    font-size: 1rem;
    line-height: 1;
    letter-spacing: 0;
    word-spacing: 0;
  }
}

/* ==========================================================================
   HOROH | DIFERENCIAIS DO POST
   Shortcode: [horoh_diferenciais_post]
   Visual sem fundo / sem card
   ========================================================================== */

.horoh-diferenciais {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px 28px;
  align-items: start;
  margin: 0;
  padding: 0;
}

.horoh-diferenciais,
.horoh-diferenciais * {
  font-family: var(
    --horoh-font-body,
    "RNS Sanz",
    "RNSSanz-Light",
    Arial,
    sans-serif
  );
  letter-spacing: 0;
  word-spacing: 0;
}

.horoh-diferenciais__item {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
  min-height: auto;
  margin: 0;
  padding: 0;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  color: #12332d;
  transition: transform 0.25s ease;
}

.horoh-diferenciais__item:hover {
  transform: translateY(-1px);
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

.horoh-diferenciais__icon,
.horoh-diferenciais img.horoh-diferenciais__icon,
.horoh-diferenciais svg.horoh-diferenciais__icon,
.horoh-diferenciais__item img,
.horoh-diferenciais__item svg {
  width: 22px !important;
  min-width: 22px !important;
  max-width: 22px !important;
  height: 22px !important;
  min-height: 22px !important;
  max-height: 22px !important;
  flex: 0 0 22px !important;
  object-fit: contain !important;
  display: block !important;
  color: #12332d;
  transition: transform 0.25s ease;
}

.horoh-diferenciais__item:hover .horoh-diferenciais__icon,
.horoh-diferenciais__item:hover img,
.horoh-diferenciais__item:hover svg {
  transform: scale(1.06);
}

.horoh-diferenciais__text {
  display: block;
  min-width: 0;
  max-width: 100px;
  margin: 0;
  padding: 0;

  font-family: var(
    --horoh-font-body,
    "RNS Sanz",
    "RNSSanz-Light",
    Arial,
    sans-serif
  );
  font-size: 0.9rem;

  letter-spacing: 0;
  word-spacing: 0;
  text-transform: none;

  color: #000000;

  white-space: normal;
  overflow-wrap: break-word;
  word-break: normal;
}

/* Responsivo */
@media (max-width: 1024px) {
  .horoh-diferenciais {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px 22px;
  }

  .horoh-diferenciais__text {
    max-width: 100px;
  }
}

@media (max-width: 640px) {
  .horoh-diferenciais {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .horoh-diferenciais__icon,
  .horoh-diferenciais img.horoh-diferenciais__icon,
  .horoh-diferenciais svg.horoh-diferenciais__icon,
  .horoh-diferenciais__item img,
  .horoh-diferenciais__item svg {
    width: 20px !important;
    min-width: 20px !important;
    max-width: 20px !important;
    height: 20px !important;
    min-height: 20px !important;
    max-height: 20px !important;
    flex-basis: 20px !important;
  }

  .horoh-diferenciais__text {
    max-width: 100%;
  }
}

.horoh-quebra-auto,
.horoh-quebra-auto .elementor-heading-title,
.horoh-quebra-auto .elementor-icon-list-text {
  line-height: 1.15;
  white-space: normal;
}

.horoh-quebra-auto .horoh-linha-palavra {
  display: block;
}

/* HOROH CSS Segura: seção movida para assets/css/horoh-loop-slider.css. */

/* ==========================================================================
   HOROH | Galeria Grid Elementor
   Uso no container:
   horoh-galeria-grid horoh-grid-2
   horoh-galeria-grid horoh-grid-3
   horoh-galeria-grid horoh-grid-4
   ========================================================================== */

.horoh-galeria-grid {
  --display: grid !important;
  --horoh-grid-columns: 3;
  --horoh-grid-ratio: 16 / 9;

  display: grid !important;
  grid-template-columns: repeat(
    var(--horoh-grid-columns),
    minmax(0, 1fr)
  ) !important;
  gap: 0 !important;
  row-gap: 0 !important;
  column-gap: 0 !important;
  width: 100% !important;
  max-width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
  line-height: 0 !important;
}

/* Quando o Elementor usa container boxed com .e-con-inner */
.horoh-galeria-grid > .e-con-inner {
  display: grid !important;
  grid-template-columns: repeat(
    var(--horoh-grid-columns),
    minmax(0, 1fr)
  ) !important;
  gap: 0 !important;
  row-gap: 0 !important;
  column-gap: 0 !important;
  width: 100% !important;
  max-width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* Controle de colunas */
.horoh-galeria-grid.horoh-grid-2 {
  --horoh-grid-columns: 2;
}

.horoh-galeria-grid.horoh-grid-3 {
  --horoh-grid-columns: 3;
}

.horoh-galeria-grid.horoh-grid-4 {
  --horoh-grid-columns: 4;
}

/* Força os widgets de imagem a obedecerem o grid */
.horoh-galeria-grid > .elementor-widget-image,
.horoh-galeria-grid > .e-con-inner > .elementor-widget-image {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Remove espaçamentos internos do widget */
.horoh-galeria-grid .elementor-widget-image,
.horoh-galeria-grid .elementor-widget-image .elementor-widget-container,
.horoh-galeria-grid .elementor-widget-image figure,
.horoh-galeria-grid .elementor-widget-image a {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  line-height: 0 !important;
}

/* Padroniza todas as imagens */
.horoh-galeria-grid .elementor-widget-image img {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  aspect-ratio: var(--horoh-grid-ratio) !important;
  object-fit: cover !important;
  object-position: center !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  vertical-align: top !important;
}

/* Tablet */
@media (max-width: 1024px) {
  .horoh-galeria-grid.horoh-grid-3,
  .horoh-galeria-grid.horoh-grid-4 {
    --horoh-grid-columns: 2;
  }
}

/* Mobile */
@media (max-width: 767px) {
  .horoh-galeria-grid,
  .horoh-galeria-grid.horoh-grid-2,
  .horoh-galeria-grid.horoh-grid-3,
  .horoh-galeria-grid.horoh-grid-4 {
    --horoh-grid-columns: 1;
    --horoh-grid-ratio: 4 / 3;
  }
}
/* ==========================================================================
   HOROH | Correção definitiva de âncora para cards de acomodação
   Evita offset duplicado entre html, Elementor e âncora customizada
   ========================================================================== */

html {
  scroll-behavior: smooth;
  scroll-padding-top: 0 !important;
}

/* Neutraliza offsets globais antigos que estavam causando pulo */
.site-main > section[id],
.site-main > div[id],
.site-main > main[id],
.site-main > article[id],
.horoh-shell [id],
[class*="horoh-"][id],
.elementor-element:has([class*="horoh-"])[id],
.elementor-section:has([class*="horoh-"])[id],
.elementor-top-section:has([class*="horoh-"])[id] {
  scroll-margin-top: 0 !important;
}

/* Não usar o recuo antigo do Elementor Menu Anchor junto com a âncora customizada */
.elementor-menu-anchor {
  top: 0 !important;
}

/* Âncora criada pelo shortcode [horoh_ancora_post] */
.horoh-anchor-target {
  display: block !important;
  position: relative !important;
  height: 0 !important;
  min-height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
  visibility: hidden !important;
  pointer-events: none !important;
  scroll-margin-top: 0 !important;

  /* Ajuste fino da posição final */
  top: -150px !important;
}

/* Quando logado no WordPress, compensa também a barra admin */
body.admin-bar .horoh-anchor-target {
  top: -104px !important;
}

@media (max-width: 1024px) {
  .horoh-anchor-target {
    top: -76px !important;
  }

  body.admin-bar .horoh-anchor-target {
    top: -122px !important;
  }
}

@media (max-width: 767px) {
  .horoh-anchor-target {
    top: -68px !important;
  }

  body.admin-bar .horoh-anchor-target {
    top: -114px !important;
  }
}
/* ==========================================================================
   HOROH | Página Reservas usando motor real
   ========================================================================== */

.horoh-reservas-motor-real {
  width: 100%;
  background: #f7f2ea;
  padding: clamp(48px, 7vw, 96px) clamp(16px, 4vw, 48px);
}

.horoh-reservas-motor-real__inner {
  width: 100%;
  max-width: 1480px;
  margin: 0 auto;
  padding: clamp(32px, 5vw, 64px);
  background: #f9f6ef;
  border: 1px solid rgba(35, 45, 43, 0.18);
  box-shadow: 0 20px 60px rgba(35, 45, 43, 0.08);
}

/* Mensagem administrativa caso o shortcode real esteja errado */
.horoh-reservas-motor-alert {
  max-width: 960px;
  margin: 40px auto;
  padding: 20px 24px;
  border: 1px solid #d4b06a;
  background: #fff8e8;
  color: #002816;
  font-family: Arial, sans-serif;
  font-size: 15px;
  line-height: 1.5;
}

/* Ajuste geral do motor real dentro da página */
.horoh-reservas-motor-real form,
.horoh-reservas-motor-real .hgh-reservation-hook,
.horoh-reservas-motor-real .horoh-booking-bridge,
.horoh-reservas-motor-real .horoh-booking,
.horoh-reservas-motor-real .booking-form {
  width: 100%;
  max-width: 100%;
}

/* Campos principais */
.horoh-reservas-motor-real input,
.horoh-reservas-motor-real select,
.horoh-reservas-motor-real button {
  font-family: var(--horoh-font-body, "RNS Sanz", Arial, sans-serif);
}

/* Layout base para campos do motor */
.horoh-reservas-motor-real .hgh-reservation-hook,
.horoh-reservas-motor-real .horoh-booking-bridge {
  background: #f9f6ef;
  color: #002816;
}

/* Labels */
.horoh-reservas-motor-real label,
.horoh-reservas-motor-real .label,
.horoh-reservas-motor-real [class*="label"] {
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #001f3f;
}

/* Botão principal */
.horoh-reservas-motor-real button[type="submit"],
.horoh-reservas-motor-real .button,
.horoh-reservas-motor-real .btn,
.horoh-reservas-motor-real [class*="submit"],
.horoh-reservas-motor-real [class*="availability"] {
  border-radius: 0;
}

/* Calendário / dropdown do motor real */
.horoh-reservas-motor-real .flatpickr-calendar,
.horoh-reservas-motor-real .datepicker,
.horoh-reservas-motor-real [class*="calendar"],
.horoh-reservas-motor-real [class*="date-picker"] {
  font-family: var(--horoh-font-body, "RNS Sanz", Arial, sans-serif);
}

/* Responsivo */
@media (max-width: 767px) {
  .horoh-reservas-motor-real {
    padding: 32px 12px 56px;
  }

  .horoh-reservas-motor-real__inner {
    padding: 20px 14px;
  }
}

/* HOROH | Botão Reservar fixo no rodapé - Mobile */

@media (max-width: 767px) {
  .horoh-header-reserva {
    position: fixed !important;
    left: 50% !important;
    bottom: calc(50px + env(safe-area-inset-bottom)) !important;
    transform: translateX(-50%) !important;
    z-index: 99999 !important;
    margin: 0 !important;
  }

}
