/* ================================================================
   DU TOIT PLUMBING · Crazy Websites capability demo
   Palette: navy #0D1F2D · copper #B87333 · white #F5F7FA · orange #FF5A1F
   ================================================================ */

:root{
  --navy:#0D1F2D;
  --navy-deep:#081420;
  --navy-card:#11283A;
  --copper:#B87333;
  --copper-hi:#E39A5B;
  --copper-pale:#F5D9B8;
  --white:#F5F7FA;
  --orange:#FF5A1F;
  --water:#7DC8FF;
  --line:rgba(245,247,250,.09);
  --muted:rgba(245,247,250,.62);
  --font-d:"Archivo Black","Archivo",sans-serif;
  --font-h:"Archivo",sans-serif;
  --font-b:"Inter",sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:auto}
html,body{overflow-x:clip}
body{
  background:var(--navy);
  color:var(--white);
  font-family:var(--font-b);
  font-size:1.0625rem;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}

/* film grain over everything */
body::after{
  content:"";position:fixed;inset:0;z-index:90;pointer-events:none;opacity:.055;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)'/%3E%3C/svg%3E");
}

.container{width:min(1180px,92vw);margin-inline:auto}
.section{padding:clamp(5rem,10vw,9rem) 0;position:relative}
.page{position:relative}

/* ---------- type ---------- */
.kicker{
  font-family:var(--font-h);font-weight:700;font-size:.78rem;letter-spacing:.32em;
  color:var(--copper-hi);margin-bottom:1.4rem;display:flex;align-items:center;gap:.9rem;
}
.kicker::before{content:"";width:34px;height:2px;background:var(--copper);flex:0 0 auto}
.kicker-orange{color:var(--orange)}
.kicker-orange::before{background:var(--orange)}
.h2{
  font-family:var(--font-d);font-weight:400;
  font-size:clamp(2rem,4.6vw,3.6rem);line-height:1.04;letter-spacing:-.01em;
  text-transform:uppercase;margin-bottom:1rem;
}
.h2 em{font-style:normal;color:var(--copper-hi)}

/* ---------- reveal defaults (JS animates; visible without JS) ---------- */
body.js .reveal{opacity:0;transform:translateY(28px)}
body.js.no-motion .reveal{opacity:1;transform:none}

/* ================= LOADER ================= */
.loader{
  position:fixed;inset:0;z-index:200;background:var(--navy-deep);
  display:flex;align-items:center;justify-content:center;
  animation:loaderbail 0s 5s forwards;
}
@keyframes loaderbail{to{visibility:hidden;opacity:0}}
.loader-inner{text-align:center}
.gauge{width:min(240px,56vw);height:auto;display:block;margin-inline:auto}
.gauge-label{fill:var(--muted);font-family:var(--font-h);font-weight:700;font-size:9px;letter-spacing:.28em}
.gauge-pct{fill:var(--white);font-family:var(--font-d);font-size:34px}
.gauge-pct-sm{font-size:26px}
.loader-word{
  margin-top:1.2rem;font-family:var(--font-h);font-weight:700;font-size:.72rem;
  letter-spacing:.42em;color:var(--copper-hi);
}
.loader.done{pointer-events:none}

