/* ============================================================
   Pay Much-Le$$ Cesspool — design system
   "Industrial dispatch": teal base (#387075), hi-vis amber.
   ============================================================ */
:root{
  --ink:#173F3D;        /* darkest teal (footer / dark sections) */
  --ink-2:#1E4F4C;      /* raised teal panels */
  --water:#387075;      /* brand teal (primary) */
  --water-dk:#2C5B58;   /* darker teal for text/links on light */
  --water-lt:#6FA6A2;   /* light teal accent */
  --amber:#FFB100;      /* hi-vis CTA */
  --amber-dk:#E69A00;
  --coupon-yellow:#FFE000;
  --paper:#F4F7F6;      /* page bg */
  --paper-2:#FFFFFF;
  --line:#DCE6E4;       /* hairlines on light */
  --line-dk:#2E605C;    /* hairlines on dark */
  --slate:#566B68;      /* muted text */
  --ink-text:#16302E;   /* body text on light */
  --green:#1FA66A;      /* trust/success */
  --r:14px;
  --r-sm:9px;
  --maxw:1180px;
  --shadow:0 18px 50px -22px rgba(8,28,26,.45);
  --shadow-sm:0 6px 20px -10px rgba(8,28,26,.35);
  --display:"Archivo",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --body:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --mono:"Spline Sans Mono","JetBrains Mono",ui-monospace,Menlo,monospace;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{overflow-x:hidden;max-width:100%}
body{
  margin:0;font-family:var(--body);color:var(--ink-text);background:var(--paper);
  font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:var(--water-dk);text-decoration:none}
h1,h2,h3,h4{font-family:var(--display);color:var(--ink);line-height:1.08;margin:0;font-weight:800;letter-spacing:-.01em}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.eyebrow{font-family:var(--mono);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--water-dk);font-weight:600}
.eyebrow.on-dark{color:var(--amber)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.55em;font-family:var(--display);font-weight:700;
  letter-spacing:.01em;border-radius:var(--r-sm);padding:.85em 1.35em;font-size:1.02rem;cursor:pointer;
  border:2px solid transparent;transition:transform .15s ease,box-shadow .15s ease,background .15s ease;white-space:nowrap}
