/* =========================================================
   HJ LANDSCAPING & CONSTRUCTION — Site stylesheet
   Tokens lifted from the design system (colors_and_type.css)
   ========================================================= */
:root{
  --ink:#14110F; --ink-soft:#1F1B18; --charcoal:#2A2522; --ink-deepest:#0B0908;
  --stone-900:#3A322C; --stone-700:#5C5147; --stone-500:#8A7E72;
  --stone-300:#C9BFB0; --stone-200:#DCD3C4; --stone-100:#EFE9DE;
  --bone:#F7F3EB; --paper:#FFFFFF;
  --earth-deep:#2E1A0F; --earth:#5B3A22; --earth-soft:#8C6240;
  --leaf-deep:#2F6A18; --leaf:#4FA12B; --leaf-bright:#7BC94A;
  --bg:var(--bone); --fg-1:var(--ink); --fg-2:var(--stone-700); --fg-3:var(--stone-500);
  --fg-on-dark-1:var(--bone); --fg-on-dark-2:#B8AE9F; --fg-on-dark-3:#7A7167;
  --border:var(--stone-300); --border-strong:var(--stone-700); --accent:var(--leaf);
  --font-display:"Oswald","Arial Narrow",sans-serif;
  --font-body:"Manrope",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --font-mono:"JetBrains Mono",ui-monospace,Menlo,monospace;
  --container:1280px; --container-wide:1480px; --gutter:clamp(20px,4vw,56px);
  --ease-out:cubic-bezier(0.22,1,0.36,1);
  --dur-fast:150ms; --dur-base:280ms;
  --shadow-1:0 1px 2px rgba(20,17,15,0.06);
  --shadow-2:0 4px 14px rgba(20,17,15,0.08);
  --shadow-3:0 14px 40px rgba(20,17,15,0.12);
}
*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
html{background:var(--ink);scroll-behavior:smooth;}
body{font-family:var(--font-body);font-size:16px;line-height:1.5;color:var(--fg-1);background:var(--bone);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}
a{text-decoration:none;color:inherit;}
button{font-family:inherit;}
input,textarea,select{font-family:inherit;}
img{display:block;max-width:100%;}
::selection{background:var(--ink);color:var(--bone);}
::-webkit-scrollbar{width:10px;}
::-webkit-scrollbar-track{background:var(--ink-deepest);}
::-webkit-scrollbar-thumb{background:var(--stone-900);border-radius:6px;}

/* Skip link */
.skip{position:absolute;left:-999px;top:0;background:var(--leaf);color:var(--ink);padding:10px 16px;z-index:100;font-weight:600;}
.skip:focus{left:8px;top:8px;}

/* ---- atoms ---- */
.eyebrow{display:inline-flex;align-items:center;gap:12px;font-family:var(--font-display);font-weight:500;font-size:12px;letter-spacing:0.22em;text-transform:uppercase;color:var(--stone-700);}
.eyebrow::before{content:"";width:28px;height:1px;background:var(--leaf);display:inline-block;flex:none;}
.eyebrow--dark{color:var(--fg-on-dark-2);}
.eyebrow--dark::before{background:var(--leaf-bright);}
.mono{font-family:var(--font-mono);}

.reveal{opacity:0;transform:translateY(14px);transition:opacity 700ms var(--ease-out),transform 700ms var(--ease-out);}
.reveal.in{opacity:1;transform:none;}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none;}html{scroll-behavior:auto;}}

