@import url('https://fonts.googleapis.com/css2?family=DM+Serif+Display&family=Nunito+Sans:wght@400;600;700;800&display=swap');
:root{
  --brick:#8B2D1A;--brick-dark:#6B1F10;--brick-light:#A84632;
  --ember:#D4622B;--ember-glow:#E8913A;--amber:#F5A623;
  --cream:#FAF6F0;--warm-white:#FFF8F2;
  --charcoal:#1E1A17;--charcoal-mid:#2A2320;--smoke:#4A4440;--ash:#7A7570;
  --stone:#C4BEB8;--stone-light:#E8E2DC;
  --forest:#2E5339;--gold:#C8952E;
  --shadow-sm:0 1px 3px rgba(42,35,32,.08);--shadow-md:0 4px 16px rgba(42,35,32,.1);
  --shadow-lg:0 8px 32px rgba(42,35,32,.14);--shadow-xl:0 16px 48px rgba(42,35,32,.18);
  --radius-sm:6px;--radius-md:12px;--radius-lg:20px;
  --font-display:'DM Serif Display',Georgia,serif;
  --font-body:'Nunito Sans',-apple-system,sans-serif;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);color:var(--charcoal);background:var(--cream);line-height:1.7;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}

@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
.anim{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease}
.anim.vis{opacity:1;transform:translateY(0)}

.container{max-width:1200px;margin:0 auto;padding:0 24px}
.section-label{font-weight:800;font-size:.75rem;letter-spacing:3px;text-transform:uppercase;color:var(--ember);margin-bottom:12px}
.section-title{font-family:var(--font-display);font-size:clamp(2rem,4vw,3rem);color:var(--charcoal);line-height:1.2;margin-bottom:16px}
.section-sub{font-size:1.1rem;color:var(--ash);max-width:600px;line-height:1.7}

