.hero {
  padding-top: var(--space-20);
}

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

.hero-copy p {
  max-width: 34rem;
}

.hero-cta {
  display: flex;
  gap: var(--space-3);
}

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

.hero-metric dt {
  font-size: var(--text-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  margin-bottom: 0.25rem;
}

.hero-metric dd {
  font-size: var(--text-sm);
}

.hero-visual {
  position: relative;
}

.hero-figure {
  padding: var(--space-4);
}

.hero-figure img {
  border-radius: var(--radius-lg);
}

.hero-figure-caption {
  margin-top: var(--space-3);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}

.hero-mini-panel {
  margin-top: var(--space-4);
}

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

.section-header-center {
  text-align: center;
  margin-left: auto;
  margin-right: auto;
}

.section-header-center p {
  margin-left: auto;
  margin-right: auto;
  max-width: 32rem;
}

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

.service-card {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.service-list li::before {
  content: "";
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 9999px;
  background: var(--color-primary);
  margin-right: 0.4rem;
}

.service-list li {
  display: flex;
  align-items: flex-start;
}

.service-cta {
  margin-top: var(--space-6);
}

.why-layout {
  gap: var(--space-12);
}

.why-aside {
  align-self: center;
}

.why-metrics dt {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-text);
}

.why-metrics dd {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}

.visualisation-layout {
  gap: var(--space-12);
}

.visualisation-figure img {
  border-radius: var(--radius-lg);
}

.visualisation-cta {
  display: flex;
  gap: var(--space-3);
  align-items: center;
}

.link-inline {
  font-size: var(--text-sm);
}

.team-layout {
  gap: var(--space-12);
  align-items: center;
}

.team-figure img {
  border-radius: var(--radius-lg);
}

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

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

.testimonial-card {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.testimonial-meta {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}

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

.case-card ul li::before {
  content: "";
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 9999px;
  background: var(--color-accent);
  margin-right: 0.4rem;
}

.case-card ul li {
  display: flex;
}

.tech-layout {
  gap: var(--space-12);
  align-items: center;
}

.tech-figure img {
  border-radius: var(--radius-lg);
}

.process-steps {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: var(--space-4);
  counter-reset: process-counter;
}

.process-step {
  min-height: 100%;
}

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

.sector-card {
  min-height: 100%;
}

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

.booking-card {
  align-self: stretch;
}

.booking-actions {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.booking-disclaimer {
  font-size: var(--text-xs);
}

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

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

.contact-links {
  display: flex;
  gap: var(--space-3);
}

.contact-form-card {
  align-self: stretch;
}

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

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

  .hero {
    padding-top: var(--space-16);
  }

  .process-steps {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .team-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .process-steps {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .booking-layout,
  .contact-layout,
  .tech-layout,
  .team-layout,
  .visualisation-layout,
  .why-layout {
    gap: var(--space-8);
  }

  .hero-cta,
  .visualisation-cta,
  .contact-links {
    flex-direction: column;
    align-items: stretch;
  }
}

@media (max-width: 640px) {
  .hero-metrics {
    flex-direction: column;
  }

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