/* ============================================
   Reliable Plumbers Dallastown — Main Stylesheet
   Professional, responsive, fast-loading
   ============================================ */

/* --- Reset & Base --- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Oxygen,sans-serif;color:#1a1a2e;line-height:1.7;background:#fff;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:#1565c0;text-decoration:none;transition:color .2s}
a:hover{color:#0d47a1}
ul,ol{list-style:none}
h1,h2,h3,h4,h5,h6{line-height:1.3;font-weight:700;color:#0d1b2a}
h1{font-size:clamp(1.8rem,4vw,2.8rem);margin-bottom:.75rem}
h2{font-size:clamp(1.4rem,3vw,2rem);margin-bottom:.6rem;margin-top:2.5rem}
h3{font-size:clamp(1.1rem,2.5vw,1.5rem);margin-bottom:.5rem;margin-top:1.5rem}
p{margin-bottom:1rem}
table{width:100%;border-collapse:collapse;margin:1.5rem 0}
th,td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid #e0e0e0}
th{background:#f5f7fa;font-weight:600;color:#0d1b2a;font-size:.9rem;text-transform:uppercase;letter-spacing:.03em}
td{font-size:.95rem}
tbody tr:hover{background:#f8fafc}
blockquote{border-left:4px solid #1565c0;padding:1rem 1.5rem;margin:1.5rem 0;background:#f0f7ff;border-radius:0 8px 8px 0;font-style:italic;color:#37474f}

/* --- Utility --- */
.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
.text-center{text-align:center}
.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:2rem}.mt-4{margin-top:3rem}
.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:2rem}

