@charset "UTF-8";
/* ============================================================
   スラトレ®認定トレーナー養成講座（trainer.yaekofu.com）ページ別スタイル
   v1.0.0 PartA - 2026-05-19
   ============================================================ */

/* ========== /about/ 代表者ご挨拶 ========== */
.about-page__greeting {
  max-width: var(--max-width-reading);
  margin: 0 auto;
  padding: var(--space-3xl) var(--space-lg);
}

.about-page__greeting p {
  font-size: 17px;
  line-height: 2.0;
  color: var(--color-text-primary);
}

.about-page__three-domains {
  background-color: var(--color-cream);
  padding: var(--space-xl);
  border-radius: var(--border-radius-lg);
  margin: var(--space-2xl) 0;
}

.about-page__three-domains h3 {
  margin-top: 0;
  font-size: var(--font-size-xl);
}

.about-page__three-domains ul {
  list-style: none;
  padding: 0;
  margin: var(--space-md) 0 0;
}

.about-page__three-domains li {
  padding: var(--space-md) 0;
  border-bottom: 1px solid rgba(201, 169, 97, 0.3);
  font-size: var(--font-size-base);
}

.about-page__three-domains li:last-child {
  border-bottom: none;
}

.about-page__three-domains li .term-label {
  /* 永続ルール準拠：装飾としてのstrong不可。
     ここでは領域名（からだ／こころ／ウェルネス）の意味的強調用。font-weight 500 のみ */
  font-weight: var(--font-weight-medium);
  color: var(--color-navy);
  margin-right: var(--space-xs);
}

.about-page__media-list {
  list-style: none;
  padding: 0;
  margin: var(--space-lg) 0;
}

.about-page__media-list li {
  padding: var(--space-md) 0;
  border-bottom: 1px solid var(--color-border-light);
  line-height: var(--line-height-base);
}

.about-page__media-list li:last-child {
  border-bottom: none;
}

/* ========== /featured/ プロ養成講座特長 ========== */
.featured-page__target {
  background-color: var(--color-cream);
  padding: var(--space-2xl);
  border-radius: var(--border-radius-lg);
  margin: var(--space-xl) 0;
}

.featured-page__step-list {
  counter-reset: step;
  list-style: none;
  padding: 0;
  margin: var(--space-xl) 0;
}

.featured-page__step-list li {
  counter-increment: step;
  position: relative;
  padding: var(--space-md) 0 var(--space-md) 56px;
  margin-bottom: var(--space-md);
  border-bottom: 1px dashed var(--color-border-light);
}

.featured-page__step-list li::before {
  content: counter(step);
  position: absolute;
  left: 0;
  top: var(--space-md);
  width: 40px;
  height: 40px;
  background-color: var(--color-navy);
  color: var(--color-gold);
  font-family: var(--font-serif);
  font-size: var(--font-size-lg);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* ========== /featured/trainer/ スラトレ®トレーナー ========== */
.trainer-page__stages {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--space-lg);
  margin: var(--space-xl) 0;
}

.trainer-page__stage {
  background-color: var(--color-off-white);
  border: 1px solid var(--color-border-light);
  border-top: 4px solid var(--color-gold);
  border-radius: var(--border-radius-md);
  padding: var(--space-xl);
}

.trainer-page__stage-level {
  font-family: var(--font-serif);
  font-size: var(--font-size-lg);
  color: var(--color-navy);
  margin: 0 0 var(--space-sm);
}

.trainer-page__stage-hours {
  font-size: var(--font-size-2xl);
  font-family: var(--font-serif);
  color: var(--color-gold-dark);
  margin: 0 0 var(--space-md);
}

.trainer-page__stage-list {
  font-size: var(--font-size-sm);
  margin: 0;
  padding-left: 1.2em;
}

/* ICF免責 aside（trainer / program 共通） */
.icf-disclaimer {
  background-color: var(--color-cream);
  border-left: 4px solid var(--color-gold);
  padding: var(--space-lg) var(--space-xl);
  margin: var(--space-2xl) 0;
  font-size: var(--font-size-sm);
  line-height: var(--line-height-base);
  color: var(--color-text-secondary);
  border-radius: 0 var(--border-radius-md) var(--border-radius-md) 0;
}

