/*
Theme Name: Valley Roofing CA
Theme URI: https://valleyroofingca.com
Description: Modern professional light theme with emerald green accents for Valley Roofing CA
Version: 2.0.0
Author: Claw
*/
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap');
:root{--primary:#059669;--primary-dark:#065F46;--primary-light:#10B981;--cta:#F97316;--cta-dark:#EA580C;--navy:#0F172A;--navy-light:#1E293B;--text:#1E293B;--text-light:#475569;--text-muted:#64748B;--white:#ffffff;--off-white:#F8FAFC;--green-tint:#F0FDF4;--light-gray:#E2E8F0;--border:rgba(0,0,0,0.08);--border-dark:rgba(255,255,255,0.1);--shadow:0 2px 20px rgba(0,0,0,0.08);--shadow-hover:0 8px 30px rgba(0,0,0,0.12);--shadow-lg:0 20px 60px rgba(0,0,0,0.15)}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Inter',-apple-system,sans-serif;color:var(--text);line-height:1.7;background:var(--white)}
h1,h2,h3,h4,h5,h6{font-family:'Inter',sans-serif;font-weight:700;color:var(--navy);line-height:1.2}
a{text-decoration:none;color:inherit}
img{max-width:100%;height:auto;display:block}
.container{max-width:1200px;margin:0 auto;padding:0 24px}
.center{text-align:center}

/* Top Bar */
.top-bar{background:var(--navy);color:rgba(255,255,255,0.7);padding:10px 0;font-size:13px;letter-spacing:0.3px;border-bottom:1px solid var(--border-dark)}
.top-bar .container{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}
.top-bar a{color:var(--primary-light);font-weight:600}
.top-bar span{color:rgba(255,255,255,0.7)}

/* Header */
.site-header{background:var(--white);padding:16px 0;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:1000;transition:all 0.3s;box-shadow:0 1px 3px rgba(0,0,0,0.05)}
.site-header .container{display:flex;justify-content:space-between;align-items:center}
.site-logo{font-size:22px;font-weight:900;color:var(--navy);letter-spacing:-0.5px}
.site-logo span{color:var(--primary)}
.header-phone a{display:flex;align-items:center;gap:8px;font-size:22px;font-weight:800;color:var(--primary);letter-spacing:-0.5px}
.header-cta{display:inline-flex;align-items:center;gap:8px;background:var(--cta);color:var(--white);padding:12px 28px;border-radius:6px;font-weight:700;font-size:15px;transition:all 0.2s}
.header-cta:hover{background:var(--cta-dark)}

/* Hero */
.hero{padding:120px 0 100px;background:linear-gradient(135deg,#0F172A 0%,#1E293B 50%,#0F172A 100%);position:relative;overflow:hidden;border-bottom:4px solid var(--primary)}
.hero::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="g" patternUnits="userSpaceOnUse" width="40" height="40"><path d="M0 40L40 0M-10 10L10-10M30 50L50 30" stroke="rgba(5,150,105,0.05)" stroke-width="1"/></pattern></defs><rect fill="url(%23g)" width="100" height="100"/></svg>');opacity:0.5}
.hero .container{position:relative;z-index:1;text-align:center;max-width:900px}
.hero-badge{display:inline-block;background:rgba(5,150,105,0.2);color:var(--primary-light);padding:10px 24px;border-radius:100px;font-size:13px;font-weight:600;margin-bottom:24px;border:1px solid rgba(5,150,105,0.3)}
.hero h1{font-size:56px;font-weight:900;margin-bottom:20px;line-height:1.1;color:#fff}
.hero h1 span{color:var(--primary-light)}
.hero > .container > p{font-size:20px;color:rgba(255,255,255,0.7);margin-bottom:40px;max-width:700px;margin-left:auto;margin-right:auto;line-height:1.8}
.hero-buttons{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-bottom:40px}
.hero-trust{display:flex;gap:32px;justify-content:center;flex-wrap:wrap}
.hero-trust-item{font-size:15px;font-weight:600;color:rgba(255,255,255,0.9)}
.hero-trust-item strong{color:var(--primary-light)}

/* Buttons */
.btn-primary{display:inline-flex;align-items:center;gap:10px;background:var(--cta);color:var(--white);padding:18px 42px;border-radius:6px;font-weight:700;font-size:17px;transition:all 0.2s;border:none;cursor:pointer}
.btn-primary:hover{background:var(--cta-dark);transform:translateY(-2px);box-shadow:0 8px 25px rgba(249,115,22,0.3)}
.btn-outline{display:inline-flex;align-items:center;gap:10px;background:transparent;color:var(--white);padding:18px 42px;border-radius:6px;font-weight:600;font-size:17px;border:2px solid rgba(255,255,255,0.3);transition:all 0.2s}
.btn-outline:hover{border-color:var(--primary-light);color:var(--primary-light)}

/* Stats Bar */
.stats-bar{background:var(--green-tint);padding:48px 0;border-bottom:1px solid var(--border)}
.stats-bar .container{display:flex;justify-content:space-around;text-align:center;flex-wrap:wrap;gap:24px}
.stat-item h3{font-size:42px;font-weight:900;color:var(--primary)}
.stat-item p{font-size:13px;color:var(--text-muted);margin-top:6px;text-transform:uppercase;letter-spacing:1.5px;font-weight:500}

/* Sections */
.section-header{margin-bottom:48px}
.section-header.center{text-align:center}
.section-tag{display:inline-block;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:2.5px;color:var(--primary);margin-bottom:12px}
.section-title{font-size:40px;font-weight:800;margin-bottom:16px;color:var(--navy)}
.section-subtitle{font-size:16px;color:var(--text-muted);max-width:600px;line-height:1.7;margin:0 auto}

/* Services */
.services{padding:100px 0;background:var(--white)}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.service-card{background:var(--white);border:1px solid var(--border);border-radius:16px;padding:44px 32px;transition:all 0.3s;position:relative;box-shadow:var(--shadow)}
.service-card:hover{box-shadow:var(--shadow-hover);border-color:var(--primary);transform:translateY(-6px)}
.service-card .icon{width:64px;height:64px;background:linear-gradient(135deg,rgba(5,150,105,0.1),rgba(5,150,105,0.2));border-radius:16px;display:flex;align-items:center;justify-content:center;margin-bottom:24px;font-size:28px}
.service-card h3{font-size:22px;margin-bottom:12px;color:var(--navy)}
.service-card p{font-size:15px;color:var(--text-muted);line-height:1.8;margin-bottom:20px}
.service-link{font-size:14px;font-weight:600;color:var(--primary);transition:color 0.2s}
.service-link:hover{color:var(--primary-dark)}

/* Why Choose */
.why-choose{padding:100px 0;background:var(--green-tint)}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.why-features{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.why-feature{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:28px;transition:all 0.3s;box-shadow:var(--shadow)}
.why-feature:hover{border-color:var(--primary);box-shadow:var(--shadow-hover)}
.why-feature .wf-icon{font-size:32px;margin-bottom:12px}
.why-feature h4{font-size:16px;margin-bottom:8px;color:var(--navy)}
.why-feature p{font-size:14px;color:var(--text-muted);line-height:1.7}

/* Process */
.our-process{padding:100px 0;background:var(--off-white)}
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px}
.process-step{text-align:center;padding:44px 24px;border-radius:16px;background:var(--white);border:1px solid var(--border);position:relative;transition:all 0.3s;box-shadow:var(--shadow)}
.process-step:hover{box-shadow:var(--shadow-hover);transform:translateY(-4px);border-color:var(--primary)}
.process-number{width:64px;height:64px;background:var(--primary);color:var(--white);font-size:26px;font-weight:800;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px}
.process-step h3{font-size:18px;margin-bottom:10px;color:var(--navy)}
.process-step p{font-size:14px;color:var(--text-muted);line-height:1.7}

/* Service Areas */
.service-areas{padding:100px 0;background:var(--white)}
.areas-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;margin-bottom:32px}
.area-col h4{font-size:14px;text-transform:uppercase;letter-spacing:1px;color:var(--primary);margin-bottom:12px}
.area-col ul{list-style:none}
.area-col li{font-size:14px;color:var(--text-muted);margin-bottom:8px;padding-left:16px;position:relative}
.area-col li::before{content:'›';position:absolute;left:0;color:var(--primary)}
.areas-note{text-align:center;font-size:16px;color:var(--text-muted);margin-top:32px}

/* Testimonials */
.testimonials{padding:100px 0;background:var(--green-tint)}
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.testimonial-card{background:var(--white);border:1px solid var(--border);border-radius:16px;padding:36px;transition:all 0.3s;box-shadow:var(--shadow)}
.testimonial-card:hover{box-shadow:var(--shadow-hover);border-color:var(--primary)}
.stars{color:var(--cta);font-size:18px;margin-bottom:16px;letter-spacing:2px}
.testimonial-card p{font-size:15px;color:var(--text-light);line-height:1.8;margin-bottom:20px;font-style:italic}
.testimonial-author strong{display:block;font-size:15px;color:var(--navy)}
.testimonial-author span{font-size:13px;color:var(--text-muted)}

/* FAQ */
.faq{padding:100px 0;background:var(--off-white)}
.faq-list{max-width:760px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--border);padding:24px 0}
.faq-q{display:flex;justify-content:space-between;align-items:center;cursor:pointer;font-weight:600;font-size:17px;color:var(--navy);transition:color 0.2s;gap:16px}
.faq-q:hover{color:var(--primary)}
.faq-q::after{content:'+';font-size:28px;color:var(--primary);font-weight:300;transition:transform 0.2s;flex-shrink:0}
.faq-item.open .faq-q::after{content:'−'}
.faq-a{max-height:0;overflow:hidden;transition:max-height 0.3s ease;color:var(--text-muted);font-size:15px;line-height:1.8}
.faq-item.open .faq-a{max-height:300px;padding-top:16px}

/* About */
.about-section{padding:100px 0;background:var(--white)}
.about-content{max-width:800px;margin:0 auto;text-align:center}
.about-content p{font-size:17px;color:var(--text-light);line-height:1.9;margin-bottom:20px}

/* CTA */
.cta-section{padding:100px 0;background:linear-gradient(135deg,#065F46 0%,#059669 50%,#065F46 100%);text-align:center;border-top:4px solid var(--primary-light);border-bottom:4px solid var(--primary-light)}
.cta-section h2{color:var(--white);font-size:44px;margin-bottom:16px}
.cta-section p{color:rgba(255,255,255,0.7);font-size:18px;margin-bottom:40px}
.cta-phone{font-size:36px;font-weight:900;color:var(--white);display:block;margin-bottom:32px;letter-spacing:-1px}

/* Footer */
.site-footer{background:var(--navy);color:rgba(255,255,255,0.5);padding:80px 0 30px;border-top:1px solid var(--border-dark)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:40px;margin-bottom:48px}
.footer-brand p{margin-top:16px;font-size:14px;line-height:1.7}
.footer-col h4{color:var(--white);font-size:14px;text-transform:uppercase;letter-spacing:1px;margin-bottom:20px}
.footer-col a{display:block;font-size:14px;margin-bottom:10px;transition:color 0.2s}
.footer-col a:hover{color:var(--primary-light)}
.footer-phone{font-size:20px!important;font-weight:700;color:var(--primary-light)!important}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.1);padding-top:24px;text-align:center;font-size:13px}

/* Mobile CTA */
.mobile-cta{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--cta);padding:14px;text-align:center;z-index:9999;box-shadow:0 -4px 20px rgba(0,0,0,0.2)}
.mobile-cta a{color:var(--white);font-weight:700;font-size:17px;display:flex;align-items:center;justify-content:center;gap:8px}

/* Responsive */
@media(max-width:1024px){
.services-grid{grid-template-columns:repeat(2,1fr)}
.process-grid{grid-template-columns:repeat(2,1fr)}
.areas-grid{grid-template-columns:repeat(2,1fr)}
.testimonials-grid{grid-template-columns:1fr}
}
@media(max-width:768px){
.top-bar .container{flex-direction:column;gap:4px;text-align:center}
.site-logo{font-size:18px}
.header-phone a{font-size:16px}
.header-cta{display:none}
.hero{padding:70px 0 60px}
.hero h1{font-size:32px}
.hero > .container > p{font-size:16px}
.btn-primary,.btn-outline{padding:14px 28px;font-size:15px;width:100%;justify-content:center}
.hero-buttons{flex-direction:column;align-items:center}
.hero-trust{flex-direction:column;align-items:center;gap:12px}
.stats-bar .container{flex-wrap:wrap}
.stat-item{flex:0 0 45%}
.services-grid{grid-template-columns:1fr}
.why-grid{grid-template-columns:1fr}
.why-features{grid-template-columns:1fr}
.process-grid{grid-template-columns:1fr}
.areas-grid{grid-template-columns:1fr}
.testimonials-grid{grid-template-columns:1fr}
.section-title{font-size:28px}
.footer-grid{grid-template-columns:1fr 1fr}
.mobile-cta{display:block}
body{padding-bottom:56px}
.cta-section h2{font-size:28px}
.cta-phone{font-size:24px}
}
@media(max-width:480px){
.hero h1{font-size:28px}
.stat-item{flex:0 0 100%}
.footer-grid{grid-template-columns:1fr}
}

/* Prevent horizontal scroll globally */
html, body { overflow-x: hidden; }

/* phone-fix-white - Force white text on CTA buttons */
.cta-button a, .cta-btn a, .hero-cta a, .btn-primary a,
a.cta-button, a.cta-btn, a.btn-primary, a.hero-cta,
.cta-button, .cta-btn, .btn-primary,
[style*="background"] a[href^="tel"],
a[href^="tel"].cta-button, a[href^="tel"].cta-btn,
a[href^="tel"].btn-primary, a[href^="tel"].hero-cta,
.hero-section a[href^="tel"], .cta-section a[href^="tel"],
button a[href^="tel"], .button a[href^="tel"] {
  color: #ffffff !important;
}
a[href^="tel"] {
  color: inherit;
}

/* ═══════════════════════════════════════════════════════════
   PREMIUM PAGE STYLES — Service + City Pages
   ═══════════════════════════════════════════════════════════ */

/* Page Hero */
.vr-page-hero{padding:100px 0 80px;background:linear-gradient(135deg,#0F172A 0%,#1E293B 50%,#0F172A 100%);position:relative;overflow:hidden;text-align:center;border-bottom:4px solid var(--primary)}
.vr-page-hero::before{content:'';position:absolute;inset:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="g" patternUnits="userSpaceOnUse" width="40" height="40"><path d="M0 40L40 0M-10 10L10-10M30 50L50 30" stroke="rgba(5,150,105,0.05)" stroke-width="1"/></pattern></defs><rect fill="url(%23g)" width="100" height="100"/></svg>');opacity:.5}
.vr-page-hero .container{position:relative;z-index:1;max-width:900px}
.vr-page-hero h1{font-size:48px;font-weight:900;color:#fff;margin-bottom:16px;line-height:1.1}
.vr-page-hero h1 span{color:var(--primary-light)}
.vr-hero-sub{font-size:18px;color:rgba(255,255,255,.7);margin-bottom:32px;line-height:1.7;max-width:680px;margin-left:auto;margin-right:auto}
.vr-hero-badge{display:inline-block;background:rgba(5,150,105,.2);color:var(--primary-light);padding:10px 24px;border-radius:100px;font-size:13px;font-weight:600;margin-bottom:20px;border:1px solid rgba(5,150,105,.3)}
.vr-hero-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-bottom:36px}
.vr-hero-trust-row{display:flex;gap:28px;justify-content:center;flex-wrap:wrap}
.vr-ht-item{font-size:14px;font-weight:600;color:rgba(255,255,255,.9)}
.vr-ht-item strong{color:var(--primary-light)}

/* Breadcrumbs */
.vr-breadcrumbs{margin-bottom:24px;font-size:13px;color:rgba(255,255,255,.5)}
.vr-breadcrumbs a{color:rgba(255,255,255,.6);text-decoration:none;transition:color .2s}
.vr-breadcrumbs a:hover{color:var(--primary-light)}
.vr-breadcrumbs span{margin:0 6px}
.vr-breadcrumbs .current{color:var(--primary-light)}

/* Stats Bar (page version) */
.vr-stats-bar{background:var(--green-tint);padding:40px 0;border-bottom:1px solid var(--border)}
.vr-stats-bar .container{display:flex;justify-content:space-around;text-align:center;flex-wrap:wrap;gap:20px}
.vr-stat h3{font-size:38px;font-weight:900;color:var(--primary)}
.vr-stat p{font-size:12px;color:var(--text-muted);margin-top:4px;text-transform:uppercase;letter-spacing:1.5px;font-weight:500}

/* Feature Cards */
.vr-features{padding:80px 0;background:var(--white)}
.vr-features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.vr-feature-card{background:var(--white);border:1px solid var(--border);border-radius:16px;padding:40px 28px;text-align:center;transition:all .3s;box-shadow:var(--shadow)}
.vr-feature-card:hover{box-shadow:var(--shadow-hover);border-color:var(--primary);transform:translateY(-4px)}
.vr-fc-icon{margin-bottom:20px}
.vr-feature-card h3{font-size:20px;margin-bottom:10px;color:var(--navy)}
.vr-feature-card p{font-size:15px;color:var(--text-muted);line-height:1.7}

/* Content Area */
.vr-content-area{padding:70px 0;background:var(--off-white)}
.vr-content-inner{max-width:860px;margin:0 auto;font-size:17px;color:var(--text-light);line-height:1.9}
.vr-content-inner h2{font-size:32px;color:var(--navy);margin:40px 0 16px;font-weight:800}
.vr-content-inner h3{font-size:24px;color:var(--navy);margin:32px 0 12px;font-weight:700}
.vr-content-inner p{margin-bottom:20px}
.vr-content-inner ul,.vr-content-inner ol{margin:0 0 24px 0;padding:0}
.vr-content-inner li{position:relative;padding-left:28px;margin-bottom:10px;list-style:none}
.vr-content-inner li::before{content:'✓';position:absolute;left:0;color:var(--primary);font-weight:700}
.vr-content-inner ol li{counter-increment:ol-counter;list-style:none}
.vr-content-inner ol{counter-reset:ol-counter}
.vr-content-inner ol li::before{content:counter(ol-counter) '.';color:var(--primary);font-weight:700}
.vr-content-inner a{color:var(--primary);font-weight:600;text-decoration:underline;text-decoration-color:rgba(5,150,105,.3);transition:text-decoration-color .2s}
.vr-content-inner a:hover{text-decoration-color:var(--primary)}
.vr-content-inner img{border-radius:12px;margin:24px 0;box-shadow:var(--shadow)}
.vr-content-inner blockquote{border-left:4px solid var(--primary);padding:20px 24px;background:var(--green-tint);border-radius:0 12px 12px 0;margin:24px 0;font-style:italic;color:var(--text-light)}

/* Mid CTA */
.vr-mid-cta{padding:70px 0;background:linear-gradient(135deg,#0F172A 0%,#1E293B 100%);text-align:center;border-top:3px solid var(--primary);border-bottom:3px solid var(--primary)}
.vr-mid-cta h2{color:#fff;font-size:36px;margin-bottom:14px;font-weight:800}
.vr-mid-cta p{color:rgba(255,255,255,.65);font-size:17px;margin-bottom:32px;max-width:600px;margin-left:auto;margin-right:auto}
.vr-mid-cta-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* Trust Badges */
.vr-trust-badges{padding:70px 0;background:var(--green-tint)}
.vr-badges-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.vr-badge-item{text-align:center;padding:32px 20px;background:var(--white);border:1px solid var(--border);border-radius:12px;transition:all .3s;box-shadow:var(--shadow)}
.vr-badge-item:hover{border-color:var(--primary);box-shadow:var(--shadow-hover);transform:translateY(-3px)}
.vr-badge-icon{font-size:36px;margin-bottom:12px}
.vr-badge-item h4{font-size:16px;color:var(--navy);margin-bottom:6px}
.vr-badge-item p{font-size:13px;color:var(--text-muted);line-height:1.6}

/* Page FAQ */
.vr-faq{padding:80px 0;background:var(--off-white)}
.vr-faq-list{max-width:760px;margin:0 auto}

/* Page Testimonials */
.vr-testimonials{padding:80px 0;background:var(--green-tint)}
.vr-test-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}

/* Related Services */
.vr-related{padding:80px 0;background:var(--white)}
.vr-related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.vr-related-card{display:block;background:var(--white);border:1px solid var(--border);border-radius:12px;padding:28px;text-decoration:none;color:inherit;transition:all .3s;box-shadow:var(--shadow)}
.vr-related-card:hover{border-color:var(--primary);box-shadow:var(--shadow-hover);transform:translateY(-3px)}
.vr-related-card h4{font-size:18px;color:var(--navy);margin-bottom:6px}
.vr-related-card span{font-size:14px;color:var(--primary);font-weight:600}

/* Final CTA */
.vr-final-cta{padding:80px 0;background:linear-gradient(135deg,#065F46 0%,#059669 50%,#065F46 100%);text-align:center;border-top:4px solid var(--primary-light);border-bottom:4px solid var(--primary-light)}
.vr-final-cta h2{color:#fff;font-size:40px;margin-bottom:14px;font-weight:800}
.vr-final-cta p{color:rgba(255,255,255,.7);font-size:17px;margin-bottom:32px}
.vr-cta-phone{font-size:34px;font-weight:900;color:#fff;display:block;margin-bottom:28px;letter-spacing:-1px;text-decoration:none}
.vr-cta-phone:hover{color:#fff}

/* ── Responsive ── */
@media(max-width:1024px){
    .vr-features-grid,.vr-test-grid,.vr-related-grid{grid-template-columns:repeat(2,1fr)}
    .vr-badges-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
    .vr-page-hero{padding:70px 0 60px}
    .vr-page-hero h1{font-size:30px}
    .vr-hero-sub{font-size:16px}
    .vr-hero-trust-row{flex-direction:column;gap:10px;align-items:center}
    .vr-hero-btns{flex-direction:column;align-items:center}
    .vr-hero-btns .btn-primary,.vr-hero-btns .btn-outline{width:100%;max-width:320px;justify-content:center}
    .vr-stats-bar .container{flex-wrap:wrap}
    .vr-stat{flex:0 0 45%}
    .vr-features-grid,.vr-test-grid,.vr-related-grid,.vr-badges-grid{grid-template-columns:1fr}
    .vr-mid-cta h2,.vr-final-cta h2{font-size:26px}
    .vr-cta-phone{font-size:24px}
    .vr-content-inner{font-size:16px}
    .vr-content-inner h2{font-size:26px}
}

/* ═══════════════════════════════════════════════════════════
   SERVICE CARD IMAGES — Real Photos Above Cards
   ═══════════════════════════════════════════════════════════ */
.service-card-img{width:100%;height:180px;overflow:hidden;border-radius:16px 16px 0 0;margin:-44px -32px 20px -32px;width:calc(100% + 64px)}
.service-card-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.4s ease}
.service-card:hover .service-card-img img{transform:scale(1.05)}
.service-card{padding-top:0!important}

/* Hero with real background photo */
.hero{background-size:cover!important;background-position:center!important}
.hero::before{background:none!important}

/* About section responsive */
@media(max-width:768px){
  .about-content{grid-template-columns:1fr!important;text-align:center!important}
  .about-image img{height:280px!important}
  .service-card-img{height:140px}
}

/* ═══════════════════════════════════════════════════════════
   PAGE HERO — Background Images for Service & City Pages
   ═══════════════════════════════════════════════════════════ */
.vr-page-hero.has-bg{background-size:cover!important;background-position:center!important}
.vr-page-hero.has-bg::before{background:rgba(15,23,42,0.78)!important}
