.topic-list {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-regular);
}
@media (max-width: 768px) {
  .topic-list {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (max-width: 480px) {
  .topic-list {
    grid-template-columns: repeat(2, 1fr);
  }
}

.topic-item img {
  width: 100%;
  object-fit: contain;
  display: block; /* インライン要素だとデフォルトで付けられる余白を消す */
  margin-bottom: var(--space-small);
}

.topic-item .title {
  margin: var(--space-regular);
}
