/* ===========================================================
   DRAIN PROS BEDFORD — BRAND SYSTEM
   Steel / Paper neutrals · Signal Orange CTA · Amber trust · Field Green positive
   Barlow Condensed (display) + Barlow (body)
   No rounded corners, no gradients, no soft shadows — industrial, functional.
=========================================================== */

:root{
  --steel-dark:#1C2128;
  --steel:#2A323C;
  --steel-line:#3A4350;
  --paper:#F4F1EA;
  --paper-dim:#E9E4D7;
  --signal-orange:#E84E1B;
  --signal-orange-dark:#C23F13;
  --amber:#F5A623;
  --field-green:#2D7D4F;
  --ink:#181B1F;
  --ink-soft:#4A4F57;
  --on-dark:#F4F1EA;
  --on-dark-soft:#AEB4BC;
  --max:1180px;
}

*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:'Barlow',Arial,sans-serif;
  color:var(--ink);
  background:var(--paper);
  font-size:17px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
ul{margin:0;padding:0;list-style:none;}
h1,h2,h3,h4{
  font-family:'Barlow Condensed',Arial Narrow,sans-serif;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:0.01em;
  line-height:1.05;
  margin:0 0 0.5em;
  color:var(--ink);
}
h1{font-size:clamp(2.2rem,5vw,3.6rem);}
h2{font-size:clamp(1.7rem,3.6vw,2.5rem);}
h3{font-size:1.4rem;}
p{margin:0 0 1em;}
.container{max-width:var(--max);margin:0 auto;padding:0 24px;}
.eyebrow{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:0.16em;
  font-size:0.82rem;
  color:var(--signal-orange-dark);
  display:block;
  margin-bottom:0.6em;
}
.on-dark .eyebrow{color:var(--amber);}

