.faq-hero {
  position: relative;
}

.faq-hero__inner {
  align-items: center;
  gap: var(--space-8);
}

.faq-hero__text {
  max-width: 40rem;
}

.faq-hero__media {
  max-width: 28rem;
  margin-inline: auto;
}

.faq-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 2fr);
  gap: var(--space-8);
}

.faq-sidebar {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.faq-sidebar__title {
  font-size: var(--font-size-md);
}

.faq-sidebar__nav ul {
  list-style: none;
}

.faq-sidebar__nav a {
  display: block;
  padding-block: 0.45rem;
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  border-left: 2px solid transparent;
  padding-left: var(--space-3);
  transition: color var(--transition-base), border-color var(--transition-base), background-color var(--transition-base);
}

.faq-sidebar__nav a:hover,
.faq-sidebar__nav a:focus-visible {
  color: var(--color-primary);
  border-color: var(--color-primary);
  background-color: var(--color-background-soft);
}

.faq-sidebar__cta {
  margin-top: var(--space-2);
}

.faq-content {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.faq-item__header {
  margin-bottom: var(--space-2);
}

.faq-item__question {
  font-size: var(--font-size-xl);
}

.faq-item__body {
  font-size: var(--font-size-sm);
}

.faq-item__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
  gap: var(--space-5);
  align-items: center;
}

.faq-item__media {
  max-width: 22rem;
  margin-inline: auto;
}

.faq-item__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-top: var(--space-3);
}

.faq-contact-cta__body {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.faq-contact-cta__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}

@media (max-width: 991px) {
  .faq-layout {
    grid-template-columns: minmax(0, 1fr);
  }

  .faq-sidebar {
    order: 2;
  }

  .faq-content {
    order: 1;
  }
}

@media (max-width: 767px) {
  .faq-hero__inner {
    grid-template-columns: minmax(0, 1fr);
  }

  .faq-hero__media {
    max-width: 20rem;
    margin-top: var(--space-4);
  }

  .faq-item__grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .faq-item__media {
    max-width: 100%;
  }
}
