/* Container que esconde o que está fora da área visível */
.logo-carousel-container {
    overflow: hidden;
    position: relative;
    width: 100%;
    /* Efeito de degradê nas laterais para um visual mais suave */
    -webkit-mask-image: linear-gradient(to right, rgba(0,0,0,0), rgba(0,0,0,1) 10%, rgba(0,0,0,1) 90%, rgba(0,0,0,0));
    mask-image: linear-gradient(to right, rgba(0,0,0,0), rgba(0,0,0,1) 10%, rgba(0,0,0,1) 90%, rgba(0,0,0,0));
}

/* A "pista" que contém todos os logos (originais + duplicados) */
.logo-carousel-track {
    display: flex;
    /* Ajuste o 'width' baseado no número de logos. (Nº de logos * largura de cada logo) */
    /* Como temos 28 logos, e cada um terá uns 150px, 28 * 2 * 150px = 8400px */
    width: calc(150px * 56); /* (largura do item * número total de itens) */
    animation: scroll 60s linear infinite;
}

/* Pausa a animação quando o mouse está sobre o carrossel */
.logo-carousel-container:hover .logo-carousel-track {
    animation-play-state: paused;
}

/* Cada item (logo) individual */
.logo-item {
    width: 150px; /* Largura fixa para cada logo */
    padding: 0 20px; /* Espaçamento entre os logos */
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.logo-item img {
    max-width: 100%;
    height: auto;
    /*filter: grayscale(100%);*/ /* Deixa os logos em escala de cinza */
    /*opacity: 0.6;*/
    transition: all 0.3s ease;
}

.logo-item:hover img {
    filter: grayscale(0%); /* Deixa o logo colorido ao passar o mouse */
    opacity: 1;
    transform: scale(1.1);
}

/* A animação que move a pista */
@keyframes scroll {
    from {
        transform: translateX(0);
    }
    to {
        /* Move a pista para a esquerda pela metade da sua largura total */
        transform: translateX(-50%);
    }
}