/* Logo Carousel Styles */
.logo-carousel-section {
    overflow: hidden;
    padding: 3rem 0;
    position: relative;
    background: transparent;
}

.logo-carousel-wrapper {
    position: relative;
    overflow: hidden;
    mask-image: linear-gradient(
        to right,
        transparent,
        black 10%,
        black 90%,
        transparent
    );
    -webkit-mask-image: linear-gradient(
        to right,
        transparent,
        black 10%,
        black 90%,
        transparent
    );
}

.logo-carousel-track {
    display: flex;
    gap: 4rem;
    /* Animation is set by JavaScript after calculating exact widths */
    will-change: transform;
    transition: animation-play-state 0.3s ease;
}

.logo-carousel-track.paused {
    animation-play-state: paused;
}

.logo-carousel-item {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 80px;
    min-width: 120px; /* Ensure minimum width for consistency */
    transition: transform 0.3s ease;
}

.logo-carousel-item a {
    display: block;
    height: 100%;
    display: flex;
    align-items: center;
}

.logo-carousel-item img {
    max-height: 60px;
    max-width: 180px;
    min-width: 40px;  /* Ensure SVGs without intrinsic width still display */
    min-height: 30px; /* Ensure SVGs without intrinsic height still display */
    width: auto;
    height: auto;
    object-fit: contain;
    filter: grayscale(100%) opacity(0.6);
    transition: filter 0.4s ease, transform 0.3s ease;
}

.logo-carousel-item:hover img {
    filter: grayscale(0%) opacity(1);
    transform: scale(1.05);
}

/* Dark mode adjustments - increase brightness and invert for visibility */
@media (prefers-color-scheme: dark) {
    .logo-carousel-item img {
        filter: grayscale(100%) opacity(0.8) invert(1) brightness(1);
    }
    
    .logo-carousel-item:hover img {
        filter: grayscale(0%) opacity(1) invert(0) brightness(1);
    }
}

/* Also support dark mode via class (for theme toggles) */
[data-bs-theme="dark"] .logo-carousel-item img,
.dark-style .logo-carousel-item img {
    filter: grayscale(100%) opacity(0.8) invert(1) brightness(1);
}

[data-bs-theme="dark"] .logo-carousel-item:hover img,
.dark-style .logo-carousel-item:hover img {
    filter: grayscale(0%) opacity(1) invert(0) brightness(1);
}

/* Scroll animation is dynamically generated by JavaScript */
/* This ensures seamless looping regardless of number of logos */

/* Responsive adjustments */
@media (max-width: 768px) {
    .logo-carousel-track {
        gap: 2rem;
    }
    
    .logo-carousel-item img {
        max-height: 50px;
        max-width: 150px;
    }
}
