@font-face{font-family:'Fraunces';font-style:normal;font-weight:500;font-display:swap;src:url('/assets/fonts/fraunces-500.woff2') format('woff2')}
@font-face{font-family:'Fraunces';font-style:italic;font-weight:500;font-display:swap;src:url('/assets/fonts/fraunces-500-italic.woff2') format('woff2')}
@font-face{font-family:'Manrope';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/fonts/manrope-400.woff2') format('woff2')}
@font-face{font-family:'Manrope';font-style:normal;font-weight:600;font-display:swap;src:url('/assets/fonts/manrope-600.woff2') format('woff2')}
:root{
  --espresso:#2A2320; --cream:#F6F1E9; --bronze:#96622F;
  --champagne:#E7D6BE; --taupe:#6E5D4E; --line:#E3D9CB;
  --max:1100px; --r:14px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--cream);color:var(--espresso);font-family:'Manrope',system-ui,sans-serif;line-height:1.65;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit}
h1,h2,h3{font-family:'Fraunces',Georgia,serif;font-weight:500;line-height:1.08;letter-spacing:-.01em}
.wrap{max-width:var(--max);margin:0 auto;padding:0 1.5rem}
.eyebrow{font-size:.75rem;letter-spacing:.22em;text-transform:uppercase;color:var(--bronze);font-weight:600}

