/* blog.css - Backwell blog content styles, new red/white/blue theme.
   Pairs with /theme.css (palette + site chrome). Covers BOTH legacy blog templates:
   T1 = .blog-hero/.blog-content/.related-*   T2 = .bc/.ph/.ct/.mc/.sb/.sc/.rel/.rc
   All colors reference theme.css palette vars (--text,--text-2,--text-3,--red,--red-bright,--blue,--blue-bright,--bg,--bg-2,--ink,--line,--line-strong). */

/* ---------- nav links (theme.css leaves .nav-links unstyled; give it proper spacing) ---------- */
.nav-links{display:flex;align-items:center;gap:1.6rem}
.nav-links a{font-size:.8125rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--text-2);transition:color .12s}
.nav-links a:hover{color:var(--text)}
@media(max-width:760px){.nav-links{display:none}}

/* ---------- T1 hero ---------- */
.blog-hero{padding:3rem 2rem 2.5rem;background:var(--ink);border-bottom:3px solid var(--blue)}
.blog-hero-inner{max-width:840px;margin:0 auto}
.blog-breadcrumb{font-size:.75rem;color:var(--text-3);letter-spacing:.06em;text-transform:uppercase;font-weight:700;margin-bottom:1.25rem}
.blog-breadcrumb a{color:var(--text-2)}
.blog-breadcrumb a:hover{color:var(--red-bright)}
.blog-hero h1{font-family:Arial,sans-serif;font-size:clamp(1.85rem,4vw,2.85rem);font-weight:900;line-height:1.08;letter-spacing:-.02em;text-transform:uppercase;color:var(--text);margin-bottom:1rem}
.blog-meta{font-size:.75rem;color:var(--text-3);display:flex;gap:1.5rem;flex-wrap:wrap;letter-spacing:.04em;text-transform:uppercase;font-weight:700}

/* ---------- T2 page header (bc / ph) ---------- */
.bc{max-width:840px;margin:0 auto;padding:2.5rem 2rem .5rem;font-size:.75rem;color:var(--text-3);letter-spacing:.06em;text-transform:uppercase;font-weight:700}
.bc a{color:var(--text-2)}
.bc a:hover{color:var(--red-bright)}
.ph{max-width:840px;margin:0 auto;padding:1.5rem 2rem 2.5rem}
.ph h1{font-family:Arial,sans-serif;font-size:clamp(2rem,5vw,3.25rem);font-weight:900;line-height:1.05;letter-spacing:-.02em;text-transform:uppercase;color:var(--text);margin-bottom:1rem}
.ph h1 em{font-style:normal;color:var(--blue-bright)}
.ph .sub,.lead{font-size:1.0625rem;color:var(--text-2);max-width:760px;line-height:1.65}

/* ---------- body content (T1 .blog-content + T2 .ct/.mc) ---------- */
.blog-content{max-width:840px;margin:0 auto;padding:3rem 2rem 4rem}
.ct{max-width:1200px;margin:0 auto;padding:2.5rem 2rem 4rem;display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:3.5rem;align-items:start}
.blog-content h2,.mc h2{font-family:Arial,sans-serif;font-size:clamp(1.4rem,3vw,2rem);font-weight:900;text-transform:uppercase;letter-spacing:-.02em;line-height:1.12;color:var(--text);margin:2.5rem 0 1rem;padding-bottom:.6rem;border-bottom:3px solid var(--red)}
.blog-content h2:first-child,.mc h2:first-child{margin-top:0}
.blog-content h3,.mc h3{font-family:Arial,sans-serif;font-size:1.1875rem;font-weight:900;color:var(--blue-bright);text-transform:uppercase;letter-spacing:.01em;margin:1.75rem 0 .6rem}
.blog-content p,.mc p{color:var(--text-2);margin-bottom:1rem;line-height:1.75;font-size:1rem}
.blog-content strong,.mc strong{color:var(--text);font-weight:700}
.blog-content a,.mc a{color:var(--blue-bright);font-weight:600}
.blog-content a:hover,.mc a:hover{text-decoration:underline}
.blog-content ul,.blog-content ol,.mc ul,.mc ol{margin:1rem 0 1.5rem;list-style:none}
.blog-content ol{list-style:decimal;margin-left:1.4rem}
.blog-content ol li{color:var(--text-2);line-height:1.7;padding:.3rem 0}
.blog-content ul li,.mc ul li{position:relative;padding:.4rem 0 .4rem 1.6rem;color:var(--text-2);line-height:1.65}
.blog-content ul li::before,.mc ul li::before{content:"";position:absolute;left:0;top:.95rem;width:8px;height:8px;background:var(--red);transform:rotate(45deg)}
/* hand-authored inline-styled lists manage their own layout, no custom bullet */
.blog-content ul[style] li::before,.mc ul[style] li::before{display:none}
.blog-content blockquote,.mc blockquote{border-left:3px solid var(--red);padding:1rem 1.5rem;margin:1.5rem 0;background:var(--bg-2)}
.blog-content blockquote p,.mc blockquote p{margin-bottom:0;font-style:italic;color:var(--text-2)}

/* ---------- figure / real images ---------- */
.blog-figure{margin:0 0 2rem}
.blog-figure img{width:100%;height:auto;border:1px solid var(--line-strong);display:block}
.blog-figure figcaption{font-size:.8125rem;color:var(--text-3);margin-top:.6rem;line-height:1.5}
.project-photos{padding:3.5rem 2rem;border-top:1px solid var(--line);background:var(--bg-2)}
.project-photos .wrap{max-width:1200px;margin:0 auto}
.project-photos h2{font-family:Arial,sans-serif;font-size:clamp(1.5rem,3vw,2rem);font-weight:900;text-transform:uppercase;letter-spacing:-.02em;color:var(--text);margin-bottom:.75rem;padding-bottom:.6rem;border-bottom:3px solid var(--red);display:inline-block}
.project-photos .lead{margin-bottom:2rem}
.project-photos .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.project-photos figure{margin:0}
.project-photos img{width:100%;height:auto;display:block;border:1px solid var(--line-strong)}
.project-photos figcaption{font-size:.8125rem;color:var(--text-3);margin-top:.5rem;line-height:1.4}
@media(max-width:760px){.project-photos .grid{grid-template-columns:1fr}}

