/* ご利用規約 Page：宽度与 checkout 一致，中间按截图 */

.terms-section {
  padding: 40px 60px 80px;
  max-width: 1200px;
  margin: 0 auto;
}

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

/* Breadcrumb */
.breadcrumb {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 20px 60px;
  margin-top: 20px;
}

.breadcrumb-link {
  font-family: 'Inter', sans-serif;
  font-size: 14px;
  font-weight: 400;
  color: #313131;
  text-decoration: none;
}

.breadcrumb-link:hover {
  color: #AF936E;
}

.breadcrumb-current {
  font-family: 'Inter', sans-serif;
  font-size: 14px;
  font-weight: 400;
  color: #313131;
}

/* 页面主标题：居中 */
.terms-page-title {
  font-family: "Noto Sans JP", "Inter", Helvetica, sans-serif;
  font-weight: 500;
  color: #000000;
  font-size: 28px;
  text-align: center;
  margin: 0 0 32px 0;
  letter-spacing: 0;
  line-height: 1.4;
}

/* 引言：ご利用規約 小标题 + 段落 */
.terms-intro {
  margin-bottom: 36px;
}

.terms-intro-title {
  font-family: "Noto Sans JP", "Inter", Helvetica, sans-serif;
  font-weight: 700;
  color: #000000;
  font-size: 18px;
  margin: 0 0 12px 0;
  letter-spacing: 0;
  line-height: 1.5;
}

.terms-intro-text {
  font-family: "Noto Sans JP", "Inter", Helvetica, sans-serif;
  font-weight: 400;
  color: #000000;
  font-size: 15px;
  line-height: 1.8;
  margin: 0;
}

/* 条项：■ 第N条（标题） */
.terms-articles {
  display: flex;
  flex-direction: column;
  gap: 28px;
}

.terms-article {
  margin: 0;
}

.terms-article-heading {
  font-family: "Noto Sans JP", "Inter", Helvetica, sans-serif;
  font-weight: 700;
  color: #000000;
  font-size: 16px;
  margin: 0 0 10px 0;
  letter-spacing: 0;
  line-height: 1.5;
}

.terms-article p {
  font-family: "Noto Sans JP", "Inter", Helvetica, sans-serif;
  font-weight: 400;
  color: #000000;
  font-size: 15px;
  line-height: 1.8;
  margin: 0 0 12px 0;
}

.terms-article p:last-child {
  margin-bottom: 0;
}

/* Responsive */
@media (max-width: 1200px) {
  .terms-section {
    padding: 40px 40px 80px;
  }
  .breadcrumb {
    padding: 20px 40px;
  }
}

@media (max-width: 992px) {
  .terms-section {
    padding: 30px 30px 60px;
  }
  .breadcrumb {
    padding: 20px 30px;
  }
}

@media (max-width: 768px) {
  .terms-section {
    padding: 20px 20px 50px;
  }
  .breadcrumb {
    padding: 15px 20px;
    font-size: 13px;
  }
  .terms-page-title {
    font-size: 24px;
    margin-bottom: 24px;
  }
  .terms-article-heading {
    font-size: 15px;
  }
  .terms-article p,
  .terms-intro-text {
    font-size: 14px;
  }
}

@media (max-width: 480px) {
  .terms-section {
    padding: 15px 15px 40px;
  }
  .breadcrumb {
    padding: 12px 15px;
    font-size: 12px;
  }
  .terms-page-title {
    font-size: 22px;
  }
}
