.veloc-gallery-grid{
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
@media (max-width: 900px){
  .veloc-gallery-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 520px){
  .veloc-gallery-grid{ grid-template-columns: 1fr; }
}
.veloc-gallery-grid a{
  display:block;
  border-radius:10px;
  overflow:hidden;
  position:relative;
  background:#111;
}
.veloc-gallery-grid img,
.veloc-gallery-grid video{
  width:100%;
  height:100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  display:block;
  border-radius:10px;
}
.veloc-video-badge{
  position:absolute;
  top:10px;
  left:10px;
  z-index:2;
  padding:6px 10px;
  border-radius:999px;
  background:rgba(0,0,0,.68);
  color:#fff;
  font-size:12px;
  line-height:1;
}
.veloc-gallery-grid .is-video::after{
  content:'▶';
  position:absolute;
  right:12px;
  bottom:12px;
  width:42px;
  height:42px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(0,0,0,.55);
  color:#fff;
  font-size:16px;
  pointer-events:none;
}

.veloc-lightbox{
  position:fixed;
  inset:0;
  background: rgba(0,0,0,.82);
  display:none;
  align-items:center;
  justify-content:center;
  z-index: 999999;
  padding: 24px;
}
.veloc-lightbox.is-open{ display:flex; }
.veloc-lightbox-inner{
  position:relative;
  max-width: 1100px;
  width: 100%;
}
.veloc-lightbox-stage img,
.veloc-lightbox-stage video{
  width:100%;
  max-height:82vh;
  display:block;
  border-radius:14px;
  box-shadow: 0 20px 60px rgba(0,0,0,.45);
  background:#111;
}
.veloc-lightbox-close,
.veloc-lightbox-prev,
.veloc-lightbox-next{
  position:absolute;
  top: 50%;
  transform: translateY(-50%);
  width:44px;
  height:44px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.25);
  background: rgba(0,0,0,.35);
  color:#fff;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  user-select:none;
}
.veloc-lightbox-close{
  top: -16px;
  right: -16px;
  transform:none;
}
.veloc-lightbox-prev{ left: -12px; }
.veloc-lightbox-next{ right: -12px; }
@media (max-width: 720px){
  .veloc-lightbox-prev{ left: 6px; }
  .veloc-lightbox-next{ right: 6px; }
  .veloc-lightbox-close{ right: 6px; top: 6px; }
}