/* ---------- tables ---------- */
.cost-table,.blog-content table,.mc table{width:100%;border-collapse:collapse;margin:1.5rem 0;border:1px solid var(--line-strong)}
.cost-table th,.blog-content th,.mc th{background:var(--bg-2);color:var(--text);font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;padding:.8rem 1rem;text-align:left;border-bottom:1px solid var(--line-strong)}
.cost-table td,.blog-content td,.mc td{padding:.8rem 1rem;border-bottom:1px solid var(--line);color:var(--text-2);font-size:.9375rem}
.cost-table tr:hover td,.blog-content table tr:hover td,.mc table tr:hover td{background:rgba(255,255,255,.03)}

/* ---------- callout boxes ---------- */
.warning-box{background:rgba(197,18,29,.10);border:1px solid rgba(197,18,29,.35);border-left:3px solid var(--red);padding:1.25rem 1.5rem;margin:1.5rem 0}
.warning-box .label{font-size:.6875rem;font-weight:800;color:var(--red-bright);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.5rem}
.warning-box p{color:var(--text-2);margin-bottom:0;line-height:1.7}
.tip-box{background:rgba(10,78,163,.12);border:1px solid rgba(30,109,209,.35);border-left:3px solid var(--blue);padding:1.25rem 1.5rem;margin:1.5rem 0}
.tip-box .label{font-size:.6875rem;font-weight:800;color:var(--blue-bright);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.5rem}
.tip-box p{color:var(--text-2);margin-bottom:0;line-height:1.7}

/* ---------- CTA box (covers T1 gradient+.btn+.cta-phone and T2 solid+a) ---------- */
.cta-box{background:var(--red);border-top:4px solid var(--text);padding:2.25rem;text-align:center;margin:2.5rem 0}
.cta-box h3{font-family:Arial,sans-serif;font-size:1.4rem;font-weight:900;text-transform:uppercase;letter-spacing:.02em;color:var(--text);margin-bottom:.6rem}
.cta-box p{color:rgba(255,255,255,.88);margin-bottom:1.25rem;font-size:1rem}
.cta-box .cta-phone{display:block;font-family:Arial,sans-serif;font-size:1.5rem;font-weight:900;color:var(--text);margin-bottom:.6rem;letter-spacing:.02em}
.cta-box .btn,.cta-box a{display:inline-flex;align-items:center;gap:.5rem;background:var(--text);color:var(--ink) !important;padding:.95rem 2rem;font-family:Arial,sans-serif;font-weight:900;font-size:.8125rem;letter-spacing:.12em;text-transform:uppercase;border:0;text-decoration:none}
.cta-box .btn:hover,.cta-box a:hover{background:var(--ink);color:var(--text) !important;text-decoration:none}

/* ---------- T2 sidebar ---------- */
.sb{align-self:start}
@media(min-width:901px){.sb{position:sticky;top:6rem}}
.sc{background:var(--bg-2);border:1px solid var(--line-strong);border-top:3px solid var(--blue);padding:1.5rem;margin-bottom:1.5rem}
.sc h3{font-family:Arial,sans-serif;font-size:.9375rem;font-weight:900;text-transform:uppercase;letter-spacing:.04em;color:var(--text);margin-bottom:1rem;padding-bottom:.6rem;border-bottom:2px solid var(--red)}
.sc a{display:block;padding:.4rem 0;font-size:.875rem;color:var(--text-2)}
.sc a:hover{color:var(--red-bright)}
.sb .cta-box{text-align:left;padding:1.5rem;margin:0 0 1.5rem}
.sb .cta-box h3{font-size:1.125rem}

/* ---------- related posts (T1 .related-* and T2 .rel/.rc) ---------- */
.related-posts,.rel{background:var(--bg-2);border-top:1px solid var(--line);padding:3.5rem 2rem}
.related-posts-inner{max-width:840px;margin:0 auto}
.rel-inner{max-width:1200px;margin:0 auto}
.related-posts h3,.rel h2{font-family:Arial,sans-serif;font-size:1.25rem;font-weight:900;text-transform:uppercase;letter-spacing:.02em;color:var(--text);margin-bottom:1.5rem;padding-bottom:.6rem;border-bottom:3px solid var(--red);display:inline-block}
.related-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.rel-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem;margin-top:1.5rem}
.related-card,.rc{background:var(--bg);border:1px solid var(--line-strong);padding:1.25rem;transition:border-color .12s}
.related-card:hover,.rc:hover{border-color:var(--red)}
.related-card a{display:block;color:var(--text);font-family:Arial,sans-serif;font-weight:800;font-size:.9375rem;margin-bottom:.4rem}
.related-card a:hover{color:var(--red-bright)}
.related-card p,.rc p{font-size:.8125rem;color:var(--text-3);margin:0;line-height:1.5}
.rc h3{font-family:Arial,sans-serif;font-size:.9375rem;font-weight:800;color:var(--text);margin-bottom:.3rem}
.rc a{color:inherit}

/* ---------- responsive ---------- */
@media(max-width:900px){.ct{grid-template-columns:1fr;gap:2rem}.sb{position:static}}
@media(max-width:768px){.related-grid{grid-template-columns:1fr}}