/* ---- buttons ---- */
.btn-accent{background:var(--leaf);color:var(--ink);font-weight:600;font-size:14px;padding:12px 20px;border-radius:2px;border:none;cursor:pointer;transition:background 180ms var(--ease-out),transform 180ms var(--ease-out);display:inline-flex;align-items:center;gap:10px;}
.btn-accent:hover{background:var(--leaf-bright);transform:translateY(-1px);}
.btn-bone{background:var(--bone);color:var(--ink);border:none;font-weight:600;font-size:15px;padding:16px 28px;border-radius:2px;cursor:pointer;display:inline-flex;align-items:center;gap:10px;transition:transform 180ms var(--ease-out),box-shadow 180ms var(--ease-out);}
.btn-bone:hover{transform:translateY(-1px);box-shadow:var(--shadow-1);}
.btn-bone .arrow{color:var(--leaf);}
.btn-outline-bone{background:transparent;color:var(--bone);border:1px solid var(--bone);font-weight:600;font-size:15px;padding:15px 28px;border-radius:2px;cursor:pointer;transition:background 180ms var(--ease-out),color 180ms var(--ease-out);}
.btn-outline-bone:hover{background:var(--bone);color:var(--ink);}
.btn-ink{background:var(--ink);color:var(--bone);border:none;font-weight:600;font-size:15px;padding:16px 28px;border-radius:2px;cursor:pointer;display:inline-flex;align-items:center;gap:10px;transition:background 180ms var(--ease-out),transform 180ms var(--ease-out),box-shadow 180ms var(--ease-out);}
.btn-ink:hover{background:var(--charcoal);transform:translateY(-1px);box-shadow:var(--shadow-1);}
.btn-ink .arrow{color:var(--leaf-bright);}
.btn-outline-ink{background:transparent;color:var(--ink);border:1px solid var(--ink);font-weight:600;font-size:15px;padding:15px 28px;border-radius:2px;cursor:pointer;transition:background 180ms var(--ease-out),color 180ms var(--ease-out);}
.btn-outline-ink:hover{background:var(--ink);color:var(--bone);}

/* =========================================================
   NAV
   ========================================================= */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;background:transparent;border-bottom:1px solid transparent;transition:background var(--dur-base) var(--ease-out),border-color var(--dur-base) var(--ease-out),backdrop-filter var(--dur-base) var(--ease-out);}
.nav.scrolled,.nav.solid{background:rgba(20,17,15,0.86);backdrop-filter:blur(14px) saturate(110%);-webkit-backdrop-filter:blur(14px) saturate(110%);border-bottom:1px solid rgba(255,255,255,0.08);}
.nav__inner{max-width:var(--container-wide);margin:0 auto;padding:18px var(--gutter);display:flex;align-items:center;justify-content:space-between;}
.brand{display:flex;align-items:center;gap:14px;}
.brand__badge{width:38px;height:38px;border-radius:50%;flex:none;background:#fff center/cover no-repeat;border:2px solid var(--bone);box-shadow:inset 0 0 0 1px rgba(20,17,15,0.15);}
.brand__name{line-height:1;font-family:var(--font-display);}
.brand__name b{display:block;color:var(--bone);font-weight:700;font-size:20px;letter-spacing:-0.01em;text-transform:uppercase;}
.brand__name span{display:block;color:var(--fg-on-dark-2);font-weight:300;font-size:10px;letter-spacing:0.22em;margin-top:3px;text-transform:uppercase;}
.nav__links{display:flex;align-items:center;gap:36px;}
.nav__links a{color:var(--bone);font-size:14px;font-weight:500;letter-spacing:0.02em;transition:opacity var(--dur-fast) var(--ease-out);}
.nav__links a:hover,.nav__links a[aria-current="page"]{opacity:0.65;}
.nav__links a.btn-accent{opacity:1;color:var(--ink);}
.nav__toggle{display:none;background:none;border:none;cursor:pointer;padding:8px;position:relative;z-index:60;}
.nav__toggle span{display:block;width:24px;height:2px;background:var(--bone);margin:5px 0;transition:transform var(--dur-base) var(--ease-out),opacity var(--dur-base) var(--ease-out);}

/* =========================================================
   SECTION SHELL
   ========================================================= */
.section{padding:clamp(80px,10vw,160px) var(--gutter);}
.section--light{background:var(--bone);}
.section--dark{background:var(--ink);color:var(--bone);}
.section--ruled{border-top:1px solid var(--border);border-bottom:1px solid var(--border);}
.section--tight{padding-top:clamp(48px,6vw,90px);}
.wrap{max-width:var(--container-wide);margin:0 auto;}
.wrap--mid{max-width:var(--container);margin:0 auto;}
.wrap--narrow{max-width:1100px;margin:0 auto;}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:24px;margin-bottom:48px;}
.section-title{font-family:var(--font-display);font-size:clamp(40px,5vw,68px);font-weight:600;text-transform:uppercase;letter-spacing:-0.015em;line-height:1.02;margin:0;color:var(--ink);max-width:900px;}
.section--dark .section-title{color:var(--bone);}
.eyebrow-row{margin-bottom:22px;display:flex;}
.text-link{font-weight:600;font-size:15px;display:inline-flex;align-items:center;gap:8px;color:var(--ink);transition:opacity var(--dur-fast) var(--ease-out);}
.section--dark .text-link{color:var(--bone);}
.text-link:hover{opacity:0.65;}
.text-link .arrow{color:var(--leaf);}
.section--dark .text-link .arrow{color:var(--leaf-bright);}
.lead{font-size:20px;line-height:1.5;color:var(--fg-2);max-width:60ch;}
.section--dark .lead{color:var(--fg-on-dark-2);}

