main {
  padding-top: var(--space-24);
  padding-bottom: var(--space-32);
}

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

.section-header {
  max-width: 720px;
  margin: 0 auto var(--space-16);
  text-align: left;
}

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

.section-header p {
  margin-bottom: 0;
}

.hero--home {
  background: radial-gradient(circle at top left, var(--color-primary-soft), transparent 55%), #f5f7fa;
}

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

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

.hero-benefits {
  margin-top: var(--space-12);
  padding-left: 1.1rem;
  color: var(--color-text-muted);
  font-size: var(--font-size-sm);
}

.hero-benefits li + li {
  margin-top: var(--space-4);
}

.hero-media {
  justify-self: end;
}

.hero-image-figure {
  max-width: 460px;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-md);
}

.hero-image {
  width: 100%;
  height: auto;
}

.service-grid {
  margin-top: var(--space-16);
}

.service-card {
  height: 100%;
  display: flex;
  flex-direction: column;
}

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

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

.filters-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
  gap: var(--space-24);
  align-items: stretch;
}

.filters-text {
  max-width: 640px;
}

.filters-cta-group,
.quality-cta-group,
.team-cta-group,
.account-cta-group {
  margin-top: var(--space-12);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-8);
}

.filters-card-body {
  display: flex;
  flex-direction: column;
  gap: var(--space-12);
}

.filters-row {
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
}

.filters-row--multi {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-12);
}

.filters-actions {
  display: flex;
  justify-content: flex-start;
}

.feature-list {
  margin-top: var(--space-8);
  padding-left: 1.1rem;
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

.feature-list li + li {
  margin-top: var(--space-4);
}

.feature-list--compact {
  margin-top: 0;
}

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

.quality-image-figure {
  max-width: 480px;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-md);
}

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

.team-image-figure {
  max-width: 420px;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-md);
}

.trust-grid {
  margin-top: var(--space-16);
}

.trust-card {
  height: 100%;
  display: flex;
  flex-direction: column;
}

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

.account-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(0, 1fr);
  gap: var(--space-24);
  align-items: stretch;
}

.account-card {
  height: 100%;
}

.account-card-cta {
  margin-top: var(--space-12);
}

.contact-cta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-12);
  padding: var(--space-16);
  border-radius: var(--radius-lg);
  background-color: var(--color-primary-soft);
}

.contact-cta-text {
  max-width: 640px;
}

.contact-cta-text p {
  margin-bottom: 0;
}

.contact-cta-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-8);
}

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

  .hero-media,
  .quality-media,
  .team-media {
    justify-self: start;
  }

  .hero-image-figure,
  .quality-image-figure,
  .team-image-figure {
    max-width: 100%;
  }

  .filters-row--multi {
    grid-template-columns: minmax(0, 1fr);
  }
}

@media (max-width: 640px) {
  main {
    padding-top: var(--space-16);
    padding-bottom: var(--space-24);
  }

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

  .hero-actions,
  .filters-cta-group,
  .quality-cta-group,
  .team-cta-group,
  .account-cta-group,
  .contact-cta-actions {
    flex-direction: column;
    align-items: stretch;
  }

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