/* ============================================================
   Denver Remediation Pros — stylesheet
   Static lead-gen site. No framework. ~15kb.
   ============================================================ */

:root{
  --navy:#0a3d7a;
  --navy-dark:#082f5e;
  --navy-light:#e7eff8;
  --cta:#e85a1a;
  --cta-dark:#c8490f;
  --text:#1c2530;
  --text-muted:#55606e;
  --bg:#ffffff;
  --bg-alt:#f4f7fb;
  --border:#dde3ec;
  --ink-footer:#0a1726;
  --radius:8px;
  --shadow:0 1px 4px rgba(10,38,74,0.06);
  --shadow-lg:0 8px 24px rgba(10,38,74,0.12);
  --max:1180px;
}

/* === Reset / base === */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;line-height:1.5;scroll-behavior:smooth}
body{
  margin:0;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
  font-size:17px;line-height:1.65;color:var(--text);background:var(--bg);
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--navy)}
strong{font-weight:700}

/* === Typography === */
h1,h2,h3,h4{line-height:1.2;margin-top:0;color:var(--text);font-weight:800;letter-spacing:-0.01em}
h1{font-size:clamp(28px,4.6vw,44px);margin-bottom:16px}
h2{font-size:clamp(23px,3.2vw,33px);margin:0 0 16px}
h3{font-size:20px;margin:0 0 10px}
h4{font-size:16px;margin:0 0 12px;text-transform:uppercase;letter-spacing:0.06em}
p{margin:0 0 16px}
ul,ol{padding-left:22px;margin:0 0 16px}
li{margin-bottom:8px}

