/* Logo Grid Flexbox Styles */

.elg-logo-grid-flexbox {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--gap-desktop, 20px);
    width: 100%;
    max-width: 100%;
    overflow: visible;
}

.elg-logo-item-flexbox {
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 100px;
    position: relative;
    transition: all 0.3s ease;
    /* Use the capped flex-basis with max-width constraint */
    flex: 0 0 var(--flex-basis, 33.33%);
    max-width: var(--max-flex-basis, 100%);
    min-width: 150px;
}

.elg-logo-item-flexbox img {
    aspect-ratio: unset !important;
    width: 100% !important;
    height: auto !important;
    object-fit: contain;
    max-width: 100%;
    max-height: var(--max-height-desktop, 100px);
    display: block;
}

.elg-logo-item-flexbox img:hover {
    opacity: 0.8;
}

.elg-logo-item-flexbox a {
    display: block;
    text-decoration: none;
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}

/* Responsive behavior using CSS custom properties */
@media (max-width: 1024px) {
    .elg-logo-grid-flexbox {
        gap: var(--gap-tablet, 15px);
    }
    
    .elg-logo-item-flexbox {
        flex: 0 0 var(--flex-basis, 50%);
        min-width: 120px;
        min-height: 80px;
    }
    
    .elg-logo-item-flexbox img {
        max-height: var(--max-height-tablet, 80px);
    }
}

@media (max-width: 768px) {
    .elg-logo-grid-flexbox {
        gap: var(--gap-mobile, 10px);
    }
    
    .elg-logo-item-flexbox {
        /* Mobile: always 100% width, no complex calculations */
        flex: 0 0 95%;
        max-width: 95%;
        min-width: 100px;
        min-height: 60px;
    }
    
    .elg-logo-item-flexbox img {
        max-height: var(--max-height-mobile, 60px);
        max-width: calc(100vw - 10px);
    }
}

@media (max-width: 480px) {
    .elg-logo-item-flexbox {
        min-width: 80px;
        min-height: 50px;
    }
}

/* Ensure proper spacing with gap property */
.elg-logo-grid-flexbox > * {
    margin: 0 !important;
}

/* Override any Elementor max-width rules for flexbox items */
.elementor-widget-elg-logo-grid .elg-logo-item-flexbox img,
.elg-logo-item-flexbox img {
    aspect-ratio: unset !important;
    width: 100% !important;
    height: auto !important;
    max-width: 100% !important;
    min-width: unset !important;
    min-height: unset !important;
    object-fit: contain !important;
    display: block !important;
}

/* Force override any inline styles */
.elg-logo-item-flexbox img[style*="aspect-ratio"] {
    aspect-ratio: unset !important;
    width: 100% !important;
    height: auto !important;
}

/* Fallback for browsers that don't support gap */
@supports not (gap: 20px) {
    .elg-logo-grid-flexbox {
        margin: -10px;
    }
    
    .elg-logo-item-flexbox {
        margin: 10px;
    }
} 