.contact-hero {
  padding-top: var(--space-12);
  padding-bottom: var(--space-10);
  background: radial-gradient(circle at top left, var(--color-primary-soft), transparent 60%),
    radial-gradient(circle at bottom right, rgba(15, 23, 42, 0.08), transparent 55%);
}

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

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

.contact-hero-text {
  max-width: 38rem;
}

.contact-kicker {
  font-size: var(--font-size-sm);
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-primary-dark);
  margin-bottom: var(--space-2);
}

.contact-hero-lead {
  font-size: var(--font-size-lg);
  color: var(--color-text-muted);
  margin-bottom: var(--space-4);
}

.contact-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-bottom: var(--space-3);
}

.contact-hero-meta {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

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

.contact-quick-list {
  list-style: none;
  margin: 0 0 var(--space-3);
  padding: 0;
}

.contact-quick-list li {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1.5fr);
  gap: var(--space-2);
  font-size: var(--font-size-sm);
  padding-block: 0.35rem;
}

@media (max-width: 600px) {
  .contact-quick-list li {
    grid-template-columns: 1fr;
  }
}

.contact-quick-label {
  color: var(--color-text-muted);
}

.contact-quick-link {
  display: inline-flex;
  align-items: center;
  font-size: var(--font-size-sm);
  color: var(--color-primary-dark);
}

.contact-section {
  padding-top: var(--space-10);
  padding-bottom: var(--space-10);
}

.contact-section-alt {
  background-color: var(--gray-50);
}

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

.contact-section-intro {
  color: var(--color-text-muted);
}

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

.contact-detail-card h3 {
  margin-bottom: var(--space-2);
}

.contact-dl {
  margin: 0;
}

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

.contact-dl dt {
  font-size: var(--font-size-sm);
  font-weight: 500;
  color: var(--color-text-muted);
}

.contact-dl dd {
  margin: 0;
  font-size: var(--font-size-sm);
}

.contact-dl-compact div {
  display: flex;
  gap: var(--space-2);
}

.contact-address {
  font-style: normal;
  margin: var(--space-3) 0;
}

.contact-hours {
  margin: 0;
}

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

.contact-hours dt {
  font-size: var(--font-size-sm);
  font-weight: 500;
}

.contact-hours dd {
  margin: 0;
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

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

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

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

.contact-form-benefits li {
  margin-bottom: 0.3rem;
}

.contact-related-links {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}

.contact-privacy-field {
  border: 1px solid var(--gray-200);
  border-radius: var(--radius-md);
  padding: var(--space-3);
}

.contact-privacy-legend {
  font-size: var(--font-size-sm);
  font-weight: 600;
  margin-bottom: var(--space-2);
}

.contact-privacy-consent {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: flex-start;
  gap: var(--space-2);
  margin-top: var(--space-2);
}

.contact-privacy-consent input[type="checkbox"] {
  margin-top: 0.1rem;
}

.contact-form-footer {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-top: var(--space-3);
}

.contact-booking {
  display: grid;
  grid-template-columns: minmax(0, 1.7fr) minmax(0, 1.4fr);
  gap: var(--space-6);
  align-items: flex-start;
}

@media (max-width: 900px) {
  .contact-booking {
    grid-template-columns: 1fr;
  }
}

.contact-booking-list {
  list-style: disc;
  padding-left: 1.25rem;
  margin-bottom: var(--space-4);
  color: var(--color-text-muted);
}

.contact-booking-list li {
  margin-bottom: 0.3rem;
}

.contact-booking-card h3 {
  margin-bottom: var(--space-2);
}

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

.contact-booking-tips li {
  margin-bottom: 0.3rem;
}

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

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

.contact-map iframe {
  width: 100%;
  min-height: 320px;
  border: 0;
}

@media (max-width: 600px) {
  .contact-map iframe {
    min-height: 260px;
  }
}

.contact-map-footer {
  margin-top: var(--space-3);
}

.contact-support-card {
  padding: var(--space-5);
}

.contact-support-header {
  margin-bottom: var(--space-4);
}

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

.contact-support-highlight {
  font-weight: 600;
}

.contact-trust {
  display: grid;
  grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
  gap: var(--space-6);
  align-items: center;
}

@media (max-width: 900px) {
  .contact-trust {
    grid-template-columns: 1fr;
  }
}

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

.contact-trust-list li {
  margin-bottom: 0.3rem;
}

.contact-trust-links {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  justify-content: flex-start;
}

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