@charset "UTF-8";
@layer page {
  body {
    background: #000;
  }
  .l-page {
    --body-color: #000;
    --text-color: #fff;
  }
  @media screen and (min-width: 768px) {
    .l-page {
      --footer-fill: #fff;
      --footer-color: var(--main);
    }
  }
  .faq {
    font-family: var(--serif);
  }
  @media screen and (max-width: 767px) {
    .faq {
      padding-left: 7.6923076923vw;
      padding-right: 7.6923076923vw;
    }
  }
  .faq-hdr {
    text-align: center;
  }
  .faq-hdr__en {
    width: 13.75rem;
    margin: 0 auto;
  }
  @media screen and (max-width: 767px) {
    .faq-hdr__en {
      width: 21.3675213675vw;
    }
  }
  .faq-hdr__ttl {
    font-size: 2.125rem;
    letter-spacing: 0.1em;
    margin-top: 0.375rem;
  }
  @media screen and (max-width: 767px) {
    .faq-hdr__ttl {
      font-size: 3.5042735043vw;
    }
  }
  .faq-body {
    margin-top: 9.375rem;
  }
  @media screen and (max-width: 767px) {
    .faq-body {
      margin-top: 6.8376068376vw;
    }
  }
  .faq-items {
    display: flex;
    flex-direction: column;
    gap: 6.25rem;
  }
  @media screen and (max-width: 767px) {
    .faq-items {
      gap: 10.2564102564vw;
    }
  }
  @media screen and (max-width: 767px) {
    .faq-item {
      font-size: var(--sp-text-size-a);
    }
  }
  .faq-item__q {
    display: flex;
    align-items: center;
    gap: 1.25rem;
  }
  @media screen and (min-width: 768px) {
    .faq-item__q {
      font-size: 1.3675213675vw;
    }
  }
  @media screen and (max-width: 767px) {
    .faq-item__q {
      align-items: flex-start;
    }
  }
  .faq-item__q::before {
    content: "Q";
    font-size: 3rem;
    position: relative;
  }
  @media screen and (max-width: 767px) {
    .faq-item__q::before {
      top: -2.3076923077vw;
      font-size: 5.5555555556vw;
    }
  }
  .faq-item__q-text {
    display: grid;
    align-items: center;
    grid-template-columns: 1fr 2.0625rem;
    gap: 0.625rem;
    padding-bottom: 0.625rem;
    border-bottom: 1px solid #fff;
    flex-grow: 1;
  }
  @media screen and (max-width: 767px) {
    .faq-item__q-text {
      grid-template-columns: 1fr 3.7606837607vw;
    }
  }
  .faq-item__a {
    display: flex;
    gap: 1.25rem;
  }
  .faq-item__a::before {
    content: "A";
    position: relative;
    top: 0.625rem;
    font-size: 3rem;
  }
  @media screen and (max-width: 767px) {
    .faq-item__a::before {
      top: 0.9401709402vw;
      font-size: 5.5555555556vw;
    }
  }
  @media screen and (max-width: 767px) {
    .faq-item__a {
      padding-top: 2.5641025641vw;
    }
  }
  .faq-item__a-inner {
    flex-grow: 1;
    padding-top: 2.125rem;
    line-height: 1.4166666667;
  }
  @media screen and (max-width: 767px) {
    .faq-item__a-inner {
      padding-top: 2.5641025641vw;
    }
  }
  .faq-item__a-inner a {
    text-decoration: underline;
  }
  @media (hover: hover) {
    .faq-item__a-inner a:hover {
      text-decoration: none;
    }
  }
  .faq-item__text + .faq-item__text {
    margin-top: 2.5rem;
  }
  @media screen and (max-width: 767px) {
    .faq-item__text + .faq-item__text {
      margin-top: 4.2735042735vw;
    }
  }
  .faq-item__list {
    margin-left: -1.5rem;
  }
  @media screen and (max-width: 767px) {
    .faq-item__list {
      margin-left: -4.1025641026vw;
    }
  }
  .faq-item__list li {
    position: relative;
    display: grid;
    align-items: flex-start;
    grid-template-columns: 1.125rem 1fr;
    gap: 0.625rem;
    margin-top: 0.2em;
  }
  @media screen and (max-width: 767px) {
    .faq-item__list li {
      grid-template-columns: 2.2222222222vw 1fr;
    }
  }
  .faq-item__list li::before {
    content: "●";
    display: inline-block;
    font-size: 1.125rem;
    position: relative;
    top: -0.1rem;
  }
  @media screen and (max-width: 767px) {
    .faq-item__list li::before {
      top: 0.3418803419vw;
      font-size: 2.5641025641vw;
    }
  }
  .faq-item__note {
    margin-left: -1.5rem;
  }
  @media screen and (max-width: 767px) {
    .faq-item__note {
      margin-left: -4.1025641026vw;
    }
  }
  .faq-item__note p {
    text-indent: -1em;
    margin-left: 1em;
  }
}