/* === Layout === */
.container{width:100%;max-width:var(--max);margin:0 auto;padding:0 22px}
.section{padding:62px 0}
.section-sm{padding:42px 0}
.section-alt{background:var(--bg-alt)}
.section-navy{background:var(--navy);color:#eaf1fa}
.section-navy h2,.section-navy h3{color:#fff}
.section-navy a{color:#fff}
.lede{font-size:19px;color:var(--text-muted);max-width:64ch}
.section-navy .lede{color:#cdddef}
.center{text-align:center}
.measure{max-width:70ch}
.mt-0{margin-top:0}.mb-0{margin-bottom:0}

.grid{display:grid;gap:22px}
.grid-2{grid-template-columns:repeat(auto-fit,minmax(290px,1fr))}
.grid-3{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}
.grid-4{grid-template-columns:repeat(auto-fit,minmax(210px,1fr))}

/* === Skip link === */
.skip-link{position:absolute;left:-9999px;top:0;background:var(--navy);color:#fff;padding:10px 16px;z-index:200}
.skip-link:focus{left:8px;top:8px}

/* === Header === */
.site-header{position:sticky;top:0;background:#fff;border-bottom:1px solid var(--border);z-index:100}
.header-inner{display:flex;align-items:center;gap:18px;min-height:70px}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
.logo-mark{
  display:inline-flex;align-items:center;justify-content:center;
  width:42px;height:42px;border-radius:9px;
  background:var(--navy);color:#fff;font-weight:800;font-size:14px;letter-spacing:0.02em;
}
.logo-text{font-weight:800;font-size:18px;color:var(--navy);line-height:1.15;letter-spacing:-0.01em}
.primary-nav{display:none;margin-left:auto;gap:6px}
.primary-nav a{
  text-decoration:none;font-weight:600;color:var(--text);
  padding:9px 12px;border-radius:7px;font-size:15px;
}
.primary-nav a:hover{background:var(--navy-light);color:var(--navy)}
.btn-call-header{
  display:none;align-items:center;gap:8px;
  background:var(--cta);color:#fff;padding:11px 17px;border-radius:8px;
  text-decoration:none;font-weight:700;font-size:15px;white-space:nowrap;
}
.btn-call-header:hover{background:var(--cta-dark)}
.nav-toggle{
  margin-left:auto;display:flex;flex-direction:column;justify-content:center;gap:5px;
  width:46px;height:46px;background:var(--navy-light);border:none;border-radius:8px;cursor:pointer;
}
.nav-toggle span{display:block;width:22px;height:2.5px;background:var(--navy);margin:0 auto;border-radius:2px}
@media(min-width:1000px){
  .nav-toggle{display:none}
  .primary-nav{display:flex}
  .btn-call-header{display:inline-flex}
}
/* mobile nav drawer */
.mobile-nav{display:none;border-top:1px solid var(--border);background:#fff}
.mobile-nav.open{display:block}
.mobile-nav a{
  display:block;padding:14px 22px;text-decoration:none;font-weight:600;
  color:var(--text);border-bottom:1px solid var(--border);
}
.mobile-nav a.mobile-call{background:var(--cta);color:#fff;text-align:center;border-bottom:none}
@media(min-width:1000px){.mobile-nav{display:none!important}}

/* === Buttons === */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:15px 26px;border-radius:8px;text-decoration:none;font-weight:700;
  font-size:16px;min-height:52px;cursor:pointer;border:2px solid transparent;
  text-align:center;line-height:1.25;transition:background .15s,transform .05s;
}
.btn:active{transform:translateY(1px)}
.btn-cta{background:var(--cta);color:#fff;border-color:var(--cta)}
.btn-cta:hover{background:var(--cta-dark);border-color:var(--cta-dark)}
.btn-navy{background:var(--navy);color:#fff;border-color:var(--navy)}
.btn-navy:hover{background:var(--navy-dark)}
.btn-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,0.6)}
.btn-outline:hover{background:rgba(255,255,255,0.12)}
.btn-outline-navy{background:#fff;color:var(--navy);border-color:var(--navy)}
.btn-outline-navy:hover{background:var(--navy-light)}
.btn-block{display:flex;width:100%}
.btn-row{display:flex;flex-wrap:wrap;gap:14px;margin-top:8px}

/* === Hero === */
.hero{background:linear-gradient(160deg,var(--navy) 0%,var(--navy-dark) 100%);color:#fff;padding:54px 0 60px}
.hero h1{color:#fff}
.hero-grid{display:grid;gap:34px;grid-template-columns:1fr}
@media(min-width:920px){.hero-grid{grid-template-columns:1.05fr .95fr;align-items:start;gap:44px}}
.hero-lead{font-size:18px;color:#d3e2f3;margin-bottom:22px;max-width:56ch}
.hero-eyebrow{
  display:inline-block;font-size:13px;font-weight:700;letter-spacing:0.09em;
  text-transform:uppercase;color:#7fb0e6;margin-bottom:14px;
}
.hero .btn-row{margin-bottom:22px}
.hero-call-btn{background:var(--cta);color:#fff;border-color:var(--cta)}
.hero-call-btn:hover{background:var(--cta-dark)}

/* trust row */
.trust-row{display:flex;flex-wrap:wrap;gap:10px 18px;margin:0;padding:0;list-style:none}
.trust-row li{
  display:flex;align-items:center;gap:7px;font-size:14px;font-weight:600;
  color:#dce8f6;margin:0;
}
.trust-row li::before{content:"✔";color:#5fd07f;font-weight:800}
.section-alt .trust-row li,.section .trust-row li{color:var(--text-muted)}

/* === Form card === */
.form-card{
  background:#fff;border-radius:10px;padding:26px;box-shadow:var(--shadow-lg);
  color:var(--text);border-top:4px solid var(--cta);
}
.form-card h2{font-size:21px;margin-bottom:5px;color:var(--navy)}
.form-card .form-intro{font-size:13.5px;color:var(--text-muted);margin-bottom:18px}
.form-field{margin-bottom:13px}
.form-row{display:grid;gap:13px;grid-template-columns:1fr}
@media(min-width:470px){.form-row{grid-template-columns:1fr 1fr}}
label{display:block;font-weight:700;margin-bottom:6px;font-size:13.5px;color:var(--text)}
input[type=text],input[type=tel],input[type=email],select,textarea{
  width:100%;padding:12px 13px;border:2px solid var(--border);border-radius:8px;
  font-size:16px;font-family:inherit;background:#fff;color:var(--text);
}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--navy)}
textarea{min-height:110px;resize:vertical}
.btn-submit{
  display:block;width:100%;padding:15px;border-radius:8px;background:var(--cta);
  color:#fff;font-weight:800;font-size:16.5px;border:none;cursor:pointer;
  min-height:54px;margin-top:6px;
}
.btn-submit:hover{background:var(--cta-dark)}
.form-fine{font-size:11.5px;color:var(--text-muted);margin:11px 0 0;line-height:1.45}
.honeypot{position:absolute!important;left:-9999px;width:1px;height:1px;overflow:hidden}

/* === Trust strip (under hero) === */
.proof-strip{background:var(--navy-dark);color:#cdddef}
.proof-strip .container{
  display:flex;flex-wrap:wrap;justify-content:center;gap:14px 36px;
  padding:18px 22px;font-size:14.5px;font-weight:600;
}
.proof-strip span{display:flex;align-items:center;gap:8px}

/* === Cards === */
.card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:26px;box-shadow:var(--shadow);
}
.card h3{color:var(--navy)}
.card-link{display:flex;flex-direction:column;text-decoration:none;color:inherit}
.card-link:hover{border-color:var(--navy);box-shadow:var(--shadow-lg)}
.card .card-cta{margin-top:auto;color:var(--cta);font-weight:700;font-size:15px}
.card-icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:52px;height:52px;border-radius:10px;background:var(--navy-light);
  font-size:25px;margin-bottom:14px;
}

/* === Steps === */
.steps{counter-reset:step;list-style:none;padding:0;margin:0;display:grid;gap:18px}
.steps li{
  position:relative;padding:22px 22px 22px 70px;background:#fff;
  border:1px solid var(--border);border-radius:var(--radius);margin:0;box-shadow:var(--shadow);
}
.steps li::before{
  counter-increment:step;content:counter(step);
  position:absolute;left:18px;top:20px;width:38px;height:38px;
  background:var(--navy);color:#fff;border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-weight:800;font-size:18px;
}
.steps li h3{margin-bottom:5px;font-size:18px}
.steps li p{margin:0;color:var(--text-muted);font-size:15.5px}

/* === Feature list with checks === */
.check-list{list-style:none;padding:0;margin:0 0 16px}
.check-list li{position:relative;padding-left:30px;margin-bottom:11px}
.check-list li::before{
  content:"✔";position:absolute;left:0;top:1px;
  color:var(--cta);font-weight:800;font-size:16px;
}

/* === Callout box === */
.callout{
  background:var(--navy-light);border-left:5px solid var(--navy);
  border-radius:8px;padding:20px 22px;margin:22px 0;
}
.callout p:last-child{margin-bottom:0}
.callout-cta{background:#fff7f2;border-left-color:var(--cta)}

/* === FAQ === */
.faq-item{border-bottom:1px solid var(--border);padding:4px 0}
.faq-item summary{
  font-weight:700;font-size:17.5px;cursor:pointer;list-style:none;
  padding:16px 34px 16px 0;position:relative;color:var(--navy);
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:"+";position:absolute;right:4px;top:13px;font-size:26px;
  color:var(--cta);font-weight:400;line-height:1;
}
.faq-item[open] summary::after{content:"–"}
.faq-item .faq-body{padding:0 0 18px;color:var(--text-muted)}
.faq-item .faq-body p:last-child{margin-bottom:0}

/* === City / link lists === */
.area-list{list-style:none;padding:0;margin:0;display:grid;gap:10px;
  grid-template-columns:repeat(auto-fit,minmax(190px,1fr))}
.area-list a{
  display:block;padding:13px 16px;background:#fff;border:1px solid var(--border);
  border-radius:8px;text-decoration:none;font-weight:700;color:var(--navy);
}
.area-list a:hover{background:var(--navy-light);border-color:var(--navy)}
.area-list a span{display:block;font-weight:500;font-size:13px;color:var(--text-muted);margin-top:2px}
.cols-2{columns:2;column-gap:34px;max-width:560px}
.cols-2 li{break-inside:avoid}

/* === Breadcrumbs === */
.breadcrumbs{font-size:13.5px;padding:14px 0;color:var(--text-muted)}
.breadcrumbs ol{list-style:none;display:flex;flex-wrap:wrap;gap:6px;padding:0;margin:0}
.breadcrumbs li{margin:0}
.breadcrumbs li+li::before{content:"›";margin-right:6px;color:var(--border)}
.breadcrumbs a{color:var(--navy);text-decoration:none}
.breadcrumbs a:hover{text-decoration:underline}

/* === Inline CTA band === */
.cta-band{background:var(--cta);color:#fff;text-align:center}
.cta-band h2{color:#fff}
.cta-band p{color:#ffe6d8;max-width:60ch;margin-left:auto;margin-right:auto}
.cta-band .btn-row{justify-content:center}

/* === Related links === */
.related-links{list-style:none;padding:0;margin:0;display:grid;gap:10px}
.related-links a{font-weight:700;color:var(--navy)}

/* === Footer === */
.site-footer{background:var(--ink-footer);color:#aeb9c6;padding:50px 0 0;margin-top:10px}
.footer-inner{display:grid;gap:30px;grid-template-columns:repeat(auto-fit,minmax(210px,1fr))}
.site-footer h3{color:#fff;font-size:18px;margin-bottom:12px}
.site-footer h4{color:#fff;font-size:13px;margin-bottom:14px}
.site-footer p{font-size:14.5px;line-height:1.6;margin-bottom:12px}
.footer-col{display:flex;flex-direction:column}
.footer-col a{color:#aeb9c6;text-decoration:none;font-size:14.5px;padding:4px 0}
.footer-col nav a,.site-footer nav a{display:block}
.footer-col a:hover{color:#fff}
.footer-col.footer-about a{color:#fff;font-weight:700}
.footer-disclosure{margin-top:36px;padding-top:24px;border-top:1px solid #25323f}
.footer-disclosure p{font-size:12.5px;color:#7c8896;line-height:1.6;margin:0}
.footer-bottom{padding:20px 22px;margin-top:14px;border-top:1px solid #25323f;
  text-align:center;color:#69757f;font-size:13px}
.footer-bottom p{margin:0}

/* === Sticky mobile call === */
.btn-sticky-call{
  display:flex;align-items:center;justify-content:center;gap:8px;
  position:fixed;left:12px;right:12px;bottom:12px;z-index:90;
  background:var(--cta);color:#fff;padding:15px;border-radius:10px;
  text-decoration:none;font-weight:800;font-size:16px;
  box-shadow:0 6px 20px rgba(0,0,0,0.28);
}
@media(min-width:1000px){.btn-sticky-call{display:none}}
@media(max-width:999px){body{padding-bottom:78px}}

/* === Generic prose page (privacy/terms) === */
.prose h2{margin-top:36px}
.prose h3{margin-top:24px}
.prose ul{margin-bottom:18px}

/* === Accessibility === */
:focus-visible{outline:3px solid var(--cta);outline-offset:2px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *{transition:none!important}
}

/* === Print === */
@media print{
  .site-header,.site-footer,.btn-sticky-call,.form-card,.cta-band,.nav-toggle,.mobile-nav{display:none}
  body{padding-bottom:0}
  .hero{background:none;color:#000}
  .hero h1,.section-navy h2{color:#000}
}

/* === Small-screen tweaks === */
@media(max-width:600px){
  .section{padding:46px 0}
  .hero{padding:40px 0 46px}
  .form-card{padding:22px}
  .cols-2{columns:1}
}
