/* ============================================================
   GREEN LIFE LANDSCAPE SERVICES LLC
   Brand: #8CCB12 (green-bright) | #2F7A16 (green-dark) | #0a0a0a | #fff
   Fonts: Oswald (headings) + Open Sans (body)
   ============================================================ */

/* ── Reset ──────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Open Sans',sans-serif;background:#0d0d0d;color:#e0e0e0;line-height:1.6;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}

/* ── CSS Variables ──────────────────────────────────────── */
:root{
  --green-bright:#8CCB12;
  --green-dark:#2F7A16;
  --dark:#0d0d0d;
  --dark-2:#111;
  --dark-3:#161616;
  --off-white:#f5f5f0;
  --gray:#888;
  --font-head:'Oswald',sans-serif;
  --font-body:'Open Sans',sans-serif;
  --ease:all .25s cubic-bezier(.4,0,.2,1);
  --shadow-xl:0 20px 60px rgba(0,0,0,.35);
  --radius:6px;
}

/* ── Custom Cursor ──────────────────────────────────────── */
@media(pointer:fine){
  *{cursor:none!important}
}
#cursor{
  width:12px;height:12px;
  background:var(--green-bright);
  border-radius:50%;
  position:fixed;top:0;left:0;
  pointer-events:none;z-index:999999;
  transform:translate(-50%,-50%);
  transition:width .12s ease,height .12s ease,background .12s ease,opacity .12s;
  mix-blend-mode:normal;
  box-shadow:0 0 8px rgba(140,203,18,.6);
}
#cursor-ring{
  width:38px;height:38px;
  border:2px solid rgba(140,203,18,.8);
  border-radius:50%;
  position:fixed;top:0;left:0;
  pointer-events:none;z-index:999998;
  transform:translate(-50%,-50%);
  transition:width .18s ease,height .18s ease,border-color .18s;
}
#cursor.hover{width:8px;height:8px;background:#fff;box-shadow:0 0 10px rgba(255,255,255,.5)}
#cursor-ring.hover{width:52px;height:52px;border-color:var(--green-bright);border-width:1.5px}
#cursor.clicking{transform:translate(-50%,-50%) scale(.8)}

