.vitales {
  background: url('../../img/fondo2.jpg') center/cover no-repeat;
  padding: 5rem 1.5rem;
}

.vitales-bloque {
  padding: 3rem 0;
}

.vitales-contenedor {
  max-width: 1720px;
  margin: 0 auto;
  text-align: center;
}

.vitales-titulo {
  font-size: 2rem;
  margin-bottom: 1rem;
  color: #111;
}

.vitales-subtitulo {
  font-size: 1.1rem;
  margin-bottom: 2rem;
  color: #333;
}

.vitales-item img {
  width: 100%;
  height: 400px;
  object-fit: cover;
  display: block;
  transition: transform 0.3s ease;
}

.vitales-item:hover img {
  transform: scale(1.05);
}

.vitales-item:hover .vitales-amenities {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: nowrap;
  gap: var(--amen-gap);
  max-width: 1440px;
  width: 100%;
  margin: 0 auto;
  padding: 2rem 0;
}

.amenity {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.3rem;
  text-align: center;
  flex: 0 0 calc((100% - 5 * var(--amen-gap)) / 6);
}

.amenity img {
  width: var(--icon-size);
  height: var(--icon-size);
  display: inline-block;
  object-fit: contain;
}

.amenity p {
  font-size: 1.05rem;
  margin-top: 0.2rem;
  color: #111;
}

.vitales-item img {
  width: 100%;
  height: 400px;
  object-fit: cover;
  display: block;
  transition: transform 0.3s ease;
}

.vitales-item:hover img {
  transform: scale(1.05);
}


.amenity {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.3rem;
  text-align: center;
  flex: 0 0 calc((100% - 5 * var(--amen-gap)) / 6);
}


.amenity p {
  font-size: 1.05rem;
  margin-top: 0.2rem;
  color: #111;
}


.galeria-carrusel {
  position: relative;
  max-width: 1280px;
  margin: 2rem auto 0;
  overflow: hidden;
  
}

.slide {
  display: none;
  position: relative;
}

.slide.activo {
  display: block;
}

.slide img {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  display: block;
}

.flecha {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background-color: rgba(0, 0, 0, 0.4);
  color: #fff;
  border: none;
  padding: 0.8rem 1rem;
  cursor: pointer;
  z-index: 10;
  border-radius: 50%;
  font-size: 2.2rem;

  border: none;
  outline: none;
  box-shadow: none;

  background-color: transparent;
  border: none;
  outline: none;
  box-shadow: none;
  border-radius: 0;
}

.flecha.anterior {
  left: 10px;
}

.flecha.siguiente {
  right: 10px;
}

.indicadores {
  text-align: center;
  margin-top: 1rem;
}

.indicadores span {
  display: inline-block;
  width: 12px;
  height: 12px;
  margin: 0 6px;
  background-color: #888;
  border-radius: 50%;
  cursor: pointer;
  transition: background-color 0.3s ease;
}

.indicadores span.activo {
  background-color: #fff;
}

.vitales-slider img {
  transition: transform 0.6s ease-in-out, border-radius 0.3s ease-in-out;
  border-radius: 16px;
  object-fit: cover;
}

.vitales-slider img:hover {
  transform: scale(1.02);
  border-radius: 16px;
}


/* === MEJORAS PARA BLOQUE 1 - V98 === */
.vitales-slider .slide img {
  border-radius: 16px;
  transition: transform 0.4s ease, opacity 0.6s ease-in-out;
  overflow: hidden;
}

.vitales-slider .slide img:hover {
  transform: scale(1.02);
}

/* Suavizar entrada de cada slide (fade) */
.vitales-slider .slide {
  transition: opacity 0.6s ease-in-out;
  opacity: 0;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
}

.vitales-slider .slide.active {
  opacity: 1;
  position: relative;
}

/* ===================== AMENITIES (Fila horizontal) ===================== */
/* Variables locales (solo afectan amenities) */
.amenities,
.bloque-amenities {
  --amen-gap: clamp(12px, 2vw, 24px);
  --icon-size: clamp(56px, 7vw, 88px);
}

/* Contenedor de ítems: SIEMPRE en una sola fila en desktop */
.amenities__grid,
.amenities__lista {
  display: flex;
  flex-wrap: nowrap;                 /* clave: no permitir salto a otra línea */
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--amen-gap);
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  padding-bottom: 6px;               /* evita cortar la sombra del scroll */
}

/* Cada ítem ocupa 1/6 del ancho en desktop */
.amenities__item,
.amenity {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.3rem;
  text-align: center;
  flex: 0 0 calc((100% - 5 * var(--amen-gap)) / 6);
}

