/* Shiloh Plumbing — watercolor desert brand (from the logo: teal→peach→orange sky,
   purple mountains, cactus green, brush-marker lettering) */
:root{
  --orange:#e87a2c; --orange-d:#c75f1a; --ink:#23272e;
  --teal:#8fd4d0; --teal-d:#4fa8a3; --peach:#f8c98f;
  --mtn:#7b6b9e; --mtn-d:#585179; --mtn-dd:#3f3a58;
  --cactus:#5c7a52; --bloom:#c0392b;
  --paper:#fdf9f2; --paper-d:#f4ead9; --card:#ffffff; --line:#eadfca;
  --mut:#6e7480; --gold:#f0a92e; --ok:#1a7f4b;
  --shadow:0 10px 30px rgba(88,81,121,.12);
  --shadow-lg:0 22px 55px rgba(88,81,121,.20);
  --r:18px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:"Segoe UI",system-ui,-apple-system,sans-serif;background:var(--paper);color:var(--ink);line-height:1.6;overflow-x:hidden}
h1,h2,h3{font-family:Georgia,"Times New Roman",serif;letter-spacing:-.01em}
.brush{font-family:"Permanent Marker","Segoe Print",cursive;letter-spacing:.01em;font-weight:400}
img{max-width:100%}
a{color:var(--teal-d)}
.wrap{max-width:1060px;margin:0 auto;padding:0 22px}

/* ---------- top bar ---------- */
.topbar{position:fixed;inset:0 0 auto 0;z-index:100;display:flex;align-items:center;gap:16px;
  padding:10px 20px;transition:background .35s,box-shadow .35s;background:transparent}
