/* ====================== Component: FAQ Section ====================== */
.faq { background: var(--color-cream); padding-block: 64px; }
.faq__grid { display: grid; grid-template-columns: 1fr; gap: 48px; }

/* Sidebar */
.faq-aside__rule { width: 48px; height: 1px; background: var(--color-yellow); margin-bottom: 14px; }
.faq-aside__title { font-size: 20px; line-height: 28px; letter-spacing: -0.2px; }
.cat-nav { margin-top: 20px; display: flex; flex-direction: column; }
.cat-link {
  position: relative;
  display: flex;
  align-items: center;
  padding: 9px 0 9px 14px;
  font-size: 14px;
  line-height: 20px;
  color: var(--color-ink);
  border-bottom: 1px solid var(--color-hairline);
  transition: color 0.2s var(--ease), padding-left 0.2s var(--ease);
}
.cat-link::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--color-yellow);
  opacity: 0;
  transition: opacity 0.2s var(--ease);
}
.cat-link:hover { color: #000; }
.cat-link.is-active { font-weight: 600; }
.cat-link.is-active::before { opacity: 1; }

.help-card { margin-top: 28px; background: var(--color-ink); padding: 28px 24px; color: var(--color-white); }
.help-card__rule { width: 24px; height: 1px; background: var(--color-yellow); margin-bottom: 14px; }
.help-card__title { color: var(--color-white); font-size: 16px; line-height: 24px; letter-spacing: -0.16px; }
.help-card__text { margin-top: 12px; font-size: 14px; line-height: 20px; color: rgba(255, 255, 255, 0.6); }
.help-card .btn--small { margin-top: 20px; padding: 10px 16px; font-size: 12px; letter-spacing: 0.72px; gap: 10px; }
.help-card .btn--small img { width: 13px; height: 13px; }

/* Accordion */
.faq-group { scroll-margin-top: 90px; }
.faq-group + .faq-group { margin-top: 48px; }
.faq-group__rule { width: 48px; height: 1px; background: var(--color-yellow); margin-bottom: 16px; }
.faq-group__title { font-size: 24px; line-height: 32px; letter-spacing: -0.24px; margin-bottom: 16px; }

.accordion {
  background: var(--color-white);
  padding-inline: 24px;
  box-shadow: 0 1px 3px rgba(24, 22, 20, 0.06), 0 1px 2px rgba(24, 22, 20, 0.04);
}
.accordion__item { border-bottom: 1px solid var(--color-hairline); }
.accordion__item:last-child { border-bottom: none; }

.accordion__q {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 20px 0;
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  font-family: var(--font-body);
  font-weight: 500;
  font-size: 16px;
  line-height: 22px;
  color: var(--color-ink);
  transition: color 0.2s var(--ease);
}
.accordion__q:hover { color: #000; }
.accordion__chev { width: 18px; height: 18px; flex: none; transition: transform 0.3s var(--ease); }
.accordion__q[aria-expanded="true"] .accordion__chev { transform: rotate(180deg); }

.accordion__panel { display: grid; grid-template-rows: 0fr; transition: grid-template-rows 0.32s var(--ease); }
.accordion__q[aria-expanded="true"] + .accordion__panel { grid-template-rows: 1fr; }
.accordion__panel-inner { overflow: hidden; }
.accordion__answer { padding-bottom: 22px; font-size: 15px; line-height: 24px; color: var(--color-body); max-width: 640px; }
.accordion__answer p { margin: 0; }
.accordion__answer p + p { margin-top: 10px; }

@media (min-width: 768px) {
  .faq { padding-block: 96px; }
}
@media (min-width: 860px) {
  .faq__grid { grid-template-columns: 300px 1fr; gap: 64px; }
  .faq-aside { position: sticky; top: 90px; align-self: start; }
}
