:root {
  --leading-trim: calc((1em - 1lh) / 2);
}

@media screen and (max-width: 1023px) and (min-width: 768px) {
  html {
    font-size: 1.3020833333vw;
  }
}
/* .c-ttl.p-faq__ttl .c-ttl_main {
  font-size: 3.4rem;
  line-height: 1.5;
}
@media screen and (max-width: 960px) {
  .c-ttl.p-faq__ttl .c-ttl_main {
    font-size: 2.5rem;
  }
} */

/* .c-ttl.p-faq__ttl .c-ttl_sub {
  font-size: 1.4rem;
  line-height: 1.7;
}
@media screen and (max-width: 960px) {
  .c-ttl.p-faq__ttl .c-ttl_sub {
    font-size: 1rem;
  }
} */

.l-mainInner {
  width: min(136rem, 100%);
  padding-inline: 2rem;
  margin: 0 auto;
}

.faq {
  letter-spacing: 0;
}

summary {
  list-style: none;
}
summary::-webkit-details-marker {
  display: none; /* Safari / Chrome対応 */
}

.p-faq:first-of-type {
  margin-top: 5.15rem;
}
@media screen and (max-width: 767px) {
  .p-faq:first-of-type {
    margin-top: 2.75rem;
  }
}
.p-faq + .p-faq {
  margin-top: 8rem;
}
.p-faq:last-of-type {
  margin-bottom: 16rem;
}
.p-faq__ttl-sub {
  margin-top: 0.4rem;
}
.p-faq__details {
  border-bottom: 1px solid #DCDCDC;
}
.p-faq__details:first-of-type {
  border-top: 1px solid #DCDCDC;
  margin-top: 3.85rem;
}
.p-faq__summary {
  cursor: pointer;
}
.p-faq__summary-inner {
  padding: 2.2rem 1.25rem 2.7rem;
  display: grid;
  grid-template-columns: auto 1fr auto;
  column-gap: 3.18rem;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .p-faq__summary-inner {
    padding: 2.2rem 0.75rem 2.7rem;
    column-gap: 1.9rem;
  }
}
.p-faq__summary-inner::before, .p-faq__answer-inner::before {
  font-family: "Urbanist", sans-serif;
  font-size: 2.6rem;
  line-height: 1.7;
}
.p-faq__summary-inner::before {
  content: "Q";
}
.p-faq__answer-inner::before {
  content: "A";
}
.p-faq__summary-text {
  line-height: 2;
}
@media screen and (max-width: 767px) {
  .p-faq__summary-text {
    line-height: 1.5;
  }
}
.p-faq__summary-icon {
  width: 2.073rem;
}
.p-faq__summary-icon::before {
  content: "";
  display: inline-block;
  width: 1.5rem;
  aspect-ratio: 1/1;
  border-right: 1px solid #000;
  border-bottom: 1px solid #000;
  rotate: 45deg;
  transition: rotate 0.3s ease;
}
.p-faq__details[open=true] .p-faq__summary-icon::before {
  rotate: 225deg;
}
@media screen and (max-width: 767px) {
  .p-faq__summary-icon::before {
    width: 1rem;
  }
}
.p-faq__answer {
  margin-top: -0.5rem;
}
.p-faq__answer-inner {
  padding: 0 5.58rem 3.6rem 1.7rem;
  display: grid;
  grid-template-columns: auto 1fr;
  column-gap: 3.18rem;
}
@media screen and (max-width: 767px) {
  .p-faq__answer-inner {
    padding: 0 3.5rem 3.6rem 0.75rem;
    column-gap: 1.9rem;
    text-align: justify;
  }
}
.p-faq__answer-text {
  padding-top: 1.7rem;
  margin-block: var(--leading-trim);
  line-height: 2;
}
@media screen and (max-width: 767px) {
  .p-faq__answer-text {
    line-height: 1.5;
  }
}

.p-faq__btn {
  width: 21.4rem;
  height: 5rem;
  margin: 0 0 5rem 6.8rem;
}
@media screen and (max-width: 768px) {
  .p-faq__btn {
    margin: 0 0 5rem 4.4rem;
  }
}
.p-faq__btn .c-btn_text {
  font-size: 1.2rem;
}