/*
Theme Name: Home4Quotes Kadence Child
Template: kadence
Version: 4.0.0
Description: Home Services Directory — Complete Clean Build
*/

/* ==========================================================================
   1. CSS VARIABLES
========================================================================== */
:root {
    --blue:        #0056b3;
    --blue-dark:   #003d82;
    --blue-light:  #1a6fd4;
    --yellow:      #ffc107;
    --yellow-dark: #e0a800;
    --red:         #e63946;
    --dark:        #1a1a2e;
    --mid:         #4a4a6a;
    --light:       #f4f7fb;
    --white:       #ffffff;
    --border:      #e2e8f0;
    --footer-bg:   #0d1b2a;
    --shadow:      0 4px 20px rgba(0,86,179,.10);
    --shadow-md:   0 8px 30px rgba(0,86,179,.16);
    --radius:      10px;
    --radius-lg:   16px;
    --ease:        all 0.25s ease;
}

/* ==========================================================================
   2. RESET
========================================================================== */
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body { font-family:'Open Sans',sans-serif; color:var(--dark); line-height:1.65; overflow-x:hidden; background:var(--white); }
a { text-decoration:none; color:inherit; }
img { max-width:100%; height:auto; display:block; }
ul { list-style:none; }
button { cursor:pointer; font-family:inherit; }

/* ==========================================================================
   3. SUPPRESS KADENCE — Safe selectors only (NOT our .main-header or .footer)
========================================================================== */
body.h4q-custom-page #masthead,
body.h4q-custom-page .site-header,
body.h4q-custom-page header.header-wrap,
body.h4q-custom-page .kadence-header,
body.h4q-custom-page .kadence-top-header,
body.h4q-custom-page #colophon,
body.h4q-custom-page .site-footer,
body.h4q-custom-page footer.footer-wrap,
body.h4q-custom-page .kadence-footer,
body.h4q-custom-page .kadence-bottom-footer,
body.h4q-custom-page .kadence-copyright,
body.h4q-custom-page .skip-link,
body.h4q-custom-page #kadence-sticky-placeholder,
body.h4q-custom-page .entry-header,
body.h4q-custom-page .wp-block-post-title { display:none !important; }

body.h4q-custom-page { padding-top:0 !important; margin-top:0 !important; }
body.h4q-custom-page .site,
body.h4q-custom-page #content,
body.h4q-custom-page .site-content,
body.h4q-custom-page .content-area,
body.h4q-custom-page .wp-site-blocks { padding:0 !important; margin:0 !important; max-width:100% !important; width:100% !important; }

/* Force OUR elements always visible */
body.h4q-custom-page .top-header,
body.h4q-custom-page .main-header,
body.h4q-custom-page .footer,
body.h4q-custom-page .copyright { display:block !important; visibility:visible !important; }

/* ==========================================================================
   4. UTILITIES
========================================================================== */
.container { max-width:1200px; margin:0 auto; padding:0 24px; }

.section-title { text-align:center; margin-bottom:52px; }
.section-title h2 { font-family:'Playfair Display',serif; font-size:clamp(26px,3.5vw,40px); font-weight:700; color:var(--dark); margin-bottom:14px; }
.section-title p { font-size:17px; color:var(--mid); max-width:600px; margin:0 auto; line-height:1.7; }
.section-title .underline { width:56px; height:4px; background:var(--yellow); border-radius:2px; margin:16px auto 0; }

/* ==========================================================================
   5. BUTTONS
========================================================================== */
.btn {
    display:inline-flex; align-items:center; justify-content:center; gap:8px;
    padding:13px 28px; border-radius:var(--radius); border:none;
    font-family:'Open Sans',sans-serif; font-weight:700; font-size:15px;
    cursor:pointer; transition:var(--ease); text-decoration:none; white-space:nowrap;
    -webkit-tap-highlight-color:transparent;
}
.btn-primary  { background:var(--blue);   color:var(--white); box-shadow:0 4px 14px rgba(0,86,179,.30); }
.btn-primary:hover  { background:var(--blue-dark); transform:translateY(-2px); box-shadow:0 6px 20px rgba(0,86,179,.40); color:var(--white); }
.btn-secondary { background:var(--yellow); color:var(--dark); box-shadow:0 4px 14px rgba(255,193,7,.30); }
.btn-secondary:hover { background:var(--yellow-dark); transform:translateY(-2px); color:var(--dark); }
.btn-outline-white { background:transparent; color:var(--white); border:2px solid rgba(255,255,255,.65); }
.btn-outline-white:hover { background:rgba(255,255,255,.15); border-color:var(--white); color:var(--white); }
.btn-lg { padding:15px 34px; font-size:16px; }
.btn-sm { padding:9px 18px; font-size:13px; }

/* ==========================================================================
   6. TOP HEADER BAR
========================================================================== */
.top-header { background:var(--yellow); padding:9px 0; text-align:center; }
.top-header p { margin:0; font-size:13.5px; color:var(--dark); font-weight:500; }
.top-header a { color:var(--blue-dark); font-weight:700; text-decoration:underline; }

/* ==========================================================================
   7. MAIN HEADER + NAVIGATION
========================================================================== */
.main-header {
    background:var(--white);
    padding:14px 0;
    box-shadow:0 2px 16px rgba(0,0,0,.09);
    position:sticky;
    top:0;
    z-index:9000;
    display:block !important;
    visibility:visible !important;
}

.header-container {
    max-width:1200px; margin:0 auto; padding:0 24px;
    display:flex; align-items:center; justify-content:space-between; gap:20px;
}

.logo img { max-height:52px; width:auto; }

/* Desktop nav */
.main-nav ul { display:flex; align-items:center; gap:32px; }
.main-nav ul li a { font-size:15px; font-weight:600; color:var(--dark); padding:6px 0; position:relative; transition:var(--ease); }
.main-nav ul li a::after { content:''; position:absolute; bottom:-2px; left:0; width:0; height:2px; background:var(--blue); transition:var(--ease); }
.main-nav ul li a:hover { color:var(--blue); }
.main-nav ul li a:hover::after { width:100%; }

/* Desktop dropdown — CSS hover only, never sticky */
.dropdown { position:relative; }
.dropdown-toggle { display:flex; align-items:center; gap:4px; }
.dropdown-toggle::after { content:'▾'; font-size:11px; transition:var(--ease); }
.dropdown:hover .dropdown-toggle::after { transform:rotate(180deg); }

.dropdown-menu {
    display:none; position:absolute; top:calc(100% + 10px); left:-16px;
    background:var(--white); border-radius:var(--radius);
    box-shadow:0 10px 40px rgba(0,0,0,.14); min-width:220px;
    padding:8px 0; z-index:99999; border:1px solid var(--border);
}
.dropdown:hover .dropdown-menu { display:block; }
.dropdown-menu li a { display:block; padding:10px 20px; font-size:14px; color:var(--dark); transition:var(--ease); }
.dropdown-menu li a:hover { background:var(--light); color:var(--blue); padding-left:26px; }
.dropdown-menu li a::after { display:none; }

