/* ============================ TOKENS ============================ */
:root{
  --paper:#ffffff;        /* clean white base */
  --paper-2:#f1f6ef;      /* misty green section */
  --sage:#e6efe4;         /* soft green panel */
  --sage-soft:#eef4ec;
  --ink:#14211a;          /* near-black green */
  --forest:#15402a;       /* deep botanical green */
  --forest-2:#1d5536;
  --moss:#5a6e5d;         /* muted green */
  --leaf:#5ea53f;         /* fresh leaf-green accent */
  --clay:#c2542f;         /* terracotta CTA */
  --clay-d:#a6451f;
  --gold:#e2b25a;         /* golden-hour highlight (hero only) */
  --line:rgba(21,40,28,.12);
  --shadow:0 24px 60px -28px rgba(21,40,28,.34);
  --maxw:1240px;
  --r:18px;
  --serif:"Fraunces",Georgia,serif;
  --sans:"Hanken Grotesk",-apple-system,system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink);
  line-height:1.6;
  font-size:clamp(16px,1.05vw,17.5px);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
/* grain overlay */
body::before{
  content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--serif);font-weight:400;line-height:1.05;letter-spacing:-.015em;font-optical-sizing:auto}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,56px)}
.eyebrow{font-family:var(--sans);font-weight:600;font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:var(--leaf);display:inline-flex;align-items:center;gap:.6em}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--leaf);display:inline-block}
.skip{position:absolute;left:-999px;top:0;background:var(--forest);color:#fff;padding:12px 18px;z-index:10000;border-radius:0 0 10px 0}
.skip:focus{left:0}

/* ============================ BUTTONS ============================ */
.btn{display:inline-flex;align-items:center;gap:.55em;font-family:var(--sans);font-weight:600;font-size:.98rem;
  padding:.92em 1.5em;border-radius:100px;border:1.5px solid transparent;cursor:pointer;transition:.25s ease;white-space:nowrap;letter-spacing:.01em}
.btn-primary{background:var(--clay);color:#fff;box-shadow:0 12px 26px -12px rgba(194,94,58,.7)}
.btn-primary:hover{background:var(--clay-d);transform:translateY(-2px);box-shadow:0 18px 34px -14px rgba(194,94,58,.8)}
.btn-ghost{background:transparent;color:var(--forest);border-color:var(--line)}
.btn-ghost:hover{background:var(--forest);color:var(--paper);border-color:var(--forest);transform:translateY(-2px)}
.btn-light{background:var(--paper);color:var(--forest)}
.btn-light:hover{background:#fff;transform:translateY(-2px)}
.btn svg{width:1.05em;height:1.05em}

/* ============================ HEADER ============================ */
header{position:sticky;top:0;z-index:1000;transition:.3s ease;border-bottom:1px solid transparent}
header.scrolled{background:rgba(255,255,255,.92);backdrop-filter:blur(14px);border-bottom-color:var(--line);box-shadow:0 10px 30px -22px rgba(21,40,28,.3)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:1.1rem 0;transition:.3s}
header.scrolled .nav{padding:.7rem 0}
.brand{display:flex;align-items:center;line-height:0}
.brand img{height:48px;width:auto;transition:height .3s ease}
header.scrolled .brand img{height:40px}
.navlinks{display:flex;align-items:center;gap:1.7rem;font-weight:500;font-size:.96rem}
.navlinks a{position:relative;color:var(--ink);transition:.2s}
.navlinks a::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:1.5px;background:var(--clay);transition:.25s}
.navlinks a:hover{color:var(--clay)}
.navlinks a:hover::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:1rem}
.nav-phone{display:flex;align-items:center;gap:.5em;font-weight:600;color:var(--forest)}
.nav-phone svg{width:1.05em;height:1.05em;color:var(--clay)}
.menu-toggle{display:none;background:none;border:none;cursor:pointer;width:42px;height:42px;color:var(--forest)}
.menu-toggle svg{width:28px;height:28px}

/* ============================ HERO ============================ */
.hero{position:relative;min-height:clamp(580px,92vh,940px);display:flex;align-items:flex-end;isolation:isolate;color:var(--paper)}
.hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:50% 40%;z-index:-2}
.hero-scrim{position:absolute;inset:0;z-index:-1;background:linear-gradient(0deg,rgba(11,26,16,.95) 0%,rgba(11,26,16,.74) 18%,rgba(11,26,16,.34) 40%,rgba(11,26,16,.05) 62%,rgba(11,26,16,0) 82%),linear-gradient(90deg,rgba(11,26,16,.42) 0%,rgba(11,26,16,0) 58%)}
.hero-inner{padding:0 clamp(20px,5vw,56px) clamp(3rem,7vw,5.5rem)}
.hero-inner>*{max-width:780px}
.hero h1{font-size:clamp(2.9rem,6.8vw,5.6rem);line-height:1.0;letter-spacing:-.015em;color:var(--paper);text-shadow:0 2px 30px rgba(0,0,0,.3)}
.hero h1 em{font-style:italic;color:#ecc463}
.hero .lead{font-size:clamp(1.08rem,1.5vw,1.3rem);max-width:52ch;margin:1.5rem 0 2.2rem;color:rgba(255,255,255,.92);text-shadow:0 1px 14px rgba(0,0,0,.3)}
.hero-cta{display:flex;flex-wrap:wrap;gap:.9rem;align-items:center}
.eyebrow.on-dark{color:#f1cb78}
.eyebrow.on-dark::before{background:#f1cb78}
.btn-ghost.ghost-light{color:var(--paper);border-color:rgba(246,241,229,.6);background:rgba(255,255,255,.06)}
.btn-ghost.ghost-light:hover{background:rgba(255,255,255,.16);border-color:var(--paper)}
.showcase{position:relative;min-height:clamp(380px,54vh,580px);display:flex;align-items:center;isolation:isolate;color:var(--paper);text-align:center}
.showcase img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:50% 56%;z-index:-2}
.showcase::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(11,26,16,.58),rgba(11,26,16,.74))}
.showcase .wrap{max-width:780px}
.showcase .eyebrow{color:var(--gold)}.showcase .eyebrow::before{background:var(--gold)}
.showcase h2{font-family:var(--serif);font-size:clamp(2rem,4.3vw,3.4rem);line-height:1.08;color:var(--paper);margin:.7rem auto 1.1rem;letter-spacing:-.01em;text-shadow:0 2px 24px rgba(0,0,0,.32)}
.showcase h2 em{font-style:italic;color:var(--gold)}
.showcase p{max-width:56ch;margin:0 auto 1.9rem;color:rgba(255,255,255,.9);font-size:clamp(1rem,1.4vw,1.15rem);line-height:1.6}

