.hero-layout {
  display: grid;
  gap: var(--space-8);
}

@media (min-width: 900px) {
  .hero-layout {
    grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
    align-items: center;
  }
}

.hero-copy {
  max-width: 38rem;
}

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

.hero-summary-card .card-title {
  font-size: var(--font-size-2xl);
}

.hero-contact-details {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--space-4);
  font-size: var(--font-size-sm);
}

.hero-contact-details dt {
  font-weight: 600;
  margin-bottom: var(--space-1);
  color: var(--gray-700);
}

.hero-contact-details dd {
  margin: 0;
  color: var(--color-text-muted);
}

.contact-layout {
  align-items: flex-start;
}

.contact-subheading {
  font-size: var(--font-size-lg);
  margin-bottom: var(--space-2);
}

.contact-options > div + div {
  margin-top: var(--space-4);
}

.contact-links-cta {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--space-3);
  margin-top: var(--space-5);
}

.quote-layout {
  align-items: flex-start;
}

.quote-form {
  max-width: 38rem;
}

.form-message {
  margin-top: var(--space-3);
  font-size: var(--font-size-sm);
}

.form-message--success {
  color: var(--color-success);
}

.form-message--error {
  color: var(--color-danger);
}

.privacy-note {
  font-size: var(--font-size-xs);
}

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

.contact-links-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: var(--space-2);
  font-size: var(--font-size-sm);
}

.contact-links-list a {
  text-decoration: underline;
}

.after-contact-layout {
  align-items: flex-start;
}

.contact-expectations-list,
.contact-privacy-list {
  list-style: disc;
  padding-left: var(--space-5);
  margin-bottom: var(--space-4);
}

.contact-expectations-list li + li,
.contact-privacy-list li + li {
  margin-top: var(--space-2);
}

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