/* ── Typography ─────────────────────────────────────────── */
h1,h2,h3,h4{font-family:var(--font-head);line-height:1.12;color:#fff;font-weight:700}
.sec-h2{font-size:clamp(1.9rem,3.5vw,2.8rem);text-transform:uppercase;letter-spacing:.5px}
.sec-h2.dark{color:#111}
.sec-h2.white{color:#fff}
.sec-sub{color:#888;font-size:.95rem;line-height:1.7;max-width:580px}
.sec-sub.white{color:rgba(255,255,255,.65)}
.tag-pill{
  display:inline-block;
  font-family:var(--font-head);
  font-size:.72rem;letter-spacing:3px;text-transform:uppercase;
  color:var(--green-bright);margin-bottom:.6rem;
}
.tag-pill.light{color:rgba(255,255,255,.5)}
.text-gb{color:var(--green-bright)}
.sec-head{margin-bottom:3rem}
.sec-head .sec-sub{margin-top:.75rem}

/* ── Layout ─────────────────────────────────────────────── */
.container{max-width:1180px;margin:0 auto;padding:0 1.5rem}

/* ── Buttons ─────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-head);
  font-size:.85rem;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;
  padding:14px 34px;border-radius:3px;
  transition:var(--ease);border:2px solid transparent;
  white-space:nowrap;
}
.btn-green{background:var(--green-bright);color:#000;border-color:var(--green-bright)}
.btn-green:hover{background:var(--green-dark);color:#fff;border-color:var(--green-dark);transform:translateY(-2px);box-shadow:0 6px 22px rgba(140,203,18,.3)}
.btn-nav{background:var(--green-bright);color:#000;border-color:var(--green-bright);padding:10px 22px;font-size:.78rem}
.btn-nav:hover{background:var(--green-dark);color:#fff;border-color:var(--green-dark)}
.btn-outline-dark{background:transparent;color:#111;border-color:#ccc}
.btn-outline-dark:hover{background:#111;color:#fff;border-color:#111;transform:translateY(-2px)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.4)}
.btn-ghost:hover{background:#fff;color:#000;border-color:#fff;transform:translateY(-2px)}

/* ── Topbar ──────────────────────────────────────────────── */
.topbar{background:var(--green-dark);padding:.42rem 0;font-size:.72rem;font-family:var(--font-head)}
.topbar-wrap{display:flex;justify-content:space-between;align-items:center;gap:.5rem;flex-wrap:wrap}
.topbar-left{display:flex;align-items:center;gap:.7rem;flex-wrap:wrap}
.topbar-left a,.topbar-left span{color:rgba(255,255,255,.85);letter-spacing:.6px;transition:color .2s}
.topbar-left a:hover{color:#fff}
.tb-div{opacity:.35}
.tb-dot{opacity:.35}
.tb-areas-label{opacity:.5;font-size:.68rem;letter-spacing:1px}
.topbar-right{display:flex;align-items:center;gap:.75rem}
.topbar-right a{color:rgba(255,255,255,.7);transition:color .2s;display:flex;align-items:center}
.topbar-right a:hover{color:#fff}
@media(max-width:768px){.topbar-left>*:nth-child(n+8){display:none}.topbar-right{display:none}}

/* ── Header / Nav ────────────────────────────────────────── */
.site-header{
  position:fixed;top:29px;left:0;right:0;z-index:900;
  padding:0;transition:background .35s,box-shadow .35s;
}
.site-header.scrolled{background:rgba(10,10,10,.97);backdrop-filter:blur(14px);box-shadow:0 2px 24px rgba(0,0,0,.5)}
/* When topbar hides on scroll, header moves to top */
body.topbar-hidden .site-header{top:0}
.site-nav{
  display:flex;align-items:center;justify-content:space-between;
  padding:1rem 1.5rem;max-width:1180px;margin:0 auto;
}
.nav-logo-wrap{display:flex;align-items:center;gap:.7rem}
.nav-logo-img{height:50px;width:auto;transition:opacity .2s}
.nav-logo-img:hover{opacity:.85}
.nav-logo-name{display:block;font-family:var(--font-head);font-size:1.1rem;font-weight:700;color:#fff;letter-spacing:.5px;line-height:1.2}
.nav-logo-sub{display:block;font-size:.62rem;color:var(--green-bright);letter-spacing:2px;text-transform:uppercase}
.nav-links-list{display:flex;align-items:center;gap:.1rem}
.nav-links-list li{position:relative}
.nav-links-list a{
  font-family:var(--font-head);font-size:.8rem;letter-spacing:1.2px;text-transform:uppercase;
  color:rgba(255,255,255,.75);padding:.5rem .9rem;
  border-radius:3px;transition:color .2s;display:block;
}
.nav-links-list a:hover,.nav-links-list a.active{color:var(--green-bright)}
.has-drop{position:relative}
.has-drop>a::after{content:' ▾';font-size:.65rem}
.nav-drop{
  display:block;
  visibility:hidden;opacity:0;
  pointer-events:none;
  position:absolute;top:100%;left:0;
  /* padding-top creates invisible bridge so mouse doesn't lose hover */
  padding-top:8px;
  background:transparent;
  min-width:210px;z-index:9999;
  /* delay on hide = 150ms grace period */
  transition:opacity .15s ease 0.15s, visibility .15s ease 0.15s;
}
.nav-drop-inner{
  background:#111;border:1px solid #222;border-radius:4px;
  padding:.5rem 0;
  box-shadow:0 12px 40px rgba(0,0,0,.5);
}
.nav-drop a{
  font-size:.75rem;letter-spacing:.8px;color:#bbb;
  padding:.55rem 1rem;display:block;border-radius:0;
  transition:color .15s, background .15s;
}
.nav-drop a:hover{color:var(--green-bright);background:#181818}
/* Show on hover — no delay on show */
.has-drop:hover .nav-drop{
  visibility:visible;opacity:1;pointer-events:auto;
  transition:opacity .12s ease 0s, visibility .12s ease 0s;
}
.nav-drop a{font-size:.75rem;letter-spacing:.8px;color:#bbb;padding:.55rem 1rem;display:block;border-radius:0}
.nav-drop a:hover{color:var(--green-bright);background:#181818}
.nav-right{display:flex;align-items:center;gap:.75rem}
.nav-phone{font-family:var(--font-head);font-size:.88rem;color:var(--green-bright);letter-spacing:.8px;display:flex;align-items:center;gap:.4rem;transition:opacity .2s}
.nav-phone:hover{opacity:.85}
.ham-btn{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:6px}
.ham-btn span{display:block;width:22px;height:2px;background:#fff;border-radius:2px;transition:var(--ease)}
.ham-btn.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.ham-btn.open span:nth-child(2){opacity:0}
.ham-btn.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ── Mobile Menu ─────────────────────────────────────────── */
.mob-menu{
  display:none;flex-direction:column;
  position:fixed;top:0;right:-100%;width:min(320px,90vw);height:100vh;
  background:#0f0f0f;border-left:1px solid #1a1a1a;
  padding:5rem 2rem 2rem;z-index:950;
  transition:right .35s cubic-bezier(.4,0,.2,1);
  overflow-y:auto;
}
.mob-menu.open{right:0;display:flex}
.mob-menu a{font-family:var(--font-head);font-size:.85rem;letter-spacing:1.5px;text-transform:uppercase;color:#ccc;padding:.7rem 0;border-bottom:1px solid #1a1a1a;transition:color .2s}
.mob-menu a:hover{color:var(--green-bright)}
.mob-close{position:absolute;top:1rem;right:1.2rem;background:none;border:none;color:#888;font-size:1.4rem;line-height:1}

/* ── Hero ────────────────────────────────────────────────── */
.hero{
  position:relative;height:100vh;min-height:600px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  overflow:hidden;background:var(--dark);
}
.hero-bg{position:absolute;inset:0;will-change:transform}
.hero-slide{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  opacity:0;transform:scale(1.1);
  transition:opacity 1.5s ease-in-out;
  will-change:transform,opacity;
}
.hero-slide.active{opacity:1;animation:kbIn 6s ease-in-out forwards}
.hero-slide.kb-out.active{animation:kbOut 6s ease-in-out forwards}
@keyframes kbIn{from{transform:scale(1.08) translate(0,0)}to{transform:scale(1.15) translate(-1.5%,-.8%)}}
@keyframes kbOut{from{transform:scale(1.15) translate(-1.5%,-.8%)}to{transform:scale(1.08) translate(0,0)}}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to bottom,rgba(0,0,0,.6) 0%,rgba(0,0,0,.45) 50%,rgba(0,0,0,.7) 100%);
}
.hero-particles{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.particle{position:absolute;border-radius:50%;background:rgba(140,203,18,.2);animation:pfloat linear infinite}
@keyframes pfloat{0%{transform:translateY(110vh) scale(0);opacity:0}8%{opacity:1}92%{opacity:.2}100%{transform:translateY(-80px) scale(1);opacity:0}}
.hero-ring{position:absolute;inset:0;pointer-events:none}
.hero-ring::before,.hero-ring::after{content:'';position:absolute;top:50%;left:50%;border-radius:50%;border:1px solid rgba(140,203,18,.1);animation:spin linear infinite}
.hero-ring::before{width:650px;height:650px;margin:-325px 0 0 -325px;animation-duration:45s}
.hero-ring::after{width:420px;height:420px;margin:-210px 0 0 -210px;animation-duration:28s;animation-direction:reverse}
@keyframes spin{to{transform:rotate(360deg)}}
.hero-center{
  position:relative;z-index:2;
  display:flex;flex-direction:column;align-items:center;text-align:center;padding:0 24px;
}
.hero-logo{
  width:auto;max-width:78vw;height:42vh;max-height:360px;min-height:200px;
  object-fit:contain;margin-bottom:24px;
  mix-blend-mode:screen;
  animation:logoIn .9s cubic-bezier(.22,1,.36,1) both;
}
@keyframes logoIn{from{opacity:0;transform:scale(.88) translateY(22px)}to{opacity:1;transform:scale(1) translateY(0)}}
.hero-cta-wrap{animation:fadeUp .8s .5s ease both}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.hero-cta{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 44px;background:transparent;color:#fff;
  border:2px solid rgba(255,255,255,.8);
  font-family:var(--font-head);font-size:.9rem;font-weight:600;
  letter-spacing:3px;text-transform:uppercase;border-radius:2px;
  transition:var(--ease);
}
.hero-cta:hover{background:#fff;color:var(--dark);border-color:#fff;transform:translateY(-2px)}
.hero-stats-row{
  display:flex;align-items:center;gap:1.5rem;
  margin-top:2rem;animation:fadeUp .8s .8s ease both;
}
.hstat{text-align:center}
.hstat strong{display:block;font-family:var(--font-head);font-size:1.4rem;color:var(--green-bright);line-height:1}
.hstat span{font-size:.65rem;color:rgba(255,255,255,.5);letter-spacing:1.5px;text-transform:uppercase}
.hstat-div{width:1px;height:28px;background:rgba(255,255,255,.15)}
.scroll-hint{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:6px;animation:fadeUp .8s .9s ease both}
.scroll-hint-label{font-family:var(--font-head);font-size:.65rem;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,.45)}
.scroll-arrow{width:18px;height:18px;border-right:2px solid rgba(255,255,255,.4);border-bottom:2px solid rgba(255,255,255,.4);transform:rotate(45deg);animation:arrowBounce 1.8s ease-in-out infinite}
@keyframes arrowBounce{0%,100%{transform:rotate(45deg) translateY(0)}50%{transform:rotate(45deg) translateY(5px)}}

/* ── Ticker ──────────────────────────────────────────────── */
.ticker{background:var(--green-dark);padding:.6rem 0;overflow:hidden;white-space:nowrap}
.tick-track{display:inline-flex;animation:ticker 28s linear infinite}
.tick-item{font-family:var(--font-head);font-size:.72rem;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.85);padding:0 2rem;display:inline-flex;align-items:center;gap:.6rem}
.tick-dot{width:5px;height:5px;background:var(--green-bright);border-radius:50%;flex-shrink:0}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ── Intro Strip ─────────────────────────────────────────── */
.intro-strip{padding:88px 0;background:#fff}
.intro-inner{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.intro-media{position:relative;height:480px}
.intro-img-main{position:absolute;top:0;left:0;width:75%;height:86%;object-fit:cover;border-radius:6px;box-shadow:var(--shadow-xl)}
.intro-img-b{position:absolute;bottom:0;right:0;width:50%;height:50%;object-fit:cover;border-radius:6px;box-shadow:var(--shadow-xl);border:6px solid #fff}
.intro-badge{position:absolute;bottom:36%;left:58%;transform:translate(-50%,50%);background:var(--green-dark);color:#fff;padding:16px 18px;border-radius:6px;text-align:center;font-family:var(--font-head);z-index:2;box-shadow:0 8px 28px rgba(0,0,0,.3)}
.intro-badge .big{font-size:1.8rem;font-weight:700;line-height:1}
.intro-badge .sm{font-size:.58rem;letter-spacing:2.5px;text-transform:uppercase;opacity:.8;margin-top:4px}
.intro-text .sec-h2{margin-bottom:.75rem}
.about-list{margin:1.5rem 0;display:flex;flex-direction:column;gap:.8rem}
.alist-item{display:flex;align-items:flex-start;gap:.8rem;font-size:.9rem;color:#444;line-height:1.5}
.alist-ico{color:var(--green-bright);font-weight:700;font-size:1rem;flex-shrink:0;margin-top:1px}
.intro-btns{display:flex;gap:1rem;flex-wrap:wrap;margin-top:1.75rem}

/* ── Stats ───────────────────────────────────────────────── */
.stats-section{background:var(--dark-2);padding:60px 0;border-top:1px solid #1a1a1a;border-bottom:1px solid #1a1a1a}
.stats-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:0}
.stat-item{text-align:center;padding:1.5rem 1rem;border-right:1px solid #1e1e1e}
.stat-item:last-child{border-right:none}
.stat-num{font-family:var(--font-head);font-size:2rem;font-weight:700;color:var(--green-bright);line-height:1;margin-bottom:.4rem}
.stat-label{font-size:.72rem;color:#666;letter-spacing:1px;text-transform:uppercase}

/* ── Services Section ────────────────────────────────────── */
.services-section{padding:96px 0;background:var(--off-white)}
.services-section .sec-sub{color:#666}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-top:2.5rem}
.scard{position:relative;border-radius:6px;overflow:hidden;height:320px;box-shadow:var(--shadow-xl)}
.scard-photo{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .55s ease}
.scard:hover .scard-photo{transform:scale(1.05)}
.scard-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.85) 0%,rgba(0,0,0,.25) 60%,transparent 100%);transition:background .3s}
.scard:hover .scard-overlay{background:linear-gradient(to top,rgba(0,0,0,.9) 0%,rgba(0,0,0,.4) 70%,rgba(0,0,0,.1) 100%)}
.scard-body{position:absolute;bottom:0;left:0;right:0;padding:1.5rem;z-index:1}
.scard-name{font-family:var(--font-head);font-size:1.2rem;font-weight:700;color:#fff;margin-bottom:.4rem;letter-spacing:.5px}
.scard-desc{font-size:.82rem;color:rgba(255,255,255,.7);line-height:1.5;margin-bottom:.75rem}
.scard-link{font-family:var(--font-head);font-size:.72rem;letter-spacing:2px;text-transform:uppercase;color:var(--green-bright);transition:gap .2s;display:inline-flex;align-items:center}
.scard-link:hover{color:#fff}

/* ── Process Section ─────────────────────────────────────── */
.process-section{
  padding:96px 0;
  background-color:var(--dark-2);
  background-image:
    repeating-linear-gradient(0deg,transparent,transparent 47px,rgba(255,255,255,.025) 47px,rgba(255,255,255,.025) 48px),
    repeating-linear-gradient(90deg,transparent,transparent 95px,rgba(255,255,255,.02) 95px,rgba(255,255,255,.02) 96px);
}
.proc-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem;margin-top:3rem}
.pstep{position:relative;border-radius:6px;overflow:hidden;height:380px}
.pstep-photo{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .5s}
.pstep:hover .pstep-photo{transform:scale(1.04)}
.pstep-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.92) 0%,rgba(0,0,0,.5) 50%,rgba(0,0,0,.2) 100%)}
.pstep-num{position:absolute;top:1rem;left:1rem;font-family:var(--font-head);font-size:3.5rem;font-weight:700;color:rgba(255,255,255,.08);line-height:1;z-index:1;pointer-events:none}
.pstep-body{position:absolute;bottom:0;left:0;right:0;padding:1.5rem;z-index:2}
.pstep-badge{font-family:var(--font-head);font-size:.65rem;letter-spacing:2.5px;text-transform:uppercase;color:var(--green-bright);margin-bottom:.5rem}
.pstep-title{font-family:var(--font-head);font-size:1.15rem;color:#fff;margin-bottom:.5rem}
.pstep-desc{font-size:.8rem;color:rgba(255,255,255,.65);line-height:1.6;margin-bottom:.75rem}
.pstep-arrow{font-family:var(--font-head);font-size:.7rem;letter-spacing:2px;text-transform:uppercase;color:var(--green-bright)}

/* ── Reviews Section ─────────────────────────────────────── */
.reviews-section{
  padding:96px 0;
  background-color:var(--dark);
  background-image:
    radial-gradient(ellipse at 10% 90%,rgba(47,122,22,.1) 0%,transparent 55%),
    radial-gradient(ellipse at 90% 10%,rgba(47,122,22,.08) 0%,transparent 55%),
    repeating-linear-gradient(-45deg,transparent,transparent 23px,rgba(255,255,255,.018) 23px,rgba(255,255,255,.018) 24px),
    repeating-linear-gradient(45deg,transparent,transparent 23px,rgba(255,255,255,.018) 23px,rgba(255,255,255,.018) 24px);
}
.grating{display:flex;align-items:center;justify-content:center;gap:20px;margin-bottom:3rem;flex-wrap:wrap}
.glogo-wrap{font-size:1.6rem;font-weight:700;font-family:sans-serif;letter-spacing:1px}
.gl-g,.gl-g2{color:#4285F4}.gl-o1{color:#EA4335}.gl-o2{color:#FBBC05}.gl-l{color:#34A853}.gl-e{color:#EA4335}
.gscore{font-family:var(--font-head);font-size:2.6rem;font-weight:700;color:#fff;line-height:1}
.gstars{color:#FBBC05;font-size:1.1rem;letter-spacing:2px}
.gcount{font-size:.72rem;color:rgba(255,255,255,.4);margin-top:4px}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.rcard{background:#111;border:1px solid #1e1e1e;border-radius:6px;padding:1.75rem;transition:border-color .25s}
.rcard:hover{border-color:rgba(140,203,18,.3)}
.rcard-head{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}
.rav{width:40px;height:40px;border-radius:50%;background:var(--green-dark);display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-size:.9rem;color:var(--green-bright);font-weight:700;flex-shrink:0}
.rname{font-family:var(--font-head);font-size:.88rem;color:#fff;letter-spacing:.5px}
.rdate{font-size:.72rem;color:#555;margin-top:2px}
.rstars{color:#FBBC05;font-size:.9rem;letter-spacing:1.5px;margin-bottom:.75rem}
.rtext{font-size:.85rem;color:#888;line-height:1.65;font-style:italic}
.gbtn{display:inline-flex;align-items:center;gap:10px;padding:13px 32px;background:#fff;color:var(--dark);border-radius:3px;font-family:var(--font-head);font-size:.78rem;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;transition:var(--ease)}
.gbtn:hover{background:var(--off-white);transform:translateY(-2px);box-shadow:0 6px 22px rgba(0,0,0,.3)}

/* ── Service Area Map ────────────────────────────────────── */
.service-area-section{
  padding:80px 0;
  background:var(--dark-2);
  border-top:1px solid #1a1a1a;
}
.sa-tabs{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-bottom:1.5rem}
.sa-tab{
  font-family:var(--font-head);font-size:.72rem;letter-spacing:2px;
  text-transform:uppercase;padding:.6rem 1.2rem;border-radius:3px;
  background:#1a1a1a;color:#777;border:1px solid #2a2a2a;
  transition:var(--ease);
}
.sa-tab:hover{background:var(--green-dark);color:#fff;border-color:var(--green-dark)}
.sa-tab.active{background:var(--green-bright);color:#000;border-color:var(--green-bright)}
.sa-map-wrap{width:100%;border-radius:6px;overflow:hidden;border:1px solid #1e1e1e;margin-bottom:1.5rem}
.sa-map{width:100%;height:400px;display:block;filter:grayscale(20%)}
.sa-city-info{display:flex;align-items:center;justify-content:space-between;gap:2rem;background:#111;border:1px solid #1e1e1e;border-radius:6px;padding:1.5rem 2rem;flex-wrap:wrap}
.sa-city-desc h3{font-family:var(--font-head);font-size:1.1rem;color:#fff;margin-bottom:.4rem;letter-spacing:.5px}
.sa-city-desc p{font-size:.85rem;color:#777;max-width:580px;line-height:1.6}
.sa-city-cta{display:flex;gap:.75rem;flex-wrap:wrap;flex-shrink:0}

/* ── CTA Split ───────────────────────────────────────────── */
.cta-split{display:grid;grid-template-columns:1fr 1fr;min-height:480px}
.cta-split-text{background:linear-gradient(135deg,var(--green-dark) 0%,#1a4a0d 100%);padding:80px 60px;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden}
.cta-split-text::before{content:'';position:absolute;top:-50%;right:-10%;width:400px;height:400px;background:radial-gradient(circle,rgba(255,255,255,.06) 0%,transparent 70%);pointer-events:none}
.cta-split-tag{font-family:var(--font-head);font-size:.68rem;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:.75rem}
.cta-split-title{font-family:var(--font-head);font-size:clamp(2rem,3.5vw,3rem);color:#fff;text-transform:uppercase;letter-spacing:.5px;line-height:1.1;margin-bottom:1rem}
.cta-split-sub{font-size:.9rem;color:rgba(255,255,255,.75);line-height:1.7;margin-bottom:1.75rem;max-width:400px}
.cta-split-trust{display:flex;flex-direction:column;gap:.6rem;margin-bottom:2rem}
.cst-item{font-size:.85rem;color:rgba(255,255,255,.8)}
.cta-split-btns{display:flex;gap:1rem;flex-wrap:wrap}
.cta-split-photos{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}
.cta-sph{background-size:cover;background-position:center;transition:transform .5s}
.cta-sph:hover{transform:scale(1.02)}

/* ── Footer ──────────────────────────────────────────────── */
.site-footer{background:#060606;border-top:1px solid #111;padding:72px 0 28px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
.footer-logo{height:58px;margin-bottom:1.25rem}
.footer-desc{font-size:.82rem;color:#555;line-height:1.7}
.footer-soc{display:flex;gap:.6rem;margin-top:1.25rem}
.footer-soc a{width:34px;height:34px;border-radius:4px;background:#111;border:1px solid #1e1e1e;display:flex;align-items:center;justify-content:center;color:#666;transition:var(--ease)}
.footer-soc a:hover{background:var(--green-bright);border-color:var(--green-bright);color:#000}
.footer-soc svg{width:15px;height:15px}
.fcol-title{font-family:var(--font-head);font-size:.75rem;letter-spacing:2.5px;text-transform:uppercase;color:#fff;margin-bottom:1.25rem;padding-bottom:.5rem;border-bottom:2px solid var(--green-bright);display:inline-block}
.fcol-links{display:flex;flex-direction:column;gap:.5rem}
.fcol-links a{font-size:.82rem;color:#555;transition:color .2s}
.fcol-links a:hover{color:var(--green-bright)}
.footer-contact{display:flex;flex-direction:column;gap:.75rem}
.fc-item{display:flex;align-items:flex-start;gap:.6rem;font-size:.82rem;color:#555}
.fc-item svg{flex-shrink:0;margin-top:2px;fill:var(--green-bright)}
.fc-item a{color:#555;transition:color .2s}
.fc-item a:hover{color:var(--green-bright)}
.footer-bottom{border-top:1px solid #111;padding-top:1.5rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.75rem;font-size:.75rem;color:#333}
.footer-bottom a{color:#444;transition:color .2s}
.footer-bottom a:hover{color:var(--green-bright)}

/* ── Page Hero (inner pages) ─────────────────────────────── */
.page-hero{
  padding:160px 0 90px;position:relative;overflow:hidden;
  background-size:cover;background-position:center;background-attachment:fixed;
  min-height:420px;
}
.page-hero::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(0,0,0,.82) 0%,rgba(0,0,0,.65) 60%,rgba(0,0,0,.75) 100%);
  z-index:0;
}
.page-hero .container{position:relative;z-index:1;}
/* Default hero bg if none set */
.page-hero:not([style]){background-image:url('../assets/images/photos/hero/colonial-home-mulch-landscaping-havertown-pa.webp')}
.page-hero .container{position:relative;z-index:1}
.breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:#555;margin-bottom:1.5rem;font-family:var(--font-head);letter-spacing:.5px}
.breadcrumb a{color:var(--green-bright);transition:opacity .2s}
.breadcrumb a:hover{opacity:.75}
.breadcrumb span{color:#333}
.page-hero h1{font-size:clamp(1.9rem,4vw,3.2rem);max-width:720px;margin-bottom:1rem;text-transform:uppercase;letter-spacing:.5px}
.page-hero p{max-width:600px;font-size:1rem;color:#777;margin-bottom:2rem;line-height:1.7}
.page-hero .hero-btns{display:flex;gap:1rem;flex-wrap:wrap}

/* ── Inner page sections ─────────────────────────────────── */
.section{padding:88px 0}
.section.bg-off{background:#f8f8f4}
.section.bg-dark{background:var(--dark-2)}
.split-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.split-img-wrap{position:relative;border-radius:6px;overflow:hidden}
.split-img-wrap img{width:100%;height:460px;object-fit:cover;border-radius:6px}
.split-img-badge{position:absolute;bottom:1.5rem;left:1.5rem;background:var(--green-bright);color:#000;font-family:var(--font-head);font-size:.78rem;font-weight:600;letter-spacing:1px;padding:.55rem 1.1rem;border-radius:3px}
.split-content h2{margin-bottom:.75rem}
.split-content p{font-size:.9rem;color:#666;line-height:1.75;margin-bottom:1rem}
.checklist{display:flex;flex-direction:column;gap:.6rem;margin:1.5rem 0}
.chk-item{display:flex;align-items:flex-start;gap:.7rem;font-size:.88rem;color:#555}
.chk-item::before{content:'✓';color:var(--green-bright);font-weight:700;flex-shrink:0;margin-top:1px}
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-top:2.5rem}
.pcard{background:#111;border:1px solid #1e1e1e;border-radius:6px;padding:2rem;text-align:center;transition:border-color .25s}
.pcard:hover{border-color:rgba(140,203,18,.3)}
.pcard-num{width:56px;height:56px;border-radius:50%;background:var(--green-dark);border:2px solid var(--green-bright);display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-size:1.4rem;color:var(--green-bright);margin:0 auto 1rem}
.pcard h3{font-size:1rem;margin-bottom:.5rem;color:#fff}
.pcard p{font-size:.82rem;color:#666}

/* City cards */
.city-cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.city-card-link{background:#111;border:1px solid #1e1e1e;border-radius:6px;padding:1.75rem;transition:border-color .25s,transform .25s;display:block}
.city-card-link:hover{border-color:rgba(140,203,18,.35);transform:translateY(-4px)}
.city-card-link h3{font-family:var(--font-head);font-size:1rem;color:#fff;margin-bottom:.4rem;letter-spacing:.5px}
.city-card-link p{font-size:.8rem;color:#666;margin-bottom:.75rem}
.city-card-link .arrow{font-family:var(--font-head);font-size:.7rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--green-bright)}

/* Gallery */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}
.gal-item{position:relative;overflow:hidden;border-radius:6px;aspect-ratio:4/3}
.gal-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.gal-item:hover img{transform:scale(1.06)}
.gal-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.7) 0%,transparent 60%);opacity:0;transition:opacity .25s;display:flex;align-items:flex-end;padding:.75rem}
.gal-item:hover .gal-overlay{opacity:1}
.gal-label{font-family:var(--font-head);font-size:.68rem;letter-spacing:1.5px;text-transform:uppercase;background:var(--green-bright);color:#000;padding:.25rem .6rem;border-radius:2px}

/* Area pills */
.areas-pills{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.5rem}
.area-pill{display:inline-flex;align-items:center;gap:.4rem;background:#111;border:1px solid #1e1e1e;border-radius:50px;padding:.4rem 1rem;font-size:.78rem;color:#888;transition:var(--ease)}
.area-pill::before{content:'📍';font-size:.65rem}
.area-pill:hover{background:var(--green-dark);color:#fff;border-color:var(--green-dark)}

/* Reviews in inner pages */
.reviews-mini-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}

/* ── CTA LUXURY ──────────────────────────────────────────── */
.cta-luxury{
  position:relative;overflow:hidden;
  background:#060606;
  border-top:1px solid #151515;
  border-bottom:1px solid #151515;
}
/* Left: text panel */
.cta-luxury-left{
  position:relative;z-index:1;
  padding:72px 64px 72px 0;
  display:flex;flex-direction:column;justify-content:center;
  flex:1;min-width:0;
}
.cta-luxury-eyebrow{
  display:flex;align-items:center;gap:.75rem;
  margin-bottom:1.5rem;
}
.cta-luxury-line{width:32px;height:1px;background:var(--green-bright);}
.cta-luxury-label{
  font-family:var(--font-head);font-size:.65rem;letter-spacing:4px;
  text-transform:uppercase;color:var(--green-bright);
}
.cta-luxury-left h2{
  font-family:var(--font-head);
  font-size:clamp(2.4rem,4vw,3.8rem);
  font-weight:700;text-transform:uppercase;
  color:#fff;line-height:1.05;letter-spacing:.5px;
  margin-bottom:1.25rem;
}
.cta-luxury-left h2 em{
  font-style:normal;color:transparent;
  -webkit-text-stroke:1px rgba(140,203,18,.7);
}
.cta-luxury-left p{
  font-size:.9rem;color:#666;line-height:1.75;
  max-width:420px;margin-bottom:2rem;
}
.cta-luxury-btns{display:flex;gap:1rem;flex-wrap:wrap;align-items:center;}
.cta-luxury-btn-primary{
  display:inline-flex;align-items:center;gap:.6rem;
  background:var(--green-bright);color:#000;
  font-family:var(--font-head);font-size:.82rem;font-weight:700;
  letter-spacing:1.5px;text-transform:uppercase;
  padding:15px 32px;border-radius:2px;
  transition:var(--ease);
  position:relative;overflow:hidden;
}
.cta-luxury-btn-primary::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.15) 0%,transparent 60%);
}
.cta-luxury-btn-primary:hover{
  background:var(--green-dark);color:#fff;
  transform:translateY(-2px);box-shadow:0 8px 28px rgba(140,203,18,.25);
}
.cta-luxury-btn-outline{
  display:inline-flex;align-items:center;gap:.5rem;
  background:transparent;color:rgba(255,255,255,.5);
  font-family:var(--font-head);font-size:.78rem;letter-spacing:1.5px;text-transform:uppercase;
  padding:15px 28px;border:1px solid rgba(255,255,255,.12);border-radius:2px;
  transition:var(--ease);
}
.cta-luxury-btn-outline:hover{border-color:rgba(255,255,255,.35);color:#fff;transform:translateY(-2px);}
.cta-luxury-divider{width:1px;height:28px;background:rgba(255,255,255,.1);}
.cta-luxury-phone{
  font-family:var(--font-head);font-size:.82rem;letter-spacing:1px;
  color:rgba(255,255,255,.4);transition:color .2s;display:flex;align-items:center;gap:.4rem;
}
.cta-luxury-phone:hover{color:var(--green-bright);}
/* Right: photo stack */
.cta-luxury-right{
  position:relative;
  width:480px;flex-shrink:0;
  background:#0a0a0a;overflow:hidden;
}
.cta-luxury-photo-main{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  opacity:.65;transition:opacity .6s;
}
.cta-luxury:hover .cta-luxury-photo-main{opacity:.75;}
.cta-luxury-photo-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to right,#060606 0%,transparent 40%);
  z-index:1;
}
/* Floating stat cards */
.cta-luxury-stats{
  position:absolute;bottom:2.5rem;right:2rem;z-index:2;
  display:flex;flex-direction:column;gap:.6rem;
}
.cta-stat-card{
  background:rgba(6,6,6,.88);
  backdrop-filter:blur(8px);
  border:1px solid rgba(140,203,18,.2);
  border-radius:4px;padding:.65rem 1rem;
  display:flex;align-items:center;gap:.75rem;min-width:160px;
}
.cta-stat-num{
  font-family:var(--font-head);font-size:1.4rem;font-weight:700;
  color:var(--green-bright);line-height:1;
}
.cta-stat-lbl{font-size:.65rem;color:#666;letter-spacing:1px;text-transform:uppercase;}
/* Vertical accent */
.cta-luxury-accent{
  position:absolute;left:0;top:15%;bottom:15%;width:2px;
  background:linear-gradient(to bottom,transparent,var(--green-bright),transparent);
  opacity:.4;z-index:2;
}
/* Wrapper */
.cta-luxury-inner{
  max-width:1180px;margin:0 auto;padding:0 1.5rem;
  display:flex;align-items:stretch;min-height:460px;
}
@media(max-width:1024px){
  .cta-luxury-right{width:360px;}
  .cta-luxury-left{padding:60px 48px 60px 0;}
}
@media(max-width:768px){
  .cta-luxury-inner{flex-direction:column;}
  .cta-luxury-left{padding:56px 0;}
  .cta-luxury-right{width:100%;height:260px;position:relative;}
  .cta-luxury-photo-overlay{background:linear-gradient(to bottom,#060606 0%,transparent 50%);}
  .cta-luxury-stats{flex-direction:row;bottom:1rem;right:1rem;left:1rem;}
}

/* Keep old cta-banner-full for backwards compat but hide */
.cta-banner-full{display:none;}

/* Contact grid */
.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:4rem;align-items:start}
.contact-info h2{text-transform:uppercase;margin-bottom:.75rem}
.contact-info p{font-size:.9rem;color:#666;margin-bottom:2rem;line-height:1.75}
.contact-details{display:flex;flex-direction:column;gap:1.25rem;margin-bottom:2rem}
.cd-item{display:flex;align-items:flex-start;gap:1rem}
.cd-icon{width:40px;height:40px;border-radius:4px;background:rgba(140,203,18,.1);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cd-icon svg{width:18px;height:18px;fill:var(--green-bright)}
.cd-item strong{display:block;color:#fff;font-size:.82rem;margin-bottom:.2rem;font-family:var(--font-head);letter-spacing:.5px}
.cd-item span,.cd-item a{font-size:.82rem;color:#666}
.cd-item a:hover{color:var(--green-bright)}
.contact-social-row{display:flex;gap:.6rem}
.soc-btn{width:38px;height:38px;border-radius:4px;background:#111;border:1px solid #1e1e1e;display:flex;align-items:center;justify-content:center;transition:var(--ease)}
.soc-btn:hover{background:var(--green-bright);border-color:var(--green-bright)}
.soc-btn:hover svg{fill:#000;stroke:none}
.soc-btn svg{width:16px;height:16px;fill:#666;stroke:none;transition:fill .2s}
.soc-btn .ig-icon{fill:none;stroke:#666;stroke-width:2;transition:stroke .2s}
.soc-btn:hover .ig-icon{stroke:#000}
.ghl-wrap{background:#111;border:1px solid #1e1e1e;border-radius:6px;overflow:hidden;min-height:520px}

/* Reveal animation */
.rev{opacity:0;transform:translateY(28px);transition:opacity .65s ease,transform .65s ease}
.rev.visible{opacity:1;transform:translateY(0)}

/* ── Responsive ──────────────────────────────────────────── */
@media(max-width:1024px){
  .footer-grid{grid-template-columns:1fr 1fr}
  .proc-steps{grid-template-columns:repeat(2,1fr)}
  .stats-grid{grid-template-columns:repeat(3,1fr)}
  .stat-item{border-bottom:1px solid #1e1e1e}
}
@media(max-width:900px){
  .cta-split{grid-template-columns:1fr}
  .cta-split-photos{height:280px;grid-template-columns:repeat(4,1fr);grid-template-rows:1fr}
  .intro-inner{grid-template-columns:1fr;gap:40px}
  .intro-media{height:320px}
  .rev-grid{grid-template-columns:1fr}
  .reviews-mini-grid{grid-template-columns:1fr}
}
@media(max-width:768px){
  .section{padding:64px 0}
  .nav-links-list,.nav-right{display:none}
  .ham-btn{display:flex}
  .svc-grid{grid-template-columns:1fr 1fr}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .city-cards-grid{grid-template-columns:repeat(2,1fr)}
  .split-grid{grid-template-columns:1fr;gap:2.5rem}
  .contact-grid{grid-template-columns:1fr;gap:2rem}
  .process-grid{grid-template-columns:repeat(2,1fr)}
  .sa-map{height:280px}
  .sa-city-info{flex-direction:column;align-items:flex-start}
  .cta-banner-full{padding:40px 24px}
  .hero-stats-row{gap:1rem}
  #cursor,#cursor-ring{display:none}
  *{cursor:auto!important}
}
@media(max-width:520px){
  .svc-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr}
  .city-cards-grid{grid-template-columns:1fr}
  .proc-steps{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr}
  .cta-split-photos{grid-template-columns:repeat(2,1fr);grid-template-rows:1fr 1fr}
}