/* ================= NAV ================= */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;gap:2rem;
  padding:.8rem clamp(1rem,4vw,3rem);
  background:linear-gradient(rgba(8,20,32,.92),rgba(8,20,32,.75));
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.brand{display:flex;align-items:center;gap:.7rem}
.brand-mark{width:38px;height:38px;flex:0 0 auto}
.brand-text{display:flex;flex-direction:column;line-height:1.1}
.brand-text strong{font-family:var(--font-d);font-weight:400;font-size:1.02rem;letter-spacing:.06em}
.brand-text em{font-style:normal;font-family:var(--font-h);font-weight:600;font-size:.56rem;letter-spacing:.34em;color:var(--copper-hi)}
.nav-links{display:flex;gap:1.7rem;margin-left:auto}
.nav-links a{
  font-family:var(--font-h);font-weight:600;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--muted);transition:color .25s;
}
.nav-links a:hover{color:var(--copper-hi)}
.nav-call{
  display:flex;align-items:center;gap:.55rem;
  font-family:var(--font-h);font-weight:700;font-size:.88rem;letter-spacing:.05em;
  border:1px solid rgba(184,115,51,.55);border-radius:999px;padding:.5rem 1.1rem;
  transition:background .25s,border-color .25s;
}
.nav-call:hover{background:rgba(184,115,51,.16);border-color:var(--copper)}
.nav-call .dot{width:8px;height:8px;border-radius:50%;background:#37d27a;box-shadow:0 0 8px #37d27a;animation:dotpulse 2s infinite}
@keyframes dotpulse{50%{opacity:.4}}

/* ================= PIPE (signature) ================= */
.pipe-svg{position:absolute;top:0;left:0;z-index:5;pointer-events:none;overflow:visible}
.pp{fill:none;stroke-linecap:round}
.pipe-shadow{stroke:rgba(0,0,0,.45);stroke-width:22;transform:translate(4px,6px);filter:blur(3px)}
.pipe-base{stroke:#5c3413;stroke-width:19}
.pipe-mid{stroke:var(--copper);stroke-width:14}
.pipe-hi{stroke:var(--copper-hi);stroke-width:6;opacity:.95;transform:translate(-2.5px,-2.5px)}
.pipe-gloss{stroke:#ffe7c9;stroke-width:2;opacity:.6;transform:translate(-3.5px,-3.5px)}
.pipe-water{
  stroke:var(--water);stroke-width:5.5;opacity:.85;
  stroke-dasharray:10 18;
  animation:waterflow 1s linear infinite;
  filter:drop-shadow(0 0 4px rgba(125,200,255,.65));
}
@keyframes waterflow{to{stroke-dashoffset:-28}}
.no-motion .pipe-water{animation:none}

/* ================= HERO ================= */
.hero{
  min-height:100svh;position:relative;display:flex;flex-direction:column;justify-content:center;
  padding:7.5rem 0 4rem;overflow:clip;
}
.hero-bg{
  position:absolute;inset:0;z-index:0;
  background:
    linear-gradient(100deg,rgba(8,20,32,.97) 0%,rgba(8,20,32,.88) 42%,rgba(13,31,45,.55) 100%),
    radial-gradient(60% 50% at 78% 30%,rgba(184,115,51,.28),transparent 70%),
    url("assets/img/hero-copper.jpg") center right/cover no-repeat;
}
.hero-bg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(to top,var(--navy) 0%,transparent 26%);
}
.hero-grid{
  position:relative;z-index:2;display:grid;grid-template-columns:1.15fr .85fr;
  align-items:center;gap:2rem;
}
.hero-h1{
  font-family:var(--font-d);font-weight:400;text-transform:uppercase;
  font-size:clamp(3.1rem,8.6vw,7.2rem);line-height:.94;letter-spacing:-.015em;
  margin:0 0 1.6rem;
}
.h1-line{display:block;overflow:hidden}
.h1-line>span{display:block}
.h1-accent{color:var(--orange)}
.hero-sub{font-size:clamp(1.05rem,1.6vw,1.3rem);color:var(--muted);max-width:34ch;margin-bottom:2.2rem}
.hero-ctas{display:flex;gap:1rem;flex-wrap:wrap;align-items:center}

.btn{
  display:inline-flex;align-items:center;gap:.65rem;
  font-family:var(--font-h);font-weight:700;font-size:.95rem;letter-spacing:.05em;
  padding:1rem 1.7rem;border-radius:12px;transition:transform .2s,box-shadow .2s,background .2s;
}
.btn-ic{width:20px;height:20px}
.btn-orange{background:var(--orange);color:#160800;box-shadow:0 10px 34px rgba(255,90,31,.35)}
.btn-orange:hover{transform:translateY(-2px);box-shadow:0 16px 44px rgba(255,90,31,.5)}
.btn-ghost{border:1px solid rgba(245,247,250,.28);color:var(--white)}
.btn-ghost:hover{border-color:var(--copper-hi);background:rgba(184,115,51,.12)}
.btn-big{font-size:1.1rem;padding:1.2rem 2.2rem}
.btn.done{background:#2c9e63;color:#04160c;box-shadow:0 10px 34px rgba(44,158,99,.35)}

.leak-msg{
  margin-top:1.4rem;font-family:var(--font-h);font-weight:600;color:var(--copper-pale);
  opacity:0;transform:translateY(10px);visibility:hidden;
}
.leak-msg a{color:var(--orange);border-bottom:2px solid rgba(255,90,31,.5)}
.leak-msg.show{visibility:visible}

/* --- the leak rig --- */
.leak-rig{position:relative;width:min(320px,74vw);margin-inline:auto;height:460px}
.rig-svg{position:absolute;inset:0;width:100%;height:100%;filter:drop-shadow(0 18px 30px rgba(0,0,0,.5))}
#leakCanvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}
#wrenchTool{
  position:absolute;width:38%;left:31%;top:21%;opacity:0;pointer-events:none;
  transform-origin:50% 15%;
  filter:drop-shadow(0 10px 16px rgba(0,0,0,.55));
}
.leak-meter{
  display:inline-flex;align-items:center;gap:.4rem;margin-top:1.4rem;
  white-space:nowrap;font-size:.78rem;letter-spacing:.05em;color:var(--muted);
  font-family:var(--font-h);font-weight:600;
  background:rgba(8,20,32,.8);border:1px solid rgba(184,115,51,.4);
  border-radius:999px;padding:.5rem 1.05rem;
}
.leak-meter strong{color:var(--water);font-weight:700}

.hero-scrollcue{
  position:absolute;left:50%;bottom:1.6rem;transform:translateX(-50%);z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:.6rem;
  font-family:var(--font-h);font-weight:700;font-size:.62rem;letter-spacing:.4em;color:var(--muted);
}
.hero-scrollcue i{width:2px;height:40px;background:linear-gradient(var(--copper),transparent);display:block;animation:cue 1.8s ease-in-out infinite}
@keyframes cue{50%{transform:translateY(8px);opacity:.4}}
.no-motion .hero-scrollcue i{animation:none}

/* ================= SERVICES ================= */
.services{background:transparent}
.svc-grid{
  margin-top:3.5rem;display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;
}
.svc{
  background:linear-gradient(160deg,var(--navy-card),rgba(13,31,45,.6));
  border:1px solid var(--line);border-radius:18px;padding:2rem 1.7rem 1.7rem;
  transition:transform .3s,border-color .3s,box-shadow .3s;position:relative;z-index:2;
}
.svc:hover{transform:translateY(-5px);border-color:rgba(184,115,51,.55);box-shadow:0 24px 50px rgba(0,0,0,.35)}
.svc h3{font-family:var(--font-h);font-weight:800;font-size:1.22rem;margin:1.3rem 0 .5rem;letter-spacing:.01em}
.svc p{color:var(--muted);font-size:.95rem}
.svc-price{
  display:inline-block;margin-top:1.1rem;font-family:var(--font-h);font-weight:700;font-size:.8rem;
  letter-spacing:.08em;color:var(--copper-hi);border:1px solid rgba(184,115,51,.4);
  border-radius:999px;padding:.34rem .85rem;
}
.svc-ic{width:60px;height:60px;overflow:visible}
.svc-ic *{fill:none;stroke:var(--copper-hi);stroke-width:2.6;stroke-linecap:round;stroke-linejoin:round}
.svc-ic .i-fill{fill:var(--copper-hi);stroke:none}
.svc-ic .i-flame,.svc-ic .i-flame2{stroke:var(--orange)}
.svc-ic .i-drop,.svc-ic .i-dripdot{stroke:var(--water)}
.svc-ic .i-pulse circle{stroke:rgba(125,200,255,.5);stroke-width:1.6;opacity:0}
.svc-ic .i-steam path{opacity:.4}
/* hover animations */
.svc:hover .i-steam path{animation:steamUp 1.3s ease-in-out infinite}
.svc:hover .i-steam path:nth-child(2){animation-delay:.2s}
.svc:hover .i-steam path:nth-child(3){animation-delay:.4s}
@keyframes steamUp{0%{transform:translateY(0);opacity:.2}50%{opacity:1}100%{transform:translateY(-7px);opacity:0}}
.svc:hover .i-flame{animation:flick .5s ease-in-out infinite alternate;transform-box:fill-box;transform-origin:50% 100%}
@keyframes flick{from{transform:scale(1)}to{transform:scale(1.18) rotate(-4deg)}}
.svc:hover .i-swirl{animation:spin 1.4s linear infinite;transform-box:fill-box;transform-origin:center}
@keyframes spin{to{transform:rotate(360deg)}}
.svc:hover .i-pulse circle{animation:pulse 1.4s ease-out infinite}
.svc:hover .i-pulse circle:nth-child(2){animation-delay:.45s}
@keyframes pulse{0%{opacity:.9;transform:scale(.5)}100%{opacity:0;transform:scale(1.15)}}
.svc .i-pulse circle{transform-box:fill-box;transform-origin:center}
.svc:hover .i-drop{animation:flick .7s ease-in-out infinite alternate;transform-box:fill-box;transform-origin:50% 0}
.svc:hover .i-spray line{animation:sprayOut .55s ease-out infinite;transform-box:fill-box;transform-origin:center}
@keyframes sprayOut{0%{opacity:0;transform:scale(.4)}35%{opacity:1}100%{opacity:0;transform:scale(1.3)}}
.svc:hover .i-dripdot{animation:dripFall 1s ease-in infinite;transform-box:fill-box;transform-origin:center}
@keyframes dripFall{0%{transform:translateY(-6px);opacity:0}30%{opacity:1}100%{transform:translateY(8px);opacity:0}}
.svc:hover .i-rays line{animation:steamUp 1.1s ease-in-out infinite}
.svc:hover .i-flame2{animation:flick .45s ease-in-out infinite alternate;transform-box:fill-box;transform-origin:50% 100%}

/* ================= WORKMANSHIP BAND ================= */
.testband{position:relative;padding:clamp(6rem,12vw,10rem) 0;overflow:clip}
.testband-img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;
  filter:saturate(.8) brightness(.8);
}
.testband::before{
  content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(95deg,rgba(8,20,32,.96) 8%,rgba(8,20,32,.82) 52%,rgba(8,20,32,.45) 100%);
}
.testband-inner{position:relative;z-index:2}
.testband-inner p{max-width:52ch;color:var(--muted);font-size:1.05rem}

/* ================= CALLOUT STEPS ================= */
.steps{margin-top:4rem;display:flex;flex-direction:column;gap:clamp(4rem,8vw,7rem)}
.step{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,4vw,4rem);align-items:center;
  position:relative;z-index:2;
}
.step-r .photo{order:2}
.step-body{max-width:44ch}
.step-r .step-body{justify-self:end}
.step-no{
  font-family:var(--font-d);font-size:clamp(2.4rem,4vw,3.4rem);color:transparent;
  -webkit-text-stroke:1.5px var(--copper);display:block;line-height:1;margin-bottom:.7rem;
}
.step h3{font-family:var(--font-h);font-weight:800;font-size:clamp(1.4rem,2.2vw,1.9rem);margin-bottom:.7rem;letter-spacing:-.01em}
.step p{color:var(--muted)}

/* art-directed photo frames */
.photo{position:relative;border-radius:16px;overflow:visible;margin:0}
.photo img{
  border-radius:16px;width:100%;aspect-ratio:4/3;object-fit:cover;
  filter:saturate(.82) contrast(1.06) brightness(.92);
  box-shadow:0 30px 60px rgba(0,0,0,.45);
}
.photo::before{
  content:"";position:absolute;inset:0;border-radius:16px;z-index:2;pointer-events:none;
  background:linear-gradient(160deg,rgba(13,31,45,.35),transparent 45%,rgba(184,115,51,.14));
  mix-blend-mode:multiply;
}
.photo::after{
  content:"";position:absolute;inset:0;border-radius:16px;z-index:3;pointer-events:none;
  border:1px solid rgba(184,115,51,.55);transform:translate(12px,12px);
}
.step-r .photo::after{transform:translate(-12px,12px)}

/* ================= BEFORE / AFTER ================= */
.ba{
  position:relative;margin-top:3rem;border-radius:18px;overflow:hidden;
  box-shadow:0 40px 80px rgba(0,0,0,.5);z-index:2;
  --ba:50%;
  touch-action:pan-y;
}
.ba img{width:100%;aspect-ratio:16/9;object-fit:cover;user-select:none;-webkit-user-drag:none}
.ba-after{filter:saturate(1.05) contrast(1.04)}
.ba-before{
  position:absolute;inset:0;
  clip-path:inset(0 calc(100% - var(--ba)) 0 0);
}
.ba-before img{
  height:100%;
  filter:saturate(.18) sepia(.55) brightness(.42) contrast(.88) hue-rotate(-12deg);
}
.ba-grime{
  position:absolute;inset:0;
  background:
    radial-gradient(42% 36% at 22% 76%,rgba(74,58,22,.75),transparent 70%),
    radial-gradient(34% 28% at 68% 28%,rgba(52,42,18,.7),transparent 70%),
    radial-gradient(26% 20% at 46% 55%,rgba(60,48,20,.5),transparent 70%),
    radial-gradient(130% 95% at 50% 112%,rgba(8,6,3,.8),transparent 62%),
    linear-gradient(rgba(30,26,14,.28),rgba(30,26,14,.28));
}
.ba-tag{
  position:absolute;top:1.1rem;z-index:4;font-family:var(--font-h);font-weight:700;font-size:.72rem;
  letter-spacing:.26em;padding:.4rem .9rem;border-radius:999px;background:rgba(8,20,32,.78);
  border:1px solid var(--line);
}
.ba-tag-l{left:1.1rem;color:rgba(245,247,250,.75)}
.ba-tag-r{right:1.1rem;color:var(--copper-hi);border-color:rgba(184,115,51,.5)}
.ba-handle{
  position:absolute;top:0;bottom:0;left:var(--ba);z-index:5;width:0;
  display:flex;align-items:center;justify-content:center;pointer-events:none;
}
.ba-handle::before{
  content:"";position:absolute;top:0;bottom:0;left:-1.5px;width:3px;
  background:linear-gradient(var(--copper-hi),var(--copper),var(--copper-hi));
  box-shadow:0 0 14px rgba(184,115,51,.8);
}
.ba-cutter{width:56px;height:84px;flex:0 0 auto;filter:drop-shadow(0 8px 14px rgba(0,0,0,.6))}
.ba{cursor:ew-resize}
.ba-range{
  position:absolute;inset:0;width:100%;height:100%;opacity:0;pointer-events:none;z-index:6;
  -webkit-appearance:none;appearance:none;margin:0;
}
.ba-cap{margin-top:2.4rem;color:var(--muted);font-size:.95rem}
.ba-hint{color:var(--copper-hi);font-family:var(--font-h);font-weight:700;letter-spacing:.06em}

/* ================= EMERGENCY ================= */
.emergency{background:var(--navy-deep);overflow:clip}
.emg-bg{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.5;
  filter:saturate(.6) brightness(.55);
}
.emergency::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(70% 60% at 50% 100%,rgba(255,90,31,.16),transparent 65%),
    linear-gradient(rgba(8,20,32,.92),rgba(8,20,32,.72) 50%,rgba(8,20,32,.94));
}
.emg-inner{position:relative;z-index:2}
.emg-clockline em{color:var(--orange);text-shadow:0 0 40px rgba(255,90,31,.4)}
#emgTime{color:var(--water)}
.emg-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:3rem;align-items:center;margin-top:2.5rem}
.emg-copy p{max-width:52ch;color:rgba(245,247,250,.78);margin-bottom:1.1rem}
.emg-copy .btn{margin-top:1rem}
.emg-note{margin-top:1.2rem;font-family:var(--font-h);font-weight:600;font-size:.85rem;letter-spacing:.08em;color:var(--copper-hi)}
.emg-gaugewrap{text-align:center;justify-self:center}
.gauge-big{width:min(290px,70vw)}
.emg-gauge-cap{
  margin-top:.8rem;font-family:var(--font-h);font-weight:700;font-size:.72rem;letter-spacing:.32em;color:var(--muted);
}
.emg-gauge-cap span{color:var(--orange)}
.emergency.redline .emg-gauge-cap span{animation:blink 1s steps(2) infinite}
@keyframes blink{50%{opacity:.25}}