/* ============================ MARQUEE STATS ============================ */
.bar{background:var(--forest);color:var(--paper)}
.bar .wrap{display:flex;flex-wrap:wrap;justify-content:space-between;gap:1.2rem;padding-top:1.5rem;padding-bottom:1.5rem}
.bar .item{display:flex;align-items:center;gap:.7em;font-weight:500;font-size:.98rem}
.bar .item svg{width:22px;height:22px;color:var(--gold);flex:none}

/* ============================ SECTION SHELL ============================ */
section{padding:clamp(3.4rem,7vw,6rem) 0}
.sec-head{max-width:62ch}
.sec-head h2{font-size:clamp(2.1rem,4.2vw,3.5rem);color:var(--forest);margin:.7rem 0;letter-spacing:-.01em}
.sec-head p{color:#46553f;font-size:1.08rem}
.center{margin-inline:auto;text-align:center}
.center .eyebrow{justify-content:center}

/* ============================ SERVICES ============================ */
.services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem;margin-top:3rem}
.card{background:#ffffff;box-shadow:0 1px 3px rgba(21,40,28,.05);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column;
  transition:.35s cubic-bezier(.2,.7,.3,1)}
.card:hover{transform:translateY(-8px);box-shadow:var(--shadow);border-color:transparent}
.card-img{aspect-ratio:1/1;overflow:hidden}
.card-img img{width:100%;height:100%;object-fit:cover;transition:.6s ease}
.services-grid .card:nth-child(1) .card-img img{object-position:55% 64%}
.services-grid .card:nth-child(2) .card-img img{object-position:42% 60%}
.services-grid .card:nth-child(3) .card-img img{object-position:50% 56%}
.services-grid .card:nth-child(4) .card-img img{object-position:50% 50%}
.services-grid .card:nth-child(5) .card-img img{object-position:50% 50%}
.services-grid .card:nth-child(6) .card-img img{object-position:62% 55%}
.services-grid .card:nth-child(7) .card-img img{object-position:58% 52%}
.services-grid .card:nth-child(8) .card-img img{object-position:50% 55%}
.card:hover .card-img img{transform:scale(1.07)}
.card-body{padding:1.4rem 1.4rem 1.6rem}
.card-body h3{font-size:1.32rem;color:var(--forest);margin-bottom:.5rem}
.card-body p{font-size:.94rem;color:#4a5a45}
.card-body .more{display:inline-flex;align-items:center;gap:.4em;margin-top:1rem;font-weight:600;font-size:.86rem;color:var(--clay)}
.card-body .more svg{width:1em;height:1em;transition:.25s}
.card:hover .more svg{transform:translateX(4px)}

/* ============================ ABOUT ============================ */
#services,#faq,.about,#reviews{background:var(--paper-2)}
.about-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(1.6rem,5vw,4rem);align-items:center}
.about-figure{position:relative}
.about-figure img{width:100%;border-radius:var(--r);box-shadow:var(--shadow);aspect-ratio:739/940;object-fit:cover;object-position:center 14%}
.about-figure .sig{position:absolute;right:-14px;top:30px;background:var(--clay);color:#fff;font-family:var(--serif);
  font-style:italic;font-size:1.05rem;padding:.7rem 1.1rem;border-radius:12px;box-shadow:var(--shadow);transform:rotate(2.5deg)}
