@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700;800&family=Open+Sans:wght@300;400;500;600&display=swap');
:root{--navy:#0d1b2e;--navy-mid:#162440;--crimson:#c41e3a;--crimson-dark:#a01830;--gold:#b89a5a;--white:#ffffff;--off-white:#f7f8fa;--light-gray:#eef0f3;--mid-gray:#c8cdd5;--text-dark:#1a2030;--text-mid:#4a5568;--text-light:#718096;--border:#e2e8f0;}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'Open Sans',sans-serif;background:var(--white);color:var(--text-dark);line-height:1.6;overflow-x:hidden;}
.top-bar{background:var(--crimson);padding:7px 2rem;display:flex;align-items:center;justify-content:center;gap:2rem;flex-wrap:wrap;}
.top-bar span,.top-bar a{color:var(--white);font-size:12px;font-weight:600;letter-spacing:.04em;font-family:'Montserrat',sans-serif;text-decoration:none;}
.top-bar-sep{color:rgba(255,255,255,.3);}
#navbar{background:var(--navy);padding:0 2rem;height:68px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 16px rgba(0,0,0,.25);position:sticky;top:0;z-index:1000;}
.nav-logo{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0;}
.nav-logo-text{display:flex;flex-direction:column;line-height:1.2;}
.nav-logo-text .name{color:var(--white);font-family:'Montserrat',sans-serif;font-size:14px;font-weight:800;letter-spacing:.02em;}
.nav-logo-text .sub{color:rgba(255,255,255,.4);font-size:10px;letter-spacing:.08em;text-transform:uppercase;}
.nav-links{display:flex;align-items:center;list-style:none;height:68px;}
.nav-links>li{position:relative;height:100%;display:flex;align-items:center;}
.nav-links>li>a{color:rgba(255,255,255,.85);text-decoration:none;font-size:13px;font-weight:600;letter-spacing:.03em;padding:0 1rem;font-family:'Montserrat',sans-serif;transition:color .2s;height:100%;display:flex;align-items:center;gap:4px;white-space:nowrap;}
.nav-links>li>a:hover,.nav-links>li>a.active{color:var(--gold);}
.arrow{font-size:9px;transition:transform .2s;display:inline-block;}
.nav-links>li:hover .arrow{transform:rotate(180deg);}
.dropdown{position:absolute;top:100%;left:0;background:var(--white);border-top:3px solid var(--crimson);border-radius:0 0 6px 6px;box-shadow:0 8px 24px rgba(0,0,0,.12);min-width:230px;opacity:0;visibility:hidden;transform:translateY(-6px);transition:all .2s;z-index:999;list-style:none;}
.nav-links>li:hover .dropdown{opacity:1;visibility:visible;transform:translateY(0);}
.dropdown li a{display:block;padding:11px 1.25rem;color:var(--text-dark);text-decoration:none;font-size:13px;font-weight:600;font-family:'Montserrat',sans-serif;letter-spacing:.02em;border-bottom:1px solid var(--border);transition:all .15s;}
.dropdown li:last-child a{border-bottom:none;}
.dropdown li a:hover{background:var(--off-white);color:var(--crimson);padding-left:1.6rem;}
.nav-right{display:flex;align-items:center;gap:1rem;flex-shrink:0;}
.nav-phone{color:var(--gold);font-family:'Montserrat',sans-serif;font-size:14px;font-weight:800;text-decoration:none;white-space:nowrap;}
.nav-cta{background:var(--crimson);color:var(--white);padding:10px 20px;border-radius:4px;font-size:12px;font-weight:700;text-decoration:none;letter-spacing:.05em;text-transform:uppercase;font-family:'Montserrat',sans-serif;transition:background .2s;white-space:nowrap;}
.nav-cta:hover{background:var(--crimson-dark);}
#hero{position:relative;min-height:70vh;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:80px 2rem;text-align:center;}
.hero-bg{position:absolute;inset:0;background:linear-gradient(105deg,rgba(13,27,46,.92) 0%,rgba(13,27,46,.72) 50%,rgba(13,27,46,.3) 100%),url('https://images.unsplash.com/photo-1562259949-e8e7689d7828?w=1600&q=80') center/cover no-repeat;}
.hero-content{position:relative;z-index:2;max-width:780px;margin:0 auto;text-align:center;}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:var(--crimson);color:var(--white);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:7px 18px;border-radius:3px;margin-bottom:1.5rem;font-family:'Montserrat',sans-serif;}
.hero-title{font-family:'Montserrat',sans-serif;font-size:clamp(34px,5vw,64px);font-weight:800;line-height:1.08;color:var(--white);margin-bottom:1.25rem;text-transform:uppercase;letter-spacing:-.01em;}
.hero-title .accent{color:var(--gold);}
.hero-sub{font-size:17px;color:rgba(255,255,255,.8);max-width:580px;margin:0 auto .6rem;font-weight:300;line-height:1.8;}
.hero-locations{font-size:11px;color:var(--gold);letter-spacing:.12em;text-transform:uppercase;margin-bottom:2.5rem;font-weight:700;font-family:'Montserrat',sans-serif;}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:3rem;justify-content:center;}
.hero-trust{display:inline-flex;flex-wrap:wrap;justify-content:center;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.15);border-radius:4px;overflow:hidden;}
.trust-pill{padding:11px 18px;font-size:11px;color:var(--white);font-weight:700;letter-spacing:.05em;text-transform:uppercase;font-family:'Montserrat',sans-serif;border-right:1px solid rgba(255,255,255,.1);display:flex;align-items:center;gap:7px;}
.trust-pill:last-child{border-right:none;}
.trust-pill .dot{width:7px;height:7px;border-radius:50%;background:var(--gold);flex-shrink:0;}
.btn-red{background:var(--crimson);color:var(--white);padding:15px 32px;border-radius:4px;font-size:13px;font-weight:700;text-decoration:none;letter-spacing:.06em;text-transform:uppercase;font-family:'Montserrat',sans-serif;transition:background .2s,transform .15s;display:inline-block;border:none;cursor:pointer;}
.btn-red:hover{background:var(--crimson-dark);transform:translateY(-1px);}
.btn-red.full{width:100%;text-align:center;padding:16px;font-size:14px;}
.btn-white{background:var(--white);color:var(--navy);padding:15px 32px;border-radius:4px;font-size:13px;font-weight:700;text-decoration:none;letter-spacing:.06em;text-transform:uppercase;font-family:'Montserrat',sans-serif;transition:all .2s;display:inline-block;}
.btn-white:hover{background:var(--off-white);transform:translateY(-1px);}
.btn-navy{background:var(--navy);color:var(--white);padding:15px 32px;border-radius:4px;font-size:13px;font-weight:700;text-decoration:none;letter-spacing:.06em;text-transform:uppercase;font-family:'Montserrat',sans-serif;transition:background .2s;display:inline-block;}
.btn-navy:hover{background:var(--navy-mid);}
.btn-outline{background:transparent;color:var(--crimson);padding:13px 28px;border-radius:4px;font-size:13px;font-weight:700;text-decoration:none;letter-spacing:.05em;text-transform:uppercase;font-family:'Montserrat',sans-serif;border:2px solid var(--crimson);transition:all .2s;display:inline-block;}
.btn-outline:hover{background:var(--crimson);color:var(--white);}
section{padding:80px 2rem;}
.container{max-width:1200px;margin:0 auto;}
.bg-white{background:var(--white);}
.bg-light{background:var(--off-white);}
.bg-navy{background:var(--navy);}
.section-eyebrow{font-size:12px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--crimson);font-family:'Montserrat',sans-serif;margin-bottom:.6rem;display:block;}
.section-eyebrow.on-dark{color:var(--gold);}
.section-title{font-family:'Montserrat',sans-serif;font-size:clamp(24px,3vw,40px);font-weight:800;line-height:1.15;margin-bottom:1rem;color:var(--text-dark);text-transform:uppercase;letter-spacing:-.01em;}
.section-title.white{color:var(--white);}
.section-desc{font-size:16px;color:var(--text-mid);max-width:640px;line-height:1.8;}
.section-header{text-align:center;margin-bottom:3.5rem;}
.section-header .section-desc{margin:0 auto;}
.stats-strip{display:grid;grid-template-columns:repeat(4,1fr);background:var(--crimson);}
.stat-item{padding:2rem 1.5rem;text-align:center;border-right:1px solid rgba(255,255,255,.2);}
.stat-item:last-child{border-right:none;}
.stat-num{font-family:'Montserrat',sans-serif;font-size:42px;font-weight:800;color:var(--white);line-height:1;}
.stat-label{font-size:12px;color:rgba(255,255,255,.75);font-weight:600;letter-spacing:.06em;text-transform:uppercase;font-family:'Montserrat',sans-serif;margin-top:.3rem;}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;}
.service-card{background:var(--white);border:1px solid var(--border);border-radius:6px;padding:2rem 1.75rem;text-decoration:none;color:var(--text-dark);transition:all .2s;display:block;}
.service-card:hover{transform:translateY(-4px);box-shadow:0 10px 28px rgba(0,0,0,.1);border-color:var(--crimson);}
.service-icon{width:54px;height:54px;background:rgba(196,30,58,.08);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem;font-size:22px;}
.service-card h3{font-family:'Montserrat',sans-serif;font-size:15px;font-weight:800;margin-bottom:.6rem;color:var(--navy);text-transform:uppercase;letter-spacing:.02em;}
.service-card p{font-size:14px;color:var(--text-mid);line-height:1.7;margin-bottom:1.25rem;}
.card-arrow{font-size:13px;color:var(--crimson);font-weight:700;font-family:'Montserrat',sans-serif;letter-spacing:.04em;text-transform:uppercase;}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;}
.col-text p{font-size:15px;color:var(--text-mid);line-height:1.9;margin-bottom:1rem;}
.col-text .section-title{text-align:left;}
.checklist{list-style:none;margin:1.25rem 0 2rem;display:flex;flex-direction:column;gap:.6rem;}
.checklist li{font-size:14px;color:var(--text-dark);padding-left:1.75rem;position:relative;font-weight:500;line-height:1.6;}
.checklist li::before{content:'✓';position:absolute;left:0;color:var(--crimson);font-weight:800;font-size:13px;top:1px;}
.img-placeholder{background:var(--light-gray);border:2px dashed var(--mid-gray);border-radius:6px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;min-height:380px;}
.img-placeholder span{color:var(--text-light);font-size:15px;font-weight:600;font-family:'Montserrat',sans-serif;}
.img-placeholder small{color:var(--text-light);font-size:12px;}
.photo-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;}
.photo-tile{background:var(--light-gray);aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--text-light);font-weight:600;border-radius:4px;overflow:hidden;font-family:'Montserrat',sans-serif;}
.brands-row{display:flex;align-items:center;justify-content:center;gap:1.5rem;flex-wrap:wrap;}
.brand-item{background:var(--white);border:1px solid var(--border);border-radius:6px;padding:1.25rem 1.75rem;text-align:center;font-family:'Montserrat',sans-serif;font-size:14px;font-weight:700;color:var(--navy);min-width:150px;}
.brand-item small{display:block;font-size:10px;color:var(--text-light);font-weight:500;letter-spacing:.06em;text-transform:uppercase;margin-top:3px;}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:2rem;}
.review-card{background:var(--white);border:1px solid var(--border);border-radius:6px;padding:1.75rem;box-shadow:0 2px 8px rgba(0,0,0,.04);}
.stars{color:#f59e0b;font-size:16px;letter-spacing:2px;margin-bottom:1rem;}
.review-text{font-size:14px;color:var(--text-mid);line-height:1.8;font-style:italic;margin-bottom:1.25rem;}
.reviewer-name{font-size:13px;color:var(--navy);font-weight:700;font-family:'Montserrat',sans-serif;}
.reviewer-loc{font-size:12px;color:var(--text-light);}
.cta-band{background:var(--navy);padding:3.5rem 2rem;text-align:center;}
.cta-band h2{font-family:'Montserrat',sans-serif;font-size:clamp(22px,3vw,36px);font-weight:800;color:var(--white);text-transform:uppercase;margin-bottom:.75rem;}
.cta-band p{color:rgba(255,255,255,.7);font-size:16px;margin-bottom:2rem;max-width:540px;margin-left:auto;margin-right:auto;}
.cta-band-btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;}
.estimate-wrap{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start;}
.estimate-left p{font-size:15px;color:rgba(255,255,255,.72);line-height:1.8;margin-bottom:1.5rem;}
.estimate-perks{list-style:none;display:flex;flex-direction:column;gap:.75rem;margin-bottom:2rem;}
.estimate-perks li{font-size:14px;color:rgba(255,255,255,.85);display:flex;align-items:flex-start;gap:.75rem;font-weight:500;line-height:1.5;}
.estimate-perks li::before{content:'✓';color:var(--gold);font-weight:800;font-size:14px;flex-shrink:0;margin-top:1px;}
.form-box{background:var(--white);border-radius:6px;padding:2.5rem;}
.form-group{margin-bottom:1.25rem;}
.form-group label{display:block;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-light);margin-bottom:.4rem;font-weight:700;font-family:'Montserrat',sans-serif;}
.form-group input,.form-group select,.form-group textarea{width:100%;background:var(--off-white);border:1.5px solid var(--border);color:var(--text-dark);padding:12px 14px;border-radius:4px;font-size:14px;font-family:'Open Sans',sans-serif;transition:border-color .2s;}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--crimson);background:var(--white);}
.form-group textarea{resize:vertical;}
.form-success{text-align:center;padding:1.5rem 0;}
.form-success h3{font-family:'Montserrat',sans-serif;font-size:22px;font-weight:800;color:var(--crimson);margin-bottom:1rem;text-transform:uppercase;}
.form-success p{font-size:14px;color:var(--text-mid);line-height:1.8;}
.form-success a{color:var(--crimson);}
.page-hero{background:var(--navy);padding:80px 2rem 60px;border-bottom:4px solid var(--crimson);}
.page-hero-inner{max-width:700px;}
.breadcrumb{font-size:12px;color:rgba(255,255,255,.4);margin-bottom:1rem;font-family:'Montserrat',sans-serif;font-weight:500;}
.breadcrumb a{color:var(--gold);text-decoration:none;}
.page-hero h1{font-family:'Montserrat',sans-serif;font-size:clamp(28px,4.5vw,52px);font-weight:800;line-height:1.1;color:var(--white);margin-bottom:1rem;text-transform:uppercase;}
.page-hero h1 span{color:var(--gold);}
.page-hero p{font-size:16px;color:rgba(255,255,255,.7);line-height:1.8;max-width:560px;}
.content-block{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;margin-bottom:5rem;}
.content-block h2{font-family:'Montserrat',sans-serif;font-size:clamp(22px,2.8vw,34px);font-weight:800;margin-bottom:1rem;line-height:1.2;color:var(--navy);text-transform:uppercase;}
.content-block p{font-size:15px;color:var(--text-mid);line-height:1.8;margin-bottom:1rem;}
.icon-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;}
.icon-card{background:var(--white);border:1px solid var(--border);border-radius:6px;padding:2rem 1.5rem;text-align:center;}
.icon-card .icon{font-size:32px;margin-bottom:1rem;}
.icon-card h3{font-family:'Montserrat',sans-serif;font-size:14px;font-weight:800;color:var(--navy);text-transform:uppercase;margin-bottom:.5rem;}
.icon-card p{font-size:13px;color:var(--text-mid);line-height:1.7;}
#footer{background:var(--navy);padding:5rem 2rem 2rem;border-top:4px solid var(--crimson);}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem;}
.footer-brand-desc{font-size:13px;color:rgba(255,255,255,.5);line-height:1.7;margin:1rem 0;max-width:280px;}
.footer-hours{font-size:13px;color:rgba(255,255,255,.5);margin-bottom:.25rem;}
.footer-hours strong{color:rgba(255,255,255,.8);}
.footer-address{font-size:13px;color:rgba(255,255,255,.5);margin-bottom:1.25rem;}
.footer-socials{display:flex;gap:.75rem;margin-top:1rem;}
.social-icon{color:rgba(255,255,255,.4);transition:color .2s;display:flex;align-items:center;}
.social-icon:hover{color:var(--gold);}
.footer-col h4{font-family:'Montserrat',sans-serif;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);font-weight:700;margin-bottom:1.25rem;}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:.6rem;}
.footer-col ul li a{color:rgba(255,255,255,.55);text-decoration:none;font-size:13px;transition:color .2s;font-weight:500;}
.footer-col ul li a:hover{color:var(--white);}
.footer-brands-bar{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;padding:1.25rem 0;border-top:1px solid rgba(255,255,255,.08);border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:1.5rem;}
.footer-brands-label{font-size:11px;color:rgba(255,255,255,.35);letter-spacing:.08em;text-transform:uppercase;font-family:'Montserrat',sans-serif;font-weight:600;}
.brand-pill{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.55);font-size:11px;padding:4px 12px;border-radius:100px;font-family:'Montserrat',sans-serif;font-weight:600;}
.footer-bottom{text-align:center;}
.footer-bottom p{font-size:12px;color:rgba(255,255,255,.35);}
.footer-bottom a{color:var(--gold);text-decoration:none;}
.footer-legal{display:flex;gap:1.5rem;justify-content:center;margin-top:.75rem;}
.footer-legal a{font-size:12px;color:rgba(255,255,255,.35);text-decoration:none;transition:color .2s;}
.footer-legal a:hover{color:var(--white);}
.legal-wrap{max-width:780px;margin:0 auto;padding:60px 2rem;}
.legal-wrap h1{font-family:'Montserrat',sans-serif;font-size:36px;font-weight:800;color:var(--navy);text-transform:uppercase;margin-bottom:.5rem;}
.legal-wrap .date{font-size:13px;color:var(--text-light);margin-bottom:2rem;display:block;}
.legal-wrap h2{font-family:'Montserrat',sans-serif;font-size:18px;font-weight:700;color:var(--navy);text-transform:uppercase;margin:2rem 0 .75rem;border-left:4px solid var(--crimson);padding-left:.75rem;}
.legal-wrap p,.legal-wrap li{font-size:14px;color:var(--text-mid);line-height:1.9;margin-bottom:.75rem;}
.legal-wrap ul{padding-left:1.5rem;margin-bottom:1rem;}
.legal-wrap a{color:var(--crimson);}
@media(max-width:960px){.nav-links{display:none;}.two-col,.estimate-wrap,.content-block{grid-template-columns:1fr;gap:2.5rem;}.services-grid{grid-template-columns:1fr 1fr;}.reviews-grid{grid-template-columns:1fr;}.stats-strip{grid-template-columns:1fr 1fr;}.footer-grid{grid-template-columns:1fr 1fr;}.photo-strip{grid-template-columns:repeat(2,1fr);}}
@media(max-width:600px){section{padding:55px 1.25rem;}#navbar{padding:0 1.25rem;}.services-grid{grid-template-columns:1fr;}.footer-grid{grid-template-columns:1fr;}}

/* ================================================
   POWER WASHING PAGE
   ================================================ */

.page-hero-img {
  position: relative;
  min-height: 55vh;
  display: flex;
  align-items: center;
  padding: 80px 2rem 60px;
  overflow: hidden;
}

/* Image set via inline style in PHP — gradient overlay handled separately by ::after */
.page-hero-img-bg {
  position: absolute;
  inset: 0;
  background-color: var(--navy);
  background-size: cover;
  background-position: center top;
}

/* Navy gradient overlay — same as homepage hero */
.page-hero-img-bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(105deg, rgba(13,27,46,.92) 0%, rgba(13,27,46,.72) 50%, rgba(13,27,46,.30) 100%);
}

