
:root{
  --navy:#1F2933;
  --steel:#4B5563;
  --orange:#F97316;
  --bg:#F3F4F6;
  --white:#fff;
  --border:#d9dde3;
  --shadow:0 12px 32px rgba(31,41,51,.08);
  --radius:22px;
  --max:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,Arial,Helvetica,sans-serif;
  line-height:1.65;
  color:var(--navy);
  background:var(--bg);
}
img{max-width:100%;display:block;border-radius:18px}
a{color:var(--navy);text-decoration:none}
a:hover{text-decoration:underline}
.container{width:min(var(--max),calc(100% - 2rem));margin:0 auto}
.narrow{max-width:860px}
.site-header{position:sticky;top:0;z-index:20;background:rgba(243,244,246,.97);backdrop-filter:blur(8px);border-bottom:1px solid rgba(31,41,51,.08)}
.topbar{display:flex;justify-content:space-between;align-items:center;padding:1rem 0}
.brand{display:flex;align-items:center;gap:.9rem;font-weight:700}
.brand span{display:block;font-size:.9rem;color:var(--steel);font-weight:500}
.mobile-call,.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.4rem;
  background:var(--orange);color:#fff;padding:.9rem 1.2rem;border-radius:999px;
  font-weight:700;border:none;cursor:pointer;box-shadow:var(--shadow)
}
.mobile-call:hover,.btn:hover{text-decoration:none;filter:brightness(.98)}
.btn-secondary{background:var(--white);color:var(--navy);border:1px solid var(--border);box-shadow:none}
.main-nav{border-top:1px solid rgba(31,41,51,.05)}
.nav-wrap{display:flex;gap:1rem;flex-wrap:wrap;padding:.8rem 0}
.main-nav a{padding:.35rem .7rem;border-radius:999px;color:var(--steel);font-weight:600}
.main-nav a.active,.main-nav a:hover{background:#fff;color:var(--navy);text-decoration:none}
.hero{padding:3.5rem 0 2rem}
.hero-grid,.two-col,.form-wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:2rem;align-items:center}
.hero h1{font-size:clamp(2rem,4vw,3.5rem);line-height:1.08;margin:.2rem 0 1rem}
.lead{font-size:1.08rem;color:var(--steel)}
.eyebrow{letter-spacing:.12em;text-transform:uppercase;color:var(--orange);font-size:.82rem;font-weight:800;margin:0 0 .7rem}
.cta-row{display:flex;gap:.9rem;flex-wrap:wrap;margin:1.4rem 0}
.trust-row,.checklist,.link-list{padding-left:1.1rem}
.trust-row{display:grid;gap:.5rem;color:var(--steel)}
.section{padding:1.2rem 0 3rem}
.section.alt{background:linear-gradient(180deg, rgba(255,255,255,.6), rgba(243,244,246,.8))}
.section-heading{max-width:860px;margin-bottom:1rem}
.section h2{font-size:clamp(1.5rem,3vw,2.2rem);margin:0 0 .9rem}
.section h3{margin:.2rem 0 .5rem}
.cards,.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.card,.info-card,.image-card,details{
  background:var(--white);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)
}
.card,.info-card{padding:1.2rem}
.info-card + .info-card{margin-top:1rem}
.stack{display:block}
.card.accent,.accent .container{position:relative}
.accent{padding:1rem 0}
.accent .container{background:linear-gradient(135deg, rgba(249,115,22,.09), rgba(31,41,51,.02));border:1px solid rgba(249,115,22,.25);border-radius:var(--radius);padding:2rem}
.big li{margin:.6rem 0}
.inline-links,.chips{display:flex;gap:.75rem;flex-wrap:wrap}
.inline-links a,.chips a{padding:.65rem .95rem;background:#fff;border:1px solid var(--border);border-radius:999px}
.price-table{width:100%;border-collapse:collapse}
.price-table th,.price-table td{padding:.75rem;border-bottom:1px solid var(--border);text-align:left}
.request-form{display:grid;grid-template-columns:1fr 1fr;gap:1rem;background:#fff;padding:1.2rem;border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow)}
.request-form label{display:flex;flex-direction:column;font-weight:600;gap:.35rem;color:var(--navy)}
.request-form input,.request-form textarea,.request-form select{
  width:100%;padding:.85rem 1rem;border-radius:14px;border:1px solid var(--border);font:inherit;background:#fff
}
.request-form textarea,.request-form label:nth-child(4),.request-form .btn,.request-form .fine-print{grid-column:1/-1}
.fine-print{font-size:.92rem;color:var(--steel);margin:0}
.faq-section details{padding:1rem 1.1rem;margin-bottom:.8rem}
details summary{cursor:pointer;font-weight:700}
.service-band{padding:0 0 5rem}
.service-band .container{background:var(--navy);color:#fff;border-radius:var(--radius);padding:2rem}
.service-band a{color:#fff;border-color:rgba(255,255,255,.18);background:rgba(255,255,255,.08)}
.site-footer{background:var(--navy);color:#fff;padding:3rem 0 6rem}
.site-footer a{color:#fff}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2rem}
.footer-grid ul{margin:0;padding-left:1rem}
.footer-bottom{padding-top:1rem;border-top:1px solid rgba(255,255,255,.12);margin-top:1rem}
.sticky-cta{
  position:fixed;left:0;right:0;bottom:0;z-index:25;background:rgba(31,41,51,.96);
  display:flex;justify-content:center;gap:1rem;padding:.9rem 1rem;box-shadow:0 -10px 24px rgba(0,0,0,.12)
}
.sticky-cta a{
  display:inline-flex;align-items:center;justify-content:center;min-width:180px;padding:.9rem 1rem;border-radius:999px;
  background:var(--orange);color:#fff;font-weight:800
}
.sticky-cta a:last-child{background:#fff;color:var(--navy)}
.article{max-width:900px}
.link-list li{margin:.45rem 0}
@media (max-width: 900px){
  .hero-grid,.two-col,.form-wrap,.footer-grid,.cards,.steps,.request-form{grid-template-columns:1fr}
  .nav-wrap{overflow:auto;white-space:nowrap;flex-wrap:nowrap;padding-bottom:.9rem}
  .site-footer{padding-bottom:7rem}
}


/* Patch: tighter image treatment and no-form contact layout */
.hero-image{
  padding:.5rem;
  max-width:420px;
  margin-inline:auto;
  overflow:hidden;
}
.hero-image img{
  width:100%;
  aspect-ratio:4 / 5;
  object-fit:cover;
  object-position:center;
  border-radius:20px;
  display:block;
}
.two-col,
.split-layout,
.grid-two,
.contact-panel{
  display:grid;
  gap:1.5rem;
  align-items:start;
}
.contact-panel{
  grid-template-columns:1.2fr .8fr;
}
.quick-contact .info-card{
  height:100%;
}
.quick-contact .inline-links{
  margin-top:1rem;
}
.request-form,
.contact-form,
form{
  display:none !important;
}
@media (max-width: 900px){
  .hero-image{
    max-width:340px;
  }
  .contact-panel{
    grid-template-columns:1fr;
  }
}


.contact-panel{
  grid-template-columns:minmax(0, 1.35fr) minmax(290px, .95fr);
  gap:1.25rem;
}
.contact-copy .eyebrow{
  margin-bottom:.4rem;
}
.compact-contact p{
  margin:.55rem 0;
}
.compact-contact{
  padding:1.15rem 1.15rem 1rem;
}
.compact-contact h3{
  margin-bottom:.85rem;
}
.quick-contact .container{
  max-width:1080px;
}
.quick-contact .big{
  padding-left:1.2rem;
}
.quick-contact .big li{
  margin:.5rem 0;
}
@media (max-width: 900px){
  .contact-panel{
    grid-template-columns:1fr;
  }
}



/* Final polish patch */
.cta-row .btn + .btn.btn-secondary{box-shadow:none}
.contact-polish{
  display:grid;
  grid-template-columns:minmax(0,1.35fr) minmax(280px,.95fr);
  gap:1.25rem;
  align-items:stretch;
}
.contact-aside{
  display:grid;
  gap:1rem;
}
.soft-panel{
  background:linear-gradient(180deg, rgba(249,115,22,.06), rgba(255,255,255,.9));
  border:1px solid rgba(249,115,22,.18);
}
.quick-contact .contact-copy{
  padding:1.5rem 1.5rem 1.35rem;
}
.quick-contact .contact-copy h2,
.contact-polish h2{
  max-width:18ch;
}
.compact-contact{
  min-height:unset;
}
.compact-contact a{
  overflow-wrap:anywhere;
}
.site-footer section:first-child a[href^="mailto:"]{
  display:inline-block;
  margin-top:.2rem;
}
@media (max-width: 900px){
  .contact-polish{
    grid-template-columns:1fr;
  }
}


/* Republish polish fix */
.contact-polish,
.contact-strip{
  display:grid;
  grid-template-columns:minmax(0,1.2fr) minmax(0,.95fr) minmax(280px,.8fr);
  gap:1.25rem;
  align-items:start;
}
.contact-strip{
  padding:1.4rem;
}
.contact-strip-copy,
.contact-strip-points,
.contact-strip-meta{
  min-width:0;
}
.contact-strip-copy h2,
.contact-strip-points h3,
.contact-polish h2,
.quick-contact .contact-copy h2{
  max-width:none;
}
.contact-strip-copy .inline-links{
  margin-top:1rem;
}
.contact-strip-points{
  background:rgba(255,255,255,.7);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:1rem 1rem .9rem;
}
.contact-strip-points h3{
  margin-bottom:.75rem;
}
.contact-strip-points .big{
  padding-left:1.15rem;
  margin:0;
}
.contact-strip-points .big li{
  margin:.55rem 0;
}
.contact-strip-meta{
  display:grid;
  gap:1rem;
}
.contact-strip .compact-contact{
  height:auto;
}
.quick-contact .container{
  max-width:1120px;
}
.quick-contact .soft-panel,
.section .soft-panel{
  padding:1.4rem;
}
@media (max-width: 980px){
  .contact-polish,
  .contact-strip{
    grid-template-columns:1fr;
  }
  .contact-strip{
    padding:1.1rem;
  }
}


/* Final revision: corrected contact CTA layout */
.contact-final{
  display:grid;
  grid-template-columns:minmax(0,1.55fr) minmax(290px,.95fr);
  gap:1.4rem;
  align-items:start;
  padding:1.4rem;
}
.contact-final-copy,
.contact-final-side{
  min-width:0;
}
.contact-final-copy h2{
  max-width:16ch;
}
.contact-final-copy .big{
  padding-left:1.2rem;
  margin:.95rem 0 0;
}
.contact-final-copy .big li{
  margin:.5rem 0;
}
.contact-final-copy .inline-links{
  margin-top:1.1rem;
  display:flex;
  flex-wrap:wrap;
  gap:.85rem;
}
.contact-final-side{
  display:grid;
  gap:1rem;
}
.contact-final .compact-contact{
  height:auto;
}
.contact-final .compact-contact p{
  margin:.55rem 0;
}
.contact-strip{
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
}
.contact-strip-copy{
  grid-column:1;
  grid-row:1;
}
.contact-strip-points{
  grid-column:1;
  grid-row:2;
}
.contact-strip-meta{
  grid-column:2;
  grid-row:1 / span 2;
}
@media (max-width: 980px){
  .contact-final,
  .contact-strip{
    grid-template-columns:1fr;
  }
  .contact-strip-copy,
  .contact-strip-points,
  .contact-strip-meta{
    grid-column:auto;
    grid-row:auto;
  }
}


/* Final revision patch: CTA visibility, cleaner section labels, navigation grids */
.inline-links .btn{
  background:var(--orange);
  color:#fff;
  border:none;
  box-shadow:var(--shadow);
}
.inline-links .btn.btn-secondary{
  background:#fff;
  color:var(--navy);
  border:1px solid var(--border);
  box-shadow:none;
}
.inline-links .btn:hover{ text-decoration:none; }
.services-grid .card,
.problem-nav-grid .card,
.emergency-nav-grid .card{
  display:block;
  font-weight:700;
}
.problem-nav-grid,
.emergency-nav-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1rem;
}
@media (max-width: 900px){
  .problem-nav-grid,
  .emergency-nav-grid{
    grid-template-columns:1fr;
  }
}
