/* カテゴリへのアンカーナビ（淡緑背景帯の中にカード3列） */
.faq-anchor-section {
  background: var(--primary-pale);
  padding: 32px 0;
  margin-bottom: 60px;
}
.faq-anchor-nav {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  max-width: var(--container-md);
  margin: 0 auto;
}
.faq-anchor-card {
  background: white;
  border: 1.5px solid var(--border);
  border-radius: var(--radius-md);
  padding: 16px 20px;
  text-decoration: none;
  color: var(--primary-dark);
  transition: all .2s;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  font-weight: 700;
  font-size: var(--fs-base);
}
.faq-anchor-card:hover {
  border-color: var(--primary);
  background: var(--primary-light);
  color: var(--primary-dark);
}
.faq-anchor-card .faq-anchor-arrow {
  flex-shrink: 0;
  width: 22px; height: 22px;
  display: flex; align-items: center; justify-content: center;
  color: var(--primary);
  font-size: var(--fs-md);
}

/* カテゴリヘッダー（クリーム色バナー＋葉っぱ装飾＋中央配置） */
.faq-cat {
  max-width: var(--container-md);
  margin: 0 auto;
  /* faq-cat には上パディングが無いので、.section ページの見出し着地位置
     （= グローバル[id]オフセット + .section の上パディング）に揃える値 */
  scroll-margin-top: 126px;
}
@media (max-width: 900px) {
  .faq-cat { scroll-margin-top: 72px; }
}
.faq-cat + .faq-cat { margin-top: 80px; }
.faq-cat-header {
  background: #FAF6EC;
  border-radius: 10px;
  padding: 28px 32px;
  text-align: center;
  position: relative;
  margin-bottom: 36px;
}
.faq-cat-header::before {
  content: '';
  position: absolute;
  left: 28px;
  top: 50%;
  transform: translateY(-50%);
  width: 44px;
  height: 44px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cpath d='M8 56 C 18 24, 42 12, 56 8 C 50 26, 36 48, 12 58 Z' fill='%237BA489' opacity='0.55'/%3E%3Cpath d='M14 50 C 22 32, 38 22, 50 18' stroke='%235B9E82' stroke-width='1.4' fill='none' opacity='0.7'/%3E%3C/svg%3E");
  background-size: contain;
  background-repeat: no-repeat;
}
.faq-cat-name {
  font-size: var(--fs-lg);
  font-weight: 700;
  color: var(--primary-dark);
  letter-spacing: .04em;
}

/* サブセクション見出し */
.faq-subsection {
  font-weight: 700;
  color: var(--primary-dark);
  margin: 32px 0 14px;
  padding-left: 12px;
  border-left: 3px solid var(--primary);
}
.faq-cat > .faq-subsection:first-of-type { margin-top: 0; }

/* アコーディオン A型（分離） */
@supports (interpolate-size: allow-keywords) {
  :root { interpolate-size: allow-keywords; }
}
.faq-list { display: flex; flex-direction: column; gap: 8px; }
.faq-item { border-radius: var(--radius-md); }
.faq-item summary {
  background: var(--primary-light);
  border-radius: var(--radius-md);
  padding: 16px 24px;
  cursor: pointer;
  font-weight: 500;
  color: var(--text);
  font-size: var(--fs-base);
  display: flex;
  align-items: center;
  gap: 16px;
  list-style: none;
  line-height: 1.55;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::before {
  content: 'Q';
  flex-shrink: 0;
  width: 40px; height: 40px;
  background: #ffffff;
  color: var(--primary-dark);
  border: 1px solid var(--primary-dark);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: var(--fs-base);
  font-weight: 500;
}
.faq-item summary::after {
  content: '＋';
  margin-left: auto;
  color: var(--primary-dark);
  font-size: var(--fs-md);
  font-weight: 400;
  transition: transform .3s cubic-bezier(0.4, 0.4, 0, 1);
}
.faq-item[open] summary::after { transform: rotate(135deg); }
.faq-item-body {
  padding: 24px;
  font-size: var(--fs-base);
  line-height: 1.9;
  color: var(--text);
}
.faq-item::details-content {
  block-size: 0;
  overflow: clip;
  opacity: 0;
  transition:
    block-size .3s cubic-bezier(0.4, 0.4, 0, 1),
    opacity .3s cubic-bezier(0.4, 0.4, 0, 1),
    content-visibility .3s allow-discrete;
}
.faq-item[open]::details-content {
  block-size: auto;
  opacity: 1;
}
.faq-item-body p + p { margin-top: 10px; }
.faq-item-body ul { margin: 8px 0 4px; padding-left: 20px; }
.faq-item-body ul li { list-style: disc; margin-bottom: 4px; }
.faq-item-body a {
  color: var(--primary);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.faq-item-body .faq-link-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 12px;
  padding: 10px 20px;
  border: 1.5px solid var(--primary);
  background: white;
  color: var(--primary-dark);
  border-radius: var(--radius-md);
  font-size: var(--fs-sm);
  font-weight: 700;
  text-decoration: none;
  transition: all .2s;
}
.faq-item-body .faq-link-btn:hover {
  background: var(--primary);
  color: white;
}
.faq-item-body .faq-link-btn svg { width: 16px; height: 16px; fill: currentColor; }

/* 電話予約ボックス（参考画像にあったスタイル） */
.faq-tel-box {
  display: block;
  max-width: 320px;
  border: 1.5px solid var(--primary);
  border-radius: var(--radius-md);
  padding: 12px 20px;
  margin-top: 14px;
  text-align: center;
  text-decoration: none;
  transition: background .2s;
}
.faq-tel-box:hover { background: var(--primary-light); }
.faq-tel-box-label {
  display: block;
  font-size: var(--fs-sm);
  color: var(--primary-dark);
  font-weight: 700;
  margin-bottom: 2px;
}
.faq-tel-box-num {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-size: var(--fs-md);
  font-weight: 700;
  color: var(--primary-dark);
}
.faq-tel-box-num svg { width: 20px; height: 20px; fill: var(--primary-dark); }

@media (max-width: 768px) {
  .faq-anchor-nav { grid-template-columns: 1fr; gap: 10px; }
  .faq-cat-header { padding: 22px 24px 22px 56px; text-align: left; }
  .faq-cat-header::before { left: 14px; width: 32px; height: 32px; }
  .faq-cat-name { font-size: var(--fs-md); }
  .faq-item summary { padding: 14px 16px; font-size: var(--fs-sm); gap: 10px; }
  .faq-item-body { padding: 18px 18px; }
}