/* =========================================================
   PAGE HERO (interior pages)
   ========================================================= */
.page-hero{background:var(--ink);color:var(--bone);padding:clamp(140px,16vw,220px) var(--gutter) clamp(64px,8vw,110px);position:relative;overflow:hidden;}
.page-hero__bar{position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,#5B3A22 0%,#5B3A22 40%,#4FA12B 60%,#7BC94A 100%);}
.page-hero h1{font-family:var(--font-display);font-size:clamp(44px,7vw,104px);font-weight:700;text-transform:uppercase;letter-spacing:-0.025em;line-height:0.95;margin:0;color:var(--bone);}
.page-hero h1 .leaf{color:var(--leaf-bright);}
.page-hero .lead{margin-top:28px;}
.breadcrumb{font-family:var(--font-mono);font-size:12px;color:var(--fg-on-dark-2);margin-bottom:28px;display:flex;gap:8px;flex-wrap:wrap;}
.breadcrumb a:hover{color:var(--bone);}
.breadcrumb span{color:var(--fg-on-dark-3);}

/* =========================================================
   PHOTO-COMING FRAMES (styled empty image placeholders)
   ========================================================= */
.photoframe{position:relative;background:repeating-linear-gradient(135deg,var(--stone-100),var(--stone-100) 12px,var(--stone-200) 12px,var(--stone-200) 24px);border:1px solid var(--stone-300);border-radius:8px;overflow:hidden;display:flex;align-items:center;justify-content:center;color:var(--stone-500);}
img.photoframe{object-fit:cover;width:100%;height:100%;display:block;background:var(--ink-soft);}
.photoframe::after{content:attr(data-label);position:absolute;font-family:var(--font-display);text-transform:uppercase;letter-spacing:0.22em;font-size:11px;color:var(--stone-700);background:var(--bone);padding:7px 12px;border:1px solid var(--stone-300);border-radius:2px;}
.photoframe--dark{background:repeating-linear-gradient(135deg,var(--ink-soft),var(--ink-soft) 12px,#23201d 12px,#23201d 24px);border-color:rgba(255,255,255,0.08);}
.photoframe--dark::after{color:var(--fg-on-dark-2);background:var(--ink);border-color:rgba(255,255,255,0.12);}
.photoframe--4x3{aspect-ratio:4/3;}
.photoframe--21x10{aspect-ratio:21/10;}
.photoframe--1x1{aspect-ratio:1/1;}
.photoframe--3x4{aspect-ratio:3/4;}

/* =========================================================
   HOME — HERO
   ========================================================= */
.hero{position:relative;background:var(--ink);color:var(--bone);min-height:100vh;display:flex;align-items:stretch;padding-top:80px;overflow:hidden;}
.hero__content{flex:1 1 56%;padding:clamp(40px,6vw,100px) clamp(20px,4vw,80px);display:flex;flex-direction:column;justify-content:space-between;gap:48px;}
.hero__title{font-family:var(--font-display);font-weight:700;font-size:clamp(56px,9.5vw,156px);line-height:0.92;letter-spacing:-0.025em;text-transform:uppercase;margin:0;color:var(--bone);}
.hero__title .leaf{color:var(--leaf-bright);}
.hero__lead{font-size:20px;line-height:1.45;color:var(--fg-on-dark-2);max-width:460px;margin-top:40px;font-weight:400;}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center;}
.hero__media{flex:1 1 44%;position:relative;}
.hero__media .photoframe{position:absolute;inset:0;border-radius:0;border:none;border-left:1px solid rgba(255,255,255,0.08);}
.hero__plate{position:absolute;bottom:32px;right:var(--gutter);background:rgba(20,17,15,0.82);backdrop-filter:blur(8px);padding:18px 22px;border-left:2px solid var(--leaf);color:var(--bone);max-width:320px;z-index:2;}
.hero__plate-eyebrow{font-family:var(--font-display);text-transform:uppercase;letter-spacing:0.18em;font-size:10px;color:var(--fg-on-dark-2);margin-bottom:6px;}
.hero__plate-title{font-family:var(--font-display);text-transform:uppercase;font-size:22px;letter-spacing:-0.01em;font-weight:600;line-height:1.1;}
.hero__plate-meta{font-family:var(--font-mono);font-size:13px;color:var(--fg-on-dark-2);margin-top:6px;}

/* trust strip */
.trust{background:var(--ink-deepest);color:var(--fg-on-dark-2);border-top:1px solid rgba(255,255,255,0.06);}
.trust__inner{max-width:var(--container-wide);margin:0 auto;padding:22px var(--gutter);display:flex;flex-wrap:wrap;gap:14px 40px;align-items:center;justify-content:center;font-family:var(--font-display);text-transform:uppercase;letter-spacing:0.18em;font-size:12px;}
.trust__inner span{display:inline-flex;align-items:center;gap:10px;}
.trust__inner span::before{content:"";width:6px;height:6px;background:var(--leaf);border-radius:50%;flex:none;}

/* =========================================================
   SERVICES STRIP (home)
   ========================================================= */
.services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--ink);}
.service{padding:36px 28px 28px 28px;border-right:1px solid var(--stone-300);}
.service:first-child{padding-left:0;}
.service:last-child{border-right:none;}
.service__n{font-family:var(--font-mono);font-size:13px;color:var(--stone-500);margin-bottom:22px;}
.service__title{font-family:var(--font-display);text-transform:uppercase;font-weight:600;font-size:22px;letter-spacing:-0.005em;line-height:1.1;margin:0 0 12px;color:var(--ink);}
.service__blurb{font-size:14.5px;line-height:1.55;color:var(--stone-700);margin:0;}
.service__link{margin-top:18px;font-size:13px;}

