.faq-hero-grid {
  align-items: center;
}

.faq-hero-media-wrapper {
  display: flex;
  justify-content: center;
}

.faq-hero-media {
  max-width: 460px;
}

.small-caption {
  margin-top: var(--space-8);
  font-size: var(--font-size-xs);
}

.faq-intro {
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
}

.faq-layout {
  display: grid;
  grid-template-columns: minmax(0, 2.2fr) minmax(0, 1fr);
  gap: var(--space-32);
  margin-top: var(--space-32);
}

.faq-items {
  display: flex;
  flex-direction: column;
  gap: var(--space-16);
}

.faq-item summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-16);
}

.faq-item summary::after {
  content: "+";
  font-size: var(--font-size-lg);
  color: var(--color-text-muted);
  flex-shrink: 0;
}

.faq-item[open] summary::after {
  content: "−";
}

.faq-sidebar-card h3 {
  margin-bottom: var(--space-12);
}

.faq-sidebar-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-12);
  font-size: var(--font-size-sm);
}

.faq-sidebar-list li strong {
  display: block;
  color: var(--color-text);
}

.faq-sidebar-list li span {
  color: var(--color-text-muted);
}

.faq-booking-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(0, 1.7fr);
  gap: var(--space-24);
  margin-top: var(--space-16);
}

.faq-booking-steps .step p {
  margin-bottom: 0;
}

.faq-location-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(0, 1.5fr);
  gap: var(--space-24);
  margin-top: var(--space-16);
}

.faq-contact-inline {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-12);
  margin-top: var(--space-12);
}

.faq-cta-section {
  padding-top: var(--space-40);
}

.faq-bottom-cta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-24);
}

.faq-bottom-cta-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-12);
}

@media (max-width: 1024px) {
  .faq-layout {
    grid-template-columns: minmax(0, 1fr);
  }

  .faq-sidebar {
    order: -1;
  }

  .faq-booking-grid,
  .faq-location-grid {
    grid-template-columns: minmax(0, 1fr);
  }
}

@media (max-width: 768px) {
  .faq-bottom-cta {
    flex-direction: column;
    align-items: flex-start;
  }

  .faq-hero-media {
    max-width: 360px;
  }
}

@media (max-width: 640px) {
  .faq-item summary {
    font-size: var(--font-size-sm);
  }
}
