/* ===== Reset / Base ===== */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;font-family:'Inter',ui-sans-serif,system-ui,-apple-system,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;color:#1c2420;line-height:1.6;background:#fbfaf6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font-size:16px}
img{max-width:100%;display:block;height:auto}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
a{color:inherit}
ul{margin:0;padding:0;list-style:none}
p{margin:0}

/* ===== Tokens ===== */
:root{
  --bg:#fbfaf6;
  --bg-warm:#f3eee3;
  --bg-cream:#f7f1e3;
  --ink:#0f1a13;
  --ink-2:#2a3530;
  --muted:#5b6a64;
  --line:#e2dccd;
  --line-soft:#ebe5d6;
  --green-900:#15301f;
  --green-800:#1f3b2d;
  --green-700:#2d4f3a;
  --green-600:#3e6a4f;
  --green-300:#a4c2af;
  --green-50:#e6efe7;
  --rust:#b94e1f;
  --shadow-sm:0 4px 14px rgba(15,26,19,.06);
  --shadow:0 18px 40px rgba(15,26,19,.10);
  --shadow-lg:0 30px 80px rgba(15,26,19,.18);
  --max:1240px;
  --radius:18px;
  --radius-sm:10px;
}
.serif{font-family:'Fraunces','Georgia','Times New Roman',serif;font-weight:500;letter-spacing:-0.015em;line-height:1.04}

/* ===== Typography ===== */
h1,h2,h3,h4,h5{margin:0;font-family:'Fraunces','Georgia','Times New Roman',serif;font-weight:500;letter-spacing:-0.015em;line-height:1.04;color:var(--ink)}
h1{font-size:clamp(44px,6vw,80px)}
h2{font-size:clamp(32px,4.2vw,52px);line-height:1.06}
h3{font-size:clamp(22px,2.6vw,30px);line-height:1.15}
h4{font-size:18px;font-weight:600;font-family:'Inter',sans-serif;letter-spacing:0}
.eyebrow{display:inline-block;font-family:'Inter',sans-serif;font-weight:600;letter-spacing:.22em;text-transform:uppercase;font-size:11.5px;color:var(--green-700);margin-bottom:18px}
.lede{font-size:18.5px;color:var(--ink-2);max-width:640px;line-height:1.6}
.muted{color:var(--muted)}

.wrap{max-width:var(--max);margin:0 auto;padding:0 28px}
@media (max-width:680px){.wrap{padding:0 20px}}

/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;gap:10px;padding:15px 26px;border-radius:999px;font-weight:600;font-size:15.5px;line-height:1;transition:transform .12s ease, box-shadow .25s ease, background .2s ease, color .2s ease;text-decoration:none;white-space:nowrap;letter-spacing:0}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--ink);color:#fff;box-shadow:0 6px 20px rgba(15,26,19,.18)}
.btn-primary:hover{background:var(--green-800);box-shadow:0 10px 28px rgba(15,26,19,.25)}
.btn-light{background:#fff;color:var(--ink);border:1px solid var(--line)}
.btn-light:hover{background:var(--bg-warm)}
.btn-ghost{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.35)}
.btn-ghost:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.6)}
.btn-lg{padding:18px 30px;font-size:16px}

