hero-home {
  display: block;
}

.hero-home {
  padding-top: var(--space-80);
  padding-bottom: var(--space-80);
}

.hero-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
  gap: var(--space-40);
  align-items: center;
}

.hero-copy {
  max-width: 640px;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-16);
  margin-top: var(--space-24);
}

.hero-meta {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-20);
  margin-top: var(--space-32);
}

.hero-meta-item {
  padding: var(--space-16);
  border-radius: var(--radius-lg);
  background-color: rgba(255, 255, 255, 0.9);
  box-shadow: var(--shadow-sm);
}

.hero-meta-label {
  display: block;
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--color-gold);
  margin-bottom: var(--space-4);
}

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

.hero-visual {
  max-width: 520px;
  margin-left: auto;
}

.section-header {
  max-width: 720px;
  margin: 0 auto var(--space-40);
}

.services-grid {
  align-items: stretch;
}

.service-card .card-body {
  font-size: var(--text-sm);
}

.service-list,
.why-list,
.team-list,
.case-list,
.pricing-list,
.consultation-list {
  padding-left: 1.1rem;
  margin-bottom: var(--space-16);
  color: var(--color-text);
}

.service-list li,
.why-list li,
.team-list li,
.case-list li,
.pricing-list li,
.consultation-list li {
  margin-bottom: var(--space-8);
}

.service-links {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-12);
  margin-top: var(--space-16);
}

.service-link {
  font-size: var(--text-sm);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}

.featured-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
  gap: var(--space-40);
  align-items: center;
}

.featured-highlights {
  margin-top: var(--space-24);
}

.featured-note {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  margin-top: var(--space-8);
}

.featured-cta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-16);
  margin-top: var(--space-24);
}

.why-grid,
.team-grid,
.testimonials-grid,
.case-grid,
.pricing-grid {
  align-items: stretch;
}

.testimonial-card {
  position: relative;
}

.testimonial-quote {
  font-style: italic;
  color: var(--color-text);
}

.testimonial-name {
  margin-top: var(--space-16);
  font-weight: 600;
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}

.team-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.2fr);
  gap: var(--space-40);
  align-items: center;
}

.team-copy {
  max-width: 640px;
  margin-left: auto;
}

.team-cta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-16);
  margin-top: var(--space-24);
}

.consultation-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 1fr);
  gap: var(--space-40);
  align-items: flex-start;
}

.consultation-form-card {
  max-width: 520px;
}

.consultation-form .card-subtitle {
  margin-bottom: var(--space-20);
}

.consultation-cta {
  margin-top: var(--space-24);
}

.consultation-privacy {
  margin-top: var(--space-16);
  font-size: var(--text-xs);
}

.location-layout {
  max-width: 960px;
}

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

.location-heading {
  margin-bottom: var(--space-12);
}

.location-links {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-16);
  margin-top: var(--space-16);
}

.location-small {
  margin-top: var(--space-24);
  font-size: var(--text-sm);
}

@media (max-width: 960px) {
  .hero-layout,
  .featured-layout,
  .team-layout,
  .consultation-layout {
    grid-template-columns: minmax(0, 1fr);
  }

  .hero-visual,
  .featured-visual,
  .team-copy,
  .consultation-form-card {
    max-width: 100%;
  }

  .hero-home {
    padding-top: var(--space-64);
    padding-bottom: var(--space-64);
  }
}

@media (max-width: 768px) {
  .hero-actions,
  .featured-cta,
  .team-cta,
  .location-links {
    flex-direction: column;
    align-items: stretch;
  }

  .hero-meta {
    grid-template-columns: minmax(0, 1fr);
  }
}

@media (max-width: 480px) {
  .section {
    padding-top: var(--space-48);
    padding-bottom: var(--space-48);
  }

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