/* TOP BAR */
.top-bar{background:var(--charcoal);color:var(--stone);font-size:.85rem;padding:8px 0}
.top-bar .container{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}
.top-bar a{color:var(--ember-glow);font-weight:700;transition:color .3s}
.top-bar a:hover{color:#fff}

/* HEADER */
header{background:var(--warm-white);border-bottom:1px solid var(--stone-light);position:sticky;top:0;z-index:100;box-shadow:var(--shadow-sm)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.logo{display:flex;align-items:center;gap:14px}
.logo-img{width:52px;height:52px;border-radius:var(--radius-md);object-fit:contain}
.logo-text h1{font-family:var(--font-display);font-size:1.5rem;color:var(--charcoal);line-height:1.1}
.logo-text span{font-size:.75rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--ash)}
nav{display:flex;align-items:center;gap:4px}
nav a{font-weight:700;font-size:.86rem;color:var(--smoke);padding:8px 12px;border-radius:var(--radius-sm);transition:all .3s}
nav a:hover{color:var(--brick);background:rgba(139,45,26,.06)}
nav a.active{color:var(--brick);background:rgba(139,45,26,.08)}
.nav-cta{background:var(--brick)!important;color:#fff!important;padding:10px 20px!important;border-radius:var(--radius-sm)!important}
.nav-cta:hover{background:var(--brick-dark)!important;transform:translateY(-1px);box-shadow:var(--shadow-md)}
.nav-book{background:var(--ember)!important;color:#fff!important;padding:10px 20px!important;border-radius:var(--radius-sm)!important;box-shadow:0 2px 10px rgba(212,98,43,.3)}
.nav-book:hover{background:var(--ember-glow)!important;transform:translateY(-1px)}
.mobile-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px}
.mobile-toggle span{display:block;width:24px;height:2px;background:var(--charcoal);margin:6px 0;border-radius:2px}

/* HERO — gradient only, no photo */
.hero{position:relative;min-height:88vh;display:flex;align-items:center;overflow:hidden;background:var(--charcoal)}
.hero-pattern{position:absolute;inset:0;opacity:.06;background-image:
  repeating-linear-gradient(0deg,transparent,transparent 40px,rgba(255,255,255,.08) 40px,rgba(255,255,255,.08) 41px),
  repeating-linear-gradient(90deg,transparent,transparent 40px,rgba(255,255,255,.08) 40px,rgba(255,255,255,.08) 41px)}
.hero-glow{position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(232,145,58,.12),transparent 70%);right:-100px;top:-100px}
.hero-glow2{position:absolute;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(212,98,43,.08),transparent 70%);left:10%;bottom:-50px}
.hero .container{position:relative;z-index:2}
.hero-content{max-width:700px;padding:60px 0;animation:fadeUp 1s ease}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);padding:8px 18px;border-radius:100px;font-size:.8rem;font-weight:700;color:var(--ember-glow);margin-bottom:28px;letter-spacing:1px;text-transform:uppercase}
.hero h2{font-family:var(--font-display);font-size:clamp(2.8rem,6vw,4.5rem);color:#fff;line-height:1.08;margin-bottom:24px}
.hero h2 em{font-style:normal;color:var(--ember-glow)}
.hero-desc{font-size:1.15rem;color:rgba(255,255,255,.65);line-height:1.8;margin-bottom:36px;max-width:540px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hero-stats{display:flex;gap:40px;margin-top:50px;padding-top:40px;border-top:1px solid rgba(255,255,255,.1)}
.hero-stat strong{display:block;font-family:var(--font-display);font-size:2rem;color:#fff}
.hero-stat span{font-size:.8rem;font-weight:700;color:rgba(255,255,255,.45);text-transform:uppercase;letter-spacing:1.5px}

/* PAGE HERO — gradient, no photo */
.page-hero{padding:80px 0 60px;text-align:center;position:relative;overflow:hidden;background:linear-gradient(145deg,var(--charcoal) 0%,#2E2318 40%,var(--brick-dark) 100%)}
.page-hero .hero-pattern{position:absolute;inset:0;opacity:.05;background-image:
  repeating-linear-gradient(0deg,transparent,transparent 40px,rgba(255,255,255,.08) 40px,rgba(255,255,255,.08) 41px),
  repeating-linear-gradient(90deg,transparent,transparent 40px,rgba(255,255,255,.08) 40px,rgba(255,255,255,.08) 41px)}
.page-hero .container{position:relative;z-index:2}
.page-hero h1{font-family:var(--font-display);font-size:clamp(2.2rem,4.5vw,3.2rem);color:#fff;margin-bottom:16px}
.page-hero p{font-size:1.1rem;color:rgba(255,255,255,.6);max-width:600px;margin:0 auto}
.page-hero .breadcrumb{margin-bottom:16px;font-size:.85rem;color:rgba(255,255,255,.4)}
.page-hero .breadcrumb a{color:var(--ember-glow)}

/* BUTTONS */
.btn-primary{display:inline-flex;align-items:center;gap:10px;background:var(--ember);color:#fff;font-family:var(--font-body);font-weight:800;font-size:1rem;padding:16px 32px;border-radius:var(--radius-sm);border:none;cursor:pointer;transition:all .3s;box-shadow:0 4px 16px rgba(212,98,43,.35)}
.btn-primary:hover{background:var(--ember-glow);transform:translateY(-2px);box-shadow:0 6px 24px rgba(212,98,43,.45)}
.btn-primary svg,.btn-primary i{width:18px;height:18px;font-size:18px}
.btn-secondary{display:inline-flex;align-items:center;gap:10px;color:rgba(255,255,255,.9);font-weight:700;font-size:1rem;padding:16px 24px;border:2px solid rgba(255,255,255,.2);border-radius:var(--radius-sm);transition:all .3s}
.btn-secondary:hover{border-color:rgba(255,255,255,.5);background:rgba(255,255,255,.05)}
.btn-brick{display:inline-flex;align-items:center;gap:10px;background:var(--brick);color:#fff;font-weight:700;font-size:1rem;padding:14px 28px;border-radius:var(--radius-sm);border:none;cursor:pointer;transition:all .3s}
.btn-brick:hover{background:var(--brick-dark);transform:translateY(-1px)}
.btn-book{display:inline-flex;align-items:center;gap:10px;background:var(--ember);color:#fff;font-weight:800;font-size:1rem;padding:16px 32px;border-radius:var(--radius-sm);border:none;cursor:pointer;transition:all .3s;box-shadow:0 4px 16px rgba(212,98,43,.35)}
.btn-book:hover{background:var(--ember-glow);transform:translateY(-2px)}

/* TRUST BAR */
.trust-bar{background:var(--warm-white);border-bottom:1px solid var(--stone-light);padding:28px 0}
.trust-items{display:flex;justify-content:center;align-items:center;gap:48px;flex-wrap:wrap}
.trust-item{display:flex;align-items:center;gap:12px;font-weight:700;font-size:.9rem;color:var(--smoke)}
.trust-icon{width:42px;height:42px;background:var(--cream);border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid var(--stone-light)}
.trust-icon svg{width:20px;height:20px;color:var(--brick)}

/* ===== ICON SERVICE CARDS (no photos) ===== */
.icon-card{background:var(--charcoal-mid);border-radius:var(--radius-lg);overflow:hidden;transition:all .4s;position:relative}
.icon-card:hover{transform:translateY(-6px);box-shadow:0 12px 40px rgba(0,0,0,.2)}
.icon-card-top{height:160px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.icon-card-top.sweep{background:linear-gradient(135deg,#2E2318,#4A3020)}
.icon-card-top.inspect{background:linear-gradient(135deg,#1E2A35,#2A3D4E)}
.icon-card-top.repair{background:linear-gradient(135deg,#2A2118,#4A3520)}
.icon-card-top.cap{background:linear-gradient(135deg,#2A2620,#3D3428)}
.icon-card-top.reline{background:linear-gradient(135deg,#2E2020,#4A2E2E)}
.icon-card-top.waterproof{background:linear-gradient(135deg,#1E2830,#2A3840)}
.icon-card-top.dryer{background:linear-gradient(135deg,#302518,#4E3820)}
.icon-card-top.lock{background:linear-gradient(135deg,#252030,#3A2E48)}
.icon-card-top svg{width:56px;height:56px;color:var(--ember-glow);opacity:.9;filter:drop-shadow(0 4px 12px rgba(232,145,58,.3))}
.icon-card-top::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at center,rgba(232,145,58,.06),transparent 70%)}
.icon-card-body{padding:24px;background:var(--warm-white)}
.icon-card h3{font-family:var(--font-display);font-size:1.15rem;color:var(--charcoal);margin-bottom:8px}
.icon-card p{font-size:.9rem;color:var(--ash);line-height:1.7}

/* Simple card (no image, white bg) */
.card{background:var(--warm-white);border-radius:var(--radius-lg);padding:40px 32px;border:1px solid var(--stone-light);transition:all .4s;position:relative;overflow:hidden}
.card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--brick),var(--ember));transform:scaleX(0);transition:transform .4s;transform-origin:left}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:transparent}
.card:hover::before{transform:scaleX(1)}
.card h3{font-family:var(--font-display);font-size:1.3rem;color:var(--charcoal);margin-bottom:12px}
.card p{font-size:.95rem;color:var(--ash);line-height:1.7}

/* PHOTO GALLERY PLACEHOLDERS */
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.gallery-placeholder{aspect-ratio:1/1;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--charcoal-mid),#3A302A);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;border:2px dashed rgba(255,255,255,.1);transition:all .3s}
.gallery-placeholder:hover{border-color:var(--ember);background:linear-gradient(135deg,#2E2318,#3A2A1E)}
.gallery-placeholder svg{width:40px;height:40px;color:rgba(255,255,255,.2)}
.gallery-placeholder span{color:rgba(255,255,255,.35);font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:1px}

/* CONTENT */
.content-section{padding:80px 0}
.content-section.alt{background:var(--warm-white)}
.content-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px}
.cities-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}
.city-tag{background:var(--warm-white);border:1px solid var(--stone-light);padding:10px 18px;border-radius:100px;font-size:.88rem;font-weight:600;color:var(--smoke);text-align:center;transition:all .3s}
.city-tag:hover{background:var(--brick);color:#fff;border-color:var(--brick)}

/* CTA — gradient, no photo */
.cta-section{padding:100px 0;text-align:center;position:relative;overflow:hidden;background:linear-gradient(135deg,var(--brick-dark) 0%,var(--brick) 40%,var(--ember) 100%)}
.cta-section::before{content:'';position:absolute;inset:0;background-image:
  repeating-linear-gradient(0deg,transparent,transparent 60px,rgba(255,255,255,.02) 60px,rgba(255,255,255,.02) 61px),
  repeating-linear-gradient(90deg,transparent,transparent 60px,rgba(255,255,255,.02) 60px,rgba(255,255,255,.02) 61px)}
.cta-section .container{position:relative;z-index:2}
.cta-section .section-label{color:rgba(255,255,255,.7)}
.cta-section .section-title{color:#fff;font-size:clamp(2.2rem,4.5vw,3.2rem);max-width:700px;margin:0 auto 16px}
.cta-section .section-sub{color:rgba(255,255,255,.7);margin:0 auto 40px;max-width:500px}
.cta-phone{display:inline-flex;align-items:center;gap:14px;background:#fff;color:var(--brick);font-family:var(--font-display);font-size:1.8rem;padding:20px 40px;border-radius:var(--radius-md);box-shadow:var(--shadow-xl);transition:all .3s}
.cta-phone:hover{transform:translateY(-3px) scale(1.02)}
.cta-phone svg{width:28px;height:28px}
.cta-or{display:block;color:rgba(255,255,255,.4);font-size:.85rem;font-weight:700;margin:16px 0;text-transform:uppercase;letter-spacing:2px}
.cta-email{color:rgba(255,255,255,.9);font-weight:700;font-size:1.1rem;border-bottom:2px solid rgba(255,255,255,.3);padding-bottom:2px;transition:border-color .3s}
.cta-email:hover{border-color:#fff}
.cta-actions{display:flex;justify-content:center;gap:16px;flex-wrap:wrap;margin-top:20px}

/* BLOG */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:32px}
.blog-card{background:var(--warm-white);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--stone-light);transition:all .4s}
.blog-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:transparent}
.blog-card-icon{height:140px;display:flex;align-items:center;justify-content:center;position:relative}
.blog-card-icon.chimney-bg{background:linear-gradient(135deg,#2E2318,#4A3020)}
.blog-card-icon.dryer-bg{background:linear-gradient(135deg,#302518,#4E3820)}
.blog-card-icon.lock-bg{background:linear-gradient(135deg,#252030,#3A2E48)}
.blog-card-icon svg{width:44px;height:44px;color:var(--ember-glow);opacity:.8}
.blog-card-body{padding:24px 28px 28px}
.blog-card .tag{font-size:.72rem;font-weight:800;letter-spacing:2px;text-transform:uppercase;color:var(--ember);margin-bottom:8px;display:inline-block}
.blog-card h3{font-family:var(--font-display);font-size:1.15rem;margin-bottom:8px}
.blog-card h3 a:hover{color:var(--brick)}
.blog-card p{font-size:.9rem;color:var(--ash);line-height:1.7}
.blog-card .meta{font-size:.8rem;color:var(--stone);margin-top:12px}

/* ARTICLE */
.article-content{max-width:760px;margin:0 auto;padding:60px 0}
.article-content h2{font-family:var(--font-display);font-size:1.8rem;margin:40px 0 16px;color:var(--charcoal)}
.article-content p{font-size:1.05rem;line-height:1.85;color:var(--smoke);margin-bottom:20px}

/* CONTACT FORM */
.contact-form{max-width:600px}
.form-group{margin-bottom:20px}
.form-group label{display:block;font-weight:700;font-size:.9rem;margin-bottom:6px;color:var(--charcoal)}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:14px 18px;border:2px solid var(--stone-light);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:1rem;color:var(--charcoal);background:var(--warm-white);transition:border-color .3s;outline:none}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--brick)}
.form-group textarea{min-height:140px;resize:vertical}

/* FOOTER */
footer{background:var(--charcoal);color:rgba(255,255,255,.6);padding:60px 0 30px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px}
.footer-brand p{font-size:.9rem;line-height:1.7;margin-top:16px;max-width:300px}
.footer-col h4{font-family:var(--font-display);color:#fff;font-size:1.1rem;margin-bottom:16px}
.footer-col a{display:block;font-size:.9rem;color:rgba(255,255,255,.5);padding:4px 0;transition:color .3s}
.footer-col a:hover{color:var(--ember-glow)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;font-size:.82rem}

/* BOOKING MODAL */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(28,25,23,.6);backdrop-filter:blur(4px);z-index:1000;justify-content:center;align-items:center;padding:24px}
.modal-overlay.open{display:flex}
.modal{background:var(--warm-white);border-radius:var(--radius-lg);max-width:560px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl);animation:fadeUp .4s ease}
.modal-header{padding:28px 32px 0;display:flex;justify-content:space-between;align-items:flex-start}
.modal-header h2{font-family:var(--font-display);font-size:1.6rem}
.modal-close{background:none;border:none;font-size:1.6rem;color:var(--ash);cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .2s;line-height:1}
.modal-close:hover{color:var(--charcoal);background:var(--stone-light)}
.modal-body{padding:24px 32px 32px}
.modal-steps{display:flex;gap:8px;margin-bottom:24px}
.modal-step{flex:1;height:4px;border-radius:2px;background:var(--stone-light)}
.modal-step.active{background:var(--ember)}
.modal-step.done{background:var(--forest)}
.time-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.time-slot{padding:10px;text-align:center;border:2px solid var(--stone-light);border-radius:var(--radius-sm);font-weight:700;font-size:.88rem;cursor:pointer;transition:all .2s}
.time-slot:hover{border-color:var(--ember);color:var(--ember)}
.time-slot.selected{background:var(--ember);color:#fff;border-color:var(--ember)}
.modal-nav{display:flex;gap:12px;margin-top:20px}
.modal-nav button{flex:1;padding:14px;border-radius:var(--radius-sm);font-family:var(--font-body);font-weight:700;font-size:1rem;cursor:pointer;transition:all .3s}
.modal-nav .btn-back{background:var(--stone-light);color:var(--smoke);border:none}
.modal-nav .btn-next{background:var(--ember);color:#fff;border:none;box-shadow:0 2px 10px rgba(212,98,43,.3)}
.modal-nav .btn-next:hover{background:var(--ember-glow)}
.booking-success{text-align:center;padding:40px 20px}
.booking-success .check{width:64px;height:64px;border-radius:50%;background:var(--forest);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;color:#fff;font-size:2rem}
.booking-success h3{font-family:var(--font-display);font-size:1.5rem;margin-bottom:12px}
.booking-success p{color:var(--ash);line-height:1.7}

/* RESPONSIVE */
@media(max-width:900px){.content-grid{grid-template-columns:1fr;gap:40px}.footer-grid{grid-template-columns:1fr 1fr;gap:30px}.hero-stats{gap:24px}.gallery-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:700px){nav{display:none}.mobile-toggle{display:block}nav.open{display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:var(--warm-white);padding:16px 24px;border-bottom:1px solid var(--stone-light);box-shadow:var(--shadow-md);z-index:99}.hero{min-height:75vh}.hero-stats{flex-wrap:wrap;gap:20px}.trust-items{gap:24px}.services-grid{grid-template-columns:1fr}.footer-grid{grid-template-columns:1fr}.cta-phone{font-size:1.3rem;padding:16px 28px}.blog-grid{grid-template-columns:1fr}.cities-grid{grid-template-columns:repeat(2,1fr)}.time-grid{grid-template-columns:repeat(2,1fr)}.gallery-grid{grid-template-columns:repeat(2,1fr)}}

/* ===== REAL PHOTO SECTIONS ===== */
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(145deg,rgba(30,26,23,.82),rgba(107,31,16,.5),rgba(30,26,23,.7));z-index:1}
.page-hero .hero-bg{position:absolute;inset:0;z-index:0}
.page-hero .hero-bg img{width:100%;height:100%;object-fit:cover}
.page-hero .hero-overlay{position:absolute;inset:0;background:linear-gradient(145deg,rgba(30,26,23,.85),rgba(107,31,16,.55));z-index:1}
.content-img{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md)}
.content-img img{width:100%;height:100%;min-height:300px;object-fit:cover}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.gallery-item{border-radius:var(--radius-md);overflow:hidden;position:relative;aspect-ratio:1/1;cursor:pointer}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.gallery-item:hover img{transform:scale(1.06)}
.gallery-item::after{content:'';position:absolute;inset:0;background:linear-gradient(transparent 50%,rgba(28,25,23,.55));pointer-events:none;transition:opacity .3s}
.gallery-item:hover::after{opacity:.5}
.gallery-item span{position:absolute;bottom:12px;left:12px;color:#fff;font-size:.82rem;font-weight:700;z-index:2;opacity:0;transform:translateY(6px);transition:all .3s}
.gallery-item:hover span{opacity:1;transform:translateY(0)}
.before-after{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:20px}
.before-after .ba-item{border-radius:var(--radius-md);overflow:hidden;position:relative}
.before-after .ba-item img{width:100%;height:240px;object-fit:cover}
.before-after .ba-label{position:absolute;top:12px;left:12px;background:var(--charcoal);color:#fff;font-size:.72rem;font-weight:800;padding:4px 12px;border-radius:100px;letter-spacing:1px;text-transform:uppercase}
.before-after .ba-label.after{background:var(--forest)}
@media(max-width:900px){.gallery-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:700px){.gallery-grid{grid-template-columns:repeat(2,1fr)}.before-after{grid-template-columns:1fr}}


/* ===== PHOTO SERVICE CARDS ===== */
.photo-card{background:var(--warm-white);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--stone-light);transition:all .4s}
.photo-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.photo-card-img{height:200px;overflow:hidden}
.photo-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.photo-card:hover .photo-card-img img{transform:scale(1.05)}
.photo-card-body{padding:24px}
.photo-card h3{font-family:var(--font-display);font-size:1.15rem;color:var(--charcoal);margin-bottom:8px}
.photo-card p{font-size:.9rem;color:var(--ash);line-height:1.7}

/* ===== SLIM HERO (for service areas etc) ===== */
.slim-hero{padding:50px 0 40px;max-height:300px}
.slim-hero .hero-bg img{object-position:center 30%}

/* ===== HERO with full background image ===== */
.hero{position:relative;min-height:88vh;display:flex;align-items:center;overflow:hidden;background:var(--charcoal)}
.hero .hero-bg{position:absolute;inset:0;z-index:0}
.hero .hero-bg img{width:100%;height:100%;object-fit:cover}
.hero .hero-overlay{position:absolute;inset:0;background:linear-gradient(145deg,rgba(30,26,23,.7),rgba(60,30,15,.55),rgba(30,26,23,.65));z-index:1}
.hero .container{position:relative;z-index:2}

/* ===== Ensure all content images are properly constrained ===== */
.content-img img{max-height:500px}
.before-after .ba-item img{height:220px}
