:root{
  --deep:#0C1F1C; --sea:#143A33; --sea2:#0E2A26; --sea3:#0a1714;
  --brass:#C08A3E; --brass-l:#E2B978; --brass-d:#9c6f2f;
  --bone:#F4EFE4; --bone-2:#EAE3D2; --sand:#DED3BC;
  --ink:#13201C; --ink-2:#2c3b35; --muted:#5d6b63; --muted-d:#9fb0a7;
  --aqua:#5FB8B0;
  --line:rgba(19,32,28,.12); --line-2:rgba(19,32,28,.07);
  --line-w:rgba(255,255,255,.14);
  --serif:'Newsreader',Georgia,serif; --sans:'Hanken Grotesk',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--bone);color:var(--ink);-webkit-font-smoothing:antialiased;line-height:1.62;font-size:17px}
.wrap{max-width:1220px;margin:0 auto;padding:0 30px}
.wrap-n{max-width:980px;margin:0 auto;padding:0 30px}
a{color:inherit;text-decoration:none}
img,svg{display:block}
.serif{font-family:var(--serif)}
.eyebrow{font-family:var(--sans);font-size:12px;font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:var(--brass-d);display:inline-flex;align-items:center;gap:10px}
.eyebrow::before{content:"";width:26px;height:1.5px;background:var(--brass)}
.eyebrow.light{color:var(--brass-l)}.eyebrow.center{justify-content:center}
h2.h{font-family:var(--serif);font-weight:500;font-size:clamp(31px,4.6vw,55px);line-height:1.07;letter-spacing:-.01em;margin-top:18px}
h2.h em{font-style:italic;color:var(--brass-d)}
.lead{font-size:19px;color:var(--muted);max-width:60ch;margin-top:18px;line-height:1.6}
.ph{position:absolute;top:12px;left:12px;z-index:6;background:rgba(10,23,20,.78);color:var(--bone);font-size:10px;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;padding:5px 10px;border-radius:30px;backdrop-filter:blur(4px)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:10px;padding:16px 30px;border-radius:3px;font-weight:700;font-size:15.5px;transition:.28s cubic-bezier(.2,.7,.2,1);cursor:pointer;border:0;letter-spacing:.01em}
.btn-brass{background:var(--brass);color:#1a1205}
.btn-brass:hover{background:var(--brass-l);transform:translateY(-2px);box-shadow:0 14px 34px rgba(192,138,62,.34)}
.btn-line{border:1.5px solid var(--line-w);color:#fff;background:rgba(255,255,255,.04);backdrop-filter:blur(4px)}
.btn-line:hover{background:rgba(255,255,255,.12);border-color:#fff}
.btn-ink{background:var(--ink);color:var(--bone)}
.btn-ink:hover{background:var(--sea);transform:translateY(-2px)}
.btn-ghost{border:1.5px solid var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--brass);color:var(--brass-d)}

/* reveal */
.rv{opacity:0;transform:translateY(28px);transition:1s cubic-bezier(.16,1,.3,1)}
.rv.in{opacity:1;transform:none}
.d1{transition-delay:.07s}.d2{transition-delay:.16s}.d3{transition-delay:.25s}.d4{transition-delay:.34s}.d5{transition-delay:.43s}

/* ============ NAV ============ */
nav{position:fixed;inset:0 0 auto 0;z-index:100;transition:.45s}
.nav-in{display:flex;align-items:center;justify-content:space-between;padding:20px 30px;max-width:1220px;margin:0 auto;transition:.45s}
nav.scrolled{background:rgba(244,239,228,.92);backdrop-filter:blur(14px);border-bottom:1px solid var(--line-2);box-shadow:0 4px 30px rgba(19,32,28,.06)}
nav.scrolled .nav-in{padding:12px 30px}
.brand{display:flex;align-items:center;gap:16px}
.brand img{height:64px;transition:.3s}
.brand .lw,.brand .lb{transition:.3s}
.brand .lb{display:none}
nav.scrolled .brand .lw{display:none}nav.scrolled .brand .lb{display:block}
nav.scrolled .brand img{height:54px}
.brand .wm b{display:block;font-family:var(--serif);font-weight:600;font-size:25px;line-height:.95;color:#fff;transition:.3s}
.brand .wm span{display:block;font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;margin-top:4px;color:rgba(255,255,255,.7);font-weight:600;transition:.3s}
nav.scrolled .brand .wm b{color:var(--ink)}nav.scrolled .brand .wm span{color:var(--muted)}
.nav-links{display:flex;gap:32px;align-items:center}
.nav-links>a{font-size:14.5px;font-weight:600;color:rgba(255,255,255,.82);transition:.2s}
nav.scrolled .nav-links>a{color:var(--ink-2)}
.nav-links>a:hover{color:var(--brass-l)}nav.scrolled .nav-links>a:hover{color:var(--brass-d)}
.call{display:inline-flex;align-items:center;gap:8px;background:var(--brass);color:#1a1205!important;padding:11px 20px;border-radius:3px;font-size:14.5px;font-weight:700;transition:.25s}
.call:hover{background:var(--brass-l);transform:translateY(-1px)}
@media(max-width:920px){.nav-links>a:not(.call){display:none}}

/* ============ HERO ============ */
.hero{position:relative;min-height:100vh;display:flex;align-items:flex-end;overflow:hidden;color:#fff}
.hero-media{position:absolute;inset:0;z-index:0}
.hero-media svg{width:100%;height:100%}
.hero-media::after{content:"";position:absolute;inset:0;z-index:1;background:
  linear-gradient(180deg,rgba(10,23,20,.55) 0%,rgba(10,23,20,.2) 32%,rgba(10,23,20,.4) 64%,rgba(10,23,20,.94) 100%),
  linear-gradient(90deg,rgba(10,23,20,.62),transparent 60%)}
.hero-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;z-index:0}
.hero .hero-diver{display:none}
.hero-diver{position:absolute;right:-30px;bottom:60px;width:520px;opacity:.12;z-index:1;filter:brightness(0) invert(1)}
@media(max-width:900px){.hero-diver{width:330px;right:-70px;bottom:120px}}
.hero-in{position:relative;z-index:5;padding:0 0 96px;width:100%}
.hero h1{font-family:var(--serif);font-weight:500;font-size:clamp(40px,6.8vw,88px);line-height:1.02;letter-spacing:-.02em;max-width:17ch;margin:20px 0 0;text-shadow:0 2px 40px rgba(0,0,0,.3)}
.hero h1 em{font-style:italic;color:var(--brass-l)}
.hero .lead{color:#dfe9e4;max-width:50ch}
.hero-cta{display:flex;gap:15px;margin-top:36px;flex-wrap:wrap}
.hero-sig{display:flex;gap:26px;flex-wrap:wrap;margin-top:40px;padding-top:26px;border-top:1px solid var(--line-w);font-size:14px;color:#cdd9d3}
.hero-sig b{color:#fff;font-weight:700}
.scrollcue{position:absolute;left:50%;bottom:30px;transform:translateX(-50%);z-index:6;color:rgba(255,255,255,.6);font-size:11px;letter-spacing:.2em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:8px;animation:bob 2.4s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,7px)}}
@media(max-width:760px){.scrollcue{display:none}}

/* ============ TRUST STRIP ============ */
.trust{background:var(--sea3);color:var(--bone);border-bottom:1px solid var(--line-w)}
.trust-in{display:grid;grid-template-columns:repeat(4,1fr);max-width:1220px;margin:0 auto}
.trust .t{padding:30px 28px;border-right:1px solid var(--line-w);display:flex;flex-direction:column;gap:6px}
.trust .t:last-child{border-right:0}
.trust .t .k{font-family:var(--serif);font-size:23px;color:var(--brass-l);line-height:1.05}
.trust .t .v{font-size:13.5px;color:var(--muted-d);font-weight:500}
@media(max-width:760px){.trust-in{grid-template-columns:1fr 1fr}.trust .t:nth-child(2){border-right:0}.trust .t:nth-child(1),.trust .t:nth-child(2){border-bottom:1px solid var(--line-w)}}

/* ============ VALUE / WHY-IT-MATTERS ============ */
.value{padding:120px 0}
.value-grid{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center}
@media(max-width:920px){.value-grid{grid-template-columns:1fr;gap:44px}}
.value .points{margin-top:30px;display:grid;gap:2px}
.pt{display:grid;grid-template-columns:auto 1fr;gap:18px;padding:22px 0;border-top:1px solid var(--line)}
.pt:last-child{border-bottom:1px solid var(--line)}
.pt .pn{font-family:var(--serif);font-style:italic;font-size:20px;color:var(--brass-d)}
.pt h4{font-size:18px;font-weight:700;margin-bottom:4px}
.pt p{font-size:15.5px;color:var(--muted);line-height:1.55}
.value-card{position:relative;border-radius:6px;overflow:hidden;box-shadow:0 30px 70px rgba(19,32,28,.2)}
.value-card .ba{aspect-ratio:4/3}

/* before/after VIDEO toggle */
.vpair{position:relative}
.vstage{position:relative;border-radius:6px;overflow:hidden;box-shadow:0 30px 70px rgba(19,32,28,.2);aspect-ratio:16/10;background:#0a1714}
.vstage .vp{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:opacity .5s ease}
.vstage .vp.after{opacity:0}
.vpair.show-after .vp.after{opacity:1}
.vpair.show-after .vp.before{opacity:0}
.vplay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:5;width:74px;height:74px;border-radius:50%;
  background:rgba(192,138,62,.92);color:#1a1205;border:2px solid var(--brass-l);font-size:24px;cursor:pointer;display:grid;place-items:center;
  transition:.3s;backdrop-filter:blur(2px);padding-left:5px}
.vplay:hover{transform:translate(-50%,-50%) scale(1.08);background:var(--brass-l)}
.vpair.playing .vplay{opacity:0;pointer-events:none}
.vstate{position:absolute;top:14px;left:14px;z-index:5;display:flex;align-items:center;gap:8px;background:rgba(10,23,20,.72);
  color:#fff;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:6px 12px;border-radius:30px;backdrop-filter:blur(4px)}
.vstate i{width:7px;height:7px;border-radius:50%;background:var(--brass-l);box-shadow:0 0 10px var(--brass-l)}
.vpair.show-after .vstate i{background:var(--aqua);box-shadow:0 0 10px var(--aqua)}
.vtoggle{display:flex;gap:0;margin-top:14px;border:1px solid var(--line);border-radius:4px;overflow:hidden;width:fit-content}
.vtoggle .vt{padding:10px 24px;background:#fff;border:0;font-family:var(--sans);font-weight:700;font-size:13px;letter-spacing:.04em;
  text-transform:uppercase;color:var(--muted);cursor:pointer;transition:.22s}
.vtoggle .vt+.vt{border-left:1px solid var(--line)}
.vtoggle .vt.active{background:var(--ink);color:var(--bone)}
.vpair figcaption{margin-top:14px;font-size:13.5px;color:var(--muted);font-style:italic}
.proof{padding:30px 0 110px}
.proof .head{max-width:680px;margin-bottom:54px}
.proof-grid{display:grid;grid-template-columns:1fr 1fr;gap:34px}
@media(max-width:820px){.proof-grid{grid-template-columns:1fr;gap:44px}}

/* ============ SERVICES ============ */
.svc{padding:30px 0 120px}
.svc .head{max-width:680px;margin-bottom:60px}
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
@media(max-width:780px){.svc-grid{grid-template-columns:1fr}}
.scard{position:relative;background:#fff;border:1px solid var(--line-2);border-radius:6px;overflow:hidden;transition:.35s cubic-bezier(.2,.7,.2,1);display:flex;flex-direction:column}
.scard:hover{transform:translateY(-6px);box-shadow:0 28px 60px rgba(19,32,28,.16);border-color:transparent}
.scard .img{position:relative;aspect-ratio:16/9;overflow:hidden}
.scard .img svg{transition:.6s}
.scard:hover .img svg{transform:scale(1.05)}
.scard .body{padding:30px 32px 34px;flex:1;display:flex;flex-direction:column}
.scard .ix{font-family:var(--serif);font-style:italic;font-size:16px;color:var(--brass-d)}
.scard h3{font-family:var(--serif);font-weight:500;font-size:27px;letter-spacing:-.01em;margin:8px 0 12px}
.scard p{color:var(--muted);font-size:15.5px;line-height:1.58;flex:1}
.scard .more{display:inline-flex;align-items:center;gap:8px;margin-top:20px;color:var(--brass-d);font-weight:700;font-size:14.5px;transition:.25s}
.scard:hover .more{gap:13px}

/* ============ MEET JARRETT (E-E-A-T) ============ */
.about{background:var(--deep);color:var(--bone);position:relative;overflow:hidden}
.about::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 70% at 88% 12%,rgba(192,138,62,.18),transparent 60%)}
.about-in{position:relative;z-index:2;padding:110px 0;display:grid;grid-template-columns:.85fr 1.15fr;gap:64px;align-items:center}
@media(max-width:920px){.about-in{grid-template-columns:1fr;gap:44px}}
.about-photo{position:relative;border-radius:6px;overflow:hidden;box-shadow:0 30px 70px rgba(0,0,0,.4);aspect-ratio:5/6;max-width:420px}
.about h2{font-family:var(--serif);font-weight:500;font-size:clamp(30px,4.4vw,50px);line-height:1.08;margin-top:18px}
.about h2 em{font-style:italic;color:var(--brass-l)}
.about p{color:#cdd9d3;font-size:17px;margin-top:20px;max-width:54ch}
.creds{display:flex;flex-wrap:wrap;gap:12px;margin-top:30px}
.cred{display:flex;align-items:center;gap:9px;border:1px solid var(--line-w);background:rgba(255,255,255,.04);padding:11px 16px;border-radius:3px;font-size:13.5px;font-weight:600}
.cred .cd{color:var(--brass-l)}
.about .sign{margin-top:32px;font-family:var(--serif);font-style:italic;font-size:22px;color:var(--brass-l)}

/* ============ PROCESS ============ */
.proc{padding:120px 0}
.proc .head{text-align:center;max-width:640px;margin:0 auto 64px}
.proc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--line)}
@media(max-width:820px){.proc-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.proc-grid{grid-template-columns:1fr}}
.step{padding:36px 30px 34px;border-right:1px solid var(--line);position:relative}
.step:last-child{border-right:0}
.step .sn{font-family:var(--serif);font-size:15px;color:var(--brass-d);letter-spacing:.05em}
.step h4{font-family:var(--serif);font-weight:500;font-size:23px;margin:14px 0 10px}
.step p{color:var(--muted);font-size:15px;line-height:1.55}
@media(max-width:820px){.step:nth-child(2){border-right:0}}

/* ============ SERVICE AREA ============ */
.area{background:var(--bone-2)}
.area-in{padding:110px 0;display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center}
@media(max-width:920px){.area-in{grid-template-columns:1fr;gap:40px}}
.area-map{border-radius:6px;overflow:hidden;box-shadow:0 24px 56px rgba(19,32,28,.16);aspect-ratio:5/4.6;position:relative}
.cities{display:flex;flex-wrap:wrap;gap:10px;margin-top:28px}
.cities a{border:1px solid var(--line);background:#fff;padding:9px 16px;border-radius:30px;font-size:14px;font-weight:600;color:var(--ink-2);transition:.22s}
.cities a:hover{border-color:var(--brass);color:var(--brass-d);background:#fff;transform:translateY(-1px)}

/* ============ REVIEWS ============ */
.rev{padding:120px 0}
.rev .head{text-align:center;max-width:620px;margin:0 auto 54px}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:860px){.rev-grid{grid-template-columns:1fr}}
.rcard{background:#fff;border:1px solid var(--line-2);border-radius:6px;padding:34px 30px;position:relative}
.rcard .qm{font-family:var(--serif);font-size:60px;line-height:.6;color:var(--sand);height:30px}
.rcard .stars{color:var(--brass);font-size:15px;letter-spacing:3px}
.rcard p{font-family:var(--serif);font-size:18px;line-height:1.55;color:var(--ink);margin:16px 0 22px}
.rcard .who{display:flex;align-items:center;gap:13px}
.rcard .av{width:44px;height:44px;border-radius:50%;background:var(--sea);color:var(--brass-l);display:grid;place-items:center;font-family:var(--serif);font-size:20px}
.rcard .who b{display:block;font-size:14.5px}.rcard .who span{font-size:12.5px;color:var(--muted)}
.rev-note{text-align:center;margin-top:28px;font-size:12.5px;color:var(--muted);font-style:italic}

/* ============ FAQ ============ */
.faq{background:var(--sea3);color:var(--bone)}
.faq-in{padding:110px 0;display:grid;grid-template-columns:.8fr 1.2fr;gap:60px;align-items:start}
@media(max-width:920px){.faq-in{grid-template-columns:1fr;gap:36px}}
.faq h2{font-family:var(--serif);font-weight:500;font-size:clamp(30px,4.4vw,48px);line-height:1.08;margin-top:16px}
.faq .sticky{position:sticky;top:120px}
.faq p.sub{color:var(--muted-d);margin-top:18px;font-size:16px}
.q{border-bottom:1px solid var(--line-w)}
.q summary{padding:24px 0;font-family:var(--serif);font-weight:500;font-size:20px;cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:20px;align-items:baseline;transition:.2s}
.q summary:hover{color:var(--brass-l)}
.q summary::-webkit-details-marker{display:none}
.q summary::after{content:"+";color:var(--brass-l);font-size:26px;font-weight:400;transition:.25s;line-height:1}
.q[open] summary::after{transform:rotate(45deg)}
.q .a{padding:0 0 24px;color:var(--muted-d);font-size:15.5px;line-height:1.65;max-width:60ch}

/* ============ FINAL CTA ============ */
.cta{position:relative;overflow:hidden;color:#fff;padding:130px 0;text-align:center}
.cta-media{position:absolute;inset:0;z-index:0}
.cta-media svg{width:100%;height:100%}
.cta-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,23,20,.78),rgba(10,23,20,.92))}
.cta-in{position:relative;z-index:3}
.cta h2{font-family:var(--serif);font-weight:500;font-size:clamp(34px,6vw,68px);line-height:1.04;letter-spacing:-.02em}
.cta h2 em{font-style:italic;color:var(--brass-l)}
.cta p{color:#dfe9e4;margin:22px auto 0;max-width:46ch;font-size:18px}
.cta .hero-cta{justify-content:center;margin-top:38px}

/* ============ FOOTER ============ */
footer{background:var(--deep);color:var(--bone);padding:72px 0 40px;border-top:1px solid var(--line-w)}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px}
@media(max-width:860px){.foot-top{grid-template-columns:1fr 1fr;gap:32px}}
@media(max-width:520px){.foot-top{grid-template-columns:1fr}}
.foot-brand img{height:126px;margin-left:-6px}
.foot-brand p{color:var(--muted-d);font-size:14.5px;max-width:34ch;margin-top:8px}
.foot-brand .ph2{margin-top:18px;font-family:var(--serif);font-size:22px;color:var(--brass-l)}
.foot-col h5{font-family:var(--sans);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--brass-l);margin-bottom:18px;font-weight:700}
.foot-col a,.foot-col p{display:block;color:var(--muted-d);font-size:14.5px;margin-bottom:11px;transition:.2s}
.foot-col a:hover{color:#fff}
.legal{margin-top:54px;padding-top:24px;border-top:1px solid var(--line-w);display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:12.5px;color:var(--muted-d)}

/* sticky mobile bar */
.mbar{display:none}
@media(max-width:720px){
  .mbar{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:95;gap:9px;padding:10px 13px;background:rgba(244,239,228,.96);border-top:1px solid var(--line);backdrop-filter:blur(10px)}
  .mbar a{flex:1;text-align:center;padding:15px;border-radius:4px;font-weight:700;font-size:15px}
  .mbar .c{background:var(--ink);color:var(--bone)}.mbar .q{background:var(--brass);color:#1a1205}
  body{padding-bottom:76px}
  .hero-sig{display:none}
}

/* ============ SUBPAGE ADDITIONS (service / city / about / faq) ============ */
.shero{position:relative;min-height:64vh;display:flex;align-items:flex-end;overflow:hidden;color:#fff}
.shero-media{position:absolute;inset:0;z-index:0}
.shero-media svg{width:100%;height:100%}
.shero-media::after{content:"";position:absolute;inset:0;z-index:1;background:
  linear-gradient(180deg,rgba(10,23,20,.58) 0%,rgba(10,23,20,.3) 34%,rgba(10,23,20,.5) 70%,rgba(10,23,20,.95) 100%),
  linear-gradient(90deg,rgba(10,23,20,.66),transparent 64%)}
.shero-in{position:relative;z-index:5;padding:150px 0 72px;width:100%}
.shero h1{font-family:var(--serif);font-weight:500;font-size:clamp(36px,5.6vw,70px);line-height:1.04;letter-spacing:-.02em;max-width:18ch;margin:18px 0 0;text-shadow:0 2px 40px rgba(0,0,0,.3)}
.shero h1 em{font-style:italic;color:var(--brass-l)}
.shero .lead{color:#dfe9e4;max-width:54ch}
@media(max-width:760px){.shero-in{padding:128px 0 56px}.shero{min-height:auto}}

/* breadcrumb */
.crumb{position:static;inset:auto;z-index:auto;display:flex;flex-wrap:wrap;align-items:center;gap:9px;font-size:12.5px;font-weight:600;letter-spacing:.02em;color:rgba(255,255,255,.62)}
.crumb a{color:rgba(255,255,255,.62);transition:.2s}
.crumb a:hover{color:var(--brass-l)}
.crumb .sep{color:rgba(255,255,255,.3)}
.crumb b{color:#fff;font-weight:600}

/* long-form copy block */
.copy{padding:114px 0 0}
.copy-in{max-width:780px}
.copy .body{margin-top:26px}
.copy .body p{font-size:18px;color:var(--ink-2);line-height:1.72;margin-bottom:19px}
.copy .body p:last-child{margin-bottom:0}
.copy .body strong{color:var(--ink);font-weight:700}

/* "what's included" checklist */
.incl{padding:114px 0}
.incl .head{max-width:680px;margin-bottom:50px}
.checks{display:grid;grid-template-columns:repeat(2,1fr);gap:0 56px}
@media(max-width:760px){.checks{grid-template-columns:1fr;gap:0}}
.chk{display:grid;grid-template-columns:auto 1fr;gap:16px;padding:21px 0;border-top:1px solid var(--line);align-items:start}
.chk .ck{width:26px;height:26px;border-radius:50%;background:var(--sea);color:var(--brass-l);display:grid;place-items:center;font-size:12px;flex:none;margin-top:2px}
.chk h4{font-size:16.5px;font-weight:700;margin-bottom:3px}
.chk p{font-size:14.5px;color:var(--muted);line-height:1.52}

/* dark stat band (reuses .trust visual language) */
.band{background:var(--sea3);color:var(--bone)}
.band-in{display:grid;grid-template-columns:repeat(4,1fr);max-width:1220px;margin:0 auto}
.band .t{padding:38px 30px;border-right:1px solid var(--line-w);display:flex;flex-direction:column;gap:7px}
.band .t:last-child{border-right:0}
.band .t .k{font-family:var(--serif);font-size:27px;color:var(--brass-l);line-height:1.04}
.band .t .v{font-size:14px;color:var(--muted-d);font-weight:500;line-height:1.5}
@media(max-width:760px){.band-in{grid-template-columns:1fr 1fr}.band .t:nth-child(2){border-right:0}.band .t:nth-child(1),.band .t:nth-child(2){border-bottom:1px solid var(--line-w)}}

/* 3-up related services */
.svc-grid.three{grid-template-columns:repeat(3,1fr)}
@media(max-width:900px){.svc-grid.three{grid-template-columns:1fr}}

/* list card (e.g. "commonly recovered" — right column where no video applies) */
.listcard{background:#fff;border:1px solid var(--line-2);border-radius:6px;padding:36px 34px;box-shadow:0 24px 56px rgba(19,32,28,.1)}
.listcard h4{font-family:var(--serif);font-weight:500;font-size:24px;line-height:1.1;margin-bottom:5px}
.listcard .lcsub{color:var(--muted);font-size:14px;font-style:italic;margin-bottom:14px}
.listcard ul{list-style:none}
.listcard li{display:grid;grid-template-columns:auto 1fr;gap:14px;padding:14px 0;border-top:1px solid var(--line);font-size:15.5px;align-items:start;color:var(--ink-2)}
.listcard li:first-child{border-top:0}
.listcard li .d{color:var(--brass-d);font-family:var(--serif);font-style:italic;font-size:15px;margin-top:1px}
.listcard li b{font-weight:700;color:var(--ink)}

/* ============ INSTANT QUOTE ESTIMATOR (re-skinned to site tokens) ============ */
.calc-sec{background:var(--bone-2);padding:110px 0}
.calc-sec .head{text-align:center;max-width:640px;margin:0 auto 50px}
.calc{width:100%;max-width:920px;margin:0 auto;background:#fff;border-radius:6px;overflow:hidden;box-shadow:0 30px 70px rgba(19,32,28,.18)}
.calc .chead{background:var(--deep);color:var(--bone);padding:24px 32px;display:flex;align-items:center;gap:16px;position:relative}
.calc .chead::after{content:"";position:absolute;left:0;right:0;bottom:0;height:3px;background:linear-gradient(90deg,var(--brass),var(--brass-l) 50%,var(--brass))}
.calc .chead img{width:46px;height:auto}
.calc .chead .name{font-family:var(--serif);font-weight:600;font-size:20px;line-height:1.05}
.calc .chead .name .a{color:var(--brass-l)}
.calc .chead .tag{font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--brass-l);margin-top:5px;font-weight:600}
.calc .chead .est{margin-left:auto;text-align:right}
.calc .chead .est .t{font-family:var(--serif);font-size:16px}
.calc .chead .est .s{font-size:8.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--brass-l);margin-top:3px;font-weight:600}
.calc .cgrid{display:grid;grid-template-columns:1fr 330px}
@media(max-width:720px){.calc .cgrid{grid-template-columns:1fr}}
.calc .controls{padding:28px 32px 32px}
.calc .field{margin-bottom:20px}
.calc .field>label{display:block;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--brass-d);font-weight:700;margin-bottom:8px}
.calc .seg{display:flex;background:var(--bone);border:1px solid var(--line);border-radius:6px;padding:4px;gap:4px}
.calc .seg button{flex:1;border:0;background:transparent;cursor:pointer;padding:11px 8px;border-radius:4px;font-family:var(--sans);font-size:13px;font-weight:700;color:var(--muted);transition:.18s;line-height:1.2}
.calc .seg button .sub{display:block;font-size:9.5px;font-weight:500;letter-spacing:.02em;margin-top:3px;opacity:.85}
.calc .seg button.active{background:var(--sea);color:#fff;box-shadow:0 4px 12px -4px rgba(15,61,53,.5)}
.calc .seg button.active .sub{color:var(--brass-l)}
.calc select{width:100%;appearance:none;font-family:var(--sans);font-size:15px;color:var(--ink);background:#fff;border:1.5px solid var(--line);border-radius:6px;padding:13px 42px 13px 14px;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23C08A3E' stroke-width='3'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 15px center;transition:.18s}
.calc select:focus{outline:none;border-color:var(--brass);box-shadow:0 0 0 3px rgba(192,138,62,.15)}
.calc .addons{border-top:1px solid var(--line-2);padding-top:18px;margin-top:2px}
.calc .addon{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--line-2)}
.calc .addon:last-child{border-bottom:0}
.calc .addon .info .n{font-size:13.5px;font-weight:700;color:var(--ink)}
.calc .addon .info .p{font-size:11px;color:var(--muted);margin-top:1px}
.calc .stepper{display:flex;align-items:center;border:1.5px solid var(--line);border-radius:6px;overflow:hidden}
.calc .stepper button{width:32px;height:32px;border:0;background:var(--bone);color:var(--sea);font-size:18px;font-weight:600;cursor:pointer;transition:.15s;line-height:1}
.calc .stepper button:hover{background:var(--brass-l);color:#fff}
.calc .stepper .q{width:34px;text-align:center;font-size:14px;font-weight:700;color:var(--ink)}
.calc .result{background:linear-gradient(160deg,var(--sea) 0%,var(--deep) 100%);color:var(--bone);padding:30px 28px;display:flex;flex-direction:column}
.calc .result .rlabel{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--brass-l);font-weight:700}
.calc .result .amount{font-family:var(--serif);font-weight:500;font-size:52px;line-height:1;margin-top:8px;color:#fff;letter-spacing:-1px}
.calc .result .amount .cur{font-size:26px;vertical-align:super;color:var(--brass-l);margin-right:2px}
.calc .result .cadence{font-size:13px;color:var(--muted-d);margin-top:6px}
.calc .break{margin-top:22px;border-top:1px solid var(--line-w);padding-top:16px}
.calc .break .row{display:flex;justify-content:space-between;font-size:12.5px;padding:5px 0;color:var(--muted-d)}
.calc .break .row .v{font-weight:600;color:#fff;white-space:nowrap}
.calc .break .row .v.struck{text-decoration:line-through;color:rgba(220,210,182,.5);font-weight:500}
.calc .break .row.floorrow span:first-child,.calc .break .row.floorrow .v{color:var(--brass-l)}
.calc .ccta{margin-top:auto;padding-top:20px}
.calc .ccta a{display:block;text-align:center;border:0;cursor:pointer;background:var(--brass);color:#1a1205;font-family:var(--sans);font-weight:700;font-size:14px;letter-spacing:.01em;padding:15px;border-radius:3px;transition:.22s}
.calc .ccta a:hover{background:var(--brass-l);transform:translateY(-2px);box-shadow:0 14px 34px rgba(192,138,62,.34)}
.calc .disclaimer{font-size:9.5px;line-height:1.5;color:var(--muted-d);margin-top:12px;text-align:center}
.calc .pulse{animation:cpulse .4s ease}
@keyframes cpulse{0%{transform:scale(1)}40%{transform:scale(1.04)}100%{transform:scale(1)}}

/* ============================================================
   SWEEP 2 — LAYOUT NORMALIZATION (condense · justify · align)
   Single vertical rhythm, consistent head alignment, justified prose.
   Appended last so it authoritatively overrides earlier section padding.
   ============================================================ */
:root{ --sec:104px; --sec-sm:64px; }

/* 1) UNIFORM SECTION RHYTHM — every major band shares one cadence */
.value{padding:var(--sec) 0}
.proof{padding:0 0 var(--sec)}                 /* flows out of .value, closes the pair */
.svc{padding:var(--sec) 0}
.about-in{padding:var(--sec) 0}
.proc{padding:var(--sec) 0}
.calc-sec{padding:var(--sec) 0}
.area-in{padding:var(--sec) 0}
.rev{padding:var(--sec) 0}
.faq-in{padding:var(--sec) 0}
.cta{padding:calc(var(--sec) + 14px) 0}        /* terminal band gets a touch more */
@media(max-width:760px){
  .value,.svc,.about-in,.proc,.calc-sec,.area-in,.rev,.faq-in{padding:var(--sec-sm) 0}
  .proof{padding:0 0 var(--sec-sm)}
  .cta{padding:var(--sec-sm) 0}
}

/* 2) CONSISTENT HEAD ALIGNMENT + WIDTH
   Centered heads truly center; their lead inherits the centering and a shared max-width. */
.proc .head,.rev .head,.calc-sec .head{margin-left:auto;margin-right:auto;text-align:center;max-width:660px}
.proc .head .lead,.rev .head .lead,.calc-sec .head .lead{margin-left:auto;margin-right:auto}
.svc .head,.proof .head{max-width:720px}        /* left-aligned heads share one measure */
.value .lead,.svc .head .lead,.proof .head .lead{max-width:62ch}

/* 3) JUSTIFIED PROSE (per ruling) — multi-line body copy only.
   Last-line left, hyphenation on to prevent rivers, applied where lines actually wrap. */
.value .lead,.proof .head .lead,.svc .head .lead,
.about p,.copy .body p,.proc .head .lead,.rev .head .lead,.calc-sec .head .lead{
  text-align:justify;text-justify:inter-word;hyphens:auto;-webkit-hyphens:auto;text-align-last:left;
}
/* never justify short single-line UI text */
.hero .lead,.eyebrow,.btn,.cred,.step h4,.scard h3,.rcard p,.foot-brand p,.disclaimer,.crumb{
  text-align:left;hyphens:manual;
}
.cta p{text-align:center;hyphens:manual}

/* 4) VERTICAL ALIGNMENT FIXES — kill the ragged grid baselines */
.value-grid{align-items:start}                  /* copy + video top-aligned, not floating mid */
.proof-grid{align-items:start}
.svc-grid{align-items:stretch}                  /* equal-height service cards */
.scard{height:100%}
.proc-grid .step{display:flex;flex-direction:column}
.rev-grid{align-items:stretch}
.rcard{display:flex;flex-direction:column}
.rcard .who{margin-top:auto}                    /* pin attribution to card bottom — aligned row */

/* 5) HEAD SPACING — tighten the gap under section intros to one value */
.svc .head,.proof .head{margin-bottom:48px}
.proc .head,.rev .head,.calc-sec .head{margin-bottom:46px}

/* ============================================================
   SERVICE-AREA MAP (Leaflet) — brand theming
   ============================================================ */
.area-map{background:var(--sea2)}
#mm-map{position:absolute;inset:0;width:100%;height:100%;background:var(--sea2);z-index:1}
.area-map .map-badge{position:absolute;top:12px;left:12px;z-index:600;background:rgba(10,23,20,.82);
  color:var(--brass-l);font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  padding:6px 11px;border-radius:3px;pointer-events:none}
.area-map .leaflet-container{background:var(--sea2);font-family:var(--sans)}
/* nudge the dark basemap toward the sea-green palette */
.area-map .leaflet-tile{filter:saturate(.8) brightness(.92) contrast(1.03) hue-rotate(-10deg)}
.area-map .leaflet-control-attribution{background:rgba(10,23,20,.62);color:rgba(244,239,228,.55);font-size:9px}
.area-map .leaflet-control-attribution a{color:var(--brass-l)}
.area-map .leaflet-bar a{background:var(--deep);color:var(--bone);border-color:rgba(192,138,62,.5)}
.area-map .leaflet-bar a:hover{background:var(--sea);color:var(--brass-l)}
.area-map .leaflet-popup-content-wrapper{background:var(--deep);color:var(--bone);border:1px solid var(--brass-d);border-radius:4px;box-shadow:0 10px 30px rgba(0,0,0,.4)}
.area-map .leaflet-popup-tip{background:var(--deep);border:1px solid var(--brass-d)}
.area-map .leaflet-popup-content{font-size:12.5px;font-weight:600;line-height:1.4;margin:9px 13px;color:var(--bone)}
.area-map a.leaflet-popup-close-button{color:var(--brass-l)}

/* ============================================================
   HERO BUBBLES — faint air rising through water (CSS-only, additive)
   ============================================================ */
.bubbles{position:absolute;inset:0;z-index:1;overflow:hidden;pointer-events:none}
.bubble{position:absolute;bottom:-44px;border-radius:50%;
  background:radial-gradient(circle at 32% 28%, rgba(244,239,228,.72), rgba(226,185,120,.16) 56%, rgba(226,185,120,0) 72%);
  box-shadow:inset 0 0 7px rgba(244,239,228,.32);
  opacity:0;animation-name:bubrise;animation-timing-function:ease-in;animation-iteration-count:infinite;will-change:transform,opacity}
@keyframes bubrise{
  0%{transform:translateY(0) translateX(0) scale(.8);opacity:0}
  10%{opacity:.6}
  55%{opacity:.46}
  88%{opacity:.2}
  100%{transform:translateY(-108vh) translateX(var(--bx,12px)) scale(1.06);opacity:0}
}
@media(prefers-reduced-motion:reduce){.bubble{display:none}}

/* ============================================================
   MAP MARKER TOOLTIP (hover name + site cue)
   ============================================================ */
.area-map .leaflet-interactive.mm-pin-link{cursor:pointer}
.mm-tip.leaflet-tooltip{background:var(--deep);color:var(--bone);border:1px solid var(--brass-d);
  border-radius:4px;padding:7px 11px;font-family:var(--sans);box-shadow:0 10px 26px rgba(0,0,0,.45);white-space:nowrap}
.mm-tip.leaflet-tooltip b{display:block;font-size:13px;font-weight:700;letter-spacing:.01em}
.mm-tip .mm-tip-go{display:block;margin-top:2px;font-size:10.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--brass-l)}
.mm-tip .mm-tip-pv{display:inline-block;margin-top:3px;font-size:9.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-d)}
.mm-tip.leaflet-tooltip-top:before{border-top-color:var(--brass-d)}

/* ============================================================
   WHAT FOULING COSTS — compact 2-col with image
   ============================================================ */
.foul{margin-top:54px;border-top:1px solid var(--line);padding-top:44px;
  display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
@media(max-width:820px){.foul{grid-template-columns:1fr;gap:28px}}
.foul-text h3{font-family:var(--serif);font-weight:500;font-size:clamp(22px,2.5vw,30px);line-height:1.14;letter-spacing:-.01em;margin:12px 0 12px}
.foul-text h3 em{font-style:italic;color:var(--brass-d)}
.foul-text>p{color:var(--muted);font-size:15px;line-height:1.6;max-width:52ch}
.foul-scale{margin:20px 0 14px;display:flex;flex-direction:column;gap:8px}
.fr{display:flex;align-items:baseline;gap:14px;padding:11px 16px;background:#fff;border:1px solid var(--line-2);border-left:3px solid var(--brass-l);border-radius:5px}
.fr.ft-2{border-left-color:var(--brass)}
.fr.ft-3{border-left-color:var(--brass-d)}
.fr .pct{font-family:var(--serif);font-size:20px;color:var(--brass-d);min-width:80px;line-height:1}
.fr .lbl{font-size:13.5px;font-weight:600;color:var(--ink)}
.foul-note{color:var(--muted);font-size:12.5px;line-height:1.55;font-style:italic;margin:0}
.foul-media{position:relative;border-radius:8px;overflow:hidden;box-shadow:0 22px 50px rgba(19,32,28,.18);aspect-ratio:4/3}
.foul-img{width:100%;height:100%;object-fit:cover;display:block}

/* ============================================================
   SERVICE PHOTOS — hero backgrounds + related-services cards
   ============================================================ */
.shero-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;z-index:0}
.shero .hero-diver{display:none}                 /* real photo replaces the ghost watermark */
.scard .img img.scard-img{width:100%;height:100%;object-fit:cover;display:block;transition:.6s}
.scard:hover .img img.scard-img{transform:scale(1.05)}

/* ============================================================
   SESSION EDITS — case-video centering + green bubble divider
   ============================================================ */

/* "The case for a clean hull" — center the before/after video against the copy */
.value .value-grid{align-items:center}
.value .vpair{max-width:560px;margin-inline:auto;width:100%}

/* ---- GREEN BUBBLE DIVIDER (between sections) ---- */
.divider{position:relative;height:150px;overflow:hidden;background:linear-gradient(180deg,var(--sea) 0%,var(--deep) 100%)}
.divider::before{content:"";position:absolute;inset:0 0 auto 0;height:3px;background:linear-gradient(90deg,var(--brass),var(--brass-l) 50%,var(--brass));opacity:.9}
.divider::after{content:"";position:absolute;inset:auto 0 0 0;height:3px;background:linear-gradient(90deg,var(--brass),var(--brass-l) 50%,var(--brass));opacity:.5}
.divider .dwrap{position:relative;height:100%;max-width:1240px;margin:0 auto;display:flex;align-items:center;justify-content:center;z-index:2}
.divider .dmark{font-family:var(--serif);font-style:italic;font-size:clamp(16px,2vw,21px);color:var(--brass-l);letter-spacing:.04em;text-align:center;text-shadow:0 2px 24px rgba(0,0,0,.4)}
.divider .bubbles{position:absolute;inset:0;z-index:1;pointer-events:none}
.divider .bubbles span{position:absolute;bottom:-26px;display:block;border-radius:50%;background:radial-gradient(circle at 32% 28%,rgba(255,255,255,.5),rgba(180,220,214,.14) 60%,rgba(255,255,255,0) 72%);box-shadow:inset 0 0 6px rgba(255,255,255,.25);animation:bub linear infinite}
@keyframes bub{0%{transform:translateY(0) translateX(0);opacity:0}
  12%{opacity:.85}
  80%{opacity:.7}
  100%{transform:translateY(-185px) translateX(var(--dx,0));opacity:0}}
@media(prefers-reduced-motion:reduce){.divider .bubbles span{animation:none;opacity:.35;transform:translateY(-70px)}}

/* ============ QUOTE FORM PAGE ============ */
.qform-sec{background:var(--bone-2);padding:var(--sec) 0}
.qform-wrap{max-width:760px}
.qform{background:#fff;border:1px solid var(--line-2);border-radius:8px;padding:44px 46px;box-shadow:0 30px 70px rgba(19,32,28,.12)}
@media(max-width:560px){.qform{padding:30px 22px}}
.qform .qrow{display:grid;grid-template-columns:1fr 1fr;gap:22px}
@media(max-width:560px){.qform .qrow{grid-template-columns:1fr;gap:0}}
.qfield{margin-bottom:20px}
.qfield label{display:block;font-size:10.5px;letter-spacing:.15em;text-transform:uppercase;color:var(--brass-d);font-weight:700;margin-bottom:8px}
.qfield label .opt{color:var(--muted);font-weight:500;text-transform:none;letter-spacing:0}
.qform input,.qform select,.qform textarea{width:100%;font-family:var(--sans);font-size:15.5px;color:var(--ink);background:#fff;border:1.5px solid var(--line);border-radius:6px;padding:13px 14px;transition:.18s}
.qform textarea{resize:vertical;min-height:96px;line-height:1.5}
.qform select{appearance:none;cursor:pointer;padding-right:42px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23C08A3E' stroke-width='3'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 15px center}
.qform input:focus,.qform select:focus,.qform textarea:focus{outline:none;border-color:var(--brass);box-shadow:0 0 0 3px rgba(192,138,62,.15)}
.qform .qsuffix{position:relative;display:flex;align-items:center}
.qform .qsuffix span{position:absolute;right:14px;font-size:13px;font-weight:700;color:var(--muted);pointer-events:none}
.qform .qsuffix input{padding-right:40px}
.qdivide{display:flex;align-items:center;gap:16px;margin:6px 0 22px;color:var(--brass-d);font-size:11px;letter-spacing:.16em;text-transform:uppercase;font-weight:700}
.qdivide::before,.qdivide::after{content:"";flex:1;height:1px;background:var(--line-2)}
.qsubmit{width:100%;justify-content:center;margin-top:8px;border:0;cursor:pointer;font-size:15px}
.qnote{font-size:13px;color:var(--muted);text-align:center;margin-top:16px;line-height:1.55}
.qnote a{color:var(--brass-d);font-weight:700}

/* ============ THANK-YOU PAGE ============ */
.thanks{position:relative;min-height:84vh;display:flex;align-items:center;color:#fff;overflow:hidden}
.thanks-media{position:absolute;inset:0;z-index:0}
.thanks-media svg{width:100%;height:100%}
.thanks-media::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 90% at 50% 40%,transparent 30%,rgba(10,23,20,.55))}
.thanks-in{position:relative;z-index:2;text-align:center;max-width:660px;margin:0 auto;padding:120px 0}
.thanks .checkmark{margin:0 auto 22px;width:62px;height:62px}
.thanks h1{font-family:var(--serif);font-weight:500;font-size:clamp(40px,6vw,64px);line-height:1.03;letter-spacing:-.02em;margin:6px 0 18px}
.thanks h1 em{font-style:italic;color:var(--brass-l)}
.thanks .lead{font-size:18.5px;color:#dfe9e4;line-height:1.65;max-width:54ch;margin:0 auto}
.thanks .lead2{font-size:15px;color:var(--muted-d);margin:18px auto 0;max-width:50ch}
.thanks .lead2 a,.thanks .lead a{color:var(--brass-l);font-weight:600}
.thanks .hero-cta{justify-content:center;margin-top:34px}
.btn-line-l{border:1.5px solid rgba(255,255,255,.5);color:#fff}
.btn-line-l:hover{border-color:var(--brass-l);color:var(--brass-l)}

/* footer attribution line */
.legal-attr{flex-basis:100%;text-align:center;font-size:11.5px;color:var(--muted-d);opacity:.85;margin-top:4px;letter-spacing:.01em}
.legal-attr a{color:var(--brass-l);font-weight:600;transition:.2s}
.legal-attr a:hover{color:var(--brass)}


/* ============ ABOUT / FAQ page additions ============ */
/* dark outline button for light-background sections */
.btn-line-d{border:1.5px solid var(--line);color:var(--ink);background:transparent}
.btn-line-d:hover{border-color:var(--brass);color:var(--brass-d)}

/* FAQ PAGE */
.faqpage{background:var(--bone);padding:var(--sec) 0}
.faqjump{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:54px;padding-bottom:30px;border-bottom:1px solid var(--line-2)}
.faqjump a{font-size:12.5px;font-weight:700;letter-spacing:.02em;color:var(--brass-d);background:var(--bone-2);border:1px solid var(--line);padding:9px 15px;border-radius:40px;transition:.18s;text-decoration:none}
.faqjump a:hover{background:var(--sea);color:#fff;border-color:var(--sea)}
.faqcat{margin-bottom:54px;scroll-margin-top:90px}
.faqcat:last-child{margin-bottom:0}
.faqcat-h{font-family:var(--serif);font-weight:500;font-size:clamp(24px,3vw,32px);color:var(--ink);letter-spacing:-.01em;padding-bottom:8px;margin-bottom:8px;border-bottom:2px solid var(--brass);display:inline-block}
.faqpage .q summary{color:var(--ink)}
.faqpage .q .a a,.faqpage .q .a{}
