/* Self-hosted latin fonts (variable woff2) — replaces the render-blocking Google Fonts request */
@font-face{font-family:'Playfair Display';font-style:normal;font-weight:400 800;font-display:swap;src:url('/assets/fonts/playfair-latin.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Source Serif 4';font-style:normal;font-weight:400 700;font-display:swap;src:url('/assets/fonts/source-serif-latin.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Caveat';font-style:normal;font-weight:500 700;font-display:swap;src:url('/assets/fonts/caveat-latin.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}

:root{
  --bg:#F5EFE2; --surface:#FFFCF5; --ink:#2A1F14; --ink-soft:#6B5746;
  --accent:#8B2A2A; --accent-deep:#6E1F1F; --accent-on:#FAF7EE;
  --gold:#C9A24B; --line:rgba(42,31,20,.14); --line-soft:rgba(42,31,20,.08);
  --radius:8px; --shadow:0 24px 60px -34px rgba(34,20,10,.55);
  --maxw:1180px; --sec:clamp(60px,8vw,116px);
  --font-h:'Playfair Display',Georgia,serif; --font-b:'Source Serif 4',Georgia,serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--font-b);
  font-size:clamp(16px,1.05vw,18px);line-height:1.65;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:var(--font-h);line-height:1.1;margin:0;font-weight:700;text-wrap:balance;letter-spacing:-.012em}
p{margin:0}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
/* universal keyboard focus ring (a11y) — accent outline + offset on every focusable surface */
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible,
summary:focus-visible,details:focus-visible,[tabindex]:focus-visible,.btn:focus-visible{
  outline:2px solid var(--accent);outline-offset:4px}
/* on the dark over-photo heroes + dark sections, switch the ring to the warm tan so it stays legible */
.phero a:focus-visible,.phero button:focus-visible,.way a:focus-visible,.way button:focus-visible,
.tst a:focus-visible,.cta a:focus-visible,.cta button:focus-visible,footer.site a:focus-visible,
.drawer a:focus-visible,.drawer button:focus-visible{outline-color:#E7C8A0}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,4vw,44px)}
.skip{position:absolute;left:-9999px;top:0;background:var(--accent);color:#fff;padding:10px 16px;z-index:200;border-radius:0 0 8px 0}
.skip:focus{left:0}
.eyebrow{font-family:var(--font-b);text-transform:uppercase;letter-spacing:.18em;font-size:.76rem;font-weight:700;color:var(--accent);display:inline-flex;align-items:center;gap:.7em}
.eyebrow::before{content:"";width:28px;height:2px;background:var(--accent)}
.eyebrow.c::before{display:none}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55em;cursor:pointer;border:0;
  font-family:var(--font-b);font-weight:700;font-size:1rem;padding:.95em 1.7em;border-radius:var(--radius);
  transition:transform .16s ease,box-shadow .22s ease,background .2s;line-height:1.1;text-align:center}
.btn-primary{background:linear-gradient(180deg,#9A3030,var(--accent));color:var(--accent-on);box-shadow:0 10px 24px -12px rgba(139,42,42,.8)}
.btn-primary:hover{background:linear-gradient(180deg,var(--accent),var(--accent-deep));transform:translateY(-2px);box-shadow:0 8px 18px -8px rgba(110,31,31,.92)}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}
.btn-lg{font-size:1.06rem;padding:1.05em 2em}

/* ---------- header (transparent over the immersive hero, solid cream once scrolled) ---------- */
.hdr{position:fixed;top:0;left:0;right:0;z-index:60;border-bottom:1px solid transparent;
  transition:background .3s ease,box-shadow .3s ease,border-color .3s ease}
.hdr::before{content:"";position:absolute;left:0;right:0;top:0;height:230%;pointer-events:none;z-index:-1;
  background:linear-gradient(180deg,rgba(20,12,6,.5),rgba(20,12,6,0));transition:opacity .3s ease}
.hdr.scrolled{background:color-mix(in srgb,var(--bg) 93%,transparent);backdrop-filter:saturate(150%) blur(10px);border-bottom-color:var(--line)}
.hdr.scrolled::before{opacity:0}
.hdr .wrap{display:flex;align-items:center;justify-content:space-between;gap:18px;height:74px}
.brand img{height:48px;width:auto;display:block;filter:drop-shadow(0 2px 8px rgba(20,12,6,.35));transition:filter .3s}
.hdr.scrolled .brand img{filter:none}
@media(max-width:560px){.brand img{height:40px}}
.mainnav{display:flex;align-items:center;gap:30px}
.mainnav>a,.has-dd>button{font-family:var(--font-b);font-weight:600;font-size:.96rem;color:#fff;
  background:none;border:0;cursor:pointer;padding:6px 0;position:relative;display:inline-flex;align-items:center;gap:.35em;
  text-shadow:0 1px 9px rgba(20,12,6,.5);transition:color .25s,text-shadow .25s}
.hdr.scrolled .mainnav>a,.hdr.scrolled .has-dd>button{color:var(--ink);text-shadow:none}
.mainnav>a::after,.has-dd>button::after{content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:currentColor;transition:width .22s}
.mainnav>a:hover,.has-dd:hover>button{color:#fff}
.hdr.scrolled .mainnav>a:hover,.hdr.scrolled .has-dd:hover>button{color:var(--accent)}
.mainnav>a:hover::after,.has-dd:hover>button::after{width:100%}
.has-dd{position:relative}
.has-dd>button .chev{font-size:.7em;transition:transform .2s}
.has-dd:hover>button .chev,.has-dd:focus-within>button .chev{transform:rotate(180deg)}
/* hover-bridge so the gap between trigger and panel never closes the menu */
.has-dd::after{content:"";position:absolute;left:-10px;right:-10px;top:100%;height:18px}
.dd{position:absolute;left:50%;transform:translateX(-50%) translateY(8px);top:calc(100% + 16px);
  background:var(--surface);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);
  padding:10px;min-width:368px;opacity:0;visibility:hidden;transition:opacity .2s,transform .2s;z-index:70}
.has-dd:hover .dd,.has-dd:focus-within .dd{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.dd a{display:flex;gap:12px;align-items:flex-start;padding:11px 12px;border-radius:8px;transition:background .15s}
.dd a:hover{background:var(--bg)}
/* §4.8 service-icon depth: accent ring + soft drop-shadow + inner top-light */
.dd a .ic{flex:0 0 auto;width:34px;height:34px;border-radius:8px;background:color-mix(in srgb,var(--accent) 12%,transparent);
  display:grid;place-items:center;color:var(--accent);font-size:1.05rem;
  box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 26%,transparent),
    0 6px 14px -8px rgba(110,31,31,.4),inset 0 1px 0 rgba(255,255,255,.5);
  transition:box-shadow .18s ease,background .18s ease}
.dd a:hover .ic{background:color-mix(in srgb,var(--accent) 18%,transparent);
  box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 40%,transparent),
    0 8px 18px -8px rgba(110,31,31,.5),inset 0 1px 0 rgba(255,255,255,.55)}
.dd a b{display:block;font-family:var(--font-b);font-weight:700;font-size:.93rem;color:var(--ink)}
.dd a small{color:var(--ink-soft);font-size:.8rem;line-height:1.35}
.hdr .hdr-actions{display:flex;align-items:center;gap:16px}
.hdr .callbtn{font-family:var(--font-h);font-weight:700;color:#fff;font-size:1.06rem;display:inline-flex;align-items:center;gap:.45em;text-shadow:0 1px 9px rgba(20,12,6,.5);transition:color .25s,text-shadow .25s}
.hdr.scrolled .callbtn{color:var(--accent);text-shadow:none}
.hdr .callbtn .ph-ic{width:20px;height:20px}
.burger{display:none;background:none;border:0;cursor:pointer;width:44px;height:44px;flex-direction:column;gap:5px;justify-content:center;align-items:center}
.burger span{width:24px;height:2px;background:#fff;transition:.25s;box-shadow:0 1px 4px rgba(20,12,6,.4)}
.hdr.scrolled .burger span{background:var(--ink);box-shadow:none}
@media(max-width:980px){
  .mainnav,.hdr .callbtn{display:none}
  .burger{display:flex}
}
/* mobile drawer */
.drawer{position:fixed;inset:0;z-index:90;background:rgba(20,12,6,.5);opacity:0;visibility:hidden;transition:.25s}
.drawer.open{opacity:1;visibility:visible}
.drawer__panel{position:absolute;top:0;right:0;height:100%;width:min(86vw,360px);background:var(--bg);
  transform:translateX(100%);transition:transform .28s ease;padding:24px 22px;overflow-y:auto;box-shadow:var(--shadow)}
.drawer.open .drawer__panel{transform:translateX(0)}
.drawer__panel a{display:block;padding:13px 6px;font-family:var(--font-h);font-size:1.25rem;border-bottom:1px solid var(--line-soft)}
.drawer__panel .sub a{display:flex;align-items:center;min-height:44px;font-family:var(--font-b);font-size:1rem;padding:8px 6px 8px 18px;color:var(--ink-soft)}
.drawer__close{position:absolute;top:16px;right:16px;width:40px;height:40px;border:0;background:none;font-size:1.6rem;cursor:pointer;color:var(--ink)}

/* ---------- hero (immersive full-bleed image, ~1.5in padding, dark text on a light wash) ---------- */
.hero{position:relative;min-height:0;padding:0;display:flex;align-items:flex-end;overflow:hidden;background:var(--bg)}
/* photo sits on the RIGHT (~72%) — scaled down for crispness — and fades in from behind the headline; the left stays fully opaque cream */
.hero__media{position:absolute;top:0;right:0;bottom:0;width:72%;z-index:0;overflow:hidden;
  -webkit-mask-image:linear-gradient(112deg,transparent 0,transparent 23%,rgba(0,0,0,.5) 43%,#000 60%);
          mask-image:linear-gradient(112deg,transparent 0,transparent 23%,rgba(0,0,0,.5) 43%,#000 60%)}
.hero__media img{width:100%;height:100%;object-fit:cover;object-position:14% 44%}
.hero .wrap{position:relative;z-index:2;width:100%;padding-top:clamp(120px,15vh,150px);padding-bottom:clamp(112px,14vh,150px)}
.hero__inner{max-width:600px}
.hero .eyebrow{margin-bottom:13px;color:var(--accent)}
.hero .eyebrow::before{background:var(--accent)}
.hero h1{font-size:clamp(2.3rem,4.2vw,3.9rem);font-weight:800;margin-bottom:.3em;max-width:16ch;color:var(--ink);text-shadow:0 1px 2px rgba(248,243,233,.7)}
.hero h1 em,h1 .accent{font-style:italic;font-weight:600;color:var(--accent)}
.hero .lede{font-size:clamp(1.05rem,1.25vw,1.22rem);color:var(--ink-soft);max-width:42ch;margin-bottom:24px;text-shadow:0 1px 2px rgba(248,243,233,.8)}
.hero .cta-row{display:inline-grid;gap:12px;margin-bottom:20px;max-width:100%}
.hero .cta-row .btn{width:100%}
.hero .btn-ghost{border-color:var(--ink);color:var(--ink)}
.hero .btn-ghost:hover{border-color:var(--accent);color:var(--accent);background:rgba(139,42,42,.06)}
.hero .micro{display:flex;flex-wrap:wrap;gap:9px 22px;font-size:.88rem;color:var(--ink-soft);font-weight:600}
.hero .micro span{display:inline-flex;align-items:center;gap:.5em}
.hero .micro .star{color:var(--gold)}
/* ---- premium home hero: slow Ken Burns (reduced-motion safe) ---- */
@keyframes lc-kenburns{from{transform:scale(1.002)}to{transform:scale(1.075) translateY(-1.6%)}}
.hero__media img{animation:lc-kenburns 24s ease-in-out infinite alternate;transform-origin:64% 42%}
@media(prefers-reduced-motion:reduce){.hero__media img{animation:none}}
@media(max-width:760px){
  /* immersive full-bleed mobile home hero — text sits high over the sky, the house showcased below */
  .hero{position:relative;min-height:100svh;display:flex;align-items:stretch;overflow:hidden;background:var(--ink)}
  .hero__media{position:absolute;inset:0;width:100%;height:100%;-webkit-mask-image:none;mask-image:none}
  .hero__media img{object-position:50% 50%;transform-origin:50% 40%;animation:lc-kenburns 26s ease-in-out infinite alternate}
  .hero::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(180deg,rgba(20,12,6,.66) 0%,rgba(20,12,6,.4) 30%,rgba(20,12,6,.05) 42%,rgba(20,12,6,.05) 66%,rgba(20,12,6,.45) 78%,rgba(20,12,6,.86) 100%)}
  .hero .wrap{position:relative;z-index:2;width:auto;text-align:center;display:flex;flex-direction:column;padding:clamp(84px,13vh,116px) clamp(22px,6vw,30px) clamp(22px,5vw,34px)}
  .hero__inner{max-width:none;margin:0 auto;width:100%;display:flex;flex-direction:column;flex:1}
  .hero .eyebrow{color:#E7C8A0;justify-content:center;margin-bottom:12px}
  .hero .eyebrow::before{display:none}
  .hero h1{font-size:clamp(2rem,7.6vw,2.7rem);color:#fff;text-shadow:0 2px 18px rgba(0,0,0,.6);max-width:none;margin:0 auto}
  .hero h1 em{color:#E7C8A0}
  .hero .lede{color:rgba(255,255,255,.92);text-shadow:0 1px 12px rgba(0,0,0,.6);font-size:1rem;max-width:34ch;margin:16px auto 18px}
  /* one prominent button; Call becomes a quiet text link so the house shows + the CTA sits lower */
  .hero .cta-row{display:flex;flex-direction:column;align-items:center;gap:14px;max-width:340px;margin:auto auto 12px}
  .hero .cta-row .btn-primary{width:100%}
  .hero .cta-row .btn-ghost{width:auto;min-height:0;padding:0;border:0;border-radius:0;background:none;
    font-family:var(--font-b);font-weight:700;font-size:1.05rem;color:#fff;
    text-decoration:underline;text-underline-offset:5px;text-decoration-thickness:1.5px;text-decoration-color:rgba(255,255,255,.5);
    text-shadow:0 1px 10px rgba(0,0,0,.65)}
  .hero .cta-row .btn-ghost:hover{background:none;border:0;color:#E7C8A0;text-decoration-color:#E7C8A0}
  .hero .micro{justify-content:center;color:rgba(255,255,255,.92);text-shadow:0 1px 10px rgba(0,0,0,.6);gap:6px 16px;font-size:.82rem;margin-top:2px}
  .hero .micro .star{color:var(--gold)}
}
/* homepage: solid cream header (the hero's left is cream, so a transparent white nav would vanish) */
body.home .hdr{background:color-mix(in srgb,var(--bg) 95%,transparent);backdrop-filter:saturate(150%) blur(10px);border-bottom-color:var(--line)}
body.home .hdr::before{opacity:0}
body.home .hdr .mainnav>a,body.home .hdr .has-dd>button,body.home .hdr .callbtn{color:var(--ink);text-shadow:none}
body.home .hdr .mainnav>a:hover,body.home .hdr .has-dd:hover>button{color:var(--accent)}
body.home .burger span{background:var(--ink);box-shadow:none}
/* mobile: home hero is a dark immersive photo, so the header goes transparent over it (after the desktop rules to win source order) */
@media(max-width:760px){
  body.home .hdr{background:transparent;backdrop-filter:none;border-bottom-color:transparent}
  body.home .hdr::before{opacity:1}
  body.home .burger span{background:#fff;box-shadow:0 1px 4px rgba(20,12,6,.45)}
  body.home .hdr.scrolled{background:color-mix(in srgb,var(--bg) 95%,transparent);backdrop-filter:saturate(150%) blur(10px);border-bottom-color:var(--line)}
  body.home .hdr.scrolled::before{opacity:0}
  body.home .hdr.scrolled .burger span{background:var(--ink);box-shadow:none}
}

/* ---------- trust band ---------- */
.stats{background:var(--surface);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.stats .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;padding:30px clamp(20px,4vw,44px)}
.stats .st{text-align:center;display:flex;flex-direction:column;align-items:center}
.stats .st::before{content:"";width:34px;height:3px;border-radius:2px;background:var(--accent);margin-bottom:14px;opacity:.85}
.stats .st b{font-family:var(--font-h);font-size:clamp(1.8rem,3vw,2.5rem);font-weight:700;color:var(--accent);display:block;line-height:1}
.stats .st span{font-size:.84rem;color:var(--ink-soft);font-weight:600;letter-spacing:.02em;margin-top:10px}
@media(max-width:620px){.stats .wrap{grid-template-columns:repeat(2,1fr);gap:24px 14px}}

/* ---------- sections ---------- */
section{padding:var(--sec) 0}
.sec-head{max-width:54rem}
.sec-head.center{margin:0 auto;text-align:center;max-width:60rem}
.sec-head .eyebrow{margin-bottom:16px}
.sec-head h2{font-size:clamp(1.9rem,3.1vw,2.85rem);margin-bottom:.4em;max-width:24ch}
.sec-head.center h2{margin-left:auto;margin-right:auto}
.sec-head p{color:var(--ink-soft);font-size:1.12rem;max-width:60ch}
.sec-head.center p{margin-left:auto;margin-right:auto}

/* services */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2vw,26px);margin-top:50px}
.svc{position:relative;border-radius:var(--radius);overflow:hidden;background:var(--ink);min-height:300px;
  display:flex;align-items:flex-end;box-shadow:var(--shadow);isolation:isolate;
  transition:transform .26s ease,box-shadow .26s ease}
.svc img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;transition:transform .5s ease}
.svc::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,rgba(20,12,6,0) 30%,rgba(20,12,6,.45) 62%,rgba(20,12,6,.86) 100%)}
.svc:hover{transform:translateY(-6px);box-shadow:0 34px 70px -30px rgba(34,20,10,.7)}
.svc:hover img{transform:scale(1.05)}
.svc .body{padding:22px 22px 24px;color:#fff}
.svc .body h3{color:#fff;font-size:1.45rem;text-shadow:0 2px 12px rgba(0,0,0,.4)}
.svc .body p{color:rgba(255,255,255,.9);font-size:.95rem;margin-top:6px;text-shadow:0 1px 8px rgba(0,0,0,.5)}
.svc .body .go{margin-top:12px;font-weight:700;font-size:.9rem;color:#fff;display:inline-flex;align-items:center;gap:.4em;border-bottom:1.5px solid rgba(255,255,255,.5);padding-bottom:2px}
.svc.tall{grid-row:span 2}
@media(max-width:860px){.svc-grid{grid-template-columns:repeat(2,1fr)}.svc.tall{grid-row:span 1}}
@media(max-width:520px){.svc-grid{grid-template-columns:1fr}}

/* the padgett way */
.way{background:var(--ink);color:var(--accent-on)}
.way h2,.way h3{color:#fff}
.way .grid{display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(30px,4vw,58px);align-items:center}
.way .eyebrow{color:var(--gold)}
.way .eyebrow::before{background:var(--gold)}
.manifesto{font-family:var(--font-h);font-weight:500;font-size:clamp(1.7rem,2.7vw,2.5rem);line-height:1.22;color:#fff;margin:14px 0 0}
.manifesto .hl{color:var(--gold);font-style:italic}
.way .lede{color:rgba(250,247,238,.78);font-size:1.06rem;margin-top:22px;max-width:44ch}
.compare{border:1px solid rgba(255,255,255,.22);border-radius:14px;overflow:hidden;background:rgba(255,255,255,.02);
  box-shadow:0 30px 66px -38px rgba(0,0,0,.7)}
.compare .r{display:grid;grid-template-columns:1fr 1fr}
.compare .c{padding:16px 19px;font-size:.96rem;border-top:1px solid rgba(255,255,255,.1)}
.compare .r:first-child .c{border-top:0}
.compare .c.us{background:linear-gradient(180deg,rgba(139,42,42,.52),rgba(139,42,42,.36));box-shadow:inset 3px 0 0 var(--gold);color:#fff}
.compare .c:not(.us){background:rgba(255,255,255,.015);color:rgba(250,247,238,.6)}
.compare .r:first-child .c.us{background:var(--accent)}
.compare .r:first-child .c:not(.us){background:rgba(255,255,255,.06);color:rgba(250,247,238,.7)}
.compare .c .lab{font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;margin-bottom:6px;color:rgba(255,255,255,.55)}
.compare .c.us .lab{color:#F0C969}
.compare .c.head{font-family:var(--font-h);font-weight:700;font-size:1.04rem}
@media(max-width:820px){.way .grid{grid-template-columns:1fr}}

/* timeline */
.timeline{background:var(--surface);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.tl{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:50px;position:relative}
.tl::before{content:"";position:absolute;top:15px;left:6%;right:6%;height:2px;background:var(--line)}
.tl .node{position:relative;z-index:2;text-align:center;opacity:0;transform:translateY(20px);
  transition:opacity .6s ease,transform .65s cubic-bezier(.22,.61,.36,1)}
.tl.in .node{opacity:1;transform:none}
.tl.in .node:nth-child(1){transition-delay:.05s}
.tl.in .node:nth-child(2){transition-delay:.34s}
.tl.in .node:nth-child(3){transition-delay:.63s}
.tl.in .node:nth-child(4){transition-delay:.92s}
.tl .node .yr{display:inline-grid;place-items:center;width:auto;font-family:var(--font-h);font-weight:800;color:#fff;
  background:var(--accent);padding:5px 14px;border-radius:20px;font-size:.92rem;position:relative;z-index:1}
.tl .node h3{font-size:1.18rem;margin:16px 0 6px}
.tl .node p{font-size:.92rem;color:var(--ink-soft)}
@media(max-width:760px){.tl{grid-template-columns:1fr 1fr;gap:30px 20px}.tl::before{display:none}}

/* gallery — clean uniform grid (no ragged masonry bottom); click to open lightbox */
.gal{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.gal.cols-2{grid-template-columns:repeat(2,1fr);max-width:820px;margin-inline:auto}
.gal figure{margin:0;border-radius:var(--radius);overflow:hidden;position:relative;cursor:zoom-in;
  box-shadow:0 14px 34px -24px rgba(34,20,10,.5),0 3px 12px -8px rgba(110,31,31,.15);
  transition:transform .26s ease,box-shadow .26s ease}
.gal figure:hover{transform:translateY(-6px);box-shadow:0 30px 60px -28px rgba(34,20,10,.62),0 6px 18px -10px rgba(110,31,31,.22)}
.gal img{width:100%;height:100%;aspect-ratio:4/3;object-fit:cover;display:block;transition:transform .5s ease}
.gal figure:hover img{transform:scale(1.05)}
.gal figure::before{content:"";position:absolute;inset:0;pointer-events:none;z-index:1;border-radius:inherit;
  box-shadow:inset 0 0 0 1px rgba(250,247,238,.32),inset 0 0 0 4px rgba(34,20,10,.05)}
.gal figcaption{position:absolute;left:0;right:0;bottom:0;padding:30px 16px 14px;color:#fff;font-size:.86rem;font-weight:600;z-index:2;
  background:linear-gradient(180deg,transparent,rgba(20,12,6,.84));opacity:0;transition:opacity .25s}
.gal figure:hover figcaption,.gal figure:focus-within figcaption{opacity:1}
@media(max-width:780px){.gal{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.gal{grid-template-columns:1fr}}
/* lightbox */
.lightbox{position:fixed;inset:0;z-index:200;background:rgba(20,12,6,.92);display:flex;align-items:center;justify-content:center;
  padding:clamp(16px,4vw,52px);opacity:0;visibility:hidden;transition:opacity .25s;cursor:zoom-out}
.lightbox.open{opacity:1;visibility:visible}
.lightbox figure{margin:0;max-width:1100px;width:100%;text-align:center}
.lightbox img{max-width:100%;max-height:82vh;width:auto;height:auto;border-radius:10px;box-shadow:0 40px 90px -30px rgba(0,0,0,.8)}
.lightbox figcaption{color:rgba(255,255,255,.9);font-weight:600;margin-top:16px;font-size:.95rem}
.lightbox .lb-close{position:absolute;top:20px;right:24px;width:46px;height:46px;border:0;border-radius:50%;cursor:pointer;
  background:rgba(255,255,255,.12);color:#fff;font-size:1.5rem;line-height:1;display:grid;place-items:center}
.lightbox .lb-close:hover{background:rgba(255,255,255,.22)}
.lightbox .lb-nav{position:absolute;top:50%;transform:translateY(-50%);width:50px;height:50px;border:0;border-radius:50%;cursor:pointer;
  background:rgba(255,255,255,.12);color:#fff;font-size:1.6rem;display:grid;place-items:center}
.lightbox .lb-nav:hover{background:rgba(255,255,255,.22)}
.lightbox .lb-prev{left:clamp(10px,2vw,28px)}.lightbox .lb-next{right:clamp(10px,2vw,28px)}
@media(max-width:600px){.lightbox .lb-nav{top:auto;bottom:24px;transform:none}.lightbox .lb-prev{left:30%}.lightbox .lb-next{right:30%}}

/* process / about */
.process .grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(34px,5vw,72px);align-items:center}
/* §4.6 framed-image: ring + warm outer glow on the process/about portrait */
.process__img{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow),0 4px 16px -9px rgba(110,31,31,.16);position:relative}
.process__img img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/5}
.process__img::after{content:"";position:absolute;inset:0;pointer-events:none;border-radius:inherit;
  box-shadow:inset 0 0 0 1px rgba(250,247,238,.3),inset 0 0 0 4px rgba(34,20,10,.05)}
.steps{list-style:none;margin:28px 0 0;padding:0;display:flex;flex-direction:column;gap:18px}
.steps li{display:flex;gap:16px}
.steps .n{flex:0 0 auto;width:42px;height:42px;border-radius:50%;background:var(--accent);color:var(--accent-on);
  display:flex;align-items:center;justify-content:center;font-family:var(--font-h);font-weight:700;font-size:1.1rem;line-height:1;padding-top:0;padding-bottom:6px}
/* center the Playfair numerals in every circular badge (grid place-items left a baseline offset) */
.procband .step .num,.seq .row .num{display:flex;align-items:center;justify-content:center;line-height:1;padding-top:0;padding-bottom:6px}
.steps b{font-size:1.1rem;font-family:var(--font-h)}
.steps small{display:block;color:var(--ink-soft);font-size:.96rem;margin-top:3px;font-weight:400}
@media(max-width:820px){.process .grid{grid-template-columns:1fr}.process__img{order:-1}.process__img img{aspect-ratio:16/10}}

/* ===== Wave 5 — per-service distinguishing elements (built from existing tokens) ===== */

/* procband — horizontal numbered phase band (kitchen timeline, custom-homes journey).
   Numbered nodes joined by a connector line, each with a phase label + duration chip. */
.procband{background:var(--surface);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.procband .pb{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;margin-top:46px;position:relative}
.procband .pb::before{content:"";position:absolute;top:21px;left:8%;right:8%;height:2px;background:var(--line)}
.procband .step{position:relative;z-index:2;text-align:center}
.procband .step .num{display:inline-grid;place-items:center;width:44px;height:44px;border-radius:50%;
  font-family:var(--font-h);font-weight:800;font-size:1.16rem;color:#fff;background:var(--accent);position:relative;z-index:1;
  box-shadow:0 0 0 6px var(--surface),0 8px 18px -10px rgba(110,31,31,.5)}
.procband .step h3{font-size:1.14rem;margin:16px 0 5px}
.procband .step .when{display:inline-block;font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;font-weight:700;
  color:var(--accent);background:color-mix(in srgb,var(--accent) 9%,transparent);padding:3px 11px;border-radius:20px;margin-bottom:9px}
.procband .step p{font-size:.92rem;color:var(--ink-soft)}
.procband .pb-note{margin-top:40px;text-align:center;font-size:.96rem;color:var(--ink-soft);max-width:62ch;margin-left:auto;margin-right:auto}
@media(max-width:760px){.procband .pb{grid-template-columns:1fr 1fr;gap:34px 22px}.procband .pb::before{display:none}}
/* dark variant — the flagship custom-homes journey runs on the ink ground so it reads
   as the premium service and is visually unmistakable from the kitchen timeline band. */
.procband.dark{background:var(--ink);border-color:rgba(255,255,255,.12)}
.procband.dark .sec-head h2{color:#fff}
.procband.dark .sec-head p{color:rgba(250,247,238,.78)}
.procband.dark .sec-head .eyebrow{color:var(--gold)}
.procband.dark .sec-head .eyebrow::before{background:var(--gold)}
.procband.dark .pb::before{background:rgba(255,255,255,.16)}
.procband.dark .step .num{box-shadow:0 0 0 6px var(--ink),0 8px 18px -10px rgba(0,0,0,.6)}
.procband.dark .step h3{color:#fff}
.procband.dark .step .when{color:#E7C8A0;background:rgba(231,200,160,.14)}
.procband.dark .step p{color:rgba(250,247,238,.74)}
.procband.dark .pb-note{color:rgba(250,247,238,.7)}

/* specgrid — "what's possible" callout cards (bathroom). 2×2 cards with a left accent rule. */
.specgrid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:46px}
.specgrid .spec{background:var(--surface);border:1px solid var(--line);border-left:3px solid var(--accent);
  border-radius:var(--radius);padding:22px 24px;transition:transform .2s ease,box-shadow .22s ease}
.specgrid .spec:hover{transform:translateY(-4px);box-shadow:0 22px 46px -28px rgba(34,20,10,.5)}
.specgrid .spec h3{font-size:1.18rem;margin-bottom:.3em}
.specgrid .spec p{font-size:.96rem;color:var(--ink-soft)}
@media(max-width:620px){.specgrid{grid-template-columns:1fr}}

/* seq — vertical numbered order-of-operations on a tinted band (basement below-grade sequence). */
.seq{background:var(--surface);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.seq__inner{display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(32px,5vw,72px);align-items:start}
.seq__inner .sec-head{max-width:none}
.seq .rail{margin-top:4px;display:flex;flex-direction:column;gap:0;position:relative;max-width:none}
@media(max-width:820px){.seq__inner{grid-template-columns:1fr;gap:14px}.seq .rail{margin-top:26px}}
.seq .row{display:flex;gap:20px;padding:18px 0;position:relative}
.seq .row:not(:last-child)::before{content:"";position:absolute;left:21px;top:46px;bottom:-6px;width:2px;background:var(--line)}
.seq .row .num{flex:0 0 auto;width:44px;height:44px;border-radius:50%;background:var(--accent);color:#fff;
  display:grid;place-items:center;font-family:var(--font-h);font-weight:800;font-size:1.12rem;position:relative;z-index:1}
.seq .row .bd h3{font-size:1.2rem;margin-bottom:.25em}
.seq .row .bd p{font-size:.97rem;color:var(--ink-soft);max-width:60ch}

/* matchband — "matches your existing home" two-column seam statement (home additions). */
.matchband .grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(26px,4vw,56px);align-items:stretch;margin-top:46px}
.matchband .panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(24px,2.6vw,34px)}
.matchband .panel .tag{display:inline-block;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;
  color:var(--accent);margin-bottom:12px}
.matchband .panel h3{font-size:1.34rem;margin-bottom:.4em}
.matchband .panel ul{list-style:none;margin:14px 0 0;padding:0;display:flex;flex-direction:column;gap:10px}
.matchband .panel li{display:flex;gap:11px;align-items:flex-start;font-size:.98rem;color:var(--ink-soft);font-weight:500}
.matchband .panel li::before{content:"";flex:0 0 auto;width:18px;height:18px;border-radius:50%;margin-top:3px;
  background:color-mix(in srgb,var(--accent) 14%,transparent);
  box-shadow:inset 0 0 0 1.5px var(--accent)}
.matchband .seam{font-family:var(--font-h);font-weight:500;font-size:clamp(1.1rem,1.5vw,1.32rem);line-height:1.4;color:var(--ink);max-width:46ch;margin-top:34px}
@media(max-width:820px){.matchband .grid{grid-template-columns:1fr}}

/* testimonials */
.tst{background:var(--ink);color:var(--accent-on)}
.tst h2{color:#fff}
.tst .eyebrow{color:var(--gold)}.tst .eyebrow::before{background:var(--gold)}
.tst .agg{display:inline-flex;flex-wrap:wrap;gap:8px 22px;align-items:center;margin-top:20px;font-weight:600;color:rgba(255,255,255,.85);font-size:.95rem}
.tst .agg .pill{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);border-radius:30px;padding:7px 16px;display:inline-flex;gap:.5em;align-items:center}
.tst .agg .star{color:var(--gold)}
.tst-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:22px;margin-top:46px}
.tcard{flex:0 1 348px;margin:0;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.12);
  border-radius:12px;padding:26px}
.tcard .stars{color:var(--gold);letter-spacing:.12em;font-size:.95rem;margin-bottom:12px}
.tcard p{font-size:.98rem;line-height:1.62;color:rgba(250,247,238,.92)}
.tcard .by{margin-top:16px;font-weight:700;font-size:.9rem;color:#fff}
.tcard .by small{display:block;font-weight:500;color:var(--gold);font-size:.78rem;margin-top:2px;letter-spacing:.02em}
@media(max-width:900px){.tcard{flex:0 1 calc(50% - 11px)}}
@media(max-width:600px){.tcard{flex:1 1 100%}}

/* faq (centered per §7b) */
.faq-wrap{max-width:780px;margin:46px auto 0}
.faq{border-top:1px solid var(--line)}
.faq details{border-bottom:1px solid var(--line)}
.faq summary{list-style:none;cursor:pointer;padding:22px 8px;display:flex;justify-content:space-between;gap:18px;align-items:center;
  font-family:var(--font-h);font-weight:600;font-size:1.18rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary .pm{flex:0 0 auto;width:34px;height:34px;border-radius:50%;position:relative;
  background:color-mix(in srgb,var(--accent) 11%,transparent);
  transition:transform .25s ease,background .25s ease}
.faq summary:hover .pm{background:color-mix(in srgb,var(--accent) 18%,transparent)}
.faq summary .pm::before,.faq summary .pm::after{content:"";position:absolute;background:var(--accent);border-radius:2px}
.faq summary .pm::before{top:16px;left:9px;right:9px;height:2px}
.faq summary .pm::after{left:16px;top:9px;bottom:9px;width:2px;transition:opacity .25s}
.faq details[open] summary .pm{background:var(--accent);transform:rotate(180deg)}
.faq details[open] summary .pm::before{background:#fff}
.faq details[open] summary .pm::after{opacity:0}
.faq details p{padding:0 8px 24px;color:var(--ink-soft);max-width:68ch}

/* final cta */
.cta{background:var(--accent);color:var(--accent-on);text-align:center}
.cta h2{color:#fff;font-size:clamp(2rem,3.6vw,3rem);max-width:18ch;margin:0 auto .4em}
.cta p{color:rgba(250,247,238,.9);max-width:50ch;margin:0 auto 32px;font-size:1.1rem}
.cta .cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.cta .btn-primary{background:#fff;color:var(--accent)}
.cta .btn-primary:hover{background:#FBEFE6}
.cta .btn-ghost{border-color:rgba(255,255,255,.5);color:#fff}
.cta .btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.08);color:#fff}
/* 7.4 real trust line under the CTA buttons */
.cta-trust{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:8px 18px;margin:22px auto 0;font-size:.9rem;font-weight:600;color:rgba(250,247,238,.85)}
.cta-trust span{display:inline-flex;align-items:center;gap:.45em}
.cta-trust .star{color:#F0C969}
.cta-trust .sep{opacity:.5}

/* footer */
footer.site{background:var(--ink);color:rgba(239,228,210,.72);padding:64px 0 28px}
footer.site .grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px}
footer.site h2{color:var(--gold);font-family:var(--font-b);font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:16px}
footer.site a{color:rgba(239,228,210,.78)}footer.site a:hover{color:#fff}
footer.site .footer-brand{font-family:var(--font-h);color:#fff;font-weight:800;font-size:1.9rem;line-height:1;letter-spacing:.01em;margin-bottom:16px;display:inline-block}
footer.site .footer-brand .sub{display:block;font-family:var(--font-b);font-weight:600;font-size:.68rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);margin-top:9px}
footer.site .fcol ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px;font-size:.95rem}
footer.site .nap{font-size:.95rem;line-height:1.8}
footer.site .nap b{color:#fff}
footer.site .bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:44px;padding-top:22px;display:flex;
  flex-wrap:wrap;gap:12px 24px;justify-content:space-between;align-items:center;font-size:.82rem}
footer.site .built a{color:var(--gold);font-weight:600}
@media(max-width:760px){footer.site .grid{grid-template-columns:1fr;gap:32px}}
/* 8.4 mobile tap area: footer nav links + the top-bar phone get a 44px touch zone
   on touch viewports without changing their visual type size. */
@media(max-width:720px){
  footer.site .fcol ul{gap:4px}
  footer.site .fcol ul a{display:inline-flex;align-items:center;min-height:44px}
  .top .tphone{display:inline-flex;align-items:center;min-height:38px;padding:2px 0}
}

/* mobile callbar (§7a — mobile only) */
.callbar{display:none}
@media(max-width:720px){
  .callbar{display:grid;grid-template-columns:1fr 1fr;gap:10px;position:fixed;left:0;right:0;bottom:0;z-index:80;
    padding:10px 12px calc(10px + min(env(safe-area-inset-bottom, 0px), 6px));background:color-mix(in srgb,var(--bg) 94%,transparent);
    backdrop-filter:blur(8px);border-top:1px solid var(--line);
    transform:translateY(120%);opacity:0;pointer-events:none;transition:transform .38s cubic-bezier(.22,.61,.36,1),opacity .38s ease}
  .callbar.show{transform:none;opacity:1;pointer-events:auto}
  .callbar a{display:flex;align-items:center;justify-content:center;min-height:46px;padding:13px;font-size:.95rem;border-radius:var(--radius);font-weight:700;text-align:center;font-family:var(--font-b)}
  body{padding-bottom:74px}
  .hdr .hdr-actions{display:none}
}

/* reveal */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}*{scroll-behavior:auto}}

/* ============ sub-page patterns (Step 2) ============ */
.hp{position:absolute!important;left:-9999px!important;top:auto;width:1px;height:1px;overflow:hidden}
/* page hero — immersive BRIGHT image (full opacity), bottom-anchored text, compact height */
.phero{position:relative;overflow:hidden;background:var(--ink);height:clamp(460px,90vh,880px);display:flex;align-items:center}
.phero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 42%;opacity:1;z-index:0}
/* legibility: subtle top strip (nav) + a soft dark wash on the LEFT only, behind the headline/copy — right side of the photo stays clear */
.phero::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg,rgba(20,12,6,.5) 0%,rgba(20,12,6,0) 16%),
    linear-gradient(96deg,rgba(20,12,6,.66) 0%,rgba(20,12,6,.42) 26%,rgba(20,12,6,.14) 46%,rgba(20,12,6,0) 62%)}
.phero .wrap{position:relative;z-index:2;width:100%;padding-top:clamp(78px,9vh,104px);padding-bottom:clamp(26px,4vh,44px)}
.phero h1{color:#fff;font-size:clamp(2.1rem,3.8vw,3.2rem);max-width:20ch;font-weight:800;text-shadow:0 2px 22px rgba(0,0,0,.5)}
.phero h1 em{font-style:italic;font-weight:600;color:#EAB964;text-shadow:0 1px 2px rgba(20,12,6,.92),0 0 8px rgba(20,12,6,.6),0 3px 12px rgba(20,12,6,.42)}
.phero p{color:rgba(255,255,255,.94);max-width:56ch;margin-top:14px;font-size:1.08rem;text-shadow:0 1px 14px rgba(0,0,0,.55)}
.phero .eyebrow{color:#E7C8A0}.phero .eyebrow::before{background:#E7C8A0}
/* light per-page measure variation (no oversize headlines — keep pheros compact) */
.svc-bath .phero h1,.svc-basement .phero h1{max-width:17ch}
.svc-custom .phero h1,.svc-kitchen .phero h1{max-width:22ch}
.crumbs{display:flex;gap:8px;flex-wrap:wrap;font-size:.82rem;color:rgba(255,255,255,.72);margin-bottom:20px;font-weight:600}
.crumbs a{color:rgba(255,255,255,.72)}.crumbs a:hover{color:#fff}
.crumbs span{opacity:.6}
.phero .cta-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:26px}
.phero .btn-ghost{border-color:rgba(255,255,255,.55);color:#fff}
.phero .btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.1);color:#fff}
#book{scroll-margin-top:100px}
/* mobile interior heroes: full-bleed image dimmed evenly so white text reads anywhere (content-driven height, no clipping) */
@media(max-width:760px){
  .phero{height:auto;min-height:62svh;align-items:flex-end}
  .phero::after{background:linear-gradient(180deg,rgba(20,12,6,.62) 0%,rgba(20,12,6,.5) 32%,rgba(20,12,6,.5) 60%,rgba(20,12,6,.78) 100%)}
  .phero .wrap{padding-top:clamp(84px,11vh,100px);padding-bottom:clamp(34px,9vw,52px)}
  .phero h1{font-size:clamp(1.9rem,7vw,2.5rem)}
}
nav.mainnav a[aria-current="page"],.has-dd[data-active] >button{color:#fff}
nav.mainnav a[aria-current="page"]::after{width:100%}
.hdr.scrolled nav.mainnav a[aria-current="page"]{color:var(--accent)}
/* prose + content split */
.lead{font-size:clamp(1.12rem,1.6vw,1.4rem);color:var(--ink);font-family:var(--font-h);font-weight:500;line-height:1.4;max-width:46ch}
.prose p{margin-bottom:1.05em;color:var(--ink-soft);font-size:1.06rem}
.prose p:last-child{margin-bottom:0}
.split2{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(34px,5vw,72px);align-items:center}
.split2.rev .split2__media{order:-1}
/* §4.6 framed-image: ring + warm outer glow; §4.7 subtle bottom-fade on split media */
.split2__media{border-radius:var(--radius);overflow:hidden;position:relative;
  box-shadow:var(--shadow),0 4px 16px -9px rgba(110,31,31,.16)}
.split2__media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3;display:block}
.split2__media::after{content:"";position:absolute;inset:0;pointer-events:none;border-radius:inherit;
  box-shadow:inset 0 0 0 1px rgba(250,247,238,.3),inset 0 0 0 4px rgba(34,20,10,.05);
  background:linear-gradient(0deg,rgba(20,12,6,.22) 0%,rgba(20,12,6,0) 30%)}
@media(max-width:820px){.split2{grid-template-columns:1fr}.split2.rev .split2__media{order:0}.split2__media img{aspect-ratio:16/10}}
/* checklist */
.checklist{list-style:none;margin:24px 0 0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:12px 28px}
.checklist li{display:flex;gap:11px;align-items:flex-start;font-weight:600;color:var(--ink);font-size:1rem}
.checklist li::before{content:"";flex:0 0 auto;width:22px;height:22px;border-radius:50%;margin-top:1px;
  background:color-mix(in srgb,var(--accent) 14%,transparent) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='13' height='13' viewBox='0 0 24 24' fill='none' stroke='%238B2A2A' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/13px no-repeat}
@media(max-width:560px){.checklist{grid-template-columns:1fr}}
/* value cards */
.vgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2vw,26px);margin-top:46px}
.vcard .vi svg{width:24px;height:24px}
.vcard{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(24px,2.4vw,32px);
  transition:transform .26s ease,box-shadow .26s ease,border-color .26s ease}
.vcard:hover{transform:translateY(-6px);box-shadow:0 28px 56px -30px rgba(34,20,10,.55);border-color:color-mix(in srgb,var(--accent) 34%,var(--line))}
/* §4.8 service-icon depth: accent ring + soft drop-shadow + inner top-light on the value-card disc */
.vcard .vi{width:46px;height:46px;border-radius:11px;background:color-mix(in srgb,var(--accent) 12%,transparent);display:grid;place-items:center;color:var(--accent);font-size:1.3rem;margin-bottom:16px;
  box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 26%,transparent),
    0 8px 18px -10px rgba(110,31,31,.42),inset 0 1px 0 rgba(255,255,255,.5);
  transition:background .26s ease,color .26s ease,box-shadow .26s ease}
.vcard:hover .vi{background:var(--accent);color:#fff;
  box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 55%,transparent),
    0 12px 24px -10px rgba(110,31,31,.55),inset 0 1px 0 rgba(255,255,255,.28)}
.vcard h3{font-size:1.3rem;margin-bottom:.4em}
.vcard p{color:var(--ink-soft);font-size:.98rem}
@media(max-width:820px){.vgrid{grid-template-columns:1fr}}
/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(34px,5vw,64px);align-items:start}
@media(max-width:880px){.contact-grid{grid-template-columns:1fr}}
.cinfo{display:flex;flex-direction:column;gap:18px}
.cinfo .row{display:flex;gap:15px;align-items:flex-start}
.cinfo .ci{flex:0 0 auto;width:44px;height:44px;border-radius:11px;background:color-mix(in srgb,var(--accent) 12%,transparent);display:grid;place-items:center;color:var(--accent)}
.cinfo .row b{font-family:var(--font-h);font-size:1.08rem;display:block}
.cinfo .row a,.cinfo .row span{color:var(--ink-soft)}
.cinfo .row a:hover{color:var(--accent)}
.form,.contact-form{position:relative;display:flex;flex-direction:column;gap:14px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(24px,3vw,38px);box-shadow:var(--shadow);overflow:hidden}
/* 7.1 gradient top accent bar on the contact form card */
.contact-form::before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,var(--accent-deep),var(--accent) 45%,var(--gold));border-radius:var(--radius) var(--radius) 0 0}
/* 7.1 expectation-setter block above the fields */
.form-promise{margin:2px 0 6px}
.form-promise b{display:block;font-family:var(--font-h);font-size:1.18rem;color:var(--ink);margin-bottom:10px}
.form-promise ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:7px}
.form-promise li{display:flex;align-items:flex-start;gap:.6em;font-size:.98rem;color:var(--ink-soft);line-height:1.45}
.form-promise li svg{flex:0 0 auto;width:18px;height:18px;margin-top:2px;color:var(--accent)}
.form .field{display:flex;flex-direction:column;gap:6px}
.form label{font-weight:700;font-size:.9rem;color:var(--ink)}
.form input,.form textarea,.form select{font-family:var(--font-b);font-size:1rem;padding:12px 14px;border:1.5px solid var(--line);border-radius:8px;background:#fff;color:var(--ink);width:100%}
.form input:focus,.form textarea:focus,.form select:focus{outline:0;border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 18%,transparent)}
/* keyboard focus on form fields keeps the accent border+halo AND restores the universal ring (3.8 pairing) */
.form input:focus-visible,.form textarea:focus-visible,.form select:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-color:var(--accent)}
.form textarea{min-height:118px;resize:vertical}
.form .row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:520px){.form .row2{grid-template-columns:1fr}}
.form__success{background:color-mix(in srgb,var(--accent) 10%,var(--surface));border:1px solid var(--accent);color:var(--ink);
  border-radius:8px;padding:14px 16px;font-weight:600;margin-top:4px}
.mapwrap{border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);line-height:0}
.mapwrap iframe{width:100%;height:340px;border:0;display:block;filter:saturate(.92)}
/* service quick-nav chips */
.chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:30px}
.chips a{display:inline-flex;align-items:center;min-height:44px;background:var(--surface);color:var(--ink);border:1px solid var(--line);border-radius:30px;padding:8px 18px;font-weight:600;font-size:.92rem;transition:.18s}
.chips a:hover,.chips a[aria-current="page"]{background:var(--accent);color:var(--accent-on);border-color:var(--accent)}

/* ============ Wave 8 — signature flourish + per-page delights ============ */

/* 8.2 handwritten-script founder signature (Caveat). Reads "David Padgett" in
   claret over the About founder story; the role line sits in soft ink beneath. */
.sig{margin-top:26px;line-height:1}
.sig .mark{font-family:'Caveat',cursive;font-weight:600;font-size:clamp(2.4rem,4.4vw,3.4rem);
  color:var(--accent);display:inline-block;transform:rotate(-3deg);transform-origin:left center}
.sig .role{display:block;margin-top:4px;font-size:.82rem;letter-spacing:.06em;color:var(--ink-soft);font-weight:600}

/* 8.3 (home + custom homes) count-up stat numerals. The value ticks from a start
   figure to the real one when the band scrolls into view. Numerals are tabular so
   the layout never reflows mid-count. Final figure is the static fallback. */
.countup{font-variant-numeric:tabular-nums}

/* 8.3 (services hub + bathroom) hand-drawn underline that draws under an accent
   word when its section reveals. Pure CSS stroke — no image. */
.underdraw{position:relative;display:inline-block}
.underdraw::after{content:"";position:absolute;left:-2px;right:-2px;bottom:-.12em;height:.34em;
  background:no-repeat center/100% 100%;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 18' preserveAspectRatio='none' fill='none' stroke='%23B07D2B' stroke-width='4' stroke-linecap='round'%3E%3Cpath d='M3 12 C 40 4, 80 4, 110 10 S 175 16, 197 7'/%3E%3C/svg%3E");
  transform:scaleX(0);transform-origin:left center;transition:transform .9s cubic-bezier(.22,.61,.36,1) .15s}
.reveal.in .underdraw::after,.in.underdraw::after{transform:scaleX(1)}

/* 8.3 (about timeline / kitchen procband) connector line draws left→right on reveal.
   We layer an accent line over the static grey rule and grow it once visible.
   The DARK custom-homes procband uses a different delight (number pop, below), so the
   connector-draw is scoped to the light procband + the about timeline only. */
.tl,.procband:not(.dark) .pb{--draw:0}
.tl::after,.procband:not(.dark) .pb::after{content:"";position:absolute;height:2px;background:var(--accent);
  transform:scaleX(var(--draw));transform-origin:left center;transition:transform 1.1s cubic-bezier(.22,.61,.36,1) .2s;z-index:0}
.tl::after{top:15px;left:6%;right:6%}
.procband:not(.dark) .pb::after{top:21px;left:8%;right:8%}
.tl.in,.procband:not(.dark) .pb.in{--draw:1}
@media(max-width:760px){.tl::after,.procband:not(.dark) .pb::after{display:none}}

/* 8.3 (custom homes) the four journey numbers pop in one-by-one when the dark band
   reveals — the flagship page's own ticking-stage delight, distinct from the lines. */
.procband.dark .pb .step .num{transform:scale(.6);opacity:0;
  transition:transform .55s cubic-bezier(.34,1.56,.64,1),opacity .45s ease}
.procband.dark .pb.in .step .num{transform:scale(1);opacity:1}
.procband.dark .pb.in .step:nth-child(1) .num{transition-delay:.05s}
.procband.dark .pb.in .step:nth-child(2) .num{transition-delay:.18s}
.procband.dark .pb.in .step:nth-child(3) .num{transition-delay:.31s}
.procband.dark .pb.in .step:nth-child(4) .num{transition-delay:.44s}

/* 8.3 (basement) vertical sequence rail draws top→bottom on reveal. */
.seq .rail{--draw:0}
.seq .rail::after{content:"";position:absolute;left:21px;top:24px;bottom:24px;width:2px;background:var(--accent);
  transform:scaleY(var(--draw));transform-origin:top center;transition:transform 1.2s cubic-bezier(.22,.61,.36,1) .2s;z-index:0}
.seq .rail.in{--draw:1}
.seq .row{z-index:1}

/* 8.3 (bathroom) spec cards rise in one-by-one when the grid reveals. */
.specgrid.stagger .spec{opacity:0;transform:translateY(16px);transition:opacity .6s ease,transform .6s cubic-bezier(.22,.61,.36,1)}
.specgrid.stagger.in .spec{opacity:1;transform:none}
.specgrid.stagger.in .spec:nth-child(1){transition-delay:.05s}
.specgrid.stagger.in .spec:nth-child(2){transition-delay:.16s}
.specgrid.stagger.in .spec:nth-child(3){transition-delay:.27s}
.specgrid.stagger.in .spec:nth-child(4){transition-delay:.38s}

/* 8.3 (contact) form-promise checkmarks stagger in when the card reveals. */
.form-promise.stagger li{opacity:0;transform:translateX(-8px);transition:opacity .55s ease,transform .55s cubic-bezier(.22,.61,.36,1)}
.form-promise.stagger.in li{opacity:1;transform:none}
.form-promise.stagger.in li:nth-child(1){transition-delay:.08s}
.form-promise.stagger.in li:nth-child(2){transition-delay:.22s}
.form-promise.stagger.in li:nth-child(3){transition-delay:.36s}

/* 8.3 (work) polaroid tilt on a single highlighted gallery card. A gentle resting
   tilt + white frame that straightens and lifts on hover/focus. ONE card only. */
.gal figure.polaroid{transform:rotate(-2.2deg);background:#FFFCF5;padding:10px 10px 30px;
  box-shadow:0 18px 40px -22px rgba(34,20,10,.6),0 4px 14px -8px rgba(110,31,31,.2)}
.gal figure.polaroid img{border-radius:4px}
.gal figure.polaroid figcaption{left:10px;right:10px;bottom:8px;padding:6px 6px 4px;border-radius:0 0 4px 4px;
  background:none;color:var(--ink-soft);font-family:'Caveat',cursive;font-size:1.15rem;font-weight:600;opacity:1;text-align:center}
.gal figure.polaroid::before{box-shadow:none}
.gal figure.polaroid:hover{transform:rotate(0) translateY(-6px)}

/* 8.3 (home additions) the closing seam pull-quote resolves in (blur→sharp), P-004 style. */
.seam.pq{opacity:0;transform:translateY(18px);filter:blur(6px);
  transition:opacity .9s cubic-bezier(.22,.61,.36,1),transform .9s cubic-bezier(.22,.61,.36,1),filter .9s cubic-bezier(.22,.61,.36,1)}
.seam.pq.in{opacity:1;transform:none;filter:none}

/* reduced-motion: every Wave-8 delight resolves to its FINAL state, no animation. */
@media(prefers-reduced-motion:reduce){
  .underdraw::after,.in.underdraw::after,.reveal.in .underdraw::after{transform:scaleX(1);transition:none}
  .tl::after,.procband:not(.dark) .pb::after{transform:scaleX(1);transition:none}
  .procband.dark .pb .step .num{transform:scale(1);opacity:1;transition:none}
  .seq .rail::after{transform:scaleY(1);transition:none}
  .specgrid.stagger .spec,.form-promise.stagger li{opacity:1;transform:none;transition:none}
  .seam.pq{opacity:1;transform:none;filter:none;transition:none}
  .sig .mark{transform:rotate(-3deg)}
}

/* ============ print ============ */
@media print{
  .callbar,.drawer,.burger,.top,.hdr-actions .btn-primary,.cta,.hero__media::after{display:none!important}
  .hdr{position:static;border:0}
  body{padding:0;background:#fff;color:#000}
  a{color:#000;text-decoration:underline}
  .phero img,.phero::after{opacity:.15}
  section,.way,.tst,.timeline,footer.site{padding:18px 0;background:#fff!important;color:#000!important}
  footer.site a,footer.site h2,.tst h2,.way h2{color:#000!important}
}
