/* ===== MDA MasterWood — V3 "Warm Premium" design system ===== */
:root{
 --ink:#2a2018;--ink2:#5d5043;--cream:#f3ece0;--cream2:#ece2d2;--paper:#fbf7f0;--card:#fff;
 --walnut:#5c4433;--terra:#bd6a3a;--terra-d:#a5572d;--forest:#3f5d45;--gold:#c79a4b;--line:#e6dccd;
 --serif:'Space Grotesk',-apple-system,system-ui,sans-serif;--sans:'Inter',-apple-system,system-ui,sans-serif;
 --radius:14px;--radius-lg:20px;--shadow:0 6px 20px rgba(42,32,24,.06);--shadow-lg:0 22px 50px rgba(42,32,24,.13);
 --ease:cubic-bezier(.22,.61,.36,1);--maxw:1220px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--sans);color:var(--ink);background:var(--paper);font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}a{color:inherit;text-decoration:none}li{list-style:none}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.16;color:var(--ink);letter-spacing:0}
h1{font-size:clamp(2.15rem,4.6vw,3.7rem);font-weight:500}h2{font-size:clamp(1.85rem,3.6vw,2.85rem)}h3{font-size:1.36rem}
p{color:var(--ink2)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 30px}
.sec{padding:clamp(60px,8vw,104px) 0}.sec-t{padding:clamp(40px,5vw,64px) 0}
.bg-cream{background:var(--cream)}.bg-cream2{background:var(--cream2)}
.center{text-align:center}
.ey{font-weight:700;letter-spacing:.16em;text-transform:uppercase;font-size:.74rem;color:var(--terra)}
.lead{font-size:1.12rem;color:var(--ink2);max-width:60ch}.center .lead{margin-inline:auto}
.shead{max-width:660px;margin-bottom:46px}.center.shead{margin:0 auto 46px}.shead .ey{display:block;margin-bottom:14px}.shead p{margin-top:12px}
/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;font-weight:600;font-size:.96rem;padding:15px 30px;border-radius:50px;cursor:pointer;border:2px solid transparent;transition:.22s var(--ease)}
.btn-p{background:var(--terra);color:#fff}.btn-p:hover{background:var(--terra-d);transform:translateY(-2px);box-shadow:0 12px 28px rgba(189,106,58,.3)}
.btn-o{background:transparent;color:var(--ink);border-color:var(--ink)}.btn-o:hover{background:var(--ink);color:#fff}
.btn-w{background:#fff;color:var(--ink)}.btn-w:hover{background:var(--terra);color:#fff}
.btn-lg{padding:18px 38px}.btn-block{width:100%}
/* header */
.top{background:var(--forest);color:#eef3ee;text-align:center;font-size:.78rem;font-weight:500;padding:9px;letter-spacing:.02em}.top b{color:#fff}
.header{position:sticky;top:0;z-index:50;background:rgba(251,247,240,.93);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:78px}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--serif);font-weight:700;font-size:1.42rem;color:var(--ink)}
.brand svg,.brand img{width:46px;height:46px}
.brand small{display:block;font-family:var(--sans);font-weight:600;font-size:.58rem;letter-spacing:.14em;text-transform:uppercase;color:var(--terra)}
.menu{display:flex;gap:24px}.menu a{font-weight:600;font-size:.92rem;white-space:nowrap}.menu a:hover{color:var(--terra)}
.navr{display:flex;align-items:center;gap:12px}
.navr .phone{display:inline-flex;align-items:center;gap:6px;font-weight:600;font-size:.96rem;white-space:nowrap;padding:15px 22px;border:2px solid var(--line);border-radius:50px;color:var(--ink);transition:.22s var(--ease)}
.navr .phone:hover{border-color:var(--terra);color:var(--terra)}
.burger{display:none;flex-direction:column;gap:5px;background:0;border:0;cursor:pointer;padding:6px}.burger span{width:26px;height:2px;background:var(--ink);border-radius:2px}
/* hero with form */
.hero{position:relative;color:#fff;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}.hero-bg img{width:100%;height:100%;object-fit:cover}
.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(105deg,rgba(28,21,15,.9) 30%,rgba(28,21,15,.55) 60%,rgba(28,21,15,.35))}
.hero-in{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;padding:clamp(44px,6vw,84px) 0}
.hero-c .pill{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);padding:7px 15px;border-radius:30px;font-size:.82rem;font-weight:600;margin-bottom:22px;backdrop-filter:blur(4px)}
.hero-c .pill .st{color:var(--gold)}
.hero-c h1{color:#fff}.hero-c h1 em{font-style:italic;color:#e8b06a;font-weight:500}
.hero-c p{color:rgba(247,243,236,.85);font-size:1.15rem;max-width:46ch;margin:20px 0 26px}
.hero-c .trust{display:flex;gap:20px;flex-wrap:wrap;font-size:.88rem;color:rgba(247,243,236,.85)}.hero-c .trust b{color:#fff}
/* hero form card */
.lead-card{background:var(--paper);color:var(--ink);border-radius:var(--radius-lg);padding:30px;box-shadow:0 26px 60px rgba(0,0,0,.35)}
.lead-card h3{font-size:1.5rem;margin-bottom:4px}.lead-card .sub{font-size:.9rem;color:var(--ink2);margin-bottom:18px}
.fr{margin-bottom:13px}.fr label{display:block;font-size:.8rem;font-weight:600;margin-bottom:5px}
.fr input,.fr select,.fr textarea{width:100%;padding:13px 14px;border:1.5px solid var(--line);border-radius:10px;background:#fff;font-family:inherit;font-size:1rem;color:var(--ink)}
.fr input:focus,.fr select:focus,.fr textarea:focus{outline:0;border-color:var(--terra);box-shadow:0 0 0 3px rgba(189,106,58,.14)}
.form-note{font-size:.78rem;color:var(--ink2);margin-top:10px;text-align:center}
.form-msg{margin-top:12px;padding:12px;border-radius:10px;font-weight:600;font-size:.9rem;display:none}
.form-msg.ok{display:block;background:#e7f0e8;color:var(--forest)}.form-msg.err{display:block;background:#f6e3e0;color:#9b3b2c}
/* trust strip */
.tstrip{background:var(--walnut);color:#f3ece0}
.tstrip .wrap{display:flex;flex-wrap:wrap;justify-content:space-around;gap:16px;padding:22px 30px;text-align:center}
.tstrip .n{font-family:var(--serif);font-size:1.8rem;font-weight:700;color:#fff}.tstrip .l{font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;color:rgba(243,236,224,.75)}
/* category group + subcategory tiles */
.cgroup{margin-bottom:56px}
.cgroup-h{display:flex;align-items:baseline;justify-content:space-between;gap:16px;border-bottom:2px solid var(--line);padding-bottom:14px;margin-bottom:24px;flex-wrap:wrap}
.cgroup-h h3{font-size:1.9rem}.cgroup-h .meta{font-weight:700;color:var(--terra);font-size:.92rem}
.cgroup-h a{font-weight:600;font-size:.86rem;color:var(--ink)}.cgroup-h a:hover{color:var(--terra)}
.tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:16px}
.tile{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:1;display:block;background:var(--cream2);box-shadow:var(--shadow);transition:.28s var(--ease)}
.tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:.5s var(--ease)}
.tile::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 22%,rgba(26,18,12,.5) 55%,rgba(26,18,12,.92))}
.tile .lab{position:absolute;left:14px;right:14px;bottom:13px;z-index:1;color:#fff}
.tile .lab b{display:block;font-family:var(--serif);font-size:1.04rem;font-weight:600;line-height:1.12}
.tile .lab span{font-size:.76rem;color:rgba(255,255,255,.82)}
.tile:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.tile:hover img{transform:scale(1.07)}
/* cards (services) */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow);transition:.28s var(--ease)}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.card-i{position:relative;aspect-ratio:4/3;overflow:hidden}.card-i img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:.6s}.card:hover .card-i img{transform:scale(1.05)}
.card-b{padding:24px;display:flex;flex-direction:column;flex:1}.card-b h3{margin-bottom:8px}.card-b .pr{font-weight:700;color:var(--terra);font-size:.9rem;margin-bottom:10px}.card-b p{font-size:.96rem;margin-bottom:16px}.card-b .lnk{margin-top:auto;font-weight:700;font-size:.88rem}.card:hover .lnk{color:var(--terra)}
/* split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.split .im{position:relative;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:1;box-shadow:var(--shadow-lg)}.split .im img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.split video{width:100%;max-height:440px;object-fit:cover;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:block;background:#000}
@media(max-width:680px){.split video{max-height:300px}}
.offer-badge{display:inline-block;background:var(--forest);color:#fff;font-weight:700;padding:7px 16px;border-radius:30px;font-size:.82rem;margin-bottom:14px;letter-spacing:.02em}
.chk li{display:flex;gap:12px;margin-bottom:12px;color:var(--ink2)}.chk li::before{content:"✓";width:24px;height:24px;flex:none;background:var(--forest);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700}
/* features */
.feat{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.feat .f{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:28px}
.feat .ic{width:48px;height:48px;border-radius:12px;background:rgba(189,106,58,.12);color:var(--terra);display:flex;align-items:center;justify-content:center;margin-bottom:15px}
.feat h3{font-size:1.18rem;margin-bottom:8px}.feat p{font-size:.95rem}
/* gallery */
.gal{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.gal .g{border-radius:var(--radius);overflow:hidden}.gal .g img{display:block;width:100%;height:240px;object-fit:cover;transition:.5s}.gal .g:hover img{transform:scale(1.06)}
/* reviews */
.revs{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.rev{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:28px;box-shadow:var(--shadow)}.rev .st{color:var(--gold);letter-spacing:2px;margin-bottom:12px}.rev p{font-size:1.04rem;margin-bottom:14px;color:var(--ink)}.rev .who{font-weight:700;font-size:.88rem}.rev .who small{display:block;font-weight:400;color:var(--ink2);font-size:.78rem}
/* blog */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.post{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow);transition:.28s var(--ease)}
.post:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.post-i{aspect-ratio:16/10;overflow:hidden}.post-i img{width:100%;height:100%;object-fit:cover;transition:.5s}.post:hover .post-i img{transform:scale(1.05)}
.post-b{padding:22px;display:flex;flex-direction:column;flex:1}.post-b .tag{font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--terra);margin-bottom:8px}
.post-b h3{font-size:1.22rem;margin-bottom:8px}.post-b p{font-size:.93rem;margin-bottom:14px}.post-b .lnk{margin-top:auto;font-weight:700;font-size:.86rem}.post:hover .lnk{color:var(--terra)}
/* faq */
.faq{max-width:820px;margin-inline:auto}
.faq details{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);margin-bottom:12px;overflow:hidden}
.faq summary{cursor:pointer;padding:18px 22px;font-weight:700;list-style:none;display:flex;justify-content:space-between;gap:14px;align-items:center}
.faq summary::-webkit-details-marker{display:none}.faq summary::after{content:"+";font-size:1.5rem;color:var(--terra);transition:.2s}.faq details[open] summary::after{transform:rotate(45deg)}
.faq .a{padding:0 22px 20px;color:var(--ink2)}
/* areas */
.areas{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}.areas span{background:var(--card);border:1px solid var(--line);padding:9px 16px;border-radius:30px;font-weight:600;font-size:.88rem}
/* cta band */
.ctaband{background:var(--cream2);border-radius:var(--radius-lg);padding:clamp(34px,5vw,58px);text-align:center}
.ctaband h2{margin-bottom:12px}.ctaband p{max-width:52ch;margin:0 auto 22px}.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
/* crumb */
.crumb{font-size:.84rem;color:var(--ink2);padding:16px 0}.crumb a:hover{color:var(--terra)}.crumb span{color:var(--terra)}
/* footer */
.footer{background:#241b14;color:rgba(243,236,224,.66);padding:62px 0 26px;font-size:.9rem}
.fg{display:grid;grid-template-columns:2fr 1fr 1fr 1.2fr;gap:36px;margin-bottom:38px}
.footer h4{color:#fff;font-family:var(--sans);font-size:.76rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:14px}
.footer a:hover{color:var(--terra)}.footer li{margin-bottom:8px}.footer .brand{color:#fff;margin-bottom:12px}
.fb{border-top:1px solid rgba(255,255,255,.12);padding-top:20px;font-size:.8rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}
/* mobile bar */
.mbar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:60;background:#fff;border-top:1px solid var(--line);padding:10px;gap:10px;box-shadow:0 -6px 20px rgba(0,0,0,.08)}.mbar .btn{flex:1;padding:13px}
/* reveal */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s var(--ease),transform .6s var(--ease)}.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}html{scroll-behavior:auto}}
/* responsive */
.nav{gap:16px}.brand{flex:0 0 auto}
@media(max-width:1300px){.menu{gap:15px}.menu a{font-size:.86rem}.brand{font-size:1.25rem}.navr{gap:10px}.navr .phone{padding:12px 16px;font-size:.9rem}.navr .btn{padding:12px 20px}}
@media(max-width:1120px){
 /* collapse nav to burger before long labels overflow */
 .menu,.navr .btn,.navr .phone{display:none}
 .burger{display:flex}
 .menu.open{display:flex;position:absolute;top:78px;left:0;right:0;flex-direction:column;background:var(--paper);padding:20px 30px;gap:16px;border-bottom:1px solid var(--line);box-shadow:var(--shadow);z-index:60}
}
@media(max-width:960px){
 .hero-in,.split{grid-template-columns:1fr;gap:28px}
 .cards,.feat,.revs,.blog-grid{grid-template-columns:1fr 1fr}
 .gal{grid-template-columns:1fr 1fr}
 .fg{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
 body{font-size:16px}
 .cards,.feat,.revs,.blog-grid,.gal{grid-template-columns:1fr}
 .tiles{grid-template-columns:1fr 1fr}
 .fg{grid-template-columns:1fr}
 .mbar{display:flex}.footer{padding-bottom:84px}
 .split video{max-height:300px}
}

@media(min-width:681px){.tiles.tiles-center{grid-template-columns:repeat(auto-fill,minmax(190px,210px));justify-content:center}}

.promo{background:var(--terra);color:#fff;text-align:center;font-size:.82rem;font-weight:600;padding:8px 12px;letter-spacing:.02em}.promo b{font-weight:800}.promo a{color:#fff;text-decoration:underline}

/* blog / article */
.article{max-width:780px;margin:0 auto;padding:0 30px}
.article-head{padding:34px 0 8px}
.article-head .tag{font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--terra)}
.article h1{font-size:clamp(1.9rem,4vw,2.7rem);margin:10px 0 10px;line-height:1.12}
.article .meta{color:var(--ink2);font-size:.9rem;margin-bottom:18px}
.article-hero{position:relative;border-radius:var(--radius-lg);overflow:hidden;margin:6px 0 26px;aspect-ratio:16/9}
.article-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.prose{font-size:1.06rem;line-height:1.75;color:var(--ink)}
.prose p{margin-bottom:16px;color:var(--ink2)}
.prose h2{font-size:1.55rem;margin:30px 0 12px}
.prose h3{font-size:1.22rem;margin:22px 0 8px}
.prose ul{margin:0 0 16px 22px}.prose li{list-style:disc;margin-bottom:7px;color:var(--ink2)}
.prose strong{color:var(--ink)}
.prose table{width:100%;border-collapse:collapse;margin:18px 0;font-size:.96rem}
.prose th,.prose td{border:1px solid var(--line);padding:10px 12px;text-align:left}
.prose th{background:var(--cream)}
.article-cta{background:var(--cream2);border-radius:var(--radius-lg);padding:28px;margin:34px 0 10px;text-align:center}
.article-cta h3{font-size:1.4rem;margin-bottom:10px}.article-cta p{margin-bottom:16px}

/* ===== Fallbacks for browsers without aspect-ratio (old Safari / in-app webviews) ===== */
@supports not (aspect-ratio: 1 / 1){
 .tile{height:0;padding-top:100%}
 .card-i{position:relative;height:0;padding-top:75%}
 .card-i img{position:absolute;inset:0}
 .split .im{position:relative;height:0;padding-top:100%}
 .split .im img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
 .article-hero{position:relative;height:0;padding-top:56.25%}
 .article-hero img{position:absolute;inset:0}
 .ba{height:0;padding-top:66%}
}
/* mobile hero: smaller heading so it never crowds the edges */
@media(max-width:680px){
 .hero-c h1{font-size:1.6rem;line-height:1.22}
 .hero-c p{font-size:1rem;margin:14px 0 20px}
 .hero-in{gap:18px}
 .wrap{padding:0 18px}
}

@media(max-width:680px){.gal{grid-template-columns:1fr 1fr;gap:10px}.gal .g img{height:160px}}

.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
@media(max-width:880px){.grid-2{grid-template-columns:1fr;gap:26px}}
