/* self-hosted variable fonts (latin subset) — replaces the render-blocking Google Fonts link */
@font-face{font-family:"Archivo";font-style:normal;font-weight:600 900;font-display:optional;src:url(/assets/fonts/archivo-latin-var.woff2) format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:"Hanken Grotesk";font-style:normal;font-weight:400 700;font-display:swap;src:url(/assets/fonts/hanken-grotesk-latin-var.woff2) format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
:root{
  --black:#0a0f0c; --ink:#0d130f;
  --green:#54b948; --green-bright:#7ed957; --green-deep:#2f7d2a;
  --blue:#1f93d9; --blue-bright:#56c2ee;
  --white:#fff; --cream:#f5f8f3; --muted:#9aa39c; --muted-dark:#5b6760;
  --line:rgba(255,255,255,.10); --line-dark:rgba(13,19,15,.12);
  --maxw:1180px; --r:16px; --shadow:0 24px 60px -22px rgba(0,0,0,.55);
  --ease:cubic-bezier(.22,1,.36,1);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;font-family:"Hanken Grotesk",system-ui,sans-serif;background:var(--black);
  color:#e9efe9;-webkit-font-smoothing:antialiased;line-height:1.6;overflow-x:hidden}
h1,h2,h3,h4{font-family:"Archivo",sans-serif;line-height:1.03;margin:0;letter-spacing:-.01em}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.eyebrow{font-family:"Archivo";font-weight:700;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--green-bright)}
.eyebrow.on-light{color:var(--green-deep)}

/* buttons — min 48px tap targets */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;min-height:48px;
  font-family:"Archivo";font-weight:700;font-size:.98rem;padding:.8rem 1.5rem;border-radius:999px;border:0;
  cursor:pointer;transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s;text-align:center}
