/* Rush Plumbing & Rooter — shared styles */
:root{
  --purple:#6A2C91; --purple-d:#4A1E68; --purple-dd:#34134c; --orange:#F7941D; --red:#ED1C24;
  --grad:linear-gradient(90deg,#ED1C24,#F7941D);
  --ink:#1C1726; --muted:#5C5566; --paper:#F7F5FA; --white:#fff; --line:#E6E1EC;
  --display:'Archivo',sans-serif; --body:'Inter',sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:132px}
body{margin:0;font-family:var(--body);color:var(--ink);background:var(--paper);font-size:17px;line-height:1.62}
h1,h2,h3,h4{font-family:var(--display);font-weight:800;line-height:1.06;margin:0 0 .4em;letter-spacing:-.5px}
h1{font-size:clamp(33px,6vw,56px);text-transform:uppercase}
h2{font-size:clamp(26px,4vw,40px);text-transform:uppercase}
h3{font-size:21px;font-weight:700}
p{margin:0 0 1em}
a{color:var(--purple);text-decoration:none}
img{max-width:100%}
.wrap{max-width:1120px;margin:0 auto;padding:0 22px}
.btn{display:inline-block;font-family:var(--display);font-weight:700;font-size:17px;padding:14px 26px;border:0;cursor:pointer;background:var(--grad);color:#fff;letter-spacing:.3px}
.btn:hover{filter:brightness(1.08)}
.btn.line{background:transparent;border:2px solid #fff;color:#fff;padding:12px 24px}
.btn.line:hover{background:#fff;color:var(--purple)}
.btn.purple{background:var(--purple)}
.btn.purple:hover{background:var(--purple-d);filter:none}
.swoosh{height:5px;background:var(--grad);width:84px;margin:0 0 18px;border-radius:3px}
.eyebrow{font-family:var(--display);font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--orange);font-size:14px;margin-bottom:8px}

/* emergency bar */
.ebar{position:sticky;top:0;z-index:50;background:var(--grad);color:#fff;text-align:center;font-family:var(--display);font-weight:700;font-size:15px;padding:8px 14px;letter-spacing:.3px}
.ebar a{color:#fff;text-decoration:underline;white-space:nowrap}

/* header + hover dropdown nav */
header{position:sticky;top:35px;z-index:40;background:#fff;border-bottom:1px solid var(--line);box-shadow:0 2px 12px rgba(74,30,104,.07)}
.bar{display:flex;align-items:center;justify-content:space-between;gap:18px;min-height:74px}
.logobox{flex:0 0 auto;display:inline-flex;align-items:center}
.logo{height:42px;width:auto;flex:0 0 auto;display:block;object-fit:contain}
nav.main{display:none}
nav.main ul{list-style:none;display:flex;align-items:center;gap:4px;margin:0;padding:0}
nav.main>ul>li{position:relative}
nav.main>ul>li>a{display:block;color:var(--ink);font-family:var(--display);font-weight:700;font-size:15px;text-transform:uppercase;letter-spacing:.2px;padding:10px 12px}
nav.main>ul>li>a:hover{color:var(--purple)}
nav.main .has>a::after{content:" \25BE";color:var(--orange)}
nav.main .drop{position:absolute;top:100%;left:0;min-width:240px;background:#fff;border:1px solid var(--line);box-shadow:0 12px 30px rgba(52,19,76,.16);padding:8px;opacity:0;visibility:hidden;transform:translateY(6px);transition:.15s;z-index:60}
nav.main li.has:hover .drop{opacity:1;visibility:visible;transform:translateY(0)}
nav.main .drop a{display:block;padding:9px 12px;font-family:var(--body);font-weight:500;font-size:15px;color:var(--ink);text-transform:none;letter-spacing:0}
nav.main .drop a:hover{background:var(--paper);color:var(--purple)}
nav.main .drop a.ddsep{border-top:1px solid var(--line);margin-top:6px;padding-top:12px;color:var(--purple);font-weight:700}
.hgroup{display:flex;align-items:center;gap:14px}
.hphone{font-family:var(--display);font-weight:800;font-size:19px;color:var(--purple);white-space:nowrap}
.menu-btn{display:inline-flex;background:var(--purple);color:#fff;border:0;font-family:var(--display);font-weight:700;font-size:15px;padding:10px 14px;cursor:pointer}
/* mobile menu */
.mobile{display:none;background:#fff;border-top:1px solid var(--line);padding:8px 0}
.mobile a{display:block;padding:11px 22px;font-family:var(--display);font-weight:700;text-transform:uppercase;font-size:15px;color:var(--ink)}
.mobile a:hover{background:var(--paper);color:var(--purple)}

/* $89.99 offer strip */
.offer{background:var(--purple)}
.offer-in{display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap;padding:13px 0;text-align:center;color:#fff}
.stamp{font-family:var(--display);font-weight:800;line-height:.85;border:3px solid var(--orange);color:#fff;padding:8px 14px;transform:rotate(-3deg)}
.stamp b{display:block;font-size:30px}.stamp span{font-size:12px;letter-spacing:2px}
.offer-txt{font-family:var(--display);font-weight:700;font-size:18px}
.offer-txt small{display:block;font-family:var(--body);font-weight:400;font-size:13px;color:#e6d8f0;text-transform:none}

/* hero */
.hero{position:relative;background:linear-gradient(135deg,#34134c,#6A2C91 70%);color:#fff;padding:52px 0 0;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% 20%,rgba(247,148,29,.18),transparent 45%);pointer-events:none}
.hero-grid{display:grid;grid-template-columns:1fr;gap:26px;position:relative;z-index:2;padding-bottom:56px}
.hero .tag{font-family:var(--display);font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--orange);font-size:15px;margin-bottom:12px}
.hero h1{margin-bottom:.3em}
.hero .lead{font-size:19px;color:#e9ddf3;max-width:48ch}
.hero .cta-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px}
.hero .mini{margin-top:18px;font-size:13.5px;color:#dcc9ec;font-family:var(--display);font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.qcard{background:#fff;color:var(--ink);padding:24px;box-shadow:0 18px 50px rgba(20,5,35,.35)}
.qcard h3{color:var(--purple)}
.qcard .big{font-family:var(--display);font-weight:800;font-size:40px;color:var(--purple);line-height:1}
.qcard form{display:grid;gap:10px;margin-top:14px}
.qcard input,.qcard select{font-family:var(--body);font-size:15px;padding:11px 12px;border:2px solid var(--line);width:100%}
.qcard .promise{font-family:var(--display);font-weight:700;color:var(--red);font-size:13px;text-transform:uppercase;letter-spacing:.4px;margin-top:4px}
/* wave divider */
.wave{display:block;width:100%;height:60px;position:relative;z-index:2;margin-bottom:-1px;vertical-align:top}
.wave.flip{transform:rotate(180deg)}
/* sections that end in a wave: kill bottom padding so the wave sits flush (no color strip) */
.wsec{padding-bottom:0}

/* client logo conveyer */
.logos{background:#fff;border-bottom:1px solid var(--line);padding:30px 0 32px;overflow:hidden}
.logos .lhead{text-align:center;font-family:var(--display);font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--muted);font-size:13px;margin-bottom:18px}
.marquee{position:relative;width:100%;overflow:hidden;padding:22px 0;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.mtrack{display:flex;align-items:center;gap:72px;width:max-content;animation:scrollx 50s linear infinite}
.mtrack img{height:84px;width:auto;object-fit:contain;transition:transform .2s ease;transform-origin:center}
.marquee:hover .mtrack{animation-play-state:paused}
.mtrack img:hover{transform:scale(1.15) rotate(-4deg)}
@keyframes scrollx{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.mtrack{animation:none;flex-wrap:wrap;justify-content:center;width:auto;gap:40px}}

/* sections */
section{padding:54px 0}
.tint{background:#fff}
.tintp{background:linear-gradient(180deg,#f1eaf7,#f7f5fa)}
/* solid dark purples so wave transitions match exactly */
.dark{background:var(--purple);color:#fff}
.darker{background:var(--purple-dd);color:#fff}
.dark h2,.darker h2{color:#fff}
.section-lead{font-size:19px;color:var(--muted);max-width:64ch}
.dark .section-lead,.darker .section-lead{color:#e3d4f0}

.grid2{display:grid;grid-template-columns:1fr;gap:18px;margin-top:24px}
.grid3{display:grid;grid-template-columns:1fr;gap:16px;margin-top:24px}
.grid4{display:grid;grid-template-columns:1fr;gap:16px;margin-top:24px}
.card{background:#fff;border:1px solid var(--line);padding:24px}
.card h3{color:var(--purple);margin-bottom:.3em}
.card ul{margin:.4em 0 0;padding-left:18px;color:var(--muted);font-size:15px}
.card .ico{font-family:var(--display);font-weight:800;color:var(--orange);font-size:13px;letter-spacing:1px}
/* service card image */
.svc{padding:0;overflow:hidden;display:flex;flex-direction:column}
.svc .thumb{display:block;width:100%;height:158px;object-fit:cover}
.svc .svc-body{padding:20px}
.svc .svc-body h3{margin-bottom:.3em}
/* service-page banner image */
.svc-banner{width:100%;height:240px;object-fit:cover;border:1px solid var(--line);margin-top:18px}
.svc-split{display:grid;grid-template-columns:1fr;gap:22px;align-items:center;margin-top:8px}
.svc-split img{width:100%;height:240px;object-fit:cover;border:1px solid var(--line)}
@media(min-width:820px){.svc-split{grid-template-columns:1fr 1fr}.svc-split.rev img{order:2}}

/* patriotic veterans accent (red/white/blue, complements purple+orange) */
/* brighter blue so red/white/blue pops on purple */
.usa-top{border-top:8px solid transparent;border-image:linear-gradient(90deg,#ED1C24 0 33%,#fff 33% 66%,#2f6bff 66%) 1}
.usa-tag{display:inline-flex;align-items:center;gap:12px;font-family:var(--display);font-weight:800;text-transform:uppercase;letter-spacing:2px;font-size:15px;color:#fff}
/* real US flag image */
.flag{display:inline-block;width:64px;height:auto;border:1px solid rgba(255,255,255,.6);box-shadow:0 2px 10px rgba(0,0,0,.3);vertical-align:middle;flex:none}
.usa-stripe{height:10px;width:240px;max-width:100%;margin:16px 0;border:1px solid rgba(255,255,255,.55);
  background:linear-gradient(90deg,#ED1C24 0 33%,#fff 33% 66%,#2f6bff 66%);box-shadow:0 2px 14px rgba(0,0,0,.25)}
/* veterans section: subtle photo behind, gradient fades to focus the text on the left */
.vbg{position:relative;background:#34134c;overflow:hidden}
.vbg::before{content:"";position:absolute;inset:0;background-image:url(img/veterans-bg.jpg);background-size:cover;background-position:right center}
.vbg::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,#34134c 0%,#34134c 48%,rgba(52,19,76,.4) 100%)}
.vbg>.wrap{position:relative;z-index:2}

/* trust bar */
.trust-in{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:24px 0}
.trust div{text-align:center}
.trust b{display:block;font-family:var(--display);font-weight:800;font-size:24px;color:var(--purple)}
.trust .star{color:var(--orange);font-size:15px;letter-spacing:1px}
.trust span{font-size:13px;color:var(--muted)}

/* stats */
.stats{display:flex;gap:14px;flex-wrap:wrap;margin-top:20px}
.stats div{background:var(--purple);color:#fff;padding:16px 22px;font-family:var(--display)}
.stats b{display:block;font-size:26px;font-weight:800}
.stats span{font-size:12px;letter-spacing:1px;text-transform:uppercase;color:#e6d8f0}

/* reviews */
.reviews{display:grid;grid-template-columns:1fr;gap:16px;margin-top:22px}
.review{background:#fff;border:1px solid var(--line);padding:20px}
.stars{color:var(--orange);letter-spacing:2px;font-size:18px}
.review cite{display:block;margin-top:8px;font-style:normal;font-weight:700;color:var(--purple)}

/* process */
.steps{display:grid;grid-template-columns:1fr;gap:14px;margin-top:24px;counter-reset:s}
.step{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.16);padding:18px 20px;display:flex;gap:14px;align-items:flex-start}
.step::before{counter-increment:s;content:counter(s);font-family:var(--display);font-weight:800;font-size:26px;color:var(--orange);line-height:1;min-width:28px}
.step b{font-family:var(--display);font-weight:700;display:block}
.step small{color:#e3d4f0;font-size:14px}

/* veterans highlight */
/* framed card with a subtle veterans photo, gradient fades left to keep text the focus */
.vetbox{color:#fff;padding:34px;position:relative;overflow:hidden;
  background:linear-gradient(90deg,#34134c 0%,#34134c 48%,rgba(52,19,76,.4) 100%),url(img/veterans-bg.jpg) right center/cover}
.vetbox>*{position:relative;z-index:2}
.vetbox h2{color:#fff}
.vetbox .section-lead{color:#ecdff6}

/* forms */
form.lead{display:grid;gap:12px;max-width:560px;margin-top:18px}
form.lead label{font-family:var(--display);font-weight:700;text-transform:uppercase;letter-spacing:.4px;font-size:13px;margin-bottom:-6px}
form.lead input,form.lead select,form.lead textarea{font-family:var(--body);font-size:16px;padding:13px 14px;border:2px solid var(--line);background:#fff;width:100%}
.dark form.lead label{color:#e6d8f0}
.promise{font-family:var(--display);font-weight:700;color:var(--orange);margin-top:12px;text-transform:uppercase;letter-spacing:.4px;font-size:14px}
/* CTA form + photo two-column */
.cta-split{display:grid;grid-template-columns:1fr;gap:28px;align-items:center;margin-top:18px}
.cta-split form.lead{margin-top:0}
.cta-photo{width:100%;height:100%;min-height:240px;object-fit:cover;border:4px solid #fff;box-shadow:0 14px 40px rgba(0,0,0,.3)}
@media(min-width:860px){.cta-split{grid-template-columns:1.1fr .9fr}}

/* areas */
.areas span{display:inline-block;background:#fff;border:1px solid var(--line);padding:6px 12px;font-size:15px;margin:0 6px 8px 0}

/* faq */
.faq details{background:#fff;border:1px solid var(--line);margin-top:12px}
.faq summary{font-family:var(--display);font-weight:700;font-size:18px;padding:16px 20px;cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:14px;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--red);font-size:26px;line-height:1}
.faq details[open] summary::after{content:"\2212"}
.faq .ans{padding:0 20px 20px;color:var(--muted);max-width:72ch}

/* blog */
.posts{display:grid;grid-template-columns:1fr;gap:18px;margin-top:24px}
.post{background:#fff;border:1px solid var(--line);padding:22px;display:flex;flex-direction:column}
.post .cat{font-family:var(--display);font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--orange);font-size:12px}
.post h3{margin:.3em 0}
.post a.more{margin-top:auto;font-family:var(--display);font-weight:700;color:var(--purple);text-transform:uppercase;font-size:14px;letter-spacing:.4px}
.article{max-width:760px;margin:0 auto}
.article h2{margin-top:1.4em}
.article .meta{color:var(--muted);font-size:15px;margin-bottom:1.4em}
.callout{background:var(--paper);border:1px solid var(--line);padding:18px 20px;margin:22px 0}

/* footer */
footer{background:#23103140;background:#2a1538;color:#cbbcd8;padding:40px 0 28px;font-size:15px}
footer .fgrid{display:grid;grid-template-columns:1fr;gap:24px}
footer b{color:#fff;font-family:var(--display);font-size:18px}
footer a{color:#e0d2ee}
footer .col h4{font-family:var(--display);color:#fff;text-transform:uppercase;font-size:14px;letter-spacing:.5px;margin:0 0 8px}
footer .col a{display:block;font-size:14px;margin-bottom:5px}
.fbar{border-top:1px solid #43285a;margin-top:24px;padding-top:16px;font-size:13px;color:#9a86ad}

@media(min-width:900px){
  nav.main{display:block}
  .menu-btn{display:none}
  .hero{padding:64px 0 0}
  .hero-grid{grid-template-columns:1.2fr .8fr;gap:44px;align-items:center}
  .trust-in{grid-template-columns:repeat(4,1fr)}
  .grid2{grid-template-columns:1fr 1fr}
  .grid3{grid-template-columns:repeat(3,1fr)}
  .grid4{grid-template-columns:repeat(4,1fr)}
  .reviews{grid-template-columns:repeat(3,1fr)}
  .steps{grid-template-columns:repeat(5,1fr)}
  .posts{grid-template-columns:repeat(3,1fr)}
  footer .fgrid{grid-template-columns:1.5fr 1fr 1fr 1fr}
  .mobile{display:none !important}
}
