main:has(.homepage) {
  padding-block-end: 0;

  &::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: calc(50% - 180px);
    bottom: 0;
    background: linear-gradient(var(--color-tint), white);
    clip-path: polygon(0% 360px, 100% 0, 100% 100%, 0% 100%);
    z-index: -1;
  }
}

.homepage {
  --flow-space: var(--space-xl);
}

.homepage-introduction {
  --column-gap: var(--space-xl);
  --flow-space: var(--space-l);
}

.homepage-introduction-images {
  --flow-space: var(--space-3xs);

  justify-self: center;
}

.homepage-introduction-links a[href] {
  color: var(--color-brand);
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-top: 1px solid var(--color-mid);
  padding: 1rem 0;

  &:hover {
    text-decoration: none;
  }
}

.homepage-services {
  text-align: center;

  .homepage-grid {
    grid-template-columns: repeat(auto-fill, minmax(min(20rem, 100%), 1fr));

    img {
      width: 3rem;
      aspect-ratio: 1;
      margin: var(--space-s) auto;
    }
  }
}

.homepage-clients {
  text-align: center;

  .homepage-grid {
    grid-template-columns: repeat(auto-fill, minmax(min(13rem, 100%), 1fr));

    li {
      display: grid;
      place-items: center;
    }
  }
}

.homepage-grid {
  background: var(--color-tint);
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(0, 1fr));
  grid-gap: 1px;
  margin-block-start: var(--space-m);

  li {
    padding: var(--space-l) var(--space-m);
    background: var(--color-light);
  }
}

.homepage-case-studies {
  > * + * {
    --flow-space: var(--space-m);
  }

  > h2 {
    text-align: center;
  }
}

.homepage-header::before {
  content: "";
  width: 0.125rem;
  height: 2.5rem;
  background: var(--color-brand);
  display: block;
  border-radius: 0.125rem;
  margin: 0 auto 1rem;
}

.homepage-more {
  text-align: center;
}

.homepage-bottom-images {
  --column-gap: 0;
  margin-block-start: var(--space-xl);

  figure {
    margin-inline: 0;
  }

  img {
    width: 100%;
  }
}