/* sticky header */
.hdr{position:sticky;top:0;z-index:50;background:rgba(246,241,233,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.hdr-in{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.7rem 1.5rem;max-width:var(--max);margin:0 auto}
.brand{font-family:'Fraunces',serif;font-size:1.05rem;font-weight:600;line-height:1.1}
.hdr-nav{display:none;gap:1.6rem;font-size:.9rem;font-weight:500}
.hdr-nav a{text-decoration:none;color:var(--taupe)}
.hdr-nav a:hover{color:var(--espresso)}
.hdr-cta{display:flex;gap:.5rem}
.btn{display:inline-flex;align-items:center;gap:.4rem;font-weight:600;font-size:.9rem;padding:.6rem 1rem;border-radius:999px;text-decoration:none;white-space:nowrap;border:1.5px solid var(--espresso);transition:.15s}
.btn-call{background:var(--espresso);color:var(--cream)}
.btn-call:hover{background:#000}
.btn-wa{background:transparent;color:var(--espresso)}
.btn-wa:hover{background:var(--espresso);color:var(--cream)}
.btn-lg{padding:.85rem 1.5rem;font-size:1rem}

/* sections */
section{padding:4.5rem 0}
.sec-head{text-align:center;max-width:34ch;margin:0 auto 2.5rem}
.sec-head h2{font-size:clamp(1.9rem,4.5vw,2.7rem);margin-bottom:.6rem}
.sec-head p{color:var(--taupe)}

/* hero */
.hero{text-align:center;padding:3.5rem 0 4rem}
.hero h1{font-size:clamp(2.4rem,7vw,4rem);margin:1.2rem auto;max-width:16ch}
.hero h1 em{font-style:italic;color:var(--bronze)}
.hero-sub{color:var(--taupe);font-size:1.1rem;max-width:46ch;margin:0 auto 1.5rem}
.hero-quote{font-family:'Fraunces',serif;font-style:italic;font-size:1.15rem;color:var(--espresso);max-width:40ch;margin:0 auto 2rem;padding-top:1.5rem;border-top:1px solid var(--line)}
.hero-cta{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}
.embed-hero{margin:2.5rem auto 0;max-width:900px}
.embed-hero iframe{width:100%;border:0;display:block}

/* before/after */
.ba{max-width:520px;margin:0 auto;border-radius:var(--r);overflow:hidden;position:relative;aspect-ratio:3/4;background:var(--champagne);touch-action:none;user-select:none}
.ba img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.ba .after{clip-path:inset(0 0 0 50%)}
.ba-handle{position:absolute;top:0;bottom:0;left:50%;width:2px;background:var(--cream);transform:translateX(-1px);pointer-events:none}
.ba-handle::after{content:"";position:absolute;top:50%;left:50%;width:38px;height:38px;transform:translate(-50%,-50%);background:var(--cream);border-radius:50%;box-shadow:0 2px 8px rgba(0,0,0,.25)}
.ba-tag{position:absolute;bottom:.7rem;font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;font-weight:600;color:#fff;background:rgba(42,35,32,.6);padding:.25rem .6rem;border-radius:6px;z-index:2}
.ba-tag.l{left:.7rem}.ba-tag.r{right:.7rem}
.ba-cap{text-align:center;color:var(--taupe);font-size:.85rem;margin-top:1rem}

/* services */
.svc-grid{display:grid;gap:1.5rem;max-width:760px;margin:0 auto}
.svc-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1.6rem 1.8rem}
.svc-card h3{font-size:1.25rem;margin-bottom:1rem;color:var(--bronze)}
.svc-row{display:flex;justify-content:space-between;gap:1rem;padding:.5rem 0;border-bottom:1px dashed var(--line);font-size:.97rem}
.svc-row:last-child{border-bottom:0}
.svc-row .p{font-weight:600;white-space:nowrap}
.svc-note{max-width:600px;margin:1.8rem auto 0;font-size:.85rem;color:var(--taupe);text-align:center}

/* gallery */
.gal{columns:2;column-gap:.8rem;max-width:880px;margin:0 auto}
@media(min-width:700px){.gal{columns:3}}
.gal img{width:100%;margin-bottom:.8rem;border-radius:10px;break-inside:avoid;transition:.3s}
.gal img:hover{filter:brightness(1.05) saturate(1.05)}

/* areas */
.areas{text-align:center}
.area-tags{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;max-width:600px;margin:0 auto}
.area-tags span{background:#fff;border:1px solid var(--line);border-radius:999px;padding:.45rem 1rem;font-size:.9rem;font-weight:500}

/* faq */
.faq{max-width:680px;margin:0 auto}
.faq details{border-bottom:1px solid var(--line);padding:1.1rem 0}
.faq summary{font-weight:600;cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:1rem;font-size:1.02rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--bronze);font-size:1.4rem;line-height:1}
.faq details[open] summary::after{content:"\2013"}
.faq p{color:var(--taupe);margin-top:.7rem}

/* contact / footer */
.contact{background:var(--espresso);color:var(--cream);text-align:center}
.contact h2{color:var(--cream)}
.contact .sec-head p{color:var(--champagne)}
.contact-cta{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap;margin-top:.5rem}
.contact .btn{border-color:var(--champagne)}
.contact .btn-call{background:var(--bronze);border-color:var(--bronze);color:#fff}
.contact .btn-wa{color:var(--cream)}
.contact .btn-wa:hover{background:var(--champagne);color:var(--espresso)}
.foot{padding:2rem 0;text-align:center;font-size:.8rem;color:var(--taupe)}
.foot a{color:var(--bronze)}

@media(min-width:760px){
  .hdr-nav{display:flex}
}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{transition:none!important}}

/* facebook button - lead channel */
.btn-fb{background:var(--bronze);color:#fff;border-color:var(--bronze)}
.btn-fb:hover{background:#9a6a3f;border-color:#9a6a3f}
/* header fits 3 buttons: tighten on mobile */
.hdr-cta{gap:.4rem}
.hdr-cta .btn{padding:.55rem .8rem;font-size:.85rem}
@media(max-width:480px){
  .hdr-in{padding:.6rem .9rem;gap:.5rem}
  .brand{font-size:.85rem;max-width:7.5rem;line-height:1.1}
  .hdr-cta .btn{padding:.5rem .65rem;font-size:.78rem}
}

/* gallery fix: never stretch, respect natural ratio */
.gal img{width:100%;height:auto}

/* gallery: switch from masonry to neat aligned grid */
.gal{columns:auto;column-gap:0;display:grid;grid-template-columns:repeat(2,1fr);gap:.7rem}
@media(min-width:700px){.gal{grid-template-columns:repeat(3,1fr)}}
.gal img{width:100%;height:100%;aspect-ratio:3/4;object-fit:cover;margin:0;border-radius:10px}

/* visible keyboard focus */
a:focus-visible,.btn:focus-visible,summary:focus-visible,input:focus-visible{outline:3px solid var(--bronze);outline-offset:2px;border-radius:4px}

/* reviews */
.reviews{text-align:center}
.stars{color:var(--bronze);letter-spacing:.15em;font-size:1.05rem;margin-bottom:.8rem}
.review-feature{max-width:620px;margin:0 auto 2.5rem}
.review-quote{font-family:'Fraunces',serif;font-style:italic;font-size:1.3rem;line-height:1.5;color:var(--espresso);margin-bottom:1rem}
.review-name{font-weight:600;font-size:.95rem}
.review-name span{color:var(--taupe);font-weight:400}
.review-grid{display:grid;gap:1.2rem;max-width:760px;margin:0 auto;grid-template-columns:1fr}
@media(min-width:640px){.review-grid{grid-template-columns:1fr 1fr}}
.review-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1.5rem;text-align:left}
.review-card p{font-size:.95rem;color:var(--espresso);margin-bottom:.6rem}
.review-card .review-name{font-size:.9rem}

/* all contact pills identical bronze */
.btn,.btn-call,.btn-wa,.btn-fb{background:var(--bronze)!important;color:#fff!important;border:1.5px solid var(--bronze)!important}
.btn:hover,.btn-call:hover,.btn-wa:hover,.btn-fb:hover{background:#7d4f25!important;border-color:#7d4f25!important}
/* contact-band pills: keep bronze on the dark background too */
.contact .btn{background:var(--bronze)!important;color:#fff!important;border-color:var(--bronze)!important}
.contact .btn:hover{background:#caa06f!important;border-color:#caa06f!important;color:var(--espresso)!important}
/* breathing room above the About section so it isn't squashed under the reviews */
#about{padding-top:5.5rem}
#about .sec-head{margin-bottom:2rem}

/* ===== EXPERIMENT: Quicksand headings + turquoise accent ===== */
@font-face{font-family:'Quicksand';font-style:normal;font-weight:500;font-display:swap;src:url('/assets/fonts/quicksand-500.woff2') format('woff2')}
@font-face{font-family:'Quicksand';font-style:normal;font-weight:600;font-display:swap;src:url('/assets/fonts/quicksand-600.woff2') format('woff2')}

/* headings -> Quicksand (friendlier, less formal) */
h1,h2,h3,.brand{font-family:'Quicksand','Manrope',sans-serif!important;font-weight:600!important;font-style:normal!important}
.review-quote{font-family:'Quicksand',sans-serif!important;font-style:normal!important;font-weight:500!important}
.hero h1 em{font-style:normal!important}

/* turquoise accent (swaps the bronze) */
:root{--turq:#1FA89B;--turq-dark:#177D73}
.eyebrow,.hero h1 em,.svc-card h3,.stars,.foot a,.review-name span,.faq summary::after{color:var(--turq)!important}
.rule{background:var(--turq)!important}
.btn,.btn-call,.btn-wa,.btn-fb,.contact .btn{background:var(--turq)!important;border-color:var(--turq)!important;color:#fff!important}
.btn:hover,.btn-call:hover,.btn-wa:hover,.btn-fb:hover,.contact .btn:hover{background:var(--turq-dark)!important;border-color:var(--turq-dark)!important}
a:focus-visible,.btn:focus-visible,summary:focus-visible{outline-color:var(--turq)!important}
.ba-handle::after{box-shadow:0 2px 8px rgba(0,0,0,.25)}

/* ===== EXPERIMENT: navy background ===== */
:root{--cream:#0F1E33;--espresso:#EAF0F7;--line:#26384F;--taupe:#9FB2C9;--turq:#2DD4BF;--turq-dark:#14B8A6}
body{background:#0F1E33;color:#EAF0F7}
.svc-card,.review-card{background:#16263D;border-color:#26384F}
.area-tags span{background:#16263D;border-color:#26384F;color:#EAF0F7}
.hdr{background:rgba(15,30,51,.92);border-bottom-color:#26384F}
.hdr-nav a{color:#9FB2C9}
.hdr-nav a:hover{color:#EAF0F7}
.review-card p,.svc-row{color:#EAF0F7}
.contact{background:#0A1626}
.foot{background:#0F1E33}
.eyebrow,.hero h1 em,.svc-card h3,.stars,.foot a,.review-name span,.faq summary::after{color:var(--turq)!important}
.rule{background:var(--turq)!important}
.btn,.btn-call,.btn-wa,.btn-fb,.contact .btn{background:var(--turq)!important;border-color:var(--turq)!important;color:#0F1E33!important}
.btn:hover,.contact .btn:hover{background:var(--turq-dark)!important;border-color:var(--turq-dark)!important;color:#0F1E33!important}

/* two-up before/after layout */
.ba-row{display:grid;grid-template-columns:1fr;gap:1.5rem;max-width:760px;margin:0 auto}
@media(min-width:720px){.ba-row{grid-template-columns:1fr 1fr;max-width:900px}}
.ba-row .ba{max-width:none}

/* fix: stop browser dragging the slider images, ensure range is the drag layer */
.ba img{-webkit-user-drag:none;user-select:none;pointer-events:none}
.ba .ba-range{position:absolute;inset:0;width:100%;height:100%;margin:0;opacity:0;cursor:ew-resize;z-index:5;touch-action:none}
.ba{touch-action:none}

/* ===== gallery: masonry (natural shapes, no crop) ===== */
.gal{columns:2;column-gap:.7rem;display:block;grid-template-columns:none}
@media(min-width:700px){.gal{columns:3}}
.gal img{width:100%;height:auto!important;aspect-ratio:auto!important;object-fit:fill;margin:0 0 .7rem;border-radius:10px;break-inside:avoid;display:block}

/* ===== gallery: back to clean uniform grid (overrides masonry) ===== */
.gal{columns:auto!important;column-gap:0!important;display:grid!important;grid-template-columns:repeat(2,1fr)!important;gap:.7rem!important}
@media(min-width:700px){.gal{grid-template-columns:repeat(3,1fr)!important}}
.gal img{width:100%!important;height:100%!important;aspect-ratio:3/4!important;object-fit:cover!important;margin:0!important;border-radius:10px!important}

/* fix: contact band text must be light on the dark navy */
.contact h2{color:#EAF0F7!important}
.contact .sec-head p{color:#9FB2C9!important}
.contact p{color:#9FB2C9}

/* skip-to-content link (visible on focus only) */
.skip-link{position:fixed;top:-100px;left:1rem;z-index:9999;background:var(--turq);color:#0F1E33;padding:.7rem 1.1rem;border-radius:0 0 8px 8px;font-weight:600;text-decoration:none;transition:top .15s}
.skip-link:focus,.skip-link:focus-visible{top:0}
/* tap targets >=44px for mobile */
.btn{min-height:44px;display:inline-flex;align-items:center;justify-content:center}
.hdr-cta .btn{min-height:40px}
@media(max-width:480px){.hdr-cta .btn{min-height:44px}}
.faq summary{min-height:44px;display:flex;align-items:center}
