/* ============ Gordon McHardy Sprinkler Repair — Fresh Green Organic / Water motif ============ */
:root{
  --green:#2f9e44;
  --green-deep:#1f7a33;
  --green-soft:#d8f3df;
  --sky:#3ba9e0;
  --sky-deep:#1b87c0;
  --sky-soft:#dbf0fb;
  --ink:#16321f;
  --muted:#4b6354;
  --bg:#ffffff;
  --tint:#f3fbf5;
  --line:#e3efe7;
  --radius:18px;
  --radius-lg:26px;
  --shadow:0 10px 30px rgba(31,122,51,.10);
  --shadow-sm:0 4px 14px rgba(31,122,51,.08);
  --wrap:1120px;
  --font-head:"Fraunces",Georgia,serif;
  --font-body:"Nunito",system-ui,-apple-system,"Segoe UI",sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%}
a{color:var(--green-deep);text-decoration:none}

.wrap{width:100%;max-width:var(--wrap);margin:0 auto;padding:0 20px}

.skip-link{
  position:absolute;left:-999px;top:0;background:var(--green);color:#fff;
  padding:10px 16px;border-radius:0 0 10px 0;z-index:200;font-weight:700;
}
.skip-link:focus{left:0}

:focus-visible{outline:3px solid var(--sky-deep);outline-offset:2px;border-radius:6px}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  min-height:48px;padding:13px 24px;border-radius:999px;
  font-family:var(--font-body);font-weight:800;font-size:1rem;
  cursor:pointer;border:none;transition:transform .15s ease,box-shadow .2s ease,background .2s ease;
  text-align:center;line-height:1.1;
}
.btn-primary{background:var(--green);color:#fff;box-shadow:0 8px 20px rgba(47,158,68,.35)}
.btn-primary:hover{background:var(--green-deep);transform:translateY(-2px)}
.btn-ghost{background:#fff;color:var(--green-deep);border:2px solid var(--green-soft)}
.btn-ghost:hover{border-color:var(--green);transform:translateY(-2px)}
.btn-sm{min-height:44px;padding:11px 20px;font-size:.95rem}
.btn-block{width:100%}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid var(--line);
  transition:box-shadow .25s ease;
}
.site-header.scrolled{box-shadow:0 6px 18px rgba(31,122,51,.10)}
.header-inner{display:flex;align-items:center;gap:12px;min-height:64px}
.logo{display:flex;align-items:center;gap:10px;flex:1;min-width:0}
.logo-mark{flex:none}
.logo-text{display:flex;flex-direction:column;line-height:1.05;min-width:0}
.logo-text strong{font-family:var(--font-head);font-size:1.05rem;color:var(--ink)}
.logo-text small{font-size:.72rem;color:var(--muted);font-weight:700;letter-spacing:.01em}

.desktop-nav{display:none}
.header-call{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--green-soft);color:var(--green-deep);
  font-weight:800;padding:10px 16px;border-radius:999px;min-height:44px;
}
.header-call:hover{background:var(--green);color:#fff}

@media(min-width:860px){
  .desktop-nav{display:flex;align-items:center;gap:22px}
  .desktop-nav a{color:var(--ink);font-weight:700;font-size:.98rem}
  .desktop-nav a:hover{color:var(--green-deep)}
  .nav-cta{background:var(--green);color:#fff!important;padding:11px 20px;border-radius:999px}
  .nav-cta:hover{background:var(--green-deep)}
  .header-call{margin-left:4px}
  .logo{flex:none;margin-right:auto}
}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;padding:0;background:#f3fbf5}
.hero-sky{position:absolute;inset:0;z-index:0}
.spray-svg{width:100%;height:100%}
.hero-grass{position:absolute;left:0;right:0;bottom:0;z-index:1;line-height:0}
.hero-grass svg{width:100%;height:90px}
.hero-content{
  position:relative;z-index:2;
  padding:40px 20px 120px;
  max-width:680px;
}
.badge{
  display:inline-block;background:#fff;color:var(--green-deep);
  border:1px solid var(--green-soft);border-radius:999px;
  padding:7px 15px;font-weight:800;font-size:.82rem;box-shadow:var(--shadow-sm);
}
.hero h1{
  font-family:var(--font-head);font-weight:700;
  font-size:clamp(2rem,8.4vw,3.4rem);line-height:1.06;
  margin:.5em 0 .3em;color:var(--ink);letter-spacing:-.01em;
}
.hero h1 .hl{color:var(--sky-deep)}
.hero-sub{font-size:1.06rem;color:var(--muted);max-width:46ch;margin:0 0 1.4em}
.hero-cta{display:flex;flex-wrap:wrap;gap:12px}
.hero-cta .btn{flex:1 1 auto;min-width:160px}
.hero-trust{
  list-style:none;margin:1.6em 0 0;padding:0;display:flex;flex-direction:column;gap:9px;
}
.hero-trust li{display:flex;align-items:center;gap:9px;font-weight:700;color:var(--ink);font-size:.95rem}
.hero-trust svg{color:var(--green);flex:none}

@media(min-width:680px){
  .hero-cta .btn{flex:0 0 auto}
  .hero-trust{flex-direction:row;flex-wrap:wrap;gap:9px 22px}
}

/* ---------- Sections ---------- */
.section{padding:64px 0}
.section-tint{background:var(--tint)}
.eyebrow{
  text-transform:uppercase;letter-spacing:.12em;font-weight:800;
  font-size:.78rem;color:var(--green);margin:0 0 .5em;
}
.section h2{
  font-family:var(--font-head);font-weight:700;
  font-size:clamp(1.6rem,5.4vw,2.4rem);line-height:1.12;
  margin:0 0 .4em;color:var(--ink);letter-spacing:-.01em;
}
.section-lead{font-size:1.05rem;color:var(--muted);max-width:62ch;margin:0 0 2em}

/* ---------- Services cards ---------- */
.card-grid{display:grid;grid-template-columns:1fr;gap:16px}
.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:26px 22px;box-shadow:var(--shadow-sm);transition:transform .2s ease,box-shadow .2s ease;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card-ico{display:block;margin-bottom:12px}
.card h3{font-family:var(--font-head);font-size:1.25rem;margin:0 0 .35em;color:var(--ink)}
.card p{margin:0;color:var(--muted);font-size:.98rem}
.card-cta{background:linear-gradient(150deg,var(--green-soft),var(--sky-soft));border:none;display:flex;flex-direction:column;justify-content:center}
.card-cta h3{color:var(--green-deep)}
.card-cta .btn{margin-top:14px;align-self:flex-start}

@media(min-width:620px){.card-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:980px){.card-grid{grid-template-columns:repeat(3,1fr)}}

/* ---------- Why ---------- */
.why-grid{display:grid;grid-template-columns:1fr;gap:18px}
.why-item{
  background:#fff;border-radius:var(--radius);padding:24px 22px;
  border:1px solid var(--line);box-shadow:var(--shadow-sm);
}
.why-ico{font-size:1.8rem;display:block;margin-bottom:8px}
.why-item h3{font-family:var(--font-head);font-size:1.18rem;margin:0 0 .3em}
.why-item p{margin:0;color:var(--muted);font-size:.97rem}
@media(min-width:720px){.why-grid{grid-template-columns:repeat(2,1fr)}}

/* ---------- Process ---------- */
.steps{list-style:none;margin:0;padding:0;display:grid;gap:18px;counter-reset:s}
.step{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:24px 22px 24px 70px;position:relative;box-shadow:var(--shadow-sm);
}
.step-num{
  position:absolute;left:20px;top:24px;width:38px;height:38px;border-radius:50%;
  background:var(--green);color:#fff;font-weight:800;font-size:1.15rem;
  display:flex;align-items:center;justify-content:center;box-shadow:0 6px 14px rgba(47,158,68,.35);
}
.step h3{font-family:var(--font-head);font-size:1.15rem;margin:0 0 .3em}
.step p{margin:0;color:var(--muted);font-size:.97rem}
@media(min-width:820px){.steps{grid-template-columns:repeat(3,1fr)}}

/* ---------- About ---------- */
.about-grid{display:grid;gap:28px;align-items:center}
.about-art{max-width:360px;margin:0 auto}
.about-copy p{color:var(--muted);margin:0 0 1em}
.about-stats{display:flex;flex-wrap:wrap;gap:14px 26px;margin-top:18px}
.about-stats div{display:flex;flex-direction:column}
.about-stats strong{font-family:var(--font-head);font-size:1.9rem;color:var(--green);line-height:1}
.about-stats span{font-size:.85rem;color:var(--muted);font-weight:700;max-width:14ch}
@media(min-width:820px){.about-grid{grid-template-columns:.85fr 1.15fr;gap:40px}}

/* ---------- Reviews ---------- */
.review-grid{display:grid;grid-template-columns:1fr;gap:16px}
.review{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:24px 22px;margin:0;box-shadow:var(--shadow-sm);
}
.stars{color:#f4b400;font-size:1.1rem;letter-spacing:2px;margin-bottom:8px}
.review blockquote{margin:0 0 .8em;font-size:1rem;color:var(--ink);font-weight:600}
.review figcaption{font-size:.85rem;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.review-note{font-size:.85rem;color:var(--muted);margin-top:16px;font-style:italic}
@media(min-width:820px){.review-grid{grid-template-columns:repeat(3,1fr)}}

/* ---------- Service area ---------- */
.area-grid{display:grid;gap:28px;align-items:center}
.area-copy p{color:var(--muted)}
.area-list{list-style:none;display:flex;flex-wrap:wrap;gap:8px;padding:0;margin:18px 0}
.area-list li{
  background:#fff;border:1px solid var(--green-soft);color:var(--green-deep);
  font-weight:700;padding:8px 14px;border-radius:999px;font-size:.92rem;
}
.area-map{max-width:380px;margin:0 auto}
@media(min-width:820px){.area-grid{grid-template-columns:1.1fr .9fr;gap:40px}}

/* ---------- Contact ---------- */
.section-contact{background:linear-gradient(170deg,var(--tint),#eaf7fb)}
.contact-grid{display:grid;gap:28px;align-items:start}
.contact-intro p{color:var(--muted)}
.contact-list{list-style:none;padding:0;margin:18px 0}
.contact-list li{display:flex;gap:12px;align-items:flex-start;margin-bottom:14px}
.ci{font-size:1.3rem;flex:none;line-height:1.3}
.contact-list a{font-weight:800;color:var(--green-deep)}
.lic-note{font-size:.85rem;color:var(--muted);font-weight:700;margin-top:8px}

.quote-form{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:26px 22px;box-shadow:var(--shadow);
}
.form-title{font-family:var(--font-head);font-size:1.3rem;margin:0 0 1em;color:var(--ink)}
.field{margin-bottom:14px}
.field label{display:block;font-weight:700;font-size:.92rem;margin-bottom:5px;color:var(--ink)}
.field .opt{font-weight:600;color:var(--muted);font-size:.85em}
.field input,.field select,.field textarea{
  width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:12px;
  font-family:var(--font-body);font-size:1rem;background:#fcfefc;color:var(--ink);min-height:48px;
  transition:border-color .15s ease,box-shadow .15s ease;
}
.field textarea{min-height:auto;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(47,158,68,.15);
}
.field input:invalid:not(:placeholder-shown){border-color:#e06666}
.form-fine{font-size:.8rem;color:var(--muted);margin:.8em 0 0;text-align:center}
.form-status{margin:.8em 0 0;font-weight:800;text-align:center;color:var(--green-deep)}
.form-status.show{padding:12px;background:var(--green-soft);border-radius:12px}
@media(min-width:820px){.contact-grid{grid-template-columns:1fr 1.05fr;gap:40px}}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);color:#cfe6d6;padding:48px 0 96px}
.footer-inner{display:grid;gap:26px}
.foot-brand strong{font-family:var(--font-head);font-size:1.2rem;color:#fff;display:block;margin-bottom:.4em}
.foot-brand p{margin:0 0 .5em;font-size:.95rem;color:#a9cbb4}
.foot-lic{font-weight:700;color:#cfe6d6!important}
.foot-links{display:flex;flex-wrap:wrap;gap:14px 20px}
.foot-links a{color:#cfe6d6;font-weight:700}
.foot-links a:hover{color:#fff}
.foot-contact{display:flex;flex-direction:column;gap:6px}
.foot-contact a{color:#fff;font-weight:800}
.foot-contact span{color:#a9cbb4;font-size:.9rem}
.copyright{text-align:center;color:#86ab92;font-size:.85rem;margin:28px 0 0;padding-top:18px;border-top:1px solid rgba(255,255,255,.08)}
@media(min-width:820px){.footer-inner{grid-template-columns:1.6fr 1fr 1fr}.site-footer{padding-bottom:56px}}

/* ---------- Sticky mobile CTA ---------- */
.mobile-cta{
  position:fixed;left:0;right:0;bottom:0;z-index:90;
  display:flex;gap:10px;padding:10px 14px calc(10px + env(safe-area-inset-bottom));
  background:rgba(255,255,255,.96);backdrop-filter:blur(8px);
  border-top:1px solid var(--line);box-shadow:0 -6px 18px rgba(31,122,51,.10);
}
.mobile-cta a{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:48px;border-radius:999px;font-weight:800;font-size:1rem}
.mc-quote{background:var(--green);color:#fff}
.mc-call{background:var(--sky);color:#fff}
@media(min-width:860px){.mobile-cta{display:none}.site-footer{padding-bottom:56px}}

/* ---------- Reveal animations ---------- */
.reveal{opacity:0;transform:translateY(24px)}
.reveal.in{opacity:1;transform:none;transition:opacity .6s ease,transform .6s ease}

/* ---------- Hero motion ---------- */
.arc{stroke-dasharray:260;stroke-dashoffset:260;animation:spray 4.2s ease-in-out infinite}
.a2{animation-delay:.5s}.a3{animation-delay:1s}.a4{animation-delay:1.5s}
@keyframes spray{
  0%{stroke-dashoffset:260;opacity:0}
  18%{opacity:.9}
  55%{stroke-dashoffset:0;opacity:.9}
  85%{opacity:0}
  100%{stroke-dashoffset:0;opacity:0}
}
.drops circle{animation:drop 3.4s ease-in infinite;opacity:0}
.d2{animation-delay:.6s}.d3{animation-delay:1.1s}.d4{animation-delay:1.7s}.d5{animation-delay:2.2s}
@keyframes drop{
  0%{transform:translateY(-14px);opacity:0}
  30%{opacity:.85}
  100%{transform:translateY(34px);opacity:0}
}
.cloud{animation:float 9s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateX(0)}50%{transform:translateX(16px)}}
.blade{transform-origin:bottom center;animation:sway 4.5s ease-in-out infinite}
.b2{animation-delay:.4s}.b3{animation-delay:.8s}.b4{animation-delay:1.2s}.b5{animation-delay:.6s}
@keyframes sway{0%,100%{transform:rotate(-3deg)}50%{transform:rotate(4deg)}}
.pin{animation:pinpulse 2.6s ease-in-out infinite;transform-origin:150px 130px}
@keyframes pinpulse{0%,100%{transform:scale(1)}50%{transform:scale(1.12)}}

@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition:none!important}
  .reveal{opacity:1!important;transform:none!important}
  .arc{stroke-dashoffset:0;opacity:.8}
}
