/* FAQ全体 */
.faq-accordion {
  border-top: 1px solid #ddd;
  margin: 2em 0;
}

/* 各項目 */
.faq-item {
  border-bottom: 1px solid #ddd;
  padding: 1em 0;
}

/* 質問部分 */
.faq-question {
  cursor: pointer;
  font-weight: bold;
  position: relative;
  padding-right: 2.5em; /* アイコン分の余白 */
  font-size: 1.25em; /* タイトル大きめ */
  display: flex;
  align-items: center;
}

/* Qを固定表示（消せない） */
.faq-question::before {
  content: "Q";
  margin-right: 0.5em;
  color: #000;
}

/* 開いているときはタイトルを少し薄く */
.faq-item.open .faq-question {
  color: #666; /* グレー寄り */
}

/* 右端のアイコン（黒丸＋白記号） */
.faq-question::after {
  content: '+';
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  font-size: 0.9em;        /* 記号の大きさ */
  font-weight: bold;       /* 記号を太めに */
  background-color: #000;  /* 黒丸 */
  color: #fff;
  border-radius: 50%;
  width: 1.2em;            /* 丸の直径 */
  height: 1.2em;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  transition: background-color 0.3s ease;
}

/* 開いているときのアイコン（グレー丸+マイナス） */
.faq-item.open .faq-question::after {
  content: '−';
  background-color: #888;
}

/* 回答部分 */
.faq-answer {
  display: none;
  margin-top: 0.5em;
  padding: 1em; /* 周囲に余白 */
  /* background-color: #f9f9f9; */
  border-radius: 4px;
  line-height: 1.6;
  color: #333;
}

/* ------------------- */
/* 下だけ線Ver */
.faq-accordion.style-border {
  border-top: none; /* 上線なし */
  margin: 2em 0;
}

.faq-accordion.style-border .faq-item {
  border-bottom: 1px solid #ddd;
  padding: 1em 0;
}

.faq-accordion.style-border .faq-item:last-child {
  border-bottom: 1px solid #ddd; /* 最後にも線を残す */
}
/* カードVer */
.faq-accordion.style-card {
  border-top: none;
  margin: 2em 0;
}

.faq-accordion.style-card .faq-item {
  background-color: #fff;
  border-radius: 8px;
  box-shadow: 0 2px 6px rgba(0,0,0,0.05);
  padding: 1em;
  margin-bottom: 1em;
  border: none; /* 枠線はなし */
}