.page-hero-img-inner {
  position: relative;
  z-index: 2;
  max-width: 700px;
}

.page-hero-img h1 {
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(28px, 4.5vw, 52px);
  font-weight: 800;
  line-height: 1.1;
  color: var(--white);
  margin-bottom: 1rem;
  text-transform: uppercase;
}

.page-hero-img h1 span { color: var(--gold); }

.page-hero-img p {
  font-size: 16px;
  color: rgba(255,255,255,.7);
  line-height: 1.8;
  max-width: 560px;
}

.before-after-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}

.before-after-card {
  position: relative;
  border-radius: 6px;
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(0,0,0,.1);
}

.before-after-card img {
  width: 100%;
  height: 340px;
  object-fit: cover;
  display: block;
}

.ba-label {
  position: absolute;
  top: 14px;
  left: 14px;
  padding: 5px 14px;
  border-radius: 3px;
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  z-index: 2;
}

.ba-label--before {
  background: rgba(196,30,58,.9);
  color: var(--white);
}

.ba-label--after {
  background: rgba(13,27,46,.88);
  color: var(--gold);
  border: 1px solid var(--gold);
}

@media (max-width: 768px) {
  .before-after-grid { grid-template-columns: 1fr; }
  .before-after-card img { height: 260px; }
}
/* ================================================
   ABOUT PAGE TEAM GRID — append to assets/theme.css
   ================================================ */