/* --- Top Bar --- */
.top-bar{background:#0d1b2a;color:#fff;padding:.5rem 0;font-size:.85rem;letter-spacing:.02em}
.top-bar .container{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}
.top-bar a{color:#90caf9;font-weight:600}
.top-bar a:hover{color:#fff}
.top-bar-left,.top-bar-right{display:flex;align-items:center;gap:1.25rem}
.top-bar-item{display:flex;align-items:center;gap:.35rem}
.top-bar-item svg{width:14px;height:14px;fill:#64b5f6}

/* --- Header / Navbar --- */
.header{background:#fff;box-shadow:0 2px 20px rgba(0,0,0,.06);position:sticky;top:0;z-index:1000;transition:box-shadow .3s}
.header.scrolled{box-shadow:0 4px 30px rgba(0,0,0,.1)}
.nav-container{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem;max-width:1200px;margin:0 auto}
.logo{display:flex;align-items:center;gap:.6rem;font-size:1.3rem;font-weight:800;color:#0d47a1;text-decoration:none}
.logo span{color:#1565c0;font-weight:400}
.logo-icon{width:40px;height:40px}
.nav-links{display:flex;align-items:center;gap:.15rem}
.nav-links a{padding:.5rem .85rem;font-size:.9rem;font-weight:500;color:#37474f;border-radius:6px;transition:all .2s}
.nav-links a:hover,.nav-links a.active{background:#e3f2fd;color:#0d47a1}

/* Dropdown */
.dropdown{position:relative}
.dropdown-toggle{cursor:pointer;display:flex;align-items:center;gap:.25rem}
.dropdown-toggle::after{content:'';border:solid #546e7a;border-width:0 2px 2px 0;padding:2.5px;transform:rotate(45deg);transition:transform .2s}
.dropdown:hover .dropdown-toggle::after{transform:rotate(-135deg)}
.dropdown-menu{position:absolute;top:100%;left:0;background:#fff;min-width:260px;max-height:70vh;overflow-y:auto;box-shadow:0 8px 30px rgba(0,0,0,.12);border-radius:8px;padding:.5rem 0;opacity:0;visibility:hidden;transform:translateY(8px);transition:all .2s;z-index:100;scrollbar-width:thin}
.dropdown:hover .dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown-menu a{display:block;padding:.6rem 1.25rem;font-size:.88rem;color:#37474f;font-weight:400}
.dropdown-menu a:hover{background:#f5f7fa;color:#0d47a1}
.dropdown-section{padding:.3rem 1.25rem;font-size:.7rem;font-weight:700;color:#90a4ae;text-transform:uppercase;letter-spacing:.08em;margin-top:.3rem}
/* Mega Menu for Areas */
.mega-menu{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(8px);background:#fff;min-width:820px;max-height:80vh;overflow-y:auto;box-shadow:0 8px 30px rgba(0,0,0,.15);border-radius:10px;padding:1rem;opacity:0;visibility:hidden;transition:all .2s;z-index:100;scrollbar-width:thin}
.dropdown:hover .mega-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.mega-cols{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem}
.mega-col{padding:0 .5rem}
.mega-col h5{font-size:.72rem;font-weight:700;color:#90a4ae;text-transform:uppercase;letter-spacing:.08em;margin:0 0 .4rem;padding:0 .5rem}
.mega-area{margin-bottom:.75rem}
.mega-area-title{display:block;padding:.35rem .5rem;font-size:.9rem;font-weight:600;color:#0d47a1;text-decoration:none}
.mega-area-title:hover{color:#1565c0;background:#e3f2fd;border-radius:4px}
.mega-sub{padding-left:1rem}
.mega-sub a{display:block;padding:.2rem .5rem;font-size:.8rem;color:#546e7a;text-decoration:none;line-height:1.5}
.mega-sub a:hover{color:#0d47a1;background:#f5f7fa;border-radius:4px}
@media(max-width:900px){.mega-menu{min-width:100%;left:0;transform:translateX(0) translateY(8px);max-height:60vh;padding:.5rem}.dropdown:hover .mega-menu{transform:translateX(0) translateY(0)}.mega-cols{grid-template-columns:1fr 1fr}.mega-sub a{font-size:.78rem;padding:.18rem .4rem}}
@media(max-width:600px){.mega-cols{grid-template-columns:1fr}}

/* Header CTA */
.header-cta{display:flex;align-items:center;gap:.75rem}
.header-phone{font-weight:700;font-size:1rem;color:#0d47a1;display:flex;align-items:center;gap:.4rem}
.header-phone svg{width:18px;height:18px;fill:#0d47a1}
.btn-cta{display:inline-flex;align-items:center;gap:.4rem;padding:.65rem 1.4rem;background:#e53935;color:#fff;font-weight:700;font-size:.9rem;border-radius:8px;border:none;cursor:pointer;transition:all .25s;text-decoration:none;white-space:nowrap}
.btn-cta:hover{background:#c62828;color:#fff;transform:translateY(-1px);box-shadow:0 4px 15px rgba(229,57,53,.35)}
.btn-cta svg{width:16px;height:16px;fill:#fff}

/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:.5rem;background:none;border:none}
.hamburger span{width:24px;height:2.5px;background:#0d1b2a;border-radius:2px;transition:all .3s}
.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* Mobile Nav */
.mobile-nav{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#fff;z-index:999;padding:5rem 1.5rem 2rem;overflow-y:auto}
.mobile-nav.active{display:block}
.mobile-nav a{display:block;padding:.9rem 0;font-size:1.1rem;color:#0d1b2a;font-weight:500;border-bottom:1px solid #f0f0f0}
.mobile-nav .mobile-section{font-size:.75rem;color:#90a4ae;text-transform:uppercase;letter-spacing:.1em;padding:1rem 0 .4rem;font-weight:700}
.mobile-nav-cta{margin-top:1.5rem;text-align:center}

/* --- Hero --- */
.hero{background:linear-gradient(135deg,#0d1b2a 0%,#1a365d 100%);color:#fff;padding:5rem 0 4rem;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:0;right:0;width:50%;height:100%;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 200 200"><circle cx="100" cy="100" r="80" fill="none" stroke="rgba(255,255,255,0.03)" stroke-width="40"/></svg>') center/cover no-repeat;opacity:.5}
.hero .container{position:relative;z-index:1}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.hero-content{max-width:600px}
.hero h1{color:#fff;font-size:clamp(2rem,4.5vw,3.2rem);margin-bottom:1rem}
.hero-text{font-size:1.1rem;line-height:1.8;color:#b0c4de;margin-bottom:2rem}
.hero-buttons{display:flex;gap:1rem;flex-wrap:wrap}
.btn-hero{padding:.9rem 2rem;font-size:1.05rem;font-weight:700;border-radius:10px;display:inline-flex;align-items:center;gap:.5rem;transition:all .3s;text-decoration:none;border:none;cursor:pointer}
.btn-hero-primary{background:#e53935;color:#fff}
.btn-hero-primary:hover{background:#c62828;color:#fff;transform:translateY(-2px);box-shadow:0 6px 25px rgba(229,57,53,.4)}
.btn-hero-secondary{background:rgba(255,255,255,.1);color:#fff;border:2px solid rgba(255,255,255,.3)}
.btn-hero-secondary:hover{background:rgba(255,255,255,.2);color:#fff}
.hero-trust{display:flex;gap:2rem;margin-top:2.5rem;flex-wrap:wrap}
.trust-item{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:#b0c4de}
.trust-item svg{width:20px;height:20px;fill:#4caf50}
.hero-image{border-radius:16px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.hero-image img{width:100%;height:400px;object-fit:cover}

/* --- Section Styles --- */
.section{padding:4rem 0}
.section-alt{background:#f8fafc}
.section-dark{background:#0d1b2a;color:#fff}
.section-dark h2,.section-dark h3{color:#fff}
.section-dark p{color:#b0c4de}
.section-header{text-align:center;max-width:700px;margin:0 auto 3rem}
.section-header p{color:#546e7a;font-size:1.05rem}
.section-label{display:inline-block;background:#e3f2fd;color:#1565c0;font-size:.75rem;font-weight:700;padding:.3rem .9rem;border-radius:20px;margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.08em}

/* --- Service Cards --- */
.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}
.service-card{background:#fff;border:1px solid #e8edf2;border-radius:12px;padding:2rem;transition:all .3s;position:relative;overflow:hidden}
.service-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,0,0,.08);border-color:#bbdefb}
.service-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(90deg,#1565c0,#42a5f5);transform:scaleX(0);transform-origin:left;transition:transform .3s}
.service-card:hover::before{transform:scaleX(1)}
.service-card-icon{width:52px;height:52px;background:#e3f2fd;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:1rem}
.service-card-icon svg{width:26px;height:26px;fill:#1565c0}
.service-card h3{font-size:1.15rem;margin-bottom:.5rem;margin-top:0}
.service-card p{font-size:.92rem;color:#546e7a;margin-bottom:1rem}
.service-card-link{font-size:.88rem;font-weight:600;color:#1565c0;display:inline-flex;align-items:center;gap:.3rem}
.service-card-link:hover{gap:.5rem}

/* --- Why Choose Us --- */
.features-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem}
.feature-item{display:flex;gap:1rem;align-items:flex-start}
.feature-icon{flex-shrink:0;width:48px;height:48px;background:#e8f5e9;border-radius:12px;display:flex;align-items:center;justify-content:center}
.feature-icon svg{width:24px;height:24px;fill:#2e7d32}
.feature-content h3{font-size:1.05rem;margin-bottom:.3rem;margin-top:0}
.feature-content p{font-size:.9rem;color:#546e7a;margin:0}

/* --- Steps / Process --- */
.steps{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:2rem;counter-reset:step}
.step{position:relative;padding:2rem;background:#fff;border-radius:12px;border:1px solid #e8edf2;text-align:center}
.step::before{counter-increment:step;content:counter(step);position:absolute;top:-18px;left:50%;transform:translateX(-50%);width:36px;height:36px;background:#1565c0;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1rem}
.step h3{margin-top:.75rem;font-size:1.05rem}
.step p{font-size:.9rem;color:#546e7a;margin:0}

/* --- Reviews --- */
.reviews-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.5rem}
.review-card{background:#fff;border:1px solid #e8edf2;border-radius:12px;padding:1.75rem}
.review-stars{color:#ffa000;font-size:1.1rem;margin-bottom:.75rem;letter-spacing:2px}
.review-text{font-size:.95rem;color:#37474f;line-height:1.7;margin-bottom:1rem}
.review-author{font-weight:600;color:#0d1b2a;font-size:.9rem}
.review-service{font-size:.8rem;color:#90a4ae;margin-top:.15rem}

/* --- CTA Banner --- */
.cta-banner{background:linear-gradient(135deg,#1565c0 0%,#0d47a1 100%);color:#fff;padding:3.5rem 0;text-align:center}
.cta-banner h2{color:#fff;font-size:clamp(1.5rem,3.5vw,2.2rem);margin-bottom:.75rem;margin-top:0}
.cta-banner p{color:#bbdefb;font-size:1.05rem;margin-bottom:1.5rem}
.cta-banner .btn-cta{padding:.9rem 2.5rem;font-size:1.1rem}

/* --- FAQ --- */
.faq-list{max-width:800px;margin:0 auto}
.faq-item{border-bottom:1px solid #e8edf2}
.faq-question{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 0;cursor:pointer;font-weight:600;font-size:1rem;color:#0d1b2a;background:none;border:none;width:100%;text-align:left;font-family:inherit;gap:1rem}
.faq-question::after{content:'+';font-size:1.4rem;color:#90a4ae;transition:transform .3s;flex-shrink:0}
.faq-item.active .faq-question::after{transform:rotate(45deg);color:#1565c0}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .4s ease;padding:0}
.faq-item.active .faq-answer{padding-bottom:1.25rem}
.faq-answer p{font-size:.95rem;color:#546e7a;margin:0}
.faq-answer a{color:#1565c0;font-weight:500}

/* --- Footer --- */
.footer{background:#0d1b2a;color:#b0c4de;padding:4rem 0 0}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1fr 1fr;gap:2rem;margin-bottom:3rem}
.footer-area-list{padding:0;margin:0;list-style:none}
.footer-area-list li{margin-bottom:.15rem}
.footer-area-list li a{padding:.15rem 0;font-size:.82rem}
.footer-area-list .area-hub{font-weight:600;color:#b0c4de;font-size:.86rem;padding:.25rem 0}
.footer-area-list .area-hub:hover{color:#64b5f6}
.footer-area-list .sub-svc{padding-left:.75rem;font-size:.78rem;color:#6b7f95}
.footer-area-list .sub-svc:hover{color:#64b5f6}
.footer-brand h3{color:#fff;font-size:1.2rem;margin-bottom:.75rem}
.footer-brand p{font-size:.9rem;line-height:1.7}
.footer h4{color:#fff;font-size:.95rem;margin-bottom:1rem;text-transform:uppercase;letter-spacing:.05em}
.footer a{color:#90a4ae;font-size:.88rem;transition:color .2s;display:block;padding:.3rem 0}
.footer a:hover{color:#64b5f6}
.footer-contact-item{display:flex;align-items:center;gap:.5rem;margin-bottom:.6rem;font-size:.9rem}
.footer-contact-item svg{width:16px;height:16px;fill:#64b5f6;flex-shrink:0}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:1.5rem 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;font-size:.82rem;color:#6b7f95}
.footer-bottom a{color:#6b7f95;font-size:.82rem}
.footer-bottom a:hover{color:#90caf9}

/* --- Floating CTA (Mobile) --- */
.floating-cta{display:none;position:fixed;bottom:0;left:0;width:100%;background:#e53935;color:#fff;text-align:center;padding:.75rem 1rem;font-weight:700;font-size:1rem;z-index:998;box-shadow:0 -4px 20px rgba(0,0,0,.15);text-decoration:none;align-items:center;justify-content:center;gap:.4rem}
.floating-cta svg{width:18px;height:18px;fill:#fff;flex-shrink:0}
.floating-cta:hover{color:#fff;background:#c62828}

/* --- Popup Overlay --- */
.popup-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.5);z-index:2000;display:none;align-items:center;justify-content:center;padding:1rem}
.popup-overlay.active{display:flex}
.popup{background:#fff;border-radius:16px;max-width:480px;width:100%;padding:2.5rem;position:relative;text-align:center;animation:popupIn .3s ease}
@keyframes popupIn{from{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}
.popup-close{position:absolute;top:1rem;right:1rem;width:32px;height:32px;background:#f5f5f5;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:#666;transition:background .2s}
.popup-close:hover{background:#e0e0e0}
.popup h3{font-size:1.3rem;margin-bottom:.5rem;color:#0d1b2a}
.popup p{color:#546e7a;margin-bottom:1.5rem;font-size:.95rem}
.popup .btn-cta{width:100%;justify-content:center;padding:1rem;font-size:1.1rem}
.popup-phone{font-size:1.8rem;font-weight:800;color:#0d47a1;margin-bottom:1rem;display:block}

/* --- Page Header (Inner Pages) --- */
.page-header{background:linear-gradient(135deg,#0d1b2a 0%,#1a365d 100%);color:#fff;padding:3.5rem 0 3rem;position:relative}
.page-header h1{color:#fff;margin-bottom:.5rem}
.page-header p{color:#b0c4de;font-size:1.05rem}
.breadcrumb{display:flex;align-items:center;gap:.4rem;font-size:.85rem;margin-bottom:1rem;flex-wrap:wrap}
.breadcrumb a{color:#90caf9}
.breadcrumb a:hover{color:#fff}
.breadcrumb span{color:#546e7a}

/* --- Content Styles (Inner Pages) --- */
.content-section{padding:3rem 0}
.content-grid{display:grid;grid-template-columns:1fr 340px;gap:3rem}
.content-main h2{color:#0d1b2a;margin-top:2rem}
.content-main h2:first-child{margin-top:0}
.content-main ul,.content-main ol{margin:1rem 0 1.5rem 1.25rem}
.content-main li{margin-bottom:.5rem;font-size:.95rem;color:#37474f}
.content-main ul li{list-style:disc}
.content-main ol li{list-style:decimal}

/* Sidebar */
.sidebar{position:sticky;top:6rem;align-self:start}
.sidebar-widget{background:#f8fafc;border:1px solid #e8edf2;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem}
.sidebar-widget h4{font-size:.95rem;margin-bottom:1rem;color:#0d1b2a}
.sidebar-cta{background:linear-gradient(135deg,#1565c0,#0d47a1);color:#fff;border-radius:12px;padding:2rem;text-align:center;margin-bottom:1.5rem}
.sidebar-cta h4{color:#fff;font-size:1.1rem;margin-bottom:.5rem}
.sidebar-cta p{color:#bbdefb;font-size:.9rem;margin-bottom:1rem}
.sidebar-cta .btn-cta{width:100%;justify-content:center}
.sidebar-links a{display:block;padding:.55rem 0;font-size:.9rem;color:#37474f;border-bottom:1px solid #f0f0f0}
.sidebar-links a:last-child{border:none}
.sidebar-links a:hover{color:#1565c0}
.sidebar-links a.active{color:#1565c0;font-weight:600}

/* --- Area Page Specific --- */
.area-hero{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:center}
.area-map{border-radius:12px;overflow:hidden;height:300px;border:1px solid #e0e0e0}
.area-map iframe{width:100%;height:100%;border:0}
.area-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin:1.5rem 0}
.area-stat{text-align:center;padding:1rem;background:#f8fafc;border-radius:8px}
.area-stat-value{font-size:1.5rem;font-weight:800;color:#1565c0}
.area-stat-label{font-size:.8rem;color:#90a4ae;margin-top:.2rem}

/* --- Blog Styles --- */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.5rem}
.blog-card{background:#fff;border:1px solid #e8edf2;border-radius:12px;overflow:hidden;transition:all .3s}
.blog-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,0,0,.08)}
.blog-card-image{height:200px;overflow:hidden}
.blog-card-image img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.blog-card:hover .blog-card-image img{transform:scale(1.05)}
.blog-card-body{padding:1.5rem}
.blog-card-tag{font-size:.72rem;font-weight:700;color:#1565c0;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.5rem;display:inline-block}
.blog-card h3{font-size:1.1rem;margin-bottom:.5rem;margin-top:0}
.blog-card p{font-size:.88rem;color:#546e7a;margin-bottom:1rem}
.blog-card-meta{font-size:.8rem;color:#90a4ae}

/* Blog Post */
.toc{background:#f8fafc;border:1px solid #e8edf2;border-radius:12px;padding:1.5rem 2rem;margin:1.5rem 0 2rem}
.toc h4{font-size:.95rem;margin-bottom:.75rem;color:#0d1b2a}
.toc ol{margin:0;padding-left:1.25rem}
.toc li{margin-bottom:.4rem;font-size:.9rem}
.toc a{color:#1565c0;font-weight:500}
.direct-answer{background:#e8f5e9;border-left:4px solid #2e7d32;padding:1.25rem 1.5rem;border-radius:0 8px 8px 0;margin:1.5rem 0;font-size:1.02rem;line-height:1.8}

/* --- Contact Form --- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem}
.form-group{margin-bottom:1.25rem}
.form-group label{display:block;font-size:.88rem;font-weight:600;color:#0d1b2a;margin-bottom:.4rem}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem 1rem;border:1px solid #d0d5dd;border-radius:8px;font-size:.95rem;font-family:inherit;transition:border-color .2s;background:#fff}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#1565c0;box-shadow:0 0 0 3px rgba(21,101,192,.1)}
.form-group textarea{height:120px;resize:vertical}
.contact-info-card{background:#f8fafc;border-radius:12px;padding:2rem;border:1px solid #e8edf2}
.emergency-box{background:#fbe9e7;border:2px solid #e53935;border-radius:12px;padding:2rem;text-align:center;margin-bottom:1.5rem}
.emergency-box h3{color:#c62828;margin-bottom:.5rem}
.emergency-box .phone-big{font-size:1.8rem;font-weight:800;color:#e53935;display:block;margin:.75rem 0}

/* --- Animations --- */
.fade-in{opacity:0;transform:translateY(20px);transition:all .6s ease}
.fade-in.visible{opacity:1;transform:translateY(0)}
.slide-left{opacity:0;transform:translateX(-30px);transition:all .6s ease}
.slide-left.visible{opacity:1;transform:translateX(0)}
.slide-right{opacity:0;transform:translateX(30px);transition:all .6s ease}
.slide-right.visible{opacity:1;transform:translateX(0)}

/* --- Image Credit --- */
.img-credit{font-size:.7rem;color:#b0b0b0;margin-top:.25rem;text-align:right}

/* --- Responsive --- */
@media(max-width:1024px){
  .hero-grid{grid-template-columns:1fr;text-align:center}
  .hero-content{max-width:none}
  .hero-buttons{justify-content:center}
  .hero-trust{justify-content:center}
  .hero-image{display:none}
  .content-grid{grid-template-columns:1fr}
  .sidebar{position:static;display:grid;grid-template-columns:1fr 1fr;gap:1rem}
  .footer-grid{grid-template-columns:1fr 1fr 1fr}
  .contact-grid{grid-template-columns:1fr}
  .area-hero{grid-template-columns:1fr}
}

@media(max-width:768px){
  .top-bar-right{display:none}
  .nav-links{display:none}
  .header-phone{display:none}
  .hamburger{display:flex}
  .floating-cta{display:flex}
  .hero{padding:3rem 0 2.5rem}
  .section{padding:3rem 0}
  .services-grid{grid-template-columns:1fr}
  .features-grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .reviews-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .sidebar{grid-template-columns:1fr}
  .blog-grid{grid-template-columns:1fr}
  .area-stats{grid-template-columns:1fr}
  .hero-buttons{flex-direction:column;align-items:stretch}
  table{display:block;overflow-x:auto}
  .page-header{padding:2.5rem 0 2rem}
}

@media(max-width:480px){
  h1{font-size:1.6rem}
  h2{font-size:1.25rem}
  .popup{padding:1.5rem;margin:1rem}
}

/* --- Back to Top Button --- */
.back-to-top{position:fixed;bottom:5rem;right:1.5rem;width:44px;height:44px;background:#1565c0;color:#fff;border:none;border-radius:50%;cursor:pointer;display:none;align-items:center;justify-content:center;box-shadow:0 4px 15px rgba(0,0,0,.2);transition:all .3s;z-index:997;font-size:1.2rem}
.back-to-top:hover{background:#0d47a1;transform:translateY(-2px)}
.back-to-top.visible{display:flex}

/* --- Google Map Embed --- */
.map-embed{border-radius:12px;overflow:hidden;margin:1.5rem 0;border:1px solid #e0e0e0}
.map-embed iframe{width:100%;height:300px;border:0}

/* --- Pricing Highlight --- */
.price-highlight{background:linear-gradient(135deg,#e3f2fd,#f0f7ff);border:1px solid #bbdefb;border-radius:12px;padding:2rem;margin:1.5rem 0;text-align:center}
.price-highlight .price{font-size:2rem;font-weight:800;color:#0d47a1}
.price-highlight .price-label{font-size:.85rem;color:#90a4ae;margin-top:.25rem}

/* --- Trust Badge Row --- */
.trust-badges{display:flex;gap:1.5rem;flex-wrap:wrap;justify-content:center;padding:1.5rem 0;margin:1rem 0;border-top:1px solid #e8edf2;border-bottom:1px solid #e8edf2}
.trust-badge{display:flex;align-items:center;gap:.5rem;font-size:.88rem;font-weight:600;color:#37474f}
.trust-badge svg{width:20px;height:20px;fill:#2e7d32}

/* --- 404 Page --- */
.error-page{text-align:center;padding:6rem 1.5rem}
.error-page h1{font-size:6rem;color:#e0e0e0;margin-bottom:0}
.error-page p{font-size:1.2rem;color:#546e7a;margin:1rem 0 2rem}

/* --- Content Image --- */
.content-image{border-radius:12px;overflow:hidden;margin:1.5rem 0}
.content-image img{width:100%;height:auto;display:block}

/* --- Scrollbar for dropdown --- */
.dropdown-menu::-webkit-scrollbar{width:6px}
.dropdown-menu::-webkit-scrollbar-track{background:#f5f5f5;border-radius:3px}
.dropdown-menu::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}
.dropdown-menu::-webkit-scrollbar-thumb:hover{background:#aaa}

/* --- Google Maps Embed --- */
.map-container{width:100%;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px rgba(0,0,0,.08);margin:1rem 0}
.map-container iframe{width:100%;min-height:300px;display:block}
