/* CD GALLERY + RELATED */
.cd-gallery { background: #2c2a26; padding: var(--cd-space-2xl) var(--cd-gutter); }
.cd-gallery__inner, .cd-related-pins__inner { width: min(100%, var(--cd-container)); margin-inline: auto; }
.cd-gallery__header, .cd-related-pins__header { margin-bottom: var(--cd-space-lg); text-align: center; }
.cd-gallery__label { margin-bottom: var(--cd-space-sm); color: var(--cd-accent); font-size: 0.68rem; font-weight: 700; letter-spacing: 0.2em; text-transform: uppercase; }
.cd-gallery__title, .cd-related-pins__title { margin-bottom: var(--cd-space-xs); font-size: clamp(1.5rem, 2.5vw, 2rem); font-weight: 300; }
.cd-gallery__title { color: var(--cd-white); }
.cd-gallery__subtitle, .cd-related-pins__subtitle { color: var(--cd-text-muted); font-size: 0.9rem; font-weight: 300; }
.cd-gallery__subtitle { color: rgb(255 255 255 / 0.58); }
.cd-gallery__showcase { position: relative; display: grid; place-items: center; height: min(58vw, 580px); min-height: 320px; overflow: hidden; border-radius: var(--cd-radius-lg); background: #3a3830; }
.cd-gallery__showcase-image { width: 100%; height: 100%; object-fit: contain; object-position: center; }
.cd-gallery__caption { position: absolute; inset-inline: 0; bottom: 0; display: flex; align-items: flex-end; justify-content: space-between; gap: var(--cd-space-sm); padding: var(--cd-space-md); background: linear-gradient(to top, rgb(26 25 22 / 0.82), transparent); }
.cd-gallery__caption-title { color: var(--cd-white); font-family: var(--cd-font-serif); font-size: 1.1rem; font-weight: 300; }
.cd-gallery__caption-subtitle { margin-top: 0.25rem; color: rgb(255 255 255 / 0.58); font-size: 0.75rem; }
.cd-gallery__caption-tag { padding: 0.4rem 0.875rem; border-radius: var(--cd-radius-pill); background: var(--cd-accent); color: var(--cd-white); font-size: 0.7rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; }
.cd-gallery__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--cd-space-md); margin-top: var(--cd-space-lg); }
.cd-gallery__grid--four { grid-template-columns: repeat(4, 1fr); }
.cd-gallery-card, .cd-related-pin { position: relative; overflow: hidden; border-radius: var(--cd-radius-lg); background: #3a3830; cursor: pointer; }
.cd-gallery-card { aspect-ratio: 3 / 4; }
.cd-related-pin { aspect-ratio: 2 / 3; }
.cd-gallery-card__image, .cd-related-pin__image { width: 100%; height: 100%; object-fit: cover; transition: transform 500ms var(--cd-ease); }
.cd-gallery-card:hover .cd-gallery-card__image, .cd-gallery-card:focus-within .cd-gallery-card__image, .cd-related-pin:hover .cd-related-pin__image, .cd-related-pin:focus-within .cd-related-pin__image { transform: scale(1.04); }
.cd-gallery-card__overlay, .cd-related-pin__overlay { position: absolute; inset: 0; display: flex; align-items: flex-end; padding: var(--cd-space-md); background: linear-gradient(to top, rgb(26 25 22 / 0.70), transparent 60%); }
.cd-gallery-card__overlay { opacity: 0; transition: opacity var(--cd-transition); }
.cd-gallery-card:hover .cd-gallery-card__overlay, .cd-gallery-card:focus-within .cd-gallery-card__overlay { opacity: 1; }
.cd-gallery-card__label, .cd-related-pin__label { color: var(--cd-white); font-family: var(--cd-font-serif); font-size: 0.95rem; line-height: 1.3; }
.cd-related-pins { padding: var(--cd-space-2xl) var(--cd-gutter); background: var(--cd-surface); border-block: 1px solid var(--cd-border); }
.cd-related-pins__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--cd-space-md); }
@media (max-width: 900px) { .cd-gallery__grid, .cd-gallery__grid--four, .cd-related-pins__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .cd-gallery__caption { flex-direction: column; align-items: flex-start; } .cd-gallery__grid { grid-template-columns: 1fr; } .cd-gallery__grid--four { grid-template-columns: repeat(2, 1fr); } .cd-gallery-card { aspect-ratio: 4 / 3; } .cd-related-pins__grid { grid-template-columns: 1fr; } }
