/* ── MASONRY GALLERY ── */
.masonry {
  padding: 0 56px 80px;
  columns: 4;
  column-gap: 6px;
  flex-grow: 1;
}
.masonry-item {
  break-inside: avoid;
  margin-bottom: 6px;
  overflow: hidden;
  cursor: pointer;
  position: relative;
}
.masonry-item a {
  display: block;
  line-height: 0;
  text-decoration: none;
  overflow: hidden;
}
.masonry-item img {
  width: 100%;
  height: auto;
  object-fit: cover;
  transition: transform 0.5s ease;
}
.masonry-item:hover img {
  transform: scale(1.04);
}

/* ── GLIGHTBOX CUSTOM ── */
.glightbox-clean .gslide-description {
  background: var(--cream-off) !important;
}
.glightbox-clean .gdesc-inner {
  background: var(--cream-off) !important;
  padding: 24px 32px;
}
.glightbox-clean .description-right .gdesc-inner,
.glightbox-clean .description-left .gdesc-inner {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
/* Only reserve room for the sidebar on slides that actually have a description.
   Metadata-less slides (no .desc-right/.desc-left) show the image full-size. */
.glightbox-clean .ginner-container.desc-right .gslide-media,
.glightbox-clean .ginner-container.desc-left .gslide-media {
  max-width: 70%;
}
.glightbox-clean .gslide-title {
  font-family: "Libre Baskerville", serif;
  font-size: 20px;
  font-weight: 400;
  color: var(--brown);
  margin-bottom: 12px;
  line-height: 1.4;
}
.glightbox-clean .gslide-desc {
  font-family: "Libre Baskerville", serif;
  font-style: italic;
  font-size: 14px;
  line-height: 1.8;
  color: var(--taupe);
}
.glightbox-clean .gslide-desc .artwork-divider {
  display: block;
  width: 24px;
  height: 0.5px;
  background: var(--gold);
  margin: 10px 0;
}
.glightbox-clean .gslide-desc .artwork-dimensions {
  display: block;
  font-family: "DM Sans", sans-serif;
  font-style: normal;
  font-size: 12px;
  letter-spacing: 0.06em;
  color: var(--muted);
}
.goverlay {
  background: rgba(10, 6, 2, 0.97) !important;
}
.glightbox-clean .gnext,
.glightbox-clean .gprev {
  background: none;
}
.glightbox-clean .gnext svg,
.glightbox-clean .gprev svg {
  fill: rgba(240, 232, 210, 0.4);
}
.glightbox-clean .gnext:hover svg,
.glightbox-clean .gprev:hover svg {
  fill: rgba(240, 232, 210, 0.8);
}
.glightbox-clean .gclose {
  background: none;
}
.glightbox-clean .gclose svg {
  fill: rgba(240, 232, 210, 0.5);
}
.glightbox-clean .gclose:hover svg {
  fill: rgba(240, 232, 210, 0.9);
}
.glightbox-clean .gslide-image img {
  border: none;
}

/* Override GLightbox mobile defaults */
.glightbox-mobile .glightbox-container .gslide-description {
  background: var(--cream-off) !important;
}
.glightbox-mobile .glightbox-container .gslide-title {
  color: var(--brown) !important;
}
.glightbox-mobile .glightbox-container .gslide-desc {
  color: var(--taupe) !important;
}
.glightbox-mobile .glightbox-container .gslide-desc * {
  color: inherit !important;
}
.glightbox-mobile .glightbox-container .gslide-desc .artwork-dimensions {
  color: var(--muted) !important;
}

@media (max-width: 768px) {
  .masonry {
    columns: 2;
    padding: 0 24px 60px;
  }
  /* Full-width media on mobile (description drops below). Must match the
     desktop scoped selector's specificity to override it. */
  .glightbox-clean .gslide-media,
  .glightbox-clean .ginner-container.desc-right .gslide-media,
  .glightbox-clean .ginner-container.desc-left .gslide-media {
    max-width: 100%;
  }
}
/* Small phones keep 2 columns — a single column of 20+ full-width images
   makes the page enormously tall; the lightbox handles detail viewing. */