/* pulsing call button */
.pulse{position:relative}
.pulse::after{
  content:"";position:absolute;inset:-4px;border-radius:16px;border:2px solid rgba(255,90,31,.7);
  opacity:0;pointer-events:none;
}
.emergency.redline .pulse::after{animation:ring 1.6s ease-out infinite}
@keyframes ring{0%{opacity:.9;transform:scale(1)}100%{opacity:0;transform:scale(1.14)}}
.no-motion .pulse::after{animation:none !important}

/* ================= TRUST ================= */
.stats{
  margin:3.4rem 0 4rem;display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;
  border-block:1px solid var(--line);padding:2.4rem 0;position:relative;z-index:2;
}
.stat{text-align:center}
.stat-n{
  display:block;font-family:var(--font-d);font-size:clamp(2.2rem,4.4vw,3.6rem);
  color:var(--copper-hi);line-height:1;letter-spacing:-.01em;
}
.stat-l{
  display:block;margin-top:.6rem;font-family:var(--font-h);font-weight:600;font-size:.78rem;
  letter-spacing:.16em;text-transform:uppercase;color:var(--muted);
}
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;position:relative;z-index:2}
.review{
  background:linear-gradient(160deg,var(--navy-card),rgba(13,31,45,.5));
  border:1px solid var(--line);border-radius:18px;padding:1.8rem;
}
.stars{color:var(--copper-hi);letter-spacing:.3em;font-size:.95rem}
.review p{margin:.9rem 0 1.1rem;color:rgba(245,247,250,.85);font-size:.98rem}
.review cite{font-style:normal;font-family:var(--font-h);font-weight:700;font-size:.8rem;letter-spacing:.1em;color:var(--muted)}
.heirloom{
  margin-top:4.5rem;display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(1.5rem,4vw,4rem);
  align-items:center;position:relative;z-index:2;
}
.heirloom h3{font-family:var(--font-h);font-weight:800;font-size:clamp(1.4rem,2.2vw,1.9rem);margin-bottom:.8rem}
.heirloom p{color:var(--muted);max-width:52ch}
.photo-wrench img{aspect-ratio:5/4}

