/* RealmOfMedieval – faq.css (page-specific styles) */
.faq-breadcrumbs {
  font-size: var(--font-size-sm);
  margin: var(--space-4) 0 var(--space-6) 0;
}
.faq-breadcrumbs ol {
  display: flex;
  gap: var(--space-2);
  list-style: none;
  flex-wrap: wrap;
}
.faq-breadcrumbs li:not(:last-child)::after {
  content: '›';
  color: var(--color-primary);
  margin: 0 var(--space-2);
  font-family: var(--font-family-display);
}

.faq-hero {
  margin-bottom: var(--space-8);
  padding: var(--space-8) var(--space-4);
  background: linear-gradient(96deg, var(--gray-100) 94%, var(--gray-300) 100%);
  box-shadow: 0 0 0 2px var(--color-primary);
  text-align: center;
}
.faq-hero h1 {
  margin-top: 0;
  margin-bottom: var(--space-3);
}
.faq-hero p {
  font-size: var(--font-size-lg);
  max-width: 52ch;
  margin-left: auto;
  margin-right: auto;
}
.faq-hero .button {
  margin-left: var(--space-2);
  margin-top: var(--space-1);
  font-size: var(--font-size-base);
  padding: 6px 20px;
  display: block;
}

.faq-nav {
  margin: var(--space-4) 0;
  text-align: center;
}
.faq-nav ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-2) var(--space-4);
}
.faq-nav a {
  font-family: var(--font-family-display);
  color: var(--color-primary);
  padding: 6px 18px;
  border-radius: var(--radius-sm);
  background: var(--gray-50);
  border: 1.5px solid var(--gray-200);
  text-decoration: none;
  font-size: var(--font-size-base);
  transition: box-shadow var(--transition-fast), color var(--transition-base);
  box-shadow: 0 1px 4px rgba(163, 112, 40, 0.02);
}
.faq-nav a:hover, .faq-nav a:focus-visible {
  background: var(--color-primary);
  color: #fff;
}

.faq-section {
  background: var(--color-surface);
  margin-bottom: var(--space-8);
  border-radius: var(--radius-xl);
  box-shadow: 0 2px 18px rgba(93,53,20,.08);
  padding: var(--space-8) var(--space-4);
  border: 2.5px double var(--color-primary);
}
.faq-section:not(:first-child) {
  margin-top: var(--space-10);
}
.faq-section h2 {
  margin-top: 0;
  margin-bottom: var(--space-6);
  font-size: var(--font-size-xl);
  color: var(--color-primary);
}
.faq-list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-6) var(--space-16);
}
.faq-list details {
  background: var(--gray-50);
  border: 2px solid var(--gray-200);
  border-radius: var(--radius-base);
  box-shadow: var(--shadow-sm);
  margin-bottom: var(--space-2);
  padding: var(--space-4) var(--space-4) var(--space-3) var(--space-4);
  transition: box-shadow var(--transition-fast);
  position: relative;
}
.faq-list details[open] {
  box-shadow: var(--shadow-lg);
  border-color: var(--color-primary);
}
.faq-list summary {
  font-family: var(--font-family-display);
  font-size: var(--font-size-lg);
  color: var(--color-primary);
  cursor: pointer;
  outline: none;
  display: list-item;
  list-style: none;
}
.faq-list details[open] summary {
  color: var(--color-success);
}
.faq-list details > div {
  margin-top: var(--space-3);
  font-family: var(--font-family-serif);
  font-size: var(--font-size-base);
  color: var(--color-text);
  animation: fadeInFaq 320ms cubic-bezier(0.14,0.68,0.6,1.0);
}
@keyframes fadeInFaq {
  from { opacity:0; transform: translateY(-12px); }
  to   { opacity:1; transform: none; }
}
/* Responsive – stack columns on mobile */
@media (max-width: 870px) {
  .faq-list {
    grid-template-columns: 1fr;
  }
  .faq-section {
    padding: var(--space-6) var(--space-2);
  }
}
@media (max-width: 600px) {
  .faq-hero {
    padding: var(--space-6) var(--space-1);
  }
  .faq-section {
    padding: var(--space-4) var(--space-1);
  }
  .faq-section h2 {
    font-size: var(--font-size-lg);
  }
  .faq-nav ul {
    gap: var(--space-1);
  }
}
/* Highlight style for anchor jumps (after clicking nav) */
:target.faq-section {
  box-shadow: 0 0 0 3px var(--color-success), 0 2px 18px rgba(93,53,20,0.06);
}

.faq-list a {
  color: var(--color-success);
  text-decoration: underline;
  text-underline-offset: 3px;
  font-weight: 500;
}
