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

.contact-intro-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1.1fr);
  gap: var(--space-10);
  align-items: center;
}

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

.contact-intro-actions {
  margin-top: var(--space-6);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}

.contact-intro-meta {
  margin-top: var(--space-5);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}

.contact-intro-panel {
  backdrop-filter: blur(18px);
}

.contact-intro-panel-header {
  margin-bottom: var(--space-5);
}

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

.contact-intro-list li {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-3);
  align-items: flex-start;
}

.contact-intro-bullet {
  width: 32px;
  height: 32px;
  border-radius: var(--radius-pill);
  border: 1px solid rgba(255, 255, 255, 0.28);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: var(--font-size-xs);
  color: var(--color-silver);
}

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

.section-contact-form .section-header {
  max-width: 42rem;
}

.contact-form-layout {
  margin-top: var(--space-10);
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1.05fr);
  gap: var(--space-8);
  align-items: flex-start;
}

.contact-form {
  position: relative;
}

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

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

.contact-preferences-title {
  font-size: var(--font-size-sm);
  color: var(--color-text);
  margin-bottom: var(--space-2);
}

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

.contact-preferences-option {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

.contact-form-consent-row {
  display: flex;
}

.contact-form-consent-row label {
  align-items: flex-start;
}

.contact-form-consent-row input[type="checkbox"] {
  margin-top: 0.15rem;
}

.contact-form-actions {
  margin-top: var(--space-5);
  gap: var(--space-6);
  align-items: flex-end;
}

.contact-form-security {
  max-width: 24rem;
  display: grid;
  gap: var(--space-2);
}

.contact-form-security p {
  margin: 0;
  font-size: var(--font-size-xs);
}

.contact-form-submit {
  flex-shrink: 0;
}

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

.contact-side-block + .contact-side-block {
  margin-top: var(--space-4);
}

.contact-side-links {
  margin-top: var(--space-5);
}

.section-hours-location {
  padding-top: var(--space-12);
}

.hours-location-grid {
  gap: var(--space-8);
}

.hours-list {
  margin-top: var(--space-4);
  display: grid;
  gap: var(--space-3);
}

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

.hours-row dt {
  color: var(--color-text);
}

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

.location-map {
  position: relative;
  border-radius: var(--radius-md);
  overflow: hidden;
  background: radial-gradient(circle at top, rgba(76, 111, 255, 0.22), transparent 60%),
              radial-gradient(circle at bottom, rgba(255, 20, 81, 0.22), transparent 55%),
              #050509;
  min-height: 220px;
  box-shadow: var(--shadow-soft);
}

.location-map-overlay {
  position: absolute;
  inset: 0;
  padding: var(--space-5);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.85), transparent 45%);
}

.location-map-overlay h3 {
  margin-top: var(--space-3);
}

.location-map-overlay p {
  max-width: 26rem;
}

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

.section-faq {
  padding-top: var(--space-12);
}

.faq-layout {
  margin-top: var(--space-8);
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-8);
}

.faq-items {
  margin-top: var(--space-4);
}

.faq-item {
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border-subtle);
  background: rgba(8, 8, 18, 0.96);
  padding: var(--space-3) var(--space-4);
}

.faq-item summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  font-size: var(--font-size-sm);
  color: var(--color-text);
}

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

.faq-item[open] summary {
  color: var(--color-primary);
}

.faq-item p {
  margin-top: var(--space-2);
  font-size: var(--font-size-sm);
}

.faq-cta,
.faq-links {
  margin-top: var(--space-4);
}

.section-appointments {
  padding-top: var(--space-12);
}

.appointments-social-grid {
  gap: var(--space-8);
}

.appointment-list {
  margin-top: var(--space-4);
}

.section-accessibility {
  padding-top: var(--space-12);
}

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

.accessibility-block ul,
.privacy-block ul {
  margin-top: var(--space-4);
}

.accessibility-block li,
.privacy-block li {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

.accessibility-block p,
.privacy-block p {
  margin-top: var(--space-4);
}

@media (max-width: 1024px) {
  .contact-intro-layout {
    grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
    gap: var(--space-6);
  }

  .contact-form-layout {
    grid-template-columns: minmax(0, 1.3fr) minmax(0, 1fr);
    gap: var(--space-6);
  }

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

  .contact-form-submit {
    display: flex;
    justify-content: flex-start;
  }
}

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

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

  .contact-intro-panel {
    order: -1;
  }

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

  .hours-location-grid,
  .faq-layout,
  .appointments-social-grid,
  .accessibility-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .hours-row {
    flex-direction: column;
    align-items: flex-start;
  }

  .location-map-overlay {
    padding: var(--space-4);
  }
}

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

  .contact-form-submit {
    width: 100%;
  }

  .contact-form-submit .btn {
    width: 100%;
    justify-content: center;
  }
}
