
:root {
  --ink:#121415;
  --charcoal:#050607;
  --muted:#5a6266;
  --line:#dde5e7;
  --paper:#f7f8f4;
  --mist:#eaf5f6;
  --sky:#bcdce8;
  --gold:#d8b35a;
  --gold-dark:#a27a25;
  --coral:#e96f4f;
  --radius:8px;
}
* { box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { margin:0; font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; color:var(--ink); background:#fff; letter-spacing:0; }
img { max-width:100%; display:block; object-fit:cover; }
a { color:inherit; text-decoration:none; }
p { color:var(--muted); line-height:1.65; font-size:17px; }
h1,h2,h3 { margin:0; line-height:1.02; letter-spacing:0; }
h1 { font-size:62px; max-width:820px; }
h2 { font-size:42px; }
h3 { font-size:26px; }
.eyebrow { margin:0 0 14px; color:var(--gold-dark); font-size:13px; font-weight:800; text-transform:uppercase; letter-spacing:0; }
.lead { font-size:20px; max-width:720px; }
.site-header { position:fixed; top:18px; left:0; right:0; z-index:50; display:flex; justify-content:center; pointer-events:none; }
.nav-pill { pointer-events:auto; width:fit-content; max-width:calc(100vw - 36px); display:inline-flex; align-items:center; gap:26px; padding:10px 12px; border:1px solid rgba(18,20,21,.15); border-radius:999px; background:rgba(255,255,255,.86); backdrop-filter:blur(18px); box-shadow:0 12px 40px rgba(18,20,21,.12); }
.brand-link { display:flex; align-items:center; padding:0 12px; }
.brand-link img { width:152px; height:auto; object-fit:contain; }
.nav-links { display:flex; gap:22px; align-items:center; margin:0; }
.nav-links a { font-size:14px; font-weight:700; color:#242829; }
.nav-cta,.button { min-height:46px; display:inline-flex; align-items:center; justify-content:center; padding:0 20px; border-radius:999px; font-weight:800; font-size:15px; border:1px solid transparent; white-space:nowrap; }
.nav-cta,.button-dark { background:var(--charcoal); color:#fff; box-shadow:0 14px 32px rgba(5,6,7,.22); }
.button-light { background:#fff; color:var(--ink); border-color:rgba(18,20,21,.14); }
.button-gold { background:var(--gold); color:#111; box-shadow:0 16px 36px rgba(216,179,90,.28); }
.mobile-menu-toggle { display:none; width:44px; height:44px; border:0; background:var(--charcoal); border-radius:50%; align-items:center; justify-content:center; flex-direction:column; gap:5px; }
.mobile-menu-toggle span { width:18px; height:2px; background:#fff; display:block; }
.mobile-menu { display:none; }
.hero { min-height:94vh; padding:132px 6vw 64px; display:grid; grid-template-columns:minmax(0, .9fr) minmax(420px, 1.1fr); gap:58px; align-items:center; background:linear-gradient(180deg, var(--mist), #fff 72%); }
.hero-copy { padding-top:30px; }
.hero-actions { display:flex; flex-wrap:wrap; gap:12px; margin-top:30px; }
.hero-media { position:relative; min-height:620px; }
.hero-media picture, .hero-media img { width:100%; height:100%; min-height:620px; border-radius:8px; }
.hero-media:before { content:""; position:absolute; left:-26px; top:44px; width:42%; height:72%; border:1px solid rgba(18,20,21,.18); border-radius:8px; z-index:0; }
.hero-media picture { position:relative; z-index:1; box-shadow:0 24px 70px rgba(18,20,21,.2); overflow:hidden; display:block; }
.proof-card { position:absolute; right:28px; bottom:28px; z-index:2; background:#fff; border-radius:8px; padding:20px 24px; box-shadow:0 16px 44px rgba(0,0,0,.22); min-width:220px; }
.proof-card strong { display:block; font-size:24px; }
.proof-card span { color:var(--muted); font-weight:700; }
.stat-rail { display:grid; grid-template-columns:repeat(3, 1fr); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.stat-rail div { padding:32px 6vw; border-right:1px solid var(--line); }
.stat-rail div:last-child { border-right:0; }
.stat-rail strong { display:block; font-size:34px; margin-bottom:6px; }
.stat-rail span { color:var(--muted); font-weight:700; }
section { padding:92px 6vw; }
.band-white { background:#fff; }
.band-soft { background:var(--paper); }
.split-proof { display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:start; }
.split-proof p:last-child { font-size:22px; color:#2f3638; margin:0; }
.section-head { max-width:880px; margin:0 auto 44px; text-align:center; }
.section-head.narrow { max-width:680px; }
.service-grid { display:grid; grid-template-columns:repeat(2, minmax(0,1fr)); gap:22px; }
.service-card { background:#fff; border:1px solid var(--line); border-radius:8px; overflow:hidden; display:grid; grid-template-columns:45% 55%; min-height:380px; }
.service-card img { height:100%; width:100%; }
.service-card div { padding:34px; display:flex; flex-direction:column; justify-content:center; }
.service-card a { font-weight:800; margin-top:14px; color:var(--gold-dark); }
.process-panel { display:grid; grid-template-columns:0.9fr 1fr; gap:0; padding:0; background:var(--charcoal); color:#fff; }
.process-image img { width:100%; height:100%; min-height:680px; }
.process-copy { padding:82px 6vw; }
.process-copy p { color:#d7dcdd; }
.process-copy .eyebrow { color:var(--gold); }
.process-copy ol { list-style:none; padding:0; margin:34px 0; display:grid; gap:18px; }
.process-copy li { display:grid; grid-template-columns:46px 1fr; gap:14px; }
.process-copy li span { color:var(--gold); font-weight:900; }
.process-copy li p { margin:6px 0 0; }
.gallery-grid { display:grid; grid-template-columns:repeat(4, minmax(0,1fr)); gap:16px; }
.gallery-grid figure { margin:0; position:relative; overflow:hidden; border-radius:8px; background:#eef1ec; aspect-ratio:4 / 3; }
.gallery-grid img { width:100%; height:100%; min-height:0; object-fit:cover; display:block; transition:transform .3s ease; }
.gallery-grid figcaption { position:absolute; left:14px; bottom:14px; background:rgba(255,255,255,.9); border-radius:999px; padding:9px 13px; font-weight:800; font-size:13px; }
.gallery-grid figure:hover img { transform:scale(1.04); }
.center { text-align:center; margin-top:34px; display:flex; justify-content:center; }
.google-reviews { padding-top:82px; padding-bottom:82px; }
.gr-summary { max-width:860px; margin:0 auto; background:#fff; border:1px solid var(--line); border-radius:8px; padding:26px; display:grid; grid-template-columns:74px 1fr auto; gap:24px; align-items:center; box-shadow:0 16px 44px rgba(18,20,21,.08); }
.gr-logo { width:64px; height:64px; border-radius:50%; display:grid; place-items:center; font-size:36px; font-weight:900; color:#4285f4; border:1px solid var(--line); }
.gr-label { margin:0 0 4px; font-size:13px; text-transform:uppercase; color:var(--muted); font-weight:800; }
.gr-score { display:flex; gap:12px; align-items:center; font-size:42px; font-weight:900; }
.gr-score span { color:#fbbc04; font-size:17px; display:inline-flex; gap:2px; }
.pill-link { display:inline-flex; align-items:center; justify-content:center; min-height:44px; border-radius:999px; background:var(--charcoal); color:#fff; padding:0 18px; font-weight:800; }
.owner-band { display:grid; grid-template-columns:380px 1fr; gap:56px; align-items:center; background:var(--mist); }
.owner-band img { border-radius:8px; height:480px; width:100%; object-position:center top; }
.final-cta { background:var(--charcoal); color:#fff; display:flex; justify-content:space-between; gap:32px; align-items:center; }
.final-cta p { color:#d7dcdd; max-width:650px; }
.final-cta .eyebrow { color:var(--gold); }
.page-hero { padding:150px 6vw 74px; background:linear-gradient(180deg, var(--mist), #fff); }
.page-hero.compact { text-align:center; display:grid; justify-items:center; }
.page-hero.compact p { max-width:760px; }
.image-hero,.service-detail,.contact-hero { display:grid; grid-template-columns:1fr 430px; gap:48px; align-items:center; }
.image-hero img,.service-detail img,.contact-hero img { width:100%; height:520px; border-radius:8px; object-position:center top; }
.service-rows { display:grid; gap:28px; }
.service-row { display:grid; grid-template-columns:42% 1fr; gap:44px; align-items:center; border-bottom:1px solid var(--line); padding:0 0 42px; }
.service-row img { height:520px; border-radius:8px; }
.service-row ul,.detail-grid ul { margin:28px 0; padding-left:22px; color:var(--muted); line-height:1.8; font-size:17px; }
.selection-band { display:grid; grid-template-columns:1fr 360px; gap:48px; align-items:center; }
.selection-band img { height:460px; border-radius:8px; }
.detail-grid { display:grid; grid-template-columns:.8fr 1fr; gap:54px; }
.faq-list { max-width:900px; margin:0 auto; }
.faq-list details { background:#fff; border:1px solid var(--line); border-radius:8px; padding:22px 24px; margin-bottom:14px; }
.faq-list summary { cursor:pointer; font-weight:900; font-size:19px; }
.faq-list p { margin-bottom:0; }
.timeline-wrap { display:grid; grid-template-columns:1fr 420px; gap:50px; align-items:start; }
.timeline { list-style:none; margin:0; padding:0; display:grid; gap:0; counter-reset:item; }
.timeline li { display:grid; grid-template-columns:74px 1fr; gap:22px; padding:28px 0; border-bottom:1px solid var(--line); }
.timeline li span { width:52px; height:52px; border-radius:50%; background:var(--gold); display:grid; place-items:center; font-weight:900; }
.timeline h2 { font-size:28px; }
.timeline p { margin:8px 0 0; }
.timeline-wrap aside { position:sticky; top:120px; background:var(--paper); border-radius:8px; overflow:hidden; }
.timeline-wrap aside p { padding:22px; margin:0; }
.bio-section { display:grid; grid-template-columns:.7fr 1fr; gap:56px; }
.bio-section p:last-child { font-size:20px; color:#333; margin:0; }
.community-grid { display:grid; grid-template-columns:1.1fr .9fr; gap:48px; align-items:center; }
.community-grid img { border-radius:8px; height:430px; width:100%; }
.trust-strip { display:flex; gap:24px; align-items:center; border-top:1px solid var(--line); border-bottom:1px solid var(--line); padding-top:38px; padding-bottom:38px; }
.trust-strip img { width:210px; height:auto; object-fit:contain; }
.projects-page .gallery-grid { grid-template-columns:repeat(3, minmax(0,1fr)); }
.contact-layout { display:grid; grid-template-columns:.8fr 1.2fr; gap:36px; align-items:start; }
.contact-card { background:var(--charcoal); color:#fff; border-radius:8px; padding:36px; }
.contact-card p { color:#d7dcdd; }
.contact-form { display:grid; grid-template-columns:1fr 1fr; gap:16px; background:var(--paper); padding:32px; border-radius:8px; border:1px solid var(--line); }
.contact-form label { display:grid; gap:8px; color:#2e3436; font-weight:800; }
.contact-form input,.contact-form textarea { width:100%; border:1px solid #cfd8da; border-radius:8px; padding:14px 15px; font:inherit; background:#fff; }
.contact-form textarea,.contact-form button { grid-column:1 / -1; }
.contact-band { background:#fff; }
.site-footer { background:#f4f5f0; padding:70px 6vw 120px; border-top:1px solid var(--line); }
.footer-grid { display:grid; grid-template-columns:1.4fr .7fr 1fr 1fr; gap:44px; }
.site-footer h2 { font-size:16px; margin-bottom:18px; }
.site-footer a { display:block; color:#343a3c; margin:10px 0; font-weight:700; }
.site-footer img { width:180px; height:auto; object-fit:contain; margin-bottom:16px; }
.footer-credit-line,.footer-bottom { font-size:14px; color:#626b6f; }
.footer-bottom { margin-top:48px; }
.nap a { display:inline; }
.sticky-cta { display:none; }
@media (min-width: 1024px) {
  .mobile-menu-toggle { display:none !important; }
}
@media (max-width: 1023px) {
  h1 { font-size:42px; }
  h2 { font-size:32px; }
  .site-header { top:10px; }
  .nav-pill { width:calc(100vw - 24px); justify-content:space-between; gap:14px; }
  .nav-links,.nav-cta { display:none; }
  .mobile-menu-toggle { display:flex; }
  .mobile-menu { position:fixed; top:72px; left:12px; right:12px; z-index:49; background:#fff; border:1px solid var(--line); border-radius:8px; padding:14px; box-shadow:0 18px 50px rgba(0,0,0,.16); }
  .mobile-menu.is-open { display:grid; gap:8px; }
  .mobile-menu a { padding:13px 12px; font-weight:800; border-bottom:1px solid var(--line); }
  .mobile-menu a:last-child { border-bottom:0; }
  .hero,.split-proof,.process-panel,.owner-band,.image-hero,.service-detail,.contact-hero,.service-row,.selection-band,.detail-grid,.timeline-wrap,.bio-section,.community-grid,.contact-layout,.footer-grid { grid-template-columns:1fr; }
  .hero { min-height:auto; padding-top:112px; gap:36px; }
  .hero-media,.hero-media picture,.hero-media img { min-height:430px; }
  .stat-rail { grid-template-columns:1fr; }
  .stat-rail div { border-right:0; border-bottom:1px solid var(--line); }
  .service-grid,.gallery-grid,.projects-page .gallery-grid { grid-template-columns:1fr 1fr; }
  .service-card { grid-template-columns:1fr; }
  .service-card img { height:310px; }
  .process-copy { padding:54px 6vw; }
  .gr-summary { grid-template-columns:58px 1fr; }
  .gr-summary .pill-link { grid-column:1 / -1; }
  .footer-grid { gap:28px; }
}
@media (max-width: 640px) {
  body { padding-bottom:60px; }
  h1 { font-size:34px; }
  h2 { font-size:27px; }
  h3 { font-size:22px; }
  p,.lead { font-size:16px; }
  section { padding:64px 22px; }
  .page-hero { padding:118px 22px 54px; }
  .brand-link img { width:134px; }
  .nav-pill { padding:8px; }
  .hero { padding:108px 22px 48px; }
  .hero-media,.hero-media picture,.hero-media img { min-height:340px; }
  .proof-card { position:relative; right:auto; bottom:auto; margin:-40px 16px 0; }
  .hero-media:before { display:none; }
  .hero-actions { display:grid; }
  .button { width:100%; }
  .service-grid,.gallery-grid,.projects-page .gallery-grid { grid-template-columns:1fr; }
  .gallery-grid figure { aspect-ratio:4 / 3; }
  .process-image img { min-height:360px; }
  .owner-band img,.image-hero img,.service-detail img,.contact-hero img,.service-row img,.selection-band img,.community-grid img { height:340px; }
  .contact-form { grid-template-columns:1fr; padding:22px; }
  .timeline li { grid-template-columns:50px 1fr; }
  .timeline li span { width:42px; height:42px; }
  .trust-strip { display:grid; }
  .final-cta { display:grid; }
  .sticky-cta { position:fixed; left:0; right:0; bottom:0; z-index:60; display:grid; grid-template-columns:1fr 1fr; height:58px; box-shadow:0 -8px 24px rgba(0,0,0,.16); }
  .sticky-cta a { display:grid; place-items:center; font-weight:900; color:#111; background:var(--gold); }
  .sticky-cta a + a { color:#fff; background:#0a0a0a; }
  .site-footer { padding-bottom:90px; }
}

/* Design polish pass: template1-inspired glass, motion, menu and review treatment */
:root {
  --ink:#071426;
  --charcoal:#050914;
  --muted:#60707a;
  --line:rgba(7,20,38,.12);
  --paper:#f4f7f4;
  --mist:#e8f2f5;
  --sky:#c8dce4;
  --gold:#d7b65d;
  --gold-dark:#8a6920;
  --electric:#8cc7d8;
  --glass:rgba(255,255,255,.66);
  --glass-strong:rgba(255,255,255,.82);
  --glass-border:rgba(255,255,255,.82);
  --shadow-glass:0 1px 0 rgba(255,255,255,.9) inset,0 0 0 1px rgba(7,20,38,.05),0 18px 44px -18px rgba(7,20,38,.36);
  --shadow-soft:0 1px 2px rgba(7,20,38,.05),0 18px 44px -22px rgba(7,20,38,.22);
}
body { background:#fff; color:var(--ink); -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; }
a,button { -webkit-tap-highlight-color:transparent; }
.reveal { opacity:0; transform:translateY(22px); transition:opacity .75s cubic-bezier(.16,1,.3,1), transform .75s cubic-bezier(.16,1,.3,1); }
.reveal.in { opacity:1; transform:none; }

/* Glass navigation */
.site-header { position:fixed; inset:0 0 auto 0; z-index:90; height:0; pointer-events:none; display:block; }
.nav-wrap { position:fixed; top:18px; left:0; right:0; display:flex; justify-content:center; pointer-events:none; }
.nav-pill {
  pointer-events:auto;
  width:auto;
  max-width:calc(100vw - 32px);
  display:flex;
  align-items:center;
  gap:4px;
  padding:7px 7px 7px 18px;
  background:var(--glass);
  border:1px solid var(--glass-border);
  border-radius:999px;
  box-shadow:var(--shadow-glass);
  backdrop-filter:blur(26px) saturate(180%);
  -webkit-backdrop-filter:blur(26px) saturate(180%);
}
.brand-link { display:flex; align-items:center; padding:0 18px 0 0; margin-right:12px; border-right:1px solid rgba(7,20,38,.1); background:transparent; }
.brand-link img { width:156px; height:auto; object-fit:contain; background:transparent; }
.nav-links { display:flex; align-items:center; gap:2px; }
.nav-links a {
  padding:10px 15px;
  border-radius:999px;
  color:#25303a;
  font-size:14px;
  font-weight:760;
  letter-spacing:0;
  transition:background .22s ease, color .22s ease, transform .22s ease;
}
.nav-links a:hover,.nav-links a.active { background:rgba(7,20,38,.06); color:var(--ink); }
.nav-cta,.button,.pill-link,.gr-cta {
  border:1px solid rgba(7,20,38,.16);
  box-shadow:0 1px 0 rgba(255,255,255,.16) inset,0 12px 30px -18px rgba(7,20,38,.55);
  transition:transform .24s ease, box-shadow .24s ease, border-color .24s ease, background .24s ease;
}
.nav-cta {
  min-height:46px;
  padding:0 20px;
  margin-left:7px;
  background:var(--charcoal);
  color:#fff;
  border-color:rgba(255,255,255,.12);
}
.nav-cta:hover,.button:hover,.pill-link:hover,.gr-cta:hover { transform:translateY(-2px); box-shadow:0 1px 0 rgba(255,255,255,.18) inset,0 18px 38px -18px rgba(7,20,38,.58); }
.nav-toggle { display:none; width:46px; height:46px; border-radius:999px; background:var(--charcoal); border:1px solid rgba(255,255,255,.12); align-items:center; justify-content:center; flex-direction:column; gap:6px; box-shadow:0 12px 28px -18px rgba(7,20,38,.7); }
.nav-toggle span { width:18px; height:2px; background:#fff; border-radius:999px; display:block; transition:transform .25s ease, opacity .25s ease; }
.nav-toggle[aria-expanded="true"] span:first-child { transform:translateY(4px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:last-child { transform:translateY(-4px) rotate(-45deg); }

/* Fuller, sharper hero */
.hero {
  min-height:100svh;
  padding:142px clamp(24px,6vw,96px) 78px;
  grid-template-columns:minmax(0,.92fr) minmax(420px,1.08fr);
  gap:clamp(34px,5vw,76px);
  align-items:center;
  color:#fff;
  background:
    linear-gradient(115deg,rgba(5,9,20,.98) 0%,rgba(8,20,38,.96) 48%,rgba(229,239,242,.92) 48.2%,rgba(244,247,244,.98) 100%);
  overflow:hidden;
}
.hero-copy { position:relative; z-index:2; padding-top:8px; }
.hero .eyebrow { color:var(--electric); margin-bottom:18px; }
.hero h1 { color:#fff; font-size:clamp(48px,6.2vw,104px); line-height:.93; max-width:900px; letter-spacing:0; text-wrap:balance; }
.hero .lead { color:rgba(255,255,255,.78); max-width:690px; margin-top:24px; }
.hero-actions { gap:14px; margin-top:34px; }
.button { min-height:52px; padding:0 23px; border-radius:999px; font-weight:860; white-space:normal; text-align:center; }
.button-dark { background:var(--charcoal); color:#fff; border-color:rgba(7,20,38,.18); }
.button-light { background:#fff; color:var(--ink); border-color:rgba(7,20,38,.16); }
.hero .button-dark { background:#fff; color:var(--ink); border-color:rgba(255,255,255,.65); box-shadow:0 18px 42px -22px rgba(0,0,0,.85); }
.hero .button-light,.process-panel .button-light { background:rgba(255,255,255,.1); color:#fff; border-color:rgba(255,255,255,.22); backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px); }
.button-gold { background:var(--gold); color:#14100a; border-color:rgba(255,255,255,.24); box-shadow:0 18px 42px -20px rgba(215,182,93,.62); }
.hero-media { min-height:690px; position:relative; }
.hero-media picture { display:block; height:100%; min-height:690px; border-radius:8px; overflow:hidden; box-shadow:0 32px 90px -42px rgba(7,20,38,.65); border:1px solid rgba(255,255,255,.42); }
.hero-media img { width:100%; height:100%; min-height:690px; border-radius:0; filter:saturate(.98) contrast(1.04); }
.hero-media:before { display:none; }
.proof-card {
  right:auto;
  left:28px;
  bottom:28px;
  border-radius:8px;
  min-width:244px;
  background:rgba(255,255,255,.78);
  border:1px solid rgba(255,255,255,.88);
  backdrop-filter:blur(20px) saturate(170%);
  -webkit-backdrop-filter:blur(20px) saturate(170%);
  box-shadow:var(--shadow-glass);
}
.proof-card strong { color:var(--ink); }
.proof-card span { color:#4d5c66; }
.stat-rail { background:#fff; border-color:var(--line); }
.stat-rail div { padding:34px clamp(24px,6vw,96px); }
.stat-rail strong { color:var(--ink); font-size:clamp(28px,3vw,44px); }
.stat-rail span { color:#53636c; }

section { padding:clamp(72px,8vw,128px) clamp(24px,6vw,96px); }
.split-proof { grid-template-columns:minmax(0,.85fr) minmax(0,1.15fr); gap:clamp(32px,6vw,90px); border-bottom:1px solid var(--line); }
.split-proof h2,.section-head h2 { text-wrap:balance; letter-spacing:0; }
.split-proof p:last-child { font-size:clamp(20px,2.3vw,32px); line-height:1.28; color:#1b2731; }
.section-head { max-width:980px; margin-bottom:54px; }
.section-head h2 { font-size:clamp(36px,5.2vw,78px); }

.service-grid { gap:24px; }
.service-card {
  min-height:430px;
  border-color:rgba(7,20,38,.1);
  box-shadow:var(--shadow-soft);
  background:rgba(255,255,255,.92);
  transition:transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}
.service-card:hover { transform:translateY(-4px); border-color:rgba(7,20,38,.18); box-shadow:0 22px 58px -32px rgba(7,20,38,.42); }
.service-card img { filter:saturate(.98) contrast(1.03); }
.service-card div { padding:clamp(28px,4vw,48px); }
.service-card a { color:var(--ink); width:max-content; border-bottom:2px solid var(--gold); padding-bottom:4px; }

/* Process: fix the squashed text column and make the section intentional */
.process-panel {
  grid-template-columns:minmax(0,.95fr) minmax(0,1.05fr);
  background:var(--charcoal);
  overflow:hidden;
}
.process-image img { min-height:760px; filter:saturate(.92) contrast(1.04); }
.process-copy { padding:clamp(72px,7vw,118px) clamp(28px,6vw,96px); min-width:0; }
.process-copy h2 { font-size:clamp(40px,5.2vw,82px); color:#fff; text-wrap:balance; }
.process-copy ol { gap:0; border-top:1px solid rgba(255,255,255,.13); }
.process-copy li {
  grid-template-columns:52px minmax(0,1fr);
  gap:18px;
  padding:22px 0;
  border-bottom:1px solid rgba(255,255,255,.13);
  min-width:0;
}
.process-copy li span { grid-row:1 / span 2; color:var(--gold); font-family:ui-monospace,SFMono-Regular,Menlo,monospace; }
.process-copy li strong { grid-column:2; color:#fff; font-size:18px; line-height:1.3; }
.process-copy li p { grid-column:2; max-width:58ch; color:rgba(255,255,255,.7); margin:7px 0 0; min-width:0; }

.gallery-grid { gap:18px; }
.gallery-grid figure { border-radius:8px; box-shadow:var(--shadow-soft); }
.gallery-grid figcaption { background:rgba(255,255,255,.86); border:1px solid rgba(255,255,255,.86); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px); }

/* Template1-style Google review marquee */
.google-reviews { overflow:hidden; background:#fff; border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.gr-summary {
  max-width:1100px;
  margin:0 auto 36px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  padding:22px 24px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:8px;
  box-shadow:var(--shadow-soft);
}
.gr-sum-left { display:flex; align-items:center; gap:18px; min-width:0; }
.gr-logo { width:52px; height:52px; border-radius:999px; background:#f8f9fa; border:1px solid var(--line); display:flex; align-items:center; justify-content:center; flex:0 0 auto; }
.gr-meta-top { display:flex; align-items:baseline; gap:10px; }
.gr-score { display:inline-flex; align-items:baseline; gap:12px; font-size:34px; font-weight:850; color:var(--ink); line-height:1; }
.gr-stars { color:#fbbc05; font-size:17px; letter-spacing:0; }
.gr-sub { color:var(--muted); font-size:14px; }
.gr-sub strong { color:var(--ink); }
.gr-cta { display:inline-flex; align-items:center; justify-content:center; min-height:44px; padding:0 18px; border-radius:999px; background:#fff; color:var(--ink); font-weight:760; white-space:nowrap; }
.gr-marquee { position:relative; overflow:hidden; margin:0 -96px 18px; padding:10px 0; min-height:184px; }
.gr-marquee::before,.gr-marquee::after { content:""; position:absolute; top:0; bottom:0; width:110px; z-index:2; pointer-events:none; }
.gr-marquee::before { left:0; background:linear-gradient(90deg,#fff,rgba(255,255,255,0)); }
.gr-marquee::after { right:0; background:linear-gradient(-90deg,#fff,rgba(255,255,255,0)); }
.gr-track { display:flex; gap:20px; width:max-content; animation:grScroll 46s linear infinite; will-change:transform; }
.gr-marquee-reverse .gr-track { animation-direction:reverse; animation-duration:54s; }
.gr-marquee:hover .gr-track { animation-play-state:paused; }
.gr-card { flex:0 0 360px; display:flex; flex-direction:column; gap:12px; padding:20px 22px; border:1px solid var(--line); border-radius:8px; background:#fff; box-shadow:var(--shadow-soft); }
.gr-card-head { display:flex; align-items:center; gap:12px; }
.gr-avatar { width:40px; height:40px; border-radius:999px; display:flex; align-items:center; justify-content:center; color:#fff; font-weight:850; font-size:13px; flex:0 0 auto; }
.gr-who { min-width:0; flex:1; }
.gr-name { color:var(--ink); font-weight:780; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.gr-date { color:var(--muted); font-size:12px; margin-top:2px; }
.gr-stars-row { display:flex; gap:2px; color:#fbbc05; font-size:15px; }
.gr-text { margin:0; font-size:14px; line-height:1.55; color:#263642; display:-webkit-box; -webkit-line-clamp:4; -webkit-box-orient:vertical; overflow:hidden; }
@keyframes grScroll { from { transform:translateX(0); } to { transform:translateX(-50%); } }

.owner-band { background:var(--mist); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.owner-band img { box-shadow:var(--shadow-soft); }
.final-cta {
  border-top:1px solid rgba(255,255,255,.12);
  background:linear-gradient(135deg,var(--charcoal),#0d1b2b);
}

/* Footer cleanup */
.site-footer { background:#f7f8f4; color:var(--ink); padding:74px clamp(24px,6vw,96px) 112px; }
.footer-grid { grid-template-columns:1.35fr .7fr 1fr 1fr; gap:clamp(28px,4vw,58px); }
.footer-brand,.footer-brand img { display:block; background:transparent; }
.footer-intro p { max-width:420px; }
.footer-badges { display:flex; flex-wrap:wrap; gap:8px; margin:20px 0; }
.footer-badges span { display:inline-flex; align-items:center; min-height:32px; padding:0 11px; border-radius:999px; background:#fff; border:1px solid var(--line); color:#34424b; font-size:12px; font-weight:760; }
.footer-huge { margin:58px 0 22px; white-space:nowrap; overflow:hidden; color:rgba(7,20,38,.92); font-size:clamp(58px,16vw,230px); line-height:.82; font-weight:900; letter-spacing:0; }
.footer-huge span { color:rgba(7,20,38,.18); }
.footer-bottom { display:flex; justify-content:space-between; border-top:1px solid var(--line); padding-top:22px; }

/* Full-screen mobile menu */
.mobile-menu {
  position:fixed;
  inset:0;
  z-index:95;
  display:flex !important;
  flex-direction:column;
  background:#fff;
  opacity:0;
  pointer-events:none;
  transform:translateY(10px);
  transition:opacity .32s cubic-bezier(.16,1,.3,1), transform .32s cubic-bezier(.16,1,.3,1);
}
.mobile-menu.is-open,.mobile-menu.open { opacity:1; pointer-events:auto; transform:none; }
.mobile-menu-head { min-height:84px; display:flex; align-items:center; justify-content:space-between; padding:18px 24px; border-bottom:1px solid var(--line); }
.mobile-menu-logo img { width:166px; height:auto; object-fit:contain; background:transparent; }
.mobile-menu-close { width:44px; height:44px; border-radius:999px; border:1px solid var(--line); background:var(--paper); position:relative; display:flex; align-items:center; justify-content:center; }
.mobile-menu-close span { position:absolute; width:18px; height:2px; background:var(--ink); border-radius:999px; }
.mobile-menu-close span:first-child { transform:rotate(45deg); }
.mobile-menu-close span:last-child { transform:rotate(-45deg); }
.mobile-menu-body { flex:1; display:flex; flex-direction:column; padding:30px 24px 24px; overflow:auto; }
.mobile-menu-kicker { color:var(--gold-dark); margin:0 0 24px; font-size:13px; font-weight:850; text-transform:uppercase; }
.mobile-menu-links { list-style:none; padding:0; margin:0 0 34px; border-top:1px solid var(--line); }
.mobile-menu-links li { border-bottom:1px solid var(--line); }
.mobile-menu-links a { display:flex; align-items:center; justify-content:space-between; gap:18px; padding:22px 2px; color:var(--ink); font-size:clamp(30px,10vw,54px); font-weight:850; line-height:.98; border-bottom:0; }
.mobile-menu-links a span { color:#94a1a8; font-size:12px; font-family:ui-monospace,SFMono-Regular,Menlo,monospace; font-weight:700; }
.mobile-menu-links a[aria-current="page"] { color:var(--gold-dark); }
.mobile-menu-foot { margin-top:auto; display:grid; gap:10px; padding-top:22px; border-top:1px solid var(--line); }
.mobile-menu-cta { min-height:64px; display:flex; align-items:center; justify-content:space-between; padding:14px 16px; border-radius:8px; background:var(--paper); border:1px solid var(--line); }
.mobile-menu-cta.primary { background:var(--charcoal); color:#fff; border-color:var(--charcoal); }
.mobile-menu-cta span { display:grid; gap:3px; }
.mobile-menu-cta strong { font-size:15px; }
.mobile-menu-cta small { color:var(--muted); font-weight:700; }
.mobile-menu-cta.primary small { color:rgba(255,255,255,.68); }
body.menu-open { overflow:hidden; }

@media (min-width:1024px) {
  .mobile-menu { display:none !important; }
}
@media (max-width:1023px) {
  .nav-wrap { top:10px; }
  .nav-pill { width:calc(100vw - 24px); justify-content:space-between; padding:8px; }
  .brand-link { border-right:0; margin-right:0; padding:0 0 0 8px; }
  .brand-link img { width:138px; }
  .nav-links,.nav-cta { display:none; }
  .nav-toggle { display:flex; }
}
@media (max-width:900px) {
  .hero,.split-proof,.process-panel,.owner-band,.image-hero,.service-detail,.contact-hero,.service-row,.selection-band,.detail-grid,.timeline-wrap,.bio-section,.community-grid,.contact-layout,.footer-grid { grid-template-columns:1fr; }
  .hero { min-height:auto; padding:118px 24px 60px; background:linear-gradient(180deg,var(--charcoal) 0%,#0b1a2c 62%,#fff 62.2%,#fff 100%); }
  .hero h1 { font-size:clamp(40px,12vw,72px); }
  .hero-media,.hero-media picture,.hero-media img { min-height:420px; }
  .service-grid,.gallery-grid,.projects-page .gallery-grid { grid-template-columns:1fr; }
  .service-card { grid-template-columns:1fr; }
  .process-image img { min-height:420px; }
  .gr-summary { align-items:flex-start; }
  .gr-marquee { margin-left:-24px; margin-right:-24px; }
  .footer-huge { white-space:normal; }
}
@media (max-width:640px) {
  section { padding:66px 22px; }
  .button { width:100%; min-height:54px; }
  .hero { padding:112px 22px 48px; }
  .hero-actions { display:grid; }
  .hero-media,.hero-media picture,.hero-media img { min-height:350px; }
  .proof-card { left:14px; right:14px; bottom:14px; min-width:0; }
  .stat-rail div { padding:28px 22px; }
  .process-copy { padding:58px 22px; }
  .process-copy li { grid-template-columns:42px minmax(0,1fr); gap:14px; }
  .gr-summary { display:grid; }
  .gr-sum-left { align-items:flex-start; }
  .gr-card { flex-basis:292px; padding:18px; }
  .gr-marquee::before,.gr-marquee::after { width:42px; }
  .owner-band img,.image-hero img,.service-detail img,.contact-hero img,.service-row img,.selection-band img,.community-grid img { height:360px; }
  .sticky-cta a { border-top:1px solid rgba(255,255,255,.18); }
}
@media (prefers-reduced-motion:reduce) {
  .reveal { opacity:1; transform:none; transition:none; }
  .gr-track { animation:none; }
}