/* ===== Top Bar ===== */
.topbar{background:var(--green-900);color:#d6dfd8;font-size:13px;font-weight:500}
.topbar .wrap{display:flex;justify-content:space-between;gap:16px;padding:9px 28px;flex-wrap:wrap;align-items:center}
.topbar a{color:#fff;text-decoration:none;font-weight:600}
.dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:#7ed3a0;box-shadow:0 0 0 3px rgba(126,211,160,.18);margin-right:9px;vertical-align:middle}
@media (max-width: 720px){.topbar .wrap > span:first-child{display:none}}

/* ===== Header ===== */
header.nav{position:sticky;top:0;z-index:60;background:rgba(251,250,246,.92);backdrop-filter:saturate(140%) blur(10px);-webkit-backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--line-soft)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding-top:18px;padding-bottom:18px;gap:18px}
.brand{display:flex;align-items:center;text-decoration:none;color:var(--ink)}
.brand-name{font-family:'Inter',sans-serif;font-weight:700;font-size:20px;letter-spacing:-0.025em;line-height:1.05;color:var(--ink)}
.brand-name small{display:block;font-family:'Inter',sans-serif;font-size:10px;font-weight:600;letter-spacing:.22em;color:var(--muted);text-transform:uppercase;margin-top:5px}

nav.menu{display:flex;align-items:center;gap:32px}
nav.menu a{font-weight:500;color:var(--ink-2);text-decoration:none;font-size:15px;position:relative}
nav.menu a:hover{color:var(--green-800)}

.nav-cta{display:flex;align-items:center;gap:14px}
.nav-phone{font-weight:600;color:var(--ink);text-decoration:none;font-size:14.5px;display:inline-flex;align-items:center;gap:8px}
.nav-phone svg{color:var(--green-700)}
.menu-toggle{display:none}
.mobile-menu{display:none}

@media (max-width: 920px){
  nav.menu{display:none}
  .nav-cta .nav-phone{display:none}
  .menu-toggle{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:999px;background:transparent;color:var(--ink);border:1px solid var(--line)}
  .mobile-menu.open{display:block;border-top:1px solid var(--line);padding-top:12px;padding-bottom:22px}
  .mobile-menu a{display:block;padding:13px 4px;font-weight:600;color:var(--ink);border-bottom:1px solid var(--line-soft);text-decoration:none;font-size:16px}
  .mobile-menu a:last-child{border-bottom:0}
}

/* ===== Photo helper (with gradient fallback) ===== */
/* The .photo wrapper holds a gradient bg then an <img>. If img is broken/missing, gradient shows. */
.photo{position:relative;overflow:hidden;background-size:cover;background-position:center;background-repeat:no-repeat}
.photo > img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1.2s cubic-bezier(.2,.7,.2,1)}
.photo > .label{position:absolute;left:14px;bottom:14px;z-index:2;background:rgba(15,26,19,.78);backdrop-filter:blur(6px);color:#f3eee3;padding:8px 12px;border-radius:8px;font-size:11.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;border:1px solid rgba(255,255,255,.08);font-family:'Inter',sans-serif}
.photo > .label small{display:block;font-weight:500;color:#a4c2af;font-size:10px;letter-spacing:.18em;margin-bottom:1px}

/* Photo gradient palettes — each slot evokes the actual photo content */
/* If user's img/0X.jpg loads, the photo shows. If not, this gradient placeholder shows. */
.bg-turf-fresh{background-image:linear-gradient(160deg,#5b9168 0%, #3a6e4a 50%, #244a32 100%)}
.bg-turf-lush{background-image:linear-gradient(135deg,#7eb685 0%, #4d8a5d 60%, #2d5a3b 100%)}
.bg-stones{background-image:linear-gradient(150deg,#d6c39a 0%, #b39767 60%, #6c5430 100%)}
.bg-pebble{background-image:linear-gradient(140deg,#e6d6ad 0%, #b89c63 100%)}
.bg-mulch{background-image:linear-gradient(150deg,#5a3b22 0%, #3a2412 60%, #1f140a 100%)}
.bg-fence{background-image:linear-gradient(135deg,#4b5258 0%, #1f2429 100%)}
.bg-tropical{background-image:linear-gradient(160deg,#496d52 0%, #234032 50%, #102018 100%)}
.bg-luxury{background-image:linear-gradient(135deg,#6cad7a 0%, #2d4f3a 50%, #15301f 100%)}
.bg-modern{background-image:linear-gradient(160deg,#e9e1cd 0%, #c9bea0 60%, #978560 100%)}
.bg-frontyard{background-image:linear-gradient(180deg,#a4c2af 0%, #4f7a5b 80%)}
.bg-machine{background-image:linear-gradient(135deg,#f0a058 0%, #d75a14 60%, #5a230a 100%)}
.bg-hero{background-image:radial-gradient(at 30% 20%, rgba(255,255,255,.18), transparent 40%), linear-gradient(155deg,#2d4f3a 0%, #15301f 60%, #07140c 100%)}

/* Subtle pattern overlay so placeholders feel intentional */
.photo::before{content:"";position:absolute;inset:0;background-image:
  radial-gradient(rgba(255,255,255,.06) 1px, transparent 1.4px);
  background-size:18px 18px;mix-blend-mode:overlay;opacity:.55;pointer-events:none}

/* ===== Hero ===== */
.hero{position:relative;color:#f3eee3;overflow:hidden;isolation:isolate}
.hero-bg{position:absolute;inset:0;z-index:-2}
.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(7,20,12,.78) 0%,rgba(7,20,12,.62) 40%,rgba(7,20,12,.92) 100%);z-index:1}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center;padding-top:110px;padding-bottom:110px}
.hero h1{color:#fff;margin:0 0 22px}
.hero h1 em{font-style:italic;color:#cfe5d4;font-weight:400}
.hero .lede{color:rgba(255,255,255,.86);font-size:19px;max-width:520px;margin-bottom:34px}
.hero-ctas{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:42px}

.hero-strip{display:flex;gap:28px;flex-wrap:wrap;align-items:center;padding-top:30px;border-top:1px solid rgba(255,255,255,.16)}
.hero-strip .item{display:flex;gap:11px;align-items:center;font-size:13.5px;color:rgba(255,255,255,.72);font-weight:500}
.hero-strip svg{color:#a4c2af;flex:none}

.hero-side{position:relative;height:100%}
.hero-card{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:4/5;box-shadow:var(--shadow-lg);border:1px solid rgba(255,255,255,.08)}
.hero-card .meta{position:absolute;left:20px;bottom:20px;right:20px;color:#f3eee3;z-index:2}
.hero-card .meta small{font-size:11px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:#a4c2af;display:block;margin-bottom:6px}
.hero-card .meta strong{font-family:'Fraunces',serif;font-weight:500;font-size:22px;letter-spacing:-.01em;line-height:1.15;display:block}
.hero-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(7,20,12,.7));z-index:1}

.hero-stat{position:absolute;top:30px;right:-20px;background:#fbfaf6;color:var(--ink);padding:18px 22px;border-radius:14px;box-shadow:var(--shadow);max-width:200px}
.hero-stat .num{font-family:'Fraunces',serif;font-size:34px;font-weight:500;line-height:1;letter-spacing:-.02em}
.hero-stat .lbl{font-size:11.5px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-top:6px}

@media (max-width: 920px){
  .hero-grid{grid-template-columns:1fr;gap:42px;padding-top:70px;padding-bottom:80px}
  .hero-card{aspect-ratio:5/4;max-width:560px;margin:0 auto}
  .hero-stat{top:auto;bottom:18px;right:18px}
}

/* ===== Section ===== */
section{padding:110px 0}
section.tight{padding:80px 0}
@media (max-width: 720px){section{padding:70px 0}section.tight{padding:54px 0}}

/* Section header layout */
.shead{display:grid;grid-template-columns:1fr 1.2fr;gap:60px;align-items:end;margin-bottom:60px}
.shead p{color:var(--muted);font-size:17px;max-width:560px}
@media (max-width: 880px){.shead{grid-template-columns:1fr;gap:18px;margin-bottom:40px}}

/* ===== Marquee strip ===== */
.tags{display:flex;gap:36px;flex-wrap:wrap;padding:34px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);font-family:'Fraunces',serif;font-size:18px;color:var(--ink-2);justify-content:center;align-items:center;background:#fbfaf6;font-weight:400}
.tags .dotmark{width:5px;height:5px;border-radius:50%;background:var(--green-700)}
@media (max-width: 720px){.tags{font-size:15px;gap:22px;padding:24px 18px}}

/* ===== Featured intro / promise ===== */
.promise{background:var(--bg-warm);position:relative;overflow:hidden}
.promise-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:80px;align-items:center}
.promise .photo{border-radius:var(--radius);aspect-ratio:4/5;box-shadow:var(--shadow)}
.promise h2 em{font-style:italic;color:var(--green-700);font-weight:400}
.promise ul{margin-top:30px;display:grid;gap:18px}
.promise li{display:flex;gap:14px;align-items:flex-start;font-size:16px;color:var(--ink-2);line-height:1.55}
.promise li svg{color:var(--green-700);flex:none;margin-top:3px}
.promise li b{display:block;color:var(--ink);font-weight:600;margin-bottom:2px;font-size:16.5px}
@media (max-width: 920px){.promise-grid{grid-template-columns:1fr;gap:42px}.promise .photo{max-width:520px;margin:0 auto}}

/* ===== Services ===== */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.svc{background:#fff;border:1px solid var(--line-soft);border-radius:var(--radius);padding:34px 30px;transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;position:relative;overflow:hidden;text-decoration:none;color:inherit;display:block}
.svc-more{display:inline-flex;align-items:center;gap:7px;margin-top:18px;color:var(--green-700);font-size:14px;font-weight:600;letter-spacing:.01em;transition:gap .2s ease, color .2s ease;font-family:'Inter',sans-serif}
.svc-more svg{transition:transform .2s ease}
a.svc:hover .svc-more{color:var(--green-800)}
a.svc:hover .svc-more svg{transform:translateX(3px)}
.svc:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--green-300)}
.svc-icon{width:46px;height:46px;border-radius:50%;background:var(--green-50);color:var(--green-800);display:grid;place-items:center;margin-bottom:22px}
.svc h3{font-size:22px;margin-bottom:10px;color:var(--ink)}
.svc p{font-size:15px;color:var(--muted);line-height:1.6}
.svc .tag{position:absolute;top:22px;right:22px;background:var(--bg-warm);color:var(--green-800);font-size:10.5px;font-weight:700;padding:5px 10px;border-radius:999px;letter-spacing:.14em;text-transform:uppercase;font-family:'Inter',sans-serif}
@media (max-width: 980px){.svc-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width: 600px){.svc-grid{grid-template-columns:1fr}}

/* ===== Gallery ===== */
.gallery-section{background:#0f1a13;color:#f3eee3}
.gallery-section h2{color:#fff}
.gallery-section .lede{color:rgba(255,255,255,.7)}
.gallery-section .eyebrow{color:#a4c2af}

.gal{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:90px;gap:14px;margin-top:50px}
.gal .photo{border-radius:14px;border:1px solid rgba(255,255,255,.06)}
.gal .photo > img{will-change:transform}
.gal .photo:hover > img{transform:scale(1.04)}
/* Tile sizes — magazine-style asymmetric layout */
.t-l{grid-column:span 7;grid-row:span 5}
.t-m{grid-column:span 5;grid-row:span 3}
.t-s{grid-column:span 4;grid-row:span 3}
.t-w{grid-column:span 8;grid-row:span 3}
.t-tall{grid-column:span 5;grid-row:span 5}
.t-h{grid-column:span 6;grid-row:span 3}

@media (max-width: 980px){
  .gal{grid-template-columns:repeat(6,1fr);grid-auto-rows:90px;gap:10px}
  .t-l{grid-column:span 6;grid-row:span 4}
  .t-m,.t-s,.t-h{grid-column:span 3;grid-row:span 3}
  .t-w,.t-tall{grid-column:span 6;grid-row:span 4}
}

/* ===== Featured project (single big image) ===== */
.featured{position:relative;border-radius:var(--radius);overflow:hidden;display:grid;grid-template-columns:1.6fr 1fr;gap:0;background:#fff;box-shadow:var(--shadow);border:1px solid var(--line-soft)}
.featured .photo{aspect-ratio:auto;height:100%;min-height:480px}
.featured-body{padding:54px 50px;display:flex;flex-direction:column;justify-content:center}
.featured-body h3{margin-bottom:14px}
.featured-body .stats{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:30px;padding-top:26px;border-top:1px solid var(--line-soft)}
.featured-body .stat{display:flex;flex-direction:column}
.featured-body .stat .num{font-family:'Fraunces',serif;font-size:24px;font-weight:500;letter-spacing:-.01em}
.featured-body .stat .lbl{font-size:11.5px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:4px}
@media (max-width: 880px){.featured{grid-template-columns:1fr}.featured .photo{min-height:340px;aspect-ratio:4/3}.featured-body{padding:36px 28px}}

/* ===== About / The machine ===== */
.about{background:var(--bg-cream)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center}
.about .photo{aspect-ratio:5/6;border-radius:var(--radius);box-shadow:var(--shadow)}
.about .specs{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:30px}
.about .spec{background:#fff;border:1px solid var(--line);border-radius:12px;padding:18px}
.about .spec .num{font-family:'Fraunces',serif;font-size:30px;font-weight:500;line-height:1;color:var(--ink)}
.about .spec .num .u{font-size:13px;color:var(--muted);font-weight:600;margin-left:3px;font-family:'Inter',sans-serif}
.about .spec .lbl{font-size:12px;color:var(--muted);font-weight:600;letter-spacing:.1em;text-transform:uppercase;margin-top:8px}
@media (max-width: 920px){.about-grid{grid-template-columns:1fr;gap:40px}.about .photo{max-width:480px;margin:0 auto}}

/* ===== Process ===== */
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:54px;counter-reset:step}
.step{position:relative;padding:30px 26px;background:#fff;border:1px solid var(--line-soft);border-radius:var(--radius)}
.step::before{counter-increment:step;content:counter(step,decimal-leading-zero);position:absolute;top:24px;right:26px;font-family:'Fraunces',serif;font-size:36px;color:var(--green-300);font-weight:500;line-height:1}
.step h4{font-size:17px;margin:8px 0 8px;color:var(--ink);font-weight:600}
.step p{font-size:14.5px;color:var(--muted);line-height:1.55}
.step-tag{font-family:'Inter',sans-serif;font-size:10.5px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--green-700)}
@media (max-width: 880px){.process-grid{grid-template-columns:1fr 1fr;gap:14px}}
@media (max-width: 520px){.process-grid{grid-template-columns:1fr}}

/* ===== Reviews ===== */
.reviews{background:#fbfaf6}
.r-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:50px}
.review{background:#fff;border:1px solid var(--line-soft);border-radius:var(--radius);padding:32px 30px}
.review .stars{color:#d4a435;letter-spacing:3px;margin-bottom:14px;font-size:15px}
.review p{font-family:'Fraunces',serif;font-size:18px;line-height:1.5;color:var(--ink);font-weight:400;margin-bottom:20px;letter-spacing:-0.005em}
.review .who{display:flex;gap:12px;align-items:center}
.review .av{width:38px;height:38px;border-radius:50%;background:var(--green-50);display:grid;place-items:center;font-family:'Fraunces',serif;font-weight:600;color:var(--green-800);font-size:15px}
.review .who div{font-size:14px;font-weight:600;color:var(--ink)}
.review .who small{display:block;font-size:13px;font-weight:400;color:var(--muted);margin-top:2px}
@media (max-width: 880px){.r-grid{grid-template-columns:1fr}}

/* ===== Areas ===== */
.areas-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:60px;align-items:center}
.area-list{column-count:2;column-gap:34px}
.area-list li{padding:11px 0;border-bottom:1px solid var(--line-soft);font-size:15.5px;color:var(--ink-2);font-weight:500;display:flex;gap:10px;align-items:center;break-inside:avoid}
.area-list li svg{color:var(--green-700);flex:none}
@media (max-width: 880px){.areas-grid{grid-template-columns:1fr;gap:32px}.area-list{column-count:2}}

/* ===== Contact / Quote ===== */
.contact{background:linear-gradient(180deg,var(--green-800) 0%, var(--green-900) 100%);color:#f3eee3;position:relative;overflow:hidden}
.contact::before{content:"";position:absolute;top:-100px;right:-100px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(164,194,175,.2),transparent);pointer-events:none}
.contact h2{color:#fff}
.contact .eyebrow{color:#a4c2af}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start;position:relative;z-index:1}
.contact .lede{color:rgba(255,255,255,.78);max-width:480px}

.cc-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:36px}
.cc{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:20px;color:#fff;text-decoration:none;display:flex;gap:14px;align-items:center;transition:background .2s ease, border-color .2s ease, transform .15s ease}
.cc:hover{background:rgba(255,255,255,.09);border-color:rgba(255,255,255,.25);transform:translateY(-1px)}
.cc-icon{width:42px;height:42px;border-radius:50%;background:rgba(164,194,175,.2);color:#a4c2af;display:grid;place-items:center;flex:none}
.cc-small{font-size:11px;color:#a4c2af;text-transform:uppercase;letter-spacing:.16em;font-weight:600}
.cc-big{font-size:15.5px;font-weight:600;color:#fff;margin-top:3px;letter-spacing:0}

.form-card{background:#fbfaf6;color:var(--ink);border-radius:var(--radius);padding:36px;box-shadow:var(--shadow-lg)}
.form-card h3{font-size:26px;margin-bottom:6px}
.form-card .sub{color:var(--muted);font-size:14.5px;margin-bottom:26px}
.field{display:flex;flex-direction:column;gap:7px;margin-bottom:16px}
.field label{font-weight:600;font-size:13px;color:var(--ink);font-family:'Inter',sans-serif}
.field input,.field select,.field textarea{font:inherit;font-size:15px;padding:14px 16px;border-radius:10px;border:1px solid var(--line);background:#fff;color:var(--ink);outline:none;transition:border-color .15s, box-shadow .15s;font-family:'Inter',sans-serif}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--green-700);box-shadow:0 0 0 4px rgba(45,79,58,.1)}
.field textarea{resize:vertical;min-height:100px}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.consent{display:flex;gap:10px;align-items:flex-start;font-size:13px;color:var(--muted);margin:8px 0 16px;line-height:1.5}
.consent input{margin-top:3px;flex:none}
.form-card .submit{width:100%;justify-content:center;padding:16px;font-size:15.5px}
.form-foot{font-size:12.5px;color:var(--muted);margin-top:12px;text-align:center}

@media (max-width: 920px){
  .contact-grid{grid-template-columns:1fr;gap:38px}
  .cc-grid{grid-template-columns:1fr}
  .row2{grid-template-columns:1fr}
}

/* ===== Footer ===== */
footer.foot{background:#06120a;color:#9fb1aa;padding:64px 0 110px;font-size:14px}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:38px;margin-bottom:40px}
.foot-grid h5{color:#fff;font-size:12px;text-transform:uppercase;letter-spacing:.18em;margin-bottom:18px;font-family:'Inter',sans-serif;font-weight:600}
.foot-grid a{color:#cfd6d3;text-decoration:none;display:block;padding:6px 0;font-size:14px;font-family:'Inter',sans-serif}
.foot-grid a:hover{color:#fff}
.foot-bottom{border-top:1px solid #14241c;padding-top:22px;display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;font-size:13px;color:#7e8e89}
@media (max-width: 880px){.foot-grid{grid-template-columns:1fr 1fr}}

/* ===== Sticky mobile CTA — scroll-aware ===== */
.mobile-cta{display:none}
@media (max-width: 920px){
  .mobile-cta{display:flex;position:fixed;left:12px;right:12px;bottom:12px;z-index:70;gap:10px;background:rgba(15,26,19,.96);backdrop-filter:blur(10px);padding:10px;border-radius:999px;border:1px solid rgba(255,255,255,.08);box-shadow:0 16px 36px rgba(0,0,0,.32);
    /* Hidden by default — JS toggles .shown after scrolling past hero */
    opacity:0;pointer-events:none;transform:translateY(120%);transition:opacity .25s ease, transform .3s cubic-bezier(.2,.7,.3,1)}
  .mobile-cta.shown{opacity:1;pointer-events:auto;transform:translateY(0)}
  .mobile-cta a{flex:1;justify-content:center;padding:13px 18px;font-size:14.5px}
}

/* ===== Misc ===== */
.divider{height:1px;background:var(--line);border:0;margin:0}
.center{text-align:center}
.ic{width:18px;height:18px;flex:none}

/* ===== Specialty (earthworks + turf spotlight on home) ===== */
.specialty{background:#0f1a13;color:#f3eee3;padding:110px 0;position:relative;overflow:hidden}
.specialty::before{content:"";position:absolute;top:-200px;right:-200px;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(255,107,26,.12),transparent 70%);pointer-events:none}
.specialty-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:70px;align-items:center;position:relative;z-index:1}
.specialty .eyebrow{color:#ff8a4a}
.specialty h2{color:#fff}
.specialty h2 em{font-style:italic;color:#ffb182;font-weight:400}
.specialty .lede{color:rgba(255,255,255,.78);max-width:560px}
.specialty-list{margin-top:30px;display:grid;gap:18px}
.specialty-list li{display:flex;gap:14px;align-items:flex-start;font-size:15.5px;color:rgba(255,255,255,.78);line-height:1.6}
.specialty-list li svg{color:#a4c2af;flex:none;margin-top:3px}
.specialty-list li b{display:block;color:#fff;font-weight:600;margin-bottom:3px;font-size:16.5px}
.specialty-ctas{margin-top:34px;display:flex;flex-wrap:wrap;gap:12px}
.specialty .btn-light{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.4)}
.specialty .btn-light:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.7)}
.specialty-side{position:relative}
.specialty-photo{aspect-ratio:4/5;border-radius:18px;box-shadow:0 30px 60px rgba(0,0,0,.4);border:1px solid rgba(255,255,255,.08)}
.specialty-specs{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px}
.sp-spec{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:16px 18px;backdrop-filter:blur(4px)}
.sp-spec .num{font-family:'Fraunces',serif;font-size:26px;font-weight:500;line-height:1;color:#fff;letter-spacing:-.01em}
.sp-spec .num .u{font-size:13px;color:#a4c2af;font-weight:600;margin-left:3px;font-family:'Inter',sans-serif}
.sp-spec .lbl{font-size:11.5px;color:#9fb1aa;font-weight:600;letter-spacing:.12em;text-transform:uppercase;margin-top:8px}
@media (max-width: 920px){
  .specialty{padding:70px 0}
  .specialty-grid{grid-template-columns:1fr;gap:42px}
  .specialty-side{max-width:560px;margin:0 auto;width:100%}
  .specialty-photo{aspect-ratio:5/4}
}

/* ===== Active nav ===== */
nav.menu a.active{color:var(--green-800);font-weight:600}
nav.menu a.active::after{content:"";display:block;height:2px;background:var(--green-700);margin-top:4px;border-radius:2px}

/* ===== Service-card "Learn more" link ===== */
a.svc{text-decoration:none;color:inherit;display:block}
.svc-more{display:inline-flex;align-items:center;gap:7px;margin-top:18px;color:var(--green-700);font-size:14px;font-weight:600;letter-spacing:.01em;transition:gap .2s ease, color .2s ease;font-family:'Inter',sans-serif}
.svc-more svg{transition:transform .2s ease}
a.svc:hover .svc-more{color:var(--green-800)}
a.svc:hover .svc-more svg{transform:translateX(3px)}

/* ===== Breadcrumbs ===== */
.crumbs{background:var(--bg-warm);padding:14px 0;border-bottom:1px solid var(--line-soft);font-size:13.5px;color:var(--muted)}
.crumbs .wrap{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.crumbs a{color:var(--muted);text-decoration:none;font-weight:500}
.crumbs a:hover{color:var(--green-800)}
.crumbs .curr{color:var(--ink);font-weight:600}
.crumbs span{color:var(--line)}
.crumbs span.curr{color:var(--ink)}

/* ===== Service-page hero ===== */
.svc-hero{padding:70px 0 80px;background:var(--bg-cream)}
.svc-hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.svc-hero h1{font-size:clamp(36px,5vw,60px)}
.svc-hero h1 em{font-style:italic;color:var(--green-700);font-weight:400}
.svc-hero-photo{aspect-ratio:5/6;border-radius:var(--radius);box-shadow:var(--shadow);background:var(--bg-warm)}
@media (max-width: 880px){.svc-hero-grid{grid-template-columns:1fr;gap:34px}.svc-hero-photo{aspect-ratio:5/4;max-width:560px;margin:0 auto}}

/* ===== "What's included" list ===== */
.incl-list{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:30px}
.incl-list li{display:flex;gap:14px;align-items:flex-start;padding:22px;background:#fff;border:1px solid var(--line-soft);border-radius:14px;line-height:1.55;font-size:15px;color:var(--muted)}
.incl-list li svg{color:var(--green-700);flex:none;margin-top:2px}
.incl-list li b{display:block;color:var(--ink);font-weight:600;margin-bottom:4px;font-size:16px}
@media (max-width: 720px){.incl-list{grid-template-columns:1fr}}

/* ===== Service photos grid ===== */
.svc-photos{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.svc-photos .photo{aspect-ratio:4/5;border-radius:14px;background:var(--bg-warm)}
@media (max-width: 880px){.svc-photos{grid-template-columns:1fr 1fr}}
@media (max-width: 600px){.svc-photos{grid-template-columns:1fr}}

/* ===== FAQ ===== */
.faq-list{display:flex;flex-direction:column;gap:10px}
.faq{background:#fff;border:1px solid var(--line-soft);border-radius:14px;padding:0;overflow:hidden;transition:border-color .2s ease}
.faq[open]{border-color:var(--green-300)}
.faq summary{padding:22px 26px;cursor:pointer;font-weight:600;font-size:17px;color:var(--ink);list-style:none;display:flex;justify-content:space-between;align-items:center;font-family:'Inter',sans-serif;gap:18px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:'Fraunces',serif;font-size:26px;color:var(--green-700);font-weight:300;transition:transform .2s ease;line-height:1;width:24px;text-align:center;flex:none}
.faq[open] summary::after{content:"–"}
.faq-body{padding:0 26px 24px;color:var(--muted);font-size:15.5px;line-height:1.65}

/* ===== Related services ===== */
.rel-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.rel-card{display:flex;gap:16px;align-items:center;background:#fff;border:1px solid var(--line-soft);border-radius:14px;padding:22px;text-decoration:none;color:var(--ink);transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease}
.rel-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm);border-color:var(--green-300)}
.rel-icon{width:42px;height:42px;border-radius:50%;background:var(--green-50);color:var(--green-800);display:grid;place-items:center;flex:none}
.rel-card h4{font-family:'Inter',sans-serif;font-weight:600;font-size:15px;color:var(--ink);margin:0 0 4px}
.rel-card span{color:var(--green-700);font-size:13px;font-weight:600}
@media (max-width: 880px){.rel-grid{grid-template-columns:1fr}}

/* ===== Bottom CTA strip ===== */
.cta-strip{background:linear-gradient(135deg,var(--green-800),var(--green-900));color:#fff;padding:60px 0}
.cta-grid{display:flex;justify-content:space-between;align-items:center;gap:30px;flex-wrap:wrap}
.cta-strip h2{font-size:clamp(28px,3.4vw,40px);color:#fff;line-height:1.1}

/* ===== Page hero ===== */
.page-hero{background:var(--bg-warm);padding:70px 0 60px;border-bottom:1px solid var(--line-soft)}
.page-hero h1{font-size:clamp(40px,5.2vw,68px);max-width:840px}
.page-hero h1 em{font-style:italic;color:var(--green-700);font-weight:400}
.page-hero p{margin-top:18px;font-size:18px;color:var(--muted);max-width:680px;line-height:1.6}

/* ===== Hub services list ===== */
.hub-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:40px}
.hub-card{display:grid;grid-template-columns:.9fr 1.1fr;background:#fff;border:1px solid var(--line-soft);border-radius:var(--radius);overflow:hidden;text-decoration:none;color:var(--ink);transition:transform .2s ease, box-shadow .25s ease, border-color .2s ease}
.hub-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--green-300)}
.hub-card .photo{aspect-ratio:auto;min-height:240px;background:var(--bg-warm)}
.hub-card-body{padding:30px}
.hub-card h3{font-size:22px;margin-bottom:8px}
.hub-card p{color:var(--muted);font-size:15px;line-height:1.55}
.hub-card .more{display:inline-flex;align-items:center;gap:6px;margin-top:18px;color:var(--green-700);font-size:14px;font-weight:600;font-family:'Inter',sans-serif}
@media (max-width: 880px){.hub-grid{grid-template-columns:1fr}.hub-card{grid-template-columns:1fr}.hub-card .photo{min-height:200px;aspect-ratio:16/10}}

/* ===== Big work gallery ===== */
.work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:40px}
.work-card{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:4/5;display:block;text-decoration:none;color:#fff;background:var(--bg-warm)}
.work-card .photo{position:absolute;inset:0;aspect-ratio:auto}
.work-card .photo > img{transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.work-card:hover .photo > img{transform:scale(1.05)}
.work-card .meta{position:absolute;left:0;right:0;bottom:0;padding:24px;background:linear-gradient(180deg,transparent,rgba(7,20,12,.85));z-index:2}
.work-card .meta small{display:block;font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:#a4c2af;margin-bottom:6px}
.work-card .meta strong{font-family:'Fraunces',serif;font-size:20px;font-weight:500;line-height:1.15;display:block;color:#fff;letter-spacing:-.005em}
@media (max-width: 880px){.work-grid{grid-template-columns:1fr 1fr;gap:12px}}
@media (max-width: 520px){.work-grid{grid-template-columns:1fr}}

/* ===== Contact-page split ===== */
.contact-page{padding:60px 0}
.contact-page-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
@media (max-width: 880px){.contact-page-grid{grid-template-columns:1fr;gap:36px}}
.contact-page .form-card{background:#fff;border:1px solid var(--line-soft)}
.cinfo-block{margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid var(--line-soft)}
.cinfo-block:last-child{border-bottom:0}
.cinfo-block h4{font-family:'Fraunces',serif;font-weight:500;font-size:22px;color:var(--ink);letter-spacing:-.01em;margin-bottom:8px}
.cinfo-block p{color:var(--muted);font-size:15px;line-height:1.55;margin-bottom:14px}
.cinfo-row{display:flex;gap:12px;align-items:center;color:var(--ink);text-decoration:none;font-weight:600;padding:6px 0}
.cinfo-row svg{color:var(--green-700)}

/* ============================================
   MOBILE TIGHTENING (≤ 600px)
   ============================================ */
@media (max-width: 600px){
  /* Wrap padding — generous so text isn't edge-to-edge */
  .wrap{padding:0 22px}

  /* Headline scale-down */
  h1{font-size:clamp(28px,8vw,36px)}
  h2{font-size:clamp(24px,6vw,30px)}
  h3{font-size:19px}
  .lede{font-size:15.5px;line-height:1.55}
  .eyebrow{font-size:11px;margin-bottom:10px}

  /* Section vertical rhythm */
  section{padding:54px 0}
  section.block{padding:54px 0}
  section.block.tight{padding:42px 0}
  .shead{margin-bottom:28px;gap:12px}
  .shead p{font-size:15px}

  /* Top bar slimmer */
  .topbar{font-size:12px}
  .topbar .wrap{padding:7px 22px;gap:8px}

  /* Header more compact */
  .nav-inner{padding-top:12px;padding-bottom:12px;gap:12px}
  .brand-name{font-size:17px}
  .brand-name small{font-size:9px;letter-spacing:.18em;margin-top:4px}
  .nav-cta .btn{padding:9px 14px;font-size:13.5px}
  .menu-toggle{width:38px;height:38px}

  /* Hero — significantly tighter */
  .hero-grid{padding-top:42px;padding-bottom:50px;gap:30px}
  .hero h1{font-size:clamp(26px,7.4vw,34px);line-height:1.1}
  .hero .lede{font-size:15.5px;margin-bottom:22px}
  .hero-ctas{gap:10px;margin-bottom:26px}
  .hero-ctas .btn{flex:1;justify-content:center;padding:14px 16px;font-size:14.5px;min-width:0}
  .hero-strip{gap:12px 18px;padding-top:22px}
  .hero-strip .item{font-size:12.5px}
  .hero-card{aspect-ratio:4/3;max-width:none}
  .hero-card .meta strong{font-size:17px}
  /* Hide the floating 120+ stat on small screens — it overlaps the hero-card meta */
  .hero-stat{display:none}
  .hero-side{margin-top:-6px}

  /* Tag marquee tighter */
  .tags{font-size:13.5px;padding:18px 22px;gap:14px}
  .tags .dotmark{width:4px;height:4px}

  /* Trust strip / promise */
  .promise{padding:54px 0}
  .promise-grid{gap:30px}
  .promise li{font-size:14.5px;line-height:1.5}
  .promise li b{font-size:15.5px}
  .promise ul{gap:14px;margin-top:22px}

  /* Specialty section */
  .specialty{padding:54px 0}
  .specialty-grid{gap:30px}
  .specialty-list li{font-size:14.5px;line-height:1.5}
  .specialty-list li b{font-size:15.5px}
  .specialty-list{gap:14px;margin-top:22px}
  .specialty-ctas{gap:10px;margin-top:26px}
  .specialty-ctas .btn{flex:1;justify-content:center;padding:13px 14px;font-size:14px;min-width:0}
  .specialty-photo{aspect-ratio:4/3}
  .sp-spec{padding:13px 14px}
  .sp-spec .num{font-size:22px}
  .sp-spec .lbl{font-size:10.5px}

  /* Service cards */
  .svc{padding:24px 22px;border-radius:14px}
  .svc-icon{width:40px;height:40px;margin-bottom:14px}
  .svc h3{font-size:18px}
  .svc p{font-size:14.5px;line-height:1.55}
  .svc-more{font-size:13px;margin-top:14px}

  /* Featured project */
  .featured{border-radius:14px}
  .featured .photo{min-height:240px;aspect-ratio:4/3}
  .featured-body{padding:28px 22px}
  .featured-body .stats{gap:12px;margin-top:22px;padding-top:22px}
  .featured-body .stat .num{font-size:20px}
  .featured-body .stat .lbl{font-size:10.5px}

  /* Process steps */
  .process-grid{gap:10px;margin-top:30px}
  .step{padding:22px 20px;border-radius:12px}
  .step h4{font-size:16px}
  .step p{font-size:14px}

  /* Reviews */
  .review{padding:24px 22px;border-radius:14px}
  .review p{font-size:16px;line-height:1.45}
  .review .who{gap:10px}
  .review .av{width:34px;height:34px;font-size:14px}

  /* Areas */
  .area-list li{font-size:14.5px;padding:9px 0}

  /* Contact form */
  .form-card{padding:24px 20px;border-radius:14px}
  .form-card h3{font-size:20px}
  .field input,.field select,.field textarea{padding:12px 13px;font-size:14.5px}
  .cc{padding:14px;border-radius:10px}
  .cc-big{font-size:14px}
  .form-card .submit{padding:14px;font-size:15px}

  /* CTA strip */
  .cta-strip{padding:42px 0}
  .cta-grid{gap:20px}
  .cta-strip h2{font-size:clamp(22px,5.5vw,28px)}
  .cta-strip .btn{padding:13px 18px;font-size:14.5px}

  /* Page hero (subpages) */
  .page-hero{padding:42px 0 38px}
  .page-hero h1{font-size:clamp(28px,8vw,38px)}
  .page-hero p{font-size:15.5px;margin-top:14px}

  /* Service page hero */
  .svc-hero{padding:38px 0 48px}
  .svc-hero h1{font-size:clamp(28px,8vw,38px)}
  .svc-hero-grid{gap:24px}
  .svc-hero-photo{aspect-ratio:4/3}

  /* Included list */
  .incl-list{gap:14px;margin-top:22px}
  .incl-list li{padding:18px;font-size:14.5px}
  .incl-list li b{font-size:15.5px}

  /* FAQ */
  .faq summary{padding:18px 20px;font-size:15.5px}
  .faq-body{padding:0 20px 20px;font-size:14.5px}

  /* Related cards */
  .rel-card{padding:18px}
  .rel-card h4{font-size:14.5px}
  .rel-card span{font-size:12.5px}
  .rel-icon{width:38px;height:38px}

  /* Hub cards */
  .hub-card .photo{min-height:170px}
  .hub-card-body{padding:22px}
  .hub-card h3{font-size:19px}
  .hub-card p{font-size:14.5px}

  /* Work gallery cards */
  .work-grid{gap:10px}
  .work-card .meta{padding:18px}
  .work-card .meta strong{font-size:16px}

  /* Crumbs */
  .crumbs{padding:11px 0;font-size:12.5px}

  /* Footer */
  footer.foot{padding:42px 0 100px}
  .foot-grid{gap:24px;margin-bottom:24px}

  /* Sticky mobile CTA tighter */
  .mobile-cta{left:8px;right:8px;bottom:8px;padding:8px}
  .mobile-cta a{padding:11px 14px;font-size:13.5px}
  body{padding-bottom:78px}

  /* Buttons on mobile */
  .btn{padding:12px 18px;font-size:14.5px}
  .btn-lg{padding:14px 22px;font-size:15px}
}

/* Even tighter for ≤ 380px */
@media (max-width: 380px){
  .wrap{padding:0 18px}
  .topbar .wrap{padding:6px 18px}
  .hero-card{aspect-ratio:5/4}
  .featured-body .stats{grid-template-columns:1fr}
  .nav-cta .btn{padding:8px 12px}
}
