.photo.photo--tpl-overlay-exif {
    container-type: inline-size;
}

.photo.photo--tpl-overlay-exif .photo__media {
    position: relative;
    overflow: hidden;
    border-radius: 10px;
}

.photo.photo--tpl-overlay-exif .photo__overlay {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 2;
    background: rgba(0, 0, 0, 0.5);
    color: #fff;
    padding: 0.7rem 0.85rem 0.8rem;
}

.photo.photo--tpl-overlay-exif .photo__overlay-title {
    font-weight: 700;
    font-size: 0.98rem;
    line-height: 1.22;
    margin-bottom: 0.24rem;
}

.photo.photo--tpl-overlay-exif .photo__overlay-description {
    font-size: 0.9rem;
    line-height: 1.4;
    margin-bottom: 0.4rem;
    opacity: 0.95;
}

.photo.photo--tpl-overlay-exif .photo__overlay-exif {
    display: flex;
    flex-wrap: wrap;
    gap: 0.3rem 0.72rem;
    font-size: 0.79rem;
    line-height: 1.22;
}

.photo.photo--tpl-overlay-exif .photo__overlay-exif-icon-wrap {
    display: inline-flex;
    align-items: center;
    opacity: 0.92;
}

.photo.photo--tpl-overlay-exif .photo__overlay-exif-icon {
    margin-right: 0 !important;
    opacity: 0.92;
}

.photo.photo--tpl-overlay-exif .photo__caption {
    margin-top: 0.6rem;
}

@container (max-width: 1024px) {
    .photo.photo--tpl-overlay-exif .photo__overlay {
        padding: 0.56rem 0.68rem 0.6rem;
    }

    .photo.photo--tpl-overlay-exif .photo__overlay-title {
        font-size: 0.92rem;
    }

    .photo.photo--tpl-overlay-exif .photo__overlay-description {
        font-size: 0.86rem;
        margin-bottom: 0.34rem;
    }

    .photo.photo--tpl-overlay-exif .photo__overlay-exif {
        font-size: 0.74rem;
        gap: 0.22rem 0.56rem;
    }
}

@container (max-width: 640px) {
    .photo.photo--tpl-overlay-exif .photo__overlay {
        padding: 0.46rem 0.56rem 0.5rem;
    }

    .photo.photo--tpl-overlay-exif .photo__overlay-title {
        font-size: 0.87rem;
        margin-bottom: 0.18rem;
    }

    .photo.photo--tpl-overlay-exif .photo__overlay-description {
        font-size: 0.82rem;
        line-height: 1.34;
        margin-bottom: 0.26rem;
    }

    .photo.photo--tpl-overlay-exif .photo__overlay-exif {
        font-size: 0.71rem;
        gap: 0.18rem 0.45rem;
    }
}

/* Overlay EXIF grouped rows */
.photo.photo--tpl-overlay-exif .photo__overlay-exif-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.2rem 0.65rem;
}

.photo.photo--tpl-overlay-exif .photo__overlay-exif-item {
    display: inline-flex;
    align-items: center;
    gap: 0.24rem;
    white-space: nowrap;
}


@container (max-width: 640px) {
    .photo.photo--tpl-overlay-exif .photo__overlay {
        max-height: 25%;
        overflow: auto;
    }

    .photo.photo--tpl-overlay-exif .photo__overlay-description {
        display: -webkit-box;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 3;
        line-clamp: 3;
        overflow: hidden;
    }
}
