@import url('https://fonts.googleapis.com/css2?family=Oswald:wght@400;500;600;700&family=Inter:wght@400;500;600;700;800;900&display=swap');
:root{--red:#c41230;--red-dark:#a00e26;--black:#111111;}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'Inter',system-ui,sans-serif;color:#111;background:#fff;display:flex;flex-direction:column;min-height:100vh;}
h1,h2,h3,h4{font-family:'Oswald',system-ui,sans-serif;letter-spacing:0.02em;}
main{flex:1;}
a{color:inherit;}

/* Header */
header{background:#fff;position:sticky;top:0;z-index:50;box-shadow:0 2px 12px rgba(0,0,0,0.12);border-bottom:1px solid #e5e7eb;}
.top-bar{background:var(--red);padding:0.45rem 1.5rem;}
.top-bar-inner{max-width:1280px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:0.5rem;}
.top-bar span,.top-bar a{font-size:0.8rem;color:rgba(255,255,255,0.9);}
.top-bar a{font-weight:800;font-size:0.95rem;color:#fff;text-decoration:none;}
nav{max-width:1280px;margin:0 auto;padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between;height:96px;}
.logo img{height:72px;width:auto;object-fit:contain;border-radius:4px;display:block;}
.nav-links{display:flex;align-items:center;gap:0.25rem;}
.nav-links a{color:#111;text-decoration:none;font-weight:700;font-size:0.85rem;letter-spacing:0.07em;text-transform:uppercase;padding:0.5rem 0.65rem;transition:color 0.2s;}
.nav-links a:hover{color:var(--red);}
.nav-cta{margin-left:0.75rem;background:var(--red);color:#fff!important;padding:0.7rem 1.4rem;border-radius:4px;white-space:nowrap;}
.nav-cta:hover{background:var(--red-dark)!important;}
.services-dropdown{position:relative;}
.services-dropdown:hover .dropdown-menu{display:block;}
.dropdown-menu{display:none;position:absolute;top:100%;left:50%;transform:translateX(-50%);background:#fff;border:1px solid #e5e7eb;border-top:3px solid var(--red);padding:0.75rem 0;min-width:260px;box-shadow:0 12px 32px rgba(0,0,0,0.15);z-index:100;}
.dropdown-menu a{display:block;padding:0.65rem 1.4rem;color:#333;text-decoration:none;font-size:0.85rem;font-weight:600;letter-spacing:0.04em;text-transform:uppercase;transition:all 0.15s;}
.dropdown-menu a:hover{background:var(--red);color:#fff;}
.mobile-btn{display:none;background:none;border:1px solid #aaa;border-radius:4px;cursor:pointer;padding:0.5rem 0.75rem;color:#111;font-weight:700;font-size:0.85rem;}
.mobile-menu{display:none;background:#1a1a1a;border-top:2px solid var(--red);}
.mobile-menu a{display:block;padding:0.65rem 1.5rem;color:#ddd;text-decoration:none;font-weight:700;font-size:0.9rem;letter-spacing:0.06em;border-bottom:1px solid #222;text-transform:uppercase;}
.mobile-menu a.indent{padding-left:2.5rem;color:#999;font-size:0.82rem;}
.mobile-call{padding:0.75rem 1.5rem;}
.mobile-call a{display:block;background:var(--red);color:#fff;font-weight:800;text-align:center;padding:1rem;text-decoration:none;font-size:1.1rem;border-radius:4px;}

/* Buttons */
.btn-primary{display:inline-block;background:var(--red);color:#fff;font-family:'Oswald',system-ui,sans-serif;font-weight:700;padding:0.75rem 1.75rem;border-radius:4px;text-decoration:none;text-align:center;transition:background 0.2s,transform 0.15s;border:none;cursor:pointer;font-size:1rem;letter-spacing:0.06em;text-transform:uppercase;}
.btn-primary:hover{background:var(--red-dark);transform:translateY(-1px);}
.btn-secondary{display:inline-block;background:transparent;color:#fff;border:2px solid #fff;font-family:'Oswald',system-ui,sans-serif;font-weight:700;padding:0.75rem 1.75rem;border-radius:4px;text-decoration:none;text-align:center;font-size:1rem;letter-spacing:0.06em;text-transform:uppercase;}
.btn-secondary:hover{background:#fff;color:var(--red);}
.btn-outline-dark{display:inline-block;background:#fff;color:var(--red);border:2px solid var(--red);font-family:'Oswald',system-ui,sans-serif;font-weight:700;padding:0.75rem 1.75rem;border-radius:4px;text-decoration:none;text-align:center;font-size:1rem;letter-spacing:0.06em;text-transform:uppercase;}
.btn-outline-dark:hover{background:var(--red);color:#fff;}

/* Service card */
.service-card{background:#fff;border-radius:4px;box-shadow:0 2px 8px rgba(0,0,0,0.08);padding:1.75rem 1.5rem;border-top:4px solid var(--red);border:1px solid #e5e7eb;border-top:4px solid var(--red);transition:transform 0.2s,box-shadow 0.2s;text-decoration:none;display:block;color:inherit;}
.service-card:hover{transform:translateY(-4px);box-shadow:0 8px 28px rgba(0,0,0,0.14);}

/* Section label */
.section-label{display:inline-block;background:var(--red);color:#fff;font-family:'Oswald',system-ui,sans-serif;font-weight:700;font-size:0.8rem;letter-spacing:0.12em;text-transform:uppercase;padding:0.3rem 1rem;margin-bottom:1rem;}

/* Forms */
.form-label{display:block;font-size:0.82rem;font-weight:700;margin-bottom:0.35rem;letter-spacing:0.04em;text-transform:uppercase;font-family:'Oswald',system-ui,sans-serif;}
.form-input{width:100%;border:2px solid #e5e7eb;border-radius:4px;padding:0.75rem 1rem;color:#111;font-size:1rem;font-family:'Inter',system-ui,sans-serif;transition:border-color 0.2s;background:#fff;}
.form-input:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 3px rgba(196,18,48,0.12);}
.contact-form{background:#f8f8f8;border-radius:4px;padding:2rem;box-shadow:0 4px 20px rgba(0,0,0,0.1);border:1px solid #e5e7eb;border-top:4px solid var(--red);}
.contact-form h2{color:#111;font-size:1.4rem;font-weight:700;margin-bottom:0.4rem;font-family:'Oswald',system-ui,sans-serif;text-transform:uppercase;letter-spacing:0.04em;}
.contact-form p.sub{color:#555;margin-bottom:1.5rem;font-size:0.88rem;}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.form-group{margin-bottom:1rem;}

/* Footer */
footer{background:#0a0a0a;color:#ccc;margin-top:0;}
.footer-emergency{background:var(--red);padding:1.5rem;}
.footer-emergency-inner{max-width:1280px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;}
.footer-emergency p{margin:0;color:#fff;font-size:1.1rem;font-weight:700;font-family:'Oswald',system-ui,sans-serif;letter-spacing:0.05em;text-transform:uppercase;}
.footer-emergency small{color:rgba(255,255,255,0.85);font-size:0.85rem;}
.footer-emergency a{color:#fff;font-size:1.7rem;font-weight:800;text-decoration:none;font-family:'Oswald',system-ui,sans-serif;}
.footer-grid{max-width:1280px;margin:0 auto;padding:3.5rem 1.5rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:2.5rem;}
.footer-col h3{color:#fff;font-size:0.85rem;font-weight:700;margin-bottom:1.25rem;font-family:'Oswald',system-ui,sans-serif;letter-spacing:0.1em;text-transform:uppercase;border-bottom:2px solid var(--red);padding-bottom:0.6rem;}
.footer-col ul{list-style:none;}
.footer-col ul li{margin-bottom:0.5rem;}
.footer-col ul li a{color:#999;text-decoration:none;font-size:0.88rem;transition:color 0.2s;}
.footer-col ul li a:hover{color:var(--red);}
.footer-col ul li span{color:#999;font-size:0.88rem;}
.footer-brand p{font-size:0.9rem;line-height:1.75;color:#999;margin-top:0;}
.lic-box{margin-top:1rem;padding:0.75rem 1rem;background:#1a1a1a;border-left:3px solid var(--red);border-radius:2px;}
.lic-box p{margin:0;color:#ccc;font-size:0.8rem;font-family:'Oswald',system-ui,sans-serif;letter-spacing:0.05em;text-transform:uppercase;}
.lic-box .lic-num{color:var(--red);font-size:0.9rem;font-weight:700;margin-top:0.15rem;}
.lic-box .owner{color:#888;font-size:0.8rem;margin-top:0.25rem;}
.footer-bottom{border-top:1px solid #1e1e1e;padding:1.25rem 1.5rem;}
.footer-bottom-inner{max-width:1280px;margin:0 auto;display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;}
.footer-bottom p{color:#555;font-size:0.82rem;}
.footer-bottom-links a{color:#555;font-size:0.82rem;text-decoration:none;letter-spacing:0.05em;text-transform:uppercase;font-weight:600;margin-left:1.5rem;}
.footer-bottom-links a:hover{color:var(--red);}

/* Hero */
.hero{background:linear-gradient(160deg,#0a0a0a 0%,#1a1a1a 60%,#1c0008 100%);color:#fff;padding:clamp(3.5rem,8vw,6rem) 1.5rem;position:relative;overflow:hidden;}
.hero::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:var(--red);}
.hero-inner{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1fr min(440px,100%);gap:4rem;align-items:center;}
.hero-badge{display:inline-flex;align-items:center;gap:0.5rem;background:rgba(196,18,48,0.15);border:1px solid rgba(196,18,48,0.4);border-radius:2px;padding:0.4rem 1rem;margin-bottom:1.25rem;}
.hero-badge span{color:var(--red);font-size:0.75rem;font-weight:800;letter-spacing:0.1em;text-transform:uppercase;font-family:'Oswald',system-ui,sans-serif;}
.hero h1{font-size:clamp(2.6rem,5.5vw,4rem);font-weight:700;line-height:1.05;margin-bottom:1.25rem;font-family:'Oswald',system-ui,sans-serif;text-transform:uppercase;}
.hero h1 span{color:var(--red);}
.hero p{font-size:1.1rem;color:#bbb;line-height:1.7;max-width:540px;margin-bottom:2rem;}
.hero-ctas{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:2.5rem;}
.trust-grid{display:grid;grid-template-columns:1fr 1fr;gap:0.6rem 1.5rem;}
.trust-item{display:flex;align-items:center;gap:0.6rem;}
.trust-item .check{color:var(--red);font-weight:900;font-size:1.1rem;flex-shrink:0;}
.trust-item span{color:#ccc;font-size:0.88rem;font-weight:600;}

/* Stats bar */
.stats-bar{background:var(--red);padding:1.25rem 1.5rem;}
.stats-bar-inner{max-width:1280px;margin:0 auto;display:flex;justify-content:space-around;flex-wrap:wrap;gap:1.5rem;}
.stat{text-align:center;color:#fff;}
.stat .num{font-size:clamp(1.6rem,3vw,2.2rem);font-weight:700;font-family:'Oswald',system-ui,sans-serif;line-height:1.1;}
.stat .label{font-size:0.8rem;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;opacity:0.85;}

/* Page hero (inner pages) */
.page-hero{background:linear-gradient(135deg,#111 0%,#1f2937 100%);color:#fff;padding:4rem 1.5rem;}
.page-hero-inner{max-width:1200px;margin:0 auto;}
.breadcrumb{display:flex;gap:0.5rem;margin-bottom:1rem;align-items:center;flex-wrap:wrap;}
.breadcrumb a{color:#aaa;font-size:0.85rem;text-decoration:none;}
.breadcrumb a:hover{color:var(--red);}
.breadcrumb span.sep{color:#555;}
.breadcrumb span.current{color:var(--red);font-size:0.85rem;}
.page-hero h1{font-size:clamp(2rem,5vw,3rem);font-weight:900;line-height:1.2;margin-bottom:1rem;}
.page-hero p{font-size:1.1rem;color:#ccc;max-width:650px;line-height:1.7;margin-bottom:2rem;}

/* Two col layout */
.two-col{max-width:1200px;margin:0 auto;padding:5rem 1.5rem;display:grid;grid-template-columns:1fr min(380px,100%);gap:3rem;align-items:start;}
.sidebar{position:sticky;top:96px;}
.emergency-box{background:var(--red);border-radius:4px;padding:1.5rem;margin-top:1.25rem;text-align:center;}
.emergency-box p{color:#fff;font-weight:700;font-size:0.85rem;margin-bottom:0.5rem;font-family:'Oswald',system-ui,sans-serif;letter-spacing:0.1em;text-transform:uppercase;}
.emergency-box a{color:#fff;font-size:1.4rem;font-weight:800;text-decoration:none;display:block;font-family:'Oswald',system-ui,sans-serif;}

/* Trust badges */
.trust-badges{display:flex;flex-wrap:wrap;gap:0.75rem;margin:2rem 0;}
.trust-badge{display:flex;align-items:center;gap:0.45rem;background:rgba(0,0,0,0.05);border:1px solid #e5e7eb;border-radius:2px;padding:0.4rem 0.9rem;font-size:0.82rem;font-weight:700;color:#333;font-family:'Oswald',system-ui,sans-serif;letter-spacing:0.06em;text-transform:uppercase;}
.trust-badge .icon{color:var(--red);}

/* Content sections */
.content-section{padding:5rem 1.5rem;}
.section-inner{max-width:1280px;margin:0 auto;}
.section-header{text-align:center;margin-bottom:3rem;}
.section-heading{font-family:'Oswald',system-ui,sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:0.04em;}

/* Service grid */
.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:1.25rem;}
.service-card-link{text-decoration:none;}
.service-card-icon{font-size:2.2rem;margin-bottom:0.75rem;}
.service-card h3{font-size:1.15rem;font-weight:700;color:#111;margin-bottom:0.5rem;font-family:'Oswald',system-ui,sans-serif;text-transform:uppercase;letter-spacing:0.03em;}
.service-card p{color:#555;font-size:0.9rem;line-height:1.65;margin:0;}
.service-card .learn-more{color:var(--red);font-weight:700;font-size:0.85rem;margin-top:1rem;display:block;font-family:'Oswald',system-ui,sans-serif;letter-spacing:0.05em;text-transform:uppercase;}

/* Feature grid */
.feature-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-bottom:2rem;}
.feature-item{background:#f8f8f8;border-radius:0.5rem;padding:0.75rem 1rem;display:flex;align-items:center;gap:0.5rem;font-size:0.9rem;font-weight:600;}
.feature-item .fi{color:var(--red);}

/* Steps */
.steps{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem;}
.step{display:flex;gap:1rem;align-items:flex-start;background:#f8f8f8;border-radius:0.75rem;padding:1rem 1.25rem;}
.step-num{width:36px;height:36px;background:var(--red);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:900;flex-shrink:0;font-family:'Oswald',system-ui,sans-serif;}
.step-title{font-weight:700;color:#111;margin-bottom:0.25rem;}
.step-desc{color:#555;font-size:0.9rem;line-height:1.6;}

/* Why choose us */
.why-item{display:flex;gap:1rem;margin-bottom:1.25rem;align-items:flex-start;}
.why-icon{font-size:1.5rem;flex-shrink:0;width:40px;text-align:center;padding-top:2px;}
.why-title{font-size:1rem;font-weight:700;color:#111;margin-bottom:0.2rem;font-family:'Oswald',system-ui,sans-serif;text-transform:uppercase;letter-spacing:0.04em;}
.why-desc{color:#555;font-size:0.9rem;margin:0;line-height:1.65;}

/* Testimonials */
.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;}
.testimonial{background:#fff;border-radius:4px;padding:2rem;box-shadow:0 2px 12px rgba(0,0,0,0.07);border-top:4px solid var(--red);}
.testimonial .stars{color:#f59e0b;font-size:1.2rem;margin-bottom:1rem;letter-spacing:0.1em;}
.testimonial blockquote{color:#333;line-height:1.75;font-style:italic;margin:0 0 1.25rem;}
.testimonial .reviewer{display:flex;justify-content:space-between;align-items:center;padding-top:1rem;border-top:1px solid #f0f0f0;}
.testimonial .reviewer strong{font-family:'Oswald',system-ui,sans-serif;font-size:1rem;text-transform:uppercase;letter-spacing:0.04em;}
.testimonial .reviewer span{color:var(--red);font-size:0.82rem;font-weight:700;}

/* Cities */
.cities-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.25rem;}
.city-card{background:#f5f5f5;border-radius:4px;padding:2rem;text-decoration:none;display:block;border-top:4px solid var(--red);transition:all 0.2s;color:inherit;}
.city-card:hover{background:#fff;box-shadow:0 4px 16px rgba(0,0,0,0.1);}
.city-card h3{font-size:1.2rem;font-weight:700;color:#111;margin-bottom:0.5rem;font-family:'Oswald',system-ui,sans-serif;text-transform:uppercase;}
.city-card p{color:#555;font-size:0.9rem;margin:0;}
.city-card .arrow{color:var(--red);font-weight:700;font-size:0.82rem;margin-top:0.75rem;display:block;font-family:'Oswald',system-ui,sans-serif;text-transform:uppercase;}
.also-serving{background:#111;border-radius:4px;padding:2rem;}
.also-serving h3{font-size:1rem;font-weight:700;color:#fff;margin-bottom:0.75rem;font-family:'Oswald',system-ui,sans-serif;text-transform:uppercase;}
.also-serving ul{list-style:none;color:#aaa;font-size:0.9rem;line-height:2.2;}
.also-serving li::before{content:'› ';color:var(--red);font-weight:700;}

/* CTA section */
.cta-section{padding:5rem 1.5rem;background:linear-gradient(135deg,#0a0a0a 0%,#1a1a1a 100%);}
.cta-inner{max-width:800px;margin:0 auto;text-align:center;}
.cta-inner h2{font-size:clamp(1.9rem,4vw,2.8rem);color:#fff;margin-bottom:1rem;font-family:'Oswald',system-ui,sans-serif;text-transform:uppercase;}
.cta-inner p{color:#aaa;font-size:1.05rem;margin-bottom:2.5rem;}
.cta-btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;}

/* FAQ */
.faq{padding:4rem 1.5rem;background:#f8f8f8;}
.faq-inner{max-width:800px;margin:0 auto;}
.faq h2{font-size:2rem;font-weight:800;color:#111;text-align:center;margin-bottom:2rem;}
.faq-item{background:#fff;border:1px solid #e5e7eb;border-radius:0.75rem;overflow:hidden;margin-bottom:0.75rem;box-shadow:0 2px 6px rgba(0,0,0,0.05);}
.faq-q{width:100%;text-align:left;padding:1.25rem 1.5rem;background:none;border:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:1rem;font-weight:700;color:#111;font-size:1rem;font-family:'Inter',system-ui,sans-serif;}
.faq-q .plus{color:var(--red);font-size:1.4rem;line-height:1;flex-shrink:0;}
.faq-a{padding:0 1.5rem 1.25rem;color:#555;line-height:1.7;font-size:0.95rem;display:none;}
.faq-item.open .faq-a{display:block;}

/* Call CTA box */
.call-cta{background:linear-gradient(135deg,var(--red),var(--red-dark));border-radius:4px;padding:2.5rem 2rem;text-align:center;margin:2.5rem 0;}
.call-cta p{color:#fff;font-weight:700;font-size:1.4rem;margin-bottom:0.75rem;font-family:'Oswald',system-ui,sans-serif;letter-spacing:0.04em;text-transform:uppercase;}
.call-cta a.phone{color:#fff;font-size:2rem;font-weight:800;text-decoration:none;display:block;margin-bottom:1.25rem;font-family:'Oswald',system-ui,sans-serif;}
.call-cta a.quote{background:#fff;color:var(--red);font-weight:800;padding:0.8rem 2rem;border-radius:4px;text-decoration:none;display:inline-block;font-family:'Oswald',system-ui,sans-serif;letter-spacing:0.06em;text-transform:uppercase;font-size:0.9rem;}

/* Emergency banner */
.emergency-banner{background:var(--red);border-radius:1rem;padding:1.5rem;text-align:center;margin-bottom:2rem;}
.emergency-banner p{color:#fff;font-weight:800;font-size:1.2rem;margin-bottom:0.75rem;}
.emergency-banner a{color:#fff;font-size:2rem;font-weight:900;text-decoration:none;display:block;}
.emergency-banner small{color:rgba(255,255,255,0.85);font-size:0.9rem;}

/* Related services */
.related-box{background:#111;border-radius:4px;padding:1.5rem;margin-top:1.25rem;}
.related-box h3{color:#fff;font-size:0.85rem;font-weight:700;margin-bottom:1rem;font-family:'Oswald',system-ui,sans-serif;letter-spacing:0.08em;text-transform:uppercase;border-bottom:2px solid var(--red);padding-bottom:0.5rem;}
.related-box ul{list-style:none;}
.related-box ul li{margin-bottom:0.5rem;}
.related-box ul li a{color:#bbb;text-decoration:none;font-size:0.88rem;display:flex;align-items:center;gap:0.5rem;}
.related-box ul li a::before{content:'▸';color:var(--red);font-size:0.75rem;}
.related-box ul li a:hover{color:var(--red);}

/* Reviews */
.review-card{background:#fff;border-radius:1rem;padding:1.75rem;box-shadow:0 4px 12px rgba(0,0,0,0.07);border:1px solid #e5e7eb;margin-bottom:1.5rem;}
.review-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:0.5rem;margin-bottom:1rem;}
.reviewer-name{font-weight:800;color:#111;}
.reviewer-city{color:#888;font-size:0.85rem;}
.review-stars{color:#f59e0b;font-size:1.1rem;}
.review-date{color:#aaa;font-size:0.8rem;}
.review-service{background:var(--red);color:#fff;display:inline-block;font-size:0.8rem;font-weight:700;padding:0.2rem 0.6rem;border-radius:0.3rem;margin-bottom:0.75rem;}
.review-text{color:#444;line-height:1.8;font-style:italic;}

/* Projects */
.project-card{background:#fff;border-radius:1rem;box-shadow:0 4px 12px rgba(0,0,0,0.07);overflow:hidden;border:1px solid #e5e7eb;margin-bottom:2rem;}
.project-header{background:linear-gradient(135deg,#111,#1f2937);padding:1.25rem 1.5rem;display:flex;justify-content:space-between;align-items:center;}
.project-cat{color:var(--red);font-weight:700;font-size:0.9rem;}
.project-city{color:#aaa;font-size:0.85rem;}
.project-body{padding:1.5rem;}
.project-title{font-size:1.1rem;font-weight:800;color:#111;margin-bottom:1rem;}
.project-desc{color:#555;line-height:1.8;font-size:0.95rem;}
.project-tags{display:flex;gap:0.5rem;flex-wrap:wrap;margin-top:1rem;}
.project-tag{background:#f3f4f6;color:#374151;font-size:0.8rem;font-weight:600;padding:0.3rem 0.75rem;border-radius:2rem;}

/* About */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;}
.nate-card{background:linear-gradient(135deg,#111,#1f2937);border-radius:1.5rem;padding:3rem 2rem;color:#fff;text-align:center;}
.nate-emoji{font-size:5rem;margin-bottom:1.5rem;}
.nate-stats{display:flex;justify-content:center;gap:2rem;flex-wrap:wrap;margin-top:2rem;}
.nate-stat .n{font-size:2rem;font-weight:900;color:var(--red);display:block;}
.nate-stat .l{font-size:0.85rem;color:#aaa;}
.values-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:2rem;}
.value-card{background:#fff;border-radius:1rem;padding:2rem;box-shadow:0 4px 12px rgba(0,0,0,0.07);border-top:4px solid var(--red);}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start;}
.contact-item{display:flex;gap:1rem;align-items:flex-start;margin-bottom:1.5rem;}
.contact-icon{width:48px;height:48px;background:var(--red);border-radius:0.75rem;display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0;}
.contact-label{font-weight:700;color:#111;margin-bottom:0.25rem;}

/* Responsive */
@media(max-width:960px){
  .nav-links{display:none;}
  .mobile-btn{display:block;}
}
@media(max-width:768px){
  .hero-inner,.two-col,.about-grid,.contact-grid{grid-template-columns:1fr!important;gap:2rem!important;}
  .form-grid{grid-template-columns:1fr;}
  .footer-emergency-inner{flex-direction:column;}
}

/* ── EMERGENCY SERVICE BANNER ─────────────────────────────── */
@keyframes pulseRing {
  0%   { transform: scale(0.8); opacity: 0.8; }
  100% { transform: scale(2.2); opacity: 0; }
}
@keyframes sirenFlash {
  0%,100% { filter: drop-shadow(0 0 6px #ff2244) brightness(1); }
  50%      { filter: drop-shadow(0 0 22px #ff6680) brightness(1.4); }
}
@keyframes sirenSpin {
  0%   { transform: rotate(-8deg) scale(1.05); }
  50%  { transform: rotate(8deg) scale(1.15); }
  100% { transform: rotate(-8deg) scale(1.05); }
}
@keyframes slideInText {
  from { opacity:0; transform: translateX(-20px); }
  to   { opacity:1; transform: translateX(0); }
}
@keyframes phonePulse {
  0%,100% { transform: scale(1); }
  10%      { transform: scale(1.06) rotate(-2deg); }
  20%      { transform: scale(1.06) rotate(2deg); }
  30%      { transform: scale(1.06) rotate(-2deg); }
  40%      { transform: scale(1); }
}
@keyframes bgShimmer {
  0%   { background-position: 0% 50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}
@keyframes borderGlow {
  0%,100% { box-shadow: 0 0 0 0 rgba(196,18,48,0.4), inset 0 0 30px rgba(196,18,48,0.05); }
  50%      { box-shadow: 0 0 0 8px rgba(196,18,48,0), inset 0 0 50px rgba(196,18,48,0.15); }
}

.services-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.25rem;
}

.emergency-service-banner {
  grid-column: 1 / -1; /* full width */
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  gap: 2rem;
  padding: 2.25rem 2.5rem;
  background: linear-gradient(270deg, #1a0005, #3d0010, #c41230, #a00e26, #1a0005);
  background-size: 400% 400%;
  animation: bgShimmer 6s ease infinite, borderGlow 2s ease-in-out infinite;
  border-radius: 8px;
  text-decoration: none;
  border: 2px solid rgba(196,18,48,0.6);
  cursor: pointer;
  transition: transform 0.2s;
}
.emergency-service-banner:hover {
  transform: translateY(-3px);
  border-color: rgba(255,80,100,0.9);
}

/* Pulse rings behind everything */
.emerg-pulse-ring {
  position: absolute;
  left: 3.5rem;
  top: 50%;
  transform: translate(-50%, -50%) scale(0.8);
  width: 70px;
  height: 70px;
  border-radius: 50%;
  border: 3px solid rgba(255,60,80,0.7);
  animation: pulseRing 2s ease-out infinite;
  pointer-events: none;
}
.emerg-pulse-ring.delay { animation-delay: 1s; border-color: rgba(255,180,180,0.4); }

.emerg-siren {
  font-size: 3.2rem;
  flex-shrink: 0;
  animation: sirenSpin 1.4s ease-in-out infinite, sirenFlash 0.9s ease-in-out infinite;
  position: relative;
  z-index: 1;
  filter: drop-shadow(0 0 10px rgba(255,80,100,0.9));
}

.emerg-content {
  flex: 1;
  animation: slideInText 0.6s ease;
  position: relative;
  z-index: 1;
}
.emerg-label {
  color: rgba(255,200,200,0.9);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-family: 'Oswald', system-ui, sans-serif;
  margin-bottom: 0.35rem;
}
.emerg-title {
  color: #fff;
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  font-weight: 700;
  font-family: 'Oswald', system-ui, sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  line-height: 1.1;
  margin-bottom: 0.4rem;
}
.emerg-sub {
  color: rgba(255,200,200,0.85);
  font-size: 0.9rem;
  line-height: 1.5;
  font-weight: 500;
}

.emerg-cta {
  flex-shrink: 0;
  text-align: center;
  position: relative;
  z-index: 1;
}
.emerg-phone {
  color: #fff;
  font-size: clamp(1.4rem, 2.5vw, 1.9rem);
  font-weight: 800;
  font-family: 'Oswald', system-ui, sans-serif;
  letter-spacing: 0.06em;
  animation: phonePulse 3s ease infinite;
  text-shadow: 0 0 20px rgba(255,150,150,0.8);
  margin-bottom: 0.5rem;
}
.emerg-btn {
  display: inline-block;
  background: #fff;
  color: #c41230;
  font-weight: 800;
  font-size: 0.9rem;
  padding: 0.6rem 1.5rem;
  border-radius: 4px;
  font-family: 'Oswald', system-ui, sans-serif;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  transition: background 0.2s, transform 0.2s;
}
.emergency-service-banner:hover .emerg-btn {
  background: #ffe0e0;
  transform: scale(1.05);
}

/* ── GOOGLE REVIEWS SPINNER ──────────────────────────────── */
@keyframes spin { to { transform: rotate(360deg); } }
.reviews-spinner {
  width: 40px; height: 40px;
  border: 4px solid #e5e7eb;
  border-top-color: #c41230;
  border-radius: 50%;
  margin: 0 auto;
  animation: spin 0.8s linear infinite;
}

/* ── RESPONSIVE ──────────────────────────────────────────── */
@media(max-width:960px) {
  .services-grid { grid-template-columns: repeat(2, 1fr); }
  .emergency-service-banner { flex-direction: column; text-align: center; gap: 1.25rem; }
  .emerg-pulse-ring { left: 50%; top: 2rem; }
}
@media(max-width:540px) {
  .services-grid { grid-template-columns: 1fr; }
}

/* HouseCall Pro booking button override */
.hcp-button {
  display: inline-block;
  background-color: var(--red);
  color: white !important;
  font-family: 'Oswald', system-ui, sans-serif;
  font-weight: 700;
  padding: 0.75rem 1.75rem;
  border-radius: 4px;
  text-decoration: none;
  text-align: center;
  transition: background-color 0.2s, transform 0.15s;
  border: none;
  cursor: pointer;
  font-size: 1rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.hcp-button:hover {
  background-color: var(--red-dark);
  transform: translateY(-1px);
}

/* ── MOBILE OPTIMIZATIONS ─────────────────────────────────── */

/* Hide top utility bar on mobile — logo shows first */
@media(max-width:960px) {
  .desktop-only { display: none !important; }
}

/* Make nav height tighter on mobile */
@media(max-width:960px) {
  nav {
    height: 70px !important;
    padding: 0 1rem !important;
  }
  .logo img {
    height: 52px !important;
  }
}

/* Hero section mobile tweaks */
@media(max-width:768px) {
  .hero {
    padding: 2.5rem 1rem !important;
  }
  .hero h1 {
    font-size: 2rem !important;
  }
  .hero-ctas {
    flex-direction: column;
  }
  .hero-ctas a, .hero-ctas button {
    width: 100%;
    text-align: center;
    justify-content: center;
  }
  .trust-grid {
    grid-template-columns: 1fr !important;
    gap: 0.4rem !important;
  }
}

/* Stats bar mobile */
@media(max-width:540px) {
  .stats-bar-inner {
    gap: 1rem !important;
    justify-content: center !important;
  }
  .stat .num { font-size: 1.4rem !important; }
}

/* Service cards — 1 column on small mobile */
@media(max-width:480px) {
  .services-grid {
    grid-template-columns: 1fr !important;
  }
  .emergency-service-banner {
    padding: 1.5rem 1rem !important;
  }
  .emerg-title { font-size: 1.4rem !important; }
  .emerg-phone { font-size: 1.3rem !important; }
}

/* Two-col why section mobile */
@media(max-width:900px) {
  .two-col-why {
    grid-template-columns: 1fr !important;
    gap: 2rem !important;
  }
}

/* Footer mobile */
@media(max-width:600px) {
  .footer-grid {
    grid-template-columns: 1fr !important;
    padding: 2rem 1rem !important;
  }
  .footer-emergency-inner {
    flex-direction: column !important;
    text-align: center !important;
  }
  .footer-bottom-inner {
    flex-direction: column !important;
    text-align: center !important;
  }
  .footer-bottom-links a {
    margin-left: 0.75rem !important;
  }
}

/* Contact form grid on mobile */
@media(max-width:500px) {
  .form-grid {
    grid-template-columns: 1fr !important;
  }
}

/* Sidebar stacks below content on mobile */
@media(max-width:768px) {
  .two-col {
    grid-template-columns: 1fr !important;
    padding: 2rem 1rem !important;
  }
  .sidebar {
    position: static !important;
  }
}

/* Page hero mobile */
@media(max-width:600px) {
  .page-hero {
    padding: 2.5rem 1rem !important;
  }
  .page-hero h1 {
    font-size: 1.8rem !important;
  }
}

/* About grid mobile */
@media(max-width:768px) {
  .about-grid {
    grid-template-columns: 1fr !important;
    gap: 2rem !important;
  }
  .contact-grid {
    grid-template-columns: 1fr !important;
    gap: 2rem !important;
  }
  .values-grid {
    grid-template-columns: 1fr !important;
  }
}

/* CTA buttons mobile */
@media(max-width:540px) {
  .cta-btns {
    flex-direction: column !important;
    align-items: center !important;
  }
  .cta-btns a, .cta-btns button {
    width: 100% !important;
    text-align: center !important;
  }
  .call-cta a.phone { font-size: 1.5rem !important; }
}

/* ── EXCITING FEATURES & ANIMATIONS ──────────────────────── */

/* Scroll progress bar at top */
#scroll-progress {
  position: fixed;
  top: 0;
  left: 0;
  height: 3px;
  background: linear-gradient(90deg, #c41230, #ff6680, #c41230);
  background-size: 200% 100%;
  animation: gradientShift 2s linear infinite;
  z-index: 9999;
  width: 0%;
  transition: width 0.1s linear;
}
@keyframes gradientShift {
  0% { background-position: 0% 50%; }
  100% { background-position: 200% 50%; }
}

/* Floating sticky call button — mobile only */
#float-call {
  display: none;
}
@media(max-width:960px) {
  #float-call {
    display: flex;
    position: fixed;
    bottom: 1.25rem;
    left: 50%;
    transform: translateX(-50%);
    z-index: 999;
    background: #c41230;
    color: #fff;
    font-family: 'Oswald', system-ui, sans-serif;
    font-weight: 700;
    font-size: 1.05rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    text-decoration: none;
    padding: 0.9rem 2.5rem;
    border-radius: 50px;
    box-shadow: 0 4px 20px rgba(196,18,48,0.5);
    align-items: center;
    gap: 0.5rem;
    animation: floatPulse 2.5s ease-in-out infinite;
    white-space: nowrap;
  }
  #float-call:active { transform: translateX(-50%) scale(0.96); }
}
@keyframes floatPulse {
  0%,100% { box-shadow: 0 4px 20px rgba(196,18,48,0.5), 0 0 0 0 rgba(196,18,48,0.4); }
  50%      { box-shadow: 0 6px 28px rgba(196,18,48,0.7), 0 0 0 10px rgba(196,18,48,0); }
}

/* Back to top button */
#back-top {
  position: fixed;
  bottom: 5.5rem;
  right: 1.25rem;
  width: 44px;
  height: 44px;
  background: #111;
  color: #fff;
  border: 2px solid #c41230;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  cursor: pointer;
  z-index: 998;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.3s, transform 0.3s;
  text-decoration: none;
}
#back-top.visible {
  opacity: 1;
  transform: translateY(0);
}
#back-top:hover { background: #c41230; }

/* Scroll reveal animations */
.reveal {
  opacity: 0;
  transform: translateY(32px);
  transition: opacity 0.65s ease, transform 0.65s ease;
}
.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}
.reveal-left {
  opacity: 0;
  transform: translateX(-32px);
  transition: opacity 0.65s ease, transform 0.65s ease;
}
.reveal-left.visible {
  opacity: 1;
  transform: translateX(0);
}
.reveal-right {
  opacity: 0;
  transform: translateX(32px);
  transition: opacity 0.65s ease, transform 0.65s ease;
}
.reveal-right.visible {
  opacity: 1;
  transform: translateX(0);
}

/* Staggered children reveal */
.stagger-children > * {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}
.stagger-children.visible > *:nth-child(1) { opacity:1; transform:translateY(0); transition-delay: 0.05s; }
.stagger-children.visible > *:nth-child(2) { opacity:1; transform:translateY(0); transition-delay: 0.15s; }
.stagger-children.visible > *:nth-child(3) { opacity:1; transform:translateY(0); transition-delay: 0.25s; }
.stagger-children.visible > *:nth-child(4) { opacity:1; transform:translateY(0); transition-delay: 0.35s; }
.stagger-children.visible > *:nth-child(5) { opacity:1; transform:translateY(0); transition-delay: 0.45s; }
.stagger-children.visible > *:nth-child(6) { opacity:1; transform:translateY(0); transition-delay: 0.55s; }
.stagger-children.visible > *:nth-child(n+7) { opacity:1; transform:translateY(0); transition-delay: 0.65s; }

/* Animated stat numbers */
.stat .num {
  display: inline-block;
  transition: transform 0.3s;
}

/* Enhanced service card hover */
.service-card {
  transition: transform 0.25s cubic-bezier(0.34,1.56,0.64,1), box-shadow 0.25s ease, border-top-color 0.2s !important;
}
.service-card:hover {
  transform: translateY(-6px) scale(1.02) !important;
  box-shadow: 0 12px 36px rgba(196,18,48,0.18) !important;
  border-top-color: #ff2244 !important;
}

/* Shimmer effect on buttons */
.btn-primary {
  position: relative;
  overflow: hidden;
}
.btn-primary::after {
  content: '';
  position: absolute;
  top: -50%;
  left: -75%;
  width: 50%;
  height: 200%;
  background: rgba(255,255,255,0.15);
  transform: skewX(-20deg);
  transition: left 0.5s ease;
}
.btn-primary:hover::after {
  left: 125%;
}

/* Mobile slide-in menu enhancement */
.mobile-menu {
  transform: translateY(-10px);
  opacity: 0;
  transition: transform 0.3s ease, opacity 0.3s ease;
  pointer-events: none;
}
.mobile-menu.open {
  transform: translateY(0);
  opacity: 1;
  pointer-events: all;
}

/* Glowing phone number in emergency sections */
.emergency-service-banner .emerg-phone {
  animation: phonePulse 3s ease infinite, phoneGlow 2s ease-in-out infinite !important;
}
@keyframes phoneGlow {
  0%,100% { text-shadow: 0 0 10px rgba(255,150,150,0.5); }
  50%      { text-shadow: 0 0 25px rgba(255,100,100,0.9), 0 0 50px rgba(255,50,50,0.4); }
}

/* Animated gradient on section labels */
.section-label {
  background: linear-gradient(90deg, #c41230, #a00e26, #c41230);
  background-size: 200% 100%;
  animation: labelShimmer 3s linear infinite;
}
@keyframes labelShimmer {
  0% { background-position: 0% 50%; }
  100% { background-position: 200% 50%; }
}

/* Trust badge pop on hover */
.trust-badge {
  transition: transform 0.2s, background 0.2s, border-color 0.2s;
  cursor: default;
}
.trust-badge:hover {
  transform: scale(1.05);
  background: rgba(196,18,48,0.08);
  border-color: rgba(196,18,48,0.3);
}

/* FAQ smooth open animation */
.faq-a {
  overflow: hidden;
  transition: max-height 0.4s ease, padding 0.3s ease;
  max-height: 0;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  display: block !important;
}
.faq-item.open .faq-a {
  max-height: 400px;
  padding-bottom: 1.25rem !important;
}
.faq-q .plus {
  transition: transform 0.35s ease;
}
.faq-item.open .faq-q .plus {
  transform: rotate(45deg);
}

/* Testimonial card hover */
.testimonial {
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.testimonial:hover {
  transform: translateY(-4px);
  box-shadow: 0 10px 30px rgba(0,0,0,0.12);
}

/* City card border animation */
.city-card {
  border: 2px solid transparent;
  border-top: 4px solid #c41230;
  transition: all 0.3s ease !important;
}
.city-card:hover {
  border-color: #c41230 !important;
  border-top-color: #c41230 !important;
}

/* Image hover zoom */
.photo-zoom {
  overflow: hidden;
  border-radius: 8px;
}
.photo-zoom img {
  transition: transform 0.5s ease;
}
.photo-zoom:hover img {
  transform: scale(1.04);
}