.team-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1.5rem;
}

.team-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 2rem;
  text-align: center;
}

.team-photo {
  width: 100%;
  height: 220px;
  object-fit: cover;
  object-position: top;
  border-radius: 4px;
  display: block;
  margin-bottom: 1rem;
}

.team-photo-placeholder {
  min-height: 220px;
  margin-bottom: 1rem;
}

.team-name {
  font-family: 'Montserrat', sans-serif;
  font-size: 16px;
  font-weight: 800;
  color: var(--navy);
  text-transform: uppercase;
  margin-bottom: .25rem;
}

.team-title {
  font-size: 12px;
  color: var(--crimson);
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-family: 'Montserrat', sans-serif;
}

.team-note {
  font-size: 12px;
  color: var(--text-light);
  margin-top: .5rem;
  font-style: italic;
}
/* ================================================
   RESIDENTIAL PAGE — append to assets/theme.css
   ================================================ */

/* Flip two-col order on exterior section for text-left layout */
.two-col--reverse {
  direction: rtl;
}
.two-col--reverse > * {
  direction: ltr;
}

/* Gallery section */
.gallery-section {
  padding-bottom: 60px;
}

.slider-wrap {
  position: relative;
  overflow: hidden;
  padding: 0 0 48px;
}

.slider-track {
  display: flex;
  transition: transform 0.5s ease;
  will-change: transform;
}

