/**
 * Partners Gallery Block - Frontend Styles
 * 
 * @package Ably_Blocks
 */

/* ----- Partners Gallery ----- */
.ap-parceiros__title {
    font-family: var(--semantics-typography-family-poppins, 'Poppins', sans-serif);
    font-weight: 700;
    font-size: var(--semantics-typography-heading-x-large, 36px);
    line-height: var(--semantics-typography-baseline-tight, 1.1);
    letter-spacing: var(--semantics-typography-tracking-tight-2, -0.02em);
    color: var(--semantics-colors-text-heading-default, #1E293B);
    text-align: center;
    margin: 0 0 var(--semantics-spacing-wide, 40px);
    max-width: 700px;
    margin-left: auto;
    margin-right: auto;
}

/* ----- Tier ----- */
.ap-tier {
    display: flex;
    flex-direction: column;
    gap: var(--semantics-spacing-large, 32px);
    margin-bottom: var(--semantics-spacing-wide, 40px);
}

.ap-tier:last-child {
    margin-bottom: 0;
}

.ap-tier__heading {
    font-family: var(--semantics-typography-family-inter, 'Inter', sans-serif);
    font-weight: 700;
    font-size: var(--semantics-typography-body-18, 18px);
    line-height: var(--semantics-typography-baseline-normal, 1.5);
    color: var(--semantics-colors-text-accent-purpura, #6D28D9);
    margin: 0;
}

.ap-tier__grid {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: var(--semantics-spacing-bigger, 80px);
}

.ap-tier__grid--4col {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.ap-tier__grid--5col {
    grid-template-columns: repeat(5, minmax(0, 1fr));
}

.ap-tier__grid--7col {
    grid-template-columns: repeat(7, minmax(0, 1fr));
}

.ap-tier__grid--8col {
    grid-template-columns: repeat(8, minmax(0, 1fr));
}

.ap-tier__grid--single {
    display: flex;
    gap: 0;
}

/* ----- Tier Header (with optional tag) ----- */
.ap-tier__header {
    display: flex;
    flex-direction: column;
    gap: var(--semantics-spacing-small, 12px);
}

.ap-tier__header--centered {
    align-items: center;
    text-align: center;
}

.ap-tier__header--row {
    flex-direction: row;
    align-items: center;
    gap: var(--semantics-spacing-small, 12px);
}

/* ----- Logo ----- */
.ap-logo {
    height: 130px;
    background-color: var(--semantics-colors-fill-neutral, #FFFFFF);
    border: var(--semantics-stroke-thin, 1px) solid var(--semantics-colors-stroke-primary, #E2E8F0);
    border-radius: var(--semantics-radius-large, 16px);
    padding: var(--semantics-spacing-medium, 24px);
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    font-family: var(--semantics-typography-family-inter, 'Inter', sans-serif);
    font-weight: 600;
    font-size: var(--semantics-typography-body-14, 14px);
    line-height: var(--semantics-typography-baseline-normal, 1.5);
    color: var(--semantics-colors-text-secondary, #64748B);
}

.ap-logo img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}

.ap-tier__grid--single .ap-logo {
    width: 428px;
    max-width: 100%;
}

/* ----- Responsive Adjustments ----- */
@media (max-width: 1024px) {
    .ap-tier__grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
        gap: var(--semantics-spacing-wide, 40px);
    }

    .ap-tier__grid--5col,
    .ap-tier__grid--7col,
    .ap-tier__grid--8col {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

@media (max-width: 768px) {
    .ap-tier__grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: var(--semantics-spacing-large, 32px);
    }

    .ap-tier__grid--4col,
    .ap-tier__grid--5col,
    .ap-tier__grid--7col,
    .ap-tier__grid--8col {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .ap-parceiros__title {
        font-size: var(--semantics-typography-heading-small, 24px);
    }
}

@media (max-width: 480px) {
    .ap-tier__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: var(--semantics-spacing-medium, 24px);
    }

    .ap-tier__grid--4col,
    .ap-tier__grid--5col,
    .ap-tier__grid--7col,
    .ap-tier__grid--8col {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .ap-logo {
        height: 100px;
    }
}
