.m-gallery__title{
  text-align:center;
  font-size: clamp(1.6rem, 2.8vw, 2.5rem);
  font-weight: 800;
  margin: 0 0 0.75rem;
  letter-spacing: -0.02em;
}
.m-gallery__desc{
  text-align:center;
  margin: 0 auto 1.75rem;
  max-width: 780px;
  opacity: .75;
}

.m-gallery__grid{
  display:grid;
  gap: 1.25rem;
  grid-template-columns: repeat(var(--mgal-cols, 3), minmax(0, 1fr));
}
@media (max-width: 900px){
  .m-gallery__grid{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 520px){
  .m-gallery__grid{ grid-template-columns: repeat(1, minmax(0,1fr)); }
}

.m-gallery__item{
  position:relative;
  overflow:hidden;
  border-radius: 1rem;
  aspect-ratio: 4/3;
  border: 1px solid rgba(0,0,0,0.06);
  background: rgba(0,0,0,0.04);
  cursor:pointer;
  opacity: 0;
  transform: translateY(18px);
  transition: opacity .65s cubic-bezier(.16,1,.3,1), transform .65s cubic-bezier(.16,1,.3,1), box-shadow .4s;
}
.m-gallery__item.is-visible{ opacity:1; transform: translateY(0); }

.m-gallery__img{
  width:100%;
  height:100%;
  object-fit:cover;
  transform: scale(1.02);
  transition: transform .7s cubic-bezier(.16,1,.3,1), filter .7s cubic-bezier(.16,1,.3,1);
  display:block;
}
.m-gallery__item:hover{ box-shadow: 0 18px 40px rgba(0,0,0,0.14); }
.m-gallery__item:hover .m-gallery__img{
  transform: scale(1.12);
  filter: brightness(0.92) contrast(1.05);
}

.m-gallery__cap{
  position:absolute;
  left:0; right:0; bottom:0;
  padding: 1rem 1rem .9rem;
  background: linear-gradient(to top, rgba(0,0,0,0.72), rgba(0,0,0,0));
  color:#fff;
}
.m-gallery__capTitle{ font-weight: 800; }
.m-gallery__capDesc{ margin-top: .25rem; opacity:.9; font-size: .92rem; }
.m-gallery__capLink{
  display:inline-block;
  margin-top: .6rem;
  color:#fff;
  text-decoration: underline;
  font-weight: 700;
}

/* Lightbox */
.m-gallery__lb{
  position: fixed; inset:0;
  display:none;
  align-items:center; justify-content:center;
  background: rgba(0,0,0,0.85);
  z-index: 9999;
  padding: 2rem;
}
.m-gallery__lb.is-open{ display:flex; }
.m-gallery__lbInner{ max-width: 1100px; width:100%; display:flex; flex-direction:column; gap:.75rem; }
.m-gallery__lbImg{
  width:100%;
  max-height: 78vh;
  object-fit: contain;
  border-radius: 1rem;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.12);
}
.m-gallery__lbTitle{ color: rgba(255,255,255,0.92); font-weight: 600; text-align:center; font-size: .95rem; }
.m-gallery__lbClose{
  position:absolute; top:16px; right:16px;
  width:42px; height:42px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.22);
  background: rgba(0,0,0,0.35);
  color:#fff; font-size:18px;
  cursor:pointer;
}