.slide {
  min-width: calc(100% / 3);
  padding: 0 8px;
  box-sizing: border-box;
}

.slide img {
  width: 100%;
  height: 280px;
  object-fit: cover;
  border-radius: 6px;
  display: block;
}

.slider-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-60%);
  background: var(--navy);
  color: var(--white);
  border: none;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  font-size: 18px;
  cursor: pointer;
  z-index: 10;
  transition: background .2s;
  display: flex;
  align-items: center;
  justify-content: center;
}

.slider-btn:hover {
  background: var(--crimson);
}

.slider-btn--prev { left: 12px; }
.slider-btn--next { right: 12px; }

.slider-dots {
  display: flex;
  justify-content: center;
  gap: 8px;
  position: absolute;
  bottom: 16px;
  width: 100%;
}

.slider-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--mid-gray);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background .2s;
}

.slider-dot.active {
  background: var(--crimson);
  width: 24px;
  border-radius: 4px;
}

/* ================================================
   GLOBAL MOBILE FIXES
   ================================================ */

@media (max-width: 960px) {
  /* Two col stacks */
  .two-col--reverse {
    direction: ltr;
  }

  /* Slider shows 2 slides */
  .slide {
    min-width: 50%;
  }

  /* Page hero text sizing */
  .page-hero-img h1 {
    font-size: clamp(24px, 5vw, 40px);
  }

  /* Team grid */
  .team-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 600px) {
  /* Slider shows 1 slide */
  .slide {
    min-width: 100%;
  }

  /* Slider buttons repositioned */
  .slider-btn {
    width: 36px;
    height: 36px;
    font-size: 14px;
  }

  /* Hero padding tighter on mobile */
  .page-hero-img {
    padding: 60px 1.25rem 40px;
    min-height: 45vh;
  }

  /* Page hero plain */
  .page-hero {
    padding: 60px 1.25rem 40px;
  }

  /* Team grid single col on small screens */
  .team-grid {
    grid-template-columns: 1fr;
  }

  /* Before after stacks */
  .before-after-grid {
    grid-template-columns: 1fr;
  }

  /* CTA band padding */
  .cta-band {
    padding: 2.5rem 1.25rem;
  }

  /* Stats strip 2 col */
  .stats-strip {
    grid-template-columns: 1fr 1fr;
  }

  /* Brands row */
  .brands-row {
    gap: 1rem;
  }

  .brand-item {
    min-width: 120px;
    padding: 1rem;
  }

  /* Reviews */
  .reviews-grid {
    grid-template-columns: 1fr;
  }

  /* Footer */
  .footer-grid {
    grid-template-columns: 1fr;
    gap: 2rem;
  }

  /* Form box */
  .form-box {
    padding: 1.5rem;
  }

  /* Estimate wrap */
  .estimate-wrap {
    grid-template-columns: 1fr;
    gap: 2rem;
  }

  /* Nav top bar wraps */
  .top-bar {
    gap: 1rem;
    padding: 6px 1rem;
    font-size: 11px;
  }
}
/* ================================================
   SPECIALTY FINISHES PAGE — append to assets/theme.css
   ================================================ */

