/* ============================================================
   LOCALPAGEUP SAMPLE SITE — SHARED STYLESHEET
   All 10 profession templates share this file.
   Each page overrides :root variables for profession colors.
   ============================================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;color:#1a202c;background:#fff;overflow-x:hidden;padding-top:0}

/* ── CSS CUSTOM PROPERTIES (overridden per profession) ─────── */
:root{
  --accent:#38bdf8;
  --accent-dark:#0ea5e9;
  --accent-rgb:56,189,248;
  --primary:#1e3a5f;
  --dark:#0f1e3c;
  --light-bg:#f0f7ff;
  --border:#bfdbfe;
  --btn-text:#0f1e3c;
  --star-color:#f59e0b;
}

/* ── CLAIM BANNER ──────────────────────────────────────────── */
#claim-banner{background:linear-gradient(135deg,#ff3b3b,#cc0000);color:#fff;padding:12px 20px;text-align:center;position:sticky;top:0;z-index:1000}
.claim-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap}
.claim-text{display:flex;flex-direction:column;align-items:center;gap:2px}
.claim-title{font-size:14px;font-weight:800}
.claim-sub{font-size:11px;opacity:.9}
.claim-btns{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}
.claim-btn-white{background:#fff;color:#cc0000;padding:8px 16px;border-radius:6px;font-size:12px;font-weight:700;text-decoration:none;white-space:nowrap;transition:background .2s}
.claim-btn-white:hover{background:#ffe5e5}
.claim-btn-outline{background:transparent;color:#fff;padding:8px 16px;border-radius:6px;font-size:12px;font-weight:700;text-decoration:none;border:2px solid rgba(255,255,255,.6);white-space:nowrap;transition:all .2s}
.claim-btn-outline:hover{border-color:#fff;background:rgba(255,255,255,.1)}

/* ── NAVIGATION ────────────────────────────────────────────── */
nav.site-nav{background:var(--primary);padding:0 5%;position:sticky;top:52px;z-index:999;height:64px;display:flex;align-items:center}
.nav-inner{max-width:1200px;margin:0 auto;width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px}
.nav-logo{font-size:19px;font-weight:900;color:#fff;text-decoration:none;white-space:nowrap;flex-shrink:0}
.nav-logo span{color:var(--accent)}
.nav-links{display:flex;align-items:center;gap:0;list-style:none;margin:0 auto}
.nav-links>li{position:relative}
.nav-links>li>a{display:flex;align-items:center;gap:4px;padding:0 14px;height:64px;color:rgba(255,255,255,.8);font-size:13px;font-weight:600;text-decoration:none;transition:color .2s;white-space:nowrap}
.nav-links>li>a:hover,.nav-links>li.active>a{color:#fff}
.nav-links>li>a.has-drop::after{content:'▾';font-size:10px;margin-left:2px}
.nav-dropdown{display:none;position:absolute;top:100%;left:0;background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:8px 0;min-width:200px;box-shadow:0 12px 40px rgba(0,0,0,.15);z-index:100}
.nav-links>li:hover .nav-dropdown{display:block}
.nav-dropdown a{display:block;padding:10px 18px;font-size:13px;font-weight:600;color:#1a202c;text-decoration:none;transition:background .15s}
.nav-dropdown a:hover{background:var(--light-bg);color:var(--primary)}
.nav-cta{background:var(--accent);color:var(--btn-text);padding:9px 20px;border-radius:7px;font-size:13px;font-weight:700;text-decoration:none;white-space:nowrap;flex-shrink:0;transition:opacity .2s}
.nav-cta:hover{opacity:.9}
.nav-phone-sm{display:none;color:#fff;font-size:13px;font-weight:700;text-decoration:none}
.nav-hamburger{display:none;background:transparent;border:none;color:#fff;font-size:22px;cursor:pointer;padding:4px 8px}
.mobile-menu{display:none;background:var(--dark);padding:16px 5%;flex-direction:column;gap:0}
.mobile-menu.open{display:flex}
.mobile-menu a{display:block;padding:11px 0;color:rgba(255,255,255,.8);font-size:14px;font-weight:600;text-decoration:none;border-bottom:1px solid rgba(255,255,255,.07)}
.mobile-menu a:last-child{border-bottom:none}
.mobile-menu .mob-sub{padding-left:16px;font-size:13px;color:rgba(255,255,255,.6)}
.mobile-menu .mob-cta{margin-top:12px;background:var(--accent);color:var(--btn-text);text-align:center;border-radius:8px;padding:12px;font-weight:800;border-bottom:none}

/* ── PAGE HERO (interior pages) ─────────────────────────────── */
.page-hero{background:var(--primary);padding:56px 5%;text-align:center;position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--dark) 0%,var(--primary) 100%);opacity:.7}
.page-hero-content{position:relative;z-index:1;max-width:760px;margin:0 auto}
.breadcrumb{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.breadcrumb a{color:rgba(255,255,255,.6);font-size:12px;font-weight:600;text-decoration:none}
.breadcrumb a:hover{color:#fff}
.breadcrumb span{color:rgba(255,255,255,.3);font-size:12px}
.breadcrumb strong{color:var(--accent);font-size:12px;font-weight:700}
.page-hero h1{font-size:clamp(28px,4vw,50px);font-weight:900;color:#fff;line-height:1.1;letter-spacing:-.5px;margin-bottom:14px}
.page-hero h1 span{color:var(--accent)}
.page-hero p{font-size:16px;color:rgba(255,255,255,.75);max-width:540px;margin:0 auto;line-height:1.7}

/* ── MAIN HERO (homepage) ────────────────────────────────────── */
.hero-full{position:relative;min-height:88vh;display:flex;align-items:center;overflow:hidden}
.hero-bg-img{position:absolute;inset:0;background-size:cover;background-position:center}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(105deg,rgba(0,0,0,.92) 0%,rgba(0,0,0,.72) 55%,rgba(0,0,0,.35) 100%)}
.hero-content{position:relative;z-index:1;max-width:740px;padding:90px 5%}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.25);padding:7px 16px;border-radius:100px;font-size:12px;font-weight:700;color:var(--accent);letter-spacing:.5px;margin-bottom:24px}
.badge-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.hero-content h1{font-size:clamp(36px,5.5vw,68px);font-weight:900;color:#fff;line-height:1.05;letter-spacing:-1.5px;margin-bottom:18px}
.hero-content h1 em{color:var(--accent);font-style:normal}
.hero-sub{font-size:17px;color:rgba(255,255,255,.82);max-width:520px;line-height:1.7;margin-bottom:34px}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:44px}
.btn-hero-primary{background:linear-gradient(135deg,var(--primary),var(--dark));color:#fff;padding:15px 28px;border-radius:8px;font-size:15px;font-weight:700;text-decoration:none;box-shadow:0 8px 24px rgba(0,0,0,.3);transition:all .25s}
.btn-hero-primary:hover{transform:translateY(-2px);box-shadow:0 14px 32px rgba(0,0,0,.4)}
.btn-hero-accent{background:var(--accent);color:var(--btn-text);padding:15px 28px;border-radius:8px;font-size:15px;font-weight:800;text-decoration:none;transition:all .25s}
.btn-hero-accent:hover{opacity:.9;transform:translateY(-2px)}
.hero-checks{display:flex;gap:18px;flex-wrap:wrap}
.hero-check{display:flex;align-items:center;gap:7px;color:rgba(255,255,255,.78);font-size:13px;font-weight:600}
.hero-check::before{content:'✓';color:var(--accent);font-weight:900;font-size:14px}

/* ── STATS BAR ───────────────────────────────────────────────── */
.stats-bar{background:var(--dark);padding:28px 5%}
.stats-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.stat-item{text-align:center;padding:14px}
.stat-num{font-size:40px;font-weight:900;color:var(--accent);line-height:1;letter-spacing:-1px}
.stat-label{font-size:12px;color:rgba(255,255,255,.6);margin-top:6px;font-weight:500}

/* ── SECTIONS ────────────────────────────────────────────────── */
.section{padding:88px 5%}
.section-inner{max-width:1200px;margin:0 auto}
.section-label{font-size:11px;font-weight:700;color:var(--accent-dark,var(--accent));letter-spacing:2px;text-transform:uppercase;margin-bottom:12px}
.section-title{font-size:clamp(28px,3.5vw,44px);font-weight:900;color:var(--dark);line-height:1.1;letter-spacing:-.5px;margin-bottom:14px}
.section-title em{color:var(--accent-dark,var(--accent));font-style:normal}
.section-sub{font-size:16px;color:#4a5568;max-width:560px;line-height:1.7}
.section-center{text-align:center}
.section-center .section-sub{margin:0 auto}
.section-bg{background:var(--light-bg)}

/* ── SERVICE CARDS ───────────────────────────────────────────── */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:52px}
.svc-card{background:#fff;border:1.5px solid #e5e7eb;border-radius:16px;padding:30px;transition:all .3s;position:relative;overflow:hidden;text-decoration:none;color:inherit;display:block}
.svc-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary),var(--accent));transform:scaleX(0);transform-origin:left;transition:transform .3s}
.svc-card:hover{transform:translateY(-4px);box-shadow:0 16px 48px rgba(0,0,0,.1);border-color:var(--border)}
.svc-card:hover::after{transform:scaleX(1)}
.svc-icon{font-size:38px;margin-bottom:16px;display:block}
.svc-card h3{font-size:17px;font-weight:800;color:var(--dark);margin-bottom:10px}
.svc-card p{font-size:14px;color:#4a5568;line-height:1.65}
.svc-link{display:inline-flex;align-items:center;gap:6px;margin-top:16px;font-size:13px;font-weight:700;color:var(--accent-dark,var(--accent));text-decoration:none}
.svc-link::after{content:'→'}

/* ── TRUST / WHY CHOOSE US ───────────────────────────────────── */
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:52px}
.trust-card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:28px 24px;text-align:center;transition:box-shadow .3s}
.trust-card:hover{box-shadow:0 8px 32px rgba(0,0,0,.08)}
.trust-icon{font-size:42px;margin-bottom:14px;display:block}
.trust-card h4{font-size:16px;font-weight:800;color:var(--dark);margin-bottom:8px}
.trust-card p{font-size:13px;color:#4a5568;line-height:1.6}

/* ── CTA BANNER ─────────────────────────────────────────────── */
.cta-banner{background:linear-gradient(135deg,var(--dark),var(--primary));padding:72px 5%;text-align:center}
.cta-banner h2{font-size:clamp(26px,3.5vw,42px);font-weight:900;color:#fff;margin-bottom:12px;letter-spacing:-.5px}
.cta-banner p{font-size:16px;color:rgba(255,255,255,.7);margin-bottom:36px}
.cta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.btn-cta-white{background:#fff;color:var(--dark);padding:14px 28px;border-radius:8px;font-size:15px;font-weight:800;text-decoration:none;transition:all .2s}
.btn-cta-white:hover{background:var(--light-bg)}
.btn-cta-accent{background:var(--accent);color:var(--btn-text);padding:14px 28px;border-radius:8px;font-size:15px;font-weight:800;text-decoration:none;transition:all .2s}
.btn-cta-accent:hover{opacity:.9}

/* ── MID BANNER (3 steps / claim) ────────────────────────────── */
.mid-banner{background:#111827;padding:72px 5%}
.mid-inner{max-width:1000px;margin:0 auto;text-align:center}
.mid-banner h2{font-size:clamp(24px,3vw,38px);font-weight:900;color:#fff;margin-bottom:10px}
.mid-banner>div>p,.mid-inner>p{font-size:15px;color:rgba(255,255,255,.6);margin-bottom:44px}
.steps-row{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:0}
.step-item{text-align:center;padding:28px 20px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:14px}
.step-num{width:50px;height:50px;border-radius:50%;background:var(--accent);color:var(--btn-text);font-size:20px;font-weight:900;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.step-item h4{font-size:16px;font-weight:800;color:#fff;margin-bottom:8px}
.step-item p{font-size:13px;color:rgba(255,255,255,.55);line-height:1.6}

/* ── TESTIMONIALS ────────────────────────────────────────────── */
.testimonials-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:52px}
.testimonial-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:30px;position:relative}
.testimonial-card::before{content:'"';position:absolute;top:14px;left:22px;font-size:60px;font-weight:900;color:var(--border);line-height:1;font-family:Georgia,serif}
.tc-stars{color:var(--star-color);font-size:16px;margin-bottom:12px}
.tc-text{font-size:14px;color:#374151;line-height:1.75;margin-bottom:20px;padding-top:18px}
.tc-reviewer{display:flex;align-items:center;gap:12px}
.tc-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;font-size:15px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.tc-name{font-size:13px;font-weight:700;color:var(--dark)}
.tc-loc{font-size:12px;color:#9ca3af;margin-top:2px}

/* ── GALLERY ─────────────────────────────────────────────────── */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:52px}
.gallery-item{border-radius:12px;overflow:hidden;aspect-ratio:4/3;position:relative;cursor:pointer}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.gallery-item:hover img{transform:scale(1.05)}
.gallery-item .gal-overlay{position:absolute;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s}
.gallery-item:hover .gal-overlay{opacity:1}
.gal-label{color:#fff;font-size:14px;font-weight:700;text-align:center;padding:0 16px}

/* ── GOOGLE REVIEWS ──────────────────────────────────────────── */
.google-reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:52px}
.gr-card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:24px}
.gr-header{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.gr-g{font-size:18px;width:32px;height:32px;border:1px solid #e5e7eb;border-radius:6px;display:flex;align-items:center;justify-content:center}
.gr-author{font-size:13px;font-weight:700;color:#1a202c}
.gr-date{font-size:11px;color:#9ca3af}
.gr-stars{color:var(--star-color);font-size:13px;margin-bottom:8px}
.gr-body{font-size:13px;color:#374151;line-height:1.6;margin-bottom:12px}
.gr-response{background:var(--light-bg);border-left:3px solid var(--accent);padding:10px 12px;border-radius:0 8px 8px 0}
.gr-response-label{font-size:10px;font-weight:700;color:var(--primary);letter-spacing:1px;text-transform:uppercase;margin-bottom:3px}
.gr-response-text{font-size:12px;color:#374151;line-height:1.5}

/* ── ABOUT / TEAM ────────────────────────────────────────────── */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;margin-top:52px}
.about-img-wrap{border-radius:20px;overflow:hidden;aspect-ratio:4/3;position:relative}
.about-img-wrap img{width:100%;height:100%;object-fit:cover}
.about-badge{position:absolute;bottom:20px;right:20px;background:var(--dark);color:#fff;padding:12px 18px;border-radius:10px;font-size:12px;font-weight:700;text-align:center}
.about-badge strong{display:block;font-size:22px;font-weight:900;color:var(--accent)}
.about-checks{list-style:none;margin-top:24px;display:flex;flex-direction:column;gap:12px}
.about-checks li{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:#374151;line-height:1.5}
.about-checks li::before{content:'✓';width:20px;height:20px;border-radius:50%;background:var(--light-bg);border:1.5px solid var(--accent);color:var(--primary);font-size:11px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:52px}
.team-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;overflow:hidden;text-align:center}
.team-photo{aspect-ratio:1/1;overflow:hidden}
.team-photo img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.team-card:hover .team-photo img{transform:scale(1.04)}
.team-info{padding:20px}
.team-name{font-size:16px;font-weight:800;color:var(--dark);margin-bottom:4px}
.team-role{font-size:12px;font-weight:600;color:var(--accent-dark,var(--accent));text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}
.team-bio{font-size:13px;color:#6b7280;line-height:1.6}

/* ── ABOUT — image containers with stable aspect-ratio fallback ── */
/* These cover every layout variant used across all 10 sample sites */

/* about-img-col: pest-control / any site that wraps img in a col div */
.about-img-col{border-radius:20px;overflow:hidden;aspect-ratio:3/2;position:relative;background:var(--light-bg,#f3f4f6)}
.about-img-col .about-img,.about-img-col img{width:100%;height:100%;object-fit:cover;display:block}
/* bare .about-img used as direct img class (no wrapper aspect-ratio set separately) */
.about-img{width:100%;height:100%;object-fit:cover;display:block;border-radius:inherit}
.about-text-col{display:flex;flex-direction:column;justify-content:center}

/* about-owner: electrician two-col owner bio layout */
.about-owner{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start;margin-top:40px}
.owner-photo-col{border-radius:20px;overflow:hidden;aspect-ratio:3/2;position:relative;background:var(--light-bg,#f3f4f6)}
.owner-photo-col img,.owner-photo{width:100%;height:100%;object-fit:cover;display:block}
.owner-bio-col p{font-size:15px;color:#374151;line-height:1.75;margin-bottom:12px}

/* credential badges */
.owner-creds{display:flex;gap:8px;flex-wrap:wrap;margin-top:20px}
.cred-badge{display:inline-block;padding:6px 14px;background:var(--light-bg,#f3f4f6);border:1.5px solid var(--border,#e5e7eb);border-radius:20px;font-size:12px;font-weight:700;color:var(--primary)}

/* team-avatar: emoji/icon fallback when no photo is available */
.team-avatar{aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;font-size:52px;background:var(--light-bg,#f3f4f6);border-bottom:1px solid var(--border,#e5e7eb)}

/* team-img-wrap: pest-control variant of .team-photo */
.team-img-wrap{aspect-ratio:1/1;overflow:hidden;background:var(--light-bg,#f3f4f6)}
.team-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.team-card:hover .team-img-wrap img{transform:scale(1.04)}

/* team-title: alias for .team-role used in pest-control */
.team-title{font-size:12px;font-weight:600;color:var(--accent-dark,var(--accent));text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}

/* about-check: div variant of .about-checks li (pest-control) */
.about-checks .about-check{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:#374151;line-height:1.5;padding:3px 0}
.about-checks .about-check>span:first-child{width:20px;height:20px;border-radius:50%;background:var(--light-bg,#f3f4f6);border:1.5px solid var(--accent);color:var(--primary);font-size:11px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}

/* ── BLOG CARDS ──────────────────────────────────────────────── */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:52px}
.blog-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;overflow:hidden;transition:box-shadow .3s;text-decoration:none;color:inherit;display:block}
.blog-card:hover{box-shadow:0 8px 32px rgba(0,0,0,.09)}
.blog-img{aspect-ratio:16/9;overflow:hidden}
.blog-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.blog-card:hover .blog-img img{transform:scale(1.04)}
.blog-body{padding:22px}
.blog-tag{font-size:11px;font-weight:700;color:var(--accent-dark,var(--accent));letter-spacing:1.5px;text-transform:uppercase;margin-bottom:8px}
.blog-title{font-size:16px;font-weight:800;color:#1a202c;line-height:1.35;margin-bottom:8px}
.blog-excerpt{font-size:13px;color:#6b7280;line-height:1.6;margin-bottom:14px}
.blog-meta{font-size:11px;color:#9ca3af}

/* ── CONTACT ─────────────────────────────────────────────────── */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.contact-form{display:flex;flex-direction:column;gap:14px;margin-top:30px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field{display:flex;flex-direction:column;gap:5px}
.field label{font-size:12px;font-weight:600;color:#374151}
.field input,.field textarea,.field select{border:1.5px solid #d1d5db;border-radius:8px;padding:10px 13px;font-size:14px;font-family:inherit;color:#1a202c;transition:border .2s;outline:none;background:#fff}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--accent)}
.field textarea{resize:vertical;min-height:100px}
.btn-submit{background:linear-gradient(135deg,var(--primary),var(--dark));color:#fff;border:none;padding:13px 26px;border-radius:8px;font-size:15px;font-weight:700;cursor:pointer;font-family:inherit;transition:all .2s;text-align:left}
.btn-submit:hover{opacity:.9}
.contact-info{margin-top:30px;display:flex;flex-direction:column;gap:18px}
.contact-info-item{display:flex;align-items:flex-start;gap:12px}
.ci-icon{width:42px;height:42px;border-radius:10px;background:var(--light-bg);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.ci-label{font-size:14px;font-weight:700;color:#1a202c}
.ci-sub{font-size:13px;color:#6b7280}
.map-wrap{margin-top:22px;border-radius:14px;overflow:hidden;border:1px solid #e5e7eb}

/* ── FAQ ──────────────────────────────────────────────────────── */
.faq-list{margin-top:52px;display:flex;flex-direction:column;gap:12px}
.faq-item{background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden}
.faq-q{width:100%;text-align:left;padding:20px 22px;background:transparent;border:none;font-family:inherit;font-size:15px;font-weight:700;color:var(--dark);cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:12px;transition:background .2s}
.faq-q:hover{background:var(--light-bg)}
.faq-icon{font-size:18px;color:var(--accent);flex-shrink:0;transition:transform .3s}
.faq-item.open .faq-icon{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease,padding .35s}
.faq-item.open .faq-a{max-height:300px}
.faq-a-inner{padding:0 22px 20px;font-size:14px;color:#4a5568;line-height:1.7}

/* ── AREAS SERVED ────────────────────────────────────────────── */
.areas-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:52px}
.area-card{background:var(--light-bg);border:1px solid var(--border);border-radius:10px;padding:16px 18px;display:flex;align-items:center;gap:10px;font-size:14px;font-weight:600;color:var(--dark)}
.area-card::before{content:'📍';font-size:16px}

/* ── SARA PANEL ──────────────────────────────────────────────── */
.sara-section{background:linear-gradient(135deg,var(--dark),var(--primary));padding:88px 5%}
.sara-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.sara-content .section-label{color:var(--accent)}
.sara-content .section-title{color:#fff}
.sara-content .section-sub{color:rgba(255,255,255,.7)}
.sara-features{list-style:none;margin-top:24px;display:flex;flex-direction:column;gap:11px}
.sara-features li{display:flex;align-items:center;gap:10px;font-size:14px;color:rgba(255,255,255,.8);font-weight:500}
.sara-features li::before{content:'✓';color:var(--accent);font-weight:900;font-size:15px}
.sara-phone-wrap{max-width:300px;margin-left:auto}
.sara-phone{background:#111;border-radius:28px;padding:20px;border:6px solid #2a2a2a;box-shadow:0 30px 80px rgba(0,0,0,.5)}
.sara-phone-header{background:var(--dark);border-radius:16px 16px 0 0;padding:12px 16px;display:flex;align-items:center;gap:10px;margin:-20px -20px 0;border-bottom:1px solid rgba(255,255,255,.1)}
.sara-avatar{width:34px;height:34px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:16px}
.sara-caller-name{font-size:13px;font-weight:700;color:#fff}
.sara-status{font-size:11px;color:#9ca3af}
.sara-msgs{padding:14px 4px;display:flex;flex-direction:column;gap:9px;margin-top:10px}
.sara-msg{max-width:82%;padding:9px 13px;border-radius:11px;font-size:12px;line-height:1.5}
.sara-msg.in{background:#1e1e1e;color:#e5e7eb;align-self:flex-start;border-radius:4px 11px 11px 11px}
.sara-msg.out{background:var(--accent);color:var(--btn-text);align-self:flex-end;border-radius:11px 4px 11px 11px}
.sara-time{font-size:10px;color:#6b7280;text-align:center;margin-top:4px}

/* ── FOOTER ──────────────────────────────────────────────────── */
footer.site-footer{background:var(--dark);color:#fff;padding:60px 5% 30px}
.footer-inner{max-width:1200px;margin:0 auto}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;padding-bottom:44px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer-brand h3{font-size:20px;font-weight:900;color:#fff;margin-bottom:8px}
.footer-brand h3 span{color:var(--accent)}
.footer-tagline{font-size:13px;color:rgba(255,255,255,.5);line-height:1.7;margin-bottom:18px}
.footer-lpu{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.6);padding:7px 14px;border-radius:8px;font-size:12px;font-weight:600;text-decoration:none}
.footer-lpu:hover{color:#fff}
.footer-lpu strong{color:var(--accent)}
.footer-col h4{font-size:12px;font-weight:700;color:#fff;margin-bottom:14px;letter-spacing:.5px;text-transform:uppercase}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:9px}
.footer-links a{font-size:13px;color:rgba(255,255,255,.5);text-decoration:none;transition:color .2s}
.footer-links a:hover{color:var(--accent)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;padding-top:28px;font-size:12px;color:rgba(255,255,255,.35);flex-wrap:wrap;gap:10px}
.footer-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);color:rgba(255,255,255,.5);padding:4px 12px;border-radius:100px;font-size:11px;font-weight:600}

/* ── FLOATING BOTTOM BAR ─────────────────────────────────────── */
#float-bar{position:fixed;bottom:-100px;left:0;right:0;background:var(--dark);border-top:3px solid var(--accent);padding:14px 5%;z-index:998;transition:bottom .5s ease;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px}
#float-bar.visible{bottom:0}
.float-features{display:flex;gap:20px;flex-wrap:wrap}
.float-feat{display:flex;align-items:center;gap:6px;font-size:12px;color:rgba(255,255,255,.85);font-weight:600}
.float-feat::before{content:'✓';color:var(--accent);font-weight:900}
.float-btns{display:flex;gap:10px;align-items:center}
.float-cta{background:var(--accent);color:var(--btn-text);padding:10px 20px;border-radius:8px;font-size:13px;font-weight:700;text-decoration:none;white-space:nowrap}
.float-close{background:transparent;border:none;color:rgba(255,255,255,.4);font-size:18px;cursor:pointer;padding:4px}

/* ── CHAT WIDGET ─────────────────────────────────────────────── */
#chat-widget{position:fixed;bottom:80px;right:22px;z-index:997}
.chat-bubble{width:54px;height:54px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 6px 20px rgba(0,0,0,.25);font-size:22px;transition:transform .2s}
.chat-bubble:hover{transform:scale(1.08)}
.chat-box{display:none;position:absolute;bottom:66px;right:0;width:310px;background:#fff;border-radius:14px;box-shadow:0 20px 60px rgba(0,0,0,.18);overflow:hidden;border:1px solid #e5e7eb}
.chat-box.open{display:flex;flex-direction:column}
.chat-head{background:linear-gradient(135deg,var(--dark),var(--primary));padding:14px 16px;display:flex;align-items:center;gap:10px}
.chat-head-avatar{width:34px;height:34px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:16px}
.chat-head-name{font-size:13px;font-weight:700;color:#fff}
.chat-head-status{font-size:11px;color:rgba(255,255,255,.6)}
.chat-body{padding:14px;display:flex;flex-direction:column;gap:9px;max-height:220px;overflow-y:auto}
.chat-msg{max-width:85%;padding:8px 12px;border-radius:9px;font-size:12px;line-height:1.5}
.chat-msg.bot{background:#f3f4f6;color:#1a202c;align-self:flex-start;border-radius:3px 9px 9px 9px}
.chat-msg.user{background:var(--accent);color:var(--btn-text);align-self:flex-end;border-radius:9px 3px 9px 9px}
.chat-qr{padding:0 14px 10px;display:flex;flex-wrap:wrap;gap:6px}
.qr-btn{background:#fff;border:1.5px solid #e5e7eb;color:#374151;padding:5px 11px;border-radius:18px;font-size:11px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .2s}
.qr-btn:hover{border-color:var(--accent);color:var(--primary)}
.chat-input-row{display:flex;border-top:1px solid #e5e7eb}
.chat-input{flex:1;border:none;padding:10px 13px;font-size:13px;font-family:inherit;outline:none;background:#fff}
.chat-send{background:var(--accent);border:none;color:var(--btn-text);padding:10px 14px;cursor:pointer;font-size:14px}

/* ── SERVICE PAGE SPECIFIC ───────────────────────────────────── */
.process-steps{margin-top:52px;display:flex;flex-direction:column;gap:0}
.process-step{display:grid;grid-template-columns:72px 1fr;gap:24px;align-items:start;padding:28px 0;border-bottom:1px solid #e5e7eb}
.process-step:last-child{border-bottom:none}
.ps-num{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;font-size:20px;font-weight:900;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ps-content h4{font-size:17px;font-weight:800;color:var(--dark);margin-bottom:8px}
.ps-content p{font-size:14px;color:#4a5568;line-height:1.65}
.service-photos{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:52px}
.service-photo{border-radius:12px;overflow:hidden;aspect-ratio:4/3}
.service-photo img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.service-photo:hover img{transform:scale(1.04)}
.related-services{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:40px}
.related-svc{display:flex;align-items:center;gap:10px;background:var(--light-bg);border:1px solid var(--border);border-radius:10px;padding:14px 16px;text-decoration:none;color:var(--dark);font-size:13px;font-weight:700;transition:all .2s}
.related-svc:hover{background:#fff;box-shadow:0 4px 16px rgba(0,0,0,.08)}
.related-svc-icon{font-size:20px}

/* ── REVIEWS PAGE ────────────────────────────────────────────── */
.reviews-summary{display:grid;grid-template-columns:auto 1fr;gap:40px;align-items:center;background:var(--light-bg);border:1px solid var(--border);border-radius:20px;padding:36px;margin-top:52px;margin-bottom:40px}
.reviews-big-num{font-size:80px;font-weight:900;color:var(--dark);line-height:1}
.reviews-big-stars{color:var(--star-color);font-size:28px;margin-bottom:6px}
.reviews-big-label{font-size:13px;color:#6b7280}
.reviews-bars{display:flex;flex-direction:column;gap:8px;width:100%}
.review-bar-row{display:flex;align-items:center;gap:10px}
.review-bar-label{font-size:12px;color:#6b7280;min-width:36px}
.review-bar-track{flex:1;height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden}
.review-bar-fill{height:100%;background:var(--star-color);border-radius:4px}
.review-bar-count{font-size:12px;color:#9ca3af;min-width:28px;text-align:right}
.all-reviews-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:24px}

/* ── AI CALLOUT BOX ──────────────────────────────────────────── */
.ai-callout{background:linear-gradient(135deg,var(--dark),var(--primary));border-radius:18px;padding:40px;text-align:center;margin-top:52px}
.ai-callout h3{font-size:24px;font-weight:900;color:#fff;margin-bottom:10px}
.ai-callout p{font-size:15px;color:rgba(255,255,255,.7);margin-bottom:28px;max-width:500px;margin-left:auto;margin-right:auto}
.ai-features{display:flex;gap:20px;justify-content:center;flex-wrap:wrap;margin-bottom:28px}
.ai-feat{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.8);padding:8px 16px;border-radius:100px;font-size:13px;font-weight:600}
.ai-feat::before{content:'✓ ';color:var(--accent)}

/* ── ESTIMATE PAGE ───────────────────────────────────────────── */
.estimate-grid{display:grid;grid-template-columns:3fr 2fr;gap:60px;align-items:start;margin-top:52px}
.estimate-form{background:#fff;border:1.5px solid #e5e7eb;border-radius:18px;padding:36px;display:flex;flex-direction:column;gap:16px}
.estimate-sidebar{display:flex;flex-direction:column;gap:20px}
.est-feature{background:var(--light-bg);border:1px solid var(--border);border-radius:12px;padding:20px;display:flex;align-items:center;gap:14px}
.est-icon{font-size:28px;flex-shrink:0}
.est-label{font-size:14px;font-weight:700;color:var(--dark);margin-bottom:4px}
.est-sub{font-size:13px;color:#6b7280}

/* ── GALLERY PAGE ────────────────────────────────────────────── */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:0}
.gallery-item{position:relative;border-radius:12px;overflow:hidden;aspect-ratio:4/3;cursor:pointer}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.gallery-item:hover img{transform:scale(1.06)}
.gallery-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.75) 0%,transparent 60%);opacity:0;transition:opacity .3s;display:flex;align-items:flex-end}
.gallery-item:hover .gallery-overlay{opacity:1}
.gallery-info{padding:16px}
.gallery-info h4{font-size:14px;font-weight:800;color:#fff;margin-bottom:4px}
.gallery-info p{font-size:12px;color:rgba(255,255,255,.75)}
.filter-btn{background:var(--light-bg);border:1.5px solid var(--border);color:var(--dark);padding:8px 18px;border-radius:100px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}
.filter-btn.active,.filter-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}

/* ── REVIEWS PAGE ─────────────────────────────────────────────── */
.reviews-summary{display:grid;grid-template-columns:auto 1fr auto;gap:40px;align-items:start;background:var(--light-bg);border:1px solid var(--border);border-radius:20px;padding:36px;margin-top:40px}
.review-score{text-align:center}
.review-big-num{font-size:80px;font-weight:900;color:var(--dark);line-height:1}
.review-stars-big{color:var(--star-color);font-size:26px;margin:6px 0}
.review-count-label{font-size:13px;color:#6b7280;white-space:nowrap}
.review-bars{display:flex;flex-direction:column;gap:8px;min-width:220px}
.review-bar-row{display:flex;align-items:center;gap:8px}
.rb-label{font-size:12px;color:#6b7280;min-width:28px}
.rb-track{flex:1;height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden}
.rb-fill{height:100%;background:var(--star-color);border-radius:4px}
.rb-pct{font-size:12px;color:#9ca3af;min-width:28px;text-align:right}
.review-platforms{display:flex;flex-direction:column;gap:10px;min-width:200px}
.rp-badge{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:10px 14px;font-size:13px;font-weight:600;color:#374151}
.reviews-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.review-card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:22px;display:flex;flex-direction:column;gap:12px}
.rc-header{display:flex;align-items:center;gap:12px}
.rc-avatar{width:40px;height:40px;border-radius:50%;background:var(--primary);color:#fff;font-size:13px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.rc-name{font-size:14px;font-weight:700;color:var(--dark)}
.rc-loc{font-size:12px;color:#9ca3af}
.rc-stars{color:var(--star-color);font-size:14px;margin-left:auto;white-space:nowrap}
.rc-text{font-size:14px;color:#374151;line-height:1.6;flex:1}
.rc-meta{font-size:12px;color:#9ca3af;font-style:italic;border-top:1px solid #f3f4f6;padding-top:10px}

/* ── BLOG PAGE ───────────────────────────────────────────────── */
.blog-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
.blog-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;overflow:hidden;display:flex;flex-direction:column;transition:box-shadow .2s}
.blog-card:hover{box-shadow:0 8px 32px rgba(0,0,0,.1)}
.blog-img{aspect-ratio:16/9;overflow:hidden}
.blog-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.blog-card:hover .blog-img img{transform:scale(1.04)}
.blog-body{padding:22px;display:flex;flex-direction:column;gap:10px;flex:1}
.blog-meta{display:flex;align-items:center;gap:10px}
.blog-cat{background:var(--light-bg);color:var(--primary);font-size:11px;font-weight:700;padding:4px 10px;border-radius:100px;border:1px solid var(--border)}
.blog-date{font-size:12px;color:#9ca3af}
.blog-title{font-size:17px;font-weight:800;color:var(--dark);line-height:1.4}
.blog-excerpt{font-size:14px;color:#4a5568;line-height:1.6;flex:1}
.blog-footer{display:flex;align-items:center;justify-content:space-between;border-top:1px solid #f3f4f6;padding-top:12px;margin-top:4px}
.blog-author{font-size:12px;color:#9ca3af}
.blog-read{font-size:13px;font-weight:700;color:var(--accent-dark);text-decoration:none}
.blog-read:hover{text-decoration:underline}

/* ── CONTACT PAGE ────────────────────────────────────────────── */
.contact-grid{display:grid;grid-template-columns:3fr 2fr;gap:60px;align-items:start;margin-top:40px}
.contact-form-col{display:flex;flex-direction:column;gap:20px}
.contact-info-col{display:flex;flex-direction:column;gap:16px}
.contact-info-card,.contact-hours-card,.sidebar-card{background:#fff;border:1.5px solid #e5e7eb;border-radius:16px;padding:24px}
.contact-info-card h3,.contact-hours-card h3,.sidebar-card h3{font-size:17px;font-weight:800;color:var(--dark);margin-bottom:16px}
.ci-item{display:flex;gap:14px;align-items:flex-start;padding:12px 0;border-bottom:1px solid #f3f4f6}
.ci-item:last-child{border-bottom:none}
.ci-icon{font-size:20px;flex-shrink:0;margin-top:2px}
.ci-label{font-size:12px;color:#9ca3af;margin-bottom:3px;font-weight:500}
.ci-value{font-size:15px;font-weight:600;color:var(--dark);text-decoration:none}
a.ci-value:hover{color:var(--accent-dark)}
.hours-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid #f3f4f6;font-size:14px;color:#374151}
.hours-row:last-of-type{border-bottom:none}
.hours-emergency{display:flex;align-items:center;gap:8px;margin-top:14px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:10px 14px;font-size:13px;color:#991b1b}
.map-container{border-radius:14px;overflow:hidden;border:1px solid #e5e7eb}

/* ── AREAS PAGE ──────────────────────────────────────────────── */
.areas-counties{display:flex;flex-direction:column;gap:48px;margin-top:48px}
.county-block{}
.county-header{display:flex;align-items:center;gap:12px;margin-bottom:20px;padding-bottom:12px;border-bottom:2px solid var(--border)}
.county-header h3{font-size:20px;font-weight:800;color:var(--dark)}
.county-icon{font-size:24px}
.areas-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.area-card{background:var(--light-bg);border:1px solid var(--border);border-radius:10px;padding:14px 16px}
.ac-name{font-size:15px;font-weight:800;color:var(--dark);margin-bottom:4px}
.ac-subs{font-size:12px;color:#6b7280}
.area-note{display:flex;align-items:flex-start;gap:12px;background:#fff8f0;border:1px solid #fed7aa;border-radius:10px;padding:16px 20px;margin-top:28px;font-size:14px;color:#92400e}
.area-note span{font-size:18px;flex-shrink:0}
.area-note a{color:var(--accent-dark);font-weight:600}
.local-knowledge-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:40px}
.lk-card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:24px;text-align:center}
.lk-icon{font-size:36px;margin-bottom:12px}
.lk-card h4{font-size:15px;font-weight:800;color:var(--dark);margin-bottom:8px}
.lk-card p{font-size:13px;color:#4a5568;line-height:1.6}

/* ── ESTIMATE PAGE ───────────────────────────────────────────── */
.estimate-layout{display:grid;grid-template-columns:3fr 2fr;gap:60px;align-items:start;margin-top:40px}
.estimate-form-col{display:flex;flex-direction:column;gap:20px}
.estimate-sidebar{display:flex;flex-direction:column;gap:0}

/* ── AI CALLOUT (inline row version) ─────────────────────────── */
.ai-callout-inner{display:flex;align-items:center;gap:20px;background:linear-gradient(135deg,var(--dark),var(--primary));border-radius:18px;padding:32px 36px}
.ai-callout-icon{font-size:48px;flex-shrink:0}
.ai-callout-inner h3{font-size:20px;font-weight:900;color:#fff;margin-bottom:6px}
.ai-callout-inner p{font-size:14px;color:rgba(255,255,255,.75);line-height:1.6}
.ai-callout-btn{display:inline-block;background:var(--accent);color:var(--btn-text);padding:12px 24px;border-radius:8px;font-size:13px;font-weight:800;text-decoration:none;white-space:nowrap;flex-shrink:0;margin-left:auto}
.ai-callout-btn:hover{opacity:.9}

/* ── RESPONSIVE ──────────────────────────────────────────────── */
@media(max-width:1024px){
  .trust-grid{grid-template-columns:repeat(2,1fr)}
  .footer-top{grid-template-columns:1fr 1fr}
}
@media(max-width:900px){
  .nav-links,.nav-cta{display:none}
  .nav-hamburger,.nav-phone-sm{display:flex}
  .services-grid,.testimonials-grid,.about-grid,.about-owner,.sara-inner,.contact-grid,.contact-grid,.team-grid,.google-reviews-grid,.steps-row,.reviews-summary,.estimate-grid,.estimate-layout,.local-knowledge-grid{grid-template-columns:1fr}
  .stats-inner{grid-template-columns:repeat(2,1fr)}
  .gallery-grid,.blog-grid,.service-photos,.related-services,.reviews-grid{grid-template-columns:repeat(2,1fr)}
  .areas-grid{grid-template-columns:repeat(2,1fr)}
  .footer-top{grid-template-columns:1fr 1fr}
  .sara-phone-wrap{margin:0 auto}
  .form-row{grid-template-columns:1fr}
  .process-step{grid-template-columns:1fr}
  .ps-num{margin-bottom:8px}
  .ai-callout-inner{flex-direction:column;text-align:center}
  .ai-callout-btn{margin-left:0}
}
@media(max-width:600px){
  .stats-inner{grid-template-columns:1fr}
  .hero-content h1{font-size:34px}
  .gallery-grid,.service-photos,.blog-grid,.related-services,.reviews-grid{grid-template-columns:1fr}
  .areas-grid{grid-template-columns:1fr}
  .trust-grid{grid-template-columns:1fr}
  .float-features{display:none}
  .footer-top{grid-template-columns:1fr}
  .review-score,.review-bars,.review-platforms{min-width:0;width:100%}
}
