/* Grid System - Module 20px */

:root {
  --grid-unit: 20px;
  --container-max-width: 1200px;
  --container-padding: calc(var(--grid-unit) * 2); /* 40px */
  --grid-gap: var(--grid-unit); /* 20px */
}

/* Container */
.container {
  width: 100%;
  max-width: var(--container-max-width);
  margin: 0 auto;
  padding: 0 var(--container-padding);
}

/* Grid System */
.grid {
  display: grid;
  gap: var(--grid-gap);
}

.grid--2col {
  grid-template-columns: 1fr 1fr;
  gap: calc(var(--grid-unit) * 2); /* 40px */
}

.grid--3col {
  grid-template-columns: repeat(3, 1fr);
}

.grid--4col {
  grid-template-columns: repeat(4, 1fr);
}

/* Responsive Grid */
@media (max-width: 768px) {
  :root {
    --container-padding: var(--grid-unit); /* 20px on mobile */
  }

  .grid--2col,
  .grid--3col,
  .grid--4col {
    grid-template-columns: 1fr;
  }
}
