/* FAQ page */

.faq-hero { padding: 8rem 3rem 4rem; text-align: center; background: var(--warm-white); }
.faq-hero h1 { font-family: 'Playfair Display', serif; font-size: clamp(2.4rem, 5vw, 3.8rem); color: var(--forest); margin-bottom: 0.8rem; }
.faq-hero p { font-size: 1.1rem; color: var(--earth); font-weight: 300; }

.faq-body { max-width: 780px; margin: 0 auto; padding: 3rem 3rem 5rem; }

.faq-group { margin-bottom: 3rem; }
.faq-group h2 { font-family: 'Playfair Display', serif; font-size: 1.5rem; color: var(--forest); margin-bottom: 1rem; padding-bottom: 0.6rem; border-bottom: 2px solid var(--light-sage); }

details.faq-item { border: 1.5px solid var(--border); border-radius: 12px; margin-bottom: 0.6rem; overflow: hidden; transition: border-color 0.15s; }
details.faq-item[open] { border-color: var(--sage); }

summary.faq-q { list-style: none; display: flex; justify-content: space-between; align-items: center; gap: 1rem; padding: 1.1rem 1.25rem; font-weight: 500; font-size: 0.95rem; color: var(--forest); cursor: pointer; user-select: none; }
summary.faq-q::-webkit-details-marker { display: none; }
summary.faq-q::after { content: '+'; font-size: 1.2rem; font-weight: 300; color: var(--sage); flex-shrink: 0; transition: transform var(--dur-fast); }
details.faq-item[open] summary.faq-q::after { transform: rotate(45deg); }
summary.faq-q:hover { background: var(--light-sage); }

.faq-a { padding: 0 1.25rem 1.25rem; font-size: 0.9rem; font-weight: 300; line-height: 1.75; color: var(--charcoal); opacity: 0.75; animation: faq-open 0.18s ease-out; }

@keyframes faq-open {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 0.75; transform: translateY(0); }
}

/* Responsive */
@media (max-width: 768px) {
  .faq-hero { padding: 7rem 1.5rem 3rem; }
  .faq-body { padding: 2rem 1.5rem 4rem; }
}

@media (max-width: 480px) {
  .faq-hero { padding: 6.5rem 1rem 2.5rem; }
  .faq-body { padding: 1.5rem 1rem 3rem; }
  summary.faq-q { font-size: 0.88rem; }
}