.specialty-card-img {
  width: 100%;
  height: 200px;
  object-fit: cover;
  border-radius: 4px;
  display: block;
  margin-bottom: 1.25rem;
}
/* ================================================
   HEADER UPDATES — append to assets/theme.css
   ================================================ */

/* Social icons in nav */
.nav-socials {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-right: 8px;
}

.nav-social-icon {
  color: rgba(255,255,255,.55);
  display: flex;
  align-items: center;
  transition: color .2s;
}

.nav-social-icon:hover { color: var(--gold); }

/* Hamburger button — hidden on desktop */
.nav-hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px;
  margin-left: 12px;
}

.nav-hamburger span {
  display: block;
  width: 24px;
  height: 2px;
  background: var(--white);
  border-radius: 2px;
  transition: all .2s;
}

/* Mobile nav drawer */
.mobile-nav {
  position: fixed;
  top: 0;
  right: -100%;
  width: 300px;
  max-width: 85vw;
  height: 100vh;
  background: var(--navy);
  z-index: 2000;
  transition: right .3s ease;
  overflow-y: auto;
  padding-top: 60px;
}

.mobile-nav.open { right: 0; }

.mobile-nav-close {
  position: absolute;
  top: 16px;
  right: 16px;
  background: none;
  border: none;
  color: var(--white);
  font-size: 20px;
  cursor: pointer;
  padding: 4px 8px;
}

