.terms-page {
  padding: 72px 40px 96px;
  background-color: #ffffff;
}

.terms-container {
  max-width: 1200px;
  margin: 0 auto;
}

.terms-title {
  margin: 0 0 18px;
  font-family: 'Mulish', sans-serif;
  font-size: clamp(2.7rem, 4.6vw, 4.1rem);
  line-height: 1.1;
  font-weight: 900;
  color: #242b29;
  letter-spacing: -0.03em;
}

.terms-effective-date {
  margin: 0 0 38px;
  font-size: 16px;
  line-height: 1.5;
  color: #2e3734;
}

.terms-effective-date strong {
  color: var(--color-primary);
}

.terms-content {
  color: #2e3734;
}

.terms-content p,
.terms-content li {
  font-family: 'Mulish', sans-serif;
  font-size: 16px;
  line-height: 1.56;
}

.terms-content p {
  margin: 0 0 24px;
}

.terms-content h2 {
  margin: 32px 0 12px;
  font-family: 'Mulish', sans-serif;
  font-size: clamp(2rem, 3.2vw, 2.9rem);
  line-height: 1.14;
  font-weight: 800;
  color: #242b29;
  letter-spacing: -0.03em;
}

.terms-content ul {
  margin: 0 0 24px 24px;
  padding: 0 0 0 16px;
}

.terms-content li {
  margin-bottom: 8px;
}

.terms-content a {
  color: var(--color-primary);
  text-decoration: none;
}

.terms-content a:hover {
  text-decoration: underline;
}

.terms-contact {
  color: #242b29;
}

@media (max-width: 1024px) {
  .terms-page {
    padding: 60px 32px 80px;
  }

  .terms-content h2 {
    margin-top: 28px;
  }
}

@media (max-width: 768px) {
  .terms-page {
    padding: 48px 24px 64px;
  }

  .terms-title {
    font-size: clamp(2.3rem, 9vw, 3rem);
    line-height: 1.12;
  }

  .terms-content h2 {
    font-size: clamp(1.75rem, 7vw, 2.2rem);
    line-height: 1.16;
  }

  .terms-effective-date,
  .terms-content p,
  .terms-content li {
    font-size: 15px;
  }

  .terms-content ul {
    margin-left: 18px;
    padding-left: 12px;
  }
}