.btn-green{background:var(--green);color:#06210a;box-shadow:0 10px 26px -10px rgba(84,185,72,.7)}
.btn-green:hover{transform:translateY(-2px);background:var(--green-bright)}
.btn-ghost{background:transparent;color:#fff;border:1.5px solid var(--line)}
.btn-ghost:hover{border-color:var(--green-bright);color:var(--green-bright);transform:translateY(-2px)}

/* header */
header{position:fixed;top:0;left:0;right:0;z-index:60;border-bottom:1px solid transparent;
  transition:background .35s var(--ease),backdrop-filter .35s,border-color .35s}
header.scrolled{background:rgba(8,12,9,.85);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:.65rem}
.brand .mark{width:40px;height:40px;flex:none}
.brand .word{font-family:"Archivo";font-weight:800;font-size:1rem;letter-spacing:.02em;line-height:.98;text-transform:uppercase}
.brand .word small{display:block;font-weight:600;font-size:.58rem;letter-spacing:.3em;color:var(--green-bright)}
.nav-links{display:flex;align-items:center;gap:1.8rem}
.nav-links a{font-weight:600;font-size:.95rem;color:#cdd6cd;transition:color .2s}
.nav-links a:hover{color:var(--green-bright)}
.nav-cta{display:flex;align-items:center;gap:1rem}
.nav-phone{font-family:"Archivo";font-weight:700;color:#fff;white-space:nowrap}
.nav-phone span{color:var(--green-bright)}
.burger{display:none;background:none;border:0;cursor:pointer;width:46px;height:46px;color:#fff}
.burger svg{width:28px;height:28px}

/* hero */
.hero{position:relative;padding:128px 0 76px;overflow:hidden;background:
  radial-gradient(120% 90% at 80% -10%, rgba(31,147,217,.22), transparent 55%),
  radial-gradient(90% 80% at 0% 110%, rgba(84,185,72,.18), transparent 55%), var(--black)}
.topo{position:absolute;inset:0;opacity:.5;pointer-events:none;
  background-image:repeating-radial-gradient(circle at 78% 22%, rgba(255,255,255,.035) 0 1px, transparent 1px 46px)}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center;position:relative;z-index:2}
.hero h1{font-weight:900;font-size:clamp(2.4rem,8vw,5rem);text-transform:uppercase;letter-spacing:-.02em}
.hero h1 .b{color:var(--blue-bright)} .hero h1 .g{color:var(--green-bright)}
.hero p.lead{font-size:1.12rem;color:#c7d0c7;max-width:36ch;margin:1.3rem 0 1.9rem}
.hero-cta{display:flex;flex-wrap:wrap;gap:.8rem;align-items:center}
.pillrow{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:2rem}
.pill{display:inline-flex;align-items:center;gap:.45rem;font-size:.8rem;font-weight:600;padding:.45rem .85rem;
  border-radius:999px;border:1px solid var(--line);color:#cdd6cd;background:rgba(255,255,255,.02)}
.pill svg{width:15px;height:15px;color:var(--green-bright)}
.hero-media{position:relative;aspect-ratio:4/5;border-radius:22px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);
  background:linear-gradient(180deg, rgba(31,147,217,.35), rgba(10,15,12,.2) 40%, rgba(47,125,42,.55)),
  repeating-linear-gradient(135deg, rgba(255,255,255,.04) 0 2px, transparent 2px 14px)}
.ph{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;text-align:center;color:rgba(255,255,255,.85);padding:1rem}
.ph svg{width:48px;height:48px;opacity:.85}
.ph small{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.55)}
.hero-badge{position:absolute;left:16px;bottom:16px;background:rgba(8,12,9,.7);backdrop-filter:blur(6px);
  border:1px solid var(--line);border-radius:12px;padding:.6rem .9rem;font-family:"Archivo";font-weight:700;font-size:.82rem}
.hero-badge span{color:var(--green-bright)}

/* client photos dropped into the media slots — containers already reserve
   their aspect-ratio, so the absolutely-/fully-filled img adds no CLS */
.hero-media>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 42%}
.ba-img>img{width:100%;height:100%;object-fit:cover}
.about-media>img{width:100%;height:100%;object-fit:cover}
.gtile{padding:0;overflow:hidden;color:transparent}
.gtile>img{width:100%;height:100%;object-fit:cover}
/* before/after project switcher */
.ba-tabs{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem;margin-bottom:1.1rem}
.ba-tab{font-family:"Archivo";font-weight:700;font-size:.82rem;padding:.5rem 1.05rem;border-radius:999px;
  border:1px solid var(--line);background:rgba(255,255,255,.02);color:#cdd6cd;cursor:pointer;min-height:42px;transition:all .25s var(--ease)}
.ba-tab:hover{border-color:var(--green-bright);color:var(--green-bright)}
.ba-tab[aria-selected="true"]{background:var(--green);color:#06210a;border-color:var(--green)}
.ba-cap{text-align:center;color:var(--muted);font-size:.86rem;margin-top:.9rem}

/* value strip */
.strip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:rgba(255,255,255,.015)}
.strip-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line)}
.strip-cell{background:var(--black);padding:28px 22px}
.strip-cell .k{font-family:"Archivo";font-weight:800;font-size:1.45rem;color:#fff}
.strip-cell .k em{font-style:normal;color:var(--green-bright)}
.strip-cell .v{color:var(--muted);font-size:.9rem;margin-top:.2rem}

/* sections */
.light{background:var(--cream);color:var(--ink)}
.light h2{color:var(--ink)} .light .muted{color:var(--muted-dark)}
section{padding:88px 0;scroll-margin-top:84px}
.section-head{max-width:680px;margin-bottom:48px}
.section-head h2{font-weight:800;font-size:clamp(1.9rem,5vw,3.1rem);text-transform:uppercase;margin-top:.7rem}
.section-head p{font-size:1.06rem;color:var(--muted-dark);margin-top:1rem}

/* services */
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.svc{position:relative;background:#fff;border:1px solid var(--line-dark);border-radius:var(--r);padding:30px;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s;overflow:hidden}
.svc::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--green);transform:scaleY(0);transform-origin:top;transition:transform .35s var(--ease)}
.svc:hover{transform:translateY(-5px);box-shadow:0 28px 50px -28px rgba(13,19,15,.35);border-color:transparent}
.svc:hover::before{transform:scaleY(1)}
.svc-ico{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;margin-bottom:16px;background:linear-gradient(150deg,var(--green),var(--green-deep));color:#06210a}
.svc-ico svg{width:28px;height:28px}
.svc h3{font-size:1.32rem;font-weight:800;text-transform:uppercase}
.svc p{color:var(--muted-dark);margin:.6rem 0 1rem;font-size:.96rem}
.svc ul{margin:0;padding:0;list-style:none;display:flex;flex-wrap:wrap;gap:.4rem}
.svc li{font-size:.78rem;font-weight:600;color:var(--green-deep);background:rgba(84,185,72,.12);padding:.3rem .7rem;border-radius:999px}

/* ===== VISUALIZER ===== */
.viz{position:relative;background:radial-gradient(100% 120% at 0% 0%, rgba(31,147,217,.16), transparent 50%),linear-gradient(180deg,#0c1410,#0a0f0c);overflow:hidden}
.viz .topo{opacity:.35}
.viz-inner{position:relative;z-index:2}
.viz-head{text-align:center;max-width:640px;margin:0 auto 14px}
.viz-head h2{font-weight:800;font-size:clamp(1.9rem,5vw,3rem);text-transform:uppercase;color:#fff;margin-top:.6rem}
.viz-head p{color:var(--muted);margin-top:.9rem;font-size:1.05rem}
.viz-disclaimer{display:inline-flex;align-items:center;gap:.5rem;margin:14px auto 0;font-size:.78rem;color:#cdd6cd;
  border:1px solid var(--line);border-radius:999px;padding:.4rem .9rem;background:rgba(255,255,255,.03)}
.viz-disclaimer svg{width:15px;height:15px;color:var(--blue-bright);flex:none}
.viz-card{max-width:820px;margin:34px auto 0;background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:22px;padding:26px;box-shadow:var(--shadow)}
.viz-stage{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.viz-pane{position:relative;aspect-ratio:4/3;border-radius:14px;overflow:hidden;border:1px solid var(--line);background:rgba(0,0,0,.25)}
.viz-pane img{width:100%;height:100%;object-fit:cover}
.viz-pane .tag{position:absolute;top:10px;left:10px;font-family:"Archivo";font-weight:800;font-size:.68rem;letter-spacing:.16em;
  padding:.3rem .6rem;border-radius:7px;background:rgba(8,12,9,.72);backdrop-filter:blur(4px);z-index:3}
.viz-pane .tag.after{color:var(--green-bright)}
.viz-drop{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.6rem;
  text-align:center;color:#cdd6cd;cursor:pointer;padding:1rem;transition:background .2s}
.viz-drop:hover,.viz-drop.drag{background:rgba(84,185,72,.08)}
.viz-drop svg{width:40px;height:40px;color:var(--green-bright)}
.viz-drop small{font-size:.78rem;color:var(--muted)}
.viz-after-empty{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;color:var(--muted);text-align:center;padding:1rem}
.viz-after-empty svg{width:38px;height:38px;opacity:.6}
.viz-spinner{position:absolute;inset:0;display:none;flex-direction:column;align-items:center;justify-content:center;gap:.8rem;background:rgba(8,12,9,.7);backdrop-filter:blur(3px);z-index:4;color:#fff}
.viz-spinner.show{display:flex}
.spin{width:38px;height:38px;border-radius:50%;border:3px solid rgba(255,255,255,.2);border-top-color:var(--green-bright);animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.viz-controls{margin-top:18px}
.viz-controls .lab{font-size:.74rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:.6rem}
.chips{display:flex;flex-wrap:wrap;gap:.5rem}
.chip{font-size:.85rem;font-weight:600;padding:.5rem .9rem;border-radius:999px;border:1px solid var(--line);background:rgba(255,255,255,.02);color:#dfe6df;cursor:pointer;transition:all .2s;min-height:42px;display:inline-flex;align-items:center}
.chip[aria-pressed="true"]{background:var(--green);color:#06210a;border-color:var(--green)}
.viz-actions{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:20px}
.viz-actions .btn{flex:1 1 auto}
.viz-msg{font-size:.85rem;color:var(--blue-bright);margin-top:12px;min-height:1.2em}
.viz-lead{margin-top:20px;padding-top:20px;border-top:1px solid var(--line)}
.viz-lead[hidden]{display:none}
.viz-lead h3{margin:0 0 .3rem;font-size:1.15rem;color:#fff}
.viz-lead>p{margin:0 0 16px;color:var(--muted);font-size:.92rem}
.vl-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.vl-field{display:flex;flex-direction:column;font-size:.74rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);gap:.4rem}
.vl-field small{font-weight:600;text-transform:none;letter-spacing:0;opacity:.7}
.vl-field .req{color:var(--green)}
.vl-field input{padding:.8rem .95rem;border:1.5px solid var(--line);border-radius:12px;font-family:inherit;font-size:16px;background:rgba(255,255,255,.04);color:#fff;transition:border-color .2s}
.vl-field input:focus{outline:none;border-color:var(--green);background:rgba(255,255,255,.07)}
.vl-field input[aria-invalid="true"]{border-color:#e0635a}
.vl-hp{position:absolute!important;left:-9999px;width:1px;height:1px;opacity:0}
.vl-actions{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:16px}
.vl-actions .btn{flex:1 1 auto}
#vlMsg{font-size:.85rem;margin-top:12px;min-height:1.2em;color:var(--blue-bright)}
#vlMsg.err{color:#ffb4ad}
#vlMsg.ok{color:var(--green)}
@media (max-width:560px){.vl-grid{grid-template-columns:1fr}}
.viz-msg.err{color:#ff9d8a}

/* commercial */
.commercial{position:relative;background:radial-gradient(100% 120% at 100% 0%, rgba(31,147,217,.2), transparent 50%),linear-gradient(180deg,#0c1410,#0a0f0c);overflow:hidden}
.commercial .topo{opacity:.4}
.comm-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;position:relative;z-index:2}
.comm-list{display:grid;gap:16px;margin-top:8px}
.comm-item{display:flex;gap:14px;align-items:flex-start}
.comm-item .ic{flex:none;width:40px;height:40px;border-radius:10px;display:grid;place-items:center;background:rgba(84,185,72,.14);border:1px solid rgba(84,185,72,.3);color:var(--green-bright)}
.comm-item .ic svg{width:20px;height:20px}
.comm-item h3{font-family:"Archivo";font-weight:700;font-size:1.04rem;color:#fff}
.comm-item p{margin:.2rem 0 0;color:var(--muted);font-size:.92rem}
.comm-card{background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:20px;padding:34px;box-shadow:var(--shadow)}
.comm-card h3{font-weight:800;text-transform:uppercase;font-size:1.45rem}
.comm-card p{color:var(--muted);margin:.8rem 0 1.3rem}
.aud{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}
.aud span{font-size:.8rem;font-weight:600;border:1px solid var(--line);padding:.4rem .8rem;border-radius:999px;color:#cdd6cd}

/* before/after slider */
.ba{max-width:900px;margin:0 auto}
.ba-wrap{position:relative;aspect-ratio:16/10;border-radius:20px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);user-select:none;touch-action:pan-y}
.ba-img{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.4rem;color:rgba(255,255,255,.9)}
.ba-before{background:linear-gradient(180deg,#5d6b56,#3a4636),repeating-linear-gradient(90deg,rgba(0,0,0,.06) 0 3px,transparent 3px 22px)}
.ba-after{position:absolute;inset:0;clip-path:inset(0 50% 0 0);background:linear-gradient(180deg, rgba(31,147,217,.45), rgba(47,125,42,.7)),repeating-linear-gradient(135deg,rgba(255,255,255,.05) 0 2px,transparent 2px 16px)}
.ba-label{position:absolute;top:14px;font-family:"Archivo";font-weight:800;font-size:.72rem;letter-spacing:.16em;padding:.35rem .7rem;border-radius:8px;background:rgba(8,12,9,.7);backdrop-filter:blur(4px)}
.ba-label.l{left:14px} .ba-label.r{right:14px;color:var(--green-bright)}
.ba-handle{position:absolute;top:0;bottom:0;left:50%;width:3px;background:#fff;cursor:ew-resize;z-index:5;touch-action:none}
.ba-knob{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:48px;height:48px;border-radius:50%;background:var(--green);display:grid;place-items:center;box-shadow:0 6px 18px rgba(0,0,0,.4);color:#06210a}
.ba-knob svg{width:24px;height:24px}
.ba-note{text-align:center;color:var(--muted);font-size:.88rem;margin-top:1rem}
/* ---- Filterable project gallery ---- */
.gallery-head{max-width:900px;margin:44px auto 0;text-align:center}
.gallery-head h3{font-family:"Archivo";font-weight:800;color:#fff;font-size:1.35rem;letter-spacing:.01em;margin:0}
.gallery-head p{color:var(--muted);margin:.5rem 0 0;font-size:.95rem}
.gallery-filters{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin:20px auto 0}
.gfilter{font-family:"Archivo";font-weight:700;font-size:.82rem;letter-spacing:.04em;color:rgba(255,255,255,.82);
  background:rgba(255,255,255,.05);border:1px solid var(--line);border-radius:999px;padding:.55rem 1.1rem;cursor:pointer;
  transition:background .2s var(--ease),border-color .2s var(--ease),color .2s var(--ease),transform .2s var(--ease)}
.gfilter:hover{background:rgba(255,255,255,.10);border-color:rgba(255,255,255,.28)}
.gfilter:focus-visible{outline:2px solid var(--green-bright);outline-offset:2px}
.gfilter[aria-pressed="true"]{background:var(--green);border-color:var(--green);color:#06210a}
.gfilter .gcount{opacity:.6;font-weight:600;font-size:.74em;margin-left:.35em}
.gfilter[aria-pressed="true"] .gcount{opacity:.75}
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:22px}
/* Uniform tiles: a fixed aspect-ratio reserves each cell BEFORE the lazy image
   loads — kills CLS and stops the #visualize anchor jump from drifting into this
   section as images settle. object-fit:cover keeps the mixed-ratio photos tidy.
   Combined before/after frames are side-by-side, so a 4/3 cover crop only trims
   top/bottom — both halves stay fully visible. */
.gcard{position:relative;aspect-ratio:4/3;border-radius:14px;border:1px solid var(--line);overflow:hidden;background:rgba(255,255,255,.03);margin:0}
.gcard.is-hidden{display:none}
.gcard>img{width:100%;height:100%;object-fit:cover;display:block}
.gcard .gba-badge{position:absolute;top:10px;left:10px;font-family:"Archivo";font-weight:800;font-size:.6rem;letter-spacing:.14em;
  padding:.3rem .55rem;border-radius:7px;background:rgba(8,12,9,.72);backdrop-filter:blur(4px);color:var(--green-bright);pointer-events:none}
.gcard figcaption{position:absolute;left:0;right:0;bottom:0;padding:.9rem .8rem .6rem;font-size:.76rem;line-height:1.35;color:#fff;
  background:linear-gradient(180deg,transparent,rgba(6,10,7,.82));pointer-events:none}
.gallery-empty{text-align:center;color:var(--muted);margin:26px auto 0;max-width:520px;font-size:.95rem}
.gtile{aspect-ratio:4/3;border-radius:14px;border:1px solid var(--line);display:grid;place-items:center;background:linear-gradient(160deg,rgba(31,147,217,.18),rgba(47,125,42,.32));color:rgba(255,255,255,.6)}
.gtile small{font-size:.68rem;letter-spacing:.14em;text-transform:uppercase}

/* about */
.about-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:48px;align-items:center}
.about-media{aspect-ratio:1/1;border-radius:20px;overflow:hidden;border:1px solid var(--line-dark);background:linear-gradient(160deg,#1f93d9,#2f7d2a);display:grid;place-items:center;color:rgba(255,255,255,.85);box-shadow:var(--shadow)}
.about-media small{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.65)}
.about h2{font-size:clamp(1.9rem,5vw,3rem);text-transform:uppercase;font-weight:800}
.about p{color:var(--muted-dark);font-size:1.02rem;margin:1rem 0}
.vals{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:1.5rem}
.val{display:flex;gap:12px;align-items:flex-start}
.val .ic{flex:none;width:38px;height:38px;border-radius:10px;background:rgba(84,185,72,.14);display:grid;place-items:center;color:var(--green-deep)}
.val .ic svg{width:20px;height:20px}
.val h4{font-family:"Archivo";font-weight:700;font-size:1rem;color:var(--ink)}
.val p{margin:.1rem 0 0;font-size:.88rem;color:var(--muted-dark)}

/* pain sections + owner pull-quote */
.pain{max-width:760px}
.pull{margin:1.5rem 0;padding:1.1rem 1.4rem;border-left:3px solid var(--green);background:rgba(84,185,72,.10);
  font-family:"Archivo";font-weight:600;font-size:1.06rem;line-height:1.5;color:var(--ink);border-radius:0 14px 14px 0}
.pull cite{display:block;margin-top:.7rem;font-style:normal;font-weight:700;font-size:.85rem;letter-spacing:.02em;color:var(--green-deep)}

/* process */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;counter-reset:step}
.step{position:relative;padding:28px;border-radius:var(--r);border:1px solid var(--line);background:rgba(255,255,255,.02)}
.step::before{counter-increment:step;content:"0" counter(step);font-family:"Archivo";font-weight:900;font-size:2.4rem;color:transparent;-webkit-text-stroke:1.5px rgba(126,217,87,.5);display:block;margin-bottom:.3rem}
.step h3{font-family:"Archivo";font-weight:700;font-size:1.12rem;color:#fff}
.step p{color:var(--muted);font-size:.92rem;margin-top:.5rem}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:48px;align-items:start}
.contact-info h2{font-size:clamp(1.9rem,5vw,3rem);text-transform:uppercase;font-weight:800}
.contact-info p{color:var(--muted-dark);margin:1rem 0 1.8rem;font-size:1.02rem}
.cline{display:flex;align-items:center;gap:14px;padding:15px 0;border-bottom:1px solid var(--line-dark)}
.cline .ic{flex:none;width:46px;height:46px;border-radius:12px;display:grid;place-items:center;background:var(--ink);color:var(--green-bright)}
.cline .ic svg{width:22px;height:22px}
.cline .lbl{font-size:.76rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-dark)}
.cline .big{font-family:"Archivo";font-weight:800;font-size:1.16rem;color:var(--ink)}
.form{background:#fff;border:1px solid var(--line-dark);border-radius:20px;padding:32px;box-shadow:0 28px 60px -34px rgba(13,19,15,.4)}
.field{margin-bottom:15px}
.field label{display:block;font-size:.78rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--muted-dark);margin-bottom:.4rem}
.field input,.field select,.field textarea{width:100%;padding:.85rem 1rem;border:1.5px solid var(--line-dark);border-radius:12px;font-family:inherit;font-size:16px;background:var(--cream);color:var(--ink);transition:border-color .2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--green);background:#fff}
.field textarea{resize:vertical;min-height:108px}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:15px}
.form .btn-green{width:100%;margin-top:6px}
.form-note{font-size:.82rem;color:var(--muted-dark);margin-top:.8rem;text-align:center}
.form-ok{display:none;text-align:center;padding:28px 10px}
.form-ok.show{display:block}
.form-ok h3{color:var(--green-deep);font-weight:800;text-transform:uppercase}
.form-ok p{color:var(--muted-dark);margin-top:.6rem}
/* invalid field + inline error */
.field input[aria-invalid="true"],.field select[aria-invalid="true"],.field textarea[aria-invalid="true"]{border-color:#d6453a;background:#fff5f4}
.form-err{display:none;color:#c0271c;font-size:.86rem;font-weight:600;margin:.2rem 0 .7rem;text-align:center}
.form-err.show{display:block}
/* honeypot — off-screen, never shown, never tab-focusable for real users */
.hp-field{position:absolute!important;left:-9999px!important;top:auto;width:1px;height:1px;overflow:hidden}

/* footer */
footer{background:var(--black);border-top:1px solid var(--line);padding:60px 0 26px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:38px;margin-bottom:36px}
.foot-grid h3{font-family:"Archivo";font-weight:700;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--green-bright);margin:0 0 1rem}
.foot-grid a,.foot-grid p{color:var(--muted);font-size:.93rem;display:block;margin-bottom:.5rem;transition:color .2s}
.foot-grid a:hover{color:#fff}
.foot-brand p{max-width:34ch;margin-top:1rem}
.foot-bottom{border-top:1px solid var(--line);padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;color:var(--muted);font-size:.84rem}

/* ===== REVIEWS ===== */
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:8px}
.rev{background:#fff;border:1px solid var(--line-dark);border-radius:var(--r);padding:28px;display:flex;flex-direction:column;gap:14px;transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.rev:hover{transform:translateY(-4px);box-shadow:0 24px 44px -26px rgba(13,19,15,.35)}
.rev .stars{display:flex;gap:3px;color:#f5a623}
.rev .stars svg{width:18px;height:18px}
.rev p{color:var(--ink);font-size:1rem;line-height:1.55;margin:0;flex:1}
.rev .who{display:flex;align-items:center;gap:12px}
.rev .who .av{width:42px;height:42px;border-radius:50%;flex:none;display:grid;place-items:center;font-family:"Archivo";font-weight:800;color:#06210a;background:linear-gradient(150deg,var(--green-bright),var(--green-deep))}
.rev .who .nm{font-family:"Archivo";font-weight:700;font-size:.96rem;color:var(--ink);line-height:1.2}
.rev .who .mt{font-size:.82rem;color:var(--muted-dark)}
.rev-cta{text-align:center;margin-top:36px}
.rev-cta a{color:var(--green-deep);font-weight:700;border-bottom:2px solid rgba(84,185,72,.4);padding-bottom:2px}

/* ===== MAP / LOCATION ===== */
.map-band{position:relative;background:linear-gradient(180deg,#0c1410,#0a0f0c)}
.map-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:0;border:1px solid var(--line);border-radius:20px;overflow:hidden;box-shadow:var(--shadow)}
.map-info{padding:40px;background:rgba(255,255,255,.02)}
.map-info h3{font-family:"Archivo";font-weight:800;text-transform:uppercase;font-size:1.5rem;color:#fff;margin-top:.6rem}
.map-info p{color:var(--muted);margin:.9rem 0 1.4rem}
.map-info .row{display:flex;align-items:center;gap:12px;padding:12px 0;border-top:1px solid var(--line)}
.map-info .row .ic{flex:none;width:40px;height:40px;border-radius:10px;display:grid;place-items:center;background:rgba(84,185,72,.14);color:var(--green-bright)}
.map-info .row .ic svg{width:20px;height:20px}
.map-info .row b{font-family:"Archivo";color:#fff;font-weight:700}
.map-info .row .lbl{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.map-frame{min-height:380px;position:relative;background:#0c1410}
.map-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0;filter:grayscale(.2) contrast(1.05)}

/* ===== STICKY MOBILE ACTION BAR ===== */
.callbar{display:none}
@media(max-width:820px){
  .callbar{display:grid;grid-template-columns:1fr 1fr 1fr;position:fixed;left:0;right:0;bottom:0;z-index:70;
    background:rgba(8,12,9,.96);backdrop-filter:blur(14px);border-top:1px solid var(--line);
    padding:10px 12px calc(10px + env(safe-area-inset-bottom));gap:8px}
  .callbar a{display:flex;align-items:center;justify-content:center;gap:.4rem;min-height:52px;border-radius:14px;
    font-family:"Archivo";font-weight:800;font-size:.92rem;letter-spacing:.01em;white-space:nowrap;padding:0 6px}
  .callbar svg{width:19px;height:19px;flex:none}
  .callbar .call{background:var(--blue);color:#04222f}
  .callbar .viz{background:linear-gradient(135deg,#1f93d9,#54b948);color:#fff}
  .callbar .est{background:var(--green);color:#06210a}
  body{padding-bottom:74px}
}

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

/* responsive layout */
@media(max-width:920px){
  .hero-grid,.comm-grid,.about-grid,.contact-grid{grid-template-columns:1fr}
  .hero-media{max-width:400px;order:-1}
  .strip-grid{grid-template-columns:1fr 1fr}
  .svc-grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr 1fr}
  .vals{grid-template-columns:1fr}
  .reviews-grid{grid-template-columns:1fr}
  .map-grid{grid-template-columns:1fr}
  .map-frame{min-height:300px;order:2}
}
@media(max-width:820px){
  .nav-links,.nav-phone{display:none}
  .burger{display:grid;place-items:center;width:42px;height:42px}
  /* keep the header row inside 360px: let the brand yield, shrink the CTA */
  .nav{gap:.5rem}
  .brand{min-width:0;gap:.5rem}
  .brand .mark{width:34px;height:34px}
  .brand .word{font-size:.86rem}
  .brand .word small{font-size:.52rem;letter-spacing:.2em}
  .nav-cta{gap:.5rem;flex:none}
  .nav-cta .btn{padding:.55rem .9rem;font-size:.86rem;min-height:44px;white-space:nowrap}
  header.open .nav-links{display:flex;position:absolute;top:72px;left:0;right:0;flex-direction:column;background:rgba(8,12,9,.98);backdrop-filter:blur(14px);padding:22px;gap:1.1rem;border-bottom:1px solid var(--line)}
  .hero{padding:104px 0 56px}
  /* hero: headline + CTAs first, photo after and shorter so they're above the fold */
  .hero-media{order:0;aspect-ratio:16/10;max-height:230px}
  /* stop horizontal overflow: stack footer cols; let long emails wrap */
  .foot-grid{grid-template-columns:1fr;gap:26px}
  .cline .big,.foot-grid a{overflow-wrap:anywhere}
  section{padding:64px 0}
  .viz-stage{grid-template-columns:1fr}
  .row2{grid-template-columns:1fr}
}
@media(max-width:560px){
  .strip-grid{grid-template-columns:1fr}
  /* keep 2-up on phones (was 1-up): halves the section height so it's far less
     to scroll past on the way to the visualizer below it */
  .gallery{grid-template-columns:1fr 1fr}
  .wrap{padding:0 18px}
}
@media(max-width:400px){
  .brand .word{font-size:.8rem}
  .nav-cta .btn{padding:.5rem .8rem;font-size:.82rem}
}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ===== service subpages + "Areas we serve" (shared into assets/css/site.css) ===== */
/* "Lawn Care →" link on each homepage service card */
.svc-more{display:inline-flex;align-items:center;gap:.4rem;margin-top:1rem;font-family:"Archivo";font-weight:800;
  font-size:.86rem;letter-spacing:.02em;text-transform:uppercase;color:var(--green-deep)}
.svc-more span{transition:transform .25s var(--ease)}
.svc:hover .svc-more span{transform:translateX(4px)}
/* breadcrumb */
.crumbs{font-size:.82rem;color:var(--muted);padding:96px 0 0}
.crumbs a{color:#cdd6cd}.crumbs a:hover{color:var(--green-bright)}.crumbs span{opacity:.5;margin:0 .5rem}
/* service-page hero (dark, text-led) */
.page-hero{position:relative;overflow:hidden;padding:26px 0 70px;background:
  radial-gradient(120% 90% at 85% -10%, rgba(31,147,217,.20), transparent 55%),
  radial-gradient(90% 80% at 0% 120%, rgba(84,185,72,.16), transparent 55%), var(--black)}
.page-hero-inner{position:relative;z-index:2;max-width:820px}
.page-hero h1{font-weight:900;font-size:clamp(2.1rem,6vw,3.7rem);text-transform:uppercase;letter-spacing:-.02em;margin-top:.7rem}
.page-hero h1 .g{color:var(--green-bright)}.page-hero h1 .b{color:var(--blue-bright)}
.page-hero .lead{font-size:1.14rem;color:#c7d0c7;max-width:60ch;margin:1.3rem 0 1.8rem}
.page-hero .hero-cta{display:flex;flex-wrap:wrap;gap:.8rem;align-items:center}
/* readable body copy on light sections */
.prose{max-width:760px}
.prose h2{font-weight:800;font-size:clamp(1.6rem,4vw,2.4rem);text-transform:uppercase;margin:0 0 .2rem}
.prose h3{font-family:"Archivo";font-weight:800;font-size:1.16rem;color:var(--ink);margin:2rem 0 .5rem}
.prose p{color:var(--muted-dark);font-size:1.04rem;margin:.9rem 0}
.prose .light-lead{font-size:1.14rem;color:var(--ink)}
.prose ul{margin:1rem 0;padding:0;list-style:none;display:grid;gap:.6rem}
.prose ul li{position:relative;padding-left:1.7rem;color:var(--muted-dark);font-size:1rem}
.prose ul li::before{content:"";position:absolute;left:0;top:.5em;width:11px;height:11px;border-radius:3px;
  background:linear-gradient(150deg,var(--green),var(--green-deep))}
.prose ul li b{color:var(--ink)}
/* two-column feature list on dark (reuses .comm-item look) */
.feat-cols{display:grid;grid-template-columns:1fr 1fr;gap:16px 34px;margin-top:8px}
/* cross-links to sibling services */
.svc-links{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:8px}
.svc-link-card{display:flex;flex-direction:column;gap:.3rem;padding:20px;border:1px solid var(--line);border-radius:14px;
  background:rgba(255,255,255,.02);transition:border-color .25s,transform .25s var(--ease)}
.svc-link-card:hover{border-color:var(--green-bright);transform:translateY(-3px)}
.svc-link-card .t{font-family:"Archivo";font-weight:800;font-size:1rem;color:#fff;text-transform:uppercase}
.svc-link-card .d{font-size:.86rem;color:var(--muted)}
.svc-link-card[aria-current="page"]{border-color:var(--green);background:rgba(84,185,72,.08)}
/* "areas we serve" prose band */
.areas p{max-width:760px;color:var(--muted-dark);font-size:1.06rem;margin:1rem 0}
.areas .light-lead{color:var(--ink);font-size:1.16rem}
/* on-page CTA band (dark) */
.cta-band{background:radial-gradient(100% 130% at 0% 0%, rgba(31,147,217,.16), transparent 55%),linear-gradient(180deg,#0c1410,#0a0f0c)}
.cta-inner{max-width:720px;text-align:center;margin:0 auto}
.cta-inner h2{font-weight:800;font-size:clamp(1.9rem,5vw,2.9rem);text-transform:uppercase;color:#fff}
.cta-inner p{color:var(--muted);font-size:1.08rem;margin:1rem 0 1.8rem}
.cta-actions{display:flex;flex-wrap:wrap;gap:.8rem;justify-content:center}
@media(max-width:820px){.svc-links{grid-template-columns:1fr 1fr}.feat-cols{grid-template-columns:1fr}}
@media(max-width:560px){.svc-links{grid-template-columns:1fr}}