.mobile-nav-links {
  list-style: none;
  padding: 0 0 1rem;
}

.mobile-nav-links li {
  border-bottom: 1px solid rgba(255,255,255,.08);
}

.mobile-nav-links li a,
.mobile-nav-parent {
  display: block;
  width: 100%;
  padding: 14px 1.5rem;
  color: rgba(255,255,255,.85);
  text-decoration: none;
  font-size: 14px;
  font-weight: 600;
  font-family: 'Montserrat', sans-serif;
  letter-spacing: .03em;
  background: none;
  border: none;
  text-align: left;
  cursor: pointer;
  transition: color .2s;
}

.mobile-nav-links li a:hover,
.mobile-nav-parent:hover { color: var(--gold); }

.mobile-submenu {
  display: none;
  background: rgba(255,255,255,.04);
  list-style: none;
}

.mobile-submenu.open { display: block; }

.mobile-submenu li a {
  padding: 11px 2rem;
  font-size: 13px;
  font-weight: 500;
  color: rgba(255,255,255,.65);
}

.mobile-nav-phone {
  color: var(--gold) !important;
  font-weight: 700 !important;
}

.mobile-nav-socials {
  display: flex;
  gap: 16px;
  padding: 14px 1.5rem;
}

.mobile-nav-socials a {
  color: rgba(255,255,255,.5);
  display: flex;
  align-items: center;
  transition: color .2s;
  border-bottom: none !important;
  padding: 0 !important;
}

.mobile-nav-socials a:hover { color: var(--gold); }

/* Overlay */
.mobile-nav-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.5);
  z-index: 1999;
}

.mobile-nav-overlay.open { display: block; }

/* Show hamburger, hide desktop nav on mobile */
@media (max-width: 960px) {
  .nav-links { display: none; }
  .nav-socials { display: none; }
  .nav-phone { display: none; }
  .nav-hamburger { display: flex; }
  .nav-logo img { height: 36px; }
}

@media (max-width: 600px) {
  .top-bar { font-size: 11px; gap: .75rem; padding: 6px 1rem; }
  .top-bar .top-bar-sep { display: none; }
  .nav-cta { font-size: 11px; padding: 8px 14px; }
}
/* ================================================
   CONTACT PAGE — append to assets/theme.css
   ================================================ */

.contact-hero-inner {
  text-align: center;
  max-width: 800px;
  margin: 0 auto;
}

.contact-hero-btns {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 2rem;
}

.contact-info-list {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  margin-top: 2rem;
}

.contact-info-row {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
}

.contact-icon { font-size: 22px; flex-shrink: 0; margin-top: 2px; }

.contact-label {
  font-weight: 700;
  color: var(--navy);
  font-family: 'Montserrat', sans-serif;
  margin-bottom: .25rem;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: .05em;
}

.contact-value {
  color: var(--crimson);
  font-size: 22px;
  font-weight: 800;
  font-family: 'Montserrat', sans-serif;
  text-decoration: none;
}

.contact-text {
  color: var(--text-mid);
  font-size: 14px;
  line-height: 1.7;
}

.contact-tip-box {
  margin-top: 2rem;
  padding: 1.25rem 1.5rem;
  background: var(--navy);
  border-radius: 6px;
}

.contact-tip-box p {
  font-size: 13px;
  color: rgba(255,255,255,.75);
  line-height: 1.7;
}

.contact-tip-box strong { color: var(--white); }

/* Service area grid */
.service-area-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
}

.service-area-card {
  background: var(--off-white);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 1.5rem;
}

.service-area-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 1rem;
  padding-bottom: .75rem;
  border-bottom: 2px solid var(--crimson);
}

.service-area-icon { font-size: 16px; }

.service-area-header h3 {
  font-family: 'Montserrat', sans-serif;
  font-size: 14px;
  font-weight: 800;
  color: var(--navy);
  text-transform: uppercase;
  letter-spacing: .02em;
}

.service-area-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: .5rem;
}

.service-area-list li {
  font-size: 13px;
  color: var(--text-mid);
  padding-left: 1rem;
  position: relative;
  font-weight: 500;
}

.service-area-list li::before {
  content: '✓';
  position: absolute;
  left: 0;
  color: var(--crimson);
  font-size: 11px;
  font-weight: 800;
  top: 2px;
}

