@import "design-system/tokens.css";

/* ===========================================================
   Durane's Landscaping — Design System (single source of truth)
   Modern / editorial: flat surfaces, hairline structure, whitespace.
   =========================================================== */

/* ---------- Base ---------- */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--limestone);color:var(--bark);font-family:var(--font-body);font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--font-display);color:var(--pine);font-weight:600;letter-spacing:-.01em;line-height:1.08;margin:0}
h1{font-size:clamp(2.5rem,5.2vw,4rem);font-weight:600}
h2{font-size:clamp(1.9rem,3.6vw,2.9rem)}
h3{font-size:1.42rem;letter-spacing:-.005em}
h4{font-size:1.08rem;letter-spacing:0}
p{margin:0 0 1rem}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 40px}
.eyebrow{font-family:var(--font-body);font-weight:600;font-size:.76rem;letter-spacing:.2em;text-transform:uppercase;color:var(--olive)}
.section{padding:104px 0}
.section-sm{padding:64px 0}
.dark{background:var(--pine);color:#E7EEDD}
.dark h1,.dark h2,.dark h3,.dark h4{color:#fff}
.lead{font-size:1.22rem;line-height:1.6;color:var(--bark7)}
.center{text-align:center}
.head{max-width:720px;margin:0 auto 64px}
.head.center{text-align:center}
.head .eyebrow{display:block;margin-bottom:16px}
.head p{margin-top:18px;font-size:1.12rem;color:var(--bark5)}
.muted{color:var(--bark5)}

/* ---------- Logo system ---------- */
.logo{display:inline-block;line-height:0}
.on-light{--lc-side:#1A4721;--lc-mid:#7BB23A;--lc-stem:#1A4721}
.on-dark{--lc-side:#7BB23A;--lc-mid:#A9D66B;--lc-stem:#7BB23A}
.on-mono{--lc-side:currentColor;--lc-mid:currentColor;--lc-stem:currentColor}
.lockup{display:inline-flex;align-items:center;gap:11px}
.lockup .name{font-family:var(--font-display);font-weight:700;font-size:1.16rem;letter-spacing:-.01em;line-height:1;color:var(--pine)}
.dark .lockup .name{color:#fff}
.logo-leaf{flex:none;display:block}
.btn-leaf{flex:none;display:block;margin-right:-1px}

/* ---------- Icons (Fine line) ---------- */
.ic{fill:none;stroke:currentColor;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.ic-fill{fill:currentColor;stroke:none}

/* ---------- Buttons (A · Grounded) ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:var(--font-body);font-weight:600;font-size:.95rem;line-height:1;border:none;border-radius:var(--r-sm);padding:15px 24px;cursor:pointer;transition:all .18s ease;white-space:nowrap}
.btn:focus-visible{outline:none;box-shadow:var(--ring)}
.btn .ic{width:18px;height:18px}
.btn-primary{background:var(--forest);color:#fff}
.btn-primary:hover{background:var(--forest8);transform:translateY(-1px)}
.btn-secondary{background:transparent;color:var(--forest);border:1.5px solid var(--olive)}
.btn-secondary:hover{background:var(--limestone-d)}
.btn-ghost{background:transparent;color:var(--forest);padding:15px 8px}
.btn-ghost:hover{color:var(--grass-d)}
.btn-spring{background:var(--gold);color:#0A0A0A}
.btn-spring:hover{background:var(--gold-lt);transform:translateY(-1px)}
.btn-outline-l{background:transparent;color:#EAF0E1;border:1.5px solid rgba(234,240,225,.42)}
.btn-outline-l:hover{border-color:#fff;background:rgba(255,255,255,.07)}
.btn-lg{padding:17px 30px;font-size:1rem}
.btn .arr{transition:transform .18s}
.btn:hover .arr{transform:translateX(3px)}
.textlink{display:inline-flex;align-items:center;gap:8px;font-weight:600;color:var(--forest)}
.textlink .ic{width:17px;height:17px;transition:transform .18s}
.textlink:hover{color:var(--grass-d)}
.textlink:hover .ic{transform:translateX(3px)}

/* ---------- Nav ---------- */
.nav{position:sticky;top:0;z-index:50;background:rgba(246,241,231,.82);backdrop-filter:blur(14px);border-bottom:1px solid var(--sand)}
.nav-in{max-width:var(--maxw);margin:0 auto;padding:14px 40px;display:flex;align-items:center;justify-content:space-between;gap:20px}
.nav-links{display:flex;align-items:center;gap:2px;margin:0;padding:0}
.nav-links>li{position:relative;list-style:none}
.nav-links a{display:inline-flex;align-items:center;gap:5px;font-size:.95rem;font-weight:500;color:var(--bark);padding:9px 14px;border-radius:var(--r-sm);transition:all .15s}
.nav-links a:hover{color:var(--forest)}
.nav-links a.active{color:var(--forest);font-weight:600}
.caret{width:13px;height:13px;transition:transform .2s}
.has-menu:hover .caret{transform:rotate(180deg)}
.menu{position:absolute;top:calc(100% + 10px);left:0;min-width:256px;background:var(--cream);border:1px solid var(--sand);border-radius:var(--r-md);box-shadow:var(--sh-lg);padding:8px;opacity:0;visibility:hidden;transform:translateY(6px);transition:all .18s;z-index:60}
.has-menu:hover .menu,.has-menu:focus-within .menu{opacity:1;visibility:visible;transform:translateY(0)}
.menu a{display:flex;align-items:center;gap:11px;padding:11px 12px;border-radius:var(--r-sm);font-weight:500;color:var(--bark7)}
.menu a:hover{background:var(--limestone-d);color:var(--forest)}
.menu .ic{width:19px;height:19px;color:var(--moss);flex:none}
.nav-cta{display:flex;align-items:center;gap:16px}
.nav-phone{display:inline-flex;align-items:center;gap:7px;font-size:.9rem;font-weight:600;color:var(--forest)}
.nav-phone .ic{width:16px;height:16px}
.hamb{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:9px}
.hamb span{width:24px;height:2px;background:var(--pine);border-radius:2px}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;background:var(--pine);color:#E7EEDD;text-align:center}
.hero .contour{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}
.hero-in{position:relative;max-width:860px;margin:0 auto;padding:120px 40px 128px}
.hero h1{color:#fff}
.hero .sub{font-size:1.24rem;color:#D3DBC6;max-width:580px;margin:24px auto 36px;line-height:1.6}
.hero .cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.hero .trust{margin-top:36px;display:inline-flex;align-items:center;gap:10px;font-size:.85rem;color:#9DAA8C}
.stars{display:inline-flex;gap:2px;color:var(--spring)}
.stars .ic{width:16px;height:16px}

/* ---------- Layout grids ---------- */
.grid{display:grid;gap:56px}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-2{grid-template-columns:repeat(2,1fr)}

/* ---------- Service items (editorial, no boxes) ---------- */
.service-card{position:relative;display:block;border-top:1.5px solid var(--bark);padding-top:28px}
.service-card .ibadge{display:block;color:var(--forest);margin-bottom:22px;transition:color .2s}
.service-card .ibadge .ic{width:38px;height:38px}
.service-card h3{margin-bottom:12px}
.service-card p{font-size:1.02rem;color:var(--bark7);margin-bottom:18px;max-width:34ch}
.service-card:hover .ibadge{color:var(--grass-d)}

/* sub-services as a clean inline list (no pills) */
.tags{display:flex;flex-wrap:wrap;align-items:center;gap:0;margin-bottom:22px}
.tag{font-size:.88rem;font-weight:500;color:var(--bark5)}
.tag:not(:last-child)::after{content:"·";margin:0 9px;color:var(--stone)}
.card-link{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:.94rem;color:var(--forest);transition:color .18s}
.card-link .ic{width:16px;height:16px;transition:transform .18s}
.service-card:hover .card-link{color:var(--grass-d)}
.service-card:hover .card-link .ic{transform:translateX(3px)}

/* ---------- Feature blocks (open, icon + text) ---------- */
.feature{display:flex;gap:18px;align-items:flex-start}
.feature .ibadge{flex:none;color:var(--grass-d)}
.feature .ibadge .ic{width:30px;height:30px}
.feature h3{margin-bottom:7px;font-size:1.15rem;letter-spacing:0}
.feature p{font-size:.98rem;color:var(--bark5);margin:0;max-width:40ch}
.dark .feature .ibadge{color:var(--spring)}
.dark .feature p{color:#9DAA8C}

/* ---------- Image / gallery (larger, calmer) ---------- */
.img-card{position:relative;border-radius:var(--r-lg);overflow:hidden;background:var(--forest8);display:block}
.img-card .ph{position:absolute;inset:0;width:100%;height:100%;transition:transform .5s ease}
.img-card:hover .ph{transform:scale(1.04)}
.img-card .cap{position:absolute;left:0;right:0;bottom:0;padding:24px;background:linear-gradient(transparent,rgba(14,42,20,.82));z-index:2}
.img-card .cap .k{font-size:.7rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--spring)}
.img-card .cap .t{font-family:var(--font-display);font-weight:700;color:#fff;font-size:1.3rem;line-height:1.15;margin-top:4px}
.img-card .watermark{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:rgba(169,214,107,.14);z-index:1}
.img-card .watermark .logo{width:84px;height:84px}

/* ---------- Testimonials (open pull-quotes) ---------- */
.testi{background:transparent;border:none;border-top:1.5px solid var(--sand);padding:26px 0 0;display:flex;flex-direction:column}
.testi .stars{color:var(--grass);margin-bottom:16px}
.testi blockquote{font-family:var(--font-display);font-weight:600;color:var(--pine);font-size:1.32rem;line-height:1.42;letter-spacing:-.01em;margin:0 0 20px}
.testi .who{margin-top:auto;display:flex;align-items:center;gap:12px}
.testi .who .av{width:40px;height:40px;border-radius:50%;background:var(--forest);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.85rem;flex:none}
.testi .who .nm{font-weight:600;font-size:.94rem;color:var(--bark)}
.testi .who .src{font-size:.78rem;color:var(--bark5)}

/* ---------- Flat seal badge ---------- */
.seal-badge{width:150px;height:150px;flex:none}
.seal-badge .seal-txt{font-family:var(--font-body);font-weight:600;font-size:11px;letter-spacing:.13em;fill:var(--forest);text-transform:uppercase}
.seal-badge .seal-est{font-family:var(--font-body);font-weight:600;font-size:9px;letter-spacing:.22em;fill:var(--grass-d)}

/* ---------- Contact band ---------- */
.cta-band{position:relative;overflow:hidden;background:var(--forest);color:#EAF0E1;border-radius:var(--r-xl)}
.cta-band .contour{position:absolute;inset:0;width:100%;height:100%}
.cta-band .inner{position:relative;padding:64px 56px;display:flex;align-items:center;justify-content:space-between;gap:36px;flex-wrap:wrap}
.cta-band h2{color:#fff}
.cta-band .phone-lg{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-display);font-weight:700;font-size:1.6rem;color:#fff;margin-top:10px}
.cta-band .phone-lg .ic{width:24px;height:24px;color:var(--spring)}

/* ---------- Forms ---------- */
.field{margin-bottom:18px}
.field label{display:block;font-size:.84rem;font-weight:600;color:var(--bark7);margin-bottom:7px}
.field input,.field textarea,.field select{width:100%;font-family:var(--font-body);font-size:1rem;color:var(--bark);background:#fff;border:1.5px solid var(--sand);border-radius:var(--r-sm);padding:13px 15px;outline:none;transition:border-color .15s,box-shadow .15s;min-height:48px}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--grass);box-shadow:var(--ring)}

/* ---------- Footer ---------- */
.footer{background:var(--pine);color:#C7D0BA}
.footer-in{max-width:var(--maxw);margin:0 auto;padding:72px 40px 36px;display:flex;gap:56px;flex-wrap:wrap}
.footer .brand{flex:1;min-width:240px}
.footer .brand .name{color:#fff;font-size:1.22rem}
.footer .brand p{font-size:.9rem;color:#9DAA8C;margin:16px 0 0;max-width:280px;line-height:1.6}
.footer .col h2{font-family:var(--font-body);font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#9DAE96;margin:0 0 16px}
.footer .col a,.footer .col span{display:block;font-size:.92rem;color:#C7D0BA;line-height:2.3}
.footer .col a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(199,208,186,.16);max-width:var(--maxw);margin:0 auto;padding:22px 40px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;font-size:.8rem;color:#8A977A}

/* ---------- Interior page header ---------- */
.page-header{position:relative;overflow:hidden;background:var(--pine);color:#E7EEDD;text-align:center}
.page-header .contour{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}
.page-header .ph-in{position:relative;max-width:820px;margin:0 auto;padding:76px 40px 84px}
.page-header h1{color:#fff;margin-top:14px}
.page-header p{color:#D3DBC6;font-size:1.16rem;max-width:620px;margin:20px auto 0;line-height:1.6}
.breadcrumb{font-size:.82rem;letter-spacing:.04em;color:#9DAA8C}
.breadcrumb a:hover{color:var(--spring)}

/* ---------- Split (text + media) ---------- */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:72px;align-items:center}
.auto-grid{display:grid;gap:48px 56px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}
.media-card{border-radius:var(--r-lg);overflow:hidden;min-height:380px;aspect-ratio:4/3;position:relative;background:var(--forest8)}
.media-card .ph{position:absolute;inset:0}
.media-card .watermark{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:rgba(169,214,107,.16)}
.media-card .watermark .logo{width:104px;height:104px}
.media-card .badge{position:absolute;left:22px;bottom:22px;z-index:2;font-size:.72rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--spring)}

/* ---------- Stat strip ---------- */
.stats{display:flex;gap:64px;flex-wrap:wrap;justify-content:center}
.stat{text-align:center}
.stat .n{font-family:var(--font-display);font-weight:700;font-size:2.4rem;color:var(--forest);line-height:1}
.dark .stat .n{color:var(--spring)}
.stat .l{display:block;margin-top:9px;font-size:.76rem;color:var(--bark5);text-transform:uppercase;letter-spacing:.12em}
.dark .stat .l{color:#9DAA8C}

/* ---------- Service-area list (inline, no chips) ---------- */
.areas{display:flex;flex-wrap:wrap;justify-content:center;gap:0;max-width:820px;margin:0 auto;font-family:var(--font-display);font-weight:600;font-size:clamp(1.2rem,2.4vw,1.8rem);color:var(--forest6);line-height:1.6;letter-spacing:-.01em}
.area{padding:0 2px}
.area:not(:last-child)::after{content:"·";margin:0 16px;color:var(--stone)}

/* ---------- Big pull quote ---------- */
.pullquote{max-width:900px;margin:0 auto;text-align:center}
.pullquote blockquote{font-family:var(--font-display);font-weight:700;color:var(--pine);font-size:clamp(1.6rem,3.2vw,2.5rem);line-height:1.26;letter-spacing:-.02em;margin:20px 0 22px}
.pullquote .who{font-weight:600;color:var(--bark)}
.pullquote .src{color:var(--bark5);font-size:.9rem}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .g-3{grid-template-columns:1fr 1fr;gap:48px}
  .nav-links,.nav-phone{display:none}
  .hamb{display:flex}
  .nav.open .nav-links{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;background:var(--cream);border-bottom:1px solid var(--sand);box-shadow:var(--sh-md);padding:10px 18px 20px;gap:2px}
  .nav.open .nav-links a{padding:14px 12px}
  .nav.open .menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;background:transparent;padding:2px 0 6px 14px;min-width:0}
  .nav.open .has-menu .caret{display:none}
  .split{grid-template-columns:1fr;gap:36px}
  .media-card{min-height:280px}
}
@media (max-width:640px){
  body{font-size:16px}
  .wrap,.nav-in,.footer-in,.footer-bottom{padding-left:22px;padding-right:22px}
  .section{padding:72px 0}
  .section-sm{padding:48px 0}
  .g-3,.g-2{grid-template-columns:1fr;gap:44px}
  .grid{gap:44px}
  .hero-in{padding:84px 22px 92px}
  .cta-band .inner{padding:44px 28px;flex-direction:column;align-items:flex-start;text-align:left}
  .head{margin-bottom:48px}
  .media-card{min-height:240px}
}

/* ===========================================================
   Quality & accessibility pass (UI/UX rule set; brand unchanged)
   =========================================================== */
a:focus-visible, button:focus-visible, .btn:focus-visible, .card:focus-visible,
input:focus-visible, textarea:focus-visible, select:focus-visible, [tabindex]:focus-visible{
  outline:none;box-shadow:var(--ring);border-radius:var(--r-sm);
}
.dark a:focus-visible, .hero a:focus-visible, .cta-band a:focus-visible, .page-header a:focus-visible{
  box-shadow:0 0 0 3px rgba(169,214,107,.6);
}
a, button, .btn{touch-action:manipulation}
.nav-links>li>a, .menu a{min-height:44px}
h1,h2,h3{text-wrap:balance}
.stat .n, .phone-lg, .nav-phone, .seal-est{font-variant-numeric:tabular-nums}
section[id], [id].anchor{scroll-margin-top:96px}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  .btn:hover,.service-card:hover .ic,.img-card:hover .ph{transform:none!important}
}

/* ===========================================================
   Visual-interest layer — signature contour motif + editorial accents
   =========================================================== */
/* grass accent mark under section eyebrows */
.head.center .eyebrow::after{content:"";display:block;width:34px;height:3px;background:var(--grass);border-radius:3px;margin:16px auto 0}
.hero .eyebrow::after{content:"";display:block;width:34px;height:3px;background:var(--spring);border-radius:3px;margin:16px auto 0;opacity:.85}

/* big editorial index number on service items */
.service-card{position:relative}
.service-card .idx{position:absolute;top:24px;right:2px;font-family:var(--font-display);font-weight:800;font-size:2.6rem;line-height:1;color:transparent;-webkit-text-stroke:1.5px var(--sand);text-stroke:1.5px var(--sand)}

/* dark stat band */
.stat-band{position:relative;overflow:hidden;background:var(--pine);color:#E7EEDD}
.stat-band .contour{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}
.stat-band .inner{position:relative;max-width:var(--maxw);margin:0 auto;padding:58px 40px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:36px}
.stat-band .stat{flex:1;min-width:150px;text-align:center}
.stat-band .stat .n{font-family:var(--font-display);font-weight:700;font-size:3rem;line-height:1;color:var(--spring)}
.stat-band .stat .l{display:block;margin-top:10px;font-size:.76rem;letter-spacing:.12em;text-transform:uppercase;color:#9DAA8C}

/* contour texture inside image tiles */
.img-card .tile-lines{position:absolute;inset:0;width:100%;height:100%;z-index:1;color:var(--spring);opacity:.5;pointer-events:none}

@media (max-width:640px){
  .stat-band .inner{padding:42px 22px;gap:30px}
  .stat-band .stat{min-width:42%}
  .stat-band .stat .n{font-size:2.4rem}
  .service-card .idx{font-size:2.1rem}
}

/* ---------- Scroll reveal (JS adds .is-in; no-JS or reduced-motion = visible) ---------- */
.reveal-on .section .head,
.reveal-on .service-card,
.reveal-on .feature,
.reveal-on .testi,
.reveal-on .img-card,
.reveal-on .pullquote,
.reveal-on .stat-band .inner,
.reveal-on .split>div,
.reveal-on .areas,
.reveal-on .cta-band{opacity:0;transform:translateY(22px);transition:opacity .7s cubic-bezier(.22,.61,.36,1),transform .7s cubic-bezier(.22,.61,.36,1);will-change:opacity,transform}
.reveal-on .is-in{opacity:1!important;transform:none!important}
.reveal-on .grid>*:nth-child(2),.reveal-on .auto-grid>*:nth-child(2){transition-delay:.08s}
.reveal-on .grid>*:nth-child(3),.reveal-on .auto-grid>*:nth-child(3){transition-delay:.16s}
.reveal-on .grid>*:nth-child(4),.reveal-on .auto-grid>*:nth-child(4){transition-delay:.24s}
.reveal-on .auto-grid>*:nth-child(5){transition-delay:.32s}
@media (prefers-reduced-motion: reduce){
  .reveal-on .section .head,.reveal-on .service-card,.reveal-on .feature,.reveal-on .testi,.reveal-on .img-card,.reveal-on .pullquote,.reveal-on .stat-band .inner,.reveal-on .split>div,.reveal-on .areas,.reveal-on .cta-band{opacity:1!important;transform:none!important;transition:none!important}
}

/* ---------- Functional panels + forms (Contact) ---------- */
.panel{background:var(--cream);border:1px solid var(--sand);border-radius:var(--r-lg);padding:36px}
.panel-head{display:flex;align-items:center;gap:12px;margin-bottom:24px}
.panel-head .ic{width:24px;height:24px;color:var(--moss)}
.field .req{color:var(--clay);margin-left:2px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.embed-slot{border:1.5px dashed var(--stone);border-radius:var(--r-md);padding:14px;text-align:center;font-size:.82rem;color:var(--bark5);margin-top:18px}
.page-header .phone-lg{display:inline-flex;align-items:center;gap:11px;font-family:var(--font-display);font-weight:700;font-size:1.8rem;color:#fff;margin-top:22px}
.page-header .phone-lg .ic{width:26px;height:26px;color:var(--spring)}
.contact-points{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:18px;font-size:.92rem;color:#A9B69A}
.contact-points a{display:inline-flex;align-items:center;gap:7px}
.contact-points a:hover{color:var(--spring)}
.contact-points .ic{width:16px;height:16px}
@media (max-width:560px){.field-row{grid-template-columns:1fr}.panel{padding:26px}}

/* ---------- Real photos ---------- */
.img-card .ph{object-fit:cover}
.media-card .ph{width:100%;height:100%;object-fit:cover}
.media-card .badge{text-shadow:0 1px 10px rgba(0,0,0,.55)}
.hero-photo{background:#0E2A14}
.hero-photo .hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero-photo .hero-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(14,42,20,.72),rgba(14,42,20,.85) 62%,rgba(14,42,20,.93))}
.hero-photo .contour{z-index:2}
.hero-photo .hero-in{position:relative;z-index:3}
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px}

/* ---------- Depth & elevation ---------- */
.img-card{box-shadow:var(--sh-md)}
.panel{box-shadow:var(--sh-sm)}

/* ---------- Alternating image + text showcase ---------- */
.showcase{display:flex;flex-direction:column;gap:100px}
.show-row{display:grid;grid-template-columns:1fr 1fr;gap:76px;align-items:center}
.show-row:nth-child(even) .show-media{order:2}
.show-media{position:relative;padding:20px 20px 0 0}
.show-media .frame{position:relative;z-index:2;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-lg);aspect-ratio:4/3}
.show-media .frame img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s ease}
.show-media:hover .frame img{transform:scale(1.04)}
.show-media::after{content:"";position:absolute;z-index:1;right:0;top:0;width:58%;height:72%;border-radius:var(--r-lg);background:rgba(123,178,58,.18)}
.show-media .chip{position:absolute;z-index:3;left:-14px;bottom:26px;display:inline-flex;align-items:center;gap:9px;background:var(--cream);border:1px solid var(--sand);box-shadow:var(--sh-md);border-radius:var(--r-pill);padding:11px 19px;font-weight:600;font-size:.82rem;color:var(--forest)}
.show-media .chip .ic{width:18px;height:18px;color:var(--grass-d)}
.show-num{font-family:var(--font-body);font-weight:600;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;color:var(--grass-d)}
.show-text h2{margin:12px 0 18px}
.show-text .tags{margin:20px 0 24px}

/* ---------- Sticky mobile action bar ---------- */
.mobile-bar{display:none}
@media (max-width:640px){
  .mobile-bar{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:60;gap:10px;padding:10px 14px calc(10px + env(safe-area-inset-bottom));background:rgba(252,250,244,.96);backdrop-filter:blur(12px);border-top:1px solid var(--sand)}
  .mobile-bar .btn{flex:1;padding:14px 12px}
  body.has-mobile-bar{padding-bottom:80px}
  .nav-cta{display:none}
  .showcase{gap:60px}
  .show-row{grid-template-columns:1fr;gap:24px}
  .show-row:nth-child(even) .show-media{order:0}
  .show-media{padding:16px 16px 0 0}
}

/* showcase reveal */
.reveal-on .show-row>*{opacity:0;transform:translateY(24px);transition:opacity .7s cubic-bezier(.22,.61,.36,1),transform .7s cubic-bezier(.22,.61,.36,1)}
@media (prefers-reduced-motion:reduce){.reveal-on .show-row>*{opacity:1!important;transform:none!important;transition:none!important}}

/* ---------- Seasonal announcement bar ---------- */
.topbar{position:relative;z-index:55;background:var(--forest);color:#EAF0E1;font-size:.86rem}
.topbar .tb-in{max-width:var(--maxw);margin:0 auto;padding:9px 44px;display:flex;align-items:center;justify-content:center;gap:9px;text-align:center}
.topbar .tb-cta{color:#fff;font-weight:600;display:inline-flex;align-items:center;gap:6px;border-bottom:1.5px solid var(--grass);padding-bottom:1px}
.topbar .tb-cta:hover{color:var(--spring);border-color:var(--spring)}
.topbar .tb-close{position:absolute;right:6px;top:50%;transform:translateY(-50%);background:none;border:none;color:#9DAA8C;cursor:pointer;font-size:1.2rem;line-height:1;width:44px;height:44px;display:inline-flex;align-items:center;justify-content:center}
.topbar .tb-close:hover{color:#fff}
@media (max-width:640px){.topbar{font-size:.78rem}.topbar .tb-in{padding:8px 36px;flex-direction:column;gap:2px}}

/* highlighted word — gold emphasis (use sparingly) */
.hl{color:var(--gold)}

/* ===========================================================
   Motion FX (all disabled under prefers-reduced-motion)
   =========================================================== */
@keyframes dl-drift{0%,100%{transform:scale(1)}50%{transform:scale(1.06)}}
@keyframes dl-glow{0%,100%{box-shadow:0 8px 30px rgba(123,178,58,.30)}50%{box-shadow:0 12px 48px rgba(123,178,58,.62)}}
@keyframes dl-marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* breathing contour */
.hero .contour,.page-header .contour{animation:dl-drift 16s ease-in-out infinite;transform-origin:center}
/* hero CTA — subtle static shadow (no pulse) */
html.theme-dark .hero .btn-spring{box-shadow:0 6px 18px rgba(0,0,0,.3)}

/* shine sweep on solid buttons */
.btn-primary,.btn-spring{position:relative;overflow:hidden}
.btn-primary::after,.btn-spring::after{content:"";position:absolute;top:0;left:-130%;width:55%;height:100%;background:linear-gradient(100deg,transparent,rgba(255,255,255,.42),transparent);transform:skewX(-18deg);transition:left .6s cubic-bezier(.2,.6,.2,1);pointer-events:none}
.btn-primary:hover::after,.btn-spring:hover::after{left:150%}

/* service-area marquee */
.marquee{overflow:hidden;border-top:1px solid var(--sand);border-bottom:1px solid var(--sand);background:var(--cream);padding:16px 0}
.marquee-track{display:inline-flex;align-items:center;white-space:nowrap;animation:dl-marquee 36s linear infinite;will-change:transform}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-item{font-family:var(--font-display);font-weight:700;font-size:1.05rem;color:var(--forest6)}
.marquee-sep{color:var(--grass);padding:0 22px;font-size:.7rem}
html.theme-dark .marquee{background:#0F2916;border-color:rgba(233,239,224,.08)}
html.theme-dark .marquee-item{color:var(--bark7)}

@media (prefers-reduced-motion:reduce){
  .hero .contour,.page-header .contour,.hero .btn-spring,.marquee-track{animation:none!important}
  .btn-primary::after,.btn-spring::after{display:none}
}

/* ===========================================================
   Design-system accent placement (restraint: color earns its place)
   Forest green = structure/links. Gold = emphasis only. Brown = money.
   =========================================================== */
/* gold reserved for genuine emphasis: big stat numbers, review stars,
   the one highlighted hero word, and small marks on dark-green bands */
.stat-band .stat .n,.stat .n{color:var(--gold)}
.stars,.testi .stars{color:var(--brass)}
.hero .eyebrow::after,.dark .head.center .eyebrow::after{background:var(--gold)}
.marquee-sep{color:var(--gold)}
.cta-band .phone-lg .ic,.page-header .phone-lg .ic{color:var(--gold)}
.img-card .cap .k,.media-card .badge{color:var(--gold)}
/* forest stays the structural accent everywhere else */
.eyebrow{color:var(--olive)}
.dark .eyebrow,.hero .eyebrow,.page-header .eyebrow{color:var(--gold-lt)}
/* money / prices — brown only */
.price,.money,.total{color:var(--brown)}

/* Decorative contour texture → barely-there, recolored off lime.
   (Overrides the inline stroke="#7BB23A/#A9D66B" attrs in the SVGs.) */
.contour g[stroke],.contour path[stroke],.contour [stroke]{stroke:var(--gold-lt)!important;opacity:.12}
.tile-lines [stroke]{stroke:var(--gold-lt)!important}
/* Review seal rings → forest on light surfaces */
.seal-badge circle[stroke]{stroke:var(--forest)!important;stroke-opacity:.5}

/* ---------- Skip-to-content link (keyboard a11y) ---------- */
.skip-link{position:absolute;left:12px;top:-60px;z-index:200;background:var(--forest);color:#fff;font-family:var(--font-body);font-weight:600;font-size:.92rem;padding:11px 18px;border-radius:var(--r-sm);transition:top .15s}
.skip-link:focus{top:12px;outline:none;box-shadow:0 0 0 3px rgba(169,214,107,.6)}
[id="main-content"]{scroll-margin-top:90px}

/* ---------- Inline form validation ---------- */
.field-error{display:none;color:var(--clay);font-size:.82rem;font-weight:600;margin-top:6px}
.field.invalid .field-error{display:block}
.field.invalid input,.field.invalid textarea{border-color:var(--clay)}
.field.invalid input:focus,.field.invalid textarea:focus{box-shadow:0 0 0 3px rgba(180,80,46,.25)}

/* ---------- Thank-you confirmation badge ---------- */
.ty-check{width:78px;height:78px;border-radius:50%;background:#fff;color:var(--forest);display:flex;align-items:center;justify-content:center;margin:0 auto 22px;box-shadow:0 10px 26px rgba(0,0,0,.28);animation:fs-ring .6s cubic-bezier(.22,.61,.36,1)}
.ty-check .ic{width:40px;height:40px;stroke-width:2.6}
@media (prefers-reduced-motion:reduce){.ty-check{animation:none}}

/* ---------- Quick-quote band (Services pages) ---------- */
.quote-band{position:relative;overflow:hidden;background:var(--forest);color:#EAF0E1;border-radius:var(--r-xl)}
.quote-band .contour{position:absolute;inset:0;width:100%;height:100%}
.quote-band .inner{position:relative;padding:48px 48px;display:grid;grid-template-columns:1fr 1.04fr;gap:44px;align-items:center}
.quote-band .qb-intro .eyebrow{color:var(--gold-lt)}
.quote-band .qb-intro h2{color:#fff;margin:12px 0 14px}
.quote-band .qb-intro p{color:#C7D0BA;margin:0 0 18px;max-width:34ch}
.quote-band .qb-intro .phone-lg{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-display);font-weight:700;font-size:1.5rem;color:#fff}
.quote-band .qb-intro .phone-lg .ic{width:22px;height:22px;color:var(--gold-lt)}
.quote-form{background:#fff;border-radius:var(--r-lg);padding:26px;box-shadow:var(--sh-md)}
.quote-form .form-mark{display:flex;align-items:center;gap:10px;margin-bottom:18px}
.quote-form .form-mark .ic{width:22px;height:22px;color:var(--forest)}
.quote-form .form-mark h3{font-size:1.18rem}
@media (max-width:820px){.quote-band .inner{grid-template-columns:1fr;padding:34px 26px;gap:24px}}

/* ===========================================================
   Contact funnel — a pretty descent into one streamlined form
   =========================================================== */
.funnel{list-style:none;max-width:560px;margin:0 auto 46px;padding:0}
.fstep{display:flex;gap:18px;align-items:flex-start;padding:0 0 30px;position:relative}
.fstep:last-child{padding-bottom:0}
.fstep::before{content:"";position:absolute;left:22px;top:48px;bottom:2px;width:2px;background:linear-gradient(var(--brass),var(--sand) 70%,transparent)}
.fstep:last-child::before{display:none}
.fnode{flex:none;width:46px;height:46px;border-radius:50%;background:var(--pine);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:600;font-size:1.16rem;border:2px solid var(--brass);box-shadow:var(--sh-sm)}
.fbody h3{margin:9px 0 4px;font-size:1.16rem;letter-spacing:0}
.fbody p{margin:0;color:var(--bark5);font-size:1rem}

/* the conversion panel — the wide catch at the bottom of the funnel */
.funnel-form{max-width:600px;margin:0 auto;border-top:3px solid var(--brass);position:relative}
.funnel-form .form-mark{display:flex;align-items:center;gap:11px;margin-bottom:22px}
.funnel-form .form-mark .ic{width:24px;height:24px;color:var(--forest)}
.funnel-form .form-mark h3{font-size:1.32rem}
.funnel-note{display:flex;align-items:center;justify-content:center;gap:8px;font-size:.86rem;color:var(--bark5);margin:16px 0 0;text-align:center}
.funnel-note .ic{width:16px;height:16px;color:var(--forest);flex:none}
.opt{font-weight:400;color:var(--bark5);font-size:.78em}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}

/* selectable timeframe chips (self-select, Calendly-lite) */
.chips{display:flex;flex-wrap:wrap;gap:10px}
.chip-opt{position:relative;cursor:pointer}
.chip-opt input{position:absolute;opacity:0;width:0;height:0}
.chip-opt span{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:10px 18px;border:1.5px solid var(--sand);border-radius:var(--r-pill);font-weight:600;font-size:.92rem;color:var(--bark7);background:#fff;transition:all .15s}
.chip-opt:hover span{border-color:var(--olive)}
.chip-opt input:checked+span{background:var(--forest);border-color:var(--forest);color:#fff}
.chip-opt input:focus-visible+span{box-shadow:var(--ring)}

/* success state */
.funnel-form.hide{display:none}
.funnel-success{display:none;max-width:600px;margin:0 auto;text-align:center;padding:54px 36px;background:var(--cream);border:1px solid var(--sand);border-top:3px solid var(--forest);border-radius:var(--r-lg);box-shadow:var(--sh-sm)}
.funnel-success.show{display:block;animation:fs-pop .5s cubic-bezier(.22,.61,.36,1)}
.funnel-success .fs-check{width:74px;height:74px;border-radius:50%;background:var(--forest);color:#fff;display:flex;align-items:center;justify-content:center;margin:0 auto 22px;animation:fs-ring .6s cubic-bezier(.22,.61,.36,1)}
.funnel-success .fs-check .ic{width:38px;height:38px;stroke-width:2.4}
.funnel-success h3{font-size:1.7rem;margin-bottom:10px}
.funnel-success p{color:var(--bark7);max-width:42ch;margin:0 auto}
@keyframes fs-pop{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
@keyframes fs-ring{0%{transform:scale(.6);opacity:0}60%{transform:scale(1.08)}100%{transform:scale(1);opacity:1}}
@media (prefers-reduced-motion:reduce){.funnel-success.show,.funnel-success .fs-check{animation:none}}

@media (max-width:560px){
  .funnel-form,.funnel-success{padding:26px}
  .fnode{width:42px;height:42px;font-size:1.05rem}
  .fstep::before{left:20px}
}
