/* ============================================================
   DME Maintenance — generated 2026-03-26
   Theme: primary=#1A1A4E accent=#67E8F9
   ============================================================ */

:root {
  --primary:      #1A1A4E;
  --overlay:      rgba(26,26,78,0.88);
  --accent:       #67E8F9;
  --accent-hover: #22D3EE;
  --accent-text:  #001A2D;
  --link:         #1A1A4E;
}

*{box-sizing:border-box}
body{
  font-family:system-ui,-apple-system,sans-serif;
  line-height:1.85;margin:0;color:#222;
  background-color:#f5f0e8;
  background-image:var(--bg-image,url('/images/header-chimney-background.jpg'));
  background-attachment:fixed;
  background-size:cover;
  background-position:center;
}
/* ---- Contact & Review Forms ---- */
.contact-form-wrap{max-width:700px;margin:32px auto}
.dme-form{
  display:flex;flex-direction:column;gap:18px;
  background:#ffffff;
  padding:36px 32px;border-radius:14px;
  box-shadow:0 6px 32px rgba(0,0,0,0.18);
}
.dme-form label{
  display:flex;flex-direction:column;gap:6px;
  font-weight:700;font-size:0.97rem;
  color:#1a1a2e;
}
.dme-form input[type=text],
.dme-form input[type=email],
.dme-form input[type=tel],
.dme-form select,
.dme-form textarea{
  padding:13px 15px;
  border:2px solid #b0bcd4;
  border-radius:9px;
  font-size:1rem;
  font-family:inherit;
  background:#ffffff;
  color:#111111;
  transition:border-color .2s,box-shadow .2s;
  width:100%;
}
.dme-form input:focus,
.dme-form select:focus,
.dme-form textarea:focus{
  border-color:var(--primary);
  outline:none;
  box-shadow:0 0 0 3px rgba(27,58,107,0.13);
  background:#ffffff;
  color:#111111;
}
.dme-form input::placeholder,
.dme-form textarea::placeholder{
  color:#7a8499;
  opacity:1;
}
.dme-form select{
  appearance:none;
  -webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23555' d='M0 0l6 8 6-8z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 14px center;
  padding-right:36px;
  color:#111111;
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:560px){.form-row{grid-template-columns:1fr}}
.email-opt-in{
  flex-direction:row !important;
  align-items:center;gap:10px;
  font-weight:400 !important;font-size:0.92rem;
  cursor:pointer;color:#333;
}
.email-opt-in input[type=checkbox]{
  width:18px;height:18px;margin:0;flex-shrink:0;
  accent-color:var(--primary);
}
.form-sent{
  text-align:center;
  background:#ffffff;
  padding:48px 32px;border-radius:14px;
  box-shadow:0 6px 32px rgba(0,0,0,0.18);
}
h2{color:#1a1a2e;font-size:1.9rem;margin-bottom:12px}
.form-sent p{color:#333;font-size:1.05rem}
/* Star picker */
.star-picker{display:flex;gap:8px;margin-top:6px}
.star{
  background:none;border:none;
  font-size:2.4rem;color:#c8c8c8;
  cursor:pointer;padding:0;
  transition:color .15s,transform .1s;
  line-height:1;
}
.star:hover{transform:scale(1.15)}
.star.active{color:#f5a623}
.star.hover{color:#f5a623}
main{position:relative;}

/* ---- Header ---- */
header{
  background:var(--primary) url('/images/header-chimney-background.jpg') center/cover no-repeat;
  color:white;padding:28px 20px 22px;text-align:center;position:relative;
}
header::before{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,0.82) 0%,rgba(0,0,0,0.82) 18%,var(--overlay) 60%)}
header>*{position:relative;z-index:1}
header h1{background:none;padding:0;border-left:none;margin:0 0 6px;font-size:clamp(1.6rem,3vw,2.2rem);color:#fff}
.site-logo{margin:0 0 10px;font-size:clamp(1.4rem,3vw,2rem);color:#fff;display:inline-block;background:rgba(0,0,0,0.55);padding:6px 18px;border-radius:6px;text-shadow:0 1px 4px rgba(0,0,0,0.8);font-weight:700}
header .tagline{margin:0 0 10px;font-size:0.95rem;opacity:0.92;text-shadow:0 1px 6px rgba(0,0,0,0.9)}
header a{color:#fff;text-decoration:none}
header .cta,header .cta-secondary{
  color:var(--accent-text) !important;
  text-decoration:none;
}
header .cta:hover,header .cta-secondary:hover{
  color:var(--accent-text) !important;
  text-decoration:none;
}
header a:hover{text-decoration:underline;opacity:0.85}

/* ---- Header service nav ---- */
.header-nav{
  display:flex;flex-wrap:wrap;justify-content:center;
  gap:6px 12px;margin:12px 0 14px;padding:0;list-style:none;
  font-size:0.82rem;
}
.header-nav a{
  color:#fff;text-decoration:none;
  border:1px solid rgba(255,255,255,0.88);
  border-radius:999px;padding:3px 11px;
  transition:background .15s;
  white-space:nowrap;
}
.header-nav a:hover{background:rgba(255,255,255,0.88);text-decoration:none}

/* ---- Header CTA row ---- */
.header-ctas{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-top:14px}

/* ---- Footer ---- */
footer{background:var(--primary);color:white;padding:28px 20px;text-align:center}
footer a{color:rgba(255,255,255,0.88);text-decoration:underline}
footer a:hover{color:#fff}

/* ---- Main ---- */
main{max-width:1150px;margin:auto;padding:28px 20px}
main p{
  margin-bottom:1em;
  line-height:1.7;
}
main ul{
  padding:10px 10px 10px 28px;
  margin:10px 0;
}
h1{
  color:#1a1a2e;font-size:clamp(1.5rem,3vw,2.1rem);margin:0 0 14px;
  background:rgba(255,255,255,0.95);display:block;text-align:center;
  padding:18px 20px;border-radius:8px;box-shadow:0 2px 12px rgba(0,0,0,0.12);
}
h3{color:#1a1a2e;font-size:1.05rem;font-weight:700;margin:18px 0 8px;padding:6px 12px;background:rgba(255,255,255,0.92);display:block;border-radius:4px;border-left:3px solid var(--accent);}
h2{color:#1a1a2e;font-size:1.2rem;font-weight:700;margin:22px 0 12px 0;padding:8px 14px;background:rgba(255,255,255,0.95);display:block;border-radius:6px;border-left:4px solid var(--accent);}
a{color:var(--link);text-decoration:underline}

/* ---- CTA buttons ---- */
.cta,
.cta-secondary{
  display:inline-block;padding:14px 30px;
  background:var(--accent);color:var(--accent-text);
  font-weight:900;border-radius:999px;border:none;
  text-decoration:none;margin:8px 5px;font-size:1.02em;
  box-shadow:0 4px 14px rgba(0,0,0,0.25);
  transition:background .18s,transform .12s,box-shadow .18s,color .18s;
  white-space:nowrap;cursor:pointer;
}
.cta:hover,
.cta-secondary:hover{
  background:var(--accent-hover);
  color:var(--accent-text);
  transform:translateY(-2px);
  box-shadow:0 8px 24px rgba(0,0,0,0.32);
  text-decoration:none;
}
.cta-bar{
  background:#ffffff;padding:20px 22px;text-align:center;
  border-radius:10px;margin:28px 0;
  border:2px solid var(--accent);
  color:#222;
}
.cta-bar a{margin:6px 4px;display:inline-block}
.cta-bar strong{color:#222;}

/* ---- Tables ---- */
table{width:100%;border-collapse:collapse;margin:10px 0 14px;}
td,th{border:1px solid #ccc;padding:14px;text-align:left;background:#ffffff}
th{background:var(--primary);color:white}

/* ---- Image grid ---- */
.img-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px;margin:24px 0;overflow:hidden;box-sizing:border-box;max-width:100%}
.img-grid img{width:100%;height:180px;object-fit:cover;border-radius:8px;border:1px solid #ddd;display:block}

/* ---- Address block ---- */
.address-block{
  background:#ffffff;padding:14px 18px;
  border-left:4px solid var(--primary);
  border-radius:6px;margin:18px 0;
}

/* ---- Long-form content ---- */
.content-body{
  background:#ffffff;border:1px solid #e5eef5;border-radius:12px;
  padding:clamp(20px,4vw,48px);margin:36px 0;
  box-shadow:0 4px 24px rgba(0,0,0,0.18);
  font-size:1.05rem;line-height:1.9;
}
.content-body p{margin:0 0 1.2em}
.content-body p:last-child{margin-bottom:0}
.content-body .speakable{
  font-size:1.1rem;font-weight:500;color:#1a1a2e;
  border-left:4px solid var(--accent);padding-left:16px;
}

/* ---- Quick AI answer box ---- */
.quick-ai{background:#ffffff;padding:14px 22px;border-radius:10px;margin:18px 0;border-left:5px solid var(--accent);font-size:0.97em;line-height:1.6}

/* ---- License line ---- */
.license-line{display:block;font-size:0.82rem;margin:4px 0;word-wrap:break-word;overflow-wrap:break-word;white-space:normal;text-align:center;line-height:1.4}

/* ---- Breadcrumb ---- */
nav[aria-label="breadcrumb"]{font-size:0.85em;margin:8px 0}
nav[aria-label="breadcrumb"] a{color:rgba(255,255,255,0.88)}
footer nav[aria-label="breadcrumb"] a{color:rgba(255,255,255,0.88)}

/* ---- FAQ Accordion ---- */
.faq-section{
  margin:36px 0;
  background:#ffffff;
  border-radius:12px;
  padding:20px 28px;
  box-shadow:0 2px 12px rgba(0,0,0,0.10);
}
.faq-section h2{
  margin:0 0 18px;
  background:none;
  padding:6px 0 6px 22px;
  border-left:4px solid var(--accent);
  border-radius:0;
  display:block;
  color:#1a1a2e;
}
.faq-item{
  background:#ffffff;
  border:1px solid #dde3ed;
  border-radius:8px;
  margin-bottom:8px;
  overflow:hidden;
}
.faq-question{
  width:100%;text-align:left;
  background:none;border:none;
  padding:16px 20px 16px 22px;
  font-size:1rem;font-weight:700;
  color:#1a1a2e;cursor:pointer;
  display:flex;justify-content:space-between;align-items:center;
  font-family:inherit;
}
.faq-question:hover{background:rgba(0,0,0,0.03)}
.faq-question .faq-icon{
  font-size:1.3rem;font-weight:400;
  transition:transform .2s;
  flex-shrink:0;margin-left:12px;
}
.faq-answer{
  display:none;
  padding:0 20px 18px;
  font-size:0.97rem;line-height:1.75;
  color:#333;
  background:#ffffff;
}
.faq-item.open .faq-answer{display:block}
.faq-item.open .faq-icon{transform:rotate(45deg)}

/* ---- Responsive ---- */
@media(max-width:640px){
  .img-grid{grid-template-columns:repeat(2,1fr);gap:8px;width:100%;max-width:100%;overflow:hidden;padding:0 1px}
  .img-grid img{height:140px;min-width:0;max-width:100%;width:100%}
  .cta,.cta-secondary{display:block;text-align:center;margin:8px 0;
    white-space:normal;word-break:break-word;font-size:0.9em;padding:12px 16px}
  .header-nav{font-size:0.75rem}
  .header-ctas{flex-direction:column;align-items:center}
}
@media(max-width:400px){
  .cta,.cta-secondary{font-size:0.82em;padding:10px 12px}
}

/* ---- Sticky mobile call bar ---- */
.sticky-call-bar{
  display:none;
  position:fixed;bottom:0;left:0;right:0;z-index:9999;
  background:var(--primary);padding:10px 12px;
  border-top:3px solid var(--accent);
  text-align:center;box-shadow:0 -3px 14px rgba(0,0,0,0.35);
  transform:translateZ(0);-webkit-transform:translateZ(0);
}
.sticky-call-bar-inner{
  display:flex;flex-direction:row;
  align-items:center;justify-content:center;
  gap:10px;max-width:500px;margin:0 auto;
}
.sticky-call-bar a.sticky-call,
.sticky-call-bar a.sticky-text{
  display:inline-block;flex:1;
  font-size:1.05rem;font-weight:900;
  background:var(--accent);color:var(--accent-text);
  padding:11px 14px;border-radius:999px;border:none;
  text-decoration:none;box-shadow:0 4px 14px rgba(0,0,0,0.25);
  box-sizing:border-box;text-align:center;white-space:nowrap;
  transition:background .18s,transform .12s,box-shadow .18s;
}
.sticky-call-bar a.sticky-call:hover,
.sticky-call-bar a.sticky-text:hover{
  background:var(--accent-hover);
  transform:translateY(-2px);
  box-shadow:0 8px 24px rgba(0,0,0,0.32);
  text-decoration:none;
}
@media(max-width:768px){
  .sticky-call-bar{display:block}
  body{padding-bottom:calc(110px + env(safe-area-inset-bottom,0px))}
  main{padding-bottom:calc(72px + env(safe-area-inset-bottom,0px))}
  footer{padding-bottom:calc(80px + env(safe-area-inset-bottom,0px))}
}
