.faq {
  padding-block: 4rem 8rem;
}

.faq__list {
  display: grid;
  gap: 1.6rem;
}

.faq__item {
  border: 1px solid var(--colorMain);
}

.faq__heading, .faq__answer {
  align-items: baseline;
  display: grid;
  gap: 0.8rem;
  width: 100%;
}

.faq__headingText, .faq__text {
  font-size: 1.8rem;
  position: relative;
  text-align: start;
  top: -0.3em;
}

.faq__heading {
  background: var(--colorMain);
  color: var(--colorWhite);
  font-weight: 700;
  grid-template-columns: 5.1rem auto 2.4rem;
  padding: 0.8rem 2rem 0.8rem 4rem;
}

.faq__headingQ, .faq__textA {
  font-size: 3rem;
}

.faq__textA {
  color: var(--colorMain);
  font-weight: 700;
}

.faq__answer {
  grid-template-columns: 5.1rem auto;
  padding: 1.6rem 2rem 1.6rem 4rem;
}

.faq__icon {
  display: block;
  height: 1.4rem;
  place-self: center;
  position: relative;
  transform: rotate(90deg);
  width: 1.4rem;
}

.faq__iconBar {
  background: var(--colorWhite);
  display: block;
  height: 100%;
  left: 50%;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  transition: transform 0.15s ease-out;
  width: 0.125rem;
}

.js-accordHeading {
  cursor: pointer;
}

.js-accordBody {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease-out;
}

.js-moveableIcon {
  transform: translate(-50%, -50%) rotate(90deg);
}

@media (max-width: 767px) {
  .faq {
    padding-block: 2.4rem 4rem;
  }

  .faq__heading, .faq__answer {
    padding: 0.8rem 1rem 0.8rem 1rem;
  }

  .faq__headingQ, .faq__textA {
    font-size: 2rem;
  }

  .faq__heading {
    grid-template-columns: 3rem auto 2.4rem;
  }

  .faq__answer {
    grid-template-columns: 3rem auto;
  }

  .faq__headingText, .faq__text {
    font-size: 1.6rem;
    top: -0.1em;
  }
}