/* ================= FOOTER ================= */
.footer{background:var(--navy-deep);border-top:1px solid var(--line);padding:0 0 2rem;position:relative}
.pipe-end{
  display:flex;flex-direction:column;align-items:center;gap:.7rem;
  padding:2.6rem 0 2rem;position:relative;z-index:2;
}
.pipe-end svg{width:74px;filter:drop-shadow(0 10px 18px rgba(0,0,0,.5))}
.pipe-end span{font-family:var(--font-h);font-weight:700;font-size:.62rem;letter-spacing:.42em;color:var(--muted)}
.tap-drip{animation:tapdrip 2.6s ease-in infinite;transform-box:fill-box;transform-origin:center}
@keyframes tapdrip{0%,55%{transform:translateY(-4px) scale(.4);opacity:0}70%{opacity:1;transform:translateY(0) scale(1)}100%{transform:translateY(22px) scale(1);opacity:0}}
.no-motion .tap-drip{animation:none}
.footer-grid{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2rem;
  padding:2.5rem 0 3rem;border-top:1px solid var(--line);position:relative;z-index:2;
}
.footer-logo{font-family:var(--font-h);font-weight:600;font-size:1.5rem;letter-spacing:.04em}
.footer-logo strong{font-family:var(--font-d);font-weight:400}
.footer-tag{color:var(--copper-hi);font-family:var(--font-h);font-weight:600;margin-top:.4rem}
.footer-col h4{
  font-family:var(--font-h);font-weight:700;font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--copper-hi);margin-bottom:.9rem;
}
.footer-col p,.footer-col a{color:var(--muted);font-size:.92rem;line-height:1.7}
.footer-tel{display:block;font-family:var(--font-h);font-weight:800;font-size:1.3rem;color:var(--white) !important;margin-bottom:.3rem}
.footer-base{
  display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;
  padding-top:1.6rem;border-top:1px solid var(--line);color:var(--muted);font-size:.82rem;
}
.cw-badge{
  font-family:var(--font-h);font-weight:600;font-size:.72rem;letter-spacing:.12em;
  border:1px solid rgba(184,115,51,.45);color:var(--copper-hi);
  border-radius:999px;padding:.4rem .95rem;
}

