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

.hero-layout {
  display: grid;
  grid-template-columns: minmax(0, 3fr) minmax(0, 2fr);
  gap: var(--space-10);
  align-items: center;
}

.hero-text .hero-meta {
  margin-top: var(--space-4);
  color: var(--color-text-muted);
  font-size: var(--font-size-sm);
}

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

.key-facts {
  display: grid;
  gap: var(--space-4);
  font-size: var(--font-size-sm);
}

.key-fact-item dt {
  font-weight: 600;
  margin-bottom: 2px;
  color: var(--gray-100);
}

.key-fact-item dd {
  margin: 0;
  color: var(--color-text-muted);
}

.section-heading--left {
  text-align: left;
  margin-bottom: var(--space-8);
}

.contact-section {
  border-top: 1px solid rgba(15, 23, 42, 0.95);
}

.contact-section--split {
  background: radial-gradient(circle at top left, rgba(34, 197, 94, 0.15), transparent 55%), var(--color-surface);
}

.contact-split-grid {
  align-items: flex-start;
}

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

.location-list {
  margin-left: 0;
  list-style: none;
  padding: 0;
}

.location-list li + li {
  margin-top: var(--space-2);
}

.location-note {
  margin-top: var(--space-4);
}

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

.map-placeholder {
  margin-top: var(--space-4);
  border-radius: var(--radius-lg);
  border: 1px dashed rgba(148, 163, 184, 0.6);
  min-height: 220px;
  background: radial-gradient(circle at top left, rgba(59, 130, 246, 0.18), rgba(15, 23, 42, 0.95));
}

.map-helper-list {
  margin-top: var(--space-4);
  margin-left: var(--space-5);
}

.contact-section--hours {
  background: var(--color-surface-alt);
}

.hours-grid {
  align-items: stretch;
}

.hours-list {
  display: grid;
  gap: var(--space-2);
  font-size: var(--font-size-sm);
}

.hours-row {
  display: flex;
  justify-content: space-between;
  gap: var(--space-4);
}

.hours-row dt {
  font-weight: 500;
  color: var(--gray-100);
}

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

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

.contact-section--direct {
  background: var(--color-surface);
}

.contact-lines {
  margin-top: var(--space-4);
  display: grid;
  gap: var(--space-2);
  font-size: var(--font-size-sm);
}

.contact-line {
  display: flex;
  justify-content: space-between;
  gap: var(--space-4);
}

.contact-line dt {
  font-weight: 500;
  color: var(--gray-100);
}

.contact-line dd {
  margin: 0;
  color: var(--color-text-muted);
}

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

.contact-section--form {
  background: radial-gradient(circle at top right, rgba(59, 130, 246, 0.18), transparent 55%), var(--color-surface-alt);
}

.contact-form-grid {
  align-items: flex-start;
}

.contact-form .form-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-4);
}

.contact-form .form-row--meta {
  margin-top: var(--space-4);
}

.contact-form .form-field {
  margin-bottom: var(--space-4);
}

.form-consent {
  margin-top: var(--space-2);
}

.form-consent-label {
  align-items: flex-start;
  gap: 0.5rem;
  font-size: var(--font-size-xs);
  line-height: var(--line-height-relaxed);
}

.form-consent-label input[type="checkbox"] {
  width: 16px;
  height: 16px;
  margin-right: 0.4rem;
}

.form-actions {
  margin-top: var(--space-6);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-4);
}

.form-status {
  min-height: 1.2em;
  font-size: var(--font-size-sm);
}

.form-status--success {
  color: var(--color-success);
}

.form-status--error {
  color: var(--color-danger);
}

.form-tips {
  margin-left: var(--space-5);
}

.form-side-note {
  margin-top: var(--space-4);
}

.contact-section--staff {
  background: var(--color-surface);
}

.staff-grid {
  align-items: stretch;
}

.staff-card {
  display: flex;
  flex-direction: column;
}

.staff-contacts {
  margin-top: var(--space-4);
  display: grid;
  gap: var(--space-2);
  font-size: var(--font-size-sm);
}

.staff-contact-row {
  display: flex;
  justify-content: space-between;
  gap: var(--space-4);
}

.staff-contact-row dt {
  font-weight: 500;
  color: var(--gray-100);
}

.staff-contact-row dd {
  margin: 0;
  color: var(--color-text-muted);
}

.staff-note {
  margin-top: var(--space-8);
}

.contact-section--visit {
  background: var(--color-surface-alt);
}

.visit-grid {
  max-width: 760px;
}

.visit-card h2 {
  margin-bottom: var(--space-4);
}

.visit-benefits {
  margin-left: var(--space-5);
}

.visit-actions {
  margin-top: var(--space-6);
}

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

.contact-section--accessibility {
  background: var(--color-surface);
}

.access-grid {
  align-items: flex-start;
}

.access-list {
  margin-left: var(--space-5);
}

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

.contact-section--faq {
  background: var(--color-surface-alt);
}

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

.faq-question {
  font-size: var(--font-size-lg);
}

.faq-answer {
  margin-top: var(--space-2);
}

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

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

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

@media (max-width: 640px) {
  .hours-row,
  .contact-line,
  .staff-contact-row {
    flex-direction: column;
    align-items: flex-start;
  }

  .map-placeholder {
    min-height: 180px;
  }
}
