:root{
  --ink:#13211c;
  --forest:#1d4d3b;
  --forest-deep:#13362a;
  --sage:#7ba894;
  --clay:#e8623d;
  --clay-deep:#c84a26;
  --cream:#f4efe4;
  --cream-dim:#e9e2d2;
  --sand:#d8cdb4;
  --paper:#fbf8f1;
  --line:rgba(19,33,28,.12);
  --shadow:0 24px 60px -22px rgba(19,54,42,.45);
  --shadow-sm:0 10px 30px -16px rgba(19,54,42,.4);
  --r:18px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Archivo',sans-serif;
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:'Fraunces',serif;line-height:1.05;font-weight:600;letter-spacing:-.01em}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:1280px;margin:0 auto;padding:0 32px}
.eyebrow{
  font-family:'Archivo';font-weight:700;font-size:.72rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--clay);display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--clay)}

/* ---------- TOP BAR ---------- */
.topbar{background:var(--forest-deep);color:var(--cream);font-size:.82rem}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;height:42px;gap:18px}
.topbar a{display:inline-flex;align-items:center;gap:7px;opacity:.92;transition:opacity .2s}
.topbar a:hover{opacity:1}
.topbar .badges{display:flex;gap:20px}
.topbar .badges span{display:inline-flex;align-items:center;gap:7px;opacity:.88}
@media(max-width:760px){.topbar .badges{display:none}}

/* ---------- NAV ---------- */
header{position:sticky;top:0;z-index:60;background:rgba(251,248,241,.86);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
nav{display:flex;align-items:center;justify-content:space-between;height:84px;gap:32px}
.logo{display:flex;align-items:center;gap:13px;font-family:'Fraunces';font-weight:900;font-size:1.32rem;letter-spacing:-.02em}
.logo .mark{
  width:44px;height:44px;border-radius:13px;flex:none;position:relative;
  background:linear-gradient(140deg,var(--forest),var(--forest-deep));
  display:grid;place-items:center;box-shadow:var(--shadow-sm);
}
.logo .mark::after{content:"";position:absolute;width:15px;height:15px;border-radius:50%;
  background:var(--clay);top:8px;right:8px}
.logo .mark svg{width:24px;height:24px}
.logo small{display:block;font-family:'Archivo';font-weight:600;font-size:.62rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--forest);opacity:.7;margin-top:1px}
.navlinks{display:flex;gap:40px;align-items:center}
.navlinks a{font-weight:600;font-size:.95rem;position:relative;padding:6px 2px;color:var(--ink)}
.navlinks .caret{font-style:normal;font-size:.7rem;opacity:.6;margin-left:3px}
.navlinks a{position:relative;color:var(--ink)}
.navlinks a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--clay);transition:width .28s}
.navlinks a:hover::after{width:100%}
.navlinks a.has-mega::after{display:none}

/* ---------- MEGA MENU ---------- */
.mega-item{position:static}
.mega{
  position:absolute;left:0;right:0;top:100%;background:var(--paper);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  box-shadow:var(--shadow);opacity:0;visibility:hidden;transform:translateY(10px);
  transition:opacity .26s ease,transform .26s ease,visibility .26s;z-index:70;
}
.mega-item:hover .mega{opacity:1;visibility:visible;transform:translateY(0)}
.mega-inner{max-width:1220px;margin:0 auto;padding:38px 28px;display:grid;
  grid-template-columns:1.1fr 1.1fr 1.1fr 1fr;gap:34px}
.mega-col h6{font-family:'Archivo';font-weight:800;font-size:.72rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--clay);margin-bottom:18px}
.mega-link{display:flex;gap:13px;align-items:flex-start;padding:9px 0;border-radius:10px;transition:.2s}
.mega-link:hover{transform:translateX(4px)}
.mega-link .mi{width:38px;height:38px;border-radius:10px;flex:none;background:var(--cream-dim);
  display:grid;place-items:center;color:var(--forest);transition:.25s}
