/* ===== LOGO STRIP / MARQUEE ===== */

#logos {
    position: relative;
    width: 100%;
}

/* Contenedor visible: ventana de la banda */
.logos-marquee {
    position: relative;
    width: 100%;
    overflow: hidden;         /* Oculta lo que se sale a los lados */
}

/* Tira de logos que se mueve de manera infinita */
.logos-track {
    display: flex;
    align-items: center;
    gap: 2.5rem;              /* Espaciado entre logos */
    animation: logos-scroll 15s linear infinite;
}

/* Al pausar (hover/touch/pointer) */
.logos-track.paused {
    animation-play-state: paused;
}

/* Logos: mismos estilos que ya usabas, ajustados a la nueva estructura */
#logos .logo-item {
    max-height: 80px;         /* Altura máxima (ajustable) */
    width: auto;              /* Mantiene proporción natural */
    object-fit: contain;
    padding: 0 5px;           /* Espaciado lateral uniforme */
    transition: transform 0.3s ease, filter 0.3s ease;
    filter: brightness(1);
}

#logos .logo-wide {
    max-height: 90px;
    width: auto;
    object-fit: contain;
    padding: 0 5px;
    transition: transform 0.3s ease, filter 0.3s ease;
    filter: brightness(1);
}

#logos .logo-item:hover,
#logos .logo-wide:hover {
    transform: scale(1.05);
    filter: brightness(1.1);
}

/* Animación infinita: la tira se desplaza hacia la izquierda */
@keyframes logos-scroll {
    0% {
        transform: translateX(0);
    }
    100% {
        /* Se mueve la mitad de su ancho porque duplicamos el contenido en JS */
        transform: translateX(-50%);
    }
}

/* Adaptación responsive */
@media (max-width: 1024px) {
    #logos .logo-item {
        max-height: 70px;
    }
}

@media (max-width: 768px) {
    #logos .logo-item {
        max-height: 60px;
    }
}

@media (max-width: 480px) {
    #logos .logo-item {
        max-height: 50px;
    }
}

#logos .container {
    margin-left: auto;
    margin-right: auto;
}