/* =========================================================
   PROJECT GRID
   ========================================================= */
.filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:40px;}
.chip{font-size:13px;font-weight:500;padding:9px 16px;border-radius:999px;cursor:pointer;background:transparent;color:var(--ink);border:1px solid var(--stone-300);transition:all 180ms var(--ease-out);}
.chip:hover{border-color:var(--stone-700);}
.chip.active{background:var(--ink);color:var(--bone);border-color:var(--ink);}
.projects{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;}
.projects--3{grid-template-columns:repeat(3,1fr);}
.project{display:block;border-radius:8px;overflow:hidden;background:var(--ink);}
.project__media{aspect-ratio:4/3;overflow:hidden;position:relative;}
.project__media .photoframe{position:absolute;inset:0;border-radius:0;border:none;transition:transform 700ms var(--ease-out);}
.project:hover .project__media .photoframe{transform:scale(1.04);}
.project__tag{position:absolute;top:16px;left:16px;z-index:2;font-family:var(--font-display);text-transform:uppercase;letter-spacing:0.22em;font-size:10.5px;color:var(--ink);font-weight:600;display:flex;align-items:center;gap:8px;background:var(--leaf-bright);padding:5px 10px;border-radius:2px;}
.project__bar{background:var(--ink);padding:20px 22px;display:flex;justify-content:space-between;align-items:center;gap:14px;}
.project__name{font-family:var(--font-display);text-transform:uppercase;font-weight:600;font-size:20px;letter-spacing:-0.005em;line-height:1.1;color:var(--bone);}
.project__meta{font-family:var(--font-mono);font-size:12px;color:var(--fg-on-dark-2);margin-top:6px;}
.project__arrow{color:var(--leaf);font-size:22px;transition:transform 220ms var(--ease-out);}
.project:hover .project__arrow{transform:translateX(4px);}