/* ================= HUD gauge ================= */
.hud{
  position:fixed;left:1.4rem;bottom:1.4rem;z-index:95;width:78px;text-align:center;
  opacity:0;transition:opacity .5s;pointer-events:none;
}
.hud.on{opacity:1}
.hud svg{width:70px;height:70px;display:block;margin-inline:auto}
.hud span{font-family:var(--font-h);font-weight:700;font-size:.5rem;letter-spacing:.26em;color:var(--muted)}
.hud.hot svg circle:first-child{stroke:rgba(255,90,31,.8)}

/* ================= RESPONSIVE ================= */
@media (max-width:1000px){
  .nav-links{display:none}
  .svc-grid{grid-template-columns:repeat(2,1fr)}
  .reviews{grid-template-columns:1fr}
  .stats{grid-template-columns:repeat(2,1fr);row-gap:2rem}
  .hud{display:none}
}
@media (max-width:820px){
  .hero-grid{grid-template-columns:1fr;gap:4.5rem}
  .leak-rig{height:400px}
  .step{grid-template-columns:1fr;gap:1.6rem}
  .step-r .photo{order:0}
  .step-r .step-body{justify-self:start}
  .emg-grid{grid-template-columns:1fr}
  .heirloom{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .hero{padding-top:6.5rem}
  .hero-scrollcue{display:none}
}
/* mobile: content clears the pipe rail on the left edge */
@media (max-width:699px){
  .container{width:auto;margin-left:46px;margin-right:18px}
  .nav{padding-left:1rem}
}
@media (max-width:560px){
  .svc-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .brand-text em{display:none}
  .nav{gap:1rem}
  .nav-call{margin-left:auto}
  .pipe-shadow{stroke-width:15}
  .pipe-base{stroke-width:13}
  .pipe-mid{stroke-width:9.5}
  .pipe-hi{stroke-width:4;transform:translate(-1.5px,-1.5px)}
  .pipe-gloss{stroke-width:1.4;transform:translate(-2.2px,-2.2px)}
  .pipe-water{stroke-width:4}
  .ba img{aspect-ratio:4/5}
}

/* ================= REDUCED MOTION ================= */
@media (prefers-reduced-motion:reduce){
  .hero-scrollcue i,.pipe-water,.tap-drip,.nav-call .dot{animation:none !important}
  .svc:hover .svc-ic *{animation:none !important}
}
