.faq {
  background: var(--paper);
}
.faq__head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.4fr);
  gap: var(--space-6);
  align-items: end;
  margin-bottom: var(--space-7);
}
@media (max-width: 820px) { .faq__head { grid-template-columns: 1fr; } }
.faq__title {
  font-size: var(--text-3xl);
  letter-spacing: -0.03em;
}
.faq__aside {
  color: var(--ink-70);
  font-size: var(--text-sm);
  max-width: 48ch;
  line-height: 1.65;
}

.faq__list {
  border-top: 1px solid var(--line);
}
.faq-item {
  border-bottom: 1px solid var(--line);
  background: transparent;
}
.faq-item__trigger {
  width: 100%;
  display: grid;
  grid-template-columns: 48px 1fr 40px;
  gap: var(--space-4);
  align-items: baseline;
  padding: var(--space-5) 0;
  text-align: left;
  color: var(--ink);
  transition: color var(--duration-fast) var(--ease-out-expo);
}
.faq-item__trigger:hover { color: var(--amber); }
.faq-item__trigger .num {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  letter-spacing: 0.14em;
  color: var(--amber);
}
.faq-item__trigger h3 {
  font-family: var(--font-serif);
  font-size: var(--text-lg);
  letter-spacing: -0.015em;
  font-weight: 500;
  color: inherit;
}
.faq-item__icon {
  justify-self: end;
  width: 28px;
  height: 28px;
  position: relative;
  transition: transform var(--duration-base) var(--ease-out-expo);
}
.faq-item__icon::before,
.faq-item__icon::after {
  content: "";
  position: absolute;
  top: 50%; left: 50%;
  background: var(--ink);
  transition: opacity var(--duration-fast) var(--ease-out-expo), background var(--duration-fast) var(--ease-out-expo);
}
.faq-item__icon::before { width: 14px; height: 1px; transform: translate(-50%, -50%); }
.faq-item__icon::after { width: 1px; height: 14px; transform: translate(-50%, -50%); }
.faq-item[open] .faq-item__icon::after { opacity: 0; }
.faq-item[open] .faq-item__icon { transform: rotate(180deg); }

.faq-item__body {
  display: grid;
  grid-template-columns: 48px 1fr 40px;
  gap: var(--space-4);
  padding-bottom: var(--space-6);
}
.faq-item__body p {
  grid-column: 2;
  color: var(--ink-70);
  font-size: var(--text-sm);
  line-height: 1.75;
  max-width: 60ch;
}
.faq-item[open] .faq-item__trigger { color: var(--amber); }
.faq-item[open] .faq-item__icon::before { background: var(--amber); }

/* Hide default marker (details) */
.faq-item summary { list-style: none; }
.faq-item summary::-webkit-details-marker { display: none; }