.icf-disclaimer__title {
  font-weight: var(--font-weight-medium);
  color: var(--color-navy);
  margin: 0 0 12px;
  font-size: var(--font-size-base);
}

.icf-disclaimer p {
  margin: 0;
}

/* ========== /featured/trainer/program/ プロ養成講座詳細 ========== */
.program-page__price-box {
  background-color: var(--color-cream);
  border: 2px solid var(--color-gold);
  border-radius: var(--border-radius-lg);
  padding: var(--space-2xl);
  margin: var(--space-xl) 0;
  text-align: center;
}

.program-page__price-label {
  font-size: var(--font-size-sm);
  letter-spacing: 0.15em;
  color: var(--color-gold-dark);
  text-transform: uppercase;
  margin: 0 0 var(--space-sm);
}

.program-page__price {
  font-family: var(--font-serif);
  font-size: var(--font-size-4xl);
  color: var(--color-navy);
  margin: 0 0 var(--space-md);
  line-height: 1.2;
}

.program-page__price-note {
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  margin: 0;
}

.program-page__split-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--space-md);
  margin: var(--space-xl) 0;
}

.program-page__split-card {
  text-align: center;
  padding: var(--space-lg);
  background-color: var(--color-off-white);
  border: 1px solid var(--color-border-light);
  border-radius: var(--border-radius-md);
}

.program-page__split-title {
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  margin: 0 0 var(--space-sm);
}

.program-page__split-amount {
  font-family: var(--font-serif);
  font-size: var(--font-size-2xl);
  color: var(--color-navy);
  margin: 0;
}

/* ========== /appointment/ 創始者面談予約 ========== */
.appointment-page__fee-box {
  background-color: var(--color-cream);
  border: 2px solid var(--color-gold);
  border-radius: var(--border-radius-lg);
  padding: var(--space-xl);
  text-align: center;
  margin: var(--space-xl) auto;
  max-width: 480px;
}

.appointment-page__fee-amount {
  font-family: var(--font-serif);
  font-size: var(--font-size-3xl);
  color: var(--color-navy);
  margin: 0 0 var(--space-sm);
}

.appointment-page__fee-detail {
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  margin: 0;
}

.appointment-page__ebook {
  background-color: var(--color-off-white);
  border: 1px solid var(--color-border-light);
  border-radius: var(--border-radius-lg);
  padding: var(--space-xl);
  margin: var(--space-2xl) 0;
  display: flex;
  gap: var(--space-lg);
  align-items: center;
}

.appointment-page__ebook-icon {
  flex-shrink: 0;
  width: 64px;
  height: 64px;
  background-color: var(--color-navy);
  color: var(--color-gold);
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--border-radius-md);
  font-family: var(--font-serif);
  font-size: var(--font-size-xl);
}

.appointment-page__ebook-body {
  flex: 1;
}

.appointment-page__ebook-title {
  font-family: var(--font-serif);
  font-size: var(--font-size-lg);
  color: var(--color-navy);
  margin: 0 0 var(--space-xs);
}

.appointment-page__ebook-desc {
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  margin: 0 0 var(--space-md);
}

@media (max-width: 639px) {
  .appointment-page__ebook { flex-direction: column; text-align: center; }
}

/* ========== FAQ ページ ========== */
.faq-section {
  max-width: var(--max-width-narrow);
  margin: 0 auto;
  padding: var(--space-2xl) var(--space-lg);
}

.faq-section__group-title {
  font-family: var(--font-serif);
  font-size: var(--font-size-2xl);
  color: var(--color-navy);
  margin: var(--space-3xl) 0 var(--space-xl);
  padding-bottom: var(--space-sm);
  border-bottom: 2px solid var(--color-gold);
}

.faq-section__group-title:first-child {
  margin-top: 0;
}

