/* =========================================
   FAQ PAGE
   ========================================= */

.p-faq {
  background: var(--color-bg-white);
}

.p-faq__content {
  padding: 120px 0;
}

.p-faq__heading {
  margin-bottom: 72px;
}

.p-faq__heading .c-section-heading__ja {
  font-size: var(--font-size-5xl);
  letter-spacing: 0.08em;
}

.p-faq__tabs {
  display: flex;
  justify-content: center;
  margin-bottom: 64px;
}

.p-faq__tabs .c-tab-nav__list {
  justify-content: center;
  row-gap: 12px;
}

.p-faq__tabs .c-tab-nav__btn {
  min-height: 40px;
  padding: 8px 32px;
  font-size: var(--font-size-base);
  position: relative;
}

.p-faq__tabs .c-tab-nav__item:first-child .c-tab-nav__btn {
  padding-left: 0;
}

.p-faq__tabs .c-tab-nav__item:not(:first-child) .c-tab-nav__btn {
  border-left: none;
}

.p-faq__tabs .c-tab-nav__item:not(:first-child) .c-tab-nav__btn::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  width: 1px;
  height: 1.1em;
  background: var(--color-text-dark);
  transform: translateY(-50%);
}

.p-faq__tabs .c-tab-nav__btn[aria-selected="true"] {
  color: var(--color-accent);
}

.p-faq__panel {
  display: none;
}

.p-faq__panel.is-active {
  display: block;
}

.p-faq__list {
  max-width: 880px;
  margin: 0 auto;
}

.p-faq__list .c-faq-item {
  border-bottom: none;
}

.p-faq__list .c-faq-item__question {
  padding: 18px 0;
  gap: 16px;
  font-weight: var(--font-weight-bold);
}

.p-faq__list .c-faq-item__label {
  width: 24px;
  color: var(--color-text);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-black);
}

.p-faq__list .c-faq-item__question-text {
  color: var(--color-text);
}

.p-faq__list .c-faq-item__answer-inner {
  padding: 0 48px 24px 40px;
  font-weight: var(--font-weight-medium);
}

.p-faq__list .c-faq-item__toggle {
  width: 40px;
  height: 40px;
}

.p-faq__list .c-faq-item__toggle-icon {
  width: 18px;
  height: 18px;
}

.p-faq__list .c-faq-item__toggle-icon::before,
.p-faq__list .c-faq-item__toggle-icon::after {
  background: var(--color-text-dark);
}

.p-faq__list .c-faq-item__toggle-icon::before {
  width: 4px;
}

.p-faq__list .c-faq-item__toggle-icon::after {
  height: 4px;
}

@media (max-width: 1100px) {
  .p-faq__tabs .c-tab-nav__btn {
    padding: 8px 16px;
    font-size: var(--font-size-sm);
  }
}

@media (max-width: 1024px) {
  .p-faq-page .l-footer__links-list {
    width: auto;
    max-width: 100%;
  }

  .p-faq__content {
    padding: 80px 0 96px;
  }

  .p-faq__heading {
    margin-bottom: 48px;
  }

  .p-faq__heading .c-section-heading__ja {
    font-size: var(--font-size-3xl);
  }

  .p-faq__tabs {
    margin-bottom: 48px;
  }

}

@media (max-width: 900px) and (min-width: 768px) {
  .p-faq__tabs .c-tab-nav__btn {
    padding: 8px 12px;
    font-size: 13px;
  }
}

@media (max-width: 767px) {
  .p-faq__content {
    padding: 56px 0 72px;
  }

  .p-faq__heading {
    margin-bottom: 32px;
  }

  .p-faq__heading .c-section-heading__ja {
    font-size: 28px;
  }

  .p-faq__tabs {
    justify-content: flex-start;
    margin-bottom: 32px;
  }

  .p-faq__tabs .c-tab-nav__list {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    gap: 6px 22px;
    width: 100%;
    padding-bottom: 0;
    overflow-x: visible;
  }

  .p-faq__tabs .c-tab-nav__item {
    min-width: 0;
    width: auto;
  }

  .p-faq__tabs .c-tab-nav__btn {
    justify-content: center;
    width: auto;
    min-height: 36px;
    padding: 4px 0;
    font-size: var(--font-size-sm);
    line-height: var(--line-height-tight);
    white-space: nowrap;
    text-align: center;
  }

  .p-faq__tabs .c-tab-nav__item:first-child .c-tab-nav__btn {
    padding-left: 0;
  }

  .p-faq__tabs .c-tab-nav__item .c-tab-nav__btn::before,
  .p-faq__tabs .c-tab-nav__item:nth-child(odd) .c-tab-nav__btn::before,
  .p-faq__tabs .c-tab-nav__item:nth-child(even) .c-tab-nav__btn::before {
    display: none;
  }

  .p-faq__list .c-faq-item__question {
    align-items: flex-start;
    gap: 12px;
    padding: 16px 0;
    line-height: var(--line-height-normal);
  }

  .p-faq__list .c-faq-item__label {
    width: 32px;
    line-height: var(--line-height-normal);
  }

  .p-faq__list .c-faq-item__question-text {
    line-height: var(--line-height-normal);
  }

  .p-faq__list .c-faq-item__toggle {
    width: 32px;
    height: 32px;
    margin-top: -4px;
  }

  .p-faq__list .c-faq-item__answer-inner {
    padding: 0 0 20px 44px;
    font-size: var(--font-size-base);
  }
}
