.lawn-care-customer-page {
  --hc-navy: #0f2233;
  --hc-muted: #51677a;
  --hc-blue: #2563eb;
  --hc-blue-dark: #1d4ed8;
  --hc-teal: #0f9aa8;
  --hc-green: #16a34a;
  --hc-soft: #f6fbff;
  --hc-border: #d9e8f5;
  --hc-shadow: 0 18px 46px rgba(15, 34, 51, 0.075);
  font-size: 17px;
}

.lawn-care-customer-page .brand-mark {
  background: linear-gradient(145deg, #237cff, #0757df);
  box-shadow: 0 8px 18px rgba(37, 99, 235, 0.2);
}

.lawn-care-customer-page .hc-hero {
  padding: 42px 0 44px;
  background:
    radial-gradient(circle at 2% 34%, rgba(187, 247, 208, 0.54) 0 105px, transparent 106px),
    radial-gradient(circle at 71% 12%, rgba(255, 255, 255, 0.98) 0 155px, transparent 156px),
    radial-gradient(circle at 100% 50%, rgba(167, 243, 208, 0.35) 0 180px, transparent 181px),
    linear-gradient(132deg, #fbfefc 0%, #f0fbf5 50%, #effaff 100%);
}

.lawn-care-customer-page .hc-hero::before {
  top: 72px;
  right: 4%;
  opacity: 0.56;
  background-image: radial-gradient(circle, #7dd3a8 3px, transparent 3.5px);
}

.lawn-care-customer-page .hc-hero::after {
  top: 190px;
  background: rgba(134, 239, 172, 0.34);
}

.lawn-care-customer-page .hc-breadcrumb {
  color: #047857;
}

.lawn-care-customer-page .hc-pill-row span {
  border-color: #a7f3d0;
  color: #047857;
  background: #ecfdf5;
}

.lawn-care-customer-page .hc-pill-row span + span {
  color: #166534;
  background: #dcfce7;
}

.lawn-care-customer-page .hc-hero-grid {
  grid-template-columns: minmax(0, 0.92fr) minmax(560px, 1.08fr);
  gap: 56px;
}

.lawn-care-customer-page .hc-hero-copy h1 {
  max-width: 780px;
  font-size: clamp(4rem, 6vw, 6.4rem);
  line-height: 0.96;
  letter-spacing: -0.055em;
}

.lawn-care-customer-page .hc-hero-copy p {
  max-width: 720px;
  font-size: 1.16rem;
}

.lc-hero-art {
  position: relative;
  min-height: 460px;
  isolation: isolate;
}

.lc-hero-art::before {
  content: "";
  position: absolute;
  z-index: -1;
  inset: 5% -1% 4% 4%;
  border-radius: 44px;
  background: rgba(187, 247, 208, 0.38);
  filter: blur(18px);
}

.lc-yard-scene {
  display: block;
  width: 100%;
  height: 540px;
  overflow: hidden;
  border-radius: 46% 54% 36% 64% / 45% 38% 62% 55%;
  filter: drop-shadow(0 25px 35px rgba(15, 83, 50, 0.15));
}

.lc-yard-photo {
  display: block;
  width: 100%;
  height: 460px;
  object-fit: cover;
  object-position: center 54%;
  border-radius: 42px;
  box-shadow: 0 25px 55px rgba(15, 83, 50, 0.16);
}

.lc-hero-art::after {
  content: "";
  position: absolute;
  z-index: 2;
  inset: 0 auto 0 0;
  width: 14%;
  border-radius: 42px 0 0 42px;
  background: linear-gradient(90deg, rgba(242, 251, 246, 0.88), rgba(242, 251, 246, 0));
  pointer-events: none;
}

.lc-hero-art > svg.lc-yard-scene {
  display: none;
}

.lc-hero-summary {
  position: absolute;
  z-index: 4;
  top: 62px;
  left: -8px;
  width: 194px;
  padding: 17px;
  border: 1px solid rgba(187, 215, 198, 0.88);
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 22px 55px rgba(15, 70, 43, 0.17);
  backdrop-filter: blur(12px);
}

.lc-hero-summary > span,
.lc-hero-summary > strong {
  display: block;
  text-align: center;
}

.lc-hero-summary > span:first-child {
  padding-bottom: 10px;
  border-bottom: 1px solid #e4eee8;
  color: #172f24;
  font-size: 0.78rem;
  font-weight: 900;
  white-space: nowrap;
}

.lc-hero-summary small {
  display: block;
  margin-top: 10px;
  color: #597065;
  font-size: 0.82rem;
  text-align: center;
}

.lc-hero-summary > strong {
  margin-top: 3px;
  color: #15803d;
  font-size: 1.8rem;
  letter-spacing: -0.04em;
}

.lc-summary-range {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-top: 15px;
}

.lc-summary-range span {
  color: #5b7065;
  font-size: 0.78rem;
  line-height: 1.35;
}

.lc-summary-range strong {
  display: block;
  color: #15803d;
  font-size: 1.02rem;
}

.lc-summary-range span:last-child strong {
  color: #2563eb;
}

.lawn-care-customer-page .hc-calculator-grid {
  margin-top: 36px;
}

.lc-form-heading {
  display: flex;
  gap: 14px;
  align-items: center;
  margin-bottom: 24px;
}

.lc-form-heading h2 {
  margin: 0 0 5px;
  color: #0f2233;
  font-size: clamp(1.8rem, 2.2vw, 2.35rem);
  font-weight: 950;
  letter-spacing: -0.035em;
}

.lc-form-subtitle {
  margin: 0;
  color: #607487;
  font-size: 1.05rem;
}

.lawn-care-customer-page .hc-input-group label .hc-icon,
.lawn-care-customer-page .hc-trust-note .hc-icon {
  color: #16a34a;
}

.lawn-care-customer-page .hc-input-group select:focus {
  border-color: #4ade80;
  outline-color: rgba(22, 163, 74, 0.14);
}

.lawn-care-customer-page .hc-check-option:has(input:checked) {
  border-color: #6ee7b7;
  background: #ecfdf5;
}

.lawn-care-customer-page .hc-check-option input {
  accent-color: #16a34a;
}

.lawn-care-customer-page .hc-check-option span:last-child {
  margin-left: auto;
  color: #047857;
  font-weight: 900;
  white-space: nowrap;
}

.lawn-care-customer-page .hc-button-primary {
  background: linear-gradient(135deg, #16a34a, #047857);
  box-shadow: 0 10px 23px rgba(4, 120, 87, 0.22);
}

.lawn-care-customer-page .hc-button-primary:hover {
  background: linear-gradient(135deg, #15803d, #065f46);
}

.lawn-care-customer-page .hc-results-card {
  background:
    radial-gradient(circle at 93% 7%, rgba(167, 243, 208, 0.36), transparent 32%),
    linear-gradient(150deg, #fbfffd, #f1fbf6);
}

.lawn-care-customer-page .hc-featured-result {
  border-color: #a7e2bc;
  background:
    radial-gradient(circle at 88% 12%, rgba(167, 243, 208, 0.38), transparent 38%),
    #ffffff;
}

.lawn-care-customer-page .hc-featured-result strong,
.lawn-care-customer-page .hc-secondary-results strong {
  color: #15803d;
}

.lawn-care-customer-page .hc-secondary-results > div:last-child strong {
  color: #2563eb;
}

.lawn-care-customer-page .hc-disclaimer {
  padding: 18px;
  border: 1px solid #d7eee0;
  border-radius: 14px;
  background: #f0fbf4;
}

.lawn-care-customer-page .hc-disclaimer .hc-icon {
  color: #15803d;
  background: #dcfce7;
}

.lc-results-updated .hc-featured-result strong {
  animation: lc-result-pop 280ms ease-out;
}

@keyframes lc-result-pop {
  0% { opacity: 0.55; transform: scale(0.96); }
  100% { opacity: 1; transform: scale(1); }
}

.lawn-care-customer-page .hc-content-section {
  padding: 40px 0 46px;
}

.lawn-care-customer-page .hc-content-grid {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

.lawn-care-customer-page .lc-content-card {
  grid-column: span 2;
  min-height: 100%;
}

.lawn-care-customer-page .lc-content-card:nth-child(4),
.lawn-care-customer-page .lc-content-card:nth-child(5) {
  grid-column: span 3;
}

.lawn-care-customer-page .hc-section-icon {
  color: #15803d;
  background: #e7f9ee;
}

.lawn-care-customer-page .hc-content-card p,
.lawn-care-customer-page .hc-content-card li,
.lawn-care-customer-page .hc-content-card table,
.lawn-care-customer-page .hc-faq-list summary,
.lawn-care-customer-page .hc-faq-list details p {
  font-size: 1.04rem;
}

.lc-related-links {
  padding: 0;
  margin: 0;
  list-style: none;
}

.lc-related-links li + li {
  border-top: 1px solid #e1eaf1;
}

.lc-related-links a {
  display: flex;
  min-height: 54px;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}

.lc-related-links .hc-icon {
  width: 17px;
  height: 17px;
}

.lc-guides-card {
  margin-top: 26px;
}

.lc-guide-links {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0 28px;
}

.lc-guides-button {
  margin-top: 20px;
  text-decoration: none;
}

.lawn-care-customer-page .hc-table-wrap {
  overflow-x: auto;
}

.lawn-care-customer-page .hc-table-wrap table {
  min-width: 560px;
}

.lawn-care-customer-page .hc-faq-card {
  margin-top: 26px;
  padding: 32px;
}

.lawn-care-customer-page .site-footer {
  padding: 56px 0 28px;
}

.lawn-care-customer-page .lc-footer-grid {
  display: grid;
  grid-template-columns: 1.4fr repeat(4, minmax(140px, 0.72fr));
  gap: 38px;
}

.lc-footer-bottom {
  padding-top: 24px;
  margin-top: 30px;
  border-top: 1px solid rgba(200, 224, 237, 0.18);
  color: #a9c0ce;
  font-size: 0.95rem;
  text-align: center;
}

@media (max-width: 1160px) {
  .lawn-care-customer-page .hc-hero-grid {
    grid-template-columns: minmax(0, 0.88fr) minmax(430px, 1.12fr);
    gap: 28px;
  }

  .lawn-care-customer-page .hc-hero-copy h1 {
    font-size: clamp(3rem, 5vw, 4.6rem);
  }

  .lc-hero-art {
    width: 100%;
    min-height: 420px;
  }

  .lc-yard-photo {
    height: 420px;
  }

  .lc-hero-summary {
    top: 54px;
    left: -5px;
    width: 174px;
    padding: 15px;
  }

  .lawn-care-customer-page .lc-footer-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .lawn-care-customer-page .lc-footer-grid > div:first-child {
    grid-column: 1 / -1;
  }
}

@media (max-width: 900px) {
  .lawn-care-customer-page .lc-content-card,
  .lawn-care-customer-page .lc-content-card:nth-child(4),
  .lawn-care-customer-page .lc-content-card:nth-child(5) {
    grid-column: span 3;
  }

  .lawn-care-customer-page .lc-content-card:last-child {
    grid-column: 1 / -1;
  }
}

@media (max-width: 820px) {
  .lawn-care-customer-page .hc-hero-grid {
    grid-template-columns: 1fr;
    gap: 28px;
  }

  .lc-hero-art {
    width: min(100%, 760px);
    min-height: 420px;
    margin: 0 auto;
  }

  .lc-yard-photo {
    height: 420px;
  }
}

@media (max-width: 720px) {
  .lc-hero-art {
    min-height: 390px;
  }

  .lc-yard-scene {
    height: 430px;
    border-radius: 32px;
  }

  .lc-yard-photo {
    height: 390px;
    border-radius: 32px;
  }

  .lc-hero-summary {
    top: 24px;
    left: 10px;
    width: 184px;
    padding: 16px;
  }

  .lawn-care-customer-page .lc-content-card,
  .lawn-care-customer-page .lc-content-card:nth-child(4),
  .lawn-care-customer-page .lc-content-card:nth-child(5) {
    grid-column: 1 / -1;
  }

  .lawn-care-customer-page .lc-footer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .lc-guide-links {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 560px) {
  .lawn-care-customer-page .hc-hero-copy h1 {
    font-size: clamp(3.25rem, 15vw, 4.15rem);
  }

  .lawn-care-customer-page .hc-hero-copy p {
    font-size: 1.08rem;
  }

  .lc-hero-art,
  .lc-yard-scene,
  .lc-yard-photo {
    min-height: 330px;
    height: 330px;
  }

  .lc-hero-summary {
    width: 184px;
  }

  .lc-hero-summary > strong {
    font-size: 1.8rem;
  }

  .lawn-care-customer-page .hc-faq-card {
    padding: 22px;
  }

  .lawn-care-customer-page .lc-footer-grid {
    grid-template-columns: 1fr;
  }

  .lawn-care-customer-page .lc-footer-grid > div:first-child {
    grid-column: auto;
  }
}