.faq-item {
  background-color: var(--color-off-white);
  border: 1px solid var(--color-border-light);
  border-radius: var(--border-radius-md);
  padding: var(--space-xl);
  margin-bottom: var(--space-md);
}

.faq-item__question {
  font-family: var(--font-serif);
  font-size: var(--font-size-lg);
  color: var(--color-navy);
  margin: 0 0 var(--space-md);
  display: flex;
  align-items: flex-start;
  gap: var(--space-sm);
}

.faq-item__question::before {
  content: "Q.";
  color: var(--color-gold-dark);
  font-weight: var(--font-weight-medium);
  flex-shrink: 0;
}

.faq-item__answer {
  margin: 0;
  line-height: var(--line-height-base);
  padding-left: 1.6em;
  position: relative;
}

.faq-item__answer::before {
  content: "A.";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--color-terracotta);
  font-weight: var(--font-weight-medium);
}

.faq-item__answer ul {
  margin-top: var(--space-sm);
}

.faq-hub__category {
  margin: var(--space-2xl) 0;
}

.faq-hub__category-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: var(--space-lg);
  padding-bottom: var(--space-sm);
  border-bottom: 1px solid var(--color-border-light);
  flex-wrap: wrap;
  gap: var(--space-sm);
}

.faq-hub__category-title {
  font-family: var(--font-serif);
  font-size: var(--font-size-2xl);
  color: var(--color-navy);
  margin: 0;
}

.faq-hub__category-more {
  font-size: var(--font-size-sm);
  color: var(--color-terracotta);
  text-decoration: none;
}

.faq-hub__category-more:hover {
  text-decoration: underline;
}

/* ========== /legal/ 特商法表記 ========== */
.legal-page {
  max-width: var(--max-width-narrow);
  margin: 0 auto;
  padding: var(--space-3xl) var(--space-lg) var(--space-4xl);
}

.legal-page h1 {
  font-family: var(--font-serif);
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-medium);
  color: var(--color-navy);
  margin: 0 0 var(--space-xl);
  padding-bottom: var(--space-md);
  border-bottom: 2px solid var(--color-gold);
}

.legal-page .lead {
  font-size: var(--font-size-base);
  line-height: var(--line-height-base);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-2xl);
}

.legal-table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: var(--space-3xl);
  font-size: 15px;
  line-height: 1.7;
}

.legal-table th {
  background-color: var(--color-cream);
  color: var(--color-navy);
  font-weight: var(--font-weight-medium);
  text-align: left;
  padding: var(--space-md) 20px;
  vertical-align: top;
  width: 30%;
  border: 1px solid var(--color-border-light);
}

.legal-table td {
  padding: var(--space-md) 20px;
  background-color: var(--color-off-white);
  border: 1px solid var(--color-border-light);
  vertical-align: top;
}

.legal-table strong {
  /* §5 例外措置：法的明示性のため。font-weight 500のみ、装飾色なし */
  font-weight: var(--font-weight-medium);
  color: var(--color-navy);
}

.legal-table p {
  margin: 0 0 var(--space-sm);
}

.legal-table p:last-child {
  margin-bottom: 0;
}

.legal-table ul {
  padding-left: 1.5em;
  margin: var(--space-sm) 0;
}

.legal-page h2 {
  font-family: var(--font-serif);
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-medium);
  color: var(--color-navy);
  margin: var(--space-3xl) 0 var(--space-md);
}

.legal-page__updated {
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  text-align: right;
  margin-top: var(--space-xl);
}

.legal-page__cta {
  margin-top: var(--space-3xl);
  padding: var(--space-xl);
  background-color: var(--color-cream);
  border-radius: var(--border-radius-lg);
  text-align: center;
}

.legal-page__cta p {
  margin-bottom: var(--space-md);
}

@media (max-width: 639px) {
  .legal-table th,
  .legal-table td {
    display: block;
    width: 100%;
  }
  .legal-table th {
    border-bottom: none;
    padding-bottom: var(--space-sm);
  }
  .legal-table td {
    padding-top: var(--space-sm);
    margin-bottom: var(--space-md);
  }
}
