@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600;9..144,700&family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap');

:root{
  --pine:#0F2E1E; --forest:#1E5631; --leaf:#2F8B4C; --moss:#6FA45C;
  --lime:#C6E84B; --lime-deep:#A9D628;
  --paper:#F1F4EC; --cream:#FBFAF3; --card:#FFFFFF;
  --ink:#162a1f; --muted:#5b6b60; --line:#dfe5d6;
  --clay:#D98E5A;
  --shadow:0 18px 40px -22px rgba(15,46,30,.45);
  --shadow-sm:0 8px 20px -14px rgba(15,46,30,.4);
}
*{box-sizing:border-box}
.bmg{font-family:'Plus Jakarta Sans',system-ui,sans-serif;color:var(--ink);
  background:var(--paper);line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:hidden}
.bmg h1,.bmg h2,.bmg h3,.bmg h4{font-family:'Fraunces',Georgia,serif;font-weight:600;line-height:1.05;letter-spacing:-.01em;margin:0}
.bmg p{margin:0}
.bmg a{color:inherit;text-decoration:none}
.wrap{max-width:1180px;margin:0 auto;padding:0 22px}
.eyebrow{font-size:.78rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--leaf);display:inline-flex;align-items:center;gap:8px}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--lime-deep)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:700;font-size:.95rem;
  border:none;cursor:pointer;border-radius:999px;padding:14px 24px;transition:.28s cubic-bezier(.2,.7,.3,1);font-family:inherit}
.btn-primary{background:var(--forest);color:var(--cream);box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--pine);transform:translateY(-2px)}
.btn-lime{background:var(--lime);color:var(--pine)}
.btn-lime:hover{background:var(--lime-deep);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--pine);border:1.5px solid var(--line)}
.btn-ghost:hover{border-color:var(--leaf);color:var(--forest);transform:translateY(-2px)}

/* nav */
.nav{position:fixed;inset:0 0 auto 0;z-index:60;transition:.35s}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:74px}
.nav.solid{background:rgba(251,250,243,.86);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line)}
.logo{display:flex;align-items:center;gap:10px;font-family:'Fraunces',serif;font-weight:700;font-size:1.22rem;color:var(--pine)}
.logo .mark{width:38px;height:38px;border-radius:12px;background:var(--forest);
  display:grid;place-items:center;color:var(--lime);box-shadow:var(--shadow-sm)}
.nav-links{display:flex;align-items:center;gap:4px}
.nav-link{padding:9px 15px;border-radius:999px;font-weight:600;font-size:.95rem;color:var(--ink);
  cursor:pointer;transition:.2s;background:transparent}
.nav-link:hover{background:rgba(47,139,76,.1);color:var(--forest)}
.nav-link.active{color:var(--forest)}
.nav-link.active::after{content:"";display:block;height:2px;border-radius:2px;background:var(--lime-deep);
  margin-top:3px;animation:grow .3s ease}
@keyframes grow{from{transform:scaleX(0)}to{transform:scaleX(1)}}
.nav-cta{display:flex;align-items:center;gap:14px}
.nav-phone{display:flex;align-items:center;gap:7px;font-weight:700;color:var(--pine);font-size:.95rem}
.burger{display:none;background:var(--forest);color:var(--cream);border:none;width:46px;height:46px;
  border-radius:12px;align-items:center;justify-content:center;cursor:pointer}

/* mobile drawer */
.drawer{position:fixed;inset:0;z-index:70;background:var(--pine);color:var(--cream);
  display:flex;flex-direction:column;padding:26px 24px;transform:translateX(100%);transition:.4s cubic-bezier(.2,.8,.2,1)}
.drawer.open{transform:translateX(0)}
.drawer a,.drawer button.dl{font-family:'Fraunces',serif;font-size:1.9rem;color:var(--cream);
  padding:14px 0;border-bottom:1px solid rgba(255,255,255,.12);text-align:left;background:none;border-top:none;border-left:none;border-right:none;cursor:pointer;width:100%}

