:root{
  --pine:#1e7a42;
  --pine-deep:#15592f;
  --moss:#2f9e57;
  --bark:#5b4633;
  --bark-deep:#463525;
  --path:#c49a62;
  --sage:#f6faf2;
  --sage-soft:#e9f4e0;
  --oak:#f5a623;
  --oak-light:#ffc14d;
  --ink:#1b2b20;
  --white:#ffffff;
  --line:rgba(30,122,66,.16);
  --radius:12px;
  --shadow:0 12px 34px rgba(27,43,32,.1);
  --display:"Bricolage Grotesque",Georgia,serif;
  --body:"Karla",-apple-system,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition:none!important}
}
html,body{max-width:100%;overflow-x:clip}
body{font-family:var(--body);color:var(--ink);background:var(--sage);line-height:1.6;font-size:17px}
img{max-width:100%;display:block}
a{color:inherit}
:focus-visible{outline:3px solid var(--oak);outline-offset:3px;border-radius:2px}
.wrap{max-width:1160px;margin:0 auto;padding:0 24px}
section{padding:80px 0}

/* ---------- buttons ---------- */
.btn{display:inline-block;background:var(--oak);color:var(--bark-deep);font-weight:700;text-decoration:none;padding:13px 26px;border-radius:var(--radius);border:none;font-size:16px;font-family:var(--body);cursor:pointer;transition:background .15s ease,transform .15s ease,box-shadow .15s ease}
.btn:hover{background:var(--oak-light);transform:translateY(-2px);box-shadow:0 8px 20px rgba(245,166,35,.35)}
.btn.ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.55)}
.btn.ghost:hover{background:rgba(255,255,255,.14);box-shadow:none}
.btn.outline{background:transparent;color:var(--pine);border:1.5px solid var(--pine)}
.btn.outline:hover{background:var(--pine);color:#fff;box-shadow:none}
.btn.small{padding:9px 18px;font-size:14px}

/* ---------- type ---------- */
.eyebrow{font-size:13px;letter-spacing:.18em;text-transform:uppercase;font-weight:700;color:var(--pine);margin-bottom:16px}
h1,h2,h3{font-family:var(--display);letter-spacing:-.015em;color:var(--bark)}
h2{font-weight:700;font-size:clamp(30px,4vw,44px);line-height:1.08}
.section-head{max-width:660px;margin-bottom:46px}
.section-head p{margin-top:14px;color:#33493c;font-size:18px}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}

/* ---------- topbar + header ---------- */
.topbar{background:var(--pine-deep);color:#fff;font-size:14px;padding:8px 24px;display:flex;justify-content:center;gap:28px;flex-wrap:wrap}
.topbar span{opacity:.92}
.topbar strong{color:var(--oak-light);font-weight:700}
.topbar a{color:#fff;text-decoration:none;font-weight:700}
header.site{position:sticky;top:0;z-index:50;background:rgba(246,250,242,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav-inner{max-width:1160px;margin:0 auto;padding:12px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.logo{display:flex;align-items:center;text-decoration:none}
.logo img{height:54px;width:auto}
nav.main{display:flex;gap:8px;align-items:center}
nav.main a{text-decoration:none;font-weight:600;font-size:15px;color:var(--ink);padding:9px 14px;border-radius:8px;transition:background .15s ease,color .15s ease}
nav.main a:hover{background:var(--sage-soft);color:var(--pine)}
nav.main a.active{background:var(--sage-soft);color:var(--pine)}
nav.main .btn{margin-left:10px;color:var(--bark-deep)}
.menu-toggle{display:none;background:var(--sage);border:1.5px solid var(--line);border-radius:8px;padding:8px 12px;font-size:22px;line-height:1;cursor:pointer;color:var(--pine)}
@media(max-width:880px){
  .menu-toggle{display:block}
  nav.main{
    position:fixed;
    inset:0;
    width:100vw;
    height:100vh;
    height:100dvh;
    max-height:100dvh;
    overflow-y:auto;
    overflow-x:hidden;
    overscroll-behavior:contain;
    background-color:var(--sage);
    flex-direction:column;
    justify-content:flex-start;
    gap:6px;
    padding:56px 24px 24px;
    transform:translateX(100%);
    opacity:0;
    visibility:hidden;
    pointer-events:none;
    transition:transform .25s ease, opacity .2s ease, visibility 0s linear .25s;
    z-index:80;
  }
  nav.main.open{
    transform:translateX(0);
    opacity:1;
    visibility:visible;
    pointer-events:auto;
    transition-delay:0s;
    background-color:var(--sage);
  }
  nav.main a{font-size:20px;padding:14px 22px}
  nav.main .btn{margin:18px 0 0}
  .nav-close{position:absolute;top:18px;right:20px;background:transparent;border:none;font-size:30px;cursor:pointer;color:var(--bark)}
}
@media(min-width:881px){.nav-close{display:none}}

/* ---------- home hero with hills ---------- */
.hero{position:relative;background:linear-gradient(170deg,#bfe6ff 0%,#e6f6ff 38%,#f3fbee 60%);overflow:hidden;padding:0}
.hero-inner{max-width:1160px;margin:0 auto;padding:96px 24px 0;position:relative;z-index:2;text-align:center}
.hero .eyebrow{color:var(--pine)}
.hero h1{font-weight:700;font-size:clamp(42px,6.6vw,78px);line-height:1.0;color:var(--bark-deep);max-width:17ch;margin:0 auto}
.hero h1 em{font-style:normal;color:var(--pine)}
.hero p.lede{margin:24px auto 0;font-size:19px;max-width:56ch;color:#3c5246}
.hero-ctas{margin-top:34px;display:flex;gap:14px;flex-wrap:wrap;justify-content:center}
.hero-hills{display:block;width:100%;height:auto;margin-top:-30px;position:relative;z-index:1}
.hero-trust{position:relative;z-index:2;background:var(--pine-deep);color:#fff;padding:22px 24px}
.hero-trust .wrap{display:flex;justify-content:center;gap:clamp(24px,6vw,72px);flex-wrap:wrap;font-size:14px;color:rgba(255,255,255,.8);text-align:center}
.hero-trust strong{display:block;font-family:var(--display);font-size:24px;color:#fff;font-weight:600}
.path-draw{stroke-dasharray:1600;stroke-dashoffset:1600;animation:draw 2.4s ease forwards .3s}
@keyframes draw{to{stroke-dashoffset:0}}
@media(prefers-reduced-motion:reduce){.path-draw{stroke-dashoffset:0}}

/* ---------- page hero (inner pages) ---------- */
.page-hero{background:linear-gradient(160deg,#2f9e57 0%,#1e7a42 55%,#15592f 100%);color:#fff;padding:72px 0 64px;position:relative;overflow:hidden}
.page-hero::after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(90deg,rgba(255,255,255,.03) 0 2px,transparent 2px 90px)}
.page-hero .wrap{position:relative;z-index:1}
.page-hero .eyebrow{color:var(--oak-light)}
.page-hero h1{color:#fff;font-size:clamp(36px,5vw,58px);font-weight:700;line-height:1.05;max-width:16ch}
.page-hero p{margin-top:18px;font-size:18px;max-width:54ch;color:rgba(255,255,255,.9)}
.page-hero .crumbs{font-size:13.5px;margin-bottom:22px;color:rgba(255,255,255,.75)}
.page-hero .crumbs a{color:#fff;text-decoration:none;font-weight:600}
.page-hero .crumbs a:hover{text-decoration:underline}

/* ---------- winding path divider ---------- */
.path-divider{display:block;width:100%;height:auto}

/* ---------- cards & grids ---------- */
.trades{display:grid;grid-template-columns:1fr 1fr;gap:28px}
@media(max-width:820px){.trades{grid-template-columns:1fr}}
.trade{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:38px 34px;position:relative;overflow:hidden;text-decoration:none;display:block;transition:transform .18s ease,box-shadow .18s ease}
.trade:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.trade::before{content:"";position:absolute;top:0;left:0;right:0;height:6px;background:var(--moss)}
.trade.carpentry::before{background:var(--path)}
.trade h3{font-size:26px;font-weight:600;margin-bottom:6px}
.trade .tagline{font-size:13.5px;letter-spacing:.1em;text-transform:uppercase;font-weight:700;color:var(--moss);margin-bottom:18px}
.trade.carpentry .tagline{color:#a87c44}
.trade ul{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:10px 18px;margin-bottom:24px}
@media(max-width:460px){.trade ul{grid-template-columns:1fr}}
.trade li{padding-left:24px;position:relative;font-size:15.5px;color:var(--ink)}
.trade li::before{content:"";position:absolute;left:0;top:9px;width:12px;height:3px;background:var(--moss);border-radius:2px}
.trade.carpentry li::before{background:var(--path)}
.trade .more{font-weight:700;color:var(--pine);font-size:15px}
.trade.carpentry .more{color:#a87c44}

.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:900px){.svc-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.svc-grid{grid-template-columns:1fr}}
.svc{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:30px 28px;transition:transform .18s ease,box-shadow .18s ease}
.svc:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.svc .icon{width:48px;height:48px;border-radius:12px;background:var(--sage-soft);display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:16px}
.svc h3{font-size:20px;font-weight:600;margin-bottom:8px}
.svc p{font-size:15.5px;color:#33493c}

/* process */
.process{background:var(--sage-soft)}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;counter-reset:step}
@media(max-width:920px){.steps{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.steps{grid-template-columns:1fr}}
.step{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:28px 26px;counter-increment:step;position:relative}
.step::before{content:counter(step,decimal-leading-zero);font-family:var(--display);font-weight:700;font-size:30px;color:var(--path);display:block;margin-bottom:10px}
.step h3{font-size:18px;font-weight:700;margin-bottom:8px}
.step p{font-size:15px;color:#33493c}

/* gallery */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:860px){.gallery-grid{grid-template-columns:1fr 1fr}}
@media(max-width:540px){.gallery-grid{grid-template-columns:1fr}}
.tile{aspect-ratio:4/3;border-radius:var(--radius);position:relative;overflow:hidden;display:flex;align-items:flex-end;color:#fff;text-decoration:none;transition:transform .18s ease,box-shadow .18s ease}
.tile:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.tile .label{position:relative;z-index:2;padding:18px;font-weight:700;font-size:15px;text-shadow:0 1px 6px rgba(0,0,0,.45)}
.tile .label small{display:block;font-weight:500;font-size:12.5px;opacity:.9}
.tile::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(16,58,32,.72),transparent 55%)}
.tile.hidden{display:none}
.t1{background:linear-gradient(135deg,#5ec77f,#1e7a42)}
.t2{background:linear-gradient(135deg,#ffc14d,#d98a1c)}
.t3{background:linear-gradient(135deg,#8fd47a,#3a9e50)}
.t4{background:linear-gradient(135deg,#f0a85c,#b86a24)}
.t5{background:linear-gradient(135deg,#46b878,#1a6b3c)}
.t6{background:linear-gradient(135deg,#ffd47a,#e09a2e)}
.t7{background:linear-gradient(135deg,#6bc98f,#23864b)}
.t8{background:linear-gradient(135deg,#e8b066,#a3712c)}
.t9{background:linear-gradient(135deg,#9bd887,#48a55c)}
.photo-note{margin-top:16px;font-size:14px;color:#56705f;font-style:italic}
.filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:28px}
.filters button{background:var(--white);border:1.5px solid var(--line);border-radius:999px;padding:9px 20px;font-family:var(--body);font-weight:700;font-size:14px;color:var(--ink);cursor:pointer;transition:all .15s ease}
.filters button:hover{border-color:var(--pine);color:var(--pine)}
.filters button.active{background:var(--pine);border-color:var(--pine);color:#fff}

/* reviews */
.reviews{background:linear-gradient(150deg,#1e7a42,#15592f);color:#fff}
.reviews h2,.reviews .eyebrow{color:#fff}
.reviews .eyebrow{color:var(--oak-light)}
.review-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:880px){.review-grid{grid-template-columns:1fr}}
.review{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);border-radius:var(--radius);padding:28px 26px}
.stars{color:var(--oak-light);letter-spacing:3px;margin-bottom:14px;font-size:15px}
.review p{font-size:15.5px;color:rgba(255,255,255,.94)}
.review footer{margin-top:16px;font-weight:700;font-size:14px;color:var(--oak-light)}
.review footer small{display:block;font-weight:500;color:rgba(255,255,255,.65)}

/* CTA band */
.cta-band{background:linear-gradient(120deg,var(--bark) 0%,var(--bark-deep) 100%);color:#fff;border-radius:var(--radius);padding:52px 48px;display:flex;align-items:center;justify-content:space-between;gap:28px;flex-wrap:wrap;position:relative;overflow:hidden}
.cta-band::after{content:"";position:absolute;right:-40px;top:-40px;width:220px;height:220px;border-radius:50%;background:rgba(245,166,35,.18)}
.cta-band h2{color:#fff;font-size:clamp(26px,3.4vw,36px)}
.cta-band p{margin-top:8px;color:rgba(255,255,255,.85)}
.cta-band .btn{position:relative;z-index:1}
@media(max-width:640px){.cta-band{padding:38px 28px}}

/* quote form */
.quote-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:48px;align-items:start}
@media(max-width:880px){.quote-grid{grid-template-columns:1fr}}
.contact-lines{display:grid;gap:12px;font-size:16px}
.contact-lines a{font-weight:700;color:var(--pine);text-decoration:none}
.contact-lines a:hover{text-decoration:underline}
.badge-row{margin-top:30px;display:flex;gap:10px;flex-wrap:wrap}
.badge{font-size:12.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;background:var(--white);border:1px solid var(--line);border-radius:999px;padding:8px 14px;color:var(--pine)}
form.quote-form{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:36px 32px;box-shadow:var(--shadow)}
form.quote-form h3{font-size:23px;font-weight:600;margin-bottom:4px}
form.quote-form .sub{font-size:14px;color:#56705f;margin-bottom:22px}
.field{margin-bottom:16px}
.field label{display:block;font-weight:700;font-size:14px;margin-bottom:6px;color:var(--bark)}
.field input,.field select,.field textarea{width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:8px;font-family:var(--body);font-size:15.5px;background:var(--sage);color:var(--ink)}
.field input:focus,.field select:focus,.field textarea:focus{outline:2px solid var(--oak);border-color:var(--oak)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:480px){.field-row{grid-template-columns:1fr}}
.quote-form .btn{width:100%;margin-top:6px;padding:14px}
.form-note{font-size:13px;color:#56705f;margin-top:12px;text-align:center}
.success{display:none;text-align:center;padding:40px 10px}
.success.show{display:block}
.success .tick{width:58px;height:58px;border-radius:50%;background:var(--moss);color:#fff;font-size:28px;display:flex;align-items:center;justify-content:center;margin:0 auto 18px}
.success h3{font-size:24px;margin-bottom:8px}
.success p{color:#33493c;font-size:15.5px}

/* FAQ */
.faq{max-width:760px}
.faq details{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:0;margin-bottom:12px;overflow:hidden}
.faq summary{cursor:pointer;font-weight:700;font-size:16.5px;padding:20px 24px;color:var(--bark);list-style:none;display:flex;justify-content:space-between;align-items:center}
.faq summary::after{content:"+";font-family:var(--display);font-size:22px;color:var(--pine)}
.faq details[open] summary::after{content:"–"}
.faq details p{padding:0 24px 20px;color:#33493c;font-size:15.5px}

/* about extras */
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:860px){.values{grid-template-columns:1fr}}
.split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
@media(max-width:840px){.split{grid-template-columns:1fr}}
.split .visual{border-radius:var(--radius);aspect-ratio:4/3;background:linear-gradient(135deg,#5ec77f,#1e7a42);position:relative;overflow:hidden;display:flex;align-items:flex-end;color:#fff}
.split .visual span{padding:18px;font-weight:700;text-shadow:0 1px 6px rgba(0,0,0,.4);position:relative;z-index:1}
.split .visual::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(16,58,32,.6),transparent 55%)}
.area-list{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}
.area-list span{background:var(--white);border:1px solid var(--line);border-radius:999px;padding:8px 16px;font-size:14px;font-weight:600;color:var(--pine)}

/* footer */
footer.site{background:var(--pine-deep);color:rgba(255,255,255,.78);padding:54px 24px 30px;font-size:14.5px}
.foot-inner{max-width:1160px;margin:0 auto;display:grid;grid-template-columns:auto 1fr 1fr 1fr;gap:40px;align-items:start}
@media(max-width:860px){.foot-inner{grid-template-columns:1fr 1fr}}
@media(max-width:540px){.foot-inner{grid-template-columns:1fr}}
.foot-logo{background:#fff;border-radius:12px;padding:10px 16px;display:inline-block}
.foot-logo img{height:60px}
.foot-inner h4{color:#fff;font-family:var(--body);font-size:13px;letter-spacing:.12em;text-transform:uppercase;margin-bottom:14px}
.foot-inner ul{list-style:none}
.foot-inner li{margin-bottom:9px}
.foot-inner a{color:rgba(255,255,255,.78);text-decoration:none}
.foot-inner a:hover{color:#fff;text-decoration:underline}
.foot-legal{margin:30px auto 0;max-width:1160px;border-top:1px solid rgba(255,255,255,.18);padding-top:18px;font-size:12.5px;color:rgba(255,255,255,.5);display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap}

/* sticky mobile CTA */
.mobile-cta{display:none;position:fixed;bottom:0;left:0;right:0;z-index:60;background:var(--pine-deep);padding:10px 14px;gap:10px;box-shadow:0 -6px 20px rgba(0,0,0,.25)}
.mobile-cta a{flex:1;text-align:center}
@media(max-width:760px){.mobile-cta{display:flex}body{padding-bottom:70px}}

/* reveal */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none}}