/* Header actions */
.header-actions { display:flex; align-items:center; gap:18px; }
.phone-link { font-weight:700; color:var(--blue); font-size:15px; display:flex; align-items:center; gap:6px; transition:var(--ease); }
.phone-link::before { content:'📞'; font-size:14px; }
.phone-link:hover { color:var(--blue-dark); }

/* Hamburger toggle — zero browser styling */
.mobile-toggle {
    display: none;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 5px;
    width: 44px;
    height: 44px;
    padding: 8px;
    cursor: pointer;
    background: transparent !important;
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    -webkit-tap-highlight-color: transparent !important;
    user-select: none;
}
/* Remove any :focus blue ring */
.mobile-toggle:focus,
.mobile-toggle:focus-visible,
.mobile-toggle:active {
    outline: none !important;
    box-shadow: none !important;
    background: transparent !important;
    border: none !important;
}
.mobile-toggle span {
    display: block;
    width: 24px;
    height: 2px;
    background: var(--dark);
    border-radius: 2px;
    transition: all 0.28s ease;
    pointer-events: none;
    transform-origin: center;
}
/* Animate to × when menu open */
.mobile-toggle.active span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.mobile-toggle.active span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.mobile-toggle.active span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Menu close × inside slide panel */
.menu-close {
    display:none; position:absolute; top:18px; right:18px;
    font-size:26px; line-height:1; cursor:pointer; color:var(--dark);
    background:none; border:none; padding:4px;
}

/* Overlay */
.menu-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.52); z-index:8998; }
.menu-overlay.active { display:block; }

/* ==========================================================================
   8. HERO SECTION — Keep exact original look, NO overlay
========================================================================== */
.hero-section {
    position:relative; min-height:600px;
    display:flex; align-items:center;
    background-size:cover; background-position:center; background-repeat:no-repeat;
    overflow:hidden;
}
/* NO .hero-overlay blue block — removed completely */
.hero-content { position:relative; z-index:2; width:100%; max-width:1200px; margin:0 auto; padding:80px 24px; }
.hero-text { max-width:680px; }

.hero-text h1 {
    font-family:'Playfair Display',serif !important;
    font-size:clamp(32px,5vw,54px); font-weight:700; line-height:1.15;
    color:#ffffff !important; margin-bottom:18px;
    text-shadow:0 2px 12px rgba(0,0,0,.35);
}
.hero-text p { font-size:18px; color:rgba(255,255,255,.92); margin-bottom:32px; line-height:1.6; }

/* Search box */
.search-container { position:relative; margin-bottom:28px; }
.search-box { display:flex; background:var(--white); border-radius:var(--radius); overflow:hidden; box-shadow:0 8px 32px rgba(0,0,0,.22); max-width:580px; }
.search-box input { flex:1; padding:16px 20px; border:none; outline:none; font-size:16px; font-family:'Open Sans',sans-serif; color:var(--dark); }
.search-box button { background:var(--yellow); border:none; padding:16px 26px; font-size:18px; color:var(--dark); font-weight:700; transition:var(--ease); cursor:pointer; }
.search-box button:hover { background:var(--yellow-dark); }

.autocomplete-list { display:none; position:absolute; top:calc(100% + 4px); left:0; right:0; max-width:580px; background:var(--white); border-radius:var(--radius); box-shadow:0 8px 30px rgba(0,0,0,.15); z-index:1000; overflow:hidden; }
.autocomplete-item { padding:12px 20px; cursor:pointer; font-size:15px; color:var(--dark); display:flex; align-items:center; gap:10px; transition:var(--ease); border-bottom:1px solid #f0f0f0; }
.autocomplete-item:last-child { border-bottom:none; }
.autocomplete-item:hover { background:var(--light); color:var(--blue); }

/* Popular service tags */
.popular-services h4 { color:rgba(255,255,255,.8); font-size:12px; font-family:'Open Sans',sans-serif; font-weight:700; text-transform:uppercase; letter-spacing:1px; margin-bottom:12px; }
.service-tags { display:flex; flex-wrap:wrap; gap:10px; }
.service-tag { display:inline-block; padding:7px 16px; background:rgba(255,255,255,.18); color:var(--white); border-radius:50px; font-size:13px; border:1px solid rgba(255,255,255,.35); transition:var(--ease); }
.service-tag:hover { background:var(--yellow); color:var(--dark); border-color:var(--yellow); transform:translateY(-1px); }

/* ==========================================================================
   9. HOW IT WORKS
========================================================================== */
.how-it-works-section { padding:90px 0; background:var(--white); }
.steps-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.step-card { text-align:center; padding:36px 28px; background:var(--white); border-radius:var(--radius-lg); border:2px solid var(--border); transition:var(--ease); }
.step-card:hover { border-color:var(--blue); transform:translateY(-6px); box-shadow:var(--shadow-md); }
.step-number { width:64px; height:64px; background:var(--blue); color:var(--white); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:22px; font-weight:700; font-family:'Playfair Display',serif; margin:0 auto 20px; box-shadow:0 4px 16px rgba(0,86,179,.3); }
.step-icon { font-size:32px; color:var(--yellow); margin-bottom:16px; }
.step-card h3 { font-family:'Playfair Display',serif; font-size:20px; margin-bottom:12px; color:var(--dark); }
.step-card p { font-size:15px; color:var(--mid); line-height:1.65; }

/* ==========================================================================
   10. SERVICES GRID
========================================================================== */
.services-section { padding:90px 0; background:var(--light); }
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-bottom:44px; }
.service-card { position:relative; border-radius:var(--radius-lg); overflow:hidden; aspect-ratio:4/3; box-shadow:var(--shadow); transition:var(--ease); }
.service-card:hover { transform:translateY(-5px); box-shadow:var(--shadow-md); }
.service-card img { width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.service-card:hover img { transform:scale(1.07); }
.service-card-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(0,0,0,.72) 0%,transparent 60%); display:flex; align-items:flex-end; padding:18px; transition:var(--ease); }
.service-card:hover .service-card-overlay { background:linear-gradient(to top,rgba(0,86,179,.82) 0%,rgba(0,86,179,.2) 60%,transparent 100%); }
.service-card-overlay h3 { font-family:'Playfair Display',serif; color:var(--white); font-size:19px; font-weight:700; text-shadow:0 2px 6px rgba(0,0,0,.4); }
.services-center { text-align:center; }

/* ==========================================================================
   11. STATS BANNER
========================================================================== */
.stats-banner { padding:56px 0; background:linear-gradient(135deg,var(--blue) 0%,var(--blue-dark) 100%); position:relative; overflow:hidden; }
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.stat-item { text-align:center; padding:16px; }
.stat-number { display:block; font-size:clamp(32px,4vw,50px); font-family:'Playfair Display',serif; font-weight:700; color:var(--yellow); line-height:1; margin-bottom:8px; }
.stat-label { font-size:14px; color:rgba(255,255,255,.85); font-weight:500; }

