/* 1. Forzar a que Bootstrap maneje correctamente la visibilidad de los slides */
.carousel-item {
  display: none !important; /* Oculta por defecto TODOS los slides */
  width: 100% !important;
  transition: transform 0.6s ease-in-out !important; /* Suaviza la transición lateral */
}

/* 2. Activar la visualización ÚNICAMENTE cuando el slide sea el activo o esté en transición */
.carousel-item.active,
.carousel-item-next,
.carousel-item-prev {
  display: flex !important; /* Usamos flex para alinear verticalmente el contenido interior */
  align-items: center;
}

/* 3. Estilos base limpios para el contenedor de la imagen de fondo */
.acat-hero-bg-slide {
  background-size: cover !important;
  background-position: center center !important;
  background-repeat: no-repeat !important;
  position: relative;
  min-height: 60vh; 
  padding: 60px 0;
}

/* 4. Capa de oscurecimiento (Overlay) */
.acat-hero-bg-slide::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(135deg, rgba(10, 37, 64, 0.9) 0%, rgba(10, 37, 64, 0.6) 100%);
  z-index: 1;
}

/* 5. Asegurar que el contenedor del texto flote por encima del fondo negro */
.acat-hero-bg-slide .container-xl {
  position: relative;
  z-index: 2;
  width: 100%;
}

/* 6. Tu maquetación de dos columnas (Corregida y aislada del comportamiento de Bootstrap) */
.acat-hero-grid-inner {
  display: grid !important;
  grid-template-columns: 1fr 1fr; 
  gap: 40px;
  align-items: center;
  width: 100%;
}

/* Responsive para celulares y tablets pequeñas */
@media (max-width: 991px) {
  .acat-hero-grid-inner {
    grid-template-columns: 1fr !important;
    text-align: center;
    gap: 30px;
  }
  .acat-cluster {
    justify-content: center;
  }
}


	
	
/**********************/	
/******* MARCAS *******/
/* Contenedor principal que oculta el desborde lateral */
.acat-logo-slider {
  overflow: hidden;
  position: relative;
  width: 100%;
  padding: 15px 0;
  background: transparent;
}

/* Difuminados elegantes en los extremos (Ocultos en móvil para mejor rendimiento) */
@media (min-width: 768px) {
  .acat-logo-slider::before,
  .acat-logo-slider::after {
    content: "";
    height: 100%;
    position: absolute;
    width: 150px;
    z-index: 2;
    pointer-events: none;
  }
  .acat-logo-slider::before {
    left: 0;
    top: 0;
    background: linear-gradient(to right, rgba(255,255,255,1) 0%, rgba(255,255,255,0) 100%);
  }
  .acat-logo-slider::after {
    right: 0;
    top: 0;
    background: linear-gradient(to left, rgba(255,255,255,1) 0%, rgba(255,255,255,0) 100%);
  }
}

/* El riel ahora calcula su ancho dinámicamente multiplicando el total por 2 */
.acat-logo-track {
  display: flex;
  gap: 20px;
  /* El ancho total es la suma de los dos bloques de logos */
  width: calc((var(--card-width) + 20px) * var(--total-marcas) * 2);
  animation: scrollLogosInfinite 25s linear infinite;
}

/* Pausa la animación al pasar el cursor (solo en computadoras con mouse) */
@media (hover: hover) {
  .acat-logo-slider:hover .acat-logo-track {
    animation-play-state: paused;
  }
}

/* Definición de las tarjetas de los logos (Responsivas) */
.acat-logo-card {
  --card-width: 220px; /* Ancho por defecto para PC */
  width: var(--card-width);
  height: 80px;
  background: #ffffff;
  border-radius: 6px;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.06);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0; /* Evita que el contenedor colapse a las tarjetas */
  padding: 10px;
}

/* Ajuste de tamaño de tarjeta exclusivo para teléfonos móviles */
@media (max-width: 576px) {
  .acat-logo-card {
    --card-width: 150px; /* Tarjetas más compactas para que quepan bien en pantallas chicas */
    height: 65px;
    padding: 8px;
  }
  .acat-logo-track {
    gap: 15px; /* Reducimos el espacio entre logos en celulares */
    width: calc((var(--card-width) + 15px) * var(--total-marcas) * 2);
  }
}

/* Asegura que los logos no se deformen ni pierdan calidad */
.acat-logo-card img {
  max-width: 85%;
  max-height: 80%;
  object-fit: contain;
  width: auto;
  height: auto;
}

/* ANIMACIÓN RESPONSIVA DEFINITIVA: Se desplaza exactamente el 50% de su ancho total */
@keyframes scrollLogosInfinite {
  0% {
    transform: translateX(0);
  }
  100% {
    /* Mueve exactamente la mitad del riel (el bloque original completo) */
    transform: translateX(-50%); 
  }
}

