/* ── FAQ accordion ── */
.m-faq { padding: 24px 64px 96px; max-width: 900px; margin: 0 auto; }
.m-faq__item { border-top: 1px solid var(--rule); }
.m-faq__item:last-of-type { border-bottom: 1px solid var(--rule); }
.m-faq__q {
  display: grid;
  grid-template-columns: 48px 1fr 32px;
  gap: 20px;
  align-items: baseline;
  width: 100%;
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  padding: 28px 0;
  font-family: inherit;
}
.m-faq__num {
  font-family: var(--serif);
  font-style: italic;
  font-size: 20px;
  color: var(--gold-deep);
}
.m-faq__qtext {
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(20px, 2vw, 26px);
  line-height: 1.25;
  color: var(--burgundy);
  letter-spacing: -0.01em;
}
.m-faq__sign {
  position: relative;
  width: 18px;
  height: 18px;
  align-self: center;
  justify-self: end;
}
.m-faq__sign::before,
.m-faq__sign::after {
  content: '';
  position: absolute;
  background: var(--gold-deep);
  transition: transform 240ms ease, opacity 240ms ease;
}
.m-faq__sign::before { left: 0; top: 8px; width: 18px; height: 1.5px; }
.m-faq__sign::after { left: 8px; top: 0; width: 1.5px; height: 18px; }
.m-faq__item.is-open .m-faq__sign::after { transform: scaleY(0); opacity: 0; }

.m-faq__a {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 300ms ease;
}
.m-faq__item.is-open .m-faq__a { grid-template-rows: 1fr; }
.m-faq__a > p {
  overflow: hidden;
  margin: 0;
  padding-left: 68px;
  font-family: var(--sans);
  font-weight: 300;
  font-size: 17px;
  line-height: 1.75;
  color: var(--ink);
  max-width: 66ch;
}
.m-faq__item.is-open .m-faq__a > p { padding-bottom: 32px; }

@media (max-width: 760px) {
  .m-faq { padding: 48px 28px 64px; }
  .m-faq__q { grid-template-columns: 32px 1fr 24px; gap: 14px; }
  .m-faq__a > p { padding-left: 0; }
}