/* ==========================================================================
   12. ZIP CTA
========================================================================== */
.cta-section { padding:80px 0; background:var(--white); }
.cta-box { background:var(--light); border-radius:var(--radius-lg); padding:52px 48px; display:flex; align-items:center; justify-content:space-between; gap:40px; border:2px solid var(--border); }
.cta-text h3 { font-family:'Playfair Display',serif; font-size:clamp(20px,2.8vw,30px); margin-bottom:10px; color:var(--dark); }
.cta-text p { font-size:15px; color:var(--mid); }
.cta-form { display:flex; gap:12px; flex-shrink:0; }
.cta-form input { padding:13px 18px; border:2px solid var(--border); border-radius:var(--radius); font-size:15px; width:190px; font-family:'Open Sans',sans-serif; outline:none; transition:var(--ease); }
.cta-form input:focus { border-color:var(--blue); }

/* ==========================================================================
   13. WHY CHOOSE US
========================================================================== */
.why-choose-section { padding:90px 0; background:var(--light); }
.why-choose-container { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }
.why-choose-image img { width:100%; border-radius:var(--radius-lg); box-shadow:0 20px 60px rgba(0,0,0,.14); }
.why-choose-content h4 { font-family:'Open Sans',sans-serif; font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:1.5px; color:var(--blue); margin-bottom:12px; }
.why-choose-content h2 { font-family:'Playfair Display',serif; font-size:clamp(24px,3vw,34px); margin-bottom:16px; }
.why-choose-content p { color:var(--mid); font-size:16px; margin-bottom:28px; line-height:1.7; }
.why-list { margin-bottom:36px; }
.why-list li { display:flex; align-items:flex-start; gap:14px; margin-bottom:16px; font-size:15px; color:var(--dark); }
.why-list li .check-icon { width:26px; height:26px; background:var(--blue); border-radius:50%; display:flex; align-items:center; justify-content:center; flex-shrink:0; margin-top:1px; }
.why-list li .check-icon i { color:var(--white); font-size:12px; }

/* ==========================================================================
   14. TESTIMONIALS
========================================================================== */
.testimonials-section { padding:90px 0; background:var(--white); }
.testimonials-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.testimonial-card { background:var(--white); border-radius:var(--radius-lg); padding:32px 28px; border:2px solid var(--border); transition:var(--ease); }
.testimonial-card:hover { border-color:var(--blue); transform:translateY(-4px); box-shadow:var(--shadow-md); }
.quote-icon { font-size:48px; color:var(--yellow); line-height:1; font-family:Georgia,serif; margin-bottom:12px; }
.testimonial-stars { color:var(--yellow); font-size:17px; letter-spacing:2px; margin-bottom:14px; }
.testimonial-card p { color:var(--mid); font-size:15px; line-height:1.7; margin-bottom:22px; font-style:italic; }
.testimonial-author { display:flex; align-items:center; gap:13px; }
.author-avatar { width:46px; height:46px; border-radius:50%; background:var(--blue); color:var(--white); display:flex; align-items:center; justify-content:center; font-size:17px; font-weight:700; font-family:'Playfair Display',serif; flex-shrink:0; }
.author-info strong { display:block; font-size:15px; color:var(--dark); font-weight:700; margin-bottom:3px; }
.author-info span { font-size:13px; color:var(--mid); }

/* ==========================================================================
   15. CATEGORIES GRID
========================================================================== */
.categories-section { padding:90px 0; background:var(--light); }
.categories-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.category-card { background:var(--white); border-radius:var(--radius-lg); padding:32px 20px; text-align:center; border:2px solid var(--border); transition:var(--ease); display:block; text-decoration:none; }
.category-card:hover { border-color:var(--blue); transform:translateY(-5px); box-shadow:var(--shadow-md); background:var(--blue); }
.category-card:hover .category-icon { background:rgba(255,255,255,.2); color:var(--white); }
.category-card:hover .category-name { color:var(--white); }
.category-icon { width:68px; height:68px; background:var(--light); border-radius:50%; display:flex; align-items:center; justify-content:center; margin:0 auto 16px; font-size:26px; color:var(--blue); transition:var(--ease); }
.category-name { font-size:14px; font-weight:700; color:var(--dark); transition:var(--ease); font-family:'Open Sans',sans-serif; }

/* ==========================================================================
   16. BLOG (homepage section)
========================================================================== */
.blog-section { padding:90px 0; background:var(--white); }
.blog-header { text-align:center; margin-bottom:48px; }
.blog-header h2 { font-family:'Playfair Display',serif; font-size:clamp(24px,3vw,36px); margin-bottom:14px; }
.blog-header p { color:var(--mid); font-size:16px; max-width:600px; margin:0 auto 20px; line-height:1.7; }
.see-all-link { color:var(--blue); font-weight:700; font-size:14px; text-transform:uppercase; letter-spacing:.8px; display:inline-flex; align-items:center; gap:6px; transition:var(--ease); }
.see-all-link::after { content:'→'; }
.see-all-link:hover { color:var(--blue-dark); gap:10px; }
.blog-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:28px; }
.blog-card { border-radius:var(--radius-lg); overflow:hidden; background:var(--white); border:1px solid var(--border); transition:var(--ease); }
.blog-card:hover { transform:translateY(-5px); box-shadow:var(--shadow-md); }
.blog-image { overflow:hidden; aspect-ratio:16/9; }
.blog-image img { width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.blog-card:hover .blog-image img { transform:scale(1.05); }
.blog-content { padding:26px; }
.blog-meta { display:flex; gap:14px; font-size:13px; color:var(--mid); margin-bottom:10px; }
.blog-content h3 { font-family:'Playfair Display',serif; font-size:19px; margin-bottom:10px; line-height:1.35; }
.blog-content h3 a { color:var(--dark); transition:var(--ease); }
.blog-card:hover .blog-content h3 a { color:var(--blue); }
.blog-content p { color:var(--mid); font-size:14.5px; line-height:1.65; margin-bottom:18px; }
.read-more { color:var(--blue); font-weight:700; font-size:13.5px; display:inline-flex; align-items:center; gap:5px; transition:var(--ease); }
.read-more::after { content:'→'; }
.read-more:hover { color:var(--blue-dark); gap:9px; }

/* ==========================================================================
   17. FOOTER
========================================================================== */
.footer {
    background:var(--footer-bg) !important;
    padding:64px 0 0 !important;
    display:block !important;
    visibility:visible !important;
}
.footer-container { max-width:1200px; margin:0 auto; padding:0 24px 52px; display:grid; grid-template-columns:1.6fr 1fr 1.2fr 1fr; gap:48px; border-bottom:1px solid rgba(255,255,255,.08); }
.footer-logo { margin-bottom:16px; }
.footer-logo img { max-height:46px; }
.footer-col > p { color:rgba(255,255,255,.55); font-size:14px; line-height:1.7; margin-bottom:22px; }
.social-links { display:flex; gap:10px; }
.social-links a { width:36px; height:36px; background:rgba(255,255,255,.1); border-radius:50%; display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.65); font-size:14px; transition:var(--ease); }
.social-links a:hover { background:var(--blue); color:var(--white); transform:translateY(-2px); }
.footer-col h3, .footer-col h4 { font-family:'Open Sans',sans-serif !important; font-size:11px !important; font-weight:700; color:rgba(255,255,255,.4) !important; text-transform:uppercase; letter-spacing:1.5px; margin-bottom:20px; }
.footer-links li { margin-bottom:11px; }
.footer-links li a { color:rgba(255,255,255,.62); font-size:14px; display:flex; align-items:center; gap:8px; transition:var(--ease); }
.footer-links li a::before { content:'›'; color:var(--yellow); font-size:16px; line-height:1; }
.footer-links li a:hover { color:var(--white); padding-left:5px; }
.footer-cta .phone { display:block; font-family:'Playfair Display',serif !important; font-size:26px !important; font-weight:700; color:var(--yellow) !important; margin-bottom:18px; transition:var(--ease); }
.footer-cta .phone:hover { color:var(--white) !important; }
.footer-cta .btn { width:100%; }
.copyright { background:rgba(0,0,0,.3); padding:18px 24px; text-align:center; margin-top:0 !important; display:block !important; }
.copyright p { color:rgba(255,255,255,.35); font-size:13px; margin:0; }

