@layer components {
  .products {
    --product-max-inline-size: 9rem;

    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(var(--product-max-inline-size), 1fr));
    gap: var(--block-space);

    @media (width >= 32rem) {
      --product-max-inline-size: 12rem;
    }

    @media (width >= 48rem) {
      --product-max-inline-size: 18rem;
    }
  }
}
