.contact-hero-grid {
  align-items: stretch;
  gap: var(--space-20);
}

.contact-hero-cta {
  margin-top: var(--space-8);
}

.contact-hero-meta {
  margin-top: var(--space-10);
  max-width: 40rem;
}

.contact-hero-card {
  align-self: center;
}

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

.contact-detail-row {
  display: flex;
  justify-content: space-between;
  gap: var(--space-6);
  font-size: var(--font-size-sm);
}

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

.contact-detail-row dd {
  margin: 0;
  text-align: right;
}

.contact-emergency {
  margin-top: var(--space-8);
  font-size: var(--font-size-sm);
}

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

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

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

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

.form-legend {
  font-size: var(--font-size-sm);
  font-weight: 600;
  margin-bottom: var(--space-2);
  color: var(--gray-800);
}

.contact-radio-label,
.contact-checkbox-label {
  display: inline-flex;
  align-items: flex-start;
  gap: var(--space-3);
  font-size: var(--font-size-sm);
}

.contact-radio-label input,
.contact-checkbox-label input {
  width: auto;
  margin-top: 2px;
}

.business-extra {
  margin-top: var(--space-4);
  border-radius: var(--radius-md);
  background-color: var(--color-primary-soft);
  padding: var(--space-6);
}

.contact-accessibility textarea {
  min-height: 96px;
}

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

.contact-consent {
  margin-bottom: var(--space-2);
}

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

.form-actions .small-info {
  font-size: var(--font-size-sm);
}

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

.contact-aside {
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
}

.contact-hours-list {
  list-style: none;
  padding: 0;
  margin: var(--space-4) 0;
  display: grid;
  row-gap: var(--space-3);
}

.contact-hours-list li {
  display: flex;
  justify-content: space-between;
  gap: var(--space-6);
  font-size: var(--font-size-sm);
}

.contact-hours-list span:first-child {
  color: var(--gray-700);
}

.small-info {
  font-size: var(--font-size-sm);
}

.contact-region-list,
.contact-security-list,
.contact-route-list,
.contact-booking-list,
.contact-booking-steps {
  margin: var(--space-4) 0;
  padding-left: var(--space-6);
  font-size: var(--font-size-sm);
}

.contact-region-list li + li,
.contact-security-list li + li,
.contact-route-list li + li,
.contact-booking-list li + li,
.contact-booking-steps li + li {
  margin-top: var(--space-2);
}

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

.contact-location-card {
  margin-top: var(--space-6);
}

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

.contact-map-frame {
  min-height: 260px;
}

.map-note {
  font-size: var(--font-size-sm);
}

.contact-booking-grid {
  gap: var(--space-20);
  align-items: stretch;
}

.contact-booking-card {
  align-self: center;
}

.contact-booking-steps {
  list-style: decimal;
}

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

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

.contact-faq-item {
  padding: var(--space-6) var(--space-8);
}

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

.contact-faq-trigger::after {
  content: "+";
  font-weight: 600;
  color: var(--color-primary);
}

.contact-faq-trigger[aria-expanded="true"]::after {
  content: "−";
}

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

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

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

@media (max-width: 900px) {
  .contact-detail-row {
    flex-direction: column;
    align-items: flex-start;
    text-align: left;
  }

  .contact-detail-row dd {
    text-align: left;
  }
}

@media (max-width: 768px) {
  .section {
    padding-top: var(--space-24);
    padding-bottom: var(--space-24);
  }

  .contact-hero-grid,
  .contact-main-grid,
  .contact-location-grid,
  .contact-booking-grid,
  .contact-faq-grid {
    gap: var(--space-16);
  }

  .contact-hero-card {
    margin-top: var(--space-8);
  }

  .contact-aside {
    margin-top: var(--space-8);
  }
}

@media (max-width: 480px) {
  .contact-hero-cta {
    flex-direction: column;
    align-items: stretch;
  }

  .contact-hours-list li {
    flex-direction: column;
    align-items: flex-start;
  }
}