/* Back to top */
.back-to-top { position:fixed; bottom:28px; right:28px; width:44px; height:44px; background:var(--blue); color:var(--white); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:15px; box-shadow:0 4px 16px rgba(0,86,179,.4); transition:var(--ease); opacity:0; pointer-events:none; z-index:9997; text-decoration:none; }
.back-to-top.visible { opacity:1; pointer-events:auto; }
.back-to-top:hover { background:var(--blue-dark); transform:translateY(-3px); color:var(--white); }

/* ==========================================================================
   18. PAGE BANNER (inner pages)
========================================================================== */
.page-banner { background:linear-gradient(135deg,var(--blue) 0%,var(--blue-dark) 100%); padding:56px 0; }
.page-banner-content { text-align:center; }
.page-banner h1 { font-family:'Playfair Display',serif; font-size:clamp(26px,4vw,44px); color:var(--white); margin-bottom:12px; }
.breadcrumb { display:flex; align-items:center; justify-content:center; gap:8px; color:rgba(255,255,255,.65); font-size:13.5px; }
.breadcrumb a { color:var(--yellow); transition:var(--ease); }
.breadcrumb a:hover { color:var(--white); }

/* ==========================================================================
   19. SERVICES DIRECTORY PAGE
========================================================================== */
.services-directory { padding:64px 0; background:var(--light); }
.zip-result-bar { background:var(--yellow); padding:13px 0; text-align:center; font-weight:600; font-size:15px; color:var(--dark); display:none; }
.zip-result-bar.visible { display:block; }
.filter-bar { background:var(--white); border-radius:var(--radius-lg); padding:22px 26px; margin-bottom:32px; display:flex; align-items:center; gap:16px; flex-wrap:wrap; box-shadow:var(--shadow); border:1px solid var(--border); }
.filter-search { flex:1; min-width:200px; display:flex; align-items:center; gap:10px; background:var(--light); border:2px solid var(--border); border-radius:var(--radius); padding:10px 16px; transition:var(--ease); }
.filter-search:focus-within { border-color:var(--blue); }
.filter-search i { color:var(--mid); font-size:14px; }
.filter-search input { border:none; background:transparent; outline:none; font-size:15px; font-family:'Open Sans',sans-serif; color:var(--dark); width:100%; }
.filter-btns { display:flex; gap:8px; flex-wrap:wrap; }
.filter-btn { padding:9px 18px; border-radius:50px; border:2px solid var(--border); background:transparent; font-size:13.5px; font-weight:600; color:var(--mid); cursor:pointer; transition:var(--ease); font-family:'Open Sans',sans-serif; }
.filter-btn:hover, .filter-btn.active { background:var(--blue); border-color:var(--blue); color:var(--white); }
.services-list-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.service-list-card { background:var(--white); border-radius:var(--radius-lg); padding:30px 26px; border:2px solid var(--border); transition:var(--ease); display:flex; flex-direction:column; }
.service-list-card:hover { border-color:var(--blue); transform:translateY(-4px); box-shadow:var(--shadow-md); }
.svc-icon { width:62px; height:62px; background:var(--light); border-radius:var(--radius); display:flex; align-items:center; justify-content:center; font-size:24px; color:var(--blue); margin-bottom:16px; transition:var(--ease); }
.service-list-card:hover .svc-icon { background:var(--blue); color:var(--white); }
.service-list-card h3 { font-family:'Playfair Display',serif; font-size:18px; margin-bottom:10px; font-weight:700; }
.service-list-card p { color:var(--mid); font-size:14px; line-height:1.65; margin-bottom:20px; flex:1; }
.svc-category-tag { display:inline-block; padding:3px 11px; background:var(--light); border-radius:50px; font-size:11.5px; font-weight:600; color:var(--mid); text-transform:uppercase; letter-spacing:.5px; margin-bottom:18px; }

/* ==========================================================================
   20. SERVICE LANDING PAGE
========================================================================== */
.svc-lp-hero { position:relative; min-height:600px; background-size:cover; background-position:center; display:flex; align-items:center; padding:80px 0; }
.svc-lp-hero-overlay { position:absolute; inset:0; background:rgba(0,0,0,.44); }
.svc-lp-hero-inner { position:relative; z-index:3; display:grid; grid-template-columns:1fr 400px; gap:48px; align-items:center; }
.svc-breadcrumb { display:flex; gap:8px; align-items:center; color:rgba(255,255,255,.65); font-size:13px; margin-bottom:10px; }
.svc-breadcrumb a { color:var(--yellow); transition:var(--ease); }
.svc-hero-icon { font-size:36px; color:var(--yellow); margin-bottom:10px; }
.svc-lp-hero-left h1 { font-family:'Playfair Display',serif !important; font-size:clamp(28px,4vw,48px); color:var(--white) !important; font-weight:700; line-height:1.15; margin:12px 0 16px; text-shadow:0 2px 10px rgba(0,0,0,.3); }
.svc-lp-hero-left > p { font-size:17px; color:rgba(255,255,255,.88); line-height:1.65; margin-bottom:22px; max-width:500px; }
.svc-hero-badges { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:26px; }
.svc-hero-badge { display:inline-flex; align-items:center; gap:6px; background:rgba(255,255,255,.15); border:1px solid rgba(255,255,255,.3); color:rgba(255,255,255,.92); padding:6px 13px; border-radius:50px; font-size:13px; font-weight:600; }
.svc-hero-ctas { display:flex; gap:14px; flex-wrap:wrap; align-items:center; }
.svc-call-btn { display:inline-flex; align-items:center; gap:8px; color:var(--white); font-size:15px; font-weight:700; padding:13px 0; border-bottom:2px solid rgba(255,255,255,.4); transition:var(--ease); text-decoration:none; }
.svc-call-btn:hover { color:var(--yellow); border-color:var(--yellow); }