.btn:focus-visible{outline:3px solid var(--amber);outline-offset:2px}
.btn-amber{background:var(--amber);color:#241700;box-shadow:0 10px 24px -10px rgba(255,177,0,.7)}
.btn-amber:hover{background:var(--amber-dk);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.35)}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.08)}
.btn-water{background:var(--water);color:#fff}
.btn-water:hover{background:var(--water-dk);transform:translateY(-2px)}
.btn-lg{font-size:1.12rem;padding:1em 1.6em}
.btn svg{width:1.15em;height:1.15em;flex:0 0 auto}
.more svg{width:1em;height:1em;flex:0 0 auto}

/* ---------- Top utility bar ---------- */
.util{background:var(--ink);color:#cfe0ee;font-family:var(--mono);font-size:.78rem;letter-spacing:.04em}
.util .wrap{display:flex;justify-content:space-between;align-items:center;gap:14px;padding-top:8px;padding-bottom:8px;flex-wrap:wrap}
.util b{color:#fff;font-weight:600}
.util .dot{color:var(--green)}
.util a{color:#cfe0ee}

/* ---------- Header ---------- */
.site-head{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line)}
.site-head .wrap{display:flex;align-items:center;justify-content:space-between;gap:18px;padding-top:13px;padding-bottom:13px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--display);font-weight:900;color:var(--ink);
  font-size:1.18rem;letter-spacing:-.02em;line-height:1}
.brand .mark{width:40px;height:40px;border-radius:9px;background:linear-gradient(135deg,var(--water),var(--ink));
  display:grid;place-items:center;flex:0 0 auto;box-shadow:var(--shadow-sm)}
.brand .mark svg{width:23px;height:23px}
.brand .less{color:var(--amber-dk)}
.brand small{display:block;font-family:var(--mono);font-weight:500;font-size:.6rem;letter-spacing:.18em;
  color:var(--slate);text-transform:uppercase;margin-top:3px}
.nav{display:flex;align-items:center;gap:6px}
.nav a{font-family:var(--display);font-weight:600;font-size:.97rem;color:var(--ink-text);padding:.5em .7em;border-radius:7px}
.nav a:hover{background:var(--paper);color:var(--water-dk)}
.nav a.active{color:var(--water-dk)}
.head-cta{display:flex;align-items:center;gap:12px}
.head-phone{font-family:var(--display);font-weight:800;color:var(--ink);font-size:1.05rem;white-space:nowrap}
.head-phone span{display:block;font-family:var(--mono);font-size:.58rem;letter-spacing:.16em;color:var(--green);text-transform:uppercase}
.burger{display:none;background:none;border:1.5px solid var(--line);border-radius:8px;width:44px;height:42px;cursor:pointer;align-items:center;justify-content:center}
.burger span{display:block;width:20px;height:2px;background:var(--ink);position:relative}
.burger span::before,.burger span::after{content:"";position:absolute;left:0;width:20px;height:2px;background:var(--ink)}
.burger span::before{top:-6px}.burger span::after{top:6px}

/* ---------- Hero ---------- */
.hero{position:relative;background:
   radial-gradient(1100px 520px at 78% -8%,rgba(111,166,162,.30),transparent 60%),
   linear-gradient(180deg,#3C797E 0%,#2C5C59 100%);
  color:#eaf6f3;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;opacity:.5;
  background-image:
   repeating-linear-gradient(115deg,rgba(143,196,191,.06) 0 2px,transparent 2px 26px),
   radial-gradient(circle at 18% 88%,rgba(255,177,0,.10),transparent 40%);
  pointer-events:none}
.hero .wrap{position:relative;display:grid;grid-template-columns:1.12fr .88fr;gap:46px;
  padding-top:66px;padding-bottom:74px;align-items:center}
.hero h1{color:#fff;font-size:clamp(2.25rem,4.4vw,3.5rem);font-weight:900;letter-spacing:-.025em;margin:.5rem 0 .9rem}
.hero h1 .hl{color:var(--amber)}
.hero p.lead{font-size:1.14rem;color:#bcd3e6;max-width:34em;margin:0 0 1.7rem}
.hero-ctas{display:flex;gap:13px;flex-wrap:wrap;margin-bottom:1.8rem}
.hero-trust{display:flex;gap:26px;flex-wrap:wrap;font-family:var(--mono);font-size:.8rem;color:#9fbdd6}
.hero-trust b{color:#fff;font-family:var(--display);font-size:1.35rem;font-weight:800;display:block;letter-spacing:-.02em}
.hero-trust .lab{letter-spacing:.06em}

/* Signature: dispatch ticket */
.ticket{position:relative;background:var(--paper-2);border-radius:16px;box-shadow:var(--shadow);
  padding:0;overflow:hidden;color:var(--ink-text)}
.ticket .tk-photo{width:100%;height:210px;object-fit:contain;background:#0E2E2C;padding:8px}
.ticket .tk-head{display:flex;justify-content:space-between;align-items:center;
  background:var(--ink);color:#fff;padding:11px 18px;font-family:var(--mono);font-size:.72rem;letter-spacing:.12em}
.ticket .tk-head .live{display:inline-flex;align-items:center;gap:7px;color:#8de8b6}
.ticket .tk-head .live i{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 0 0 rgba(25,160,106,.6);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(25,160,106,.55)}70%{box-shadow:0 0 0 9px rgba(25,160,106,0)}100%{box-shadow:0 0 0 0 rgba(25,160,106,0)}}
.ticket .tk-body{padding:16px 18px 20px}
.tk-row{display:flex;justify-content:space-between;gap:12px;padding:9px 0;border-bottom:1px dashed var(--line);
  font-family:var(--mono);font-size:.82rem}
.tk-row:last-child{border-bottom:0}
.tk-row .k{color:var(--slate);letter-spacing:.04em}
.tk-row .v{color:var(--ink);font-weight:600;text-align:right}
.tk-row .v.amber{color:var(--amber-dk)}
.tk-perf{height:14px;background:
  radial-gradient(circle at center,transparent 6px,var(--paper-2) 6px) ;
  position:relative}
.ticket .tk-cta{display:block;text-align:center;background:var(--amber);color:#241700;font-family:var(--display);
  font-weight:800;padding:14px;font-size:1.08rem;letter-spacing:.01em}
.ticket .tk-cta:hover{background:var(--amber-dk)}
.ticket .tk-cta svg{width:1.05em;height:1.05em;vertical-align:-3px;margin-right:4px}

/* ---------- Trust strip ---------- */
.trust{background:var(--ink-2);border-top:1px solid var(--line-dk);border-bottom:1px solid var(--line-dk)}
.trust .wrap{display:flex;flex-wrap:wrap;gap:14px 34px;justify-content:center;align-items:center;
  padding-top:18px;padding-bottom:18px;font-family:var(--mono);font-size:.82rem;color:#bcd3e6}
.trust .ti{display:inline-flex;align-items:center;gap:9px}
.trust .ti svg{width:18px;height:18px;color:var(--amber);flex:0 0 auto}

/* ---------- Sections ---------- */
section{padding:76px 0}
.sec-head{max-width:64ch;margin-bottom:38px}
.sec-head h2{font-size:clamp(1.8rem,3.2vw,2.5rem);margin:.5rem 0 .6rem}
.sec-head p{color:var(--slate);font-size:1.08rem;margin:0}
.bg-paper2{background:var(--paper-2)}
.bg-ink{background:var(--ink);color:#dceaf6}
.bg-ink h2,.bg-ink h3{color:#fff}
.bg-ink .sec-head p{color:#a9c4da}

/* Services catalog */
.cat{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.card{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r);padding:26px 24px;
  box-shadow:var(--shadow-sm);transition:transform .18s ease,box-shadow .18s ease,border-color .18s}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--water-lt)}
.card .ic{width:46px;height:46px;border-radius:11px;background:linear-gradient(135deg,rgba(56,112,117,.16),rgba(56,112,117,.05));
  display:grid;place-items:center;margin-bottom:15px}
.card .ic svg{width:25px;height:25px;color:var(--water-dk)}
.card h3{font-size:1.22rem;margin-bottom:9px}
.card p{color:var(--slate);font-size:.97rem;margin:0 0 12px}
.card ul{margin:0;padding:0;list-style:none;font-size:.92rem}
.card ul li{padding:5px 0 5px 22px;position:relative;color:var(--ink-text);border-bottom:1px solid var(--paper)}
.card ul li:last-child{border-bottom:0}
.card ul li::before{content:"";position:absolute;left:2px;top:13px;width:9px;height:9px;border-radius:2px;
  background:var(--amber)}
.card .more{font-family:var(--display);font-weight:700;color:var(--water-dk);font-size:.92rem;
  display:inline-flex;align-items:center;gap:6px;margin-top:14px}

/* Two-col content */
.split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.split img{border-radius:var(--r);box-shadow:var(--shadow);width:100%;object-fit:cover}
.prose h2{font-size:clamp(1.7rem,3vw,2.3rem);margin-bottom:.7rem}
.prose h3{font-size:1.3rem;margin:1.6rem 0 .5rem;color:var(--ink)}
.prose p{color:var(--ink-text);margin:0 0 1rem}
.bg-ink .prose p{color:#cde0ef}
.prose a{color:var(--water-dk);font-weight:600;border-bottom:1px solid var(--water-lt)}
.bg-ink .prose a{color:var(--amber);border-color:rgba(255,177,0,.5)}

/* Symptoms list */
.symptoms{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin:8px 0 0;padding:0;list-style:none}
.symptoms li{display:flex;align-items:flex-start;gap:11px;background:var(--paper);border:1px solid var(--line);
  border-radius:10px;padding:13px 15px;font-weight:600;font-size:.97rem}
.bg-ink .symptoms li{background:var(--ink-2);border-color:var(--line-dk);color:#eaf3fb}
.symptoms li svg{width:19px;height:19px;color:var(--amber-dk);flex:0 0 auto;margin-top:2px}
.bg-ink .symptoms li svg{color:var(--amber)}

/* Coupon */
.coupon{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center;
  background:linear-gradient(135deg,var(--ink),var(--ink-2));border-radius:20px;padding:40px;
  color:#eaf3fb;box-shadow:var(--shadow);position:relative;overflow:hidden}
.coupon::after{content:"SAVE";position:absolute;top:18px;right:-42px;transform:rotate(45deg);
  background:var(--amber);color:#241700;font-family:var(--display);font-weight:900;letter-spacing:.18em;
  padding:7px 60px;font-size:.8rem}
.coupon h2{color:#fff;font-size:clamp(1.7rem,3vw,2.4rem)}
.coupon p{color:#bcd3e6}
.coupon .cp-img{border-radius:12px;box-shadow:var(--shadow);border:5px solid #fff;background:#fff}
.coupon .note{font-family:var(--mono);font-size:.75rem;color:#9fbdd6;margin-top:10px}

/* Steps (real sequence — numbered legitimately) */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;counter-reset:s}
.step{position:relative;background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r);padding:24px}
.step .n{font-family:var(--mono);font-size:.78rem;color:var(--water-dk);letter-spacing:.1em;font-weight:600}
.step h3{font-size:1.12rem;margin:8px 0 6px}
.step p{color:var(--slate);font-size:.93rem;margin:0}

/* Areas */
.areas-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:4px 18px}
.areas-grid a{font-size:.92rem;padding:6px 0;color:var(--ink-text);border-bottom:1px solid var(--line);
  display:flex;justify-content:space-between;gap:8px}
.areas-grid a:hover{color:var(--water-dk)}
.areas-grid a .z{font-family:var(--mono);font-size:.72rem;color:var(--slate)}
.bg-ink .areas-grid a{color:#cfe0ee;border-color:var(--line-dk)}
.bg-ink .areas-grid a:hover{color:var(--amber)}
.bg-ink .areas-grid a .z{color:#7f9ab3}

/* CTA band */
.cta-band{background:linear-gradient(120deg,var(--amber),#ffce5c);color:#241700;text-align:center}
.cta-band h2{color:#241700;font-size:clamp(1.8rem,3.4vw,2.7rem);margin-bottom:.5rem}
.cta-band p{color:#5a4500;font-size:1.1rem;max-width:48ch;margin:0 auto 1.5rem;font-weight:500}
.cta-band .btn-ink{background:var(--ink);color:#fff}
.cta-band .btn-ink:hover{background:#08131e;transform:translateY(-2px)}

/* Breadcrumb */
.crumb{background:var(--paper-2);border-bottom:1px solid var(--line)}
.crumb .wrap{padding-top:14px;padding-bottom:14px;font-family:var(--mono);font-size:.78rem;color:var(--slate)}
.crumb a{color:var(--water-dk)}
.crumb .sep{margin:0 8px;color:var(--line)}

/* Inner hero (sub pages) */
.subhero{background:radial-gradient(900px 400px at 80% -20%,rgba(111,166,162,.30),transparent 60%),linear-gradient(180deg,#3C797E,#2A5A57);color:#fff}
.subhero .wrap{padding-top:52px;padding-bottom:52px}
.subhero .eyebrow{color:var(--amber)}
.subhero h1{color:#fff;font-size:clamp(2rem,4vw,3rem);margin:.5rem 0 .6rem;max-width:18ch}
.subhero p{color:#bcd3e6;max-width:46ch;font-size:1.1rem;margin:0 0 1.4rem}
.subhero .hero-ctas{margin-bottom:0}

/* Service rail (sub pages sidebar) */
.layout{display:grid;grid-template-columns:1fr 320px;gap:46px;align-items:start}
.rail{position:sticky;top:96px;display:flex;flex-direction:column;gap:18px}
.rail .panel{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r);padding:22px;box-shadow:var(--shadow-sm)}
.rail .panel h3{font-size:1.05rem;margin-bottom:12px}
.rail ul{list-style:none;margin:0;padding:0;font-size:.92rem}
.rail ul li{padding:7px 0 7px 20px;position:relative;border-bottom:1px solid var(--paper);color:var(--ink-text)}
.rail ul li::before{content:"";position:absolute;left:0;top:14px;width:8px;height:8px;border-radius:2px;background:var(--water)}
.rail .panel.call{background:linear-gradient(135deg,var(--ink),var(--ink-2));color:#fff;text-align:center}
.rail .panel.call h3{color:#fff}
.rail .panel.call .ph{font-family:var(--display);font-size:1.5rem;font-weight:900;color:var(--amber);margin:6px 0 12px;display:block}
.rail .panel.call p{color:#bcd3e6;font-size:.88rem;margin:0 0 14px}

/* Footer */
.foot{background:var(--ink);color:#a9c4da;padding-top:60px}
.foot .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:36px;padding-bottom:40px;border-bottom:1px solid var(--line-dk)}
.foot h4{color:#fff;font-size:1.05rem;margin-bottom:14px;font-family:var(--display)}
.foot a{color:#a9c4da}
.foot a:hover{color:#fff}
.foot ul{list-style:none;margin:0;padding:0}
.foot ul li{padding:5px 0;font-size:.94rem}
.foot .fbrand{font-family:var(--display);font-weight:900;color:#fff;font-size:1.3rem;margin-bottom:10px}
.foot .fbrand .less{color:var(--amber)}
.foot .meta{font-size:.92rem;line-height:1.8}
.foot .meta b{color:#fff}
.foot .badge{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:.74rem;
  background:var(--ink-2);border:1px solid var(--line-dk);border-radius:8px;padding:7px 11px;margin:5px 6px 0 0;color:#cfe0ee}
.foot .badge svg{width:15px;height:15px;color:var(--amber)}
.foot-areas{padding:28px 0;border-bottom:1px solid var(--line-dk)}
.foot-areas .lab{font-family:var(--mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:#7f9ab3;margin-bottom:12px}
.foot-areas .links{display:flex;flex-wrap:wrap;gap:4px 14px;font-size:.86rem}
.foot-areas .links a{color:#9fbdd6}
.foot-areas .links a:hover{color:var(--amber)}
.foot-bottom{padding:20px 0 30px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;
  font-size:.82rem;color:#7f9ab3;font-family:var(--mono)}

/* Floating mobile call */
.float-call{display:none;position:fixed;left:0;right:0;bottom:0;z-index:60;background:var(--amber);
  color:#241700;text-align:center;font-family:var(--display);font-weight:800;padding:14px;font-size:1.1rem;
  box-shadow:0 -8px 26px -12px rgba(8,22,36,.6)}
.float-call svg{width:1.05em;height:1.05em;vertical-align:-3px;margin-right:5px}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .hero .wrap{grid-template-columns:1fr;gap:34px;padding-top:46px;padding-bottom:54px}
  .cat{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr 1fr}
  .layout{grid-template-columns:1fr}
  .rail{position:static;flex-direction:row;flex-wrap:wrap}
  .rail .panel{flex:1 1 240px}
  .foot .cols{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  body{font-size:16px}
  .nav,.head-phone{display:none}
  .burger{display:flex}
  .site-head .wrap{gap:10px;padding-top:11px;padding-bottom:11px}
  .brand{font-size:1.04rem;gap:9px}
  .brand .mark{width:34px;height:34px}
  .brand .mark svg{width:19px;height:19px}
  .brand small{font-size:.52rem;letter-spacing:.12em;margin-top:2px}
  .head-cta{gap:8px}
  .head-cta .btn{padding:.62em .8em;font-size:.92rem}
  .head-cta .btn svg{width:1.25em;height:1.25em}
  .nav.open{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;
    background:#fff;border-bottom:1px solid var(--line);padding:8px 22px 16px;box-shadow:var(--shadow)}
  .nav.open a{padding:.8em 0;border-bottom:1px solid var(--paper);font-size:1.05rem}
  .split{grid-template-columns:1fr;gap:28px}
  .coupon{grid-template-columns:1fr;padding:28px}
  .symptoms{grid-template-columns:1fr}
  .cat{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .util .wrap{justify-content:center;font-size:.72rem;gap:6px 16px;text-align:center}
  section{padding:54px 0}
  .float-call{display:block}
  body{padding-bottom:54px}
  .foot .cols{grid-template-columns:1fr}
}
@media(max-width:430px){
  .brand small{display:none}
  .head-cta .btn .ctxt{display:none}      /* icon-only call button on small phones */
  .head-cta .btn{padding:.62em .8em}
  .head-cta .btn svg{margin:0}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
}

/* ---------- Native coupon cards (sharp, on-brand) ---------- */
.coupon-band{background:var(--water)}            /* #387075 brand teal */
.coupon-band .sec-head h2,.coupon-band .sec-head .eyebrow{color:#fff}
.coupon-band .sec-head p{color:#dff0ee}
.coupons{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.coupons.two{grid-template-columns:repeat(2,1fr);max-width:760px;margin:0 auto}
.coupon-card{background:#fff;border:3px solid var(--coupon-yellow);border-radius:12px;
  padding:26px 22px 24px;text-align:center;display:flex;flex-direction:column;
  box-shadow:0 14px 34px -18px rgba(0,0,0,.5)}
.coupon-card .tag{width:40px;height:40px;margin:0 auto 14px;color:var(--water-dk)}
.coupon-card .tag svg{width:40px;height:40px}
.coupon-card h3{font-size:1.18rem;color:var(--water-dk);line-height:1.18;margin-bottom:6px;min-height:2.4em;
  display:flex;align-items:center;justify-content:center}
.coupon-card .price{font-family:var(--display);font-weight:900;color:var(--water-dk);
  font-size:2.1rem;letter-spacing:-.02em;line-height:1.05;margin:10px 0 14px}
.coupon-card .price small{display:block;font-size:1.25rem;font-weight:800}
.coupon-card .fine{font-size:.78rem;color:#6a7d7a;line-height:1.5;margin:0 0 18px;flex:1 0 auto}
.coupon-card .use{display:block;background:var(--ink-2);color:var(--coupon-yellow);
  font-family:var(--display);font-weight:800;letter-spacing:.02em;border-radius:7px;
  padding:13px 14px;font-size:1rem;transition:background .15s ease,transform .15s ease}
.coupon-card .use:hover{background:var(--ink);transform:translateY(-2px)}
.coupon-note{text-align:center;font-family:var(--mono);font-size:.8rem;color:#dff0ee;margin-top:22px}
.coupon-band .coupon-note a{color:#fff;text-decoration:underline}

@media(max-width:980px){.coupons{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.coupons,.coupons.two{grid-template-columns:1fr}.coupon-card h3{min-height:0}}

/* ---------- Footer legal/marketing line ---------- */
.foot-legal{padding:16px 0 30px;border-top:1px solid var(--line-dk);font-size:.77rem;color:#8fb3af;
  font-family:var(--mono);line-height:1.7;text-align:center}
.foot-legal a{color:#cfe7e3;text-decoration:underline}
.foot-legal .sepbar{color:var(--line-dk);margin:0 8px}

/* ---------- Print: coupons ---------- */
@media print{
  .util,.site-head,.float-call,.foot,.cta-band,.subhero .hero-ctas,.crumb,.trust{display:none!important}
  body{background:#fff;padding:0}
  .coupon-band{background:#fff!important}
  .coupon-band .sec-head h2,.coupon-band .sec-head .eyebrow{color:#000!important}
  .coupon-card{break-inside:avoid;box-shadow:none;border-color:#000}
  .coupons{grid-template-columns:repeat(2,1fr)!important}
  section{padding:14px 0!important}
}

/* ---------- Feature photo (Residential / Commercial pages) ---------- */
.feature-photo{width:100%;aspect-ratio:3/2;object-fit:cover;border-radius:14px;
  box-shadow:var(--shadow);margin-bottom:26px;display:block}
