.contact-hero {
  position: relative;
}

.contact-hero__inner {
  align-items: center;
  gap: var(--space-40);
}

.contact-hero__content p {
  max-width: 560px;
}

.contact-hero__highlights {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-12);
  margin-top: var(--space-20);
}

.contact-hero__badge {
  padding: 0.4rem 0.9rem;
  border-radius: var(--radius-full);
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  border: 1px solid rgba(212, 175, 55, 0.5);
  background: radial-gradient(circle at top, rgba(212, 175, 55, 0.2), rgba(5, 5, 7, 0.95));
}

.contact-hero__cta-group {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-16);
  margin-top: var(--space-24);
}

.contact-hero__meta {
  margin-top: var(--space-24);
  font-size: 0.9rem;
}

.contact-hero__visual {
  max-height: 420px;
}

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

.contact-form__wrapper > p {
  max-width: 640px;
}

.contact-form {
  margin-top: var(--space-24);
}

.contact-form__grid {
  display: grid;
  gap: var(--space-20);
}

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

.contact-form__field {
  margin-bottom: var(--space-20);
}

.contact-form__radios-inner {
  display: flex;
  flex-direction: column;
  gap: var(--space-12);
}

.contact-radio {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  font-size: 0.9rem;
  color: var(--color-text-muted);
}

.contact-radio input {
  margin-top: 0.15rem;
}

.contact-checkbox {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  font-size: 0.85rem;
  color: var(--color-text-muted);
}

.contact-checkbox input {
  margin-top: 0.25rem;
}

.contact-form__actions {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-12);
  margin-top: var(--space-8);
}

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

.contact-details,
.contact-hours {
  display: grid;
  gap: var(--space-8);
  font-size: 0.9rem;
}

.contact-details dt,
.contact-hours dt {
  font-weight: 500;
}

.contact-details dd,
.contact-hours dd {
  color: var(--color-text-muted);
}

.contact-aside__cta,
.contact-membership__cta {
  margin-top: var(--space-16);
}

.contact-location {
  align-items: center;
  gap: var(--space-40);
}

.contact-location__card {
  margin-top: var(--space-24);
}

.contact-list {
  margin-top: var(--space-12);
  display: grid;
  gap: var(--space-8);
  padding-left: 1rem;
}

.contact-list li {
  color: var(--color-text-muted);
  list-style: disc;
}

.contact-steps {
  margin-top: var(--space-12);
  padding-left: 1.2rem;
  display: grid;
  gap: var(--space-8);
  font-size: 0.95rem;
  color: var(--color-text-muted);
}

.contact-steps li::marker {
  color: var(--color-accent-gold);
}

.contact-reservation__cta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-12);
  margin-top: var(--space-20);
}

.contact-membership {
  align-self: stretch;
}

.contact-management {
  align-items: flex-start;
  gap: var(--space-40);
}

.contact-faq__header {
  max-width: 640px;
}

.contact-faq__grid {
  margin-top: var(--space-32);
}

.contact-faq__item h3 {
  margin-bottom: var(--space-12);
}

.contact-faq__footer {
  margin-top: var(--space-32);
  font-size: 0.95rem;
}

.contact-legal__grid {
  margin-top: var(--space-24);
}

.contact-legal__item h3 {
  margin-bottom: var(--space-12);
}

.contact-legal__item p {
  margin-bottom: var(--space-16);
}

@media (max-width: 960px) {
  .contact-hero__inner,
  .contact-layout,
  .contact-location,
  .contact-reservation,
  .contact-management {
    gap: var(--space-32);
  }

  .contact-hero__cta-group {
    justify-content: flex-start;
  }
}

@media (max-width: 768px) {
  .contact-hero__cta-group {
    flex-direction: column;
    align-items: stretch;
  }

  .contact-hero__visual {
    max-height: none;
  }

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

@media (max-width: 640px) {
  .contact-hero__highlights {
    flex-direction: column;
    align-items: flex-start;
  }

  .contact-form {
    margin-top: var(--space-20);
  }
}
