:root{
  --pine:#0E3320;
  --deep:#072E1C;
  --ink:#15251C;
  --cream:#F2EEE3;
  --paper:#FAF8F1;
  --ochre:#B07E24;
  --line:#DAD3C0;
  --radius:10px;
  --disp:"Bricolage Grotesque",system-ui,sans-serif;
  --body:"Inter",system-ui,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{animation:none!important;transition:none!important}}
body{font-family:var(--body);color:var(--ink);background:var(--cream);font-size:16.5px;line-height:1.65;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:var(--pine)}
.wrap{max-width:1080px;margin:0 auto;padding:0 22px}

/* type */
h1,h2,h3{font-family:var(--disp);color:var(--pine);line-height:1.08;letter-spacing:-.015em}
h1{font-size:clamp(2.3rem,5.4vw,3.9rem);font-weight:800}
h2{font-size:clamp(1.7rem,3.4vw,2.4rem);font-weight:700}
h3{font-size:1.18rem;font-weight:700;line-height:1.3}
.eyebrow{font-family:var(--body);font-size:.78rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--ochre);margin-bottom:.7rem}
.lede{font-size:1.13rem;color:#3C4A40;max-width:56ch}

/* header */
header{background:var(--cream);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.7rem 22px;max-width:1080px;margin:0 auto}
.brand{display:flex;align-items:center;gap:.65rem;text-decoration:none}
.brand img{height:46px;width:auto}
.brand span{font-family:var(--disp);font-weight:800;font-size:1.05rem;color:var(--pine);letter-spacing:.01em;line-height:1.1}
.nav-links{display:flex;align-items:center;gap:1.4rem;list-style:none}
.nav-links a{text-decoration:none;font-weight:600;font-size:.93rem;color:var(--ink)}
.nav-links a:hover{color:var(--ochre)}
.nav-links a.active{color:var(--ochre)}
.btn{display:inline-block;background:var(--pine);color:var(--cream);text-decoration:none;font-weight:700;font-size:.95rem;padding:.72rem 1.35rem;border-radius:999px;border:2px solid var(--pine);transition:background .15s,color .15s}
.btn:hover{background:transparent;color:var(--pine)}
.btn.light{background:var(--cream);color:var(--pine);border-color:var(--cream)}
.btn.light:hover{background:transparent;color:var(--cream)}
.btn.ghost{background:transparent;color:var(--pine)}
.btn.ghost:hover{background:var(--pine);color:var(--cream)}
.menu-toggle{display:none;background:none;border:0;font-size:1.7rem;color:var(--pine);cursor:pointer;line-height:1}
@media(max-width:820px){
  .menu-toggle{display:block}
  .nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:var(--cream);border-bottom:1px solid var(--line);flex-direction:column;align-items:flex-start;padding:1rem 22px;gap:1rem}
  .nav-links.open{display:flex}
  .nav .btn{display:none}
}