.mega-link:hover .mi{background:var(--forest);color:var(--cream)}
.mega-link b{display:block;font-family:'Archivo';font-weight:700;font-size:.95rem;color:var(--ink)}
.mega-link span{font-size:.8rem;color:#6a7972;line-height:1.4}
.mega-feat{background:linear-gradient(155deg,var(--forest),var(--forest-deep));border-radius:16px;
  padding:26px 24px;color:var(--cream);display:flex;flex-direction:column;justify-content:space-between}
.mega-feat .stars{color:var(--clay);font-size:.95rem;margin-bottom:10px}
.mega-feat h6{color:var(--clay)}
.mega-feat p{font-size:.9rem;color:rgba(244,239,228,.85);margin:8px 0 18px;font-family:'Fraunces';font-style:italic}
.mega-feat .btn{align-self:flex-start;font-size:.85rem;padding:11px 20px}
.mega-areas{display:flex;flex-wrap:wrap;gap:8px}
.mega-areas a{background:var(--cream-dim);padding:7px 13px;border-radius:100px;font-size:.82rem;
  font-weight:600;transition:.2s}
.mega-areas a:hover{background:var(--clay);color:#fff}
@media(max-width:980px){
  .mega{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;
    border:none;background:transparent;display:none}
  .mega-item.mopen .mega{display:block}
  .mega-inner{grid-template-columns:1fr;padding:14px 0 6px;gap:18px}
  .mega-feat,.mega-col h6{display:none}
  .mega-areas{margin-top:4px}
}

.nav-cta{display:flex;align-items:center;gap:16px}
.callbtn{font-weight:800;font-size:1rem;color:var(--forest);display:flex;align-items:center;gap:8px}
.btn{
  display:inline-flex;align-items:center;gap:9px;font-family:'Archivo';font-weight:700;
  font-size:.95rem;padding:14px 26px;border-radius:100px;cursor:pointer;border:none;
  transition:transform .22s cubic-bezier(.34,1.56,.64,1),box-shadow .22s;white-space:nowrap;
}
.btn-primary{background:var(--clay);color:#fff;box-shadow:0 12px 26px -10px rgba(200,74,38,.7)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 20px 38px -12px rgba(200,74,38,.8)}
.btn-dark{background:var(--forest);color:var(--cream)}
.btn-dark:hover{transform:translateY(-3px)}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--cream)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.burger span{width:26px;height:2.5px;background:var(--ink);border-radius:2px;transition:.3s}
@media(max-width:980px){
  .navlinks{position:fixed;inset:126px 0 auto 0;background:var(--paper);flex-direction:column;
    padding:30px 28px;gap:22px;border-bottom:1px solid var(--line);transform:translateY(-120%);
    transition:transform .35s ease;box-shadow:var(--shadow)}
  .navlinks.open{transform:translateY(0)}
  .navlinks a{font-size:1.1rem}
  .burger{display:flex}
  .nav-cta .callbtn{display:none}
}

/* ---------- HERO ---------- */
.hero{position:relative;padding:84px 0 96px;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;z-index:-2;
  background:
    radial-gradient(900px 500px at 78% -8%,rgba(232,98,61,.14),transparent 60%),
    radial-gradient(800px 600px at 8% 100%,rgba(29,77,59,.1),transparent 55%);
}
.hero::after{content:"";position:absolute;inset:0;z-index:-1;opacity:.4;
  background-image:radial-gradient(var(--line) 1px,transparent 1px);background-size:26px 26px;
  -webkit-mask-image:radial-gradient(circle at 50% 40%,#000,transparent 75%)}
.hero-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:62px;align-items:center}
.hero-loc{margin-bottom:22px}
.hero h1{font-size:clamp(2.7rem,5.4vw,4.5rem);font-weight:900;letter-spacing:-.025em}
.hero h1 em{font-style:italic;color:var(--clay);font-weight:600}
.hero p.lead{font-size:1.18rem;color:#3c4f47;max-width:520px;margin:26px 0 34px}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;align-items:center}
.hero-trust{display:flex;gap:30px;margin-top:42px;flex-wrap:wrap}
.hero-trust .ht{display:flex;flex-direction:column}
.hero-trust .num{font-family:'Fraunces';font-weight:900;font-size:1.9rem;color:var(--forest);line-height:1}
.hero-trust .lbl{font-size:.78rem;font-weight:600;color:#5a6b62;text-transform:uppercase;letter-spacing:.08em;margin-top:6px}
.stars{color:var(--clay);letter-spacing:2px;font-size:1.05rem}

/* hero visual */
.hero-visual{position:relative}
.hero-card{
  position:relative;border-radius:26px;overflow:hidden;box-shadow:var(--shadow);
  aspect-ratio:4/5;background:linear-gradient(160deg,var(--forest),var(--forest-deep));
}
.hero-card .swatches{position:absolute;inset:0;display:grid;grid-template-rows:1.4fr 1fr}
.hero-card .room{
  background:
    linear-gradient(180deg,rgba(0,0,0,0) 55%,rgba(0,0,0,.35)),
    linear-gradient(140deg,#e9d9bf,#d4bd97);
  position:relative;display:flex;align-items:flex-end;padding:26px}
.hero-card .room::before{content:"";position:absolute;top:14%;left:14%;width:44%;height:50%;
  border-radius:10px;background:linear-gradient(160deg,var(--cream),#fff);box-shadow:0 20px 40px -14px rgba(0,0,0,.35);
  border:8px solid #fff;transform:rotate(-3deg)}
.hero-card .room .tag{position:relative;background:#fff;color:var(--ink);font-weight:700;
  font-size:.8rem;padding:8px 16px;border-radius:100px;box-shadow:var(--shadow-sm)}
.hero-card .palette{display:flex}
.hero-card .palette i{flex:1}
.hero-card .palette i:nth-child(1){background:var(--forest)}
.hero-card .palette i:nth-child(2){background:var(--clay)}
.hero-card .palette i:nth-child(3){background:var(--sand)}
.hero-card .palette i:nth-child(4){background:var(--sage)}
.hero-badge{
  position:absolute;bottom:-26px;left:-26px;background:var(--paper);border-radius:18px;
  padding:18px 22px;box-shadow:var(--shadow);display:flex;align-items:center;gap:14px;
  border:1px solid var(--line);max-width:255px}
.hero-badge .ic{width:44px;height:44px;border-radius:12px;background:var(--clay);color:#fff;
  display:grid;place-items:center;flex:none}
.hero-badge b{font-family:'Fraunces';font-size:1.05rem;display:block}
.hero-badge span{font-size:.78rem;color:#5a6b62}
.hero-float{position:absolute;top:24px;right:-18px;background:var(--cream);border:1px solid var(--line);
  border-radius:14px;padding:12px 18px;box-shadow:var(--shadow-sm);font-weight:700;font-size:.85rem;
  display:flex;align-items:center;gap:8px}
.hero-float .dot{width:9px;height:9px;border-radius:50%;background:#3fae6f;box-shadow:0 0 0 4px rgba(63,174,111,.22)}
@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:70px}
  .hero-visual{max-width:430px;margin:0 auto;width:100%}
}

/* ---------- MARQUEE TRUST ---------- */
.trustbar{background:var(--forest-deep);color:var(--cream);padding:22px 0;overflow:hidden}
.marquee{display:flex;gap:60px;white-space:nowrap;animation:scroll 32s linear infinite;font-family:'Fraunces';
  font-weight:500;font-size:1.15rem;align-items:center;opacity:.92}
.marquee span{display:inline-flex;align-items:center;gap:60px}
.marquee b{color:var(--clay)}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ---------- SECTION SHELL ---------- */
section{position:relative}
.sec{padding:100px 0}
.sec-head{max-width:680px;margin-bottom:56px}
.sec-head.center{margin:0 auto 56px;text-align:center}
.sec-head h2{font-size:clamp(2.1rem,4vw,3.2rem);margin:16px 0 18px;font-weight:600}
.sec-head h2 em{font-style:italic;color:var(--clay)}
.sec-head p{font-size:1.08rem;color:#4c5d54}

/* ---------- SERVICES ---------- */
.services{background:var(--cream)}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.svc{
  background:var(--paper);border-radius:var(--r);padding:34px 30px;border:1px solid var(--line);
  position:relative;overflow:hidden;transition:transform .3s,box-shadow .3s;
}
.svc::before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;
  background:var(--clay);transform:scaleX(0);transform-origin:left;transition:transform .35s}
.svc:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.svc:hover::before{transform:scaleX(1)}
.svc .ic{width:58px;height:58px;border-radius:15px;background:linear-gradient(145deg,var(--forest),var(--forest-deep));
  color:var(--cream);display:grid;place-items:center;margin-bottom:22px}
.svc.feat{background:var(--forest);color:var(--cream)}
.svc.feat .ic{background:var(--clay)}
.svc.feat p{color:rgba(244,239,228,.82)}
.svc.feat a{color:var(--clay)}
.svc h3{font-size:1.45rem;margin-bottom:12px}
.svc p{color:#4c5d54;font-size:.97rem;margin-bottom:18px}
.svc a{font-weight:700;color:var(--forest);display:inline-flex;align-items:center;gap:7px;font-size:.92rem}
.svc a svg{transition:transform .25s}
.svc a:hover svg{transform:translateX(5px)}
@media(max-width:900px){.svc-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.svc-grid{grid-template-columns:1fr}}

/* ---------- WHY / SPLIT ---------- */
.why{background:var(--paper)}
.split{display:grid;grid-template-columns:.95fr 1.05fr;gap:64px;align-items:center}
.why-visual{position:relative;border-radius:26px;overflow:hidden;aspect-ratio:1/1;
  background:linear-gradient(155deg,#e9d9bf,#cbb592);box-shadow:var(--shadow);display:grid;place-items:center}
.why-visual .panel{position:absolute;inset:8% 8%;border-radius:18px;
  background:repeating-linear-gradient(135deg,rgba(255,255,255,.5) 0 18px,rgba(255,255,255,.25) 18px 36px);
  border:10px solid #fff;box-shadow:inset 0 0 60px rgba(0,0,0,.08)}
.why-visual .roller{position:absolute;width:120px;height:120px;border-radius:50%;
  background:var(--clay);right:-10px;bottom:-10px;display:grid;place-items:center;color:#fff;
  font-family:'Fraunces';font-weight:900;font-size:.95rem;text-align:center;line-height:1.1;
  box-shadow:var(--shadow);padding:18px}
.why-stat{position:absolute;left:-22px;top:34px;background:var(--paper);border:1px solid var(--line);
  border-radius:16px;padding:16px 22px;box-shadow:var(--shadow-sm)}
.why-stat .n{font-family:'Fraunces';font-weight:900;font-size:1.7rem;color:var(--forest);line-height:1}
.why-stat .t{font-size:.74rem;text-transform:uppercase;letter-spacing:.08em;color:#5a6b62;margin-top:4px}
.feature-list{display:flex;flex-direction:column;gap:22px;margin-top:34px}
.fl{display:flex;gap:18px;align-items:flex-start}
.fl .ic{width:46px;height:46px;border-radius:12px;flex:none;background:var(--cream-dim);
  display:grid;place-items:center;color:var(--forest)}
.fl h4{font-size:1.18rem;margin-bottom:4px}
.fl p{color:#4c5d54;font-size:.95rem}
@media(max-width:900px){.split{grid-template-columns:1fr;gap:48px}.why-visual{max-width:420px;margin:0 auto;width:100%}}

/* ---------- PROCESS ---------- */
.process{background:var(--forest-deep);color:var(--cream);overflow:hidden}
.process .sec-head h2{color:var(--cream)}
.process .sec-head p{color:rgba(244,239,228,.75)}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;counter-reset:s}
.step{background:rgba(244,239,228,.05);border:1px solid rgba(244,239,228,.14);border-radius:var(--r);
  padding:30px 26px;position:relative;transition:background .3s}
.step:hover{background:rgba(232,98,61,.12)}
.step::before{counter-increment:s;content:"0" counter(s);font-family:'Fraunces';font-weight:900;
  font-size:2.6rem;color:var(--clay);opacity:.9;display:block;margin-bottom:14px}
.step h4{font-size:1.25rem;margin-bottom:10px;color:var(--cream)}
.step p{font-size:.92rem;color:rgba(244,239,228,.72)}
@media(max-width:900px){.steps{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.steps{grid-template-columns:1fr}}

/* ---------- GALLERY / AREAS ---------- */
.areas{background:var(--cream)}
.area-flex{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.area-tags{display:flex;flex-wrap:wrap;gap:12px;margin-top:30px}
.area-tags span{background:var(--paper);border:1px solid var(--line);padding:11px 20px;border-radius:100px;
  font-weight:600;font-size:.92rem;display:inline-flex;align-items:center;gap:8px;transition:.25s}
.area-tags span:hover{background:var(--forest);color:var(--cream);border-color:var(--forest)}
.area-map{aspect-ratio:5/4;border-radius:24px;background:
    radial-gradient(circle at 60% 40%,rgba(232,98,61,.18),transparent 50%),
    linear-gradient(155deg,var(--forest),var(--forest-deep));
  position:relative;overflow:hidden;box-shadow:var(--shadow);display:grid;place-items:center}
.area-map .pin{position:absolute;width:18px;height:18px;border-radius:50% 50% 50% 0;background:var(--clay);
  transform:rotate(-45deg);box-shadow:0 0 0 6px rgba(232,98,61,.25)}
.area-map .pin.p1{top:42%;left:48%;width:26px;height:26px}
.area-map .pin.p2{top:28%;left:30%}
.area-map .pin.p3{top:62%;left:64%}
.area-map .pin.p4{top:55%;left:28%}
.area-map .pin.p5{top:34%;left:68%}
.area-map .lab{position:relative;color:var(--cream);font-family:'Fraunces';font-weight:900;
  font-size:1.5rem;text-align:center;z-index:2;opacity:.95;text-shadow:0 2px 20px rgba(0,0,0,.4)}
@media(max-width:900px){.area-flex{grid-template-columns:1fr;gap:42px}}

/* ---------- GALLERY / PORTFOLIO ---------- */
.gallery{background:var(--paper)}
.gal-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:16px}
.gal{position:relative;border-radius:16px;overflow:hidden;box-shadow:var(--shadow-sm);
  background:linear-gradient(155deg,#e9d9bf,#cbb592);cursor:pointer}
.gal::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 45%,rgba(19,33,28,.7))}
.gal .ph{position:absolute;inset:0;display:grid;place-items:center;color:rgba(19,54,42,.4);
  font-family:'Archivo';font-weight:700;font-size:.78rem;text-align:center;padding:14px;z-index:1}
.gal .cap{position:absolute;left:16px;bottom:14px;z-index:2;color:#fff}
.gal .cap b{display:block;font-family:'Fraunces';font-size:1.05rem;font-weight:600}
.gal .cap span{font-size:.78rem;opacity:.9}
.gal .pill{position:absolute;top:12px;left:12px;z-index:2;background:var(--clay);color:#fff;
  font-size:.68rem;font-weight:700;padding:5px 11px;border-radius:100px;letter-spacing:.05em;text-transform:uppercase}
.gal.tall{grid-row:span 2}
.gal.wide{grid-column:span 2}
.gal:hover{transform:translateY(-4px);transition:transform .3s}
@media(max-width:900px){.gal-grid{grid-template-columns:1fr 1fr}.gal.wide{grid-column:span 2}}
@media(max-width:560px){.gal-grid{grid-template-columns:1fr 1fr;grid-auto-rows:150px}.gal.wide,.gal.tall{grid-column:auto;grid-row:auto}}

/* ---------- BEFORE / AFTER ---------- */
.beforeafter{background:var(--cream)}
.ba-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.ba{background:var(--paper);border-radius:20px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-sm)}
.ba-imgs{display:grid;grid-template-columns:1fr 1fr;position:relative}
.ba-imgs .side{aspect-ratio:4/3;position:relative;display:grid;place-items:center}
.ba-imgs .before{background:linear-gradient(155deg,#9a8f7a,#7c7160)}
.ba-imgs .after{background:linear-gradient(155deg,#e9d9bf,#d4bd97)}
.ba-imgs .side .ph{color:rgba(255,255,255,.55);font-family:'Archivo';font-weight:700;font-size:.74rem;text-align:center;padding:10px}
.ba-imgs .after .ph{color:rgba(19,54,42,.4)}
.ba-imgs .tag{position:absolute;top:12px;left:12px;font-size:.66rem;font-weight:800;letter-spacing:.08em;
  text-transform:uppercase;padding:5px 11px;border-radius:100px}
.ba-imgs .before .tag{background:rgba(19,33,28,.78);color:#fff}
.ba-imgs .after .tag{background:var(--clay);color:#fff}
.ba-imgs::after{content:"➜";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:44px;height:44px;background:var(--forest);color:#fff;border-radius:50%;display:grid;
  place-items:center;font-size:1.1rem;box-shadow:var(--shadow-sm);z-index:3}
.ba-body{padding:20px 24px}
.ba-body b{font-family:'Fraunces';font-size:1.15rem;font-weight:600;display:block}
.ba-body span{font-size:.85rem;color:#6a7972}
@media(max-width:760px){.ba-grid{grid-template-columns:1fr}}

/* ---------- REVIEWS ---------- */
.reviews{background:var(--paper)}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.rev{background:var(--cream);border-radius:var(--r);padding:32px 30px;border:1px solid var(--line);
  position:relative;display:flex;flex-direction:column}
.rev .stars{margin-bottom:16px}
.rev p{font-size:1rem;color:#33433b;flex:1;font-family:'Fraunces';font-weight:400;font-style:italic;line-height:1.5}
.rev .who{display:flex;align-items:center;gap:14px;margin-top:22px}
.rev .av{width:46px;height:46px;border-radius:50%;background:linear-gradient(145deg,var(--clay),var(--clay-deep));
  color:#fff;display:grid;place-items:center;font-weight:800;font-family:'Archivo';flex:none}
.rev .who b{display:block;font-size:.95rem}
.rev .who span{font-size:.8rem;color:#5a6b62}
@media(max-width:900px){.rev-grid{grid-template-columns:1fr}.rev:nth-child(3){display:none}}

/* ---------- FAQ ---------- */
.faq{background:var(--cream)}
.faq-wrap{max-width:840px;margin:0 auto}
.q{background:var(--paper);border:1px solid var(--line);border-radius:14px;margin-bottom:14px;overflow:hidden}
.q summary{list-style:none;cursor:pointer;padding:24px 28px;font-family:'Fraunces';font-weight:600;
  font-size:1.18rem;display:flex;justify-content:space-between;align-items:center;gap:18px}
.q summary::-webkit-details-marker{display:none}
.q summary .plus{width:30px;height:30px;border-radius:50%;background:var(--cream-dim);flex:none;
  display:grid;place-items:center;transition:.3s;color:var(--forest)}
.q[open] summary .plus{background:var(--clay);color:#fff;transform:rotate(135deg)}
.q .a{padding:0 28px 26px;color:#4c5d54;font-size:1rem}

/* ---------- CTA ---------- */
.cta{padding:80px 0 100px}
.cta-box{background:linear-gradient(145deg,var(--clay),var(--clay-deep));border-radius:32px;
  padding:64px 56px;color:#fff;position:relative;overflow:hidden;text-align:center}
.cta-box::before{content:"";position:absolute;inset:0;opacity:.16;
  background-image:radial-gradient(rgba(255,255,255,.6) 1px,transparent 1px);background-size:22px 22px}
.cta-box h2{font-size:clamp(2rem,4vw,3rem);color:#fff;position:relative;margin-bottom:16px}
.cta-box p{font-size:1.12rem;opacity:.94;max-width:540px;margin:0 auto 32px;position:relative}
.cta-box .hero-actions{justify-content:center;position:relative}
.cta-box .btn-light{background:#fff;color:var(--clay-deep)}
.cta-box .btn-light:hover{transform:translateY(-3px)}
.cta-box .btn-outline{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.6)}
.cta-box .btn-outline:hover{background:rgba(255,255,255,.14)}

/* ---------- QUOTE FORM ---------- */
.quote{background:var(--forest-deep);color:var(--cream)}
.quote-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.quote .sec-head h2{color:var(--cream)}
.quote .sec-head p{color:rgba(244,239,228,.78)}
.quote-feats{display:flex;flex-direction:column;gap:16px;margin-top:30px}
.quote-feats div{display:flex;align-items:center;gap:13px;font-size:1rem}
.quote-feats .ck{width:30px;height:30px;border-radius:50%;background:var(--clay);color:#fff;
  display:grid;place-items:center;flex:none}
.form-card{background:var(--paper);border-radius:24px;padding:38px 34px;box-shadow:var(--shadow);color:var(--ink)}
.form-card h3{font-size:1.5rem;margin-bottom:6px}
.form-card .sub{color:#5a6b62;font-size:.92rem;margin-bottom:24px}
.field{margin-bottom:16px}
.field label{display:block;font-weight:600;font-size:.82rem;margin-bottom:7px;color:var(--forest)}
.field input,.field select{width:100%;padding:13px 16px;border:1.5px solid var(--line);border-radius:11px;
  font-family:'Archivo';font-size:.95rem;background:var(--paper);transition:border .2s,box-shadow .2s}
.field input:focus,.field select:focus{outline:none;border-color:var(--clay);box-shadow:0 0 0 4px rgba(232,98,61,.13)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-card .btn-primary{width:100%;justify-content:center;margin-top:8px;font-size:1.02rem;padding:16px}
.form-card .fine{font-size:.76rem;color:#7c8a82;text-align:center;margin-top:14px}
@media(max-width:900px){.quote-grid{grid-template-columns:1fr;gap:44px}}

/* ---------- FOOTER ---------- */
footer{background:var(--ink);color:rgba(244,239,228,.72);padding:72px 0 32px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:44px;margin-bottom:50px}
footer .logo{color:var(--cream);margin-bottom:18px}
footer .logo small{color:var(--sage)}
footer p.blurb{font-size:.92rem;max-width:280px}
.foot-col h5{color:var(--cream);font-family:'Archivo';font-weight:700;font-size:.82rem;
  letter-spacing:.14em;text-transform:uppercase;margin-bottom:18px}
.foot-col a{display:block;margin-bottom:11px;font-size:.92rem;transition:color .2s,padding .2s}
.foot-col a:hover{color:var(--clay);padding-left:4px}
.foot-contact div{display:flex;gap:10px;margin-bottom:14px;font-size:.92rem;align-items:flex-start}
.foot-contact .ic{color:var(--clay);flex:none;margin-top:2px}
.foot-bottom{border-top:1px solid rgba(244,239,228,.12);padding-top:26px;display:flex;
  justify-content:space-between;gap:18px;flex-wrap:wrap;font-size:.82rem}
@media(max-width:900px){.foot-grid{grid-template-columns:1fr 1fr;gap:36px}}
@media(max-width:520px){.foot-grid{grid-template-columns:1fr}}

/* ---------- STICKY MOBILE CTA ---------- */
.mobile-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:80;background:var(--paper);
  border-top:1px solid var(--line);padding:10px 16px;gap:10px;box-shadow:0 -10px 30px -16px rgba(0,0,0,.3)}
.mobile-bar .btn{flex:1;justify-content:center;padding:14px}
@media(max-width:760px){.mobile-bar{display:flex}body{padding-bottom:74px}}

/* reveal */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- BREADCRUMBS ---------- */
.crumbs{background:var(--cream);border-bottom:1px solid var(--line);padding:14px 0;font-size:.85rem}
.crumbs a{color:#5a6b62;font-weight:600}
.crumbs a:hover{color:var(--clay)}
.crumbs span{color:var(--ink);font-weight:700}
.crumbs i{font-style:normal;opacity:.4;margin:0 8px}

/* ---------- PAGE HERO (subpages) ---------- */
.phero{background:linear-gradient(155deg,var(--forest),var(--forest-deep));color:var(--cream);
  padding:72px 0;position:relative;overflow:hidden}
.phero::after{content:"";position:absolute;inset:0;opacity:.18;
  background-image:radial-gradient(rgba(244,239,228,.5) 1px,transparent 1px);background-size:24px 24px;
  -webkit-mask-image:radial-gradient(circle at 70% 30%,#000,transparent 75%)}
.phero .eyebrow{color:var(--clay)}
.phero h1{font-size:clamp(2.3rem,4.5vw,3.6rem);font-weight:900;margin:14px 0 14px;position:relative}
.phero h1 em{font-style:italic;color:var(--clay);font-weight:600}
.phero p{font-size:1.12rem;max-width:580px;color:rgba(244,239,228,.85);position:relative}

/* ---------- PROSE (service/city/blog body) ---------- */
.prose{max-width:760px;margin:0 auto}
.prose h2{font-size:clamp(1.7rem,3vw,2.3rem);margin:42px 0 16px;font-weight:600}
.prose h2 em{font-style:italic;color:var(--clay)}
.prose h3{font-size:1.3rem;margin:30px 0 12px;color:var(--forest)}
.prose p{color:#3c4f47;font-size:1.05rem;margin-bottom:18px}
.prose ul{margin:0 0 20px 22px;color:#3c4f47}
.prose li{margin-bottom:9px;font-size:1.04rem}
.prose strong{color:var(--ink)}

/* ---------- CARD GRID (landing pages) ---------- */
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.lcard{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:32px 28px;
  transition:transform .3s,box-shadow .3s;display:flex;flex-direction:column}
.lcard:hover{transform:translateY(-7px);box-shadow:var(--shadow)}
.lcard .ic{width:54px;height:54px;border-radius:14px;background:linear-gradient(145deg,var(--forest),var(--forest-deep));
  color:var(--cream);display:grid;place-items:center;margin-bottom:18px}
.lcard h3{font-size:1.3rem;margin-bottom:10px}
.lcard p{color:#4c5d54;font-size:.96rem;flex:1;margin-bottom:16px}
.lcard a.more{font-weight:700;color:var(--forest);display:inline-flex;align-items:center;gap:7px;font-size:.92rem}
@media(max-width:900px){.card-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.card-grid{grid-template-columns:1fr}}

/* ---------- BLOG ---------- */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.bcard{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
  transition:transform .3s,box-shadow .3s;display:flex;flex-direction:column}
.bcard:hover{transform:translateY(-7px);box-shadow:var(--shadow)}
.bcard .thumb{aspect-ratio:16/10;background:linear-gradient(155deg,#e9d9bf,#cbb592);position:relative;
  display:grid;place-items:center;color:rgba(19,54,42,.4);font-weight:700;font-size:.78rem;text-align:center;padding:14px}
.bcard .thumb .cat{position:absolute;top:12px;left:12px;background:var(--clay);color:#fff;font-size:.66rem;
  font-weight:700;padding:5px 11px;border-radius:100px;text-transform:uppercase;letter-spacing:.05em}
.bcard .bbody{padding:24px 24px 26px;display:flex;flex-direction:column;flex:1}
.bcard .meta{font-size:.78rem;color:#8a978f;font-weight:600;margin-bottom:10px}
.bcard h3{font-size:1.25rem;margin-bottom:10px;line-height:1.2}
.bcard p{color:#4c5d54;font-size:.94rem;flex:1;margin-bottom:16px}
.bcard a.more{font-weight:700;color:var(--forest);font-size:.9rem}
@media(max-width:900px){.blog-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.blog-grid{grid-template-columns:1fr}}

/* article */
.article{padding:70px 0}
.article .prose img{border-radius:16px;margin:24px 0}
.article .ph-img{aspect-ratio:16/9;border-radius:16px;background:linear-gradient(155deg,#e9d9bf,#cbb592);
  display:grid;place-items:center;color:rgba(19,54,42,.4);font-weight:700;font-size:.85rem;margin:28px 0;text-align:center;padding:18px}
.article .byline{display:flex;align-items:center;gap:12px;margin:8px 0 0;color:#8a978f;font-size:.85rem;font-weight:600}