/* =========================================================
   BEFORE / AFTER
   ========================================================= */
.ba-head{display:grid;grid-template-columns:1fr 1.6fr;gap:64px;margin-bottom:56px;align-items:end;}
.ba-head h2{font-family:var(--font-display);font-size:clamp(40px,5vw,72px);font-weight:600;text-transform:uppercase;letter-spacing:-0.015em;line-height:1.02;margin:0;}
.ba-head p{font-size:18px;line-height:1.55;color:var(--fg-on-dark-2);margin:0;max-width:540px;}
.ba{position:relative;width:100%;aspect-ratio:21/10;border-radius:8px;overflow:hidden;user-select:none;cursor:ew-resize;}
.ba__layer{position:absolute;inset:0;}
.ba__layer .photoframe{position:absolute;inset:0;border-radius:0;border:none;}
.ba__before{clip-path:inset(0 50% 0 0);}
.ba__label{position:absolute;top:18px;z-index:3;font-family:var(--font-display);text-transform:uppercase;letter-spacing:0.22em;font-size:11px;font-weight:500;padding:6px 10px;}
.ba__label--before{left:18px;color:var(--bone);background:rgba(20,17,15,0.7);}
.ba__label--after{right:18px;color:var(--ink);font-weight:600;background:var(--leaf-bright);}
.ba__divider{position:absolute;top:0;bottom:0;left:50%;width:2px;background:var(--bone);transform:translateX(-1px);z-index:4;box-shadow:0 0 0 1px rgba(20,17,15,0.2),0 4px 16px rgba(20,17,15,0.4);}
.ba__handle{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:52px;height:52px;border-radius:50%;background:var(--bone);border:2px solid var(--ink);cursor:ew-resize;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;color:var(--ink);font-size:20px;box-shadow:0 4px 16px rgba(20,17,15,0.4);touch-action:none;}
.ba-foot{display:flex;justify-content:space-between;align-items:center;margin-top:28px;flex-wrap:wrap;gap:16px;}
.ba-foot .mono{font-size:13px;color:var(--fg-on-dark-2);}

/* =========================================================
   TESTIMONIAL
   ========================================================= */
