/* ==== Continuous Logo Ticker ==== */
.logo-ticker-section {
    background-color: #fff;
}

.logo-ticker {
    overflow: hidden;
    position: relative;
    mask-image: linear-gradient(90deg, transparent 0, #000 5%, #000 95%, transparent 100%);
    -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 5%, #000 95%, transparent 100%);
}

.logo-ticker__track {
    display: inline-flex;
    align-items: center;
    gap: 56px; /* space between logos */
    will-change: transform;
    animation: logo-ticker-marquee var(--ticker-speed, 35s) linear infinite;
}

.logo-ticker__item {
    height: 56px; /* logo height – tweak as needed */
    width: auto;
    object-fit: contain;
    filter: grayscale(100%);
    opacity: 0.85;
    transition: transform .25s ease, opacity .25s ease, filter .25s ease;
    /* Prevent images from shrinking oddly */
    flex: 0 0 auto;
}

    .logo-ticker__item:hover {
        filter: grayscale(0%);
        opacity: 1;
        transform: scale(1.05);
    }

/* Smooth, gapless loop: translate exactly one set width */
@keyframes logo-ticker-marquee {
    from {
        transform: translateX(0);
    }

    to {
        transform: translateX(-50%);
    }
    /* because we duplicated the set */
}

/* Respect users who prefer reduced motion */
@media (prefers-reduced-motion: reduce) {
    .logo-ticker__track {
        animation: none;
    }
}

/* Responsive tuning */
@media (max-width: 992px) {
    .logo-ticker__item {
        height: 48px;
    }

    .logo-ticker__track {
        gap: 40px;
    }
}

@media (max-width: 576px) {
    .logo-ticker__item {
        height: 40px;
    }

    .logo-ticker__track {
        gap: 28px;
    }
}
