/* Services Institutions Section Styles */
.services-institutions-section {
    margin: 0 auto;
    padding: 0 120px;
}

.services-institutions-container {
    max-width: 1200px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 48px;
}

.institutions-header {
    display: flex;
    gap: 32px;
    align-items: flex-start;
    width: 100%;
}

.institutions-text {
    flex: 1 1 0;
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.institutions-title {
    font-family: 'IvyOra Display', serif;
    font-weight: 700;
    font-style: normal;
    font-size: 32px;
    color: #005b68;
    margin: 0;
}

.institutions-title em,
.institutions-title-italic,
.institutions-title-rest {
    font-weight: 500;
    font-style: italic;
}

.institutions-description {
    font-family: 'IBM Plex Sans', sans-serif;
    color: #403936;
    font-size: 16px;
    line-height: normal;
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.institutions-description p {
    margin: 0 0 0;
}

.institutions-cta {
    font-family: 'IBM Plex Sans', sans-serif;
    font-weight: 700;
    font-style: italic;
    color: #403936;
}

/* CTA button - now uses centralized component (teal-primary), keep only layout */
.institutions-cta-button {
    width: auto;
    align-self: flex-start !important;
}

.institutions-cta-button--mobile {
    display: none;
}

/* Hide mobile note on desktop */
.institutions-mobile-note {
    display: none;
}

/* Mobile CTA wrapper - hide on desktop */
.institutions-cta-mobile-wrap {
    display: none;
}

/* Content Wrapper */
.institutions-content-wrapper {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.institutions-image {
    flex: 0 0 356px;
    height: 297px;
    border-radius: 20px;
    overflow: hidden;
}

.institutions-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* Default visibility for responsive image variants
   Use modifier classes on the parent `.institutions-image` so the
   parent can be hidden on mobile without leaving reserved height. */
.institutions-image.institutions-image--mobile {
    display: none;
}

.institutions-image.institutions-image--desktop {
    display: block;
}

.institutions-cards {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.institutions-row {
    display: flex;
    gap: 24px;
}

.inst-card {
    flex: 1 1 0;
    background: #ffffff;
    border: 0.8px solid #d4d2e3;
    padding: 16px;
    border-radius: 12px;
}

.inst-card-title {
    font-family: 'IBM Plex Sans', sans-serif;
    font-weight: 700;
    color: #ed6a59;
    font-size: 20px;
    margin: 0 0 24px;
    text-align: center;
}

.inst-columns {
    display: flex;
    gap: 16px;
}

.inst-list {
    list-style: disc;
    padding-left: 24px;
    margin: 0;
    color: #403936;
    font-family: 'IBM Plex Sans', sans-serif;
    flex: 1;
}

.inst-list li {
    margin: 0 0 12px 0;
}

.inst-list li:last-child {
    margin-bottom: 0;
}

/* Breakpoints */
@media (max-width: 1200px) {
    .services-institutions-section {
        padding: 0 60px;
    }

    .services-institutions-container {
        max-width: 1000px;
        gap: 40px;
    }

    .institutions-image img {
        object-position: top;
    }

    .institutions-header {
        flex-direction: column;
        align-items: center;
    }

    .institutions-image {
        width: 100%;
        max-width: 720px;
        height: auto;
    }

    .institutions-text {
        align-items: center;
        text-align: center;
    }

    .institutions-cards .institutions-row {
        flex-direction: column;
    }

    .institutions-cta-button {
        align-self: center;
    }
}

@media (max-width: 767px) {
    .services-institutions-section {
        padding: 0 24px;
    }

    .institutions-title {
        font-size: 24px;
        text-align: left;
    }

    /* Mobile Note */
    .institutions-mobile-note {
        display: flex;
        align-items: center;
        gap: 16px;
    }

    .institutions-mobile-note__text {
        font-family: 'IBM Plex Sans', sans-serif;
        font-size: 16px;
        font-weight: 400;
        font-style: italic;
        color: #005b68;
    }

    .institutions-mobile-note__icon {
        width: 20px;
        height: 20px;
        flex-shrink: 0;
        transition: transform 0.25s ease;
    }

    /* Collapsed state: hide institution lists */
    .services-institutions-section.details-hidden .inst-list {
        display: none;
    }

    /* When expanded ensure icon rotates */
    .services-institutions-section:not(.details-hidden) .institutions-mobile-note__icon {
        transform: rotate(180deg);
    }

    .inst-card-title {
        font-size: 18px;
    }

    .institutions-description {
        text-align: left;
    }

    .inst-list li {
        margin-left: 16px;
    }

    .inst-list {
        padding-left: 16px;
    }

    .inst-columns {
        flex-direction: column;
        gap: 12px;
    }

    /* Mobile: hide inline CTA and show mobile CTA at end of section */
    .institutions-cta-button:not(.institutions-cta-button--mobile) {
        display: none !important;
    }

    .institutions-cta-mobile-wrap {
        display: flex;
        justify-content: center;
        align-items: center;
    }

    .institutions-cta-button--mobile {
        display: block;
        align-self: center;
        width: auto;
        align-items: center;
        text-align: center;
        font-size: 16px;
        padding: 14px 20px;
    }

    /* Mobile: show mobile image variant, hide desktop image parent */
    .institutions-image.institutions-image--mobile {
        display: block;
        width: 100%;
        max-width: 720px;
        height: auto;
        border-radius: 12px;
        overflow: hidden;
        margin-bottom: 8px;
    }

    .institutions-image.institutions-image--desktop {
        display: none;
    }
}