.quote{font-family:var(--font-display);font-weight:300;font-size:clamp(28px,3.6vw,52px);line-height:1.15;letter-spacing:-0.015em;margin:0;color:var(--ink);border-left:2px solid var(--leaf);padding-left:32px;}
.attrib{margin-top:48px;display:flex;align-items:center;gap:18px;padding-left:34px;}
.attrib__avatar{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#5B3A22,#8A7E72);border:1px solid var(--stone-300);flex:none;}
.attrib__name{font-weight:600;font-size:15px;color:var(--ink);}
.attrib__meta{font-family:var(--font-mono);font-size:12px;color:var(--stone-500);margin-top:4px;}

/* =========================================================
   CTA BAND
   ========================================================= */
.cta{position:relative;overflow:hidden;}
.cta__bar{position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,#5B3A22 0%,#5B3A22 40%,#4FA12B 60%,#7BC94A 100%);}
.cta__grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;max-width:1200px;margin:0 auto;}
.cta__title{font-family:var(--font-display);font-size:clamp(44px,5.4vw,80px);font-weight:700;text-transform:uppercase;letter-spacing:-0.02em;line-height:0.98;margin:0 0 28px;color:var(--bone);}
.cta__lead{font-size:18px;color:var(--fg-on-dark-2);line-height:1.55;max-width:460px;margin:0;}
.cta__contact{margin-top:48px;display:flex;flex-direction:column;gap:14px;font-family:var(--font-mono);font-size:13px;color:var(--fg-on-dark-2);}
.cta__contact a:hover{color:var(--bone);}
.form{display:flex;flex-direction:column;gap:18px;}
.field{display:flex;flex-direction:column;gap:6px;}
.field label{font-family:var(--font-display);text-transform:uppercase;letter-spacing:0.18em;font-size:11px;color:var(--fg-on-dark-2);font-weight:500;}
.field input,.field textarea,.field select{background:transparent;border:none;border-bottom:1px solid rgba(255,255,255,0.18);padding:10px 0;font-size:16px;color:var(--bone);outline:none;transition:border-color 180ms var(--ease-out);}
.field select option{background:var(--ink);color:var(--bone);}
.field textarea{resize:none;}
.field input:focus,.field textarea:focus,.field select:focus{border-bottom-color:var(--leaf-bright);}
.field input::placeholder,.field textarea::placeholder{color:var(--fg-on-dark-3);}
.form .btn-accent{margin-top:8px;align-self:flex-start;padding:16px 28px;font-size:15px;}
.thanks{background:var(--ink-soft);padding:40px;border-radius:8px;border:1px solid rgba(255,255,255,0.08);}
.thanks__check{width:48px;height:48px;border-radius:50%;background:var(--leaf);display:flex;align-items:center;justify-content:center;color:var(--ink);font-size:22px;margin-bottom:20px;font-weight:700;}
.thanks h3{font-family:var(--font-display);text-transform:uppercase;font-size:28px;font-weight:600;margin:0 0 12px;color:var(--bone);}
.thanks p{color:var(--fg-on-dark-2);font-size:15px;line-height:1.55;margin:0;}

/* =========================================================
   GENERIC CONTENT (about / service pages)
   ========================================================= */
.prose p{max-width:65ch;line-height:1.65;color:var(--fg-2);margin:0 0 1.1em;font-size:16.5px;}
.prose h2{font-family:var(--font-display);text-transform:uppercase;font-size:clamp(28px,3.2vw,40px);font-weight:600;letter-spacing:-0.01em;margin:0 0 20px;color:var(--ink);}
.prose h3{font-family:var(--font-display);text-transform:uppercase;font-size:22px;font-weight:600;margin:32px 0 12px;color:var(--ink);}
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,90px);align-items:center;}
.split--text-first{grid-template-columns:1.1fr 0.9fr;}

.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;border-top:1px solid var(--border);padding-top:40px;margin-top:8px;}
.stat__n{font-family:var(--font-display);font-weight:300;font-size:clamp(44px,5vw,72px);line-height:1;color:var(--ink);letter-spacing:-0.02em;}
.section--dark .stat__n{color:var(--bone);}
.stat__n em{color:var(--leaf);font-style:normal;}
.stat__label{font-family:var(--font-mono);font-size:12.5px;color:var(--fg-3);margin-top:12px;}
.section--dark .stat__label{color:var(--fg-on-dark-2);}

/* service detail blocks */
.svc-block{display:grid;grid-template-columns:0.9fr 1.1fr;gap:clamp(32px,5vw,80px);align-items:center;padding:clamp(48px,7vw,90px) 0;border-bottom:1px solid var(--border);}
.svc-block:last-child{border-bottom:none;}
.svc-block:nth-child(even) .svc-block__media{order:-1;}
.svc-block__n{font-family:var(--font-mono);font-size:13px;color:var(--stone-500);margin-bottom:16px;}
.svc-block h2{font-family:var(--font-display);text-transform:uppercase;font-size:clamp(28px,3.6vw,46px);font-weight:600;letter-spacing:-0.01em;line-height:1.04;margin:0 0 18px;color:var(--ink);}
.svc-list{list-style:none;padding:0;margin:22px 0 0;display:grid;grid-template-columns:1fr 1fr;gap:10px 24px;}
.svc-list li{font-size:14.5px;color:var(--fg-2);padding-left:20px;position:relative;}
.svc-list li::before{content:"";position:absolute;left:0;top:9px;width:8px;height:1px;background:var(--leaf);}

