/* -------------------------------------------------------------------------- */
/*  Shared grid layouts                                                       */
/* -------------------------------------------------------------------------- */

.gridContainer {
  display: grid;
  gap: 0.75rem;
}

.grid-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  max-width: calc(3 * 350px + 2 * 0.75rem);
}

@media (max-width: 650px) {
  .grid-3 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    max-width: calc(2 * 300px + 1 * 0.75rem);
  }
}

.grid-4 {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  max-width: calc(4 * 300px + 3 * 0.75rem);
}

@media (max-width: 900px) {
  .grid-4 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    max-width: calc(3 * 300px + 2 * 0.75rem);
  }
}

@media (max-width: 650px) {
  .grid-4 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    max-width: calc(2 * 300px + 1 * 0.75rem);
  }
}

.grid-5 {
  grid-template-columns: repeat(5, minmax(0, 1fr));
  max-width: calc(5 * 300px + 4 * 0.75rem);
}

@media (max-width: 1150px) {
  .grid-5 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    max-width: calc(4 * 300px + 3 * 0.75rem);
  }
}

@media (max-width: 900px) {
  .grid-5 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    max-width: calc(3 * 300px + 2 * 0.75rem);
  }
}

@media (max-width: 650px) {
  .grid-5 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    max-width: calc(2 * 300px + 1 * 0.75rem);
  }
}
