/* Home Service One — consumer marketplace site (homeserviceone.com)
   Mirrors CleanSlate One's consumer landing (find-a-pro + search), restyled to the
   HSO green "property health" brand with a teal "systems" accent. Static, no build. */

:root {
  --green-900:#0f3d24; --green-800:#15532f; --green-700:#1b6e3f; --green-600:#1f8a4c;
  --green-500:#34a85f; --green-300:#7bd39b; --green-50:#eaf6ee;
  --teal-700:#0e6e63; --teal-600:#12897b; --teal-50:#e6f4f1;
  --ink:#16241c; --muted:#5d6b62; --faint:#90a097;
  --line:#e4eae5; --surface:#f5f8f5; --card:#fff;
  --shadow:0 18px 44px rgba(15,61,36,.12);
  --shadow-sm:0 8px 22px rgba(15,61,36,.08);
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --grad:linear-gradient(95deg,var(--green-800),var(--green-500));
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--surface);
  line-height:1.55;-webkit-font-smoothing:antialiased;font-size:16px}
a{color:inherit;text-decoration:none}
img,svg{display:block}
.wrap{max-width:1180px;margin:0 auto;padding:48px 24px 0}
h1,h2,h3{letter-spacing:-.02em;line-height:1.06;font-weight:800}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;gap:9px;border-radius:999px;font-weight:700;
  font-size:15px;padding:13px 22px;transition:.18s;cursor:pointer;border:1.6px solid transparent;white-space:nowrap}
