/**
 * noras original theme
 * Page CSS: よくある質問
 * @author: shirako
 * @link: https://norasinc.jp
 * @license: http://www.gnu.org/licenses/gpl-2.0.html GPL v2 or later
 */

/* ベース（SP） */
.ly_cont.ly_faq {
  background-color: #fff;
  padding-inline: 16px;
  padding-block: 40px 80px;
}

.bl_faqCont {
  max-width: 1200px;
  margin-inline: auto;
  display: flex;
  flex-direction: column;
  gap: var(--space-3xl);
}

/* FAQカテゴリーグループ */
.bl_faqGroup {
  display: flex;
  align-items:start;
  gap: var(--space-20);
}
.bl_faqGroup_header {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  width: 100%;
}

.bl_faqGroup_ttl {
  color: #fff;
  font-size: clamp(1.125rem, 0.971rem + 0.71vw, 1.5rem);
  font-weight: 700;
  background: var(--color-primary);
  padding: 8px 24px;
  border-radius:0 8px 8px 0; 
  width: 100%;
}
@media screen and (max-width: 767px) {
  .bl_faqGroup{
    flex-wrap: wrap;
}
}
/* FAQリスト */
.bl_faqList {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

/* FAQ項目 → コンポーネント化: components/faq-item.css */

/* SP専用改行 */
.sm_only {
  display: inline;
}

/* Tablet (768px〜) */
@media screen and (min-width: 768px) {
  .ly_cont.ly_faq {
    padding-inline: 24px;
    padding-block: 70px 120px;
  }

  .bl_faqCont {
    gap: var(--space-5xl);
  }

  .bl_faqGroup {
    gap: 28px;
  }

  .bl_faqGroup_header {
    gap: var(--space-sm);
    width: 30%;
  }

  .bl_faqGroup_circle {
    width: 24px;
    height: 24px;
  }

  .bl_faqList {
    gap: var(--space-20);
  }

  .sm_only {
    display: none;
  }
}

/* Large PC (1024px〜) */
@media screen and (min-width: 1024px) {
  .bl_faqGroup_ttl {
    font-size: 24px;
  }

  .bl_faqList {
    gap: var(--space-lg);
  }
}