@charset "utf-8";

.ttl-wrap {
  padding-top: 100px;
}

ul.categories {
  display: flex;
  max-width: 541px;
  margin-top: 30px;
  font-size: 18px;
  flex-wrap: wrap;
  column-gap: 20px;
  row-gap: 20px;
}

ul:nth-of-type(2).categories {
  margin-top: 20px;
}

ul.categories a {
  padding-inline: 5px;
  letter-spacing: 2px;
}

.cate-link.hidden {
  visibility: hidden;
}

.faq-ttl {
  margin-bottom: 20px;
  padding-bottom: 20px;
  font-size: 18px;
  font-weight: 400;
  border-bottom: 2px solid var(--primary-border-color);
}

.faq-content .faq-item {
  background-color: #f1f1f1;
  padding-inline: 20px;
}

.faq-content .faq-list .btn-faq {
  display: flex;
  position: relative;
  width: 100%;
  border: none;
  text-align: start;
  gap: 15px;
  appearance: none;
  background-color: transparent;
  padding-inline: unset;
  padding-block: 23px;
  align-items: center;
}

.faq-content .faq-list li+li {
  margin-top: 10px;
}

.faq-blk {
  padding-top: 100px;
}

#join.faq-blk {
  padding-top: 40px;
  scroll-margin-top: 80px;
}

.faq-content .faq-question .plus-icon {
  display: block;
  position: relative;
  min-width: 15px;
  margin-left: auto;
  aspect-ratio: 1;
}

.faq-content .faq-question .faq-q,
.faq-answer-inner .faq-a {
  font-family: var(--font-quaternary);
  font-size: 18px;
  font-weight: 500;
  align-self: flex-start;
}

.faq-content .faq-question .question {
  line-height: 2;
  font-weight: 400;
}

.faq-content .faq-question .plus-icon::before,
.faq-content .faq-question .plus-icon::after {
  display: block;
  position: absolute;
  margin: auto;
  background: var(--clr-neutral-900);
  content: "";
  inset: 0;
  transform-origin: center;
  transition: transform .4s;
}

.faq-content .faq-question .plus-icon:before {
  width: 100%;
  height: 1.5px;
}

.faq-content .faq-question .plus-icon:after {
  width: 1.5px;
  height: 100%;
}

.faq-content .faq-list .faq-answer {
  border-top: 1px solid var(--clr-border-500);
  padding-block: 40px;
}

.faq-content .faq-list .faq-answer p+p {
  margin-top: 27px;
}

.faq-content .faq-list .faq-answer-inner {
  display: flex;
  gap: 12px;
}

.btn-faq[aria-expanded="true"] .plus-icon::before,
.btn-faq[aria-expanded="true"] .plus-icon::after {
  transform: rotate(180deg);
}

.btn-faq[aria-expanded="true"] .plus-icon::after {
  opacity: 0;
  transition: opacity .2s .2s, transform .4s;
}

.faq-btn-wrap {
  display: flex;
  width: 100%;
  justify-content: space-between;
}

.faq-btn-wrap button {
  padding: 15px 30px;
  border-radius: 4px;
  background: var(--clr-neutral-900);
  color: var(--clr-neutral-100);
  font-weight: 500;
  font-size: 16px;
}

.faq-btn-wrap button:hover {
  background-color: var(--clr-neutral-100);
  color: var(--clr-neutral-900);
}

@media (max-width: 768px) {
  .sm-pt-40 {
    padding-top: 40px;
  }

  .sm-pt-50 {
    padding-top: 50px;
  }

  ul.categories {
    margin-top: 55px;
    flex-direction: column;
  }

  .categories li a.cate-link:hover, .categories li a.cate-link.active:hover {
    opacity: 1;
  }

  .cate-link.hidden {
    display: none;
  }

  .faq-content .faq-list .btn-faq {
    padding-block: 20px;
  }

  .faq-blk {
    padding-top: 50px;
  }

  .has-side-column {
    gap: 40px;
  }

  .faq-blk {
    scroll-margin-top: 20px;
  }

  #join.faq-blk {
    padding-top: 50px;
    scroll-margin-top: 50px;
  }

  .faq-content .faq-question .question {
    padding-right: 10px;
  }

  .faq-btn-wrap {
    flex-direction: column;
    row-gap: 30px;
  }
}
