.blog-page {
  background: #e4e4e4;
  color: #1f1f1f;
}

.blog-page__shell {
  width: min(1280px, calc(100% - 48px));
  margin-inline: auto;
}

.blog-archive {
  padding: clamp(88px, 9vw, 136px) 0 clamp(96px, 10vw, 140px);
  background: #e4e4e4;
}

.blog-archive__kicker {
  margin: 0;
  color: #1f1f1f;
  font-family: var(--tomato-latin-heading-font);
  font-size: 24px;
  font-weight: 700;
  line-height: 24px;
  letter-spacing: 9.6px;
}

.blog-archive__title {
  margin: 26px 0 0;
  color: #1f1f1f;
  font-family: var(--tomato-heading-font);
  font-size: 48px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 9.6px;
}

.blog-archive__grid {
  margin-top: clamp(48px, 9vw, 128px);
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 40px;
}

.blog-archive__card {
  width: 100%;
}

.blog-page .index-voice {
  padding-top: clamp(72px, 9vw, 123px);
  padding-bottom: clamp(80px, 9vw, 120px);
}

.blog-page .index-contact,
.blog-page .index-contact__inner {
  min-height: 723px;
}

@media (max-width: 1199px) {
  .blog-archive__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 767px) {
  .blog-page__shell {
    width: min(100%, calc(100% - 32px));
  }

  .blog-archive {
    padding: 88px 0 96px;
  }

  .blog-archive__kicker {
    font-size: 18px;
    letter-spacing: 0.24em;
  }

  .blog-archive__title {
    margin-top: 18px;
    font-size: 34px;
    letter-spacing: 0.1em;
  }

  .blog-archive__grid {
    margin-top: 48px;
    gap: 24px;
  }

  .blog-page .index-voice {
    padding-top: 96px;
    padding-bottom: 88px;
  }

  .blog-page .index-contact,
  .blog-page .index-contact__inner {
    min-height: 560px;
  }
}

@media (max-width: 720px) {
  .blog-page__shell {
    width: min(100%, calc(100% - 24px));
  }

  .blog-archive {
    padding: 64px 0 72px;
  }

  .blog-archive__kicker {
    font-size: 14px;
    letter-spacing: 0.2em;
  }

  .blog-archive__title {
    margin-top: 14px;
    font-size: 28px;
    letter-spacing: 0.06em;
  }

  .blog-archive__grid {
    margin-top: 32px;
    grid-template-columns: minmax(0, 1fr);
    gap: 16px;
  }

  .blog-page .index-voice {
    padding-top: 64px;
    padding-bottom: 64px;
  }

  .blog-page .index-contact,
  .blog-page .index-contact__inner {
    min-height: 440px;
  }
}
