.contact-hero-inner {
  display: grid;
  grid-template-columns: minmax(0, 3fr) minmax(0, 2.4fr);
  gap: var(--space-8);
  align-items: center;
}

.contact-hero-text {
  max-width: 620px;
}

.contact-hero-lead {
  margin-top: var(--space-4);
}

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

.contact-hero-highlight {
  padding: var(--space-6);
}

.contact-hero-subtitle {
  font-size: var(--font-size-lg);
  margin-bottom: var(--space-3);
}

.contact-hero-list {
  margin-top: var(--space-4);
  display: grid;
  gap: var(--space-2);
  font-size: var(--font-size-sm);
  color: var(--color-text-soft);
}

.contact-section-header {
  max-width: 720px;
  margin-bottom: var(--space-8);
}

.contact-section-header h2 {
  margin-bottom: var(--space-3);
}

.contact-details-grid {
  gap: var(--space-6);
}

.contact-card {
  height: 100%;
}

.contact-card-title {
  font-size: var(--font-size-xl);
  margin-bottom: var(--space-3);
}

.contact-social-list {
  margin-top: var(--space-4);
  display: grid;
  gap: var(--space-2);
}

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

.contact-form-intro p + ul {
  margin-top: var(--space-4);
}

.contact-form-benefits {
  display: grid;
  gap: var(--space-2);
  color: var(--color-text-soft);
}

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

.contact-form-card {
  padding: var(--space-6);
}

.contact-form {
  display: grid;
  gap: var(--space-4);
}

.contact-form-inline {
  gap: var(--space-4);
}

.contact-form-consent {
  font-size: var(--font-size-sm);
  color: var(--color-text-soft);
}

.contact-checkbox-label {
  display: flex;
  align-items: flex-start;
  gap: var(--space-2);
}

.contact-checkbox-label input[type="checkbox"] {
  margin-top: 0.2rem;
}

.contact-form-actions {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

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

.contact-form-status {
  margin-top: var(--space-2);
  font-size: var(--font-size-xs);
  min-height: 1em;
}

.contact-hours-grid {
  gap: var(--space-8);
}

.contact-hours-table {
  margin-top: var(--space-4);
}

.contact-hours-note {
  margin-top: var(--space-4);
  font-size: var(--font-size-sm);
}

.contact-hours-aside {
  align-self: stretch;
}

.contact-hours-list {
  margin-top: var(--space-4);
  display: grid;
  gap: var(--space-2);
}

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

.contact-subheading {
  margin-top: var(--space-4);
  margin-bottom: var(--space-2);
  font-size: var(--font-size-lg);
}

.contact-access-list {
  display: grid;
  gap: var(--space-2);
  margin-bottom: var(--space-3);
}

.contact-access-note {
  margin-top: var(--space-3);
  font-size: var(--font-size-sm);
}

.contact-map-card {
  height: 100%;
}

.contact-map-links {
  margin-top: var(--space-4);
  display: grid;
  gap: var(--space-2);
}

.contact-special-grid {
  gap: var(--space-6);
}

.contact-special-card {
  height: 100%;
}

.contact-special-list {
  margin-top: var(--space-3);
  display: grid;
  gap: var(--space-2);
}

.contact-mini-form {
  margin-top: var(--space-4);
  display: grid;
  gap: var(--space-3);
}

.contact-feedback-grid {
  gap: var(--space-8);
}

.contact-feedback-card {
  height: 100%;
}

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

.contact-faq-item {
  padding: 0;
}

.contact-faq-toggle {
  width: 100%;
  padding: var(--space-4) var(--space-6);
  background: transparent;
  color: var(--color-text);
  display: flex;
  justify-content: space-between;
  align-items: center;
  text-align: left;
}

.contact-faq-toggle span:first-child {
  font-family: var(--font-serif);
  font-size: var(--font-size-lg);
}

.contact-faq-icon {
  width: 1.75rem;
  height: 1.75rem;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.24);
  position: relative;
}

.contact-faq-icon::before,
.contact-faq-icon::after {
  content: "";
  position: absolute;
  background-color: var(--color-text-soft);
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  transition: transform var(--transition-normal), opacity var(--transition-normal);
}

.contact-faq-icon::before {
  width: 10px;
  height: 2px;
}

.contact-faq-icon::after {
  width: 2px;
  height: 10px;
}

.contact-faq-toggle[aria-expanded="true"] .contact-faq-icon::after {
  transform: translate(-50%, -50%) rotate(90deg);
  opacity: 0;
}

.contact-faq-body {
  max-height: 0;
  overflow: hidden;
  padding: 0 var(--space-6);
  transition: max-height var(--transition-slow), padding-bottom var(--transition-normal);
}

.contact-faq-body.open {
  padding-bottom: var(--space-4);
}

@media (max-width: 1024px) {
  .contact-hero-inner {
    grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
  }
}

@media (max-width: 768px) {
  .contact-hero-inner {
    grid-template-columns: minmax(0, 1fr);
  }

  .contact-hero-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .contact-form-grid,
  .contact-hours-grid,
  .contact-access-grid,
  .contact-feedback-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .contact-form-card,
  .contact-map-card {
    margin-top: var(--space-4);
  }

  .contact-faq-toggle {
    padding: var(--space-4);
  }

  .contact-faq-body {
    padding-left: var(--space-4);
    padding-right: var(--space-4);
  }
}

@media (max-width: 480px) {
  .contact-form-inline {
    grid-template-columns: minmax(0, 1fr);
  }
}
