.page {
  padding: 48px 0 60px;
}

.page__container {
  width: min(1200px, calc(100% - 28px));
  margin: 0 auto;
}

.page__kicker {
  margin: 0 0 0.8rem;
  font-size: 0.88rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #456530;
}

.page__title {
  margin: 0 0 1rem;
  font-size: clamp(2rem, 2.2vw + 1rem, 3rem);
  line-height: 1.1;
  color: #1f2f1c;
}

.page__lead {
  margin: 0 0 1rem;
  max-width: 74ch;
  font-size: clamp(1.1rem, 0.9rem + 0.6vw, 1.28rem);
  line-height: 1.65;
  font-weight: 700;
  color: #243524;
}

.page__intro,
.page__closing {
  margin: 0 0 1.2rem;
  max-width: 86ch;
  font-size: 1.03rem;
  line-height: 1.75;
  color: #1f2937;
}

.page__services {
  margin: 1.6rem 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 1rem;
  max-width: 92ch;
}

.page__services li {
  position: relative;
  padding-left: 1.7rem;
  font-size: 1.03rem;
  line-height: 1.75;
  color: #223120;
}

.page__services li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.45em;
  width: 0.72rem;
  height: 0.72rem;
  border-right: 3px solid #4f7a2e;
  border-bottom: 3px solid #4f7a2e;
  transform: rotate(45deg);
}

.page__services strong {
  color: #1f2f1c;
}

.page__link {
  color: #2e4f20;
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 2px;
  font-weight: 700;
}

.page__link:hover {
  color: #1f3614;
}

.page__link:focus-visible {
  outline: 2px solid #2e4f20;
  outline-offset: 2px;
  border-radius: 4px;
}

@media (max-width: 768px) {
  .page {
    padding: 40px 0 52px;
  }

  .page__container {
    width: min(1200px, calc(100% - 24px));
  }
}