/* hero (home) */
.hero{position:relative;min-height:74vh;display:flex;align-items:flex-end;background:var(--deep)}
.hero img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.55}
.hero .panel{position:relative;z-index:2;max-width:1080px;margin:0 auto;width:100%;padding:5.5rem 22px 3.2rem}
.hero h1{color:var(--cream);max-width:15ch}
.hero p{color:#DCE5DC;font-size:1.15rem;max-width:52ch;margin:1.1rem 0 1.7rem}
.hero .cta-row{display:flex;gap:.8rem;flex-wrap:wrap;align-items:center}
.hero .phone{color:var(--cream);font-weight:700;text-decoration:none;font-size:1.05rem}
.hero .phone:hover{color:var(--ochre)}

/* page hero (interior) */
.page-hero{background:var(--deep);color:var(--cream);padding:4rem 0 3rem}
.page-hero h1{color:var(--cream)}
.page-hero p{color:#DCE5DC;max-width:56ch;margin-top:1rem;font-size:1.12rem}

/* sections */
section{padding:4.2rem 0}
.section-head{margin-bottom:2.2rem}

/* services grid */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
.svc{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;text-decoration:none;color:var(--ink);display:flex;flex-direction:column;transition:transform .15s,box-shadow .15s}
.svc:hover{transform:translateY(-3px);box-shadow:0 10px 24px rgba(14,51,32,.12)}
.svc img{height:190px;object-fit:cover;width:100%}
.svc .pad{padding:1.15rem 1.2rem 1.35rem}
.svc h3{margin-bottom:.4rem}
.svc p{font-size:.95rem;color:#4A5850}
.svc .go{margin-top:.7rem;font-weight:700;font-size:.9rem;color:var(--ochre)}
.svc-row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem;margin-top:1.1rem}
.svc-row .svc{flex-direction:row}
.svc-row .svc img{width:38%;height:auto;min-height:150px}
@media(max-width:820px){.svc-grid{grid-template-columns:1fr}.svc-row{grid-template-columns:1fr}.svc-row .svc{flex-direction:column}.svc-row .svc img{width:100%;height:190px}}

/* estimate card (signature) */
.quote-band{background:var(--pine)}
.quote-band .inner{display:grid;grid-template-columns:1fr 1.05fr;gap:3rem;align-items:center}
.quote-band h2{color:var(--cream)}
.quote-band p{color:#D6E0D6}
.qcard{background:var(--paper);border-radius:var(--radius);overflow:hidden;box-shadow:0 18px 44px rgba(0,0,0,.28)}
.qcard .qhead{background:var(--deep);color:var(--cream);padding:.9rem 1.3rem;display:flex;justify-content:space-between;align-items:center;font-family:var(--disp);font-weight:700}
.qcard .qhead small{font-family:var(--body);font-weight:600;font-size:.72rem;letter-spacing:.12em;color:#B9C9BB}
.qcard ul{list-style:none;padding:1.1rem 1.3rem .4rem}
.qcard li{display:flex;justify-content:space-between;gap:1rem;padding:.55rem 0;border-bottom:1px dashed var(--line);font-size:.93rem}
.qcard li span:last-child{color:#6A7268;white-space:nowrap}
.qcard .qfoot{padding:.9rem 1.3rem 1.2rem;font-size:.85rem;color:#6A7268}
@media(max-width:820px){.quote-band .inner{grid-template-columns:1fr}}

/* work grid */
.work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.8rem}
.work-grid figure{border-radius:var(--radius);overflow:hidden;position:relative}
.work-grid img{height:230px;width:100%;object-fit:cover;transition:transform .3s}
.work-grid figure:hover img{transform:scale(1.04)}
.work-grid figcaption{position:absolute;left:0;right:0;bottom:0;padding:.55rem .8rem;font-size:.8rem;font-weight:600;color:var(--cream);background:linear-gradient(transparent,rgba(7,46,28,.85))}
@media(max-width:820px){.work-grid{grid-template-columns:1fr 1fr}}
@media(max-width:540px){.work-grid{grid-template-columns:1fr}}

/* reviews */
.review-band{background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.review-band .inner{display:flex;justify-content:space-between;align-items:center;gap:2rem;flex-wrap:wrap}
.stars{color:var(--ochre);font-size:1.3rem;letter-spacing:.15em}

/* about */
.about .inner{display:grid;grid-template-columns:1.1fr .9fr;gap:3rem;align-items:center}
@media(max-width:820px){.about .inner{grid-template-columns:1fr}}
.about img{border-radius:var(--radius)}

/* interior content */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:3rem;align-items:start}
@media(max-width:820px){.split{grid-template-columns:1fr}}
.split img{border-radius:var(--radius)}
.check{list-style:none;margin-top:1.2rem}
.check li{padding:.45rem 0 .45rem 1.7rem;position:relative}
.check li::before{content:"";position:absolute;left:0;top:.95em;width:.7em;height:.7em;background:var(--ochre);border-radius:2px;transform:rotate(45deg)}

/* cta band */
.cta-band{background:var(--deep);text-align:center}
.cta-band h2{color:var(--cream);max-width:22ch;margin:0 auto 1rem}
.cta-band p{color:#D6E0D6;margin-bottom:1.6rem}

/* form */
form{display:grid;gap:1rem;max-width:640px}
label{font-weight:600;font-size:.9rem;display:block;margin-bottom:.3rem}
input,select,textarea{width:100%;padding:.75rem .9rem;border:1px solid var(--line);border-radius:8px;background:var(--paper);font:inherit;color:var(--ink)}
input:focus,select:focus,textarea:focus{outline:2px solid var(--ochre);outline-offset:1px;border-color:var(--ochre)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:600px){.form-row{grid-template-columns:1fr}}
.hidden{display:none}

/* footer */
footer{background:var(--deep);color:#C7D3C8;padding:3.2rem 0 2rem;font-size:.92rem}
footer .cols{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:2.5rem;margin-bottom:2.2rem}
@media(max-width:820px){footer .cols{grid-template-columns:1fr}}
footer h4{font-family:var(--disp);color:var(--cream);margin-bottom:.8rem;font-size:1rem}
footer a{color:#C7D3C8;text-decoration:none}
footer a:hover{color:var(--ochre)}
footer ul{list-style:none}
footer li{padding:.2rem 0}
footer .legal{border-top:1px solid rgba(255,255,255,.12);padding-top:1.3rem;font-size:.8rem;color:#8FA093;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}
footer .flogo{height:52px;margin-bottom:.9rem}
:focus-visible{outline:2px solid var(--ochre);outline-offset:2px}

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

/* hero upgrade */
.hero img.bg{animation:heroZoom 18s ease-out forwards;transform-origin:center}
@keyframes heroZoom{from{transform:scale(1.08)}to{transform:scale(1)}}
.trust-chips{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:1.6rem}
.trust-chips span{background:rgba(242,238,227,.12);border:1px solid rgba(242,238,227,.3);color:var(--cream);backdrop-filter:blur(4px);font-size:.8rem;font-weight:600;padding:.4rem .85rem;border-radius:999px}

/* funnel widget */
.funnel{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:1.8rem;box-shadow:0 14px 34px rgba(14,51,32,.1)}
.funnel h2{font-size:clamp(1.4rem,2.6vw,1.8rem)}
.funnel-opts{display:grid;grid-template-columns:repeat(3,1fr);gap:.7rem;margin-top:1.2rem}
.funnel-opts a{display:flex;flex-direction:column;gap:.25rem;text-decoration:none;background:var(--cream);border:1.5px solid var(--line);border-radius:10px;padding:.95rem 1rem;color:var(--ink);font-weight:700;font-size:.95rem;transition:border-color .15s,transform .15s,box-shadow .15s}
.funnel-opts a small{font-weight:500;color:#5A685E;font-size:.78rem}
.funnel-opts a:hover{border-color:var(--ochre);transform:translateY(-2px);box-shadow:0 8px 18px rgba(14,51,32,.1)}
@media(max-width:820px){.funnel-opts{grid-template-columns:1fr 1fr}}
@media(max-width:540px){.funnel-opts{grid-template-columns:1fr}}

/* sticky mobile action bar */
.action-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:60;background:var(--deep);padding:.6rem .8rem calc(.6rem + env(safe-area-inset-bottom));gap:.6rem;box-shadow:0 -6px 20px rgba(0,0,0,.25)}
.action-bar a{flex:1;text-align:center;text-decoration:none;font-weight:800;font-size:.95rem;padding:.75rem 0;border-radius:10px}
.action-bar .call{background:transparent;border:1.5px solid var(--cream);color:var(--cream)}
.action-bar .est{background:var(--ochre);color:#fff}
@media(max-width:820px){.action-bar{display:flex}body{padding-bottom:64px}}

/* lightbox */
.lightbox{position:fixed;inset:0;background:rgba(7,26,17,.93);display:none;align-items:center;justify-content:center;z-index:100;padding:2rem;cursor:zoom-out}
.lightbox.open{display:flex}
.lightbox img{max-width:min(1100px,95vw);max-height:88vh;border-radius:10px;box-shadow:0 30px 80px rgba(0,0,0,.5)}
.lightbox .cap{position:absolute;bottom:1.4rem;left:0;right:0;text-align:center;color:var(--cream);font-weight:600;font-size:.95rem}
.work-grid figure{cursor:zoom-in}

/* multi-step form */
.steps{display:flex;gap:.4rem;margin-bottom:1.4rem}
.steps span{flex:1;height:5px;border-radius:99px;background:var(--line);transition:background .3s}
.steps span.done{background:var(--ochre)}
.fstep{display:none}
.fstep.active{display:grid;gap:1rem;animation:stepIn .35s ease}
@keyframes stepIn{from{opacity:0;transform:translateX(14px)}to{opacity:1;transform:none}}
.svc-pick{display:grid;grid-template-columns:1fr 1fr;gap:.7rem}
@media(max-width:540px){.svc-pick{grid-template-columns:1fr}}
.svc-pick label{display:block;border:1.5px solid var(--line);border-radius:10px;padding:1rem;cursor:pointer;font-weight:700;margin:0;font-size:.95rem;background:var(--paper);transition:border-color .15s,background .15s}
.svc-pick label small{display:block;font-weight:500;color:#5A685E;font-size:.78rem;margin-top:.15rem}
.svc-pick input{position:absolute;opacity:0;width:0}
.svc-pick label:has(input:checked){border-color:var(--ochre);background:#FBF3E2}
.svc-pick label:hover{border-color:var(--ochre)}
.form-nav{display:flex;justify-content:space-between;gap:1rem;margin-top:.4rem}
.btn.small{padding:.6rem 1.1rem;font-size:.88rem}
.step-note{font-size:.85rem;color:#5A685E}