/* Mobile */
@media (max-width: 960px) {
  .service-area-grid { grid-template-columns: 1fr 1fr; }
  .contact-hero-btns { flex-direction: column; align-items: center; }
}

@media (max-width: 600px) {
  .service-area-grid { grid-template-columns: 1fr; }
  .contact-value { font-size: 18px; }
}
/* ================================================
   HOMEPAGE UPDATES — append to assets/theme.css
   ================================================ */

/* Brand items with actual logos */
.brand-item--logo {
  text-decoration: none;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .5rem;
  transition: transform .2s, box-shadow .2s;
}

.brand-item--logo:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0,0,0,.08);
}

.brand-item--logo img {
  height: 48px;
  width: auto;
  object-fit: contain;
  display: block;
}

/* Photo strip with real images */
.photo-tile {
  background-color: var(--light-gray);
}
/* ============================================================
   BLOG — template-blog.php + single.php
   Append to assets/theme.css
   ============================================================ */

/* --- Blog Index Grid --- */
.blog-index-section {
    padding: 64px 0 80px;
    background: #f8f8f6;
}

.blog-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
    margin-bottom: 48px;
}

.blog-grid--3 {
    grid-template-columns: repeat(3, 1fr);
}

/* --- Blog Card --- */
.blog-card {
    background: #fff;
    border-radius: 6px;
    overflow: hidden;
    box-shadow: 0 2px 12px rgba(13,27,46,0.08);
    display: flex;
    flex-direction: column;
    transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.blog-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 28px rgba(13,27,46,0.14);
}

.blog-card__image-wrap {
    display: block;
    overflow: hidden;
    aspect-ratio: 16 / 9;
}

.blog-card__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.35s ease;
}

.blog-card:hover .blog-card__image {
    transform: scale(1.04);
}

.blog-card__image-wrap--placeholder {
    background: #0d1b2e;
    display: flex;
    align-items: center;
    justify-content: center;
}

.blog-card__placeholder {
    color: #b89a5a;
    font-family: 'Montserrat', sans-serif;
    font-weight: 700;
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding: 32px 16px;
    text-align: center;
}

.blog-card__body {
    padding: 24px;
    display: flex;
    flex-direction: column;
    flex: 1;
}

.blog-card__meta {
    display: flex;
    gap: 12px;
    align-items: center;
    margin-bottom: 10px;
}

.blog-card__date {
    font-size: 0.78rem;
    color: #777;
    font-family: 'Open Sans', sans-serif;
}

.blog-card__cat {
    font-size: 0.72rem;
    font-family: 'Montserrat', sans-serif;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    color: #fff;
    background: #c41e3a;
    padding: 2px 8px;
    border-radius: 3px;
}

.blog-card__title {
    font-family: 'Montserrat', sans-serif;
    font-size: 1.05rem;
    font-weight: 700;
    line-height: 1.35;
    margin: 0 0 10px;
}

.blog-card__title a {
    color: #0d1b2e;
    text-decoration: none;
    transition: color 0.2s;
}

.blog-card__title a:hover {
    color: #c41e3a;
}

.blog-card__excerpt {
    font-size: 0.9rem;
    color: #555;
    line-height: 1.65;
    flex: 1;
    margin-bottom: 16px;
}

.blog-card__read-more {
    font-family: 'Montserrat', sans-serif;
    font-size: 0.82rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: #c41e3a;
    text-decoration: none;
    margin-top: auto;
    transition: color 0.2s;
}

.blog-card__read-more:hover {
    color: #0d1b2e;
}

/* --- Pagination --- */
.blog-pagination {
    display: flex;
    justify-content: center;
    gap: 8px;
    flex-wrap: wrap;
    margin-top: 16px;
}

.blog-pagination .page-numbers {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 4px;
    font-family: 'Montserrat', sans-serif;
    font-size: 0.85rem;
    font-weight: 600;
    text-decoration: none;
    color: #0d1b2e;
    background: #fff;
    border: 1.5px solid #ddd;
    transition: all 0.2s;
}

.blog-pagination .page-numbers.current,
.blog-pagination .page-numbers:hover {
    background: #c41e3a;
    border-color: #c41e3a;
    color: #fff;
}

.blog-pagination .page-numbers.prev,
.blog-pagination .page-numbers.next {
    width: auto;
    padding: 0 16px;
}

/* --- Blog Empty State --- */
.blog-empty {
    text-align: center;
    padding: 80px 20px;
    color: #555;
}

.blog-empty h2 {
    font-family: 'Montserrat', sans-serif;
    color: #0d1b2e;
    margin-bottom: 12px;
}

/* ============================================================
   SINGLE POST
   ============================================================ */

.page-hero--post {
    min-height: 420px;
}

.post-hero__meta {
    display: flex;
    gap: 12px;
    align-items: center;
    justify-content: center;
    margin-bottom: 14px;
}

.post-hero__cat {
    font-family: 'Montserrat', sans-serif;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    background: #c41e3a;
    color: #fff;
    padding: 3px 10px;
    border-radius: 3px;
    text-decoration: none;
}

.post-hero__date {
    font-size: 0.82rem;
    color: rgba(255,255,255,0.75);
}

.post-hero__byline {
    margin-top: 14px;
    font-size: 0.88rem;
    color: rgba(255,255,255,0.8);
    font-family: 'Open Sans', sans-serif;
}

