
:root{
  --primary:#000000;
  --accent:#B32028;
  --highlight:#F29E23;
  --text:#291C1D;
  --light:#F5F5F5;
  --white:#ffffff;
  --border:#e7dcc8;
  --soft:#fff7ea;
  --shadow:0 12px 30px rgba(0,0,0,.10);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Arial,Helvetica,sans-serif;color:var(--text);background:var(--light);line-height:1.6}
img{max-width:100%;display:block;border-radius:20px}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
.wrap{width:min(1120px,92%);margin:0 auto}
.narrow{width:min(820px,100%)}
.topbar{background:var(--primary);color:#e5e7eb;font-size:.92rem}
.topbar-inner{display:flex;justify-content:space-between;gap:1rem;padding:.55rem 0;flex-wrap:wrap}
.site-header{background:#fff;position:sticky;top:0;z-index:40;box-shadow:0 2px 14px rgba(0,0,0,.06)}
.nav-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 0}
.logo{display:flex;align-items:center;gap:.8rem;color:var(--primary)}
.logo:hover{text-decoration:none}
.logo-mark{width:52px;height:52px;border-radius:14px;background:var(--primary);color:#fff;display:grid;place-items:center;font-weight:700}
.logo-text{display:flex;flex-direction:column}
.logo-text small{color:#6b6464}
.main-nav{display:flex;gap:1rem;flex-wrap:wrap}
.main-nav a{color:var(--primary);font-weight:600}
.header-cta{display:flex;gap:.7rem;flex-wrap:wrap}
.btn{display:inline-block;background:var(--accent);color:#fff;padding:.9rem 1.15rem;border-radius:999px;font-weight:700;border:2px solid var(--accent)}
.btn:hover{text-decoration:none;opacity:.95}
.btn-outline{background:#fff;color:var(--accent)}
.hero{padding:2.5rem 0 2rem;background:linear-gradient(180deg,#fff 0%,#eef2f7 100%)}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:2rem;align-items:center}
.eyebrow{letter-spacing:.08em;text-transform:uppercase;color:var(--accent);font-weight:700;font-size:.8rem}
h1,h2,h3{line-height:1.2;color:var(--primary);margin:.3rem 0 .8rem}
h1{font-size:clamp(2rem,5vw,3.3rem)}
h2{font-size:clamp(1.45rem,3vw,2.2rem)}
h3{font-size:1.2rem}
.lead{font-size:1.1rem;color:#334155}
.hero-actions,.cta-band-actions{display:flex;gap:.8rem;flex-wrap:wrap;margin:1.3rem 0}
.trust-list,.check-grid,.area-list,.related-links ul,.footer-grid ul{padding-left:1.2rem}
.trust-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.5rem 1.2rem}
.breadcrumb{font-size:.92rem;padding:1rem 0 .25rem;color:#6b6464}
.self-check,.service-cards,.content-section,.split-section,.problems,.areas,.faq-section,.related-links,.service-area-band,.cta-band{padding:2.3rem 0}
.self-check{background:#fff}
.check-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.8rem 1rem}
.card-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem}
.card,.feature-panel{background:#fff;border:1px solid var(--border);border-radius:24px;padding:1.2rem;box-shadow:0 8px 24px rgba(31,42,68,.06)}
.split-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:1.2rem;align-items:start}
.content-section ol,.content-section ul{padding-left:1.25rem}
.faq-section details{background:#fff;border:1px solid var(--border);border-radius:18px;padding:1rem 1.1rem;margin-bottom:.8rem}
.faq-section summary{font-weight:700;cursor:pointer;color:var(--primary)}
.service-area-band{background:#eef2f7}
.cta-band{background:var(--primary);color:#fff}
.cta-band h2,.cta-band p{color:#fff}
.cta-band-inner{display:flex;justify-content:space-between;gap:1rem;align-items:center}
.site-footer{background:#111827;color:#e5e7eb;padding:2.2rem 0 1rem}
.site-footer a{color:#fff}
.footer-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr 1fr;gap:1.2rem}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:1rem;padding-top:1rem;font-size:.92rem;color:#cbd5e1}
.sticky-cta{position:fixed;left:0;right:0;bottom:0;background:#111827;display:none;grid-template-columns:1fr 1fr;z-index:50}
.sticky-cta a{padding:1rem;text-align:center;color:#fff;font-weight:700}
.sticky-cta a:first-child{background:#374151}
.sticky-cta a:last-child{background:var(--accent)}
@media (max-width:960px){
  .hero-grid,.split-grid,.footer-grid,.cta-band-inner{grid-template-columns:1fr;display:grid}
  .card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .nav-row{flex-direction:column;align-items:flex-start}
  .header-cta{width:100%}
}
@media (max-width:720px){
  .main-nav{gap:.75rem}
  .trust-list,.check-grid,.card-grid{grid-template-columns:1fr}
  .sticky-cta{display:grid}
  body{padding-bottom:64px}
  .hero{padding-top:1.5rem}
}


.quick-paths{padding:1rem 0 2.3rem;background:#eef2f7}
.quick-paths-head{max-width:860px;margin:0 0 1.2rem}
.quick-path-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
.quick-path-card ul{padding-left:1.2rem;margin:.8rem 0 1rem}
.quick-path-card li{margin:.35rem 0}
.text-link{font-weight:700}
@media (max-width:960px){
  .quick-path-grid{grid-template-columns:1fr}
}


.quick-paths{padding:1.5rem 0 0;background:#fff}
.quick-path-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}
.path-card{display:block;background:#fff;border:1px solid #d7dbe2;border-radius:16px;padding:1rem 1rem 1.1rem;text-decoration:none;color:#1f1f1f;box-shadow:0 8px 20px rgba(0,0,0,.04)}
.path-card strong{display:block;font-size:1.05rem;margin-bottom:.35rem;color:#1f1f1f}
.path-card span{display:block;color:#4b5563;line-height:1.5}
.related-links ul{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.5rem 1.25rem;padding-left:1.1rem}
.cta-band-actions .btn{min-width:210px;text-align:center}
@media (max-width: 900px){
  .quick-path-grid,.related-links ul{grid-template-columns:1fr}
}


/* Santa Maria Roofing Co brand refresh */
body{
  background:linear-gradient(180deg,#ffffff 0%, var(--light) 100%);
  color:var(--text);
}
a{color:var(--accent)}
a:hover{color:var(--highlight);text-decoration:none}
.site-header{
  background:rgba(255,255,255,.96);
  backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid rgba(0,0,0,.05);
  box-shadow:0 8px 24px rgba(0,0,0,.06);
}
.topbar{
  background:var(--primary);
  color:#f8f5ef;
}
.logo{
  color:var(--primary);
}
.logo-image-wrap{
  width:68px;
  height:68px;
  border-radius:18px;
  background:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:6px;
  box-shadow:0 8px 20px rgba(0,0,0,.12);
  border:2px solid rgba(242,158,35,.35);
}
.logo-image{
  width:100%;
  height:100%;
  object-fit:contain;
  border-radius:12px;
}
.logo-text strong{
  color:var(--primary);
  letter-spacing:.01em;
}
.logo-text small{
  color:#6b6464;
}
.main-nav a{
  color:var(--primary);
  position:relative;
}
.main-nav a:hover{
  color:var(--accent);
}
.main-nav a::after{
  content:"";
  position:absolute;
  left:0;
  bottom:-4px;
  width:0;
  height:2px;
  background:var(--highlight);
  transition:width .2s ease;
}
.main-nav a:hover::after{
  width:100%;
}
.btn{
  background:linear-gradient(135deg,var(--accent),#cf3a2a);
  border-color:var(--accent);
  color:#fff;
  box-shadow:0 10px 24px rgba(179,32,40,.20);
}
.btn:hover{
  background:var(--highlight);
  border-color:var(--highlight);
  color:#000;
  transform:translateY(-1px);
}
.btn-outline{
  background:#fff;
  color:var(--accent);
  border-color:rgba(179,32,40,.22);
  box-shadow:none;
}
.btn-outline:hover{
  color:#000;
}
.hero{
  background:
    radial-gradient(circle at top right, rgba(242,158,35,.16), transparent 32%),
    linear-gradient(135deg, var(--primary) 0%, #1d1d1d 58%, #33231c 100%);
  color:#fff;
  padding:3rem 0 2.6rem;
}
.hero h1,
.hero .lead{
  color:#fff;
}
.hero .eyebrow{
  color:var(--highlight);
}
.hero-grid{
  align-items:center;
}
.hero img{
  border-radius:24px;
  border:3px solid rgba(242,158,35,.32);
  box-shadow:0 18px 38px rgba(0,0,0,.24);
}
.breadcrumb{
  color:#7b7070;
}
.self-check{
  background:
    linear-gradient(180deg,#fff 0%, #fffaf3 100%);
  border-top:1px solid rgba(242,158,35,.18);
  border-bottom:1px solid rgba(242,158,35,.18);
}
.check-grid li::marker,
.trust-list li::marker,
.area-list li::marker,
.related-links li::marker,
.footer-grid li::marker{
  color:var(--highlight);
}
.card,.feature-panel{
  background:#fff;
  border:1px solid rgba(242,158,35,.24);
  box-shadow:var(--shadow);
}
.card{
  position:relative;
  overflow:hidden;
}
.card::before{
  content:"";
  position:absolute;
  left:0;
  top:0;
  width:100%;
  height:5px;
  background:linear-gradient(90deg,var(--accent),var(--highlight));
}
.card:hover,.feature-panel:hover{
  transform:translateY(-3px);
  transition:transform .2s ease, box-shadow .2s ease;
  box-shadow:0 16px 36px rgba(0,0,0,.12);
}
h1,h2,h3{
  color:var(--primary);
}
.content-section h2,
.split-section h2,
.problems h2,
.areas h2,
.faq-section h2,
.related-links h2,
.service-area-band h2{
  position:relative;
  padding-bottom:.35rem;
}
.content-section h2::after,
.split-section h2::after,
.problems h2::after,
.areas h2::after,
.faq-section h2::after,
.related-links h2::after,
.service-area-band h2::after{
  content:"";
  display:block;
  width:72px;
  height:4px;
  border-radius:999px;
  background:linear-gradient(90deg,var(--accent),var(--highlight));
  margin-top:.5rem;
}
.faq-section details{
  border:1px solid rgba(242,158,35,.24);
  box-shadow:0 8px 18px rgba(0,0,0,.04);
}
.faq-section summary{
  color:var(--primary);
}
.service-area-band{
  background:linear-gradient(180deg,#fff5e5 0%, #fff 100%);
  border-top:1px solid rgba(242,158,35,.18);
  border-bottom:1px solid rgba(242,158,35,.18);
}
.cta-band{
  background:
    radial-gradient(circle at top right, rgba(242,158,35,.20), transparent 28%),
    linear-gradient(135deg, var(--primary) 0%, #231f20 100%);
  color:#fff;
}
.site-footer{
  background:var(--primary);
}
.site-footer a{
  color:var(--highlight);
}
.site-footer a:hover{
  color:#fff;
}
.footer-bottom{
  border-top-color:rgba(242,158,35,.22);
}
.sticky-cta{
  background:var(--primary);
  box-shadow:0 -6px 20px rgba(0,0,0,.16);
}
.sticky-cta a:first-child{
  background:#2a2a2a;
}
.sticky-cta a:hover{
  background:var(--highlight);
  color:#000;
}
img{
  border-radius:22px;
}

@media (max-width: 900px){
  .logo-image-wrap{
    width:58px;
    height:58px;
    border-radius:16px;
  }
}

.hero-grid > div:last-child img{
  background:#ffffff !important;
  padding:20px !important;
  border-radius:16px !important;
  display:block !important;
}