/* Generic JSON-builder sections used by website_structure.json. */

.ipp-builder-section {
    background: var(--color-white);
}

.ipp-builder-media-copy {
    max-width: 760px;
    margin-bottom: 32px;
}

.ipp-builder-media-copy h2 {
    margin-bottom: 14px;
    color: var(--color-electric-blue);
    text-transform: uppercase;
}

.ipp-builder-media-copy h3 {
    margin-bottom: 14px;
}

.ipp-builder-media-copy p {
    margin-bottom: 0;
}

.ipp-video-frame {
    width: 100%;
    overflow: hidden;
    border-radius: 18px;
    background: var(--color-midnight-steel);
}

.ipp-video-frame video,
.ipp-video-frame iframe {
    display: block;
    width: 100%;
    aspect-ratio: 16 / 9;
    border: 0;
}

.ipp-slideshow-track,
.ipp-media-gallery-grid {
    display: grid;
    gap: 22px;
}

.ipp-slideshow-track {
    grid-auto-flow: column;
    grid-auto-columns: minmax(260px, 1fr);
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    padding-bottom: 8px;
}

.ipp-slide-card {
    min-width: 0;
    border-radius: 18px;
    overflow: hidden;
    background: rgba(219, 224, 229, 0.5);
    scroll-snap-align: start;
}

.ipp-slide-card img,
.ipp-media-gallery-card img {
    display: block;
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
}

.ipp-slide-card figcaption,
.ipp-media-gallery-card figcaption {
    padding: 16px 18px;
    color: var(--color-midnight-steel);
    font-size: 15px;
    line-height: 1.35;
}

.ipp-media-gallery-grid {
    grid-template-columns: repeat(3, 1fr);
}

.ipp-media-gallery-card {
    margin: 0;
    overflow: hidden;
    border-radius: 18px;
    background: rgba(219, 224, 229, 0.5);
}

@media screen and (max-width: 900px) {
    .ipp-media-gallery-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media screen and (max-width: 600px) {
    .ipp-slideshow-track {
        grid-auto-columns: minmax(230px, 88%);
    }

    .ipp-media-gallery-grid {
        grid-template-columns: 1fr;
    }
}
