:root {
  --ink: #04282f;
  --deep: #063f4a;
  --teal: #0c8595;
  --aqua: #16b0c4;
  --spray: #5fd4e6;
  --sun: #ffcb45;
  --paper: #f1fbfc;
  --white: #fff;
  --text: #0c2127;
  --muted: #557079;
  --line: rgba(12,33,39,.13);
  --shadow: 0 24px 80px rgba(4,40,47,.18);
  --radius: 10px;
  --spray-drift: 0px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; background: var(--paper); color: var(--text); font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; line-height: 1.55; overflow-x: hidden; }
body.menu-open { overflow: hidden; }
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; height: auto; }
h1, h2, h3, p, a, span, strong, article, section, div { min-width: 0; }
h1, h2, h3, p { overflow-wrap: break-word; }
.site-header { position: sticky; top: 0; z-index: 50; min-height: 74px; display: flex; align-items: center; justify-content: space-between; gap: 20px; padding: 10px clamp(16px, 4vw, 56px); background: rgba(4, 40, 47, .94); border-bottom: 1px solid rgba(95,212,230,.28); backdrop-filter: blur(18px); }
.brand { display: inline-flex; align-items: center; gap: 11px; }
.brand-drop { display: inline-flex; align-items: center; justify-content: center; width: 38px; height: 38px; border-radius: 11px; background: linear-gradient(150deg, var(--spray), var(--teal)); box-shadow: 0 12px 26px rgba(4,40,47,.32); }
.brand-drop svg { width: 21px; height: 21px; fill: #06303a; }
.brand-text { display: grid; line-height: 1; }
.brand-text strong { color: #fff; font-size: 1.22rem; font-weight: 950; letter-spacing: .12em; }
.brand-text em { color: var(--spray); font-style: normal; font-size: .6rem; font-weight: 850; text-transform: uppercase; letter-spacing: .22em; }
.nav-links { display: flex; gap: 24px; color: rgba(255,255,255,.78); font-size: 14px; font-weight: 850; text-transform: uppercase; letter-spacing: .04em; }
.nav-links a:hover { color: var(--spray); }
.nav-actions { display: flex; align-items: center; gap: 10px; }
.phone-link { color: #dffaff; font-weight: 950; white-space: nowrap; }
.btn { display: inline-flex; min-height: 50px; align-items: center; justify-content: center; border: 1px solid transparent; border-radius: var(--radius); padding: 0 20px; font-size: 14px; font-weight: 950; text-transform: uppercase; letter-spacing: .035em; cursor: pointer; transition: transform .18s ease, box-shadow .18s ease, background .18s ease; }
.btn:hover { transform: translateY(-2px); box-shadow: 0 18px 38px rgba(4,40,47,.2); }
.btn.primary, .btn.small { background: var(--sun); color: #2a1c00; border-color: var(--sun); }
.btn.secondary { background: rgba(255,255,255,.1); color: #fff; border-color: rgba(255,255,255,.32); }
.btn.light { background: #fff; color: #062b33; border-color: #fff; }
.btn.ghost { color: #fff; border-color: rgba(255,255,255,.44); background: transparent; }
.btn.small { min-height: 42px; padding: 0 15px; }
.menu-toggle { display: none; width: 46px; height: 46px; border: 1px solid rgba(255,255,255,.22); border-radius: var(--radius); background: transparent; position: relative; }
.menu-toggle span, .menu-toggle:before, .menu-toggle:after { content: ""; position: absolute; left: 12px; right: 12px; height: 2px; border-radius: 999px; background: #fff; }
.menu-toggle span { top: 22px; }
.menu-toggle:before { top: 15px; }
.menu-toggle:after { top: 29px; }
.mobile-menu { display: none; }
.hero { position: relative; isolation: isolate; min-height: calc(100svh - 74px); display: grid; grid-template-columns: minmax(0, .95fr) minmax(360px, 1.05fr); align-items: center; gap: clamp(30px, 5vw, 70px); padding: clamp(42px, 7vw, 90px) clamp(16px, 5vw, 76px); background: radial-gradient(circle at 76% 16%, rgba(95,212,230,.26), transparent 34%), linear-gradient(135deg, #04282f, #063f4a 52%, #0c8595); color: #fff; overflow: hidden; }
.hero > *:not(.spray-motion) { position: relative; z-index: 1; }
.spray-motion { position: absolute; inset: 0; z-index: 0; pointer-events: none; overflow: hidden; }
.spray-glow { position: absolute; right: -10%; top: -20%; width: 70%; height: 80%; background: radial-gradient(circle at 50% 50%, rgba(95,212,230,.3), transparent 62%); transform: translate3d(calc(var(--spray-drift) * -1), 0, 0); }
.drop-field { position: absolute; inset: 0; }
.drop-field i { position: absolute; left: var(--x); top: -8%; width: 3px; height: 16px; border-radius: 999px; background: linear-gradient(180deg, rgba(223,250,255,.05), rgba(95,212,230,.85)); opacity: var(--o); transform: scaleY(var(--s)); animation: dropFall 4.6s linear infinite; animation-delay: var(--d); }
@keyframes dropFall { 0% { transform: translateY(0) scaleY(var(--s)); opacity: 0; } 12% { opacity: var(--o); } 100% { transform: translateY(118vh) scaleY(var(--s)); opacity: 0; } }
.hero h1, .subhero h1, .detail-hero h1, .contact-hero h1 { margin: 0; font-size: clamp(3rem, 7vw, 6.6rem); line-height: .94; letter-spacing: -.01em; max-width: 11ch; text-wrap: balance; }
.hero p, .subhero p, .detail-hero p, .contact-hero p { color: rgba(255,255,255,.82); font-size: clamp(1.05rem, 2vw, 1.32rem); max-width: 720px; }
.eyebrow { display: inline-flex; margin-bottom: 16px; color: var(--teal); font-size: .76rem; text-transform: uppercase; letter-spacing: .12em; font-weight: 950; }
.hero .eyebrow, .dark .eyebrow, .cta-band .eyebrow, .subhero .eyebrow, .detail-hero .eyebrow, .contact-hero .eyebrow, .review-lead .eyebrow, .wash-copy .eyebrow { color: #b6f3ff; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 28px; }
.hero-steps { display: inline-grid; grid-template-columns: repeat(4, auto); gap: 8px; margin-top: 24px; padding: 8px; border: 1px solid rgba(255,255,255,.18); border-radius: 999px; background: rgba(255,255,255,.08); backdrop-filter: blur(12px); }
.hero-steps span { position: relative; display: inline-flex; min-height: 34px; align-items: center; padding: 0 14px; border-radius: 999px; background: rgba(255,255,255,.1); color: rgba(255,255,255,.86); font-size: .82rem; font-weight: 950; text-transform: uppercase; letter-spacing: .05em; }
.hero-steps span:first-child { background: var(--spray); color: #06303a; }
.hero-steps span:not(:last-child):after { content: ""; position: absolute; right: -8px; top: 50%; width: 8px; height: 2px; background: rgba(255,255,255,.3); }
.hero-visual { position: relative; min-height: 540px; border-radius: var(--radius); }
.shine-card { position: absolute; inset: 0; border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow); border: 1px solid rgba(255,255,255,.2); }
.shine-clean { position: absolute; inset: 0; background: linear-gradient(135deg, #7fe2ef, #1fb6c9 60%, #0c8595); }
.shine-clean:before { content: ""; position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,.18) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.18) 1px, transparent 1px); background-size: 64px 64px; mix-blend-mode: overlay; }
.shine-grime { position: absolute; inset: 0; background: linear-gradient(135deg, #4b5b50, #2f3a33 55%, #1d2723); clip-path: inset(0 0 0 0); animation: grimeWipe 6.5s cubic-bezier(.6,0,.3,1) infinite; }
.shine-grime:before { content: ""; position: absolute; inset: 0; opacity: .5; background-image: radial-gradient(circle at 20% 30%, rgba(0,0,0,.5) 0 8px, transparent 9px), radial-gradient(circle at 64% 58%, rgba(0,0,0,.45) 0 12px, transparent 13px), radial-gradient(circle at 82% 24%, rgba(0,0,0,.4) 0 7px, transparent 8px), radial-gradient(circle at 40% 78%, rgba(0,0,0,.45) 0 10px, transparent 11px); }
.shine-edge { position: absolute; top: 0; bottom: 0; left: 0; width: 10px; background: linear-gradient(90deg, rgba(255,255,255,0), rgba(255,255,255,.95)); filter: blur(.4px); animation: edgeSweep 6.5s cubic-bezier(.6,0,.3,1) infinite; }
.shine-jet { position: absolute; top: 50%; left: -10%; width: 36%; height: 4px; background: linear-gradient(90deg, transparent, rgba(255,255,255,.9)); border-radius: 999px; transform-origin: left center; opacity: 0; animation: jetSweep 6.5s cubic-bezier(.6,0,.3,1) infinite; }
.shine-sparks i { position: absolute; left: var(--sx); top: var(--sy); width: 10px; height: 10px; opacity: 0; background: radial-gradient(circle, #fff 0 2px, transparent 3px); animation: sparkPop 6.5s ease-in-out infinite; animation-delay: var(--sd); }
.shine-sparks i:before { content: ""; position: absolute; inset: 0; background: conic-gradient(from 0deg, transparent, rgba(255,255,255,.9), transparent 25%, transparent 50%, rgba(255,255,255,.9), transparent 75%); border-radius: 50%; }
.shine-tag { position: absolute; z-index: 3; padding: 6px 12px; border-radius: 999px; font-size: .72rem; font-weight: 950; text-transform: uppercase; letter-spacing: .08em; }
.tag-before { left: 16px; top: 16px; background: rgba(8,18,16,.62); color: #d6e0db; }
.tag-after { right: 16px; bottom: 16px; background: rgba(255,255,255,.92); color: #06303a; }
@keyframes grimeWipe { 0%, 8% { clip-path: inset(0 0 0 0); } 60%, 88% { clip-path: inset(0 0 0 100%); } 100% { clip-path: inset(0 0 0 0); } }
@keyframes edgeSweep { 0%, 8% { left: 0; opacity: 0; } 10% { opacity: 1; } 60% { left: calc(100% - 10px); opacity: 1; } 70%, 100% { left: calc(100% - 10px); opacity: 0; } }
@keyframes jetSweep { 0%, 8% { opacity: 0; transform: scaleX(.2); } 12% { opacity: .9; } 55% { opacity: .9; transform: scaleX(2.4); } 66%, 100% { opacity: 0; transform: scaleX(2.6); } }
@keyframes sparkPop { 0%, 55% { opacity: 0; transform: scale(.2); } 66% { opacity: 1; transform: scale(1.1); } 82% { opacity: .9; transform: scale(.9); } 92%, 100% { opacity: 0; transform: scale(.4); } }
.float-card { position: absolute; z-index: 4; display: inline-flex; align-items: center; min-height: 44px; padding: 0 16px; border-radius: 999px; background: var(--sun); color: #2a1c00; font-weight: 950; box-shadow: 0 14px 34px rgba(4,40,47,.28); animation: floatLift 4.8s ease-in-out infinite; }
.float-one { right: -14px; top: 26%; }
.float-two { left: -18px; bottom: 26%; animation-delay: -1.8s; background: #fff; color: var(--deep); }
@keyframes floatLift { 0%, 100% { translate: 0 0; } 50% { translate: 0 -10px; } }
.hero-badge { position: absolute; left: 18px; right: 18px; bottom: 18px; z-index: 3; padding: 20px; border-radius: var(--radius); background: rgba(255,255,255,.94); color: var(--text); backdrop-filter: blur(14px); box-shadow: 0 18px 42px rgba(4,40,47,.22); }
.hero-badge strong { display: block; font-size: clamp(1.3rem, 2.6vw, 1.85rem); line-height: 1.05; color: var(--deep); }
.hero-badge span { display: block; color: var(--muted); margin-top: 8px; font-size: .98rem; }
.ba-slider { position: relative; aspect-ratio: 3 / 2; border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow); border: 1px solid rgba(255,255,255,.18); touch-action: pan-y; user-select: none; -webkit-user-select: none; }
.ba-base, .ba-clip img { display: block; width: 100%; height: 100%; object-fit: cover; }
.ba-clip { position: absolute; inset: 0; clip-path: inset(0 calc(100% - var(--pos)) 0 0); }
.ba-divider { position: absolute; top: 0; bottom: 0; left: var(--pos); width: 3px; background: #fff; transform: translateX(-1.5px); box-shadow: 0 0 0 1px rgba(4,40,47,.22); pointer-events: none; }
.ba-divider:before { content: ""; position: absolute; top: 50%; left: 50%; width: 44px; height: 44px; transform: translate(-50%, -50%); border-radius: 50%; background: #fff; box-shadow: 0 8px 20px rgba(4,40,47,.38); }
.ba-divider:after { content: ""; position: absolute; top: 50%; left: 50%; width: 20px; height: 8px; transform: translate(-50%, -50%); border-radius: 999px; background: var(--teal); box-shadow: -13px 0 0 -3px var(--teal), 13px 0 0 -3px var(--teal); }
.ba-range { position: absolute; inset: 0; width: 100%; height: 100%; margin: 0; padding: 0; opacity: 0; cursor: ew-resize; -webkit-appearance: none; appearance: none; background: transparent; }
.ba-range::-webkit-slider-thumb { -webkit-appearance: none; appearance: none; width: 46px; height: 100%; }
.ba-range::-moz-range-thumb { width: 46px; height: 100%; border: 0; background: transparent; }
.ba-range:focus-visible { outline: 3px solid var(--spray); outline-offset: 2px; }
.ba-tag { position: absolute; z-index: 2; padding: 6px 12px; border-radius: 999px; font-size: .7rem; font-weight: 950; text-transform: uppercase; letter-spacing: .08em; pointer-events: none; }
.ba-before-tag { left: 14px; bottom: 14px; background: rgba(8,18,16,.66); color: #e7ece9; }
.ba-after-tag { right: 14px; top: 14px; background: rgba(255,255,255,.92); color: #06303a; }
.ba-hero { padding: 0; border: 0; background: transparent; }
.ba-hero .ba-slider { position: absolute; inset: 0; aspect-ratio: auto; height: 100%; border-radius: var(--radius); }
.ba-section .ba-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
.ba-card { border: 1px solid var(--line); border-radius: var(--radius); background: #fff; overflow: hidden; }
.ba-label { display: block; padding: 16px 18px 0; color: var(--teal); font-size: .74rem; text-transform: uppercase; letter-spacing: .1em; font-weight: 950; }
.ba-card .ba-slider { margin: 12px 18px 18px; box-shadow: none; border-color: var(--line); }
.wash-reveal { --wash-progress: 0; padding: clamp(18px, 3vw, 34px) clamp(16px, 5vw, 76px); background: linear-gradient(180deg, #d4f2f7, #f1fbfc); overflow: hidden; }
.wash-panel { max-width: 1180px; margin: 0 auto; display: grid; grid-template-columns: minmax(240px, .72fr) minmax(340px, 1.28fr); gap: clamp(18px, 4vw, 48px); align-items: center; padding: clamp(18px, 3vw, 34px); border: 1px solid rgba(12,33,39,.12); border-radius: var(--radius); background: rgba(255,255,255,.76); box-shadow: 0 22px 70px rgba(4,40,47,.1); }
.wash-copy h2 { margin: 0; font-size: clamp(1.6rem, 3.4vw, 3.4rem); line-height: 1.02; text-wrap: balance; color: var(--deep); }
.wash-stage { position: relative; }
.wash-surface { position: relative; height: clamp(180px, 26vw, 250px); border-radius: var(--radius); overflow: hidden; box-shadow: inset 0 0 0 1px rgba(12,33,39,.1); }
.wash-clean { position: absolute; inset: 0; background: linear-gradient(135deg, #8be6f1, #1fb6c9 58%, #0c8595); }
.wash-clean:before { content: ""; position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,.16) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.16) 1px, transparent 1px); background-size: 52px 52px; }
.wash-grime { position: absolute; inset: 0; background: linear-gradient(135deg, #50605520, #2f3a33); background-blend-mode: multiply; clip-path: inset(0 0 0 calc(var(--wash-progress) * 100%)); }
.wash-grime:before { content: ""; position: absolute; inset: 0; background: linear-gradient(135deg, #4b5b50, #283129); opacity: .94; background-image: radial-gradient(circle at 24% 36%, rgba(0,0,0,.5) 0 9px, transparent 10px), radial-gradient(circle at 58% 64%, rgba(0,0,0,.45) 0 13px, transparent 14px), radial-gradient(circle at 84% 28%, rgba(0,0,0,.4) 0 8px, transparent 9px); }
.wash-edge { position: absolute; top: 0; bottom: 0; left: calc(var(--wash-progress) * 100%); width: 8px; transform: translateX(-4px); background: linear-gradient(90deg, rgba(255,255,255,.92), rgba(255,255,255,0)); opacity: calc(.2 + var(--wash-progress) * .8); }
.wash-sparks i { position: absolute; left: var(--wx); top: var(--wy); width: 9px; height: 9px; background: radial-gradient(circle, #fff 0 2px, transparent 3px); border-radius: 50%; opacity: 0; transform: scale(.3); transition: opacity .2s ease, transform .2s ease; }
.wash-reveal[style*="--wash-progress"] .wash-sparks i { opacity: clamp(0, calc((var(--wash-progress) - var(--wt)) * 6), 1); transform: scale(calc(.4 + clamp(0, calc((var(--wash-progress) - var(--wt)) * 6), 1) * .7)); }
.wash-wand { position: absolute; top: -14px; left: calc(var(--wash-progress) * 100%); width: 0; height: 0; z-index: 3; }
.wand-arm { position: absolute; left: -2px; top: -22px; width: 4px; height: 30px; border-radius: 999px; background: linear-gradient(180deg, #d7eef2, #0c8595); transform: rotate(20deg); transform-origin: bottom center; box-shadow: 0 6px 14px rgba(4,40,47,.25); }
.wand-fan { position: absolute; left: 0; top: 6px; width: 26px; height: 60px; background: linear-gradient(180deg, rgba(255,255,255,.85), rgba(95,212,230,.05)); clip-path: polygon(0 0, 100% 12%, 100% 88%, 0 100%); opacity: calc(.25 + var(--wash-progress) * .75); }
.wash-bar { position: relative; margin-top: 16px; height: 8px; border-radius: 999px; background: rgba(12,33,39,.12); overflow: hidden; }
.wash-bar span { display: block; width: var(--wash-fill, 0%); height: 100%; border-radius: inherit; background: linear-gradient(90deg, var(--spray), var(--sun)); transition: width .08s linear; }
/* photo squeegee reveal */
.wash-reveal.has-photo .wash-stage { position: relative; }
.wash-reveal.has-photo .wash-surface { height: auto; aspect-ratio: 4 / 5; max-height: 76vh; overflow: visible; box-shadow: none; border-radius: 0; }
.wash-clip { position: absolute; inset: 0; overflow: hidden; border-radius: var(--radius); box-shadow: var(--shadow); }
.wash-after, .wash-before img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; }
.wash-before { position: absolute; inset: 0; clip-path: inset(0 0 0 calc(var(--wash-progress, 0) * 100%)); }
.wash-before:after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(8,20,16,.12), rgba(8,20,16,.28)); }
.wash-sheen { position: absolute; top: 0; bottom: 0; left: 0; width: calc(var(--wash-progress, 0) * 100%); background: linear-gradient(90deg, transparent, rgba(255,255,255,.16) 84%, rgba(255,255,255,.34)); pointer-events: none; z-index: 2; }
/* pressure-washer spray reveal */
.washer { position: absolute; top: 0; bottom: 0; left: calc(var(--wash-progress, 0) * 100%); width: 0; z-index: 6; pointer-events: none; opacity: clamp(0, calc(var(--wash-progress, 0) * 7), 1); }
.pw-spray { position: absolute; top: 12%; bottom: 0; left: 0; width: clamp(36px, 5.4vw, 56px); transform: translateX(-38%); background: linear-gradient(90deg, rgba(255,255,255,0), rgba(255,255,255,.42) 42%, rgba(255,255,255,.05)); clip-path: polygon(40% 0, 60% 0, 100% 100%, 0 100%); }
.pw-spray:before { content: ""; position: absolute; inset: 0; background: repeating-linear-gradient(168deg, rgba(255,255,255,.62) 0 2px, transparent 2px 9px); animation: pwFlow .5s linear infinite; }
@keyframes pwFlow { to { background-position: 0 18px; } }
.pw-bubbles { position: absolute; inset: 0; }
.pw-bubble { position: absolute; left: 0; top: var(--by); width: var(--bs); height: var(--bs); border-radius: 50%; background: radial-gradient(circle at 34% 28%, rgba(255,255,255,.96) 0 13%, rgba(255,255,255,.14) 42%, rgba(206,238,245,.12) 70%, transparent 74%); border: 1.5px solid rgba(255,255,255,.74); box-shadow: 0 2px 7px rgba(8,52,60,.34); opacity: 0; animation: pwBubble var(--bdur) ease-out var(--bd) infinite; }
@keyframes pwBubble { 0% { transform: translate(0, 0) scale(.2); opacity: 0; } 14% { opacity: 1; } 80% { opacity: .82; } 100% { transform: translate(var(--bx), var(--drift)) scale(1.05); opacity: 0; } }
.pw-gun { position: absolute; top: 1%; left: 0; width: clamp(50px, 6.6vw, 74px); transform: translateX(-48%) rotate(-9deg); transform-origin: 50% 88%; filter: drop-shadow(0 10px 18px rgba(4,40,47,.45)); }
.pw-gun-svg { display: block; width: 100%; height: auto; }
.wash-tag { position: absolute; z-index: 5; padding: 6px 12px; border-radius: 999px; font-size: .7rem; font-weight: 950; text-transform: uppercase; letter-spacing: .08em; }
.wash-tag-dirty { right: 14px; top: 14px; background: rgba(8,18,16,.66); color: #e7ece9; }
.wash-tag-clean { left: 14px; bottom: 14px; background: rgba(255,255,255,.92); color: #06303a; }
.wash-reveal.has-photo .wash-copy p { color: var(--muted); margin: 6px 0 18px; }
.wash-reveal.has-photo .wash-bar { max-width: 320px; }
.proof-strip { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 1px; padding: 0 clamp(16px, 5vw, 76px); background: var(--line); border-bottom: 1px solid var(--line); }
.proof-strip div { min-height: 116px; display: grid; align-content: center; gap: 5px; padding: 20px; background: rgba(255,255,255,.94); }
.proof-strip strong { color: var(--deep); font-size: 1.03rem; line-height: 1.05; }
.proof-strip span { color: var(--muted); font-size: .95rem; line-height: 1.35; }
.service-ribbon { display: flex; flex-wrap: wrap; gap: 10px; padding: 18px clamp(16px, 5vw, 76px); background: #e2f6fa; border-bottom: 1px solid var(--line); }
.service-ribbon span, .pill { display: inline-flex; padding: 10px 13px; border: 1px solid var(--line); border-radius: 999px; background: #fff; color: var(--deep); font-weight: 900; }
.section { padding: clamp(64px, 9vw, 120px) clamp(16px, 5vw, 76px); }
.section.soft { background: #e4f5f9; }
.section.dark { background: var(--ink); color: #fff; }
.section-head { max-width: 950px; margin-bottom: 34px; }
.section h2, .dark h2, .cta-band h2, .estimate-card h2 { margin: 0 0 14px; font-size: clamp(2.1rem, 4.6vw, 4.6rem); line-height: 1.02; letter-spacing: -.01em; text-wrap: balance; }
.section-head p, .two-col p, .service-card p, .area-card p, .process-grid p, .faq-list p, .stacked-list p, .portrait-card span { color: var(--muted); font-size: 1.03rem; }
.dark p, .dark .stacked-list p { color: rgba(255,255,255,.74); }
.review-spotlight { display: grid; grid-template-columns: minmax(280px, .92fr) minmax(0, 1.08fr); gap: 16px; align-items: stretch; background: #fff; }
.review-lead { display: grid; align-content: center; padding: clamp(26px, 5vw, 54px); border-radius: var(--radius); background: linear-gradient(135deg, #04282f, #0c8595); color: #fff; box-shadow: var(--shadow); }
.review-lead blockquote { margin: 0; font-size: clamp(1.7rem, 3vw, 3rem); line-height: 1.08; font-weight: 950; text-wrap: balance; }
.review-lead cite { margin-top: 18px; color: #b6f3ff; font-style: normal; font-weight: 950; }
.review-minis { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.mini-review { display: grid; align-content: space-between; gap: 18px; margin: 0; padding: 24px; border: 1px solid var(--line); border-radius: var(--radius); background: var(--paper); }
.mini-review blockquote { margin: 0; color: var(--text); font-weight: 850; line-height: 1.45; }
.mini-review figcaption { color: var(--teal); font-weight: 950; }
.card-grid { display: grid; gap: 16px; }
.card-grid.three { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.featured-services { display: grid; grid-template-columns: minmax(320px, .95fr) minmax(0, 1.05fr); gap: 16px; align-items: stretch; }
.service-mini-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
.service-card, .service-mini-card, .area-card, .process-grid article, .estimate-card, .portrait-card, .review-grid figure { border: 1px solid var(--line); border-radius: var(--radius); background: #fff; overflow: hidden; transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease; }
.service-card:hover, .service-mini-card:hover, .area-card:hover { transform: translateY(-4px); box-shadow: var(--shadow); border-color: rgba(95,212,230,.65); }
.service-visual { position: relative; height: 168px; display: grid; place-items: center; background: linear-gradient(140deg, #0c8595, #16b0c4 55%, #5fd4e6); overflow: hidden; }
.service-visual:before { content: ""; position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,.14) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.14) 1px, transparent 1px); background-size: 38px 38px; }
.service-visual:after { content: ""; position: absolute; top: -40%; left: -20%; width: 60%; height: 180%; background: linear-gradient(90deg, transparent, rgba(255,255,255,.34), transparent); transform: skewX(-18deg); }
.svc-icon { position: relative; width: 64px; height: 64px; fill: none; stroke: #fff; stroke-width: 2.4; stroke-linecap: round; stroke-linejoin: round; filter: drop-shadow(0 6px 14px rgba(4,40,47,.3)); }
.feature-service { display: grid; grid-template-rows: minmax(300px, 1fr) auto; }
.feature-visual { height: 100%; min-height: 300px; }
.feature-visual .svc-icon { width: 108px; height: 108px; }
.feature-copy { padding: 26px; display: grid; gap: 8px; }
.feature-copy span { color: var(--teal); font-size: .72rem; text-transform: uppercase; letter-spacing: .1em; font-weight: 950; }
.feature-copy h3 { margin: 4px 0 0; font-size: clamp(1.6rem, 2.6vw, 2.3rem); line-height: 1.02; }
.feature-copy p { margin: 0; color: var(--muted); }
.feature-copy strong { display: inline-flex; margin-top: 4px; color: var(--teal); font-weight: 950; }
.service-mini-card { display: grid; align-content: start; gap: 6px; min-height: 220px; padding: 24px; }
.mini-icon { display: inline-flex; width: 42px; height: 42px; border-radius: 11px; background: linear-gradient(140deg, #0c8595, #16b0c4); align-items: center; justify-content: center; margin-bottom: 8px; }
.mini-icon .svc-icon { width: 26px; height: 26px; stroke-width: 2.6; filter: none; }
.mini-eyebrow { color: var(--teal); font-size: .72rem; text-transform: uppercase; letter-spacing: .1em; font-weight: 950; }
.service-mini-card h3 { margin: 4px 0 4px; font-size: clamp(1.25rem, 2vw, 1.7rem); line-height: 1.05; }
.service-mini-card p { margin: 0; color: var(--muted); }
.service-card span { display: block; padding: 18px 20px 0; color: var(--teal); font-size: .76rem; text-transform: uppercase; letter-spacing: .1em; font-weight: 950; }
.service-card h3 { margin: 8px 20px 0; font-size: clamp(1.35rem, 2.2vw, 1.9rem); line-height: 1.05; }
.service-card p { margin: 10px 20px 22px; }
.area-card span { display: block; padding: 20px 20px 0; color: var(--teal); font-size: .76rem; text-transform: uppercase; letter-spacing: .1em; font-weight: 950; }
.area-card h3 { margin: 8px 20px 0; font-size: clamp(1.35rem, 2.2vw, 1.9rem); line-height: 1.05; }
.area-card p { margin: 10px 20px 22px; color: var(--muted); font-size: 1.03rem; }
.split, .two-col { display: grid; grid-template-columns: minmax(0, .86fr) minmax(0, 1.14fr); gap: clamp(28px, 6vw, 76px); align-items: start; }
.stacked-list { display: grid; gap: 12px; }
.stacked-list article { border: 1px solid var(--line); border-radius: var(--radius); background: rgba(255,255,255,.06); padding: 22px; }
.dark .stacked-list article { background: rgba(255,255,255,.05); border-color: rgba(255,255,255,.12); }
.stacked-list strong { font-size: 1.25rem; }
.portrait-card { padding: 0; }
.owner-panel { display: flex; align-items: center; gap: 18px; padding: 30px; background: linear-gradient(140deg, #04282f, #0c8595); }
.owner-mono { display: inline-flex; align-items: center; justify-content: center; width: 78px; height: 78px; border-radius: 20px; background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.25); color: #fff; font-size: 1.9rem; font-weight: 950; letter-spacing: .04em; }
.owner-mono.big { width: 120px; height: 120px; font-size: 3rem; border-radius: 28px; }
.owner-meta { display: grid; gap: 2px; }
.owner-meta strong { color: #fff; font-size: 1.3rem; }
.owner-meta span { color: #b6f3ff; font-weight: 850; }
.portrait-card > div:last-child { padding: 22px; display: grid; gap: 6px; }
.portrait-card strong { font-size: 1.45rem; line-height: 1.05; }
.process-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 14px; }
.process-grid article { padding: 22px; }
.process-grid span { color: var(--teal); font-weight: 950; font-size: 1.1rem; }
.process-grid h3 { margin: 16px 0 8px; font-size: 1.35rem; }
.check-list { list-style: none; display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; padding: 0; margin: 0; }
.check-list li, .mini-list li { position: relative; padding: 15px 15px 15px 44px; border: 1px solid var(--line); border-radius: var(--radius); background: #fff; color: var(--text); font-weight: 800; }
.check-list li:before, .mini-list li:before { content: ""; position: absolute; left: 16px; top: 20px; width: 13px; height: 13px; border-radius: 50%; background: var(--aqua); box-shadow: inset 0 0 0 4px #d2f1f6; }
.mini-list { list-style: none; display: grid; gap: 10px; padding: 0; margin: 18px 0 24px; }
.area-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 16px; }
.area-card { min-height: 230px; }
.review-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; }
.review-grid figure { margin: 0; padding: 26px; }
.review-grid blockquote { margin: 0; color: var(--text); font-weight: 800; line-height: 1.5; font-size: 1.05rem; }
.review-grid figcaption { margin-top: 16px; color: var(--teal); font-weight: 950; }
.faq-list { display: grid; gap: 10px; max-width: 980px; }
.faq-list details { border: 1px solid var(--line); border-radius: var(--radius); background: #fff; padding: 18px 20px; }
.faq-list summary { cursor: pointer; font-size: 1.08rem; font-weight: 950; }
.faq-list p { margin: 12px 0 0; }
.cta-band { margin: 0 clamp(16px, 5vw, 76px) clamp(64px, 9vw, 96px); padding: clamp(28px, 5vw, 56px); border-radius: var(--radius); background: linear-gradient(135deg, #063f4a, #0c8595 58%, #16b0c4); color: #fff; display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 24px; align-items: center; }
.cta-band p { color: rgba(255,255,255,.84); max-width: 720px; }
.cta-actions { display: flex; gap: 12px; flex-wrap: wrap; justify-content: flex-end; }
.subhero { padding: clamp(82px, 12vw, 150px) clamp(16px, 5vw, 76px) 58px; background: var(--ink); color: #fff; }
.subhero h1 { max-width: 14ch; }
.detail-hero, .contact-hero { display: grid; grid-template-columns: minmax(0, .95fr) minmax(320px, .85fr); gap: clamp(28px, 5vw, 62px); align-items: center; padding: clamp(70px, 10vw, 130px) clamp(16px, 5vw, 76px); background: var(--ink); color: #fff; }
.detail-hero h1, .contact-hero h1 { max-width: 13ch; }
.detail-visual { position: relative; }
.detail-shine { position: relative; height: min(60vh, 480px); border-radius: var(--radius); display: grid; place-items: center; gap: 10px; background: linear-gradient(140deg, #0c8595, #16b0c4 55%, #5fd4e6); box-shadow: var(--shadow); overflow: hidden; }
.detail-shine:before { content: ""; position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,.14) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.14) 1px, transparent 1px); background-size: 56px 56px; }
.detail-shine:after { content: ""; position: absolute; top: -30%; left: -25%; width: 55%; height: 160%; background: linear-gradient(90deg, transparent, rgba(255,255,255,.32), transparent); transform: skewX(-18deg); animation: detailSheen 5s ease-in-out infinite; }
@keyframes detailSheen { 0%, 100% { left: -25%; } 50% { left: 95%; } }
.detail-shine .svc-icon { position: relative; width: 120px; height: 120px; }
.area-shine { gap: 4px; }
.area-shine .map-pin { position: relative; width: 30px; height: 30px; border-radius: 50% 50% 50% 0; background: #fff; transform: rotate(-45deg); box-shadow: 0 8px 18px rgba(4,40,47,.3); }
.area-shine .map-pin:before { content: ""; position: absolute; inset: 9px; border-radius: 50%; background: var(--teal); }
.area-shine strong { position: relative; color: #fff; font-size: clamp(1.6rem, 3vw, 2.4rem); line-height: 1; }
.area-shine em { position: relative; color: #eafdff; font-style: normal; font-weight: 850; letter-spacing: .1em; }
.owner-shine strong { position: relative; color: #fff; font-size: 1.6rem; }
.owner-shine em { position: relative; color: #eafdff; font-style: normal; font-weight: 850; }
.detail-tag { position: absolute; left: 16px; bottom: 16px; z-index: 2; padding: 8px 14px; border-radius: 999px; background: rgba(255,255,255,.92); color: var(--deep); font-size: .74rem; font-weight: 950; text-transform: uppercase; letter-spacing: .06em; }
.contact-line { margin-top: 16px; }
.contact-line a { color: #b6f3ff; font-weight: 850; }
.estimate-card { padding: clamp(22px, 4vw, 36px); background: #fff; color: var(--text); box-shadow: var(--shadow); }
.estimate-card h2 { font-size: clamp(2rem, 4vw, 3.2rem); }
.footer { display: flex; justify-content: space-between; gap: 30px; padding: 36px clamp(16px, 5vw, 76px); background: var(--ink); color: #fff; }
.footer .brand { width: fit-content; }
.footer p { color: rgba(255,255,255,.7); max-width: 520px; margin: 16px 0 0; }
.footer-social { display: flex; gap: 16px; margin-top: 14px; }
.footer-social a { color: var(--spray); font-weight: 850; }
.footer-grid { display: grid; grid-template-columns: repeat(2, max-content); gap: 10px 24px; color: rgba(255,255,255,.8); }
.mobile-sticky { display: none; opacity: 0; transform: translateY(18px); pointer-events: none; }
.reveal { opacity: 1; transform: none; transition: transform .35s cubic-bezier(.22,1,.36,1); }
.reveal.in { opacity: 1; transform: none; }
@media (max-width: 1040px) {
  .nav-links, .nav-actions { display: none; }
  .menu-toggle { display: block; }
  .mobile-menu { position: fixed; inset: 76px 16px auto; z-index: 49; display: grid; gap: 6px; padding: 10px; border: 1px solid var(--line); border-radius: var(--radius); background: #fff; box-shadow: var(--shadow); transform: translateY(-12px); opacity: 0; visibility: hidden; pointer-events: none; transition: .18s ease; }
  body.menu-open .mobile-menu { transform: translateY(0); opacity: 1; visibility: visible; pointer-events: auto; }
  .mobile-menu a { padding: 14px; border-radius: var(--radius); color: var(--deep); font-weight: 950; }
  .hero, .detail-hero, .contact-hero, .split, .two-col, .cta-band, .review-spotlight, .featured-services, .wash-panel { grid-template-columns: 1fr; }
  .hero { min-height: auto; }
  .hero-visual { min-height: 460px; }
  .proof-strip { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .card-grid.three, .process-grid, .area-grid, .review-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .cta-actions { justify-content: flex-start; }
}
@media (max-width: 760px) {
  .site-header { min-height: 66px; padding: 10px 12px; }
  .brand-text strong { font-size: 1.05rem; }
  .brand-drop { width: 34px; height: 34px; }
  .hero { min-height: auto; padding: 34px 12px 34px; gap: 0; }
  .hero h1, .subhero h1, .detail-hero h1, .contact-hero h1 { font-size: clamp(2.25rem, 10vw, 3.2rem); max-width: 11ch; }
  .hero p, .subhero p, .detail-hero p, .contact-hero p { font-size: 1rem; line-height: 1.5; }
  .hero .eyebrow { margin-bottom: 12px; font-size: .68rem; letter-spacing: .14em; }
  .hero-actions, .cta-actions { display: grid; grid-template-columns: 1fr; }
  .hero-actions { margin-top: 18px; gap: 10px; }
  .btn { width: 100%; }
  .hero-steps { width: 100%; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 6px; margin-top: 16px; padding: 6px; }
  .hero-steps span { justify-content: center; min-height: 32px; padding: 0 6px; font-size: .68rem; }
  .hero-steps span:not(:last-child):after { display: none; }
  .hero-visual { min-height: 360px; margin-top: 22px; }
  .float-one { right: 4px; }
  .float-two { left: 4px; }
  .wash-reveal { padding: 0; }
  .wash-panel { border-left: 0; border-right: 0; border-radius: 0; padding: 18px 12px 20px; gap: 14px; }
  .wash-copy h2 { font-size: clamp(1.45rem, 6vw, 2.1rem); max-width: 16ch; }
  .wash-reveal:not(.has-photo) .wash-surface { height: 168px; }
  .wash-reveal.has-photo .wash-surface { aspect-ratio: 4 / 5; max-height: 68vh; }
  .wash-reveal.has-photo .wash-bar { max-width: none; }
  .service-ribbon { flex-wrap: nowrap; overflow-x: auto; padding: 12px; scrollbar-width: none; }
  .service-ribbon::-webkit-scrollbar { display: none; }
  .service-ribbon span { flex: 0 0 auto; padding: 8px 11px; font-size: .86rem; }
  .proof-strip { grid-template-columns: repeat(2, minmax(0, 1fr)); padding: 0; }
  .proof-strip div { min-height: auto; padding: 14px 12px; }
  .proof-strip strong { font-size: .92rem; }
  .proof-strip span { font-size: .85rem; }
  .review-spotlight { padding-top: 46px; padding-bottom: 46px; }
  .review-minis, .service-mini-grid, .ba-section .ba-grid { grid-template-columns: 1fr; }
  .review-lead { padding: 24px; }
  .review-lead blockquote { font-size: clamp(1.45rem, 6vw, 1.9rem); line-height: 1.1; }
  .mini-review, .service-mini-card { padding: 18px; min-height: auto; }
  .mini-review { gap: 10px; }
  .feature-service { grid-template-rows: auto auto; }
  .feature-visual { min-height: 220px; }
  .spray-motion { opacity: .7; }
  .card-grid.three, .process-grid, .area-grid, .review-grid, .check-list { grid-template-columns: 1fr; }
  .section, .subhero, .detail-hero, .contact-hero { padding-left: 12px; padding-right: 12px; }
  .section h2, .dark h2, .cta-band h2 { font-size: clamp(2rem, 8.4vw, 2.7rem); }
  .detail-shine { height: 320px; }
  .cta-band { margin-left: 12px; margin-right: 12px; margin-bottom: 78px; }
  .footer { display: grid; padding-bottom: 92px; }
  .footer-grid { grid-template-columns: 1fr; }
  .mobile-sticky { position: fixed; left: 12px; right: 12px; bottom: 12px; z-index: 60; display: grid; grid-template-columns: 1fr 1fr; gap: 8px; transition: opacity .22s ease, transform .22s ease; }
  .mobile-sticky .btn { box-shadow: var(--shadow); }
  .mobile-sticky .btn.secondary { background: var(--deep); color: #fff; border-color: var(--deep); }
  body.show-mobile-sticky .mobile-sticky { opacity: 1; transform: translateY(0); pointer-events: auto; }
}
@media (max-width: 380px) {
  .proof-strip { grid-template-columns: 1fr; }
  .hero-steps { grid-template-columns: repeat(2, minmax(0, 1fr)); border-radius: var(--radius); }
}
@media (prefers-reduced-motion: reduce) {
  *, *:before, *:after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; scroll-behavior: auto !important; transition-duration: .01ms !important; }
  .spray-motion, .drop-field { display: none; }
  .shine-grime { clip-path: inset(0 0 0 62%); }
  .shine-edge { left: calc(62% - 5px); opacity: 1; }
}