/* ==========================================================================
   FAQ page styling — native details/summary accordion
   ========================================================================== */

.faq-hero {
  background: var(--c-fog);
  padding-block: var(--s-16) var(--s-12);
  border-bottom: 1px solid var(--c-mist);
}

.faq-hero__title {
  font-size: var(--fs-h1);
  margin-bottom: var(--s-4);
  max-width: 22ch;
}

.faq-hero__lede {
  font-size: 1.25rem;
  color: var(--c-charcoal);
  max-width: 60ch;
  line-height: var(--lh-relaxed);
}

.faq-toc {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-2);
  margin-top: var(--s-6);
}

.faq-toc a {
  display: inline-block;
  padding: var(--s-2) var(--s-4);
  background: var(--c-paper);
  border: 1px solid var(--c-mist);
  border-radius: 999px;
  text-decoration: none;
  color: var(--c-ink);
  font-size: var(--fs-small);
  font-weight: var(--fw-semibold);
  transition: all var(--motion-fast) var(--easing);
}

.faq-toc a:hover {
  border-color: var(--c-signal);
  background: var(--c-signal-soft);
  color: var(--c-signal-deep);
}

/* Category sections */
.faq-category {
  padding-block: var(--s-12);
  border-bottom: 1px solid var(--c-mist);
}

.faq-category:last-of-type {
  border-bottom: 0;
}

.faq-category__title {
  font-size: var(--fs-h2);
  margin-bottom: var(--s-2);
  scroll-margin-top: 80px;
}

.faq-category__intro {
  color: var(--c-slate);
  margin-bottom: var(--s-8);
  max-width: 60ch;
}

.faq-list {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  max-width: 880px;
}

/* The accordion item — uses native <details> */
.faq-item {
  background: var(--c-paper);
  border: 1px solid var(--c-mist);
  border-radius: var(--radius);
  transition: border-color var(--motion-base) var(--easing);
}

.faq-item:hover {
  border-color: var(--c-slate);
}

.faq-item[open] {
  border-color: var(--c-signal);
  box-shadow: var(--shadow-subtle);
}

.faq-item__q {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-4);
  padding: var(--s-5) var(--s-6);
  cursor: pointer;
  list-style: none;
  font-weight: var(--fw-bold);
  font-size: var(--fs-body);
  color: var(--c-ink);
  user-select: none;
}

/* Hide the default disclosure triangle */
.faq-item__q::-webkit-details-marker {
  display: none;
}
.faq-item__q::marker {
  display: none;
  content: "";
}

.faq-item__icon {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--c-signal-soft);
  color: var(--c-signal);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: var(--fw-bold);
  font-size: 1.125rem;
  line-height: 1;
  transition: transform var(--motion-base) var(--easing);
}

.faq-item[open] .faq-item__icon {
  transform: rotate(45deg);
  background: var(--c-signal);
  color: var(--c-paper);
}

.faq-item__a {
  padding: 0 var(--s-6) var(--s-6);
  color: var(--c-charcoal);
  border-top: 1px solid var(--c-mist);
  margin-top: -1px; /* visually fuse with question on open */
  padding-top: var(--s-5);
}

.faq-item__a p {
  margin-bottom: var(--s-3);
}

.faq-item__a p:last-child {
  margin-bottom: 0;
}

.faq-item__a ul {
  margin: var(--s-2) 0 var(--s-3);
  padding-left: var(--s-5);
}

.faq-item__a li {
  margin-bottom: var(--s-2);
}

/* Pricing table inside FAQ */
.faq-pricing {
  margin: var(--s-4) 0;
  border-collapse: collapse;
  width: 100%;
  font-size: var(--fs-small);
}

.faq-pricing th,
.faq-pricing td {
  padding: var(--s-3) var(--s-4);
  text-align: left;
  border-bottom: 1px solid var(--c-mist);
}

.faq-pricing th {
  background: var(--c-fog);
  font-weight: var(--fw-bold);
  color: var(--c-ink);
  font-size: var(--fs-small);
}

.faq-pricing td:nth-child(2) {
  font-weight: var(--fw-semibold);
  color: var(--c-signal-deep);
  white-space: nowrap;
}

/* Still got a question CTA */
.faq-still-question {
  background: var(--c-fog);
  border-radius: var(--radius);
  padding: var(--s-8);
  text-align: center;
  margin-top: var(--s-12);
}

.faq-still-question h3 {
  font-size: var(--fs-h3);
  margin-bottom: var(--s-3);
}

.faq-still-question p {
  color: var(--c-charcoal);
  max-width: 50ch;
  margin: 0 auto var(--s-5);
}

.faq-still-question__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-3);
  justify-content: center;
}
