:root{
  /* Brand accent — Fresh Plaster terracotta. Swap these three when the logo hex arrives. */
  --accent:#C4623E; --accent-dark:#A44B2C; --accent-tint:#F6E3DA;
  --ink:#1A1C1F; --ink2:#454A52; --muted:#7A8089;
  --paper:#FFFFFF; --paper2:#F7F5F3; --paper3:#ECE7E3;
  --line:#E4DFDA; --line2:#CFC8C1; --graphite:#1A1C1F; --graphite2:#26292E;
  --maxw:1240px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:Inter,system-ui,-apple-system,sans-serif;color:var(--ink);background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,.mn{font-family:Manrope,sans-serif;letter-spacing:-.025em;line-height:1.06;font-weight:800}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{font-size:12px;letter-spacing:.16em;text-transform:uppercase;font-weight:600;color:var(--accent)}
.lead{font-size:18px;color:var(--ink2)}
section{padding:84px 0}
@media(max-width:720px){section{padding:56px 0}}

/* buttons — square, sharp */
.btn{font-family:Manrope;font-weight:700;font-size:15px;padding:15px 24px;border:0;border-radius:0;display:inline-flex;align-items:center;gap:9px;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,background .15s ease;position:relative;overflow:hidden}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-dark);transform:translateY(-2px);box-shadow:0 10px 22px rgba(196,98,62,.32)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{transform:translateY(-2px);box-shadow:0 10px 22px rgba(26,28,31,.3)}
.btn-ghost{background:transparent;border:1.5px solid currentColor}
.btn-ghost:hover{transform:translateY(-2px)}
.btn .shine{position:absolute;top:0;left:-130%;width:60%;height:100%;background:linear-gradient(120deg,transparent,rgba(255,255,255,.35),transparent);transform:skewX(-20deg)}
.btn:hover .shine{left:140%;transition:left .7s ease}

/* header */
header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.82);backdrop-filter:saturate(140%) blur(12px);transition:box-shadow .2s,border-color .2s;border-bottom:1px solid transparent}
header.scrolled{box-shadow:0 1px 0 var(--line),0 6px 24px rgba(20,25,35,.06);border-bottom-color:var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px}
.logo{font-family:Manrope;font-weight:800;font-size:21px;letter-spacing:-.03em}
.logo span{color:var(--accent)}
.nav-links{display:flex;gap:30px;align-items:center}
.nav-links a.link{font-size:15px;font-weight:500;color:var(--ink2);position:relative;padding:4px 0}
.nav-links a.link::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--accent);transition:width .25s ease}
.nav-links a.link:hover{color:var(--ink)}
.nav-links a.link:hover::after,.nav-links a.link.active::after{width:100%}
.nav-links a.link.active{color:var(--ink)}
.nav-cta{display:flex;gap:10px;align-items:center}
.phone-link{font-family:Manrope;font-weight:700;font-size:15px;display:flex;align-items:center;gap:7px}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.burger span{width:24px;height:2px;background:var(--ink);display:block}
@media(max-width:980px){
  .nav-links{display:none}
  .burger{display:flex}
  .nav-cta .phone-link span.label{display:none}
}

