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

.contact-hero-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
  gap: var(--space-16);
  padding: var(--space-16);
  border-radius: var(--radius-xl);
}

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

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

.contact-kicker {
  font-size: var(--font-size-sm);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-primary-strong);
}

.contact-hero-lead {
  font-size: var(--font-size-lg);
  color: var(--color-text-muted);
  max-width: 36rem;
}

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

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

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

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

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

.contact-hero-channels {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

.contact-channel h3 {
  font-size: var(--font-size-md);
  margin-bottom: var(--space-2);
}

.contact-channel-note {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
}

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

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

.contact-form-intro p {
  max-width: 34rem;
}

.contact-form-highlights {
  margin-top: var(--space-6);
  display: grid;
  gap: var(--space-3);
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

.contact-form-highlights li::before {
  content: "•";
  margin-right: var(--space-3);
  color: var(--color-primary);
}

.contact-form-wrapper {
  padding: var(--space-12);
}

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

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

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

.contact-form-field label {
  display: block;
  font-size: var(--font-size-sm);
  margin-bottom: var(--space-2);
}

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

.contact-checkbox {
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
}

.contact-checkbox input[type="checkbox"] {
  margin-top: var(--space-1);
}

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

.contact-form-note {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
}

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

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

.contact-list,
.opening-hours,
.contact-booking-list,
.contact-access-list {
  display: grid;
  gap: var(--space-4);
  font-size: var(--font-size-sm);
}

.contact-list dt,
.opening-hours dt {
  font-weight: 600;
}

.contact-tip,
.contact-note {
  margin-top: var(--space-6);
  font-size: var(--font-size-xs);
}

.contact-section-map .contact-map-grid {
  gap: var(--space-16);
  align-items: stretch;
}

.contact-map-info p,
.contact-map-info ul {
  max-width: 34rem;
}

.contact-map-placeholder {
  min-height: 260px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: var(--space-8);
}

.contact-map-title {
  font-size: var(--font-size-lg);
}

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

.contact-section-faq-feedback .contact-faq-grid {
  gap: var(--space-16);
}

.contact-faq-items {
  margin-top: var(--space-6);
  display: grid;
  gap: var(--space-4);
}

.contact-faq-items details {
  border-radius: var(--radius-md);
  background: var(--color-bg-soft);
  border: 1px solid var(--color-border-subtle);
  padding: var(--space-4) var(--space-6);
}

.contact-faq-items summary {
  cursor: pointer;
  font-size: var(--font-size-sm);
  list-style: none;
}

.contact-faq-items summary::-webkit-details-marker {
  display: none;
}

.contact-faq-items details[open] {
  border-color: rgba(229, 177, 91, 0.5);
}

.contact-faq-items details p {
  margin-top: var(--space-3);
  font-size: var(--font-size-sm);
}

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

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

.feedback-form {
  display: grid;
  gap: var(--space-6);
}

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