.topbar.scrolled{background:rgba(253,249,242,.94);backdrop-filter:blur(10px);box-shadow:0 2px 16px rgba(88,81,121,.14)}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:#fff;transition:color .35s}
.topbar.scrolled .logo{color:var(--ink)}
.logo img{width:44px;height:44px;border-radius:10px;object-fit:cover;box-shadow:0 3px 10px rgba(0,0,0,.22);background:#fff}
.logo .nm{font-family:"Permanent Marker",cursive;font-size:1.05rem;line-height:1.05}
.logo .nm b{color:var(--orange);font-weight:400}
.logo small{display:block;font-family:"Segoe UI",sans-serif;font-size:.6rem;letter-spacing:.08em;opacity:.85}
nav.top{margin-left:auto;display:flex;gap:2px;align-items:center}
nav.top a{padding:8px 12px;border-radius:999px;font-size:.87rem;font-weight:600;color:#fff;text-decoration:none;transition:.25s}
.topbar.scrolled nav.top a{color:var(--ink)}
nav.top a:hover{background:rgba(232,122,44,.22)}
nav.top a.active{background:rgba(232,122,44,.34)}
.topbar.scrolled nav.top a.active{background:var(--paper-d);color:var(--orange-d)}
.callpill{display:inline-flex;align-items:center;gap:8px;background:var(--orange);color:#fff!important;padding:9px 17px;border-radius:999px;
  font-weight:800;font-size:.87rem;text-decoration:none;box-shadow:0 6px 18px rgba(232,122,44,.4);transition:.25s;white-space:nowrap}
.callpill:hover{transform:translateY(-2px);background:var(--orange-d)}
.callpill .ring{display:inline-block;animation:ringring 6s ease-in-out infinite}
@keyframes ringring{0%,86%,100%{transform:rotate(0)}88%{transform:rotate(-18deg)}90%{transform:rotate(14deg)}92%{transform:rotate(-10deg)}94%{transform:rotate(6deg)}96%{transform:rotate(0)}}
.menu-btn{display:none;margin-left:auto;background:none;border:0;color:#fff;font-size:1.6rem;cursor:pointer}
.topbar.scrolled .menu-btn{color:var(--ink)}

/* ---------- heroes ---------- */
.hero,.subhero{position:relative;color:#fff;overflow:hidden;text-align:center;
  background:linear-gradient(180deg,#9edbd6 0%,#f2ddb2 38%,#f2ae70 72%,var(--orange) 108%)}
.hero{min-height:88vh;display:flex;align-items:center;justify-content:center}
.subhero{padding:140px 22px 96px}
.mtns{position:absolute;left:0;right:0;bottom:-2px;pointer-events:none;will-change:transform}
.mtns svg{display:block;width:100%;height:auto}
.cacti{position:absolute;bottom:0;pointer-events:none;opacity:.9;z-index:4}
.cacti.l{left:2%}.cacti.r{right:2%;transform:scaleX(-1)}
.heroin{position:relative;z-index:5;padding:110px 22px 170px;max-width:840px}
.hero .logoart{width:150px;height:150px;border-radius:26px;object-fit:cover;box-shadow:0 14px 40px rgba(63,58,88,.35);animation:fadeup .9s .05s both}
.kicker{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.4);backdrop-filter:blur(6px);
  padding:6px 16px;border-radius:999px;font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin:20px 0 16px;color:#453e2a;animation:fadeup .9s .2s both}
.hero h1{font-size:clamp(2.1rem,5.2vw,3.5rem);line-height:1.14;color:#3b3350;text-shadow:0 2px 14px rgba(255,255,255,.35);animation:fadeup .9s .3s both}
.hero h1 .brush{display:block;font-size:clamp(2.6rem,6.5vw,4.4rem);color:var(--orange-d);-webkit-text-stroke:.5px rgba(0,0,0,.06)}
.subhero h1{font-size:clamp(1.9rem,4vw,2.7rem);max-width:820px;margin:0 auto;color:#3b3350;position:relative;z-index:5}
.subhero h1 .brush{color:var(--orange-d)}
.hero p.sub,.subhero p.sub{margin:18px auto 26px;max-width:600px;font-size:1.1rem;color:#4b4436;position:relative;z-index:5;animation:fadeup .9s .45s both}
.heroctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;position:relative;z-index:5;animation:fadeup .9s .6s both}
.herostars{margin-top:30px;display:inline-flex;align-items:center;gap:10px;font-weight:800;color:#3b3350;position:relative;z-index:5;animation:fadeup .9s .72s both}
.herostars .g{color:var(--gold);letter-spacing:3px;font-size:1.15rem;text-shadow:0 1px 0 #fff}
.trustline{position:relative;z-index:5;display:inline-flex;flex-wrap:wrap;justify-content:center;gap:6px 16px;margin-top:20px;
  background:rgba(255,255,255,.3);border:1px solid rgba(255,255,255,.5);border-radius:999px;padding:8px 20px;font-size:.8rem;font-weight:700;color:#453e2a;backdrop-filter:blur(6px)}
.trustline .g{color:var(--orange-d)}
@keyframes fadeup{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}
.hawk{position:absolute;z-index:4;font-size:1.5rem;animation:hawkfloat 14s ease-in-out infinite;opacity:.85}
@keyframes hawkfloat{0%,100%{transform:translate(0,0)}25%{transform:translate(30px,-14px)}50%{transform:translate(64px,4px)}75%{transform:translate(28px,-10px)}}

/* ---------- buttons ---------- */
.btn{position:relative;overflow:hidden;display:inline-flex;align-items:center;gap:10px;padding:14px 28px;border-radius:999px;
  font-weight:800;font-size:1rem;text-decoration:none;border:0;cursor:pointer;transition:transform .22s,box-shadow .22s,background .22s}
.btn:active{transform:scale(.97)}
.btn.orange{background:var(--orange);color:#fff;box-shadow:0 10px 26px rgba(232,122,44,.4)}
.btn.orange:hover{transform:translateY(-3px);background:var(--orange-d)}
.btn.paper{background:#fff;color:var(--orange-d);box-shadow:0 10px 26px rgba(63,58,88,.22)}
.btn.paper:hover{transform:translateY(-3px)}
.btn.ghost{background:rgba(255,255,255,.28);border:1.5px solid rgba(255,255,255,.75);color:#3b3350;backdrop-filter:blur(6px)}
.btn.ghost:hover{background:rgba(255,255,255,.45);transform:translateY(-3px)}
.ripple{position:absolute;border-radius:50%;background:rgba(255,255,255,.5);transform:scale(0);animation:rip .55s ease-out forwards;pointer-events:none}
@keyframes rip{to{transform:scale(4);opacity:0}}

/* ---------- trust strip (static, itemized) ---------- */
.truststrip{background:var(--mtn-dd);color:#f3e9d6;padding:16px 0}
.truststrip .in{max-width:1060px;margin:0 auto;padding:0 22px;display:flex;flex-wrap:wrap;gap:8px 26px;justify-content:center;font-size:.87rem;font-weight:600}
.truststrip b{color:var(--peach)}

/* ---------- sections ---------- */
section.blk{padding:72px 0}
section.blk.alt{background:linear-gradient(180deg,#fff 0%,var(--paper) 100%)}
.eyebrow{font-family:"Permanent Marker",cursive;color:var(--orange);font-size:1rem;letter-spacing:.04em;margin-bottom:8px}
h2.big{font-size:clamp(1.6rem,3.2vw,2.3rem);line-height:1.2;margin-bottom:12px}
.leadp{font-size:1.04rem;color:var(--mut);max-width:700px}

/* reveal */
.rv{opacity:0;transform:translateY(30px);transition:opacity .8s cubic-bezier(.2,.7,.3,1),transform .8s cubic-bezier(.2,.7,.3,1)}
.rv.in{opacity:1;transform:none}
.rv.d1{transition-delay:.08s}.rv.d2{transition-delay:.16s}.rv.d3{transition-delay:.24s}

/* stats */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-top:34px}
.stat{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:24px 18px;text-align:center;box-shadow:var(--shadow);transition:transform .3s,box-shadow .3s}
.stat:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.stat .n{display:block;font-family:"Permanent Marker",cursive;font-size:2.1rem;color:var(--orange);line-height:1.1}
.stat .l{display:block;margin-top:6px;font-size:.84rem;color:var(--mut)}

/* cards */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:18px;margin-top:32px}
.tcard{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:24px;box-shadow:var(--shadow);
  transition:transform .35s cubic-bezier(.2,.7,.3,1),box-shadow .35s;will-change:transform;position:relative;overflow:hidden}
.tcard::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--teal),var(--orange));transform:scaleX(0);transform-origin:left;transition:transform .45s}
.tcard:hover::before{transform:scaleX(1)}
.tcard:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.tcard .ico{font-size:1.8rem;display:inline-block;margin-bottom:8px;transition:transform .4s}
.tcard:hover .ico{transform:scale(1.18) rotate(-6deg)}
.tcard h3{font-size:1.08rem;margin-bottom:6px}
.tcard p{font-size:.92rem;color:var(--mut)}

/* itemized lists */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center;margin-top:28px}
ul.signs{list-style:none}
.signs li{padding:10px 0 10px 38px;position:relative;border-bottom:1px dashed var(--line);font-size:.95rem;color:var(--mut)}
.signs li b{color:var(--ink)}
.signs li::before{content:"";position:absolute;left:4px;top:15px;width:17px;height:17px;border-radius:50%;
  background:radial-gradient(circle at 35% 35%,var(--peach),var(--orange));box-shadow:0 0 0 4px rgba(232,122,44,.16);transform:scale(0);transition:transform .5s cubic-bezier(.3,1.5,.5,1)}
.signs li.in::before{transform:scale(1)}
ul.checks{list-style:none;margin-top:14px}
.checks li{padding:8px 0 8px 32px;position:relative;font-size:.95rem;color:var(--mut)}
.checks li b{color:var(--ink)}
.checks li::before{content:"✓";position:absolute;left:2px;color:var(--cactus);font-weight:900;font-size:1.05rem}

/* gauge box */
.gaugebox{background:linear-gradient(165deg,var(--mtn) 0%,var(--mtn-dd) 100%);border-radius:var(--r);padding:34px 28px;color:#fff;text-align:center;box-shadow:var(--shadow-lg);position:relative;overflow:hidden}
.gaugebox::after{content:"";position:absolute;inset:auto -40% -60% -40%;height:70%;background:radial-gradient(ellipse at center,rgba(248,201,143,.4),transparent 70%)}
.gauge{width:200px;margin:0 auto}
.gauge .arc{stroke-dasharray:264;stroke-dashoffset:264;transition:stroke-dashoffset 1.6s cubic-bezier(.3,.7,.3,1)}
.gauge.go .arc{stroke-dashoffset:66}
.gaugebox .ttl{font-family:"Permanent Marker",cursive;font-size:1.5rem;margin-top:6px;color:var(--peach)}
.gaugebox .cap{font-size:.85rem;color:#ded8ee;max-width:300px;margin:8px auto 0}

/* reviews */
.revwrap{position:relative;background:linear-gradient(160deg,var(--mtn-dd),var(--mtn) 70%,#94829f);border-radius:26px;color:#fff;padding:50px 28px 58px;overflow:hidden;box-shadow:var(--shadow-lg)}
.revwrap .bigq{position:absolute;top:-34px;left:16px;font-family:Georgia,serif;font-size:11rem;opacity:.13;line-height:1}
.revhead{text-align:center;margin-bottom:22px}
.revhead .g{color:var(--gold);letter-spacing:4px;font-size:1.45rem;filter:drop-shadow(0 0 10px rgba(240,169,46,.55))}
.revstage{position:relative;max-width:640px;margin:0 auto;min-height:168px}
.rquote{position:absolute;inset:0;opacity:0;transform:translateX(46px);transition:opacity .6s,transform .6s;text-align:center;pointer-events:none}
.rquote.on{opacity:1;transform:none;pointer-events:auto}
.rquote p{font-family:Georgia,serif;font-size:1.22rem;line-height:1.55;font-style:italic}
.rquote .who{margin-top:12px;font-weight:700;color:var(--peach);font-size:.94rem}
.rdots{display:flex;gap:10px;justify-content:center;margin-top:22px}
.rdots button{width:11px;height:11px;border-radius:50%;border:0;background:rgba(255,255,255,.35);cursor:pointer;transition:.3s;padding:0}
.rdots button.on{background:var(--gold);transform:scale(1.35)}
.revcta{text-align:center;margin-top:22px}
.revcta a{color:var(--peach);font-weight:700}

/* compare */
.compare{display:grid;grid-template-columns:1fr 1fr;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-lg);margin-top:32px}
.compare .side{padding:30px 26px}
.compare .side.a{background:var(--card)}
.compare .side.b{background:linear-gradient(160deg,var(--teal-d),#357d7a);color:#fff}
.compare h3{font-size:1.2rem;margin-bottom:2px}
.compare .tag{font-size:.72rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;opacity:.72}
.compare ul{list-style:none;margin-top:14px}
.compare li{padding:6px 0 6px 26px;position:relative;font-size:.92rem}
.compare .side.a li{color:var(--mut)}
.compare li::before{content:"✓";position:absolute;left:0;font-weight:900}
.compare .side.a li::before{color:var(--orange)}
.compare .side.b li::before{color:var(--peach)}

/* FAQ */
.faq{max-width:740px;margin:30px auto 0}
details.f{background:var(--card);border:1px solid var(--line);border-radius:14px;margin-bottom:11px;box-shadow:var(--shadow);overflow:hidden;transition:box-shadow .3s}
details.f[open]{box-shadow:var(--shadow-lg)}
details.f summary{list-style:none;cursor:pointer;padding:16px 20px;font-weight:700;display:flex;align-items:center;gap:12px;font-size:.96rem}
details.f summary::-webkit-details-marker{display:none}
details.f summary .pm{margin-left:auto;flex:0 0 25px;width:25px;height:25px;border-radius:50%;background:var(--paper-d);color:var(--orange);display:inline-flex;align-items:center;justify-content:center;font-weight:900;transition:transform .35s,background .35s}
details.f[open] summary .pm{transform:rotate(45deg);background:var(--orange);color:#fff}
details.f .a{padding:0 20px 16px;color:var(--mut);font-size:.93rem}

/* towns */
.towns{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;margin-top:30px}
.town{background:var(--card);border:1px solid var(--line);border-left:5px solid var(--orange);border-radius:14px;padding:18px 20px;box-shadow:var(--shadow);transition:transform .3s,border-color .3s}
.town:hover{transform:translateX(6px);border-left-color:var(--teal-d)}
.town h3{font-size:1rem;margin-bottom:4px;color:var(--mtn-dd)}
.town p{font-size:.87rem;color:var(--mut)}

/* contact */
.contactgrid{display:grid;grid-template-columns:1fr 1fr;gap:36px;margin-top:32px;align-items:start}
form.lead{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:28px;box-shadow:var(--shadow-lg)}
form.lead label{display:block;font-size:.83rem;font-weight:700;margin:13px 0 5px}
form.lead input,form.lead select,form.lead textarea{width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:10px;font-size:.95rem;font-family:inherit;background:var(--paper);transition:border .25s,box-shadow .25s}
form.lead input:focus,form.lead select:focus,form.lead textarea:focus{outline:none;border-color:var(--teal-d);box-shadow:0 0 0 4px rgba(79,168,163,.15);background:#fff}
form.lead .consent{display:flex;gap:10px;align-items:flex-start;font-weight:400;font-size:.75rem;color:var(--mut);margin-top:15px}
form.lead .consent input{width:auto;margin-top:2px}
form.lead button{margin-top:16px;width:100%}
.cinfo .row{display:flex;gap:14px;align-items:flex-start;padding:13px 0;border-bottom:1px dashed var(--line);font-size:.94rem}
.cinfo .row .i{font-size:1.35rem;flex:0 0 32px;text-align:center}
.cinfo b{display:block}
.urgent{background:#fdf3e2;border:1px solid #ecd9ae;border-radius:12px;padding:13px 17px;font-size:.84rem;color:#7a5b1d;margin-top:18px}

/* CTA band */
.ctaband{text-align:center;padding:64px 22px;background:linear-gradient(160deg,var(--orange),#d4681f);color:#fff;border-radius:26px;box-shadow:var(--shadow-lg);position:relative;overflow:hidden}
.ctaband h2{font-size:clamp(1.5rem,3vw,2.1rem);margin-bottom:8px}
.ctaband .brush{color:#ffe9cd}
.ctaband p{color:#ffe3c4;max-width:560px;margin:0 auto 22px}

/* footer */
footer.ft{background:var(--mtn-dd);color:#cfc9df;margin-top:80px;position:relative}
footer.ft .ridge{display:block;width:100%;margin-bottom:-1px}
footer.ft .in{max-width:1060px;margin:0 auto;padding:26px 22px 36px;display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:24px;font-size:.87rem}
footer.ft h4{color:#fff;font-size:.93rem;margin-bottom:7px}
footer.ft a{color:var(--peach)}
footer.ft .cred{grid-column:1/-1;border-top:1px solid #56507a;padding-top:16px;text-align:center;font-size:.78rem}

/* sticky mobile call bar */
.callbar{position:fixed;left:12px;right:12px;bottom:12px;z-index:90;display:none;background:var(--orange);color:#fff;border-radius:16px;
  padding:13px 18px;font-weight:800;text-align:center;box-shadow:0 12px 34px rgba(199,95,26,.5);text-decoration:none;transform:translateY(120%);transition:transform .45s cubic-bezier(.2,.9,.3,1)}
.callbar.show{transform:none}

@media (max-width:860px){
  .split,.contactgrid,.compare{grid-template-columns:1fr}
  nav.top{display:none}
  nav.top.open{display:flex;position:fixed;inset:60px 12px auto 12px;flex-direction:column;background:#fff;border-radius:16px;box-shadow:var(--shadow-lg);padding:12px;z-index:99}
  nav.top.open a{color:var(--ink)}
  .menu-btn{display:block}
  .callbar{display:block}
  .topbar .callpill{display:none}
  .hero{min-height:82vh}
  .cacti{display:none}
}
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto}
  .rv{opacity:1;transform:none}
}
