/* ==========================================================================
   PATH: /css/faq.css
   TYPE: stylesheet
   STATUS: shared
   USES: reusable FAQ accordions across homepage, FAQ page, support pages,
         and canonical city-page FAQ sections

   PURPOSE
   This file owns the FAQ component system used for:
   - homepage FAQ preview
   - dedicated FAQ page
   - support pages reusing grouped FAQ blocks
   - canonical city-page dark-band FAQ accordions

   KEEP IN THIS FILE
   - .faq-list base accordion styles
   - .faq-list--dark dark-theme FAQ variant
   - .faq-heading grouped FAQ section heading
   - .faq-list--cards boxed FAQ-page / support-page card layout
   - .faq-list--lined city-page dark accordion variant
   - FAQ summary / details / paragraph internals
   - shared responsive behavior for FAQ modules

   DO NOT PUT IN THIS FILE
   - outer section shell layout like .faq-grid
   - intro-column spacing like .faq-intro
   - broad band spacing or section padding
   - page-only copy spacing tweaks
   - unrelated support-page layout wrappers

   OWNERSHIP NOTES
   - If the selector styles the accordion itself, it belongs here.
   - If the selector positions the intro column beside the FAQ block, it belongs
     in bands.css.
   - If a page needs a one-off FAQ presentation, add a modifier or page override
     rather than editing the base module.
   ========================================================================== */

/* ==========================================================================
   BASE FAQ LIST
   Default lighter FAQ accordion used on the homepage and similar light-band
   preview sections.
   ========================================================================== */

.faq-list {
  display: grid;
  gap: 0.8rem;
  padding: 0 0 1rem;
}

.faq-list details {
  border-top: 1px solid var(--line-dark);
  padding-top: 1rem;
  padding-bottom: 0.2rem;
}

.faq-list summary {
  position: relative;
  padding-right: 2rem;
  list-style: none;
  cursor: pointer;
  color: var(--text-dark);
  font-family: var(--font-display);
  font-size: var(--type-heading-sm);
  font-weight: 400;
  line-height: 1.06;
}

.faq-list summary::-webkit-details-marker {
  display: none;
}

.faq-list summary::after {
  content: "+";
  position: absolute;
  right: 0;
  top: 0;
  color: var(--gold);
  font-family: var(--font-body);
  font-size: var(--type-body-size);
  line-height: 1;
}

.faq-list details[open] summary::after {
  content: "–";
}

.faq-list p {
  margin-top: 0.7rem;
  max-width: var(--measure-copy);
  color: var(--muted-dark);
  font-size: var(--type-body-size);
  line-height: var(--type-body-line-loose);
}

/* ==========================================================================
   DARK FAQ VARIANT
   Shared dark treatment for FAQ blocks placed on dark bands.
   ========================================================================== */

.faq-list--dark {
  border-bottom: 1px solid var(--line-light);
}

.faq-list--dark details {
  border-top: 1px solid var(--line-light);
}

.faq-list--dark summary {
  color: var(--text-light);
}

.faq-list--dark p {
  color: var(--muted-light);
}

.faq-list--dark summary::after {
  color: var(--gold-light);
}

/* ==========================================================================
   GROUPED FAQ PAGE VARIANT
   Dedicated FAQ and support-page version with headings plus boxed FAQ cards in
   a two-column grid on larger screens.
   ========================================================================== */

.faq-heading {
  grid-column: 1 / -1;
  margin: 1.4rem 0 0.15rem;
  padding-top: 1.1rem;
  border-top: 1px solid var(--line-dark);
  color: var(--muted-dark);
  font-family: var(--font-body);
  font-size: var(--type-label-size);
  font-weight: 700;
  letter-spacing: var(--type-label-tracking);
  line-height: 1;
  text-transform: uppercase;
}

.faq-heading:first-child {
  margin-top: 0;
  padding-top: 0;
  border-top: 0;
}

.faq-list--cards {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  column-gap: 1rem;
  row-gap: 1rem;
  align-content: start;
  padding: 0 0 1rem;
}