/* ---------- Skip link / focus ---------- */
.skip-link{position:absolute;left:-9999px;top:0;background:var(--signal-orange);color:#fff;padding:10px 16px;z-index:200;}
.skip-link:focus{left:8px;top:8px;}
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible{
  outline:3px solid var(--amber);outline-offset:2px;
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:'Barlow Condensed',sans-serif;
  font-weight:800;text-transform:uppercase;letter-spacing:0.04em;
  font-size:1.05rem;
  padding:14px 26px;
  border:2px solid var(--signal-orange);
  background:var(--signal-orange);
  color:#fff;
  border-radius:0;
  cursor:pointer;
  transition:background .15s ease,color .15s ease,transform .1s ease;
}
.btn:hover{background:var(--signal-orange-dark);border-color:var(--signal-orange-dark);}
.btn:active{transform:translateY(1px);}
.btn-outline{
  background:transparent;color:var(--on-dark);border-color:var(--on-dark-soft);
}
.btn-outline:hover{border-color:var(--amber);color:var(--amber);background:transparent;}
.btn-block{width:100%;}
.btn-lg{font-size:1.3rem;padding:18px 30px;}

/* ---------- Hazard divider — signature element ---------- */
.hazard{
  height:10px;width:100%;
  background:repeating-linear-gradient(135deg,var(--signal-orange) 0 18px,var(--steel-dark) 18px 36px);
}
.hazard-thin{height:6px;}

/* ---------- Header ---------- */
.site-header{
  background:var(--steel-dark);
  position:sticky;top:0;z-index:100;
  border-bottom:3px solid var(--signal-orange);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 24px;max-width:var(--max);margin:0 auto;
}
.logo{display:flex;align-items:center;gap:10px;color:#fff;font-family:'Barlow Condensed',sans-serif;}
.logo-mark{width:38px;height:38px;flex:none;}
.logo-text{font-weight:900;text-transform:uppercase;font-size:1.25rem;line-height:1;}
.logo-text small{display:block;font-size:0.62rem;letter-spacing:0.22em;font-weight:700;color:var(--amber);}
.logo-text strong{color:var(--signal-orange);}

.main-nav{display:flex;align-items:center;gap:28px;}
.main-nav ul{display:flex;gap:22px;}
.main-nav a{
  font-family:'Barlow Condensed',sans-serif;font-weight:700;text-transform:uppercase;
  letter-spacing:0.05em;font-size:0.95rem;color:var(--on-dark-soft);
  padding:6px 2px;border-bottom:2px solid transparent;
}
.main-nav a:hover,.main-nav a.active{color:#fff;border-bottom-color:var(--signal-orange);}

.header-call{
  display:flex;align-items:center;gap:10px;
}
.header-phone{
  font-family:'Barlow Condensed',sans-serif;font-weight:900;font-size:1.3rem;color:#fff;
  white-space:nowrap;
}
.header-phone span{display:block;font-size:0.6rem;letter-spacing:0.18em;font-weight:700;color:var(--amber);text-transform:uppercase;}

.nav-toggle-label{display:none;color:#fff;font-size:1.6rem;cursor:pointer;}
#nav-toggle{display:none;}

@media(max-width:900px){
  .main-nav ul{
    position:fixed;top:0;right:0;height:100vh;width:78%;max-width:320px;
    background:var(--steel-dark);flex-direction:column;gap:0;
    padding:90px 28px 28px;transform:translateX(100%);transition:transform .25s ease;
    border-left:3px solid var(--signal-orange);
  }
  .main-nav ul li{border-bottom:1px solid var(--steel-line);width:100%;}
  .main-nav ul a{display:block;padding:16px 0;}
  #nav-toggle:checked ~ .main-nav ul{transform:translateX(0);}
  .nav-toggle-label{display:block;}
  .header-phone{font-size:1.05rem;}
}

/* ---------- Sticky mobile call bar ---------- */
.mobile-call-bar{
  display:none;position:fixed;left:0;right:0;bottom:0;z-index:120;
  background:var(--signal-orange);
}
.mobile-call-bar a{
  display:flex;align-items:center;justify-content:center;gap:10px;
  padding:14px;color:#fff;font-family:'Barlow Condensed',sans-serif;
  font-weight:900;text-transform:uppercase;letter-spacing:0.05em;font-size:1.1rem;
}
@media(max-width:900px){
  .mobile-call-bar{display:block;}
  body{padding-bottom:54px;}
}

/* ---------- Hero ---------- */
.hero{
  background:var(--steel-dark);color:var(--on-dark);
  padding:64px 0 56px;position:relative;
}
.hero-grid{display:grid;grid-template-columns:1.1fr 0.9fr;gap:48px;align-items:center;}
.hero h1{color:#fff;}
.hero-sub{font-size:1.15rem;color:var(--on-dark-soft);max-width:48ch;margin-bottom:1.6em;}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:28px;}
.hero-trust{display:flex;gap:22px;flex-wrap:wrap;}
.hero-trust .badge{margin:0;}

.hero-art{display:flex;align-items:center;justify-content:center;}

@media(max-width:880px){
  .hero-grid{grid-template-columns:1fr;}
  .hero-art{order:-1;max-width:220px;margin:0 auto 8px;}
}

/* ---------- Trust badges (stamped plate signature) ---------- */
.badge{
  display:flex;align-items:center;gap:10px;
  font-family:'Barlow Condensed',sans-serif;font-weight:700;text-transform:uppercase;
  font-size:0.85rem;letter-spacing:0.03em;
  padding:10px 14px;
  position:relative;
  border:1.5px solid var(--steel-line);
  color:var(--on-dark);
}
.badge::before,.badge::after{
  content:"";position:absolute;width:5px;height:5px;background:var(--amber);
  top:4px;left:4px;
}
.badge::after{left:auto;right:4px;}
.badge-icon{color:var(--amber);font-size:1.1rem;line-height:1;}
.on-light .badge{border-color:#D8D2C2;color:var(--ink);}
.on-light .badge::before,.on-light .badge::after{background:var(--field-green);}

/* ---------- Sections ---------- */
.section{padding:64px 0;}
.section-dark{background:var(--steel-dark);color:var(--on-dark);}
.section-dark h2,.section-dark h3{color:#fff;}
.section-tight{padding:44px 0;}
.section-head{max-width:62ch;margin-bottom:36px;}
.section-head p{color:var(--ink-soft);font-size:1.08rem;}
.on-dark p{color:var(--on-dark-soft);}

/* ---------- Service grid ---------- */
.service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.service-card{
  background:#fff;border:1px solid #DDD7C7;border-top:4px solid var(--signal-orange);
  padding:26px;display:flex;flex-direction:column;gap:10px;
}
.service-card h3{font-size:1.3rem;margin-bottom:2px;}
.service-card p{color:var(--ink-soft);font-size:0.97rem;margin-bottom:6px;flex:1;}
.service-card .link-more{
  font-family:'Barlow Condensed',sans-serif;font-weight:800;text-transform:uppercase;
  letter-spacing:0.04em;color:var(--signal-orange-dark);font-size:0.92rem;
}
.service-card .link-more:hover{text-decoration:underline;}
@media(max-width:880px){.service-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:600px){.service-grid{grid-template-columns:1fr;}}

/* ---------- Two column content blocks (service page anatomy) ---------- */
.content-block{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;}
.content-block.reverse .content-art{order:2;}
.content-art{
  background:var(--paper-dim);border:1px solid #DDD7C7;
  aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;
}
@media(max-width:780px){
  .content-block,.content-block.reverse{grid-template-columns:1fr;}
  .content-block.reverse .content-art{order:0;}
}

/* ---------- Process / numbered steps (genuine sequence) ---------- */
.steps{counter-reset:step;display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.step{position:relative;padding:24px 18px 18px;background:#fff;border:1px solid #DDD7C7;border-left:4px solid var(--field-green);}
.step::before{
  counter-increment:step;content:counter(step);
  font-family:'Barlow Condensed',sans-serif;font-weight:900;font-size:1.6rem;
  color:var(--field-green);display:block;margin-bottom:8px;
}
@media(max-width:880px){.steps{grid-template-columns:1fr 1fr;}}
@media(max-width:560px){.steps{grid-template-columns:1fr;}}

/* ---------- Areas ---------- */
.areas-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.area-card{
  background:#fff;border:1px solid #DDD7C7;padding:18px 20px;
  display:flex;justify-content:space-between;align-items:center;
}
.area-card a{font-family:'Barlow Condensed',sans-serif;font-weight:800;text-transform:uppercase;letter-spacing:0.03em;}
.area-card .pin{color:var(--signal-orange-dark);font-size:0.85rem;}
@media(max-width:780px){.areas-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:520px){.areas-grid{grid-template-columns:1fr;}}

/* ---------- FAQ ---------- */
.faq-item{border-bottom:1px solid #DDD7C7;padding:18px 0;}
.faq-item summary{
  font-family:'Barlow Condensed',sans-serif;font-weight:800;font-size:1.15rem;
  cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:16px;
}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary::after{content:"+";color:var(--signal-orange-dark);font-size:1.4rem;font-weight:900;}
.faq-item[open] summary::after{content:"–";}
.faq-item p{margin-top:12px;color:var(--ink-soft);}

/* ---------- Testimonials ---------- */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.testi-card{background:#fff;border:1px solid #DDD7C7;padding:24px;border-top:4px solid var(--amber);}
.testi-card p{font-style:italic;color:var(--ink-soft);}
.testi-name{font-family:'Barlow Condensed',sans-serif;font-weight:800;text-transform:uppercase;color:var(--ink);margin-top:10px;}
.stars{color:var(--amber);letter-spacing:2px;margin-bottom:8px;}
@media(max-width:880px){.testi-grid{grid-template-columns:1fr;}}

/* ---------- CTA banner ---------- */
.cta-banner{
  background:var(--steel-dark);color:#fff;text-align:center;padding:56px 24px;
  border-top:6px solid var(--signal-orange);
}
.cta-banner h2{color:#fff;}
.cta-banner p{color:var(--on-dark-soft);max-width:54ch;margin:0 auto 26px;}

/* ---------- Forms ---------- */
.form-grid{display:grid;gap:16px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
label{font-family:'Barlow Condensed',sans-serif;font-weight:700;text-transform:uppercase;font-size:0.82rem;letter-spacing:0.04em;display:block;margin-bottom:6px;color:var(--ink-soft);}
input,textarea,select{
  width:100%;padding:12px 14px;border:1.5px solid #C9C2AE;background:#fff;
  font-family:'Barlow',sans-serif;font-size:1rem;border-radius:0;
}
textarea{resize:vertical;min-height:120px;}
.form-note{font-size:0.86rem;color:var(--ink-soft);margin-top:10px;}
@media(max-width:600px){.form-row{grid-template-columns:1fr;}}

/* ---------- Footer ---------- */
.site-footer{background:var(--steel-dark);color:var(--on-dark-soft);padding:52px 0 0;}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px;padding-bottom:36px;}
.footer-col h4{color:#fff;font-size:1rem;margin-bottom:14px;letter-spacing:0.05em;}
.footer-col ul li{margin-bottom:9px;}
.footer-col a:hover{color:var(--amber);}
.footer-phone{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-size:1.5rem;color:#fff;}
.footer-bottom{border-top:1px solid var(--steel-line);padding:20px 0;font-size:0.84rem;}
.footer-bottom .container{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;}
.disclaimer{
  background:#171B20;padding:20px 0;font-size:0.82rem;color:#7C828B;line-height:1.6;
}
@media(max-width:880px){.footer-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:560px){.footer-grid{grid-template-columns:1fr;}}

/* ---------- Breadcrumb ---------- */
.breadcrumb{background:var(--paper-dim);padding:12px 0;font-size:0.85rem;}
.breadcrumb a{color:var(--ink-soft);}
.breadcrumb a:hover{color:var(--signal-orange-dark);}
.breadcrumb span{margin:0 6px;color:#B7B09B;}

/* ---------- Misc ---------- */
.text-center{text-align:center;}
.mt-0{margin-top:0;}
.list-check li{position:relative;padding-left:26px;margin-bottom:10px;}
.list-check li::before{content:"✓";position:absolute;left:0;color:var(--field-green);font-weight:900;}
.price-note{background:var(--paper-dim);border-left:4px solid var(--amber);padding:18px 20px;margin:24px 0;}
.price-note strong{color:var(--ink);}
