.mnc-logo-grid {
    /* Auto Grid: responsive without breakpoints */
    --min: 14rem; /* minimum card width (override per instance: e.g., #myGrid { --min: 280px; }) */
    --gap: 1rem;  /* gap between items */
    --padding-logo:1rem;
    --logo-border-color: #e1e0e0;
    --logo-height:200px;
    --subtitle-size:0.8rem;
    --subtitle-color: #808080;

    display:grid;
    grid-template-columns: repeat(auto-fit, minmax(var(--min), 1fr));
    gap: var(--gap);

    padding: 0;
    margin: 0;
    list-style: none;
    align-items: center; /* vertically center logo images if heights differ */
}

.mnc-logo-grid > .logo-card {
    margin: 0;
    padding: var(--padding-logo);
    height:var(--logo-height);
    border:1px solid var(--logo-border-color);
    gap:var(--padding-logo);
    display:flex;
    flex-direction: column;
    justify-content:space-between;
}

.logo-card__imgwrap {
    height:100%;
    width:100%;
    flex-grow:1;
    display:flex;
    flex-direction: column;
    place-content: center;
    overflow:hidden;
    img {
        height:100%;
        width:auto;
        object-fit: contain;
    }
}

.logo-card__subtitle {
    width:100%;
    text-align: center;
    font-family:"Open Sans", sans-serif;
    font-size:var(--subtitle-size);
    font-weight:200;
    line-height:1.2;
    color:var(--subtitle-color);
}

/* --- Layout rules appended for explicit logo counts --- */

/* Fix nested selector so logo images scale correctly in plain CSS */
.logo-card__imgwrap img {
    height: 100%;
    width: auto;
    object-fit: contain;
}

/* Explicit layouts by count */
.mnc-logo-grid[data-count="3"] {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
}

.mnc-logo-grid[data-count="4"] {
    display: grid;
    grid-template-columns: repeat(2, 1fr); /* 2 x 2 */
}

.mnc-logo-grid[data-count="6"] {
    display: grid;
    grid-template-columns: repeat(3, 1fr); /* 3 x 2 */
}

.mnc-logo-grid[data-count="8"] {
    display: grid;
    grid-template-columns: repeat(4, 1fr); /* 3 x 2 */
}

/* 5 logos: 3 on top, 2 centered below using a 6-column grid.
   Row 1: each card spans 2 columns (1-2, 3-4, 5-6) → perfectly centered.
   Row 2: leave col 1 and 6 empty; place cards at 2-3 and 4-5. */
.mnc-logo-grid[data-count="5"] {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
}
/* Top row (3 logos, each spans 2 columns) */
.mnc-logo-grid[data-count="5"] > .logo-card:nth-child(1) { grid-column: 1 / span 2; }
.mnc-logo-grid[data-count="5"] > .logo-card:nth-child(2) { grid-column: 3 / span 2; }
.mnc-logo-grid[data-count="5"] > .logo-card:nth-child(3) { grid-column: 5 / span 2; }
/* Bottom row (2 logos centered with empty outer columns) */
.mnc-logo-grid[data-count="5"] > .logo-card:nth-child(4) { grid-column: 2 / span 2; }
.mnc-logo-grid[data-count="5"] > .logo-card:nth-child(5) { grid-column: 4 / span 2; }

.mnc-logo-grid[data-count="7"] {
    display: grid;
    grid-template-columns: repeat(8, 1fr);
}
/* Top row (4 logos, each spans 2 columns) */
.mnc-logo-grid[data-count="7"] > .logo-card:nth-child(1) { grid-column: 1 / span 2; }
.mnc-logo-grid[data-count="7"] > .logo-card:nth-child(2) { grid-column: 3 / span 2; }
.mnc-logo-grid[data-count="7"] > .logo-card:nth-child(3) { grid-column: 5 / span 2; }
.mnc-logo-grid[data-count="7"] > .logo-card:nth-child(4) { grid-column: 7 / span 2; }
/* Bottom row (3 logos centered with empty outer columns) */
.mnc-logo-grid[data-count="7"] > .logo-card:nth-child(5) { grid-column: 2 / span 2; }
.mnc-logo-grid[data-count="7"] > .logo-card:nth-child(6) { grid-column: 4 / span 2; }
.mnc-logo-grid[data-count="7"] > .logo-card:nth-child(7) { grid-column: 6 / span 2; }

.mnc-logo-grid[data-count="10"] {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    .logo-card {
        /*grid-column: span 2;*/
    }
    /*.logo-card:nth-child(9) {*/
    /*    grid-column: 2;*/
    /*}*/
}


/* Container for logo grid: enables container queries */
.mnc-logo-grid-container {
    container-type: inline-size;
    container-name: mnc-logos;
}

/* Force two columns whenever the container is <= 810px */
@container mnc-logos (max-width: 810px) {
    .mnc-logo-grid {
        display: grid; /* ensure grid context is kept */
        grid-template-columns: repeat(2, 1fr) !important; /* override any explicit templates */
    }
    /* Reset explicit placements so items flow in two columns */
    .mnc-logo-grid[data-count="5"] > .logo-card:nth-child(n),
    .mnc-logo-grid[data-count="7"] > .logo-card:nth-child(n) {
        grid-column: auto !important;
    }
}

/* Fallback for browsers without container queries */
@supports not (container-type: inline-size) {
    @media (max-width: 810px) {
        .mnc-logo-grid {
            display: grid;
            grid-template-columns: repeat(2, 1fr) !important;
        }
        .mnc-logo-grid[data-count="5"] > .logo-card:nth-child(n),
        .mnc-logo-grid[data-count="7"] > .logo-card:nth-child(n) {
            grid-column: auto !important;
        }
    }
}


/* When container is <= 350px: force single column (stacked) */
@container mnc-logos (max-width: 350px) {
    .mnc-logo-grid {
        display: grid; /* keep grid to preserve gaps */
        grid-template-columns: 1fr !important; /* single column */
    }
    /* Reset explicit placements so items stack naturally */
    .mnc-logo-grid[data-count="5"] > .logo-card:nth-child(n),
    .mnc-logo-grid[data-count="7"] > .logo-card:nth-child(n) {
        grid-column: auto !important;
    }
}

/* Fallback for browsers without container queries: <= 350px → single column */
@supports not (container-type: inline-size) {
    @media (max-width: 350px) {
        .mnc-logo-grid {
            display: grid;
            grid-template-columns: 1fr !important;
        }
        .mnc-logo-grid[data-count="5"] > .logo-card:nth-child(n),
        .mnc-logo-grid[data-count="7"] > .logo-card:nth-child(n) {
            grid-column: auto !important;
        }
    }
}