.btn-grad{background:var(--grad);color:#fff;box-shadow:var(--shadow-sm)}
.btn-grad:hover{filter:brightness(1.07);transform:translateY(-1px)}
.btn-light{background:#fff;color:var(--green-800)}
.btn-light:hover{transform:translateY(-1px)}
.arrow{transition:transform .18s}
.btn:hover .arrow{transform:translateX(3px)}

/* ---- header ---- */
.mkt-head{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:12px;
  background:#fff;border-bottom:1px solid var(--line);padding:13px 36px}
.lock{display:inline-flex;align-items:center;gap:11px}
.lock .mark{width:38px;height:38px;border-radius:10px;background:var(--green-700);color:#fff;
  display:grid;place-items:center;font-size:21px;flex:0 0 auto}
.lock .mark i{line-height:1}
.lock-text{display:flex;flex-direction:column;line-height:1.15}
.lock .word{font-weight:820;font-size:18px;letter-spacing:.01em;color:var(--ink)}
.lock .sub{font-size:12px;color:var(--muted)}
.head-cta{margin-left:auto;display:flex;align-items:center;gap:14px}
.hlink{font-size:13.5px;font-weight:650;color:var(--muted)}
.hlink:hover{color:var(--green-700)}
.hbtn{border:1.5px solid var(--green-300);background:#fff;color:var(--green-700);
  border-radius:999px;padding:10px 18px;font-size:13.5px;font-weight:650;transition:.18s}
.hbtn:hover{border-color:var(--green-700)}

/* ---- hero / search ---- */
.hero{padding:64px 24px 60px;
  background:radial-gradient(120% 130% at 50% -20%,#e2f3ea 0%,transparent 50%),
             linear-gradient(135deg,#eef6f0 0%,#f2f5f2 55%,#e9f4ee 100%)}
.hero-in{max-width:820px;margin:0 auto;text-align:center}
.eyebrow{font-size:13px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--green-700);margin-bottom:14px}
.hero h1{font-size:clamp(36px,5vw,56px);margin-bottom:16px}
.accent{color:var(--teal-700)}
.lede{color:#3f4a43;font-size:17px;max-width:560px;margin:0 auto 30px}

.search{display:flex;gap:10px;max-width:720px;margin:0 auto;background:#fff;
  border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:10px}
.search-field,.search-zip{display:flex;align-items:center;gap:9px;background:var(--surface);
  border:1px solid var(--line);border-radius:11px;padding:0 13px}
.search-field{flex:1;position:relative}

/* service autocomplete */
.ac{position:absolute;top:calc(100% + 8px);left:0;right:0;background:#fff;border:1px solid var(--line);
  border-radius:12px;box-shadow:var(--shadow);padding:6px;margin:0;list-style:none;z-index:30;
  max-height:300px;overflow-y:auto;text-align:left}
.ac li{padding:10px 12px;border-radius:8px;font-size:14.5px;cursor:pointer;color:var(--ink)}
.ac li:hover,.ac li.active{background:var(--green-50);color:var(--green-700)}
.search-zip{width:130px}
.search i{color:var(--muted);font-size:18px}
.search input{border:none;background:none;outline:none;font:inherit;font-size:15px;
  color:var(--ink);width:100%;padding:13px 0}
.search .btn{padding:13px 22px}

/* single-service search (per-service page) */
.svc-search{max-width:420px}
.svc-search .search-zip{flex:1;width:auto}

/* sub-service chips + back link */
.chips{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin-top:22px}
.chip{border:1px solid var(--line);background:#fff;border-radius:999px;padding:7px 14px;
  font-size:12.5px;color:var(--muted)}
.back{display:inline-block;margin-top:22px;font-size:13.5px;font-weight:650;color:var(--green-700)}
.back:hover{color:var(--green-900)}

/* quick category tiles */
.cat-grid{display:grid;gap:12px;max-width:760px;margin:26px auto 0;
  grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}
.cat{display:flex;flex-direction:column;align-items:center;gap:9px;background:#fff;
  border:1px solid var(--line);border-radius:16px;padding:18px 12px;transition:.18s;font-size:13.5px;font-weight:650}
.cat:hover{border-color:var(--green-300);box-shadow:var(--shadow-sm);transform:translateY(-2px)}
.cat-ic{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;
  background:var(--green-50);color:var(--green-700);transition:.18s}
.cat:hover .cat-ic{background:var(--green-700);color:#fff}
.cat-ic i{font-size:22px;line-height:1}

/* ---- section headers ---- */
.kicker{font-size:12px;font-weight:800;letter-spacing:.13em;text-transform:uppercase;color:var(--green-700);margin-bottom:8px}
.sec-h2{font-size:26px}

/* all services grid */
.svc-grid{display:grid;gap:12px;margin-top:20px;grid-template-columns:repeat(auto-fit,minmax(245px,1fr))}
.svc{display:flex;align-items:center;gap:13px;background:#fff;border:1px solid var(--line);
  border-radius:14px;padding:16px;transition:.18s;cursor:pointer}
.svc:hover{border-color:var(--green-300);box-shadow:var(--shadow-sm)}
.svc-ic{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;
  background:var(--green-50);color:var(--green-700);flex:0 0 auto}
.svc-ic i{font-size:21px;line-height:1}
.svc-t{font-size:14.5px;font-weight:700}
.svc-d{font-size:12.5px;color:var(--muted)}

/* how it works */
.steps3{display:grid;gap:14px;margin-top:20px;grid-template-columns:repeat(auto-fit,minmax(230px,1fr))}
.step3{background:#fff;border:1px solid var(--line);border-radius:18px;padding:20px}
.step3 .num{width:30px;height:30px;border-radius:50%;background:var(--green-700);color:#fff;
  display:grid;place-items:center;font-size:14px;font-weight:800;margin-bottom:11px}
.step3 b{font-size:15px}
.step3 p{margin-top:5px;font-size:13px;color:var(--muted)}

/* provider band */
.provider{margin-top:60px;background:var(--green-900);color:#dceae2;padding:48px 24px}
.provider-in{max-width:1180px;margin:0 auto;display:flex;flex-wrap:wrap;align-items:center;gap:30px}
.provider-in > div{flex:1;min-width:280px}
.provider h2{color:#fff;font-size:24px;margin-bottom:7px}
.provider p{font-size:14px;color:#bcd4c5;max-width:640px}

/* footer */
.mkt-foot{text-align:center;padding:40px 24px;background:#fff;border-top:1px solid var(--line)}
.mkt-foot .word{font-weight:800;color:var(--ink)}
.foot-links{display:flex;gap:22px;justify-content:center;flex-wrap:wrap;margin:14px 0 12px}
.foot-links a{font-size:13.5px;color:var(--muted)}
.foot-links a:hover{color:var(--green-700)}
.foot-meta{font-size:12.5px;color:var(--faint)}

/* request-quotes popup */
.lead-backdrop{position:fixed;inset:0;background:rgba(15,30,20,.5);z-index:100;display:flex;
  align-items:flex-start;justify-content:center;padding:40px 16px;overflow-y:auto}
.lead-backdrop[hidden]{display:none}
.lead-card{position:relative;background:#fff;border-radius:18px;width:100%;max-width:480px;
  box-shadow:0 30px 70px rgba(0,0,0,.3);padding:26px}
.lead-close{position:absolute;top:12px;right:14px;border:none;background:none;font-size:26px;
  line-height:1;color:var(--faint);cursor:pointer}
.lead-close:hover{color:var(--ink)}
.lead-form-wrap h3,.lead-thanks h3{font-size:21px;margin:0}
.lead-sub{font-size:13.5px;color:var(--muted);margin:5px 0 16px}
.lf-row{display:flex;gap:12px}
.lf-field{flex:1;margin-bottom:12px;min-width:0}
.lf-field label{display:block;font-size:12px;font-weight:650;color:var(--ink);margin-bottom:5px}
.lf-field input{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:9px;
  font-family:inherit;font-size:14px;background:#fff}
.lf-field input:focus{outline:none;border-color:var(--green-600)}
.lf-field input[readonly]{background:var(--surface);color:var(--muted)}
.lf-zip,.lf-st{flex:0 0 110px}
.lf-error{color:#b3261e;font-size:13px;margin:2px 0 10px}
.lf-submit{width:100%;justify-content:center;margin-top:4px}
.lf-fine{font-size:11.5px;color:var(--faint);text-align:center;margin-top:12px}
.lead-thanks{text-align:center;padding:18px 6px}
.lead-check{width:56px;height:56px;border-radius:50%;background:var(--green-50);color:var(--green-600);
  display:grid;place-items:center;font-size:30px;margin:0 auto 14px}
.lead-thanks p{color:var(--muted);font-size:15px;margin:10px 0 22px;max-width:360px;margin-left:auto;margin-right:auto}
.lead-done{justify-content:center}

@media(max-width:620px){
  .lf-row{flex-direction:column;gap:0}
  .lf-zip,.lf-st{flex:1}
  .mkt-head{padding:12px 18px}
  .lock .sub{display:none}
  .search{flex-direction:column}
  .search-zip{width:100%}
  .head-cta .hlink{display:none}
}
