.faq_bg {
  position: relative;
  background: url("../img/faq/bg.jpg") no-repeat center top/cover;
}
@media screen and (max-width: 767px) {
  .faq_bg {
    background: url("../img/faq/bg_sp.jpg") no-repeat center top/cover;
  }
}

.page-faq {
  padding-top: 206px;
}
@media screen and (max-width: 767px) {
  .page-faq {
    padding-top: 107px;
  }
}
.page-faq .faq_container--wrap .faq_container--box {
  margin-top: 50px;
}

.idx-faq_inner {
  max-width: 1075px;
  margin-inline: auto;
  padding-inline: 20px;
  width: 100%;
  padding-bottom: 160px;
}
@media screen and (max-width: 767px) {
  .idx-faq_inner {
    padding-inline: 16px;
    padding-bottom: 75px;
  }
}

.idx-faq_title h1 {
  width: 132px;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .idx-faq_title h1 {
    width: 30.3206997085%;
  }
}
.idx-faq_title p {
  margin-top: 8px;
  font-size: 18px;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .idx-faq_title p {
    font-size: 16px;
    letter-spacing: 0.01em;
  }
}

.idx-faq_anchor {
  margin-top: 55px;
  display: flex;
  justify-content: center;
  align-items: center;
  max-width: 860px;
  width: 100%;
  margin-inline: auto;
  gap: 25px min(5.5vw, 92px);
  flex-wrap: wrap;
}
@media screen and (max-width: 767px) {
  .idx-faq_anchor {
    margin-top: 41px;
    gap: 25px 15px;
  }
}
.idx-faq_anchor a {
  display: block;
  padding: 14px 48px;
  border-radius: 100vmax;
  background-color: #fff;
  border: 1px solid #ddd;
  text-align: center;
  font-size: 17px;
  font-weight: 500;
  letter-spacing: 0.03em;
  color: #333;
  position: relative;
}
@media screen and (max-width: 767px) {
  .idx-faq_anchor a {
    padding: 12px 33px 12px 18px;
  }
}
.idx-faq_anchor a::before {
  content: "";
  position: absolute;
  top: 50%;
  right: 26px;
  width: 9px;
  height: 10px;
  background: url("../img/faq/icon_btn.svg") no-repeat center/contain;
  transform: translateY(-50%);
}
@media screen and (max-width: 767px) {
  .idx-faq_anchor a::before {
    right: 16px;
  }
}

.faq_container--wrap {
  margin-top: 93px;
}
@media screen and (max-width: 767px) {
  .faq_container--wrap {
    margin-top: 80px;
  }
}

.faq_container--title {
  text-align: center;
  font-size: 26px;
  font-weight: 700;
  letter-spacing: 0.03em;
  position: relative;
  z-index: 1;
}
.faq_container--title::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 230px;
  height: 18px;
  background: url("../img/faq/line_title1.png") no-repeat center/contain;
  transform: translateX(-50%);
  z-index: -1;
}
.faq_container--title.faq02::before {
  width: 280px;
  height: 22px;
  background: url("../img/faq/line_title2.png") no-repeat center/contain;
}