/* Service hero form */
.svc-hero-form-box { background:var(--white); border-radius:var(--radius-lg); overflow:hidden; box-shadow:0 20px 60px rgba(0,0,0,.25); position:relative; z-index:3; }
.svc-hero-form-header { background:var(--blue); padding:22px 26px; text-align:center; color:var(--white); }
.svc-hero-form-header i { font-size:26px; color:var(--yellow); margin-bottom:7px; display:block; }
.svc-hero-form-header h3 { font-family:'Playfair Display',serif; color:var(--white) !important; font-size:19px; margin-bottom:4px; }
.svc-hero-form-header p { font-size:13px; color:rgba(255,255,255,.75); margin:0; }
.svc-quick-form { padding:20px 22px; display:flex; flex-direction:column; gap:10px; }
.sqf-row { width:100%; }
.sqf-row input, .sqf-row textarea, .sqf-row select { width:100%; padding:11px 14px; border:2px solid var(--border); border-radius:var(--radius); font-size:15px; font-family:'Open Sans',sans-serif; color:var(--dark); background:var(--light); outline:none; transition:var(--ease); box-sizing:border-box; }
.sqf-row input:focus, .sqf-row textarea:focus { border-color:var(--blue); background:var(--white); }
.sqf-row textarea { resize:vertical; min-height:80px; }
.sqf-row .btn { width:100%; margin-top:4px; }
.sqf-privacy { text-align:center; font-size:12px; color:var(--mid); padding:8px 22px 16px; display:flex; align-items:center; justify-content:center; gap:6px; margin:0; }

/* Stats bar */
.svc-stats-bar { background:var(--dark); padding:18px 0; }
.svc-stats-inner { display:flex; align-items:center; justify-content:center; flex-wrap:wrap; }
.svc-stat { text-align:center; padding:12px 32px; }
.svc-stat strong { display:block; font-family:'Playfair Display',serif; font-size:22px; font-weight:700; color:var(--yellow); line-height:1; }
.svc-stat span { font-size:12px; color:rgba(255,255,255,.6); text-transform:uppercase; letter-spacing:.5px; margin-top:3px; display:block; }
.svc-stat-divider { width:1px; height:36px; background:rgba(255,255,255,.15); }

