@layer components {
  .product-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    column-gap: var(--spacing-unit-s);
    row-gap: var(--spacing-unit-m);

    @media screen and (min-width: 1024px), print {
      grid-template-columns: repeat(4, 1fr);
      column-gap: var(--spacing-unit-l);
      row-gap: var(--spacing-unit-xl);
    }
  }
}