.faq-list--cards details {
  padding: 0;
  border: 1px solid var(--line-dark);
  background: rgba(255, 255, 255, 0.44);
  transition:
    background 180ms ease,
    border-color 180ms ease,
    box-shadow 180ms ease,
    transform 180ms ease;
}

.faq-list--cards details:hover {
  background: rgba(255, 255, 255, 0.68);
  border-color: rgba(34, 30, 25, 0.18);
}

.faq-list--cards details[open] {
  background: rgba(255, 255, 255, 0.78);
  border-color: rgba(198, 164, 109, 0.45);
  box-shadow: 0 14px 28px rgba(0, 0, 0, 0.05);
}

.faq-list--cards summary {
  position: relative;
  padding: 1.15rem 3.2rem 1.05rem 1.15rem;
  list-style: none;
  cursor: pointer;
  color: var(--text-dark);
  font-family: var(--font-display);
  font-size: var(--type-heading-sm);
  font-weight: 500;
  line-height: 1.06;
}

.faq-list--cards summary::-webkit-details-marker {
  display: none;
}

.faq-list--cards summary::after {
  content: "+";
  position: absolute;
  right: 1.05rem;
  top: 1.1rem;
  display: grid;
  place-items: center;
  width: 1.5rem;
  height: 1.5rem;
  border: 1px solid var(--gold-line-strong);
  color: var(--gold);
  font-family: var(--font-body);
  font-size: 0.95rem;
  line-height: 1;
}

.faq-list--cards details[open] summary::after {
  content: "–";
}

.faq-list--cards p {
  margin: 0;
  padding: 0 1.15rem 1.15rem;
  max-width: 42ch;
  color: var(--muted-dark);
  font-size: var(--type-body-size-sm);
  line-height: var(--type-body-line-loose);
}

/* ==========================================================================
   CITY-PAGE LINED VARIANT
   Shared lined-row FAQ treatment for dark city-page sections.
   ========================================================================== */

.faq-list--lined {
  display: grid;
  gap: 0;
}

.faq-list--lined details {
  border-top: 1px solid rgba(243, 239, 232, 0.16);
}

.faq-list--lined details:last-child {
  border-bottom: 1px solid rgba(243, 239, 232, 0.16);
}

.faq-list--lined summary {
  position: relative;
  padding: 22px 34px 22px 0;
  list-style: none;
  cursor: pointer;
  color: var(--text-light);
  font-family: var(--font-display);
  font-size: var(--type-heading-sm);
  font-weight: 500;
  line-height: 1.06;
}

.faq-list--lined summary::-webkit-details-marker {
  display: none;
}

.faq-list--lined summary::after {
  content: "+";
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  color: rgba(243, 239, 232, 0.82);
  font-family: var(--font-body);
  font-size: 1.2rem;
  line-height: 1;
  transition: transform 0.2s ease;
}

.faq-list--lined details[open] summary::after {
  transform: translateY(-50%) rotate(45deg);
}

.faq-list--lined p {
  margin: 0;
  padding: 0 34px 22px 0;
  max-width: var(--measure-copy-wide);
  color: rgba(243, 239, 232, 0.76);
  font-size: var(--type-body-size);
  line-height: var(--type-body-line-loose);
}

/* ==========================================================================
   RESPONSIVE BEHAVIOR
   ========================================================================== */

@media (max-width: 979px) {
  .faq-list--cards {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767px) {
  .faq-heading {
    margin-top: 1.15rem;
    padding-top: 0.95rem;
    font-size: var(--type-label-size-sm);
  }

  .faq-list summary,
  .faq-list--cards summary,
  .faq-list--lined summary {
    font-size: 1.35rem;
  }

  .faq-list--cards summary {
    padding: 1rem 2.9rem 0.95rem 1rem;
  }

  .faq-list--cards summary::after {
    top: 0.95rem;
    right: 0.9rem;
    width: 1.4rem;
    height: 1.4rem;
  }

  .faq-list--cards p {
    padding: 0 1rem 1rem;
    font-size: 0.93rem;
  }

  .faq-list--lined summary {
    padding: 20px 30px 20px 0;
  }

  .faq-list--lined p {
    padding: 0 30px 20px 0;
    font-size: var(--type-body-size-sm);
  }
}