/* Gallery-specific styles (masonry grid + lightbox) */
.masonry-gallery{
  column-count:4;
  column-gap:20px;
  padding:24px 60px;
}
figure.masonry-item{
  break-inside:avoid;
  margin:0 0 20px;
  background:transparent;
  display:block;
}
figure.masonry-item img{
  width:100%;
  height:auto;
  display:block;
  border-radius:6px;
  box-shadow:0 8px 24px rgba(0,0,0,0.12);
}
.masonry-caption{font-size:13px;color:var(--color-secondary);margin-top:8px}

.lightbox-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.85);display:none;align-items:center;justify-content:center;z-index:9999;padding:20px}
.lightbox-overlay.active{display:flex}
.lightbox-inner{max-width:1200px;max-height:90vh;display:flex;flex-direction:column;align-items:center}
.lightbox-inner img{max-width:100%;max-height:85vh;border-radius:6px;box-shadow:0 20px 50px rgba(0,0,0,0.6)}
.lightbox-caption{color:#fff;margin-top:12px;font-size:15px;text-align:center}
.lightbox-close{position:absolute;top:18px;right:20px;color:#fff;font-size:28px;background:none;border:none;cursor:pointer}
/* Place prev/next arrows on the left/right edges, vertically centered */
.lightbox-nav{position:absolute;inset:0;display:flex;align-items:center;justify-content:space-between;pointer-events:none;padding:0 8px}
.lightbox-nav button{pointer-events:all;background:rgba(0,0,0,0.35);border:none;color:#fff;padding:12px 16px;border-radius:6px;font-size:22px;cursor:pointer;margin:0}


@media (max-width:1200px){
  .masonry-gallery{column-count:3;padding:20px 40px}
}
@media (max-width:968px){
  .masonry-gallery{column-count:2;padding:20px 30px}
}
@media (max-width:480px){
  /* Make photos span the full viewport on small screens */
  .masonry-gallery{
    column-count:1;
    /* remove internal padding so images can reach the viewport edges */
    padding:20px;
    /* expand to full viewport width and cancel surrounding container padding */
    width:100vw;
    margin-left:calc(50% - 50vw);
    margin-right:calc(50% - 50vw);
  }
  .masonry-gallery figure.masonry-item{margin:0 0 20px}
  .masonry-gallery figure.masonry-item a{display:block}
  .masonry-gallery figure.masonry-item img{
    width:100%;
    max-width:100%;
    height:auto;
    display:block;
    border-radius:0;
  }
  /* Remove gallery-category padding on very small screens so headings line up with full-bleed images */
  .gallery-category{padding:0}
}

/* Simple category headings */
.gallery-category{padding:18px 60px 8px}
.gallery-category h2{font-size:20px;color:var(--color-primary);margin:0 0 12px}
