body {
  max-width: 80ch;
  margin: 0 auto;
  padding: 0 1em;
  background: burlywood;
  color: black;
  font-weight: 400;
  font-family: Lexend, sans-serif;
}

main > div {
  margin: 5rem 0;
}

h1, h2 {
  font-weight: 400;
  font-family: "B612 Mono", monospace;
}

h1 a:link, h1 a:visited, h1 a:active {
  color: black;
  text-decoration: none;
}

a:link, a:visited, a:active {
  color: maroon;
}

.light {
  opacity: 30%;
}

.game-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(16rem, 1fr));
  grid-auto-flow: row;
  gap: 1rem;
}

.game-tile {
  display: block;
  width: 100%;
  padding-bottom: 56.25%;
  position: relative;
}

.game-tile:link, .game-tile:visited, .game-tile:active {
  color: white;
}

.game-tile div {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
}

.game-tile img {
  object-fit: cover;
  height: 100%;
  width: 100%;
}

.game-desc {
  display: grid;
  grid-template-rows: auto 1fr;
}

.game-desc h3 {
  background: rgba(0, 0, 0, 0.5);
  margin: 0;
  padding: 0.5em;
}

.game-desc p {
  background: rgba(0, 0, 0, 0.5);
  margin: 0;
  padding: 0.5em;
  opacity: 0;
  transition: opacity 0.15s ease-in-out;
}

.game-desc:hover p {
  opacity: 1;
}

img {
  max-width: 100%;
}