/* contact page */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,90px);align-items:start;}
.contact-info{display:flex;flex-direction:column;gap:28px;}
.contact-item__label{font-family:var(--font-display);text-transform:uppercase;letter-spacing:0.22em;font-size:11px;color:var(--fg-on-dark-2);margin-bottom:8px;}
.contact-item__value{font-size:18px;color:var(--bone);}
.contact-item__value a:hover{color:var(--leaf-bright);}
.map-frame{border:1px solid rgba(255,255,255,0.1);border-radius:8px;overflow:hidden;margin-top:8px;}
.map-frame iframe{display:block;width:100%;height:320px;border:0;filter:grayscale(0.3) contrast(1.05);}

/* =========================================================
   FOOTER
   ========================================================= */
.footer{background:var(--ink-deepest);color:var(--fg-on-dark-2);padding:clamp(60px,7vw,100px) var(--gutter) 40px;}
.footer__grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:48px;padding-bottom:56px;border-bottom:1px solid rgba(255,255,255,0.08);}
.footer__brand .brand__badge{width:44px;height:44px;}
.footer__brand .brand__name b{font-size:22px;}
.footer__brand .brand__name span{color:var(--fg-on-dark-3);font-size:11px;}
.footer__about{font-size:14.5px;color:var(--fg-on-dark-2);line-height:1.6;max-width:360px;margin-top:28px;}
.foot-col__title{font-family:var(--font-display);text-transform:uppercase;letter-spacing:0.22em;font-size:11px;color:var(--bone);font-weight:500;margin-bottom:22px;}
.foot-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px;}
.foot-col a{color:var(--fg-on-dark-2);font-size:14px;transition:opacity var(--dur-fast) var(--ease-out);}
.foot-col a:hover{opacity:0.65;}
.footer__fine{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;margin-top:32px;font-family:var(--font-mono);font-size:12px;color:var(--stone-700);}
.footer__fine a{color:var(--stone-700);}
.footer__fine-links{display:flex;gap:22px;}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1080px){.footer__grid{grid-template-columns:1fr 1fr;}.projects--3{grid-template-columns:repeat(2,1fr);}}
@media (max-width:900px){
  .nav__toggle{display:block;}
  .nav__links{position:fixed;top:0;right:0;height:100vh;width:min(78vw,340px);flex-direction:column;align-items:flex-start;justify-content:center;gap:28px;background:rgba(20,17,15,0.97);backdrop-filter:blur(14px);padding:0 40px;transform:translateX(100%);transition:transform var(--dur-base) var(--ease-out);z-index:55;}
  body.nav-open{overflow:hidden;}
  body.nav-open .nav__links{transform:translateX(0);}
  body.nav-open .nav__toggle span:nth-child(1){transform:translateY(7px) rotate(45deg);}
  body.nav-open .nav__toggle span:nth-child(2){opacity:0;}
  body.nav-open .nav__toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
  .nav__links a{font-size:18px;}
  .hero{flex-direction:column;}
  .hero__content{flex:none;}
  .hero__media{flex:none;min-height:46vh;}
  .ba-head{grid-template-columns:1fr;gap:24px;}
  .cta__grid,.contact-grid,.split,.split--text-first,.svc-block{grid-template-columns:1fr;gap:40px;}
  .svc-block:nth-child(even) .svc-block__media{order:0;}
  .stats{grid-template-columns:1fr 1fr;gap:32px 24px;}
}
@media (max-width:760px){
  .services-grid{grid-template-columns:1fr 1fr;}
  .service{border-right:none;}
  .service:nth-child(odd){border-right:1px solid var(--stone-300);padding-left:0;}
  .service:nth-child(3),.service:nth-child(4){border-top:1px solid var(--stone-300);}
  .projects,.projects--3{grid-template-columns:1fr;}
  .footer__grid{grid-template-columns:1fr;gap:40px;}
  .svc-list{grid-template-columns:1fr;}
}
@media (max-width:520px){
  .services-grid{grid-template-columns:1fr;}
  .service,.service:nth-child(odd){border-right:none;padding-left:0;border-top:1px solid var(--stone-300);}
  .service:first-child{border-top:none;}
  .stats{grid-template-columns:1fr;}
}

