/* ========================================
   よくある質問ページ専用スタイル
   ======================================== */

/* FAQ ページ専用: コンテンツ間隔を狭める（Cases統一） */
.page-template-page-faq .stats-section {
  padding-top: var(--space-lg);
  padding-bottom: var(--space-lg);
}

.page-template-page-faq .stats-section:first-of-type {
  padding-top: var(--space-md);
}

.page-template-page-faq .section-large-title {
  margin-bottom: var(--space-md);
}

/* パンくずナビゲーションの調整 */
.page-template-page-faq .container:first-child {
  margin-bottom: var(--space-sm);
}

.faq-categories {
  display: grid;
  gap: calc(var(--space-2xl) * 2);
  margin-top: var(--space-lg); /* Cases統一: より狭い間隔に変更 */
}

.faq-category {
  background-color: var(--bg-white);
  padding: var(--space-2xl);
}

.faq-category h3 {
  font-size: 2.4rem;
  font-weight: 700;
  margin-bottom: var(--space-xl);
  color: var(--main-text);
  text-align: center;
  border-bottom: 3px solid var(--emphasis);
  padding-bottom: var(--space-md);
}

.faq-item {
  border-bottom: 1px solid var(--border-line);
  margin-bottom: var(--space-lg);
}

.faq-question {
  font-size: 1.8rem;
  font-weight: 700;
  color: var(--main-text);
  cursor: pointer;
  padding: var(--space-md) 0;
  position: relative;
  transition: var(--transition);
  margin: 0;
  line-height: 1.4;
}

.faq-question::after {
  content: '+';
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  font-size: 2rem;
  font-weight: 700;
  color: var(--emphasis);
  transition: transform 0.3s ease-in-out;
}

.faq-item.active .faq-question::after {
  content: '−';
  transform: translateY(-50%) rotate(180deg);
}

.faq-question:hover {
  color: var(--emphasis);
}

.faq-answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease-in-out, padding 0.3s ease-in-out;
  padding: 0;
}

.faq-item.active .faq-answer {
  padding: var(--space-md) 0 var(--space-lg) 0;
}

.faq-answer p {
  font-size: 1.6rem;
  line-height: 1.7;
  margin-bottom: var(--space-md);
}

.faq-answer ul {
  list-style: none;
  padding: 0;
  margin-top: var(--space-md);
}

.faq-answer li {
  position: relative;
  padding-left: var(--space-md);
  margin-bottom: var(--space-xs);
  font-size: 1.4rem;
}

.faq-answer li::before {
  content: '•';
  position: absolute;
  left: 0;
  color: var(--emphasis);
  font-weight: 700;
}

/* カテゴリ説明文のスタイル */
.category-description {
  font-size: 1.6rem;
  color: var(--auxiliary-text);
  margin-bottom: var(--space-lg);
  text-align: center;
  font-style: italic;
}

/* CMSでFAQがない場合のスタイル */
.faq-item .btn {
  display: inline-block;
  padding: var(--space-md) var(--space-xl);
  background: var(--accent-color);
  color: var(--emphasis);
  text-decoration: none;
  border-radius: 4px;
  font-weight: var(--font-weight-medium);
  transition: var(--transition);
}

.faq-item .btn:hover {
  background: var(--main-text);
  color: var(--emphasis);
  transform: translateY(-2px);
}

/* レスポンシブ対応 */
@media (max-width: 768px) {
  .faq-categories {
    margin-top: var(--space-md); /* モバイルでさらに狭く */
    gap: var(--space-xl);
  }

  .faq-category {
    padding: var(--space-lg);
  }

  .faq-category h3 {
    font-size: 1.8rem;
    margin-bottom: var(--space-md);
  }

  .faq-question {
    font-size: 1.6rem;
    padding: var(--space-sm) 0;
  }

  .faq-question::after {
    font-size: 1.6rem;
  }

  .faq-answer p {
    font-size: 1.4rem;
  }

  /* モバイル専用間隔調整 */
  .page-template-page-faq .stats-section {
    padding-top: var(--space-md);
    padding-bottom: var(--space-md);
  }

  .page-template-page-faq .stats-section:first-of-type {
    padding-top: var(--space-sm);
  }
}