/* ===================================
   Partners Section
   =================================== */

.partners-section {
    position: relative;
    padding: var(--space-4xl) 0;
    /* Removed horizontal padding to allow full width marquee */
    overflow: hidden;
    border-top: 1px solid var(--color-border);
}

.partners-marquee {
    position: relative;
    width: 100%;
    overflow: hidden;
    padding: var(--space-md) 0;
    /* Fade out edges */
    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);
}

.partners-track {
    display: flex;
    width: max-content;
    animation: scroll 80s linear infinite;
    gap: var(--space-xl);
    /* Initial offset */
}

/* Pause animation on hover for better UX */
.partners-track:hover {
    animation-play-state: paused;
}

@keyframes scroll {
    0% {
        transform: translateX(0);
    }

    100% {
        transform: translateX(calc(-50% - var(--space-xl)/2));
        /* Account for gap */
    }
}

.partner-logo {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-md);
    background: transparent;
    border: none;
    transition: all var(--transition-base);
    cursor: pointer;
    user-select: none;
    min-width: 250px;
    /* Reduced by 30% from 360px */
    height: 140px;
    /* Reduced by 30% from 200px */
}

.partner-logo:hover {
    background: transparent;
    border-color: transparent;
    box-shadow: none;
    transform: translateY(-2px);
}

.partner-img {
    height: 90px;
    /* Reduced by 30% from 130px */
    width: auto;
    object-fit: contain;
    filter: grayscale(100%) brightness(1.5);
    opacity: 0.7;
    transition: all 0.3s ease;
}

.partner-logo:hover .partner-img {
    filter: grayscale(0%) brightness(1);
    opacity: 1;
    transform: scale(1.1);
}

/* Responsive */
@media (max-width: 1280px) {
    .partners-track {
        gap: 12px;
    }

    .partner-logo {
        min-width: 160px;
        padding: 0;
        height: 100px;
    }

    .partner-img {
        height: 70px;
    }
}

@media (max-width: 768px) {
    .partners-section {
        padding: var(--space-2xl) 0;
    }

    .partners-track {
        animation-duration: 25s;
        gap: var(--space-xs);
        /* Halved again */
    }

    .partner-logo {
        min-width: 100px;
        /* Reduced from 160px to bring icons closer */
        height: 80px;
        padding: 0;
        /* Remove padding to minimize spacing */
    }

    .partner-img {
        height: 60px;
    }
}