.m-photo-trio__head { max-width: 60ch; margin: 0 auto var(--space-7); }
.m-photo-trio__grid {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-4);
}
.m-photo-trio__grid figure {
    margin: 0;
    aspect-ratio: 4 / 5;
    border-radius: var(--radius-md);
    overflow: hidden;
    position: relative;
    background: var(--color-bg-alt);
}
.m-photo-trio__grid img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--transition-base); }
.m-photo-trio__grid figure:hover img { transform: scale(1.04); }
.m-photo-trio__grid figcaption {
    position: absolute;
    inset: auto 0 0 0;
    padding: var(--space-3) var(--space-4);
    background: linear-gradient(0deg, rgba(0,0,0,0.6), rgba(0,0,0,0));
    color: var(--color-text-inverse);
    font-size: var(--fs-sm);
}
@media (max-width: 720px) {
    .m-photo-trio__grid { grid-template-columns: 1fr; }
    .m-photo-trio__grid figure { aspect-ratio: 4 / 3; }
}
