.product-grid {
  display: flex;
  flex-wrap: wrap;
  gap: var(--gap-md);
}
.product-grid > * {
  --width: calc((100% - 2*var(--gap-md))/3.001);
  width: var(--width);
  flex: 0 0 var(--width);
}
@media (max-width: 1279px) {
  .product-grid > * {
    --width: calc((100% - 2*var(--gap-md))/2);
  }
}
@media (max-width: 759px) {
  .product-grid > * {
    --width: 100%;
  }
}