.faq-hero {
  padding-top: var(--space-32);
  padding-bottom: var(--space-24);
}

.faq-hero__grid {
  align-items: center;
  gap: var(--space-16);
}

.faq-hero__content {
  max-width: 560px;
}

.faq-hero__lead {
  font-size: var(--font-size-lg);
}

.faq-hero__image-wrapper {
  max-width: 520px;
  margin-inline: auto;
}

.faq-hero__image {
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
}

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

.faq-layout {
  align-items: flex-start;
  gap: var(--space-16);
}

.faq-sidebar__card {
  position: sticky;
  top: var(--space-24);
}

.faq-sidebar__nav {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  margin-top: var(--space-8);
}

.faq-chip {
  padding: 0.35rem 0.9rem;
  border-radius: var(--radius-pill);
  border: 1px solid var(--gray-200);
  background-color: #ffffff;
  font-size: var(--font-size-xs);
  cursor: pointer;
  color: var(--gray-700);
  transition: background-color var(--transition-base),
              border-color var(--transition-base),
              color var(--transition-base),
              box-shadow var(--transition-base);
}

.faq-chip:hover {
  background-color: var(--color-primary-soft);
  border-color: var(--color-primary);
  color: var(--color-primary-strong);
}

.faq-chip--active {
  background-color: var(--color-primary);
  border-color: var(--color-primary-strong);
  color: #ffffff;
  box-shadow: var(--shadow-sm);
}

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

.faq-item--with-media {
  display: grid;
  grid-template-columns: minmax(0, 2fr) minmax(0, 1.4fr);
  gap: var(--space-12);
  align-items: center;
}

.faq-item__image {
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
}

.faq-contact-cta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-12);
}

.faq-contact-cta__content {
  max-width: 560px;
}

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

@media (max-width: 960px) {
  .faq-sidebar__card {
    position: static;
  }
}

@media (max-width: 768px) {
  .faq-hero {
    padding-top: var(--space-24);
  }

  .faq-hero__grid {
    gap: var(--space-12);
  }

  .faq-item--with-media {
    grid-template-columns: 1fr;
  }

  .faq-contact-cta {
    align-items: flex-start;
  }
}

@media (max-width: 480px) {
  .faq-hero__lead {
    font-size: var(--font-size-base);
  }

  .faq-sidebar__nav {
    gap: var(--space-2);
  }

  .faq-chip {
    padding-inline: 0.7rem;
  }
}