/* =========================================================
   SERVICE-AREA PAGES
   ========================================================= */
.area-meta{font-family:var(--font-mono);font-size:12.5px;color:var(--fg-on-dark-2);margin-top:24px;display:flex;flex-wrap:wrap;gap:8px 20px;}
.area-meta span{display:inline-flex;align-items:center;gap:8px;}
.area-meta span::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--leaf-bright);flex:none;}

.terrain{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--border);margin-top:8px;}
.terrain__item{padding:48px 44px 44px;border-right:1px solid var(--stone-300);border-bottom:1px solid var(--stone-300);}
.terrain__item:first-child{padding-left:0;}
.terrain__item:last-child{border-right:none;padding-right:0;}
/* outer-edge columns flush to container: every 3rd item has no right border + right pad 0; every (3n+1) item left pad 0 */
.terrain__item:nth-child(3n){border-right:none;padding-right:0;}
.terrain__item:nth-child(3n+1){padding-left:0;}
/* last row: drop the bottom border so the block closes cleanly */
.terrain__item:nth-last-child(-n+3){border-bottom:none;}
.terrain__item h3{font-family:var(--font-display);text-transform:uppercase;font-weight:600;font-size:18px;letter-spacing:-0.005em;line-height:1.15;margin:0 0 14px;color:var(--ink);}
.section--dark .terrain{border-top-color:rgba(255,255,255,0.14);}
.section--dark .terrain__item{border-right-color:rgba(255,255,255,0.1);border-bottom-color:rgba(255,255,255,0.1);}
.section--dark .terrain__item h3{color:var(--bone);}
.terrain__item p{font-size:14.5px;line-height:1.55;color:var(--fg-2);margin:0;}
.section--dark .terrain__item p{color:var(--fg-on-dark-2);}

/* area hub grid */
.area-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.area-card{display:block;border:1px solid var(--border);border-radius:8px;padding:28px;background:var(--paper);transition:border-color 180ms var(--ease-out),box-shadow 180ms var(--ease-out),transform 180ms var(--ease-out);}
.area-card:hover{border-color:var(--ink);box-shadow:var(--shadow-2);transform:translateY(-2px);}
.area-card__name{font-family:var(--font-display);text-transform:uppercase;font-weight:600;font-size:24px;letter-spacing:-0.01em;color:var(--ink);margin:0 0 8px;display:flex;align-items:center;justify-content:space-between;gap:10px;}
.area-card__name .arrow{color:var(--leaf);font-size:20px;transition:transform 200ms var(--ease-out);}
.area-card:hover .area-card__name .arrow{transform:translateX(4px);}
.area-card__blurb{font-size:14px;color:var(--fg-2);line-height:1.5;margin:0;}

@media (max-width:760px){
  .terrain{grid-template-columns:1fr;}
  .terrain__item,.terrain__item:nth-child(3n),.terrain__item:nth-child(3n+1){border-right:none;padding:28px 0;border-top:1px solid var(--stone-300);border-bottom:none;padding-left:0;padding-right:0;}
  .terrain__item:first-child{border-top:none;}
  .area-cards{grid-template-columns:1fr;}
}
@media (max-width:1080px){.area-cards{grid-template-columns:repeat(2,1fr);}}
