@import url('brand.css'); /* ALL brand tokens live in brand.css — edit there, not here */
*{margin:0;padding:0;box-sizing:border-box}
html{scrollbar-width:thin}
body{font-family:var(--display);background:var(--paper);color:var(--ink);line-height:1.5;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.mono{font-family:var(--mono);font-weight:500;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft)}
.mono b{color:var(--amber);font-weight:500}
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
.rule{border-top:1px solid var(--line)}

/* ===== header ===== */
header{position:fixed;inset:0 0 auto 0;z-index:200;transition:background .35s,border-color .35s;border-bottom:1px solid transparent}
header.solid{background:rgba(244,242,236,.88);backdrop-filter:blur(12px);border-color:var(--line)}
.hbar{display:flex;align-items:center;justify-content:space-between;padding:12px var(--pad);max-width:var(--maxw);margin:0 auto}
.brand{display:block}
.brand svg{display:block;height:112px;width:auto}
@media(max-width:640px){.brand svg{height:80px}}
footer .brand svg{height:76px}
.brand .serif{font-family:var(--display)}
.brand .sans{font-family:var(--body)}

/* homepage: header sits over the dark hero image until it goes solid */
header.over-dark:not(.solid) .hnav>a,
header.over-dark:not(.solid) .has-drop>a{color:rgba(244,240,232,.92)}
header.over-dark:not(.solid) .hnav>a:hover,
header.over-dark:not(.solid) .has-drop>a:hover{color:#fff}
header.over-dark:not(.solid) .hcta{border-color:rgba(244,240,232,.85);color:#F4F0E8!important}
header.over-dark:not(.solid) .hcta:hover{background:#F4F0E8;color:#2A2825!important}
header.over-dark:not(.solid) .burger span{background:#F4F0E8}
header.over-dark:not(.solid) .brand svg text{fill:#F4F0E8}
header.over-dark:not(.solid) .brand svg text.sans{fill:#E2AA4E}
.hnav{display:flex;gap:34px;align-items:center}
.hnav>a,.has-drop>a{font-size:14px;font-weight:500;color:var(--ink-soft);transition:color .2s}
.hnav>a:hover,.has-drop>a:hover{color:var(--ink)}
.hcta{font-family:var(--mono);font-size:12px!important;letter-spacing:.06em;text-transform:uppercase;border:1px solid var(--ink);padding:12px 22px;border-radius:100px;color:var(--ink)!important;transition:.3s!important}
.hcta:hover{background:var(--ink);color:var(--paper)!important}
.has-drop{position:relative;padding:10px 0}
.drop{position:absolute;top:100%;left:-18px;min-width:250px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:10px;opacity:0;visibility:hidden;transform:translateY(8px);transition:.25s;box-shadow:0 24px 60px rgba(22,21,18,.14)}
.has-drop:hover .drop{opacity:1;visibility:visible;transform:none}
.drop a{display:flex;justify-content:space-between;align-items:center;padding:11px 14px;border-radius:9px;font-size:14px;font-weight:500;color:var(--ink)}
.drop a:hover{background:var(--paper);color:var(--amber)}
.drop a span{font-family:var(--mono);font-size:10px;color:var(--ink-soft)}
.drop-label{display:block;padding:12px 14px 4px;margin-top:4px;border-top:1px solid var(--line);font-family:var(--mono);font-weight:500;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--amber)}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:6px;z-index:300}
.burger span{width:26px;height:2px;background:var(--ink);transition:.3s}
@media(max-width:880px){.hnav{display:none}.burger{display:flex}}
.mnav{position:fixed;inset:0;background:var(--ink);color:var(--paper);z-index:250;display:flex;flex-direction:column;justify-content:center;padding:0 var(--pad);opacity:0;visibility:hidden;transition:.35s}
.mnav.open{opacity:1;visibility:visible}
.mnav a{font-size:clamp(30px,7vw,44px);font-weight:600;letter-spacing:-.02em;text-transform:uppercase;padding:10px 0;border-bottom:1px solid rgba(244,242,236,.12)}
.mnav a:hover{color:var(--amber)}
.mnav .sub{font-size:clamp(18px,4.4vw,24px);font-weight:500;text-transform:none;padding-left:18px}
.mnav-close{position:absolute;top:22px;right:var(--pad);font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;background:none;border:1px solid rgba(244,242,236,.4);color:var(--paper);padding:10px 18px;border-radius:100px;cursor:pointer}

/* ===== reveals / parallax ===== */
.rv{opacity:0;transform:translateY(38px)}
.plx{overflow:hidden}
.plx img{width:100%;height:118%;object-fit:cover;will-change:transform}

/* ===== home hero — pinned scroll story (Design → Build → Renovate) ===== */
.hs{position:relative;height:100svh;overflow:hidden;color:#F4F0E8}
.hs-media{position:absolute;inset:0}
.hs-img{position:absolute;inset:0;opacity:0}
.hs-img:first-child{opacity:1}
.hs-img img{width:100%;height:100%;object-fit:cover;transform:scale(1.08);will-change:transform}
.hs-media::after{content:"";position:absolute;inset:0;background:
  linear-gradient(to bottom,rgba(22,19,15,.6) 0%,rgba(22,19,15,0) 26%),
  linear-gradient(75deg,rgba(22,19,15,.78) 0%,rgba(22,19,15,.42) 48%,rgba(22,19,15,.15) 100%)}
.hs-inner{position:relative;z-index:2;height:100%;display:flex;flex-direction:column;justify-content:flex-start;padding-top:clamp(150px,20vh,190px);padding-bottom:clamp(28px,5vh,60px)}
.hs .meta-row{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap}
.hs .meta-row .mono{color:rgba(244,240,232,.75)}
.hs .meta-row .mono b{color:var(--amber-light)}

/* the always-visible small tagline stack — active word highlighted per stage */
.hs-stack{list-style:none;display:flex;flex-direction:column;gap:9px;margin-top:clamp(20px,4vh,40px)}
.hs-stack li{font-family:var(--display);font-size:clamp(17px,1.9vw,24px);letter-spacing:.02em;text-transform:uppercase;color:rgba(244,240,232,.42);display:flex;gap:14px;align-items:baseline;transition:color .35s}
.hs-stack li .n{font-family:var(--mono);font-weight:500;font-size:11px;letter-spacing:.14em;color:rgba(244,240,232,.35);transition:color .35s}
.hs-stack li.active{color:#F4F0E8}
.hs-stack li.active .n{color:var(--amber-light)}

/* the big word — one at a time inside a masked line */
.hs-bottom{margin-top:auto}
.hs-bigmask{position:relative;height:1.06em;overflow:hidden;font-size:clamp(48px,8.6vw,140px);line-height:1;letter-spacing:.005em;font-weight:500;text-transform:uppercase}
.hb{position:absolute;left:0;bottom:0;white-space:nowrap;visibility:hidden;font-family:var(--display)}
.hb em{font-style:normal;color:var(--amber-light)}
.hero-sub{display:flex;justify-content:space-between;align-items:flex-end;gap:28px;flex-wrap:wrap;margin-top:26px}
.hs .hero-sub p{max-width:46ch;font-size:clamp(16px,1.4vw,19px);color:rgba(244,240,232,.88)}
.hs .hero-sub .mono{color:rgba(244,240,232,.7)}

/* ===== inner page hero ===== */
.phero{padding:clamp(150px,20vh,220px) 0 0}
.phero .crumb{margin-bottom:26px;display:block}
.phero h1{font-size:clamp(44px,7.4vw,110px);line-height:.95;letter-spacing:-.04em;font-weight:600;text-transform:uppercase;max-width:14ch}
.phero h1 em{font-style:normal;color:var(--amber)}
.phero-sub{display:flex;justify-content:space-between;align-items:flex-end;gap:28px;flex-wrap:wrap;margin:30px 0 52px}
.phero-sub p{max-width:52ch;font-size:clamp(16px,1.4vw,19px);color:var(--ink-soft)}
.phero-media{height:58vh;border-radius:18px;position:relative}
.phero-media .tag{position:absolute;left:22px;bottom:20px;color:#fff;font-family:var(--mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;background:rgba(15,14,12,.55);padding:9px 14px;border-radius:100px;backdrop-filter:blur(6px);z-index:2}

/* ===== marquee ===== */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;padding:18px 0;background:var(--paper)}
.mq-track{display:flex;width:max-content;will-change:transform}
.mq-track span{font-family:var(--mono);font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);padding:0 26px;white-space:nowrap}
.mq-track span::after{content:"·";color:var(--amber);margin-left:52px}

/* ===== statement ===== */
.statement{padding:clamp(90px,12vw,170px) 0}
.statement .mono{margin-bottom:26px;display:block}
.statement p{font-size:clamp(26px,3.6vw,54px);line-height:1.18;letter-spacing:-.02em;font-weight:500;max-width:22ch}
.statement p .w{opacity:.14}

/* ===== service rows (home) ===== */
.services{padding-bottom:clamp(60px,8vw,120px)}
.svc-row{display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);gap:clamp(24px,5vw,80px);align-items:center;padding:clamp(48px,7vw,96px) 0;border-top:1px solid var(--line)}
.svc-row:nth-child(even){grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr)}
.svc-row:nth-child(even) .svc-media{order:-1}
.svc-num{font-family:var(--mono);font-size:13px;color:var(--amber);margin-bottom:18px;display:block}
.svc-row h3{font-size:clamp(30px,4vw,54px);letter-spacing:-.03em;font-weight:600;line-height:1.02;margin-bottom:18px;text-transform:uppercase}
.svc-row p{color:var(--ink-soft);font-size:17px;max-width:46ch;margin-bottom:26px}
.svc-list{list-style:none;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:30px}
.svc-list li{font-family:var(--mono);font-size:12px;letter-spacing:.05em;text-transform:uppercase;border:1px solid var(--line);padding:8px 14px;border-radius:100px;color:var(--ink-soft)}
.svc-link{font-family:var(--mono);font-size:13px;letter-spacing:.08em;text-transform:uppercase;display:inline-flex;align-items:center;gap:10px;color:var(--ink);border-bottom:1px solid var(--ink);padding-bottom:5px;transition:.25s}
.svc-link:hover{color:var(--amber);border-color:var(--amber);gap:16px}
.svc-media{position:relative;border-radius:16px;aspect-ratio:4/3}
@media(max-width:820px){.svc-row,.svc-row:nth-child(even){grid-template-columns:1fr}.svc-row:nth-child(even) .svc-media{order:0}}

/* ===== generic content blocks ===== */
.sec{padding:clamp(70px,9vw,130px) 0}
.sec-head{max-width:720px;margin-bottom:clamp(36px,5vw,64px)}
.sec-head h2{font-size:clamp(30px,4.4vw,60px);letter-spacing:-.03em;text-transform:uppercase;font-weight:600;line-height:1;margin-top:14px}
.sec-head p{font-size:17px;color:var(--ink-soft);margin-top:18px;max-width:56ch}
.split2{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:clamp(28px,5vw,80px);align-items:start}
.split2 .plx{border-radius:16px;aspect-ratio:4/3}
.split2 h3{font-size:clamp(24px,3vw,38px);letter-spacing:-.02em;text-transform:uppercase;font-weight:600;line-height:1.05;margin-bottom:16px}
.split2 p{color:var(--ink-soft);font-size:16.5px;margin-bottom:16px;max-width:52ch}
@media(max-width:820px){.split2{grid-template-columns:1fr}}

/* numbered list rows (services index on inner pages) */
.lrows{border-top:1px solid var(--line)}
.lrow{display:grid;grid-template-columns:90px minmax(0,1fr) minmax(0,1.4fr);gap:clamp(16px,3vw,40px);padding:clamp(26px,4vw,44px) 0;border-bottom:1px solid var(--line);align-items:baseline;transition:background .25s}
.lrow:hover{background:rgba(201,134,43,.06)}
.lrow .n{font-family:var(--mono);font-size:13px;color:var(--amber)}
.lrow h4{font-size:clamp(20px,2.4vw,30px);letter-spacing:-.02em;font-weight:600;text-transform:uppercase;line-height:1.1}
.lrow p{color:var(--ink-soft);font-size:15.5px;max-width:60ch}
@media(max-width:720px){.lrow{grid-template-columns:60px 1fr}.lrow p{grid-column:2}}

/* pill grid */
.pills{list-style:none;display:flex;flex-wrap:wrap;gap:10px}
.pills li{font-family:var(--mono);font-size:12px;letter-spacing:.05em;text-transform:uppercase;border:1px solid var(--line);padding:10px 16px;border-radius:100px;color:var(--ink-soft)}
.pills li b{color:var(--amber);font-weight:500;margin-right:6px}

/* tick list */
.ticks{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:14px 24px;margin:26px 0}
.ticks li{display:flex;gap:11px;font-weight:500;font-size:15.5px;align-items:flex-start}
.ticks li::before{content:"—";color:var(--amber);font-weight:700}
@media(max-width:640px){.ticks{grid-template-columns:1fr}}

/* ===== dark band / stats ===== */
.band{background:var(--ink);color:var(--paper);padding:clamp(80px,10vw,140px) 0}
.band .mono{color:rgba(244,242,236,.5)}
.band h2{font-size:clamp(30px,4.4vw,60px);letter-spacing:-.03em;text-transform:uppercase;font-weight:600;line-height:1;margin-top:14px}
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:36px;margin-top:54px}
.stat b{font-size:clamp(44px,5.6vw,86px);font-weight:600;letter-spacing:-.04em;display:block;line-height:1}
.stat b i{font-style:normal;color:var(--amber)}
.stat span{font-family:var(--mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:rgba(244,242,236,.55);display:block;margin-top:14px}
@media(max-width:820px){.stat-grid{grid-template-columns:1fr 1fr}}

/* ===== horizontal work (home) ===== */
.work{background:var(--ink);color:var(--paper);overflow:hidden}
.work .head{padding-bottom:30px}
.work h2{font-size:clamp(34px,5vw,72px);letter-spacing:-.03em;text-transform:uppercase;font-weight:600;margin-top:14px}
.htrack{display:flex;gap:26px;padding:10px var(--pad) 90px;width:max-content}
.card{position:relative;width:clamp(300px,38vw,560px);aspect-ratio:4/5;border-radius:16px;overflow:hidden;flex-shrink:0}
.card img{width:100%;height:100%;object-fit:cover;transition:transform .7s cubic-bezier(.2,.7,.2,1)}
.card:hover img{transform:scale(1.06)}
.card .cap{position:absolute;inset:auto 0 0 0;padding:70px 22px 20px;background:linear-gradient(to top,rgba(10,9,8,.82),transparent);display:flex;justify-content:space-between;align-items:flex-end;gap:10px}
.card .cap b{font-size:19px;font-weight:600;letter-spacing:-.01em}
.card .cap span{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:rgba(244,242,236,.65)}

/* ===== gallery page ===== */
.filters{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:38px}
.chip{font-family:var(--mono);font-size:12.5px;letter-spacing:.05em;text-transform:uppercase;font-weight:500;padding:11px 20px;border-radius:100px;border:1px solid var(--line);background:transparent;color:var(--ink-soft);cursor:pointer;transition:.2s}
.chip:hover{border-color:var(--ink);color:var(--ink)}
.chip.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.ggrid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.gitem{position:relative;border-radius:14px;overflow:hidden;aspect-ratio:4/5;cursor:pointer}
.gitem img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.gitem:hover img{transform:scale(1.07)}
.gitem .cap{position:absolute;inset:auto 0 0 0;padding:60px 18px 16px;background:linear-gradient(to top,rgba(10,9,8,.8),transparent);color:#fff;display:flex;justify-content:space-between;align-items:flex-end;gap:8px;opacity:0;transition:.3s}
.gitem:hover .cap{opacity:1}
.gitem .cap b{font-size:16px;font-weight:600}
.gitem .cap span{font-family:var(--mono);font-size:10.5px;letter-spacing:.07em;text-transform:uppercase;color:rgba(244,242,236,.7)}
@media(max-width:900px){.ggrid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.ggrid{grid-template-columns:1fr}}
.lightbox{position:fixed;inset:0;background:rgba(12,11,9,.94);z-index:400;display:none;align-items:center;justify-content:center;padding:4vw}
.lightbox.open{display:flex}
.lightbox img{max-width:92vw;max-height:86vh;border-radius:12px;object-fit:contain}
.lightbox button{position:absolute;top:24px;right:26px;font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;background:none;border:1px solid rgba(244,242,236,.4);color:#f4f2ec;padding:10px 18px;border-radius:100px;cursor:pointer}

/* ===== reviews ===== */
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--line)}
.rev{padding:38px 34px;border-bottom:1px solid var(--line);border-right:1px solid var(--line)}
.rev:first-child{border-left:1px solid var(--line)}
.rev .stars{color:var(--amber);letter-spacing:4px;margin-bottom:20px}
.rev p{font-size:16.5px;line-height:1.6;color:var(--ink-soft);margin-bottom:26px}
.rev b{font-size:14px;font-weight:600;display:block}
.rev span{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft)}
.rev-note{font-family:var(--mono);font-size:11.5px;color:var(--ink-soft);margin-top:22px;letter-spacing:.04em}

/* accreditation logos (social proof) */
.proof{display:flex;align-items:center;gap:22px;flex-wrap:wrap;margin-top:38px}
.proof .mono{max-width:26ch}
.proof-logos{display:inline-flex;gap:14px;align-items:stretch}
.proof-logos img{height:52px;width:auto;background:#fff;border:1px solid var(--line);border-radius:12px;padding:10px 16px;box-sizing:border-box;object-fit:contain}
@media(max-width:640px){.proof-logos img{height:44px;padding:8px 12px}}
@media(max-width:900px){.rev-grid{grid-template-columns:1fr}.rev{border-left:1px solid var(--line)}}

/* ===== CTA band ===== */
.cta{background:var(--amber);color:#fff;padding:clamp(90px,13vw,180px) 0}
.cta h2{font-size:clamp(48px,8.5vw,132px);line-height:.95;letter-spacing:-.04em;text-transform:uppercase;font-weight:600;margin:18px 0 40px}
.cta .mono{color:rgba(255,255,255,.75)}
.cta-row{display:flex;gap:16px;flex-wrap:wrap;align-items:center}
.btn-xl{font-family:var(--mono);font-size:13px;letter-spacing:.08em;text-transform:uppercase;padding:20px 36px;border-radius:100px;border:1px solid #fff;color:#fff;transition:.3s;display:inline-flex;gap:12px;align-items:center;background:none;cursor:pointer}
.btn-xl.fill{background:#fff;color:var(--amber)}
.btn-xl:hover{transform:translateY(-3px)}
.btn-dark{border-color:var(--ink);color:var(--ink)}
.btn-dark.fill{background:var(--ink);color:var(--paper)}

/* ===== contact ===== */
.c-grid{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);gap:clamp(30px,5vw,80px);align-items:start}
@media(max-width:880px){.c-grid{grid-template-columns:1fr}}
form.cf{display:grid;gap:18px}
.cf .f2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:640px){.cf .f2{grid-template-columns:1fr}}
.cf label{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);display:block;margin-bottom:8px}
.cf input,.cf textarea,.cf select{width:100%;font-family:var(--display);font-size:16px;padding:16px 18px;border:1px solid var(--line);border-radius:12px;background:#fff;color:var(--ink);transition:border-color .2s}
.cf input:focus,.cf textarea:focus,.cf select:focus{outline:none;border-color:var(--amber)}
.cf textarea{min-height:150px;resize:vertical}
.c-info{border:1px solid var(--line);border-radius:18px;padding:clamp(24px,3vw,40px);background:#fff}
.c-info h4{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);margin:22px 0 8px}
.c-info h4:first-child{margin-top:0}
.c-info a.big{font-size:clamp(20px,2.4vw,28px);font-weight:600;letter-spacing:-.02em;display:block}
.c-info a.big:hover{color:var(--amber)}
.c-info p{color:var(--ink-soft);font-size:15.5px}
.map{border-radius:18px;overflow:hidden;border:1px solid var(--line);margin-top:clamp(40px,6vw,70px)}
.map iframe{display:block;width:100%;height:440px;border:0;filter:grayscale(1) contrast(1.05)}
.form-ok{display:none;background:rgba(201,134,43,.1);border:1px solid var(--amber);color:#5a4318;border-radius:12px;padding:18px 20px;font-size:15px}

/* ===== footer ===== */
footer{background:var(--ink);color:rgba(244,242,236,.65);padding:90px 0 0}
.f-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.3fr;gap:44px;padding-bottom:70px}
footer h4{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:rgba(244,242,236,.4);margin-bottom:20px}
footer ul{list-style:none}
footer li{margin-bottom:12px;font-size:15px}
footer a:hover{color:var(--amber)}
.f-brand p{max-width:30ch;font-size:15px;margin-top:14px}
.f-word{overflow:hidden;padding:0 var(--pad)}
.f-word b{display:block;font-size:clamp(70px,14.5vw,230px);line-height:.82;letter-spacing:-.04em;font-weight:700;color:rgba(244,242,236,.1);text-transform:uppercase;transform:translateY(30%)}
.f-bottom{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;padding:26px var(--pad);border-top:1px solid rgba(244,242,236,.12);font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:rgba(244,242,236,.4);max-width:var(--maxw);margin:0 auto}
@media(max-width:900px){.f-top{grid-template-columns:1fr 1fr}}

/* ===== BRAND TYPOGRAPHY — Fraunces display serif (brand pack v1.0) ===== */
.hero h1,.phero h1,.sec-head h2,.work h2,.band h2,.cta h2,.svc-row h3,.split2 h3,.lrow h4,.statement p,.f-word b,.stat b,.c-info a.big{
  font-family:var(--display);
  font-weight:500;
  letter-spacing:.01em;
}
.hero h1,.phero h1{letter-spacing:.005em}
.f-word b{font-weight:600}

/* ===== MOBILE OPTIMISATION ===== */
@media(max-width:640px){
  .hbar{padding:8px var(--pad)}
  /* hero: keep RENOVATE. on one line on small phones, tidy spacing */
  .hs-bigmask{font-size:clamp(38px,12.5vw,140px)}
  .hs .hero-sub p{font-size:15px}
  .hs .meta-row .mono{font-size:11px}
  .hs-stack{gap:7px}
  .hero-sub{margin-top:18px}
  /* horizontal work: bigger cards relative to screen, tighter track */
  .card{width:80vw}
  .htrack{gap:16px;padding-bottom:64px}
  /* comfortable paddings and tap targets */
  .svc-row{padding:40px 0}
  .lrow{padding:22px 0}
  .rev{padding:26px 20px}
  .c-info{padding:22px}
  .map iframe{height:320px}
  .filters{gap:8px}
  .chip{padding:9px 14px;font-size:11.5px}
  /* CTAs: full-width stacked buttons, easy thumbs */
  .btn-xl{padding:16px 24px;font-size:12px}
  .cta-row{flex-direction:column;align-items:stretch}
  .cta-row .btn-xl{justify-content:center}
  /* stats + footer breathe on one column */
  .stat-grid{gap:26px 18px;margin-top:38px}
  .f-top{grid-template-columns:1fr;gap:32px}
  .phero-media{height:44vh}
  .mnav a{padding:8px 0}
}

@media (prefers-reduced-motion: reduce){
  *{animation:none!important;transition:none!important}
  .rv{opacity:1;transform:none}
  .hero h1 .l span{transform:none}
  .hero-media{clip-path:none}
  .f-word b{transform:none}
}