/* hero — split */
.hero{display:grid;grid-template-columns:1.05fr .95fr;min-height:560px}
.hero-left{background:var(--graphite);color:#fff;display:flex;align-items:center;padding:64px clamp(24px,4vw,64px)}
.hero-left .inner{max-width:520px;margin-left:auto;width:100%}
.hero h1{font-size:clamp(32px,4.6vw,52px);color:#fff;margin:14px 0 14px}
.hero h1 em{font-style:normal;color:var(--accent)}
.hero .sub{color:#cfd2d6;font-size:17px;margin-bottom:22px;max-width:46ch}
.hero-right{position:relative;background:var(--paper3) center/cover no-repeat}
.hero-right img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-badge{position:absolute;left:24px;bottom:24px;background:#fff;color:var(--ink);padding:12px 16px;box-shadow:0 12px 30px rgba(0,0,0,.25);display:flex;gap:11px;align-items:center}
.hero-badge .stars{color:var(--accent);font-size:15px;letter-spacing:1px}
.hero-badge b{font-family:Manrope;font-size:15px;display:block}
.hero-badge small{color:var(--muted);font-size:12px}

/* compact page hero (subpages) */
.phero{background:var(--graphite);color:#fff;padding:64px 0}
.phero .eyebrow{color:#f0a98f}
.phero h1{font-size:clamp(30px,4.4vw,46px);color:#fff;margin:12px 0 14px;max-width:18ch}
.phero h1 em{font-style:normal;color:var(--accent)}
.phero p{color:#cfd2d6;font-size:18px;max-width:60ch}
.phero .row{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}
.crumb{font-size:13px;color:#9aa0a8}
.crumb a:hover{color:#fff}

/* quote form */
.qform{background:var(--graphite2);padding:20px;margin-top:6px}
.qform .frow{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.qform input,.qform select{width:100%;font-family:Inter;font-size:15px;padding:12px 13px;border:1.5px solid #3a3e44;border-radius:0;background:#1f2226;color:#fff;margin-bottom:10px}
.qform input::placeholder{color:#8b9099}
.qform input:focus,.qform select:focus{outline:0;border-color:var(--accent);box-shadow:0 0 0 3px rgba(196,98,62,.35)}
.qform .btn{width:100%;justify-content:center;margin-top:2px}
.qform .tiny{font-size:12px;color:#9aa0a8;margin-top:10px;text-align:center}
.qform .tiny a{color:#cfd2d6;text-decoration:underline}
.form-note{font-size:11px;color:#ffd9c7;background:rgba(196,98,62,.16);border-left:3px solid var(--accent);padding:7px 10px;margin-bottom:12px}

@media(max-width:860px){
  .hero{grid-template-columns:1fr}
  .hero-right{min-height:280px;order:-1}
  .hero-left{padding:40px 24px}
  .hero-left .inner{margin:0 auto}
}

/* trust strip */
.trust{background:var(--accent);color:#fff}
.trust .wrap{display:flex;flex-wrap:wrap;justify-content:center;gap:14px 40px;padding:16px 24px;font-family:Manrope;font-weight:700;font-size:15px;text-align:center}
.trust .wrap span{display:inline-flex;align-items:center;gap:8px}

/* section heading */
.shead{max-width:680px;margin-bottom:40px}
.shead h2{font-size:clamp(26px,3.4vw,38px);margin:12px 0 12px}
.shead p{color:var(--ink2);font-size:17px}
.center{margin-left:auto;margin-right:auto;text-align:center}

/* services */
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:880px){.grid3{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.grid3{grid-template-columns:1fr}}
.scard{background:var(--paper);border:1px solid var(--line);padding:28px 24px;transition:transform .2s,box-shadow .2s,border-color .2s;position:relative;display:block;color:inherit}
.scard:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(20,25,35,.09);border-color:var(--line2)}
.scard .ic{width:48px;height:48px;background:var(--accent-tint);color:var(--accent-dark);display:flex;align-items:center;justify-content:center;margin-bottom:16px;font-size:22px}
.scard h3{font-size:20px;margin-bottom:8px}
.scard p{color:var(--ink2);font-size:15px}
.scard .more{display:inline-block;margin-top:14px;font-family:Manrope;font-weight:700;font-size:14px;color:var(--accent-dark)}
.scard .ul{position:absolute;left:24px;bottom:24px;height:3px;width:0;background:var(--accent);transition:width .3s ease}
.scard:hover .ul{width:40px}
a.scard:hover .more{text-decoration:underline}

/* why-us band */
.why{background:var(--paper2)}
.why .layout{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
@media(max-width:860px){.why .layout{grid-template-columns:1fr;gap:28px}}
.promises{list-style:none;display:grid;gap:14px}
.promises li{display:flex;gap:13px;align-items:flex-start;font-size:16px}
.promises .tick{flex:none;width:26px;height:26px;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;margin-top:1px}
.why-photo{position:relative}
.why-photo img{width:100%;height:100%;max-height:440px;object-fit:cover}

/* feature row (subpages): alternating text + image */
.frow2{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;margin-bottom:64px}
.frow2:last-child{margin-bottom:0}
.frow2 .ic{width:48px;height:48px;background:var(--accent-tint);color:var(--accent-dark);display:flex;align-items:center;justify-content:center;margin-bottom:16px;font-size:22px}
.frow2 h2{font-size:clamp(24px,3vw,32px);margin-bottom:14px}
.frow2 p{color:var(--ink2);font-size:16px;margin-bottom:12px}
.frow2 .mini{list-style:none;display:grid;gap:10px;margin-top:14px}
.frow2 .mini li{display:flex;gap:11px;align-items:flex-start;font-size:15px}
.frow2 .mini .tick{flex:none;width:22px;height:22px;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;margin-top:2px}
.frow2 .photo img{width:100%;height:100%;max-height:420px;object-fit:cover}
.frow2.flip .text{order:2}
@media(max-width:860px){.frow2{grid-template-columns:1fr;gap:24px;margin-bottom:44px}.frow2.flip .text{order:0}}

/* gallery */
.gal{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
@media(max-width:880px){.gal{grid-template-columns:1fr 1fr}}
.gal a{position:relative;overflow:hidden;display:block;aspect-ratio:1/1}
.gal img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.gal a:hover img{transform:scale(1.06)}

/* testimonials */
.tband{background:var(--graphite);color:#fff}
.tband .shead h2{color:#fff}
.tband .shead p{color:#cfd2d6}
.vids{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:34px}
@media(max-width:760px){.vids{grid-template-columns:1fr}}
.vcap{font-size:14px;line-height:1.55;margin-top:14px}
.tband .vcap{color:#cfd2d6}
.vcap b{font-family:Manrope;color:#fff;display:block;margin-bottom:4px;font-size:15px}
.vid{position:relative;aspect-ratio:16/9;background:#000;display:block;overflow:hidden}
.vid iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
/* youtube facade (loads/links only on click — avoids file:// player errors) */
.ytfacade{cursor:pointer}
.ytfacade img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .4s ease,filter .3s ease}
.ytfacade:hover img{transform:scale(1.05);filter:brightness(.82)}
.ytfacade .playbtn{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:74px;height:52px;background:var(--accent);border-radius:12px;transition:background .2s ease,transform .2s ease;box-shadow:0 8px 24px rgba(0,0,0,.4)}
.ytfacade .playbtn::after{content:"";position:absolute;top:50%;left:53%;transform:translate(-50%,-50%);border-style:solid;border-width:11px 0 11px 18px;border-color:transparent transparent transparent #fff}
.ytfacade:hover .playbtn{background:var(--accent-dark);transform:translate(-50%,-50%) scale(1.08)}
.ytfacade .vlabel{position:absolute;left:0;right:0;bottom:0;padding:14px 16px 12px;color:#fff;font-family:Manrope;font-weight:700;font-size:15px;background:linear-gradient(transparent,rgba(0,0,0,.72));pointer-events:none}
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:760px){.quotes{grid-template-columns:1fr}}
.quote{background:var(--graphite2);padding:24px;border-top:3px solid var(--accent)}
.quote .stars{color:var(--accent);letter-spacing:1px;margin-bottom:10px}
.quote p{color:#e7e9ec;font-size:15px}
.quote cite{display:block;margin-top:12px;color:#9aa0a8;font-style:normal;font-size:13px;font-family:Manrope;font-weight:600}

/* areas */
.areas .chips{display:flex;flex-wrap:wrap;gap:9px;margin-top:8px}
.areas .chips span{border:1px solid var(--line2);padding:7px 13px;font-size:14px;color:var(--ink2)}

/* contact split */
.csplit{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
@media(max-width:860px){.csplit{grid-template-columns:1fr;gap:32px}}
.cinfo h3{font-size:20px;margin:22px 0 8px}
.cinfo h3:first-child{margin-top:0}
.cinfo p{color:var(--ink2);font-size:16px}
.cinfo a{color:var(--accent-dark);font-weight:600}
.cform-wrap{background:var(--paper2);border:1px solid var(--line);padding:8px}

/* CTA band */
.cta{background:var(--graphite);color:#fff;text-align:center}
.cta h2{font-size:clamp(26px,3.6vw,40px);color:#fff;margin-bottom:12px}
.cta p{color:#cfd2d6;font-size:18px;margin-bottom:26px;max-width:60ch;margin-left:auto;margin-right:auto}
.cta .row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* footer */
footer{background:#101113;color:#aeb3ba;font-size:14px;padding:56px 0 28px}
.fgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px;margin-bottom:34px}
@media(max-width:760px){.fgrid{grid-template-columns:1fr;gap:26px}}
footer .logo{color:#fff;font-size:20px;margin-bottom:12px}
footer h4{color:#fff;font-size:13px;letter-spacing:.1em;text-transform:uppercase;margin-bottom:14px;font-family:Manrope}
footer a{color:#aeb3ba}
footer a:hover{color:#fff}
footer ul{list-style:none;display:grid;gap:9px}
.fbar{border-top:1px solid #26292E;padding-top:20px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:13px;color:#7a8089}

/* mobile drawer */
.drawer{position:fixed;inset:0;z-index:60;background:#fff;transform:translateX(100%);transition:transform .28s ease;padding:24px;display:flex;flex-direction:column}
.drawer.open{transform:translateX(0)}
.drawer .top{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}
.drawer .close{background:none;border:0;font-size:30px;cursor:pointer;line-height:1}
.drawer a{font-family:Manrope;font-weight:700;font-size:22px;padding:14px 0;border-bottom:1px solid var(--line)}
.drawer .btn{margin-top:20px;justify-content:center}

/* reveal */
.reveal{transition:opacity .6s ease,transform .6s ease}
.js .reveal{opacity:0;transform:translateY(22px)}
.js .reveal.in{opacity:1;transform:none}
.toast{position:fixed;left:50%;bottom:28px;transform:translateX(-50%) translateY(120%);background:var(--ink);color:#fff;padding:14px 22px;font-weight:600;z-index:80;transition:transform .35s ease;box-shadow:0 14px 40px rgba(0,0,0,.3)}
.toast.show{transform:translateX(-50%) translateY(0)}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}