/* Service body */
.svc-lp-body { padding:64px 0; background:var(--light); }
.svc-lp-grid { display:grid; grid-template-columns:1fr 360px; gap:32px; align-items:start; }
.svc-lp-sidebar { position:sticky; top:90px; display:flex; flex-direction:column; gap:18px; }
.svc-content-block { background:var(--white); border-radius:var(--radius-lg); padding:40px; border:1px solid var(--border); margin-bottom:24px; }
.svc-content-block h2 { font-family:'Playfair Display',serif; font-size:24px; margin-bottom:18px; padding-bottom:14px; border-bottom:2px solid var(--border); color:var(--dark); }
.svc-content-block p, .svc-entry-content p { color:var(--mid); font-size:15.5px; line-height:1.75; margin-bottom:14px; }
.svc-included-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.svc-included-item { display:flex; gap:13px; align-items:flex-start; padding:14px; background:var(--light); border-radius:var(--radius); border:1px solid var(--border); }
.svc-included-item > i { color:var(--blue); font-size:20px; margin-top:2px; flex-shrink:0; }
.svc-included-item strong { display:block; font-size:14px; margin-bottom:4px; color:var(--dark); }
.svc-included-item p { font-size:13px; color:var(--mid); margin:0; line-height:1.5; }
.svc-why-block { display:grid; grid-template-columns:1fr 1.2fr; gap:0; padding:0; overflow:hidden; }
.svc-why-left img { width:100%; height:100%; object-fit:cover; min-height:320px; }
.svc-why-right { padding:40px; }
.svc-why-right h2 { font-size:22px; margin-bottom:18px; padding-bottom:12px; border-bottom:2px solid var(--border); }
.svc-why-list { list-style:none; }
.svc-why-list li { display:flex; gap:13px; align-items:flex-start; padding:12px 0; border-bottom:1px solid #f0f0f0; font-size:15px; color:var(--dark); line-height:1.6; }
.svc-why-list li:last-child { border-bottom:none; }
.svc-why-icon { width:34px; height:34px; background:var(--blue); border-radius:50%; display:flex; align-items:center; justify-content:center; flex-shrink:0; margin-top:1px; }
.svc-why-icon i { color:var(--white); font-size:13px; }
.svc-process-steps { display:flex; align-items:center; gap:14px; }
.svc-process-step { flex:1; text-align:center; padding:26px 18px; background:var(--light); border-radius:var(--radius-lg); border:2px solid var(--border); transition:var(--ease); }
.svc-process-step:hover { border-color:var(--blue); transform:translateY(-3px); }
.svc-step-num { width:50px; height:50px; background:var(--blue); color:var(--white); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:18px; font-weight:700; font-family:'Playfair Display',serif; margin:0 auto 14px; }
.svc-process-step h4 { font-family:'Playfair Display',serif; font-size:15px; margin-bottom:7px; }
.svc-process-step p { font-size:13px; color:var(--mid); margin:0; line-height:1.5; }
.svc-process-arrow { color:var(--blue); font-size:18px; flex-shrink:0; }
.svc-related-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.svc-related-card { background:var(--light); border:2px solid var(--border); border-radius:var(--radius); padding:18px 14px; text-align:center; display:flex; flex-direction:column; align-items:center; gap:9px; transition:var(--ease); text-decoration:none; }
.svc-related-card:hover { border-color:var(--blue); background:var(--blue); transform:translateY(-3px); }
.svc-related-card:hover .svc-related-icon,.svc-related-card:hover .svc-related-name,.svc-related-card:hover .svc-related-arrow { color:var(--white); }
.svc-related-icon { font-size:24px; color:var(--blue); transition:var(--ease); }
.svc-related-name { font-size:13.5px; font-weight:700; color:var(--dark); transition:var(--ease); }
.svc-related-arrow { font-size:12px; color:var(--mid); transition:var(--ease); }

/* Sidebar forms */
.svc-sidebar-form-box { background:var(--white); border-radius:var(--radius-lg); border:2px solid var(--blue); overflow:hidden; box-shadow:var(--shadow); }
.svc-sidebar-form-top { background:var(--blue); padding:20px 24px; text-align:center; }
.svc-sidebar-form-top h3 { font-family:'Playfair Display',serif; color:var(--white) !important; font-size:19px; margin-bottom:5px; }
.svc-sidebar-form-top p { color:rgba(255,255,255,.75); font-size:13px; margin:0; }
.svc-form-trust { display:flex; justify-content:space-around; padding:12px 18px; border-top:1px solid var(--border); background:var(--light); }
.svc-form-trust span { font-size:12px; color:var(--mid); display:flex; align-items:center; gap:5px; font-weight:600; }
.svc-form-trust span i { color:var(--blue); }
.svc-phone-box { background:var(--white); border-radius:var(--radius-lg); padding:22px; text-align:center; border:1px solid var(--border); }
.svc-phone-box p { font-size:13.5px; color:var(--mid); margin-bottom:9px; }
.svc-phone-box a { display:block; font-family:'Playfair Display',serif; font-size:22px; font-weight:700; color:var(--blue); margin-bottom:5px; transition:var(--ease); }
.svc-phone-box a:hover { color:var(--blue-dark); }
.svc-phone-box span { font-size:12px; color:var(--mid); display:block; }
.svc-trust-box { background:var(--white); border-radius:var(--radius-lg); padding:24px; border:1px solid var(--border); }
.svc-trust-box h4 { font-family:'Playfair Display',serif; font-size:15px; margin-bottom:14px; padding-bottom:11px; border-bottom:2px solid var(--border); color:var(--dark); }
.svc-trust-box ul li { display:flex; align-items:center; gap:10px; padding:8px 0; font-size:14px; color:var(--dark); border-bottom:1px solid #f5f5f5; }
.svc-trust-box ul li:last-child { border-bottom:none; }
.svc-trust-box ul li i { color:var(--blue); font-size:14px; width:16px; text-align:center; }

/* Service CTA banner */
.svc-cta-banner { background:linear-gradient(135deg,var(--blue) 0%,var(--blue-dark) 100%); padding:56px 0; }
.svc-cta-inner { display:flex; align-items:center; justify-content:space-between; gap:28px; flex-wrap:wrap; }
.svc-cta-text h2 { font-family:'Playfair Display',serif; color:var(--white) !important; font-size:clamp(20px,3vw,30px); margin-bottom:8px; }
.svc-cta-text p { color:rgba(255,255,255,.78); font-size:15px; margin:0; }
.svc-cta-actions { display:flex; gap:14px; align-items:center; flex-shrink:0; }

/* FAQ */
.faq-item { border:1px solid var(--border); border-radius:var(--radius); margin-bottom:10px; overflow:hidden; }
.faq-question { padding:16px 20px; cursor:pointer; display:flex; justify-content:space-between; align-items:center; font-size:15.5px; font-weight:600; color:var(--dark); background:var(--white); transition:var(--ease); user-select:none; gap:12px; }
.faq-question:hover { background:var(--light); color:var(--blue); }
.faq-item.active .faq-question { background:var(--blue); color:var(--white); }
.faq-toggle { font-size:20px; flex-shrink:0; transition:transform .25s ease; }
.faq-item.active .faq-toggle { transform:rotate(45deg); color:var(--white); }
.faq-answer { display:none; padding:16px 20px; background:var(--light); font-size:14.5px; color:var(--mid); line-height:1.7; border-top:1px solid var(--border); }
.faq-item.active .faq-answer { display:block; }

/* Form shared */
.form-success-msg { display:none; background:#d4edda; border:1px solid #c3e6cb; color:#155724; padding:14px 18px; border-radius:var(--radius); font-size:15px; margin-top:12px; text-align:center; }

/* ==========================================================================
   21. REQUEST SERVICE PAGE
========================================================================== */
.request-page-layout { padding:64px 0; background:var(--light); }
.request-page-grid { display:grid; grid-template-columns:1fr 360px; gap:32px; align-items:start; }
.request-form-box { background:var(--white); border-radius:var(--radius-lg); padding:44px; border:1px solid var(--border); box-shadow:var(--shadow); }
.request-form-box h2 { font-family:'Playfair Display',serif; font-size:26px; margin-bottom:8px; }
.form-subtitle { color:var(--mid); font-size:15px; margin-bottom:28px; line-height:1.65; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-group { margin-bottom:14px; }
.form-group label { display:block; font-size:13px; font-weight:600; color:var(--dark); margin-bottom:5px; }
.form-group input, .form-group select, .form-group textarea { width:100%; padding:11px 14px; border:2px solid var(--border); border-radius:var(--radius); font-size:15px; font-family:'Open Sans',sans-serif; color:var(--dark); outline:none; transition:var(--ease); background:var(--white); box-sizing:border-box; }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color:var(--blue); }
.form-group textarea { resize:vertical; min-height:100px; }
.form-hint { font-size:12px; color:var(--mid); margin-top:4px; }
.radio-group { display:flex; gap:20px; margin-top:6px; flex-wrap:wrap; }
.radio-option { display:flex; align-items:center; gap:7px; cursor:pointer; font-size:14.5px; color:var(--dark); }
.radio-option input { cursor:pointer; accent-color:var(--blue); }
.file-upload-area { border:2px dashed var(--border); border-radius:var(--radius); padding:24px; text-align:center; cursor:pointer; transition:var(--ease); background:var(--light); }
.file-upload-area:hover { border-color:var(--blue); background:var(--white); }
.file-upload-area i { font-size:26px; color:var(--mid); margin-bottom:8px; display:block; }
.file-upload-area p { font-size:13.5px; color:var(--mid); margin:0; }
.file-upload-area input { display:none; }
.form-submit { width:100%; margin-top:6px; }
.trust-sidebar { position:sticky; top:90px; display:flex; flex-direction:column; gap:18px; }
.trust-box { background:var(--white); border-radius:var(--radius-lg); padding:28px; border:1px solid var(--border); box-shadow:var(--shadow); }
.trust-box h3 { font-family:'Playfair Display',serif; font-size:18px; margin-bottom:18px; padding-bottom:12px; border-bottom:2px solid var(--border); }
.trust-list li { display:flex; align-items:center; gap:12px; padding:9px 0; font-size:14.5px; color:var(--dark); border-bottom:1px solid #f0f0f0; }
.trust-list li:last-child { border-bottom:none; }
.trust-list li i { color:var(--blue); font-size:15px; width:18px; }
.phone-cta-box { background:linear-gradient(135deg,var(--blue),var(--blue-dark)); border-radius:var(--radius-lg); padding:28px; text-align:center; color:var(--white); }
.phone-cta-box h4 { font-family:'Open Sans',sans-serif !important; font-size:11px !important; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:rgba(255,255,255,.65) !important; margin-bottom:9px; }
.phone-cta-box .cta-phone { display:block; font-family:'Playfair Display',serif; font-size:24px; font-weight:700; color:var(--yellow); margin-bottom:7px; transition:var(--ease); }
.phone-cta-box .cta-phone:hover { color:var(--white); }
.phone-cta-box p { font-size:13px; color:rgba(255,255,255,.6); margin:0; }
.trust-badges { display:flex; flex-direction:column; gap:9px; margin-top:16px; }
.trust-badge { display:flex; align-items:center; gap:10px; padding:9px 13px; background:rgba(255,255,255,.12); border-radius:var(--radius); font-size:13px; color:rgba(255,255,255,.9); }
.trust-badge i { color:var(--yellow); font-size:15px; }

/* ==========================================================================
   22. BLOG PAGE
========================================================================== */
.blog-page-layout { padding:64px 0; background:var(--light); }
.blog-page-grid { display:grid; grid-template-columns:1fr 320px; gap:36px; align-items:start; }
.featured-post { display:grid; grid-template-columns:1fr 1fr; background:var(--white); border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--border); margin-bottom:28px; transition:var(--ease); }
.featured-post:hover { transform:translateY(-3px); box-shadow:var(--shadow-md); }
.feat-image { position:relative; overflow:hidden; min-height:270px; }
.feat-image img { width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.featured-post:hover .feat-image img { transform:scale(1.04); }
.featured-badge { position:absolute; top:14px; left:14px; background:var(--yellow); color:var(--dark); font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:1px; padding:4px 10px; border-radius:4px; z-index:2; }
.feat-content { padding:32px 28px; display:flex; flex-direction:column; justify-content:center; }
.feat-cat { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:var(--blue); margin-bottom:11px; }
.feat-content h2 { font-family:'Playfair Display',serif; font-size:21px; margin-bottom:12px; line-height:1.3; }
.feat-content h2 a { color:var(--dark); transition:var(--ease); }
.feat-content h2 a:hover { color:var(--blue); }
.feat-content p { color:var(--mid); font-size:14.5px; line-height:1.7; margin-bottom:20px; }
.blog-posts-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-bottom:36px; }
.blog-post-card { background:var(--white); border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--border); transition:var(--ease); }
.blog-post-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); }
.bpc-image { overflow:hidden; aspect-ratio:16/9; }
.bpc-image img { width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.blog-post-card:hover .bpc-image img { transform:scale(1.06); }
.bpc-content { padding:18px; }
.bpc-cat { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:var(--blue); margin-bottom:7px; }
.bpc-content h3 { font-family:'Playfair Display',serif; font-size:16px; margin-bottom:8px; line-height:1.35; }
.bpc-content h3 a { color:var(--dark); transition:var(--ease); text-decoration:none; }
.blog-post-card:hover .bpc-content h3 a { color:var(--blue); }
.bpc-meta { font-size:12px; color:var(--mid); display:flex; gap:10px; margin-top:9px; }
.blog-sidebar { position:sticky; top:90px; }
.sidebar-widget { background:var(--white); border-radius:var(--radius-lg); padding:24px; margin-bottom:20px; border:1px solid var(--border); }
.sidebar-widget h3 { font-family:'Open Sans',sans-serif !important; font-size:12px !important; font-weight:700; color:var(--mid) !important; text-transform:uppercase; letter-spacing:1.2px; margin-bottom:16px; padding-bottom:11px; border-bottom:2px solid var(--border); }
.category-list li { margin-bottom:6px; }
.category-list li a { display:flex; justify-content:space-between; align-items:center; font-size:14px; color:var(--mid); padding:7px 0; border-bottom:1px solid #f5f5f5; transition:var(--ease); text-decoration:none; }
.category-list li a:hover { color:var(--blue); padding-left:5px; }
.category-list li a span { background:var(--light); padding:2px 8px; border-radius:12px; font-size:12px; }
.recent-post-item { display:flex; gap:12px; padding:9px 0; border-bottom:1px solid #f5f5f5; }
.recent-post-item:last-child { border-bottom:none; }
.recent-post-item img { width:58px; height:58px; object-fit:cover; border-radius:8px; flex-shrink:0; }
.recent-post-info h4 { font-size:13.5px; font-family:'Open Sans',sans-serif; margin-bottom:4px; line-height:1.35; }
.recent-post-info h4 a { color:var(--dark); text-decoration:none; transition:var(--ease); }
.recent-post-info h4 a:hover { color:var(--blue); }
.recent-post-info span { font-size:12px; color:var(--mid); }
.sidebar-cta-widget { background:linear-gradient(135deg,var(--blue),var(--blue-dark)); border-radius:var(--radius-lg); padding:26px; text-align:center; color:var(--white); margin-bottom:20px; }
.sidebar-cta-widget h3 { font-family:'Playfair Display',serif !important; color:var(--white) !important; font-size:18px; margin-bottom:10px; border-bottom:none !important; padding-bottom:0 !important; }
.sidebar-cta-widget p { font-size:13.5px; color:rgba(255,255,255,.78); margin-bottom:18px; line-height:1.6; }
.blog-pagination { display:flex; justify-content:center; gap:8px; flex-wrap:wrap; margin-top:8px; }
.page-btn { width:38px; height:38px; display:flex; align-items:center; justify-content:center; border-radius:var(--radius); border:2px solid var(--border); font-size:14px; font-weight:600; color:var(--mid); cursor:pointer; transition:var(--ease); background:var(--white); text-decoration:none; font-family:'Open Sans',sans-serif; }
.page-btn:hover, .page-btn.active { background:var(--blue); border-color:var(--blue); color:var(--white); }

/* ==========================================================================
   23. RESPONSIVE — COMPLETE MOBILE SYSTEM
========================================================================== */

/* --- LAPTOP 1024px --- */
@media (max-width:1024px) {
    .steps-grid { position:relative; }
    .footer-container { grid-template-columns:1fr 1fr; gap:36px; }
    .svc-lp-hero-inner { grid-template-columns:1fr 360px; gap:28px; }
    .svc-lp-grid { grid-template-columns:1fr 320px; }
    .request-page-grid { grid-template-columns:1fr 300px; }
    .blog-page-grid { grid-template-columns:1fr 280px; }
    .blog-posts-grid { grid-template-columns:repeat(2,1fr); }
    .services-list-grid { grid-template-columns:repeat(2,1fr); }
}

/* --- TABLET / MOBILE 768px --- */
@media (max-width:768px) {

    /* --- HAMBURGER MENU --- */
    .mobile-toggle { display:flex !important; }
    .header-actions .btn { display:none; }
    .header-actions { gap:10px; }

    /* Slide-in nav panel */
    .main-nav {
        position:fixed !important;
        top:0 !important; right:-320px !important;
        width:300px; height:100vh;
        background:var(--white) !important;
        padding:70px 20px 28px !important;
        transition:right .3s ease !important;
        z-index:9999 !important;
        overflow-y:auto;
        box-shadow:-6px 0 28px rgba(0,0,0,.18) !important;
        display:block !important;
    }
    .main-nav.active { right:0 !important; }

    .main-nav ul { flex-direction:column; gap:0; }
    .main-nav ul li a {
        display:block; padding:13px 10px; font-size:16px;
        border-bottom:1px solid #f0f0f0; color:var(--dark);
    }
    .main-nav ul li a::after { display:none; }

    /* Mobile dropdown */
    .dropdown-menu {
        display:none !important; position:static !important;
        box-shadow:none !important; border:none !important;
        padding:0 0 4px 16px !important; background:#f8f9fb !important;
        border-radius:0 !important; min-width:100% !important;
    }
    .dropdown.active .dropdown-menu { display:block !important; }
    .dropdown-menu li a { font-size:14px !important; padding:10px 12px !important; color:var(--mid) !important; border-bottom:1px solid #eee !important; }
    .dropdown-menu li a::after { display:none !important; }
    .dropdown-toggle::after { content:'▾'; transition:transform .25s ease; }
    .dropdown.active .dropdown-toggle::after { transform:rotate(180deg); }

    .menu-close { display:block !important; }
    .menu-overlay.active { display:block; }

    /* --- HERO --- */
    .hero-section { min-height:480px; }
    .hero-content { padding:56px 20px 46px; }
    .hero-text h1 { font-size:28px; }
    .hero-text p { font-size:15px; margin-bottom:22px; }
    .search-box { max-width:100%; }
    .service-tag { font-size:12.5px; padding:6px 13px; }

    /* --- SECTIONS --- */
    .how-it-works-section, .services-section, .stats-banner,
    .why-choose-section, .testimonials-section, .categories-section,
    .blog-section { padding:56px 0; }
    .cta-section { padding:48px 0; }

    .steps-grid { grid-template-columns:1fr; gap:14px; }
    .services-grid { grid-template-columns:repeat(2,1fr); gap:14px; }
    .stats-grid { grid-template-columns:repeat(2,1fr); gap:18px; }
    .testimonials-grid { grid-template-columns:1fr; gap:16px; }
    .categories-grid { grid-template-columns:repeat(3,1fr); gap:12px; }
    .blog-grid { grid-template-columns:1fr; gap:18px; }

    .cta-box { flex-direction:column; text-align:center; padding:30px 22px; gap:20px; }
    .cta-form { flex-direction:column; width:100%; }
    .cta-form input { width:100%; }
    .why-choose-container { grid-template-columns:1fr; gap:28px; }
    .why-choose-image { display:none; }
    .section-title h2 { font-size:26px; }

    /* --- PAGE BANNER --- */
    .page-banner { padding:40px 0; }
    .page-banner h1 { font-size:26px; }

    /* --- SERVICES DIRECTORY --- */
    .filter-bar { flex-direction:column; align-items:stretch; padding:16px 18px; gap:12px; }
    .filter-search { min-width:100%; }
    .filter-btns { justify-content:flex-start; flex-wrap:wrap; }
    .services-list-grid { grid-template-columns:1fr; gap:14px; }

    /* --- FOOTER --- */
    .footer-container { grid-template-columns:1fr; gap:28px; padding:0 20px 36px; }
    .footer-cta .btn { width:100%; }

    /* --- BLOG PAGE --- */
    .blog-page-layout { padding:48px 0; }
    .blog-page-grid { grid-template-columns:1fr; gap:28px; }
    .blog-sidebar { position:static; }
    .featured-post { grid-template-columns:1fr; }
    .feat-image { min-height:200px; }
    .feat-content { padding:22px 20px; }
    .blog-posts-grid { grid-template-columns:repeat(2,1fr); gap:14px; }

    /* --- SERVICE LANDING --- */
    .svc-lp-hero { min-height:auto; padding:48px 0 36px; }
    .svc-lp-hero-inner { grid-template-columns:1fr; gap:28px; }
    .svc-lp-hero-left h1 { font-size:26px; }
    .svc-hero-ctas { flex-direction:column; align-items:flex-start; gap:12px; }
    .svc-stats-inner { justify-content:center; }
    .svc-stat-divider { display:none; }
    .svc-lp-body { padding:40px 0 52px; }
    .svc-lp-grid { grid-template-columns:1fr; }
    .svc-lp-sidebar { position:static; margin-top:0; }
    .svc-content-block { padding:26px 20px; }
    .svc-included-grid { grid-template-columns:1fr; }
    .svc-why-block { grid-template-columns:1fr; }
    .svc-why-left { display:none; }
    .svc-why-right { padding:26px 20px; }
    .svc-process-steps { flex-direction:column; gap:10px; }
    .svc-process-arrow { transform:rotate(90deg); align-self:center; }
    .svc-related-grid { grid-template-columns:repeat(2,1fr); }
    .svc-cta-inner { flex-direction:column; text-align:center; gap:20px; }
    .svc-cta-actions { flex-direction:column; align-items:center; width:100%; }
    .svc-cta-actions .btn { width:100%; }

    /* --- REQUEST PAGE --- */
    .request-page-layout { padding:48px 0; }
    .request-page-grid { grid-template-columns:1fr; gap:22px; }
    .request-form-box { padding:26px 20px; }
    .form-row { grid-template-columns:1fr; gap:0; }
    .trust-sidebar { position:static; }
}

/* --- MOBILE 480px --- */
@media (max-width:480px) {
    .container { padding:0 16px; }
    .logo img { max-height:42px; }
    .main-header { padding:12px 0; }
    .main-nav { width:280px; padding:65px 18px 26px !important; }

    .hero-section { min-height:440px; }
    .hero-content { padding:46px 16px 38px; }
    .hero-text h1 { font-size:24px; }
    .hero-text p { font-size:14px; }
    .search-box input { font-size:16px; padding:13px 14px; } /* prevent iOS zoom */
    .service-tag { font-size:12px; padding:5px 11px; }

    .categories-grid { grid-template-columns:repeat(2,1fr); gap:10px; }
    .category-card { padding:20px 12px; }
    .category-icon { width:52px; height:52px; font-size:22px; }
    .category-name { font-size:13px; }
    .services-grid { grid-template-columns:1fr; gap:12px; }
    .stats-grid { grid-template-columns:1fr 1fr; gap:14px; }
    .stat-number { font-size:28px !important; }
    .stat-label { font-size:12px; }
    .testimonial-card { padding:24px 18px; }

    .page-banner { padding:32px 0; }
    .page-banner h1 { font-size:22px; }

    .blog-posts-grid { grid-template-columns:1fr; gap:12px; }
    .feat-content h2 { font-size:18px; }

    .svc-lp-hero { padding:38px 0 30px; }
    .svc-lp-hero-left h1 { font-size:22px; }
    .svc-hero-badges { display:none; }
    .svc-call-btn { width:100%; justify-content:center; border:2px solid rgba(255,255,255,.4); padding:11px 18px; border-radius:var(--radius); text-align:center; }
    .svc-content-block { padding:20px 16px; }
    .svc-related-grid { grid-template-columns:repeat(2,1fr); gap:10px; }
    .svc-process-step { padding:18px 14px; }
    .request-form-box { padding:22px 16px; }

    .footer { padding:44px 0 0 !important; }
    .footer-container { padding:0 16px 32px; gap:24px; }
    .footer-cta .phone { font-size:22px !important; }
    .copyright p { font-size:12px; }

    /* Forms — prevent iOS zoom */
    .form-group input, .form-group select, .form-group textarea,
    .sqf-row input, .sqf-row textarea { font-size:16px; }
}

/* --- XSMALL 360px --- */
@media (max-width:360px) {
    .hero-text h1 { font-size:21px; }
    .search-box { flex-direction:column; }
    .search-box button { width:100%; padding:13px; }
    .main-nav { width:260px !important; }
    .categories-grid { grid-template-columns:repeat(2,1fr); }
    .svc-lp-hero-left h1 { font-size:20px; }
    .page-banner h1 { font-size:20px; }
    .section-title h2 { font-size:21px; }
}

/* --- DESKTOP — enforce hamburger hidden, dropdown hover --- */
@media (min-width:769px) {
    .mobile-toggle { display:none !important; }
    .menu-close  { display:none !important; }
    .header-actions .btn  { display:inline-flex !important; }
    .header-actions .phone-link { display:flex !important; }
    .main-nav {
        position:static !important; right:auto !important;
        width:auto !important; height:auto !important;
        background:transparent !important; padding:0 !important;
        box-shadow:none !important; overflow:visible !important;
        display:block !important;
    }
    .dropdown-menu { position:absolute !important; display:none !important; }
    .dropdown:hover > .dropdown-menu { display:block !important; }
}
