/* ─── FAQ Page Styles ─────────────────────────────── */
.faq-page {
  padding: clamp(100px, 12vh, 160px) 0 clamp(60px, 8vh, 100px);
}

.faq-page .container--narrow {
  max-width: 720px;
  margin-inline: auto;
  padding-inline: var(--space-5);
}

.faq-page .section-eyebrow {
  display: block;
  text-align: center;
  margin-bottom: var(--space-2);
}

.faq-page .section-heading {
  text-align: center;
  margin-bottom: var(--space-3);
}

.faq-page__intro {
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--color-text-muted);
  text-align: center;
  line-height: var(--leading-relaxed);
  max-width: 560px;
  margin: 0 auto clamp(40px, 6vh, 64px);
}

/* Category group */
.faq-category {
  margin-bottom: clamp(32px, 5vh, 48px);
}

.faq-category__title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 400;
  color: var(--color-text);
  letter-spacing: 0.02em;
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-2);
  border-bottom: 1px solid var(--color-divider);
}

/* Accordion item */
.faq-item {
  border-bottom: 1px solid var(--color-divider);
}

.faq-item:last-child {
  border-bottom: none;
}

.faq-item__question {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-4);
  width: 100%;
  padding: var(--space-4) 0;
  background: none;
  border: none;
  cursor: pointer;
  font-family: var(--font-body);
  font-size: var(--text-base);
  font-weight: 400;
  color: var(--color-text);
  text-align: left;
  line-height: var(--leading-relaxed);
  letter-spacing: 0.01em;
  transition: color var(--transition-interactive);
}

.faq-item__question:hover {
  color: var(--color-text-muted);
}

.faq-item__icon {
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  position: relative;
  transition: transform 300ms cubic-bezier(0.16, 1, 0.3, 1);
}

.faq-item__icon::before,
.faq-item__icon::after {
  content: '';
  position: absolute;
  background: var(--color-text-faint);
  transition: transform 300ms cubic-bezier(0.16, 1, 0.3, 1), opacity 300ms ease;
}

.faq-item__icon::before {
  /* horizontal bar */
  top: 50%;
  left: 0;
  right: 0;
  height: 1px;
  transform: translateY(-50%);
}

.faq-item__icon::after {
  /* vertical bar */
  left: 50%;
  top: 0;
  bottom: 0;
  width: 1px;
  transform: translateX(-50%);
}

.faq-item.is-open .faq-item__icon::after {
  transform: translateX(-50%) rotate(90deg);
  opacity: 0;
}

.faq-item__answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height 400ms cubic-bezier(0.16, 1, 0.3, 1),
              opacity 300ms ease;
  opacity: 0;
}

.faq-item.is-open .faq-item__answer {
  opacity: 1;
}

.faq-item__answer-inner {
  padding-bottom: var(--space-5);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: var(--leading-relaxed);
}

.faq-item__answer-inner p + p {
  margin-top: var(--space-3);
}

/* CTA at bottom */
.faq-cta {
  text-align: center;
  margin-top: clamp(40px, 6vh, 64px);
  padding-top: clamp(32px, 4vh, 48px);
  border-top: 1px solid var(--color-divider);
}

.faq-cta__text {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 300;
  color: var(--color-text);
  margin-bottom: var(--space-4);
}

.faq-cta__link {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: 400;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  text-decoration: none;
  padding-bottom: 2px;
  border-bottom: 1px solid var(--color-divider);
  transition: color var(--transition-interactive), border-color var(--transition-interactive);
}

.faq-cta__link:hover {
  color: var(--color-text);
  border-color: var(--color-text);
}
