/* =============================================
   CORRECCIONES LOCALES — Wine for the Few
   ============================================= */

/* 1. SCROLLBAR — reserva espacio siempre, evita el salto de ancho */
html {
  scrollbar-gutter: stable;
  overflow-y: scroll;
}

/* 2. PARALLAX SUAVE — imágenes con parallax en GPU para mayor fluidez */
.home-services-item-image,
.home-services-item-image img,
.home-hero-image img,
.post-image,
.post-image img,
.section-home-hero img {
  will-change: transform;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}

/* 2b. SIN PARALLAX en la sección "Rare Wines Only For Rare People"
   Esa imagen queda fija — Webflow no la mueve con el scroll */
.home-services-item.odd .home-services-item-image,
.home-services-item.odd .home-services-item-image img {
  will-change: auto !important;
  transform: none !important;
  transition: none !important;
}

/* 3. REVEAL — elementos visibles una vez revelados, entrada suave */
.wftf-revealed {
  opacity: 1 !important;
  transition: opacity 0.6s ease !important;
  will-change: auto !important;
  /* NO tocamos transform aquí para no romper el parallax */
}

/* 4. BLOG — espacio superior reducido */
@media screen and (min-width: 992px) {
  .section-blog-posts-top {
    padding-top: 5rem !important;
  }
}

/* 5. BLOG — espacio antes del footer */
.section-blog-posts {
  padding-bottom: 6rem !important;
}

/* 6. SCROLL REVEAL — texto que sube al entrar en el viewport */
[data-reveal-slide] {
  transform: translate3d(0, 105%, 0);
  display: block;
}
.overflow-hidden.is-revealed [data-reveal-slide] {
  transform: translate3d(0, 0%, 0);
  transition: transform 0.9s cubic-bezier(0.16, 1, 0.3, 1);
}

[data-reveal-fade] {
  opacity: 0;
  transform: translate3d(0, 22px, 0);
}
[data-reveal-fade].is-revealed {
  opacity: 1;
  transform: translate3d(0, 0, 0);
  transition: opacity 0.7s ease, transform 0.7s ease;
}

/* 7. PAGELOADER — telón negro con WFTF© que sube al cargar la página
   Todo (display, transform, transition) lo controla PageLoader.tsx vía style inline.
   El CSS sólo garantiza que empiece oculto. */
.pageloader {
  display: none;
}

/* 8. BLOG — links de posts (display block, sin depender de w-inline-block) */
.post-preview-image-wrapper,
.post-preview-content {
  display: block;
  max-width: 100%;
}

/* 9. NAVBAR — navbar-menu-item y navbar-logo sin w-inline-block (no hay Webflow JS) */
.navbar-menu-item {
  display: flex;
  align-items: center;
  max-width: 100%;
}
.navbar-logo {
  display: inline-flex;
  align-items: center;
  max-width: 100%;
  text-decoration: none;
}
.button-text {
  display: inline-flex;
  max-width: 100%;
  text-decoration: none;
}

/* 10. NAVBAR PEQUEÑA — aparece fija al hacer scroll (controlada por React state) */
.header-small-copy {
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease, transform 0.3s ease;
  transform: translateY(-8px);
}
.header-small-copy.is-scrolled {
  position: fixed !important;
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
  background-color: var(--global-colors--background-default);
  box-shadow: 0 1px 0 rgba(0,0,0,0.08);
}

/* 11. MOBILE MENU — toggle button sin estilos de <a>, menú animado */
.mobile-menu-toggle {
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
}
.mobile-menu {
  transition: opacity 0.25s ease, transform 0.35s cubic-bezier(0.16, 1, 0.3, 1);
  opacity: 0;
  transform: translateY(-12px);
  pointer-events: none;
}
.mobile-menu.is-open {
  display: block !important;
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

/* Hamburger → X cuando el menú está abierto */
.mobile-menu-toggle .menu-toggle-line {
  transition: transform 0.3s ease, opacity 0.2s ease;
}
.mobile-menu-toggle.is-open .menu-toggle-line.top {
  transform: translateY(5px) rotate(45deg);
}
.mobile-menu-toggle.is-open .menu-toggle-line.bottom {
  transform: translateY(-5px) rotate(-45deg);
}

/* 12. FOOTER — entra más tarde: la última sección de servicios tiene espacio extra */
.section-home-services {
  padding-bottom: 25vh;
}

/* Asegura que el footer no se superponga antes de tiempo */
.footer {
  position: relative;
  z-index: 0;
}
.main-wrapper {
  position: relative;
  z-index: 1;
}