.about h2{font-size:clamp(2rem,4vw,3rem);color:var(--forest);margin:.6rem 0 1.2rem}
.about p{color:#3f4f3e;margin-bottom:1rem;max-width:54ch}
.why{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem 1.6rem;margin:1.8rem 0 2rem}
.why div{display:flex;gap:.8rem;align-items:flex-start}
.why .ic{width:42px;height:42px;border-radius:11px;background:var(--sage);color:var(--forest);display:grid;place-items:center;flex:none}
.why .ic svg{width:20px;height:20px}
.why h4{font-family:var(--sans);font-weight:700;font-size:1rem;margin-bottom:.15rem;color:var(--ink)}
.why p{font-size:.9rem;margin:0;color:#4a5a45}

/* ============================ STEPS ============================ */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem;margin-top:3rem;counter-reset:step}
.step{position:relative;padding:2.2rem 1.7rem 1.8rem;background:#ffffff;border:1px solid var(--line);border-radius:var(--r);box-shadow:0 1px 3px rgba(21,40,28,.05)}
.step::before{counter-increment:step;content:"0" counter(step);font-family:var(--serif);font-size:3rem;color:var(--sage);
  position:absolute;top:1rem;right:1.4rem;line-height:1}
.step h3{font-size:1.4rem;color:var(--forest);margin-bottom:.5rem}
.step p{font-size:.96rem;color:#4a5a45}

/* ============================ AREAS ============================ */
.areas{background:var(--forest);color:var(--paper);position:relative;overflow:hidden}
.areas h2{color:var(--paper)}
.areas .sec-head p{color:var(--sage)}
.area-list{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:2.4rem}
.area-list span{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.16);padding:.55em 1.1em;border-radius:100px;
  font-size:.92rem;font-weight:500;transition:.25s}
.area-list span:hover{background:var(--clay);border-color:var(--clay)}
.areas .leaf-bg{position:absolute;right:-60px;bottom:-60px;width:320px;opacity:.06;color:#fff}

/* ============================ TESTIMONIALS ============================ */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:3rem}
.quote{background:#ffffff;border:1px solid var(--line);border-radius:var(--r);padding:1.8rem}
.stars{display:flex;gap:3px;color:var(--gold);margin-bottom:1rem}
.stars svg{width:18px;height:18px}
.quote p{font-family:var(--serif);font-size:1.12rem;font-style:italic;color:var(--ink);line-height:1.45;margin-bottom:1.2rem}
.quote cite{font-style:normal;font-weight:600;font-size:.92rem;color:var(--forest)}
.quote cite span{display:block;font-weight:400;font-size:.82rem;color:var(--moss)}

/* ============================ FAQ ============================ */
.faq-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:start;margin-top:1rem}
details{border-bottom:1px solid var(--line);padding:.4rem 0}
summary{font-family:var(--serif);font-size:1.22rem;color:var(--forest);padding:1.1rem 2.5rem 1.1rem 0;cursor:pointer;
  position:relative;list-style:none;transition:.2s}
summary::-webkit-details-marker{display:none}
summary::after{content:"+";position:absolute;right:.3rem;top:1rem;font-size:1.6rem;color:var(--clay);transition:.3s;font-family:var(--sans);line-height:1}
details[open] summary::after{transform:rotate(45deg)}
details summary:hover{color:var(--clay)}
details p{padding:0 2.5rem 1.3rem 0;color:#46553f}

/* ============================ CTA / FORM ============================ */
.cta{background:linear-gradient(160deg,var(--forest),var(--forest-2));color:var(--paper)}
.cta-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.cta h2{color:var(--paper);font-size:clamp(2.1rem,4.2vw,3.2rem)}
.cta h2 em{font-style:italic;color:var(--gold)}
.cta .lead{color:var(--sage);margin:1.2rem 0 1.8rem;max-width:42ch;font-size:1.08rem}
.cta-contact{display:flex;flex-direction:column;gap:1rem;margin-top:1.6rem}
.cta-contact a{display:inline-flex;align-items:center;gap:.7em;font-weight:600;font-size:1.05rem}
.cta-contact svg{width:22px;height:22px;color:var(--gold)}
.form{background:#ffffff;border-radius:var(--r);padding:clamp(1.6rem,3vw,2.4rem);box-shadow:var(--shadow);color:var(--ink)}
.form h3{font-size:1.6rem;color:var(--forest);margin-bottom:.3rem}
.form .sub{font-size:.92rem;color:var(--moss);margin-bottom:1.4rem}
.field{margin-bottom:1rem}
.field label{display:block;font-size:.82rem;font-weight:600;margin-bottom:.4rem;color:var(--forest)}
.field input,.field select,.field textarea{width:100%;font-family:var(--sans);font-size:1rem;padding:.8em .95em;
  border:1.5px solid var(--line);border-radius:11px;background:var(--paper);color:var(--ink);transition:.2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--clay);background:#fff;box-shadow:0 0 0 3px rgba(194,94,58,.12)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form .btn-primary{width:100%;justify-content:center;margin-top:.4rem}
.form .fineprint{font-size:.78rem;color:var(--moss);text-align:center;margin-top:.9rem}
.form-error{background:#fbeae5;border:1px solid #e3b3a1;color:#9a3b1f;border-radius:10px;padding:.7rem .9rem;font-size:.86rem;line-height:1.5;margin-top:.2rem}
.form-success{text-align:center;padding:1.6rem .4rem}
.form-success svg{width:30px;height:30px;color:var(--clay);background:#f3e7df;border-radius:50%;padding:11px;box-sizing:content-box;margin-bottom:.7rem}
.form-success h3{margin:.2rem 0 .55rem}
.form-success p{color:var(--moss);font-size:.95rem;line-height:1.65;max-width:34ch;margin:0 auto}
.form-success a{color:var(--clay);font-weight:600}

/* ============================ FOOTER ============================ */
footer{background:var(--ink);color:#c9d2c2;padding:clamp(3rem,5vw,4.5rem) 0 2rem}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr .9fr .9fr 1.1fr;gap:2rem}
.foot-brand{margin-bottom:1.1rem}
.foot-brand img{height:54px;width:auto}
footer h4{font-family:var(--sans);font-weight:700;font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;color:var(--sage);margin-bottom:1.1rem}
footer ul{list-style:none}
footer li{margin-bottom:.6rem}
footer a:hover{color:var(--gold)}
.foot-contact a{display:flex;align-items:center;gap:.6em;margin-bottom:.7rem}
.foot-contact svg{width:17px;height:17px;color:var(--gold);flex:none}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:2.6rem;padding-top:1.6rem;display:flex;flex-wrap:wrap;
  justify-content:space-between;gap:1rem;font-size:.82rem;color:#8a9684}
.foot-bottom a{color:#8a9684}

/* ============================ MOBILE CALL BAR ============================ */
.callbar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:1500;background:var(--forest);
  border-top:1px solid rgba(255,255,255,.12);padding:.6rem .8rem;gap:.6rem;box-shadow:0 -10px 30px -12px rgba(0,0,0,.4)}
.callbar a{flex:1;justify-content:center}

/* ============================ REVEAL ============================ */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.3,1)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ============================ RESPONSIVE ============================ */
@media(max-width:980px){
  .about-grid,.cta-grid,.faq-grid{grid-template-columns:1fr}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .steps,.quotes{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .hero{min-height:clamp(500px,80vh,720px)}
  .hero-inner{max-width:none}
  .hero-scrim{background:linear-gradient(0deg,rgba(19,32,22,.9) 4%,rgba(19,32,22,.5) 46%,rgba(19,32,22,.22) 100%)}
  .about-figure{max-width:440px;margin-inline:auto}
  .navlinks,.nav-phone{display:none}
  .menu-toggle{display:grid;place-items:center}
  .navlinks.open{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:flex-start;
    gap:0;background:var(--paper);border-bottom:1px solid var(--line);padding:.5rem clamp(20px,5vw,56px) 1.2rem}
  .navlinks.open a{padding:.85rem 0;width:100%;border-bottom:1px solid var(--line)}
  .callbar{display:flex}
  body{padding-bottom:70px}
}
@media(max-width:560px){
  .services-grid,.field-row,.why{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
}

/* ============================================================
   ===============  MULTI-PAGE ADDITIONS (Balar)  =============
   ============================================================ */

/* Active nav state */
.navlinks a.active{color:var(--clay)}
.navlinks a.active::after{width:100%}

/* ---------- SUB-PAGE HERO ---------- */
.subhero{position:relative;min-height:clamp(320px,44vh,440px);display:flex;align-items:flex-end;isolation:isolate;color:var(--paper)}
.subhero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:50% 50%;z-index:-2}
.subhero::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(0deg,rgba(11,26,16,.94) 2%,rgba(11,26,16,.6) 48%,rgba(11,26,16,.3) 100%)}
.subhero .wrap{padding-top:clamp(2.4rem,7vw,3.4rem);padding-bottom:clamp(2.2rem,5vw,3rem)}
.subhero h1{color:var(--paper);font-size:clamp(2.1rem,4.8vw,3.5rem);max-width:20ch;text-shadow:0 2px 24px rgba(0,0,0,.34)}
.subhero p.lead{color:rgba(255,255,255,.92);max-width:56ch;margin:1rem 0 1.5rem;font-size:clamp(1.02rem,1.4vw,1.18rem);text-shadow:0 1px 12px rgba(0,0,0,.28)}
.subhero .hero-cta{display:flex;flex-wrap:wrap;gap:.8rem;align-items:center}

/* ---------- BREADCRUMBS ---------- */
.crumbs{display:flex;flex-wrap:wrap;gap:.45em;align-items:center;font-size:.8rem;font-weight:500;margin-bottom:.85rem}
.subhero .crumbs{color:rgba(255,255,255,.82)}
.subhero .crumbs a{color:rgba(255,255,255,.82)}
.subhero .crumbs a:hover{color:#fff;text-decoration:underline}
.crumbs .sep{opacity:.5}

/* ---------- CONTENT LAYOUT ---------- */
.layout{display:grid;grid-template-columns:1.55fr .9fr;gap:clamp(1.8rem,4vw,3.4rem);align-items:start}
.prose>:first-child{margin-top:0}
.prose p{margin-bottom:1.1rem;color:#3f4f3e}
.prose h2{font-size:clamp(1.7rem,3.2vw,2.4rem);color:var(--forest);margin:2.4rem 0 1rem;letter-spacing:-.01em}
.prose h3{font-family:var(--serif);font-weight:400;font-size:1.35rem;color:var(--forest);margin:1.7rem 0 .6rem}
.prose .lead-p{font-size:1.12rem;color:#36462f}
.prose a.inline{color:var(--clay);font-weight:600;text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:1px}
.prose a.inline:hover{color:var(--clay-d)}

/* checklist */
.checklist{list-style:none;display:grid;gap:.75rem;margin:1.4rem 0 1.6rem}
.checklist li{display:flex;gap:.7rem;align-items:flex-start;color:#3f4f3e;font-size:.99rem}
.checklist .tick{width:25px;height:25px;border-radius:7px;background:var(--sage);color:var(--forest);display:grid;place-items:center;flex:none;margin-top:1px}
.checklist .tick svg{width:14px;height:14px}

/* feature cards */
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem;margin:1.8rem 0}
.feature{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1.4rem 1.3rem}
.feature .ic{width:40px;height:40px;border-radius:11px;background:var(--sage);color:var(--forest);display:grid;place-items:center;margin-bottom:.8rem}
.feature .ic svg{width:20px;height:20px}
.feature h3{font-family:var(--sans);font-weight:700;font-size:1.02rem;color:var(--ink);margin:0 0 .35rem}
.feature p{font-size:.9rem;color:#4a5a45;margin:0}

/* sidebar aside card */
.aside-card{background:var(--forest);color:var(--paper);border-radius:var(--r);padding:1.6rem 1.5rem;box-shadow:var(--shadow);position:sticky;top:96px}
.aside-card h3{font-family:var(--serif);font-weight:400;color:#fff;font-size:1.45rem;margin-bottom:.5rem}
.aside-card p{color:var(--sage);font-size:.93rem;margin-bottom:1.1rem}
.aside-card .ac-contact{display:flex;flex-direction:column;gap:.7rem;margin-bottom:1.2rem}
.aside-card .ac-contact a{display:inline-flex;align-items:center;gap:.6em;font-weight:600;color:#fff;font-size:1rem}
.aside-card .ac-contact svg{width:19px;height:19px;color:var(--gold);flex:none}
.aside-card .btn{width:100%;justify-content:center}
.aside-card .trust{margin-top:1.2rem;padding-top:1.1rem;border-top:1px solid rgba(255,255,255,.14);display:grid;gap:.55rem}
.aside-card .trust div{display:flex;gap:.5em;align-items:center;font-size:.86rem;color:#d8e2d2}
.aside-card .trust svg{width:16px;height:16px;color:var(--gold);flex:none}

/* ---------- LINK GRID (related services / areas) ---------- */
.linkgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:.8rem;margin-top:1.5rem}
.linkgrid a{display:flex;align-items:center;justify-content:space-between;gap:.6em;background:#fff;border:1px solid var(--line);border-radius:12px;padding:.85rem 1.1rem;font-weight:600;font-size:.95rem;color:var(--forest);transition:.22s}
.linkgrid a svg{width:1em;height:1em;color:var(--clay);transition:.2s;flex:none}
.linkgrid a:hover{border-color:var(--clay);color:var(--clay);transform:translateY(-2px);box-shadow:0 10px 24px -16px rgba(21,40,28,.4)}
.linkgrid a:hover svg{transform:translateX(3px)}

/* ---------- HUB CARDS (services hub, areas hub) ---------- */
.hub-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:3rem}
.hub-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:0 1px 3px rgba(21,40,28,.05);transition:.35s cubic-bezier(.2,.7,.3,1)}
.hub-card:hover{transform:translateY(-8px);box-shadow:var(--shadow);border-color:transparent}
.hub-card .card-img{aspect-ratio:16/10;overflow:hidden}
.hub-card .card-img img{width:100%;height:100%;object-fit:cover;transition:.6s ease}
.hub-card:hover .card-img img{transform:scale(1.06)}
.hub-card .card-body{padding:1.3rem 1.35rem 1.5rem;display:flex;flex-direction:column;flex:1}
.hub-card h3{font-size:1.28rem;color:var(--forest);margin-bottom:.4rem}
.hub-card p{font-size:.92rem;color:#4a5a45;margin-bottom:1rem;flex:1}
.hub-card .more{display:inline-flex;align-items:center;gap:.4em;font-weight:600;font-size:.85rem;color:var(--clay)}
.hub-card .more svg{width:1em;height:1em;transition:.25s}
.hub-card:hover .more svg{transform:translateX(4px)}

/* area chips that are links */
.area-list a{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.16);padding:.55em 1.1em;border-radius:100px;font-size:.92rem;font-weight:500;transition:.25s;color:var(--paper)}
.area-list a:hover{background:var(--clay);border-color:var(--clay);color:#fff}

/* ---------- GALLERY ---------- */
.gallery{columns:3;column-gap:1rem;margin-top:2.6rem}
.gallery img{width:100%;margin-bottom:1rem;border-radius:14px;break-inside:avoid;box-shadow:0 1px 3px rgba(21,40,28,.08);transition:.3s}
.gallery img:hover{transform:scale(1.015);box-shadow:var(--shadow)}
@media(max-width:900px){.gallery{columns:2}}
@media(max-width:540px){.gallery{columns:1}}

/* ---------- INTRO STRIP (light) ---------- */
.introstrip{background:var(--paper-2)}
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.6rem,4vw,3.4rem);align-items:center}
.split img{width:100%;border-radius:var(--r);box-shadow:var(--shadow);object-fit:cover}

/* contact grid */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.contact-info .ci{display:flex;gap:.9rem;align-items:flex-start;margin-bottom:1.5rem}
.contact-info .ci .ic{width:46px;height:46px;border-radius:12px;background:var(--sage);color:var(--forest);display:grid;place-items:center;flex:none}
.contact-info .ci .ic svg{width:21px;height:21px}
.contact-info .ci h4{font-family:var(--sans);font-weight:700;font-size:1rem;color:var(--ink);margin-bottom:.2rem}
.contact-info .ci p,.contact-info .ci a{color:#46553f;font-size:.96rem}
.contact-info .ci a:hover{color:var(--clay)}

/* responsive */
@media(max-width:900px){
  .layout,.contact-grid,.split{grid-template-columns:1fr}
  .hub-grid,.feature-grid{grid-template-columns:repeat(2,1fr)}
  .aside-card{position:static}
}
@media(max-width:620px){
  .hub-grid,.feature-grid{grid-template-columns:1fr}
}

/* ---------- THANK YOU ---------- */
.ty-badge{display:inline-grid;place-items:center;width:74px;height:74px;border-radius:50%;
  background:rgba(226,178,90,.16);border:1px solid rgba(226,178,90,.5);color:var(--gold)}
.ty-badge svg{width:34px;height:34px}
.ty-cta{display:flex;flex-wrap:wrap;gap:.8rem;justify-content:center}