/* hero */
.hero{position:relative;padding:128px 0 90px;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0;
  background:radial-gradient(120% 80% at 80% 0%,#dfeed0 0%,var(--paper) 55%)}
.hero-hills{position:absolute;left:0;right:0;bottom:0;z-index:0;width:100%;height:auto;display:block}
.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.hero h1{font-size:clamp(2.6rem,5.4vw,4.4rem);color:var(--pine)}
.hero h1 em{font-style:italic;color:var(--leaf)}
.hero-sub{margin-top:20px;font-size:1.12rem;color:var(--muted);max-width:34ch}
.hero-points{margin:24px 0 30px;display:grid;gap:11px}
.hero-points li{display:flex;align-items:center;gap:11px;font-weight:500}
.tick{width:24px;height:24px;border-radius:50%;background:var(--lime);color:var(--pine);
  display:grid;place-items:center;flex-shrink:0}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}

/* quote card */
.quote-card{position:relative;background:var(--card);border-radius:28px;padding:30px;
  box-shadow:var(--shadow);border:1px solid var(--line)}
.quote-card h3{font-size:1.5rem;color:var(--pine)}
.qc-row{display:flex;gap:10px;margin-top:18px}
.qc-input{flex:1;border:1.5px solid var(--line);border-radius:14px;padding:14px 16px;font-family:inherit;
  font-size:1rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;outline:none;transition:.2s;background:var(--cream)}
.qc-input:focus{border-color:var(--leaf);box-shadow:0 0 0 4px rgba(47,139,76,.12)}
.qc-result{margin-top:16px;padding:14px 16px;border-radius:14px;background:#eaf4dd;color:var(--forest);
  font-weight:600;display:flex;align-items:center;gap:10px;animation:rise .4s ease}
.qc-result.err{background:#fbe9e0;color:#b4561f}
.qc-foot{margin-top:16px;font-size:.84rem;color:var(--muted);display:flex;align-items:center;gap:8px}
.stars{display:inline-flex;gap:2px;color:#e8a33d}

/* trust strip */
.trust{background:var(--pine);color:var(--cream);padding:30px 0}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;text-align:center}
.trust .num{font-family:'Fraunces',serif;font-size:2.3rem;color:var(--lime);font-weight:600}
.trust .lbl{font-size:.9rem;opacity:.82;margin-top:2px}

/* sections */
.section{padding:88px 0;position:relative}
.section.alt{background:var(--cream)}
.section-head{max-width:640px;margin-bottom:46px}
.section-head h2{font-size:clamp(2rem,4vw,3rem);color:var(--pine);margin-top:14px}
.section-head p{margin-top:14px;color:var(--muted);font-size:1.08rem}

/* services grid */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.svc{background:var(--card);border:1px solid var(--line);border-radius:22px;padding:26px;
  cursor:pointer;transition:.3s cubic-bezier(.2,.7,.3,1);position:relative;overflow:hidden}
.svc::before{content:"";position:absolute;left:0;bottom:0;height:3px;width:0;background:var(--lime-deep);transition:.35s}
.svc:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:#cfe0c0}
.svc:hover::before{width:100%}
.svc .ic{width:54px;height:54px;border-radius:15px;background:#eaf4dd;color:var(--forest);
  display:grid;place-items:center;transition:.3s}
.svc:hover .ic{background:var(--forest);color:var(--lime);transform:rotate(-6deg)}
.svc h3{font-size:1.28rem;margin:18px 0 8px;color:var(--pine)}
.svc p{color:var(--muted);font-size:.96rem}
.svc .price{margin-top:16px;font-weight:700;color:var(--forest);display:flex;align-items:center;gap:6px}

/* steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;counter-reset:s}
.step{position:relative;padding:32px 26px;border-radius:22px;background:var(--card);border:1px solid var(--line)}
.step .n{font-family:'Fraunces',serif;font-size:2.6rem;color:var(--lime-deep);font-weight:700;line-height:1}
.step h3{font-size:1.3rem;margin:12px 0 8px;color:var(--pine)}
.step p{color:var(--muted)}
.step .arr{position:absolute;right:-26px;top:50%;color:var(--moss);z-index:2}

/* why / split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.why-list{display:grid;gap:18px;margin-top:26px}
.why-item{display:flex;gap:16px}
.why-item .ic{width:46px;height:46px;border-radius:13px;flex-shrink:0;display:grid;place-items:center;
  background:#eaf4dd;color:var(--forest)}
.why-item h4{font-size:1.12rem;color:var(--pine);margin-bottom:4px}
.why-item p{color:var(--muted);font-size:.96rem}
.why-visual{position:relative;border-radius:28px;overflow:hidden;min-height:430px;
  background:linear-gradient(160deg,#2f8b4c,#0f2e1e);box-shadow:var(--shadow);display:grid;place-items:center}

/* gallery */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.tile{border-radius:20px;overflow:hidden;position:relative;min-height:230px;cursor:pointer;
  border:1px solid var(--line);transition:.35s}
.tile:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.tile .cap{position:absolute;left:0;right:0;bottom:0;padding:18px;color:#fff;
  background:linear-gradient(transparent,rgba(15,46,30,.82));font-weight:600}
.tile .cap small{display:block;opacity:.85;font-weight:500;font-size:.8rem;margin-top:2px}

/* testimonials */
.tgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.tcard{background:var(--card);border:1px solid var(--line);border-radius:22px;padding:28px;position:relative;transition:.3s}
.tcard:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.tcard .q{color:var(--lime-deep);margin-bottom:8px}
.tcard p{color:var(--ink);font-size:1rem}
.tcard .who{margin-top:18px;display:flex;align-items:center;gap:12px}
.avatar{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:700;
  font-family:'Fraunces',serif;background:var(--leaf)}
.tcard .who b{display:block;color:var(--pine)}
.tcard .who small{color:var(--muted)}

/* areas */
.areas{display:flex;flex-wrap:wrap;gap:11px;margin-top:8px}
.chip{background:var(--card);border:1px solid var(--line);border-radius:999px;padding:10px 18px;
  font-weight:600;color:var(--pine);transition:.25s;cursor:default;display:flex;align-items:center;gap:7px}
.chip:hover{background:var(--forest);color:var(--cream);border-color:var(--forest);transform:translateY(-2px)}
.chip:hover svg{color:var(--lime)}

/* faq */
.faq{display:grid;gap:12px;max-width:780px}
.q-item{background:var(--card);border:1px solid var(--line);border-radius:16px;overflow:hidden}
.q-head{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:20px 22px;background:none;border:none;cursor:pointer;font-family:'Fraunces',serif;
  font-size:1.12rem;font-weight:600;color:var(--pine);text-align:left}
.q-head .chev{transition:.3s;flex-shrink:0;color:var(--leaf)}
.q-item.open .chev{transform:rotate(180deg)}
.q-body{max-height:0;overflow:hidden;transition:max-height .4s ease;color:var(--muted)}
.q-body .inner{padding:0 22px 22px}

/* big CTA */
.cta-band{background:var(--pine);border-radius:32px;padding:60px;position:relative;overflow:hidden;color:var(--cream)}
.cta-band h2{font-size:clamp(2rem,4vw,3.2rem);max-width:16ch;color:#fff}
.cta-band p{opacity:.85;margin-top:14px;max-width:46ch}
.cta-actions{margin-top:30px;display:flex;gap:14px;flex-wrap:wrap}
.cta-leaf{position:absolute;opacity:.16;color:var(--lime)}

/* footer */
.footer{background:var(--cream);border-top:1px solid var(--line);padding:64px 0 30px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:36px}
.foot-grid h5{font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:16px;font-family:'Plus Jakarta Sans',sans-serif;font-weight:700}
.foot-grid a{display:block;padding:6px 0;color:var(--ink);font-size:.95rem;transition:.2s}
.foot-grid a:hover{color:var(--forest);padding-left:5px}
.foot-bottom{margin-top:46px;padding-top:22px;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;color:var(--muted);font-size:.88rem}

/* page intro (subpages) */
.page-top{padding:128px 0 60px;background:radial-gradient(120% 90% at 80% -10%,#dfeed0,var(--paper));position:relative;overflow:hidden}
.page-top h1{font-size:clamp(2.4rem,5vw,3.8rem);color:var(--pine)}
.page-top p{margin-top:16px;color:var(--muted);font-size:1.1rem;max-width:52ch}

/* pricing */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:stretch}
.plan{background:var(--card);border:1px solid var(--line);border-radius:24px;padding:32px;display:flex;flex-direction:column;transition:.3s}
.plan:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.plan.feat{background:var(--pine);color:var(--cream);border-color:var(--pine)}
.plan.feat .amt,.plan.feat h3{color:#fff}
.plan .tag{font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--leaf)}
.plan.feat .tag{color:var(--lime)}
.plan h3{font-size:1.5rem;margin:6px 0 4px}
.amt{font-family:'Fraunces',serif;font-size:2.6rem;color:var(--pine);font-weight:700;margin:14px 0 6px}
.amt small{font-size:1rem;color:var(--muted);font-weight:500}
.plan ul{list-style:none;padding:0;margin:18px 0 26px;display:grid;gap:11px;flex:1}
.plan li{display:flex;gap:10px;font-size:.96rem}
.plan.feat li{color:#eaf3e6}
.plan li svg{color:var(--lime-deep);flex-shrink:0;margin-top:2px}
.plan.feat li svg{color:var(--lime)}

/* contact / book */
.book-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:start}
.form-card{background:var(--card);border:1px solid var(--line);border-radius:26px;padding:34px;box-shadow:var(--shadow-sm)}
.field{margin-bottom:16px}
.field label{display:block;font-weight:600;font-size:.9rem;margin-bottom:7px;color:var(--pine)}
.field input,.field select,.field textarea{width:100%;border:1.5px solid var(--line);border-radius:13px;
  padding:13px 15px;font-family:inherit;font-size:.98rem;outline:none;transition:.2s;background:var(--cream)}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--leaf);box-shadow:0 0 0 4px rgba(47,139,76,.12)}
.two{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.contact-side{display:grid;gap:14px}
.ci{display:flex;gap:14px;align-items:center;background:var(--card);border:1px solid var(--line);border-radius:18px;padding:20px}
.ci .ic{width:46px;height:46px;border-radius:13px;background:#eaf4dd;color:var(--forest);display:grid;place-items:center;flex-shrink:0}
.ci b{color:var(--pine)}.ci span{color:var(--muted);font-size:.92rem}
.success{text-align:center;padding:30px 0}
.success .ring{width:78px;height:78px;border-radius:50%;background:var(--lime);color:var(--pine);display:grid;place-items:center;margin:0 auto 18px;animation:pop .5s cubic-bezier(.2,1.4,.4,1)}

/* reveal + animations */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.3,1)}
.reveal.in{opacity:1;transform:none}
.page-enter{animation:rise .5s ease}
@keyframes rise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
@keyframes pop{0%{transform:scale(.5);opacity:0}100%{transform:scale(1);opacity:1}}
@keyframes sway{0%,100%{transform:rotate(-4deg)}50%{transform:rotate(5deg)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
.sway{transform-origin:bottom center;animation:sway 6s ease-in-out infinite}
.sway.s2{animation-duration:7.5s;animation-delay:-2s}
.sway.s3{animation-duration:5.5s;animation-delay:-1s}
.floaty{animation:float 7s ease-in-out infinite}
.to-top{position:fixed;right:22px;bottom:22px;z-index:50;width:48px;height:48px;border-radius:50%;
  background:var(--forest);color:var(--cream);border:none;cursor:pointer;display:grid;place-items:center;
  box-shadow:var(--shadow);opacity:0;pointer-events:none;transition:.3s}
.to-top.show{opacity:1;pointer-events:auto}

@media (max-width:920px){
  .hero-grid,.split,.book-grid{grid-template-columns:1fr;gap:34px}
  .svc-grid,.steps,.gallery,.tgrid,.price-grid{grid-template-columns:1fr 1fr}
  .trust-grid{grid-template-columns:1fr 1fr;gap:30px}
  .foot-grid{grid-template-columns:1fr 1fr}
  .nav-links,.nav-phone{display:none}.burger{display:flex}
  .step .arr{display:none}.cta-band{padding:40px 26px}
}
@media (max-width:560px){
  .svc-grid,.steps,.gallery,.tgrid,.price-grid,.foot-grid,.two,.qc-row{grid-template-columns:1fr}
  .qc-row{flex-direction:column}
  .section{padding:62px 0}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition-duration:.001s!important}
  .reveal{opacity:1;transform:none}
}

/* --- static-port helpers (Lucide icons + JS-driven states) --- */
.lucide{display:inline-block;vertical-align:middle;flex-shrink:0}
.bmg svg{display:inline-block}
.q-body{transition:max-height .4s ease}

/* --- brand logo mark (custom Book My Gardeners icon) --- */
.logo .mark{background:transparent;box-shadow:none;border-radius:0;width:40px;height:40px;
  display:grid;place-items:center;overflow:visible}
.logo .mark .brand-icon{width:40px;height:40px;display:block}