/* --- Single Post Layout --- */
.single-post-section {
    padding: 64px 0 80px;
    background: #f8f8f6;
}

.single-post-layout {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: 48px;
    align-items: start;
}

/* --- Post Content --- */
.post-content {
    background: #fff;
    border-radius: 6px;
    padding: 48px;
    box-shadow: 0 2px 12px rgba(13,27,46,0.07);
    min-width: 0;
}

.post-content h2,
.post-content h3,
.post-content h4 {
    font-family: 'Montserrat', sans-serif;
    color: #0d1b2e;
    margin-top: 1.8em;
    margin-bottom: 0.6em;
}

.post-content h2 { font-size: 1.55rem; }
.post-content h3 { font-size: 1.25rem; }
.post-content h4 { font-size: 1.05rem; }

.post-content p {
    font-size: 1rem;
    line-height: 1.8;
    color: #444;
    margin-bottom: 1.3em;
}

.post-content ul,
.post-content ol {
    padding-left: 1.5rem;
    margin-bottom: 1.3em;
    color: #444;
    line-height: 1.8;
}

.post-content ul li { list-style: disc; }
.post-content ol li { list-style: decimal; }

.post-content a {
    color: #c41e3a;
    text-decoration: underline;
}

.post-content img {
    max-width: 100%;
    border-radius: 4px;
    margin: 24px 0;
}

.post-content blockquote {
    border-left: 4px solid #b89a5a;
    margin: 32px 0;
    padding: 16px 24px;
    background: #f0ede6;
    border-radius: 0 4px 4px 0;
    font-style: italic;
    color: #555;
}

/* --- Post Footer --- */
.post-footer {
    margin-top: 48px;
    padding-top: 32px;
    border-top: 1px solid #eee;
}

.post-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 32px;
}

.post-tag {
    font-family: 'Montserrat', sans-serif;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: #0d1b2e;
    border: 1.5px solid #0d1b2e;
    padding: 4px 12px;
    border-radius: 3px;
    text-decoration: none;
    transition: all 0.2s;
}

.post-tag:hover {
    background: #0d1b2e;
    color: #fff;
}

/* --- Post Navigation --- */
.post-nav {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
}

.post-nav__prev,
.post-nav__next {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.post-nav__next {
    text-align: right;
}

.post-nav__label {
    font-size: 0.75rem;
    font-family: 'Montserrat', sans-serif;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    color: #999;
}

.post-nav a {
    font-family: 'Montserrat', sans-serif;
    font-size: 0.9rem;
    font-weight: 600;
    color: #0d1b2e;
    text-decoration: none;
    transition: color 0.2s;
}

.post-nav a:hover { color: #c41e3a; }

/* --- Sidebar --- */
.post-sidebar {
    display: flex;
    flex-direction: column;
    gap: 24px;
    position: sticky;
    top: 100px;
}

.sidebar-card {
    background: #fff;
    border-radius: 6px;
    padding: 28px;
    box-shadow: 0 2px 12px rgba(13,27,46,0.07);
}

.sidebar-card--about {
    text-align: center;
}

.sidebar-card__photo {
    width: 90px;
    height: 90px;
    border-radius: 50%;
    object-fit: cover;
    border: 3px solid #b89a5a;
    margin-bottom: 12px;
}

.sidebar-card h3 {
    font-family: 'Montserrat', sans-serif;
    font-size: 1rem;
    font-weight: 700;
    color: #0d1b2e;
    margin: 0 0 4px;
}

.sidebar-card__role {
    font-size: 0.8rem;
    color: #c41e3a;
    font-family: 'Montserrat', sans-serif;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 10px;
}

.sidebar-card p {
    font-size: 0.88rem;
    color: #555;
    line-height: 1.65;
    margin-bottom: 14px;
}

.sidebar-services-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.sidebar-services-list li {
    border-bottom: 1px solid #f0f0f0;
}

.sidebar-services-list li:last-child { border-bottom: none; }

.sidebar-services-list a {
    display: block;
    padding: 9px 0;
    font-size: 0.9rem;
    color: #0d1b2e;
    text-decoration: none;
    font-family: 'Open Sans', sans-serif;
    transition: color 0.2s, padding-left 0.2s;
}

.sidebar-services-list a:hover {
    color: #c41e3a;
    padding-left: 6px;
}

.sidebar-card--area p {
    margin-bottom: 0;
}

.btn--full {
    display: block;
    width: 100%;
    text-align: center;
    margin-bottom: 8px;
}

/* --- Related Posts --- */
.related-posts-section {
    padding: 64px 0;
    background: #fff;
}

.related-posts-section .section-title {
    font-family: 'Montserrat', sans-serif;
    font-size: 1.6rem;
    color: #0d1b2e;
    margin-bottom: 32px;
    text-align: center;
}

/* ============================================================
   RESPONSIVE — BLOG
   ============================================================ */

@media (max-width: 1024px) {
    .single-post-layout {
        grid-template-columns: 1fr;
    }
    .post-sidebar {
        position: static;
    }
    .blog-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 640px) {
    .blog-grid,
    .blog-grid--3 {
        grid-template-columns: 1fr;
    }
    .post-content {
        padding: 28px 20px;
    }
    .post-nav {
        grid-template-columns: 1fr;
    }
    .post-nav__next {
        text-align: left;
    }
}