.section--contact-hero {
  padding-top: var(--space-20);
}

.hero--contact {
  align-items: stretch;
}

.hero-text {
  align-self: center;
}

.hero-side {
  align-self: center;
}

.contact-quick-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}

@media (min-width: 768px) {
  .contact-quick-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.contact-layout-grid {
  align-items: flex-start;
  gap: var(--space-8);
}

.contact-details-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.contact-detail-row h3 {
  margin-bottom: var(--space-1);
}

.contact-links-list {
  list-style: none;
  padding-left: 0;
  display: grid;
  gap: var(--space-2);
  font-size: var(--font-size-sm);
}

.contact-links-list a {
  color: var(--color-primary);
}

.business-hours-grid {
  display: grid;
  gap: var(--space-3);
}

.business-hours-grid dt {
  font-weight: 600;
  color: var(--gray-800);
}

.business-hours-grid dd {
  margin: 0;
  color: var(--color-text-muted);
}

.contact-form-grid {
  align-items: flex-start;
  gap: var(--space-8);
}

.contact-form-benefits {
  list-style: disc;
  padding-left: 1.25rem;
  color: var(--color-text-muted);
}

.contact-form {
  font-size: var(--font-size-sm);
}

.form-field--consent {
  font-size: var(--font-size-sm);
}

.form-field--consent .flex {
  align-items: flex-start;
}

.form-field--consent input[type="checkbox"] {
  margin-top: 0.15rem;
}

.contact-form-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-top: var(--space-4);
}

.form-success {
  margin-top: var(--space-4);
  font-size: var(--font-size-sm);
  color: var(--color-success);
}

.consultation-grid {
  align-items: flex-start;
  gap: var(--space-8);
}

.consultation-list {
  list-style: disc;
  padding-left: 1.25rem;
  color: var(--color-text-muted);
}

.consultation-card {
  font-size: var(--font-size-sm);
}

.consultation-actions {
  margin-top: var(--space-4);
}

.faq-container {
  display: grid;
  gap: var(--space-8);
}

.faq-accordion {
  display: grid;
  gap: var(--space-3);
}

.faq-item {
  border-radius: var(--radius-md);
  background-color: #ffffff;
  box-shadow: var(--shadow-sm);
}

.faq-question {
  width: 100%;
  text-align: left;
  padding: var(--space-4) var(--space-5);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  font-size: var(--font-size-md);
  font-weight: 500;
}

.faq-icon {
  width: 1.5rem;
  height: 1.5rem;
  border-radius: 999px;
  border: 1px solid var(--gray-300);
  position: relative;
}

.faq-icon::before,
.faq-icon::after {
  content: "";
  position: absolute;
  background-color: var(--gray-600);
  transition: transform var(--transition-base);
}

.faq-icon::before {
  width: 60%;
  height: 2px;
  top: 50%;
  left: 20%;
  transform: translateY(-50%);
}

.faq-icon::after {
  height: 60%;
  width: 2px;
  left: 50%;
  top: 20%;
  transform: translateX(-50%);
}

.faq-question[aria-expanded="true"] .faq-icon::after {
  transform: translateX(-50%) rotate(90deg);
}

.faq-answer {
  padding: 0 var(--space-5) var(--space-4);
  font-size: var(--font-size-sm);
}

.map-grid {
  align-items: flex-start;
  gap: var(--space-8);
}

.map-card {
  padding: var(--space-4);
}

.map-embed-wrapper {
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: var(--shadow-md);
}

.map-embed-wrapper iframe {
  border: 0;
  width: 100%;
  min-height: 280px;
}

.accessibility-grid {
  align-items: flex-start;
  gap: var(--space-8);
}

.accessibility-list {
  list-style: disc;
  padding-left: 1.25rem;
  color: var(--color-text-muted);
}

.language-card {
  font-size: var(--font-size-sm);
}

.language-dl {
  display: grid;
  gap: var(--space-3);
  margin-top: var(--space-3);
}

.language-dl dt {
  font-weight: 600;
  color: var(--gray-800);
}

.language-dl dd {
  margin: 0;
  color: var(--color-text-muted);
}

.social-grid {
  display: grid;
  grid-template-columns: minmax(0, 2fr) minmax(0, 1.4fr);
  gap: var(--space-8);
  align-items: center;
}

.social-card {
  font-size: var(--font-size-sm);
}

.social-list {
  list-style: none;
  padding-left: 0;
  display: grid;
  gap: var(--space-3);
}

.social-list a {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
}

.social-label {
  font-weight: 600;
  color: var(--gray-800);
}

.social-description {
  color: var(--color-text-muted);
  font-size: var(--font-size-sm);
}

@media (max-width: 960px) {
  .social-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px) {
  .section--contact-hero {
    padding-top: var(--space-16);
  }

  .contact-layout-grid,
  .contact-form-grid,
  .consultation-grid,
  .map-grid,
  .accessibility-grid {
    gap: var(--space-6);
  }

  .faq-question {
    padding: var(--space-3) var(--space-4);
  }

  .faq-answer {
    padding: 0 var(--space-4) var(--space-3);
  }
}
