/* Estilos para el slider principal - Versión completamente responsive mejorada */
#sliderPrincipal {
  margin-bottom: 30px;
  position: relative;
  overflow: hidden;
}

/* Solución para que el slider se adapte a cualquier tamaño */
#sliderPrincipal .carousel-inner {
  width: 100%;
}

/* Enfoque basado en relación de aspecto en lugar de altura fija */
#sliderPrincipal .carousel-item {
  position: relative;
  width: 100%;
  height: auto;
  overflow: hidden;
}

/* La relación de aspecto para el contenedor (16:9 es un buen punto medio) */
#sliderPrincipal .carousel-item::before {
  content: "";
  display: block;
  padding-top: 40%; /* Para pantallas grandes (proporción más ancha) */
}

/* Posicionamiento de la imagen para evitar cortes */
#sliderPrincipal .carousel-item img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center; /* Centra el contenido importante */
}

/* Mejorando indicadores para mejor visibilidad */
#sliderPrincipal .carousel-indicators {
  bottom: 20px;
  z-index: 5;
}

#sliderPrincipal .carousel-indicators button {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  margin: 0 5px;
  background-color: rgba(255, 255, 255, 0.7);
  border: 1px solid rgba(0, 0, 0, 0.2);
}

#sliderPrincipal .carousel-indicators button.active {
  background-color: var(--bs-primary);
}

/* Mejorando controles para mejor visibilidad */
#sliderPrincipal .carousel-control-prev,
#sliderPrincipal .carousel-control-next {
  width: 10%;
  opacity: 0.7;
  z-index: 5;
}

#sliderPrincipal .carousel-control-prev-icon,
#sliderPrincipal .carousel-control-next-icon {
  width: 40px;
  height: 40px;
  background-color: rgba(0, 0, 0, 0.3);
  border-radius: 50%;
  background-size: 50%;
}

/* Botones en el slider */
#sliderPrincipal .btn-container {
  position: absolute;
  bottom: 20px;
  left: 0;
  right: 0;
  text-align: center;
  z-index: 4;
}

#sliderPrincipal .btn-primary {
  padding: 0.6rem 1.5rem;
  border-radius: 30px;
  font-weight: 600;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
  transition: all 0.3s ease;
}

#sliderPrincipal .btn-primary:hover {
  transform: translateY(-3px);
  box-shadow: 0 6px 15px rgba(0, 0, 0, 0.3);
}

/* Efecto de transición suave */
.transition-effect {
  transition: transform 0.5s ease, opacity 0.5s ease;
}

.carousel-item.active img.transition-effect {
  transform: scale(1.05);
}

/* Media queries para ajustar la relación de aspecto y comportamiento en móviles */
@media (max-width: 1199px) {
  #sliderPrincipal .carousel-item::before {
    padding-top: 45%; /* Modificamos proporcionalmente */
  }
}

@media (max-width: 991px) {
  #sliderPrincipal .carousel-item::before {
    padding-top: 50%; /* Un poco más alto para tablets */
  }
  
  #sliderPrincipal .carousel-control-prev-icon,
  #sliderPrincipal .carousel-control-next-icon {
    width: 35px;
    height: 35px;
  }
}

/* MEJORAS ESPECÍFICAS PARA MÓVILES */
@media (max-width: 767px) {
  /* Usamos una proporción más ancha para móviles para evitar cortes excesivos */
  #sliderPrincipal .carousel-item::before {
    padding-top: 45%; /* Proporción más ancha para móviles */
  }
  
  /* Cambiamos el comportamiento de las imágenes en móviles */
  #sliderPrincipal .carousel-item img {
    object-fit: contain; /* Muestra toda la imagen sin cortar */
    background-color: #f8f9fa; /* Fondo suave para las áreas vacías */
  }
  
  #sliderPrincipal .carousel-control-prev-icon,
  #sliderPrincipal .carousel-control-next-icon {
    width: 30px;
    height: 30px;
  }
  
  #sliderPrincipal .carousel-indicators button {
    width: 8px;
    height: 8px;
    margin: 0 3px;
  }
  
  #sliderPrincipal .carousel-indicators {
    bottom: 10px;
  }
  
  #sliderPrincipal .btn-container {
    bottom: 15px;
  }
  
  #sliderPrincipal .btn-primary {
    padding: 0.4rem 1rem;
    font-size: 0.875rem;
  }
}

@media (max-width: 575px) {
  /* Para pantallas muy pequeñas, mantenemos proporción ancha */
  #sliderPrincipal .carousel-item::before {
    padding-top: 50%; /* Proporción balanceada para móviles pequeños */
  }
  
  /* Opción alternativa: usar object-fit cover pero con mejor posicionamiento */
  #sliderPrincipal .carousel-item img {
    object-fit: cover;
    object-position: center top; /* Prioriza la parte superior de la imagen */
  }
  
  #sliderPrincipal .carousel-indicators {
    bottom: 5px;
  }
  
  #sliderPrincipal .btn-container {
    bottom: 10px;
  }
  
  #sliderPrincipal .btn-primary {
    padding: 0.3rem 0.8rem;
    font-size: 0.8rem;
  }
}

/* ALTERNATIVA AVANZADA: Diferentes comportamientos según orientación */
@media (max-width: 767px) and (orientation: portrait) {
  #sliderPrincipal .carousel-item img {
    object-fit: contain; /* En vertical, muestra toda la imagen */
  }
}

@media (max-width: 767px) and (orientation: landscape) {
  #sliderPrincipal .carousel-item img {
    object-fit: cover; /* En horizontal, permite recorte controlado */
    object-position: center center;
  }
}