/* Icono: tamaño fluido, centrado y sin deformación */
.amenities__icon,
.amenity__icon,
.amenities__item img,
.amenity img {
  width: var(--icon-size);
  height: var(--icon-size);
  display: inline-block;
  object-fit: contain;
}

/* Títulos/etiquetas de cada ítem */
.amenities__label,
.amenity__label {
  display: block;
  margin-top: 8px;
  font-weight: 500;
  line-height: 1.25;
}

/* --------- Responsivo: mantener fila única con scroll si hace falta --------- */
@media (max-width: 1280px) { .amenity {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.3rem;
  text-align: center;
  flex: 0 0 calc((100% - 5 * var(--amen-gap)) / 6);
} }
@media (max-width: 768px) { .amenity {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.3rem;
  text-align: center;
  flex: 0 0 calc((100% - 5 * var(--amen-gap)) / 6);
} }

/* ===================== HOTFIX: Amenities horizontal seguro ===================== */
/* Escopado a Espacios Vitales / Amenities sin romper otros bloques */
:root {
  --amen-gap: clamp(16px, 2vw, 28px);
  --amen-icon: clamp(72px, 8vw, 110px);
}

/* Contenedores posibles */
.vitales .bloque-amenities .vitales-amenities,
.vitales .bloque-amenities .amenities,
.vitales .bloque-amenities .amenities__lista,
.vitales .bloque-amenities .amenities__grid,
.vitales-amenities, .amenities, .amenities__lista, .amenities__grid {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  justify-content: space-between !important;
  align-items: flex-start !important;
  gap: var(--amen-gap) !important;
  width: 100%;
  margin: 0 auto;
}

/* Ítems (6 en fila) */
.vitales .bloque-amenities .vitales-amenities > *,
.vitales .bloque-amenities .amenities > *,
.vitales .bloque-amenities .amenities__lista > *,
.vitales .bloque-amenities .amenities__grid > *,
.vitales-amenities > *, .amenities > *, .amenities__lista > *, .amenities__grid > * {
  flex: 0 0 calc((100% - 5 * var(--amen-gap)) / 6) !important;
  text-align: center;
}

/* Iconos */
.vitales .bloque-amenities img,
.vitales-amenities img,
.amenities img,
.amenities__lista img,
.amenities__grid img {
  width: var(--amen-icon) !important;
  height: var(--amen-icon) !important;
  object-fit: contain;
  display: inline-block;
}

/* Etiquetas */
.vitales .bloque-amenities .amenity__label,
.amenities__label, .amenity__label {
  display: block;
  margin-top: 8px;
  line-height: 1.25;
  font-weight: 500;
}

/* Evitar reglas heredadas que rompen la fila */
.vitales-amenities > * { max-width: none !important; }
.vitales-amenities > * > * { width: auto !important; }

@media (max-width: 1280px) {
  .vitales-amenities > *,
  .amenities > *,
  .amenities__lista > *,
  .amenities__grid > * {
    min-width: 180px !important;
    flex: 0 0 auto !important;
  }
}

@media (max-width: 768px) {
  .vitales-amenities > *,
  .amenities > *,
  .amenities__lista > *,
  .amenities__grid > * {
    min-width: 160px !important;
  }
}
/* =================== FIN HOTFIX: Amenities horizontal seguro =================== */

/* ===================== AMENITIES – Hover pro + microinteracciones ===================== */
/* Ajustes suaves, sin romper layout */
.amenity {
  transition: transform .25s ease, box-shadow .25s ease;
  will-change: transform;
}
.amenity:hover {
  transform: translateY(-4px);
}

.amenity img,
.amenities__icon,
.amenity__icon {
  transition: transform .25s ease, filter .25s ease, opacity .25s ease;
  will-change: transform;
}
.amenity:hover img,
.amenity:hover .amenities__icon,
.amenity:hover .amenity__icon {
  transform: scale(1.06);
  filter: drop-shadow(0 6px 16px rgba(0,0,0,.25));
}

.amenities__label,
.amenity__label {
  opacity: .9;
  transition: opacity .25s ease;
}
.amenity:hover .amenities__label,
.amenity:hover .amenity__label {
  opacity: 1;
}

/* Accesibilidad: respetar usuarios con “reducir movimiento” */
@media (prefers-reduced-motion: reduce) {
  .amenity,
  .amenity img,
  .amenities__icon,
  .amenity__icon {
    transition: none !important;
    transform: none !important;
    filter: none !important;
  }
}
