:root{
  --green:#1d5a39; --green-dk:#123a26; --green-darker:#0e2c1d;
  --sage:#a7bbab; --sage-soft:#cdd8cd;
  --cream:#f4f1e7; --paper:#fbfaf4; --white:#ffffff;
  --ink:#1f2620; --muted:#6c7269; --line:rgba(31,38,32,.14);
  --brass:#b08a52; --brass-lt:#c8a878;
  --shadow:0 20px 50px -28px rgba(18,40,30,.45);
  --serif:"Cormorant Garamond",Georgia,serif;
  --sans:"Jost",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --wrap:1240px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--paper);line-height:1.65;font-weight:400;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 28px}
h1,h2,h3{font-family:var(--serif);font-weight:600;line-height:1.05;letter-spacing:.01em}
.serif{font-family:var(--serif)}
.eyebrow{font-family:var(--sans);font-size:12px;font-weight:600;letter-spacing:.28em;text-transform:uppercase;color:var(--brass)}
.eyebrow.on-dark{color:var(--brass-lt)}
section{position:relative}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.6em;font-family:var(--sans);font-weight:500;font-size:14px;letter-spacing:.04em;padding:15px 30px;border-radius:2px;transition:.25s ease;cursor:pointer;border:1px solid transparent;white-space:nowrap}
.btn-primary{background:var(--green);color:#fff}
.btn-primary:hover{background:var(--green-dk);transform:translateY(-2px);box-shadow:var(--shadow)}
.btn-ghost{border-color:currentColor;color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:#fff}
.btn-ghost.on-dark{color:#fff;border-color:rgba(255,255,255,.55)}
.btn-ghost.on-dark:hover{background:#fff;color:var(--green-dk)}
.btn-brass{background:var(--brass);color:#fff}
.btn-brass:hover{background:var(--brass-lt)}
.link-arrow{font-family:var(--sans);font-weight:500;font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:var(--green);display:inline-flex;align-items:center;gap:.5em;transition:.2s}
.link-arrow:hover{gap:.9em;color:var(--green-dk)}

/* topbar */
.topbar{background:var(--green-darker);color:#dfe7df;font-size:12.5px;letter-spacing:.05em}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;height:38px}
.topbar a{color:#fff;font-weight:500}
.topbar .tb-r{display:flex;gap:22px;align-items:center}
.topbar svg{width:13px;height:13px;vertical-align:-2px;margin-right:6px;fill:var(--brass-lt)}

/* header */
header{position:sticky;top:0;z-index:50;background:rgba(251,250,244,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);transition:.3s}
header.scrolled{box-shadow:0 6px 24px -16px rgba(18,40,30,.5)}
.nav{display:flex;align-items:center;justify-content:space-between;height:80px;transition:height .3s}
header.scrolled .nav{height:66px}
.brand{display:flex;align-items:center;gap:13px}
.brand img{width:46px;height:46px;transition:.3s}
header.scrolled .brand img{width:40px;height:40px}
.brand .bt{line-height:1}
.brand .bt .nm{display:block;font-family:var(--serif);font-weight:600;font-size:23px;line-height:1;letter-spacing:.06em;color:var(--green-dk)}
.brand .bt .sb{display:block;font-size:9.5px;font-weight:500;letter-spacing:.34em;text-transform:uppercase;color:var(--sage);margin-top:3px}
.menu{display:flex;align-items:center;gap:32px;list-style:none}
.menu a{font-size:13.5px;font-weight:500;letter-spacing:.04em;color:var(--ink);position:relative;padding:4px 0}
.menu a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1.5px;background:var(--brass);transition:.25s}
.menu a:hover::after{width:100%}
.menu-cta{display:none}
.nav-cta{display:flex;align-items:center;gap:18px}
.nav-phone{font-weight:600;font-size:15px;color:var(--green-dk);letter-spacing:.02em}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.burger span{width:24px;height:2px;background:var(--ink);transition:.3s}

/* hero */
.hero{background:linear-gradient(180deg,var(--paper),var(--cream));overflow:hidden}
.hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center;padding-top:78px;padding-bottom:78px}
.hero-eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:26px}
.hero-eyebrow .mtf{display:flex;gap:3px}
.hero-eyebrow .mtf i{display:block;width:7px;height:9px;background:var(--sage);opacity:.8}
.hero h1{font-size:clamp(40px,5.6vw,68px);color:var(--ink);margin-bottom:22px}
.hero h1 em{font-style:italic;color:var(--green)}
.hero .lede{font-size:18px;color:var(--muted);max-width:30em;margin-bottom:34px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:38px}
.hero-trust{display:flex;gap:26px;flex-wrap:wrap;border-top:1px solid var(--line);padding-top:24px}
.hero-trust div{font-size:13px;color:var(--ink)}
.hero-trust b{display:block;font-family:var(--serif);font-size:26px;font-weight:600;color:var(--green);line-height:1}
.hero-trust span{color:var(--muted);font-size:12.5px;letter-spacing:.03em}
.hero-img{position:relative}
.hero-img .frame{aspect-ratio:4/4.7;overflow:hidden;border-radius:3px;box-shadow:var(--shadow);border:1px solid rgba(0,0,0,.06)}
.hero-img .frame img{width:100%;height:100%;object-fit:cover}
.hero-img .badge{position:absolute;left:-26px;bottom:38px;background:#fff;padding:18px 24px;border-radius:3px;box-shadow:var(--shadow);border-top:3px solid var(--brass);max-width:215px}
.hero-img .badge .st{font-family:var(--serif);font-size:30px;font-weight:600;color:var(--green);line-height:1}
.hero-img .badge .lb{font-size:12px;color:var(--muted);letter-spacing:.04em}

/* trust strip */
.strip{background:var(--green-dk);color:#eef3ee}
.strip .wrap{display:flex;justify-content:space-around;flex-wrap:wrap;gap:20px;padding:24px 28px;text-align:center}
.strip .it{display:flex;align-items:center;gap:11px;font-size:14px;letter-spacing:.05em;font-weight:400}
.strip svg{width:22px;height:22px;fill:var(--brass-lt);flex:none}

/* section heading */
.sec{padding:104px 0}
.sec-head{text-align:center;max-width:680px;margin:0 auto 56px}
.sec-head .eyebrow{margin-bottom:16px;display:inline-block}
.sec-head h2{font-size:clamp(32px,4.2vw,48px);color:var(--ink)}
.sec-head h2 em{font-style:italic;color:var(--green)}
.sec-head p{color:var(--muted);font-size:17px;margin-top:16px}

/* services */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.card{background:#fff;border:1px solid var(--line);border-radius:3px;overflow:hidden;transition:.3s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.card .ph{height:230px;overflow:hidden}
.card .ph img{width:100%;height:100%;object-fit:cover;transition:.6s}
.card:hover .ph img{transform:scale(1.06)}
.card .bd{padding:26px 26px 30px}
.card h3{font-size:25px;color:var(--green-dk);margin-bottom:9px}
.card p{font-size:14.5px;color:var(--muted);margin-bottom:18px}
.card .link-arrow{margin-top:auto}

/* feature band */
.feature{background:var(--cream)}
.feature .wrap{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.feature.alt .wrap{direction:rtl}
.feature.alt .wrap>*{direction:ltr}
.feature-img{aspect-ratio:5/5.6;overflow:hidden;border-radius:3px;box-shadow:var(--shadow);position:relative}
.feature-img img{width:100%;height:100%;object-fit:cover}
.feature-tx h2{font-size:clamp(30px,3.6vw,44px);color:var(--ink);margin:14px 0 18px}
.feature-tx h2 em{font-style:italic;color:var(--green)}
.feature-tx p{color:var(--muted);font-size:16px;margin-bottom:22px}
.feat-list{list-style:none;margin-bottom:30px}
.feat-list li{display:flex;gap:13px;padding:11px 0;border-bottom:1px solid var(--line);font-size:15px;color:var(--ink)}
.feat-list li:last-child{border-bottom:0}
.feat-list svg{width:19px;height:19px;fill:var(--green);flex:none;margin-top:3px}

/* glass options */
.glass{background:var(--paper)}
.glass-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:16px}
.swatch{text-align:center}
.swatch .sw{aspect-ratio:1;border-radius:3px;overflow:hidden;border:1px solid var(--line);box-shadow:0 8px 20px -16px rgba(0,0,0,.5);transition:.3s}
.swatch:hover .sw{transform:translateY(-4px);box-shadow:var(--shadow)}
.swatch .sw img{width:100%;height:100%;object-fit:cover}
.swatch .nm{font-size:13px;font-weight:500;margin-top:11px;letter-spacing:.04em;color:var(--ink)}
.swatch .ds{font-size:11px;color:var(--muted)}

/* gallery */
.gallery{background:var(--green-darker);color:#eef3ee}
.gallery .sec-head h2{color:#fff}
.gallery .sec-head h2 em{color:var(--sage)}
.gallery .sec-head p{color:#b9c6ba}
.gallery .eyebrow{color:var(--brass-lt)}
.masonry{column-count:3;column-gap:16px}
.masonry .gi{break-inside:avoid;margin-bottom:16px;border-radius:3px;overflow:hidden;cursor:pointer;position:relative}
.masonry .gi img{width:100%;transition:.5s}
.masonry .gi::after{content:"+";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:40px;color:#fff;background:rgba(18,40,30,.4);opacity:0;transition:.3s}
.masonry .gi:hover::after{opacity:1}
.masonry .gi:hover img{transform:scale(1.05)}
.gallery .more{text-align:center;margin-top:46px}

/* process */
.process .steps{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:10px}
.step{text-align:center;padding:0 14px}
.step .no{font-family:var(--serif);font-size:54px;font-weight:500;color:var(--sage);line-height:1}
.step h3{font-size:23px;color:var(--green-dk);margin:10px 0 10px}
.step p{font-size:14.5px;color:var(--muted)}
.values{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:74px;border-top:1px solid var(--line);padding-top:54px}
.value svg{width:30px;height:30px;fill:var(--brass);margin-bottom:14px}
.value h4{font-family:var(--serif);font-size:21px;font-weight:600;color:var(--ink);margin-bottom:6px}
.value p{font-size:13.5px;color:var(--muted)}

/* area */
.area{background:var(--green);color:#eaf1ea}
.area .wrap{display:grid;grid-template-columns:.9fr 1.1fr;gap:60px;align-items:center}
.area .eyebrow{color:var(--brass-lt)}
.area h2{font-size:clamp(30px,3.6vw,44px);color:#fff;margin:14px 0 18px}
.area h2 em{font-style:italic;color:var(--sage)}
.area p{color:#cfe0d2;font-size:16px;margin-bottom:18px}
.towns{display:flex;flex-wrap:wrap;gap:9px}
.towns span{font-size:13px;border:1px solid rgba(255,255,255,.28);padding:7px 14px;border-radius:99px;letter-spacing:.03em;transition:.25s}
.towns span:hover{background:rgba(255,255,255,.12)}

/* testimonials */
.tnt{background:var(--cream)}
.tgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.quote{background:#fff;border:1px solid var(--line);border-radius:3px;padding:34px 30px;display:flex;flex-direction:column}
.quote .stars{color:var(--brass);letter-spacing:3px;margin-bottom:16px;font-size:15px}
.quote p{font-family:var(--serif);font-size:21px;font-style:italic;line-height:1.4;color:var(--ink);margin-bottom:20px}
.quote .who{font-size:13px;font-weight:600;letter-spacing:.05em;color:var(--green-dk);margin-top:auto}
.quote .who span{display:block;font-weight:400;color:var(--muted);letter-spacing:.03em}

/* cta band */
.ctaband{background:var(--green-dk);color:#fff;text-align:center}
.ctaband .wrap{padding:78px 28px}
.ctaband h2{font-size:clamp(32px,4.4vw,52px);margin-bottom:18px}
.ctaband h2 em{font-style:italic;color:var(--sage)}
.ctaband p{color:#c5d4c7;font-size:17px;margin-bottom:32px}
.ctaband .row{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;align-items:center}
.ctaband .ph{font-family:var(--serif);font-size:30px;color:#fff;font-weight:600}

/* contact */
.contact .wrap{display:grid;grid-template-columns:1fr 1.15fr;gap:64px}
.contact h2{font-size:clamp(30px,3.6vw,44px);color:var(--ink);margin:14px 0 18px}
.contact h2 em{font-style:italic;color:var(--green)}
.contact .lede{color:var(--muted);font-size:16px;margin-bottom:30px}
.cinfo{list-style:none}
.cinfo li{display:flex;gap:15px;padding:16px 0;border-bottom:1px solid var(--line);align-items:flex-start}
.cinfo svg{width:22px;height:22px;fill:var(--green);flex:none;margin-top:3px}
.cinfo .l{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.cinfo .v{font-size:16px;color:var(--ink);font-weight:500}
form{background:var(--cream);padding:38px;border-radius:3px;border:1px solid var(--line)}
form h3{font-size:25px;color:var(--green-dk);margin-bottom:6px}
form .fnote{font-size:13px;color:var(--muted);margin-bottom:24px}
.field{margin-bottom:16px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:16px}
label{display:block;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:7px;font-weight:500}
input,select,textarea{width:100%;padding:13px 15px;border:1px solid var(--line);border-radius:2px;font-family:var(--sans);font-size:15px;background:#fff;color:var(--ink);transition:.2s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(29,90,57,.1)}
textarea{resize:vertical;min-height:96px}
form .btn{width:100%;justify-content:center;margin-top:6px}

/* footer */
footer{background:var(--green-darker);color:#aebcae;font-size:14px}
.fmain{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px;padding:72px 0 50px}
.fbrand .blk{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.fbrand img{width:48px;height:48px}
.fbrand .nm{font-family:var(--serif);font-size:23px;color:#fff;letter-spacing:.06em}
.fbrand .sb{font-size:9px;letter-spacing:.32em;color:var(--sage);text-transform:uppercase}
.fbrand p{max-width:30ex;color:#9fb0a1;font-size:14px}
footer h5{font-family:var(--sans);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:#fff;margin-bottom:18px;font-weight:600}
footer ul{list-style:none}
footer ul li{margin-bottom:11px}
footer ul a:hover{color:#fff}
.fcontact div{margin-bottom:14px;line-height:1.5}
.fcontact b{color:#fff;font-weight:500}
.fbot{border-top:1px solid rgba(255,255,255,.1);padding:22px 0;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:12.5px;color:#8a9a8c}
.fbot a:hover{color:#fff}

/* lightbox */
.lb{position:fixed;inset:0;background:rgba(10,22,15,.94);z-index:200;display:none;align-items:center;justify-content:center;padding:40px}
.lb.open{display:flex}
.lb img{max-width:92vw;max-height:90vh;border-radius:3px;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.lb .x{position:absolute;top:24px;right:30px;font-size:40px;color:#fff;cursor:pointer;font-family:var(--serif);line-height:1}

/* responsive */
@media(max-width:960px){
  .menu,.nav-phone,.nav-cta .btn{display:none}
  .burger{display:flex}
  .menu.open .menu-cta{display:block}
  .menu.open .menu-cta a{color:var(--green);font-weight:600}
  .hero .wrap{grid-template-columns:1fr;gap:44px;padding-top:50px}
  .hero-img{max-width:440px;margin:0 auto}
  .feature .wrap,.contact .wrap,.area .wrap{grid-template-columns:1fr;gap:40px}
  .feature.alt .wrap{direction:ltr}
  .svc-grid,.tgrid,.process .steps{grid-template-columns:1fr 1fr;gap:18px}
  .glass-grid{grid-template-columns:repeat(4,1fr)}
  .values{grid-template-columns:1fr 1fr;gap:30px}
  .masonry{column-count:2}
  .fmain{grid-template-columns:1fr 1fr;gap:32px}
  .menu.open{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;background:var(--paper);padding:20px 28px;gap:6px;border-bottom:1px solid var(--line);box-shadow:var(--shadow)}
  .menu.open a{padding:11px 0;border-bottom:1px solid var(--line)}
}
@media(max-width:560px){
  .wrap{padding:0 20px}
  .sec{padding:68px 0}
  .svc-grid,.tgrid{grid-template-columns:1fr}
  .glass-grid{grid-template-columns:repeat(3,1fr)}
  .values,.fmain{grid-template-columns:1fr}
  .masonry{column-count:1}
  .frow{grid-template-columns:1fr}
  .hero-img .badge{left:0}
  .topbar .tb-l{display:none}
}

/* ===== enhancements ===== */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s cubic-bezier(.2,.6,.2,1),transform .8s cubic-bezier(.2,.6,.2,1)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1!important;transform:none!important;transition:none!important}}

/* stats credibility band */
.stats{background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.stats .wrap{display:grid;grid-template-columns:repeat(4,1fr);padding:56px 28px;text-align:center}
.stat{padding:0 20px}
.stat+.stat{border-left:1px solid var(--line)}
.stat .n{font-family:var(--serif);font-size:clamp(40px,4.6vw,58px);font-weight:600;color:var(--green);line-height:1}
.stat .n .suf{color:var(--brass)}
.stat .l{font-size:12.5px;letter-spacing:.08em;color:var(--muted);margin-top:10px;text-transform:uppercase}

/* hardware finishes */
/* hardware finishes */
.feat-finishes{font-size:14.5px;color:var(--muted);margin:2px 0 26px;line-height:1.5}
.feat-finishes a{color:var(--green);font-weight:600;border-bottom:1px solid var(--brass)}
.feat-finishes a:hover{color:var(--green-dk)}
.finishes-sec{background:var(--cream)}
.finish-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:32px 18px;max-width:940px;margin:0 auto}
.finish{text-align:center}
.fdisc{display:block;width:76px;height:76px;border-radius:50%;margin:0 auto 13px;border:1px solid rgba(0,0,0,.1);box-shadow:0 9px 18px -9px rgba(0,0,0,.5)}
.finish .fn{font-size:13.5px;font-weight:500;color:var(--ink);line-height:1.25}
.finish .fc{font-size:11px;color:var(--muted);margin-top:3px;letter-spacing:.1em}
.finish-note{text-align:center;font-size:13px;color:var(--muted);margin:46px auto 0;max-width:640px;font-style:italic}
.finish-note a{color:var(--green);font-weight:600;font-style:normal}
@media(max-width:760px){.finish-grid{grid-template-columns:repeat(4,1fr);gap:26px 14px}}
@media(max-width:520px){.finish-grid{grid-template-columns:repeat(3,1fr)}}
.f-ch{background:radial-gradient(circle at 38% 30%,#ffffff,#cdd3d8 48%,#5f676d 93%)}
.f-sc{background:radial-gradient(circle at 41% 35%,#e8eaec,#c4c8cb 56%,#9a9ea1 96%)}
.f-bsc{background:radial-gradient(circle at 39% 33%,#eef0f1,#c6cacd 53%,#8e9295 94%)}
.f-ps{background:radial-gradient(circle at 37% 29%,#f8fbfc,#cfd6db 47%,#6c757c 92%)}
.f-bs{background:radial-gradient(circle at 40% 34%,#e9eced,#c3c8cc 54%,#868d92 95%)}
.f-pn{background:radial-gradient(circle at 38% 30%,#fbf9f3,#d6d1c4 49%,#7f7a6c 92%)}
.f-sn{background:radial-gradient(circle at 41% 35%,#ece9e1,#ccc7ba 57%,#948f81 96%)}
.f-bn{background:radial-gradient(circle at 39% 33%,#e7e3d9,#c6c1b4 54%,#8a8578 95%)}
.f-abn{background:radial-gradient(circle at 40% 34%,#d6d0c2,#aaa493 56%,#6c6658 96%)}
.f-bb{background:radial-gradient(circle at 39% 32%,#d8c0a0,#a8825a 53%,#6f5234 94%)}
.f-pb{background:radial-gradient(circle at 37% 29%,#f9ecb8,#ddb759 47%,#997d2c 92%)}
.f-sb{background:radial-gradient(circle at 41% 34%,#ecdca8,#c8ac61 55%,#8c722f 95%)}
.f-ub{background:radial-gradient(circle at 38% 31%,#f0dd9c,#d0a648 50%,#946d22 93%)}
.f-orb{background:radial-gradient(circle at 41% 33%,#7a6552,#3d2e21 56%,#1c140d 96%)}
.f-mb{background:radial-gradient(circle at 43% 37%,#4d4d4d,#232323 56%,#0f0f0f 96%)}

/* google rating badge */
.gbadge{display:inline-flex;align-items:center;gap:11px;background:#fff;border:1px solid var(--line);border-radius:99px;padding:9px 20px;margin-top:20px;box-shadow:var(--shadow)}
.gbadge .g{font-family:var(--sans);font-weight:700;font-size:15px;letter-spacing:.01em;color:var(--ink)}
.gbadge .g b:nth-child(1){color:#4285F4}.gbadge .g b:nth-child(2){color:#EA4335}.gbadge .g b:nth-child(3){color:#FBBC05}.gbadge .g b:nth-child(4){color:#4285F4}.gbadge .g b:nth-child(5){color:#34A853}.gbadge .g b:nth-child(6){color:#EA4335}
.gbadge .rt{font-family:var(--serif);font-weight:600;font-size:18px;color:var(--ink)}
.gbadge .stars{color:#f5b731;letter-spacing:1px;font-size:14px}
.gbadge small{color:var(--muted);font-size:12px}

/* FAQ */
.faq{background:var(--cream)}
.faq-list{max-width:840px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;background:none;border:0;text-align:left;font-family:var(--serif);font-size:clamp(20px,2.4vw,24px);color:var(--ink);padding:24px 46px 24px 0;cursor:pointer;position:relative;line-height:1.25;transition:color .2s}
.faq-q:hover{color:var(--green)}
.faq-q::after{content:"+";position:absolute;right:4px;top:50%;transform:translateY(-50%);font-family:var(--sans);font-size:28px;font-weight:300;color:var(--brass);transition:transform .3s}
.faq-item.open .faq-q::after{content:"\2212"}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-a p{padding:0 46px 26px 0;color:var(--muted);font-size:15.5px;margin:0}

/* contact locations */
.locations{display:grid;gap:18px;margin:8px 0 22px}
.loc{background:#fff;border:1px solid var(--line);border-radius:3px;padding:22px 24px;border-top:3px solid var(--green)}
.loc.main{border-top-color:var(--brass)}
.loc .tag{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--brass);font-weight:600;margin-bottom:5px}
.loc h3{font-family:var(--serif);font-size:23px;color:var(--green-dk);margin-bottom:12px;line-height:1}
.loc .row{display:flex;gap:11px;align-items:flex-start;padding:6px 0;font-size:14.5px;color:var(--ink);line-height:1.45}
.loc .row svg{width:17px;height:17px;fill:var(--green);flex:none;margin-top:3px}
.loc .row a{color:var(--green-dk);font-weight:600}
.loc .row a:hover{color:var(--green)}
.loc-map{margin-top:15px;border-radius:3px;overflow:hidden;border:1px solid var(--line);aspect-ratio:16/7}
.loc-map iframe{width:100%;height:100%;border:0;display:block;filter:grayscale(.12) contrast(1.03)}
/* service-areas hub directory */
.area-cols{display:grid;grid-template-columns:1fr 1fr;gap:44px;margin-top:8px}
.area-col h3{font-family:var(--serif);font-size:26px;color:var(--green-dk);margin-bottom:6px;line-height:1.1}
.area-col .ac-sub{font-size:13.5px;color:var(--muted);margin-bottom:20px}
.area-links{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.area-links a{display:flex;align-items:center;gap:9px;padding:13px 16px;background:#fff;border:1px solid var(--line);border-radius:3px;font-size:14.5px;font-weight:500;color:var(--ink);transition:.2s}
.area-links a:hover{border-color:var(--green);color:var(--green);transform:translateY(-2px);box-shadow:var(--shadow)}
.area-links a svg{width:14px;height:14px;fill:var(--brass);flex:none}
.area-links a.is-showroom{border-left:3px solid var(--brass)}
@media(max-width:820px){.area-cols{grid-template-columns:1fr;gap:34px}}
@media(max-width:440px){.area-links{grid-template-columns:1fr}}
.cmail{display:inline-flex;align-items:center;gap:10px;font-size:15px;color:var(--ink)}
.cmail svg{width:18px;height:18px;fill:var(--green);flex:none}
.cmail a:hover{color:var(--green)}
.fcontact a:hover{color:#fff}
.floc{margin-bottom:16px}
/* fast quote from owner */
.fastquote{background:var(--green-dk);color:#eaf1ea;border-radius:4px;padding:28px 30px;margin-bottom:26px;border-top:3px solid var(--brass)}
.fastquote .fq-badge{display:inline-flex;align-items:center;gap:7px;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--brass-lt);font-weight:600;margin-bottom:11px}
.fastquote .fq-badge svg{width:14px;height:14px;fill:var(--brass-lt)}
.fastquote h3{font-family:var(--serif);font-size:26px;color:#fff;margin-bottom:9px;line-height:1.12}
.fastquote p{font-size:14.5px;color:#c6d5c8;margin-bottom:15px}
.fq-list{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:9px 18px;margin-bottom:22px}
.fq-list li{font-size:13.5px;color:#eaf1ea;display:flex;gap:9px;align-items:center}
.fq-list li::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--brass-lt);flex:none}
.fastquote .btn{width:100%;justify-content:center}
@media(max-width:520px){.fq-list{grid-template-columns:1fr}}
/* shower enclosure styles strip */
.styles-sec{background:var(--paper)}
.style-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.style{display:block;position:relative;border-radius:3px;overflow:hidden;text-decoration:none;border:1px solid var(--line);box-shadow:0 12px 26px -18px rgba(18,40,30,.5)}
.style .ph{aspect-ratio:4/3.6;overflow:hidden;background:#000}
.style .ph img{width:100%;height:100%;object-fit:cover;transition:.55s}
.style:hover .ph img{transform:scale(1.06)}
.style .sl{position:absolute;left:0;right:0;bottom:0;padding:30px 16px 13px;color:#fff;font-weight:500;font-size:14.5px;letter-spacing:.02em;background:linear-gradient(to top,rgba(12,30,20,.85),rgba(12,30,20,.28) 62%,transparent)}
.style .sl small{display:block;font-weight:400;font-size:11.5px;color:#cdd8cd;letter-spacing:.04em;margin-top:1px}
@media(max-width:760px){.style-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:520px){.style-grid{grid-template-columns:repeat(2,1fr)}}

/* sticky mobile action bar */
.mbar{display:none}

@media(max-width:760px){
  .stats .wrap{grid-template-columns:1fr 1fr;gap:38px 0;padding:46px 28px}
  .stat:nth-child(2n+1){border-left:0}
  .mbar{display:grid;grid-template-columns:1.4fr 1fr 1fr;position:fixed;left:0;right:0;bottom:0;z-index:60;box-shadow:0 -6px 22px rgba(0,0,0,.24)}
  .mbar a{padding:15px 6px;text-align:center;font-weight:600;font-size:13px;letter-spacing:.03em;color:#fff;display:flex;align-items:center;justify-content:center;gap:7px}
  .mbar a svg{width:17px;height:17px;fill:currentColor}
  .mbar .m-text{background:var(--brass);font-size:15px;font-weight:700;letter-spacing:.04em}
  .mbar .m-call{background:var(--green-dk)}
  .mbar .m-quote{background:var(--green)}
  body{padding-bottom:56px}
}

/* ===== breadcrumbs ===== */
.crumbs{font-size:13px;color:var(--muted);letter-spacing:.02em}
.crumbs .wrap{padding-top:18px;padding-bottom:0}
.crumbs a{color:var(--green);font-weight:500}
.crumbs a:hover{color:var(--green-dk);text-decoration:underline}
.crumbs i{font-style:normal;color:var(--sage);margin:0 9px}

/* ===== guide / article ===== */
.guide-hero{background:linear-gradient(180deg,var(--paper),var(--cream))}
.guide-hero .wrap{padding-top:34px;padding-bottom:56px}
.guide-hero .eyebrow{display:inline-block;margin-bottom:15px}
.guide-hero h1{font-size:clamp(32px,4.6vw,54px);color:var(--ink);line-height:1.05;max-width:18ch}
.guide-hero h1 em{font-style:italic;color:var(--green)}
.guide-hero .lede{font-size:18px;color:var(--muted);max-width:62ch;margin-top:18px}
.guide-meta{font-size:12.5px;color:var(--muted);margin-top:20px;letter-spacing:.04em;text-transform:uppercase}
.guide-meta b{color:var(--green-dk);font-weight:600}
.article{max-width:772px;margin:0 auto}
.article>p:first-of-type{font-size:18px;color:var(--ink)}
.article h2{font-family:var(--serif);font-weight:600;font-size:clamp(26px,3vw,34px);color:var(--green-dk);margin:46px 0 14px;line-height:1.12}
.article h3{font-family:var(--serif);font-weight:600;font-size:23px;color:var(--ink);margin:32px 0 10px}
.article p{font-size:16.5px;color:var(--ink);margin-bottom:18px;line-height:1.72}
.article ul,.article ol{margin:0 0 20px 4px;padding-left:22px}
.article li{font-size:16.5px;color:var(--ink);margin-bottom:10px;line-height:1.62}
.article a{color:var(--green);font-weight:500;border-bottom:1px solid var(--brass)}
.article a:hover{color:var(--green-dk)}
.article strong{color:var(--ink);font-weight:600}
.article .callout{background:var(--cream);border-left:3px solid var(--brass);border-radius:0 3px 3px 0;padding:20px 24px;margin:28px 0}
.article .callout p{margin:0;font-size:15.5px;color:var(--ink)}
.article .callout b{color:var(--green-dk)}
.gtable{width:100%;border-collapse:collapse;margin:24px 0;font-size:15px}
.gtable th,.gtable td{text-align:left;padding:13px 15px;border-bottom:1px solid var(--line);vertical-align:top}
.gtable thead th{font-family:var(--sans);font-weight:600;color:#fff;background:var(--green-dk);font-size:12px;letter-spacing:.06em;text-transform:uppercase}
.gtable tbody tr:nth-child(even){background:var(--cream)}
.gtable td:first-child{font-weight:500;color:var(--green-dk)}
.article-cta{background:var(--green-dk);color:#eaf1ea;border-radius:4px;padding:32px 34px;margin:44px 0 0;text-align:center;border-top:3px solid var(--brass)}
.article-cta h3{font-family:var(--serif);font-weight:600;font-size:27px;color:#fff;margin-bottom:9px}
.article-cta p{color:#c6d5c8;margin-bottom:20px;font-size:15.5px}

/* ===== guide hub cards ===== */
.guide-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.gcard{background:#fff;border:1px solid var(--line);border-radius:3px;padding:32px 30px;transition:.3s;display:flex;flex-direction:column}
.gcard:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:transparent}
.gcard .tag{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--brass);font-weight:600;margin-bottom:11px}
.gcard h3{font-size:24px;color:var(--green-dk);margin-bottom:10px;line-height:1.16}
.gcard p{font-size:14.5px;color:var(--muted);margin-bottom:18px}
.gcard .link-arrow{margin-top:auto}
@media(max-width:760px){.guide-grid{grid-template-columns:1fr}}

/* ===== about page ===== */
.story{background:var(--paper)}
.story .wrap{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.story-img{aspect-ratio:5/5.4;overflow:hidden;border-radius:3px;box-shadow:var(--shadow);position:relative}
.story-img img{width:100%;height:100%;object-fit:cover}
.story-tx h2{font-size:clamp(30px,3.6vw,44px);color:var(--ink);margin:14px 0 18px}
.story-tx h2 em{font-style:italic;color:var(--green)}
.story-tx p{color:var(--muted);font-size:16px;margin-bottom:16px;line-height:1.7}
.about-stats{background:var(--green-dk);color:#fff}
.about-stats .wrap{display:grid;grid-template-columns:repeat(4,1fr);padding:54px 28px;text-align:center}
.about-stats .as{padding:0 18px}
.about-stats .as+.as{border-left:1px solid rgba(255,255,255,.16)}
.about-stats .n{font-family:var(--serif);font-size:clamp(38px,4.4vw,54px);font-weight:600;line-height:1;color:#fff}
.about-stats .n .suf{color:var(--brass-lt)}
.about-stats .l{font-size:12.5px;letter-spacing:.08em;color:#bcccbe;margin-top:10px;text-transform:uppercase}
@media(max-width:760px){
  .story .wrap{grid-template-columns:1fr;gap:36px}
  .about-stats .wrap{grid-template-columns:1fr 1fr;gap:36px 0}
  .about-stats .as:nth-child(2n+1){border-left:0}
}

/* ===== reviews page ===== */
.rev-hero{background:var(--green-dk);color:#fff;text-align:center}
.rev-hero .wrap{padding:64px 28px 56px}
.rev-hero .eyebrow{color:var(--brass-lt);display:inline-block;margin-bottom:14px}
.rev-hero h1{font-size:clamp(34px,4.6vw,54px);margin-bottom:8px}
.rev-hero h1 em{font-style:italic;color:var(--sage)}
.rev-grid{columns:3;column-gap:24px}
.rev-grid .quote{break-inside:avoid;margin-bottom:24px;display:block}
@media(max-width:900px){.rev-grid{columns:2}}
@media(max-width:600px){.rev-grid{columns:1}}

/* ===== local / service-area page ===== */
.locale-info{background:var(--cream)}
.locale-info .wrap{display:grid;grid-template-columns:1.02fr .98fr;gap:54px;align-items:center}
.locale-info .eyebrow{display:inline-block;margin-bottom:14px}
.locale-info h2{font-size:clamp(28px,3.4vw,40px);color:var(--ink);margin-bottom:16px;line-height:1.1}
.locale-info h2 em{font-style:italic;color:var(--green)}
.locale-info p{color:var(--muted);font-size:16px;margin-bottom:16px;line-height:1.7}
.locale-facts{list-style:none;margin:20px 0 26px}
.locale-facts li{display:flex;gap:13px;padding:12px 0;border-bottom:1px solid var(--line);font-size:15px;color:var(--ink);align-items:flex-start}
.locale-facts li:last-child{border-bottom:0}
.locale-facts svg{width:19px;height:19px;fill:var(--green);flex:none;margin-top:3px}
.locale-facts a{color:var(--green-dk);font-weight:600}
.locale-facts a:hover{color:var(--green)}
.locale-map{position:relative;aspect-ratio:1/1;border-radius:4px;overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line);background:linear-gradient(135deg,var(--sage-soft),var(--cream))}
.locale-map iframe{position:relative;z-index:1;width:100%;height:100%;border:0;display:block;filter:grayscale(.12) contrast(1.03)}
.locale-map .map-fallback{position:absolute;inset:0;z-index:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;text-align:center;color:var(--green-dk);padding:24px}
.locale-map .map-fallback svg{width:36px;height:36px;fill:var(--green)}
.locale-map .map-fallback b{font-family:var(--serif);font-size:20px}
.locale-map .map-fallback span{font-size:13px;color:var(--muted)}
@media(max-width:860px){.locale-info .wrap{grid-template-columns:1fr;gap:34px}.locale-map{aspect-ratio:4/3}}
/* local quick-fact chips */
.geo-strip{background:var(--green-darker);color:#dfe7df}
.geo-strip .wrap{display:flex;flex-wrap:wrap;justify-content:center;gap:14px 34px;padding:20px 28px;text-align:center;font-size:13.5px;letter-spacing:.03em}
.geo-strip b{color:#fff;font-weight:600}
.geo-strip span{display:inline-flex;align-items:center;gap:9px}
.geo-strip svg{width:15px;height:15px;fill:var(--brass-lt);flex:none}
/* showrooms-near-you cards */
.near-list{display:grid;gap:14px;margin:22px 0 24px}
.near{background:#fff;border:1px solid var(--line);border-radius:3px;padding:18px 20px;border-left:3px solid var(--sage)}
.near.closest{border-left-color:var(--brass)}
.near .nhead{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:7px}
.near h3{font-family:var(--serif);font-size:20px;color:var(--green-dk);line-height:1;margin:0}
.near .dist{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);background:var(--cream);padding:5px 11px;border-radius:99px;white-space:nowrap}
.near.closest .dist{color:#fff;background:var(--brass)}
.near .naddr{font-size:13.5px;color:var(--muted);margin-bottom:9px;line-height:1.45}
.near .nrow{display:flex;flex-wrap:wrap;gap:6px 16px;font-size:14px}
.near .nrow a{color:var(--green-dk);font-weight:600}
.near .nrow a:hover{color:var(--green)}
/* grouped service-area towns */
.town-cols{display:grid;gap:22px}
.town-group h4{font-family:var(--sans);font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--brass-lt);margin-bottom:12px;display:flex;align-items:center;gap:8px}
.town-group h4 svg{width:15px;height:15px;fill:var(--brass-lt);flex:none}
/* helpful guides block */
.guides-block{background:var(--paper)}
.guide-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.gcard{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:3px;padding:24px 22px;transition:.25s}
.gcard:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:transparent}
.gcard .gtag{font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--brass);margin-bottom:10px}
.gcard h3{font-family:var(--serif);font-size:19px;color:var(--green-dk);line-height:1.22;margin-bottom:14px}
.gcard .link-arrow{margin-top:auto}
@media(max-width:860px){.guide-cards{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.guide-cards{grid-template-columns:1fr}}
