/* ============================================================
   LAKE BUENA HVAC — Inner Pages Shared CSS
   Brand: Lake Buena HVAC | Location: Lake Buena Vista, FL 32830
   Colors: Teal #026586 | Green #5d9331
   Font: Montserrat
============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700;800;900&display=swap');

/* ── TOKENS ── */
:root {
  --primary:        #026586;
  --primary-dark:   #014d65;
  --primary-light:  #028aad;
  --accent:         #5d9331;
  --accent-light:   #7ab840;
  --secondary:      #5d9331;
  --secondary-light:#7ab840;
  --white:          #FFFFFF;
  --off-white:      #F8FAFF;
  --gray-50:        #F9FAFB;
  --gray-100:       #F3F4F6;
  --gray-200:       #E5E7EB;
  --gray-300:       #D1D5DB;
  --gray-500:       #6B7280;
  --gray-700:       #374151;
  --gray-900:       #111827;
  --success:        #10B981;
  --shadow-sm:      0 1px 3px rgba(0,0,0,0.08);
  --shadow-md:      0 4px 16px rgba(0,0,0,0.10);
  --shadow-lg:      0 10px 40px rgba(0,0,0,0.14);
  --shadow-xl:      0 20px 60px rgba(0,0,0,0.18);
  --radius-sm:      8px;
  --radius-md:      12px;
  --radius-lg:      20px;
  --radius-xl:      32px;
  --transition:     all 0.3s cubic-bezier(0.4,0,0.2,1);
  --transition-fast:all 0.15s ease;
  --font-main:      'Montserrat', sans-serif;
  --font-heading:   'Montserrat', sans-serif;
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;font-size:16px;}
body{font-family:var(--font-main);color:var(--gray-700);background:var(--white);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased;}
img{max-width:100%;height:auto;}
a{text-decoration:none;}

/* ── LAYOUT ── */
.container{max-width:1200px;margin:0 auto;padding:0 24px;}
.container-wide{max-width:1400px;margin:0 auto;padding:0 24px;}
.section-padding{padding:96px 0;}
.section-padding-sm{padding:64px 0;}

/* ── TYPOGRAPHY ── */
.section-label{display:inline-flex;align-items:center;gap:8px;font-size:0.75rem;font-weight:800;text-transform:uppercase;letter-spacing:0.1em;color:var(--accent);background:rgba(93,147,49,0.10);border:1px solid rgba(93,147,49,0.25);padding:5px 14px;border-radius:50px;margin-bottom:16px;}
.section-title{font-family:var(--font-heading);font-size:clamp(1.7rem,3.5vw,2.6rem);font-weight:900;color:var(--gray-900);line-height:1.18;margin-bottom:16px;letter-spacing:-0.02em;}
.section-title span{color:var(--primary);}
.section-subtitle{font-size:1rem;color:var(--gray-500);line-height:1.75;max-width:640px;}

/* ── BUTTONS ── */
.btn-primary{display:inline-flex;align-items:center;gap:10px;background:linear-gradient(135deg,var(--primary),var(--primary-light));color:var(--white);padding:14px 28px;border-radius:50px;font-weight:700;font-size:0.95rem;font-family:var(--font-main);border:none;cursor:pointer;transition:var(--transition);box-shadow:0 4px 18px rgba(2,101,134,0.30);}
.btn-primary:hover{background:linear-gradient(135deg,var(--primary-dark),var(--primary));transform:translateY(-2px);box-shadow:0 8px 28px rgba(2,101,134,0.40);}
.btn-secondary{display:inline-flex;align-items:center;gap:10px;background:rgba(255,255,255,0.12);backdrop-filter:blur(10px);color:var(--white);padding:14px 28px;border-radius:50px;font-weight:700;font-size:0.95rem;font-family:var(--font-main);border:1.5px solid rgba(255,255,255,0.30);cursor:pointer;transition:var(--transition);}
.btn-secondary:hover{background:rgba(255,255,255,0.20);transform:translateY(-2px);}
.btn-outline-dark{display:inline-flex;align-items:center;gap:8px;background:transparent;color:var(--primary);padding:13px 26px;border-radius:50px;font-weight:700;font-size:0.92rem;font-family:var(--font-main);border:2px solid var(--primary);cursor:pointer;transition:var(--transition);}
.btn-outline-dark:hover{background:var(--primary);color:var(--white);transform:translateY(-2px);}
.btn-white{display:inline-flex;align-items:center;gap:8px;background:var(--white);color:var(--primary);padding:14px 28px;border-radius:50px;font-weight:700;font-size:0.95rem;font-family:var(--font-main);border:none;cursor:pointer;transition:var(--transition);box-shadow:0 4px 18px rgba(0,0,0,0.15);}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,0,0,0.20);}

/* ── ANNOUNCEMENT BAR ── */
.announcement-bar{background:linear-gradient(90deg,var(--primary-dark),var(--primary));padding:10px 0;overflow:hidden;}
.announcement-items{display:flex;align-items:center;justify-content:center;gap:32px;}
.announcement-item{display:flex;align-items:center;gap:8px;font-size:0.78rem;font-weight:600;color:rgba(255,255,255,0.90);white-space:nowrap;}
.dot{width:7px;height:7px;border-radius:50%;background:var(--accent-light);animation:dotPulse 1.8s ease-in-out infinite;}
@keyframes dotPulse{0%,100%{transform:scale(1);opacity:1;}50%{transform:scale(1.5);opacity:0.7;}}

/* ── NAV ── */
.nav-wrapper{position:sticky;top:0;z-index:1000;transition:var(--transition);}
.nav-wrapper nav{display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:70px;max-width:1200px;margin:0 auto;background:transparent;transition:var(--transition);}
.nav-wrapper{background:rgba(255,255,255,0.96);backdrop-filter:blur(16px);border-bottom:1px solid var(--gray-100);}
.nav-wrapper.scrolled{box-shadow:0 4px 24px rgba(2,101,134,0.12);}
.nav-logo{display:flex;align-items:center;gap:11px;text-decoration:none;}
.nav-logo-icon{width:42px;height:42px;background:linear-gradient(135deg,var(--primary),var(--primary-light));border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--white);font-family:var(--font-heading);font-weight:900;font-size:0.72rem;letter-spacing:0.04em;box-shadow:0 2px 8px rgba(10,46,92,0.18);flex-shrink:0;}
.nav-logo-text{display:flex;flex-direction:column;line-height:1.15;}
.nav-logo-text strong{display:block;font-family:var(--font-heading);font-size:0.97rem;font-weight:800;color:var(--gray-900);}
.nav-logo-text span{font-size:0.68rem;color:var(--gray-400);font-weight:500;}
.nav-links{list-style:none;display:flex;align-items:center;gap:4px;}
.nav-links li a{padding:8px 14px;border-radius:var(--radius-sm);font-size:0.87rem;font-weight:600;color:var(--gray-700);transition:var(--transition-fast);text-decoration:none;}
.nav-links li a:hover,.nav-links li a.active{color:var(--primary);background:rgba(2,101,134,0.07);}
.nav-links li.nav-dropdown{position:relative;}
.nav-links li.nav-dropdown:hover .dropdown-menu{opacity:1;visibility:visible;transform:translateY(0);}
.dropdown-menu{position:absolute;top:calc(100% + 8px);left:0;min-width:200px;background:var(--white);border:1px solid var(--gray-100);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:8px;opacity:0;visibility:hidden;transform:translateY(-8px);transition:var(--transition);}
.dropdown-menu a{display:flex;align-items:center;gap:8px;padding:9px 14px;border-radius:var(--radius-sm);font-size:0.84rem;font-weight:600;color:var(--gray-700);text-decoration:none;transition:var(--transition-fast);}
.dropdown-menu a:hover{background:rgba(2,101,134,0.08);color:var(--primary);}
.nav-phone{font-size:0.88rem;font-weight:700;color:var(--primary);text-decoration:none;}
.nav-actions{display:flex;align-items:center;gap:16px;}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px;}
.hamburger span{display:block;width:24px;height:2px;background:var(--gray-900);border-radius:2px;transition:var(--transition);}

/* ── MOBILE NAV ── */
.mobile-nav{position:fixed;inset:0;background:var(--white);z-index:2000;transform:translateX(100%);transition:transform 0.35s cubic-bezier(0.4,0,0.2,1);display:flex;flex-direction:column;padding:24px;}
.mobile-nav.open{transform:translateX(0);}
.mobile-nav-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px;}
.mobile-nav-close{background:none;border:none;font-size:1.4rem;cursor:pointer;color:var(--gray-900);}
.mobile-nav-links{list-style:none;display:flex;flex-direction:column;gap:4px;flex:1;}
.mobile-nav-links li a{display:block;padding:14px 16px;border-radius:var(--radius-md);font-size:1rem;font-weight:700;color:var(--gray-900);text-decoration:none;transition:var(--transition-fast);}
.mobile-nav-links li a:hover{background:rgba(2,101,134,0.08);color:var(--primary);}
.mobile-nav-actions{display:flex;flex-direction:column;gap:12px;margin-top:24px;}

/* ── PAGE HERO (inner pages) ── */
.page-hero{background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary) 55%,var(--primary-light) 100%);padding:80px 0 72px;position:relative;overflow:hidden;}
.page-hero::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");}
.page-hero-inner{position:relative;z-index:1;max-width:800px;}
.page-hero-breadcrumb{display:flex;align-items:center;gap:8px;margin-bottom:20px;font-size:0.8rem;font-weight:600;}
.page-hero-breadcrumb a{color:rgba(255,255,255,0.65);text-decoration:none;transition:var(--transition-fast);}
.page-hero-breadcrumb a:hover{color:var(--white);}
.page-hero-breadcrumb span{color:rgba(255,255,255,0.40);}
.page-hero-breadcrumb .current{color:rgba(255,255,255,0.85);}
.page-hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,0.12);border:1px solid rgba(255,255,255,0.22);padding:6px 16px;border-radius:50px;font-size:0.76rem;font-weight:700;color:rgba(255,255,255,0.90);margin-bottom:20px;}
.page-hero h1{font-family:var(--font-heading);font-size:clamp(2rem,4.5vw,3.2rem);font-weight:900;color:var(--white);line-height:1.12;letter-spacing:-0.03em;margin-bottom:18px;}
.page-hero h1 span{color:var(--accent-light);}
.page-hero p{font-size:1.05rem;color:rgba(255,255,255,0.78);line-height:1.75;margin-bottom:32px;max-width:680px;}
.page-hero-actions{display:flex;align-items:center;gap:16px;flex-wrap:wrap;}
.page-hero-trust{display:flex;flex-wrap:wrap;gap:16px;margin-top:28px;}
.page-hero-trust-item{display:flex;align-items:center;gap:7px;font-size:0.82rem;font-weight:600;color:rgba(255,255,255,0.78);}
.hero-check{width:20px;height:20px;border-radius:50%;background:rgba(93,147,49,0.35);border:1px solid rgba(93,147,49,0.5);display:flex;align-items:center;justify-content:center;font-size:0.65rem;color:var(--accent-light);}

/* ── SERVICE CARDS ── */
.services-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px;}
.service-card{background:var(--white);border:1px solid var(--gray-100);border-radius:var(--radius-lg);padding:28px 24px;box-shadow:var(--shadow-sm);transition:var(--transition);display:flex;flex-direction:column;gap:12px;}
.service-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);border-color:rgba(2,101,134,0.20);}
.service-card-icon{width:52px;height:52px;border-radius:var(--radius-md);background:linear-gradient(135deg,rgba(2,101,134,0.10),rgba(2,138,173,0.15));display:flex;align-items:center;justify-content:center;font-size:1.4rem;}
.service-card-tag{display:inline-block;font-size:0.68rem;font-weight:800;text-transform:uppercase;letter-spacing:0.08em;color:var(--accent);background:rgba(93,147,49,0.10);border:1px solid rgba(93,147,49,0.22);padding:3px 10px;border-radius:50px;}
.service-card h3{font-family:var(--font-heading);font-size:1.05rem;font-weight:800;color:var(--gray-900);line-height:1.3;}
.service-card p{font-size:0.87rem;color:var(--gray-500);line-height:1.65;flex:1;}
.service-card-link{font-size:0.82rem;font-weight:700;color:var(--primary);display:flex;align-items:center;gap:4px;}

/* ── WHY US CARDS ── */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.why-card{background:linear-gradient(160deg,#F4FAF7,#fff);border:1px solid var(--gray-100);border-radius:var(--radius-lg);padding:28px 24px;border-top:3px solid var(--primary);}
.why-card-icon{font-size:2rem;margin-bottom:14px;display:block;}
.why-card h3{font-size:1rem;font-weight:800;color:var(--gray-900);margin-bottom:10px;}
.why-card p{font-size:0.87rem;color:var(--gray-500);line-height:1.65;}

/* ── FAQ ── */
.faq-list{display:flex;flex-direction:column;gap:10px;}
.faq-item{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-md);overflow:hidden;transition:var(--transition-fast);}
.faq-item.open{border-color:rgba(2,101,134,0.30);box-shadow:0 4px 16px rgba(2,101,134,0.08);}
.faq-question{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;cursor:pointer;gap:16px;}
.faq-question span{font-size:0.95rem;font-weight:700;color:var(--gray-900);line-height:1.4;}
.faq-toggle{width:28px;height:28px;border-radius:50%;background:var(--gray-100);display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:700;color:var(--primary);flex-shrink:0;transition:var(--transition-fast);}
.faq-item.open .faq-toggle{background:var(--primary);color:var(--white);transform:rotate(45deg);}
.faq-answer{max-height:0;overflow:hidden;transition:max-height 0.4s ease;}
.faq-answer.open{max-height:400px;}
.faq-answer-inner{padding:0 22px 18px;font-size:0.9rem;color:var(--gray-500);line-height:1.75;}

/* ── CONTACT FORM ── */
.contact-form-wrap{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-xl);padding:40px;box-shadow:var(--shadow-md);}
.form-group{margin-bottom:16px;}
.form-group label{display:block;font-size:0.78rem;font-weight:700;color:var(--gray-700);margin-bottom:6px;text-transform:uppercase;letter-spacing:0.04em;}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 16px;border:1.5px solid var(--gray-200);border-radius:var(--radius-md);font-size:0.9rem;color:var(--gray-900);background:var(--gray-50);transition:var(--transition-fast);font-family:var(--font-main);outline:none;}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);background:var(--white);box-shadow:0 0 0 3px rgba(2,101,134,0.08);}
.form-group textarea{resize:vertical;min-height:120px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.form-submit-btn{width:100%;background:linear-gradient(135deg,var(--primary),var(--primary-light));color:var(--white);padding:15px;border:none;border-radius:50px;font-size:1rem;font-weight:700;cursor:pointer;transition:var(--transition);font-family:var(--font-main);box-shadow:0 4px 18px rgba(2,101,134,0.30);}
.form-submit-btn:hover{background:linear-gradient(135deg,var(--primary-dark),var(--primary));transform:translateY(-2px);}

/* ── INFO CARDS ── */
.info-card{background:linear-gradient(160deg,#F2F8F5,#fff);border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:30px;}
.info-card h3{font-family:var(--font-heading);font-size:1.05rem;font-weight:800;color:var(--gray-900);margin-bottom:16px;display:flex;align-items:center;gap:10px;}
.info-list{list-style:none;display:flex;flex-direction:column;gap:10px;}
.info-list li{display:flex;align-items:flex-start;gap:10px;font-size:0.88rem;color:var(--gray-700);}
.info-list li::before{content:'✓';color:var(--accent);font-weight:900;flex-shrink:0;margin-top:1px;}

/* ── FEATURE SPLIT ── */
.feature-split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;}
.feature-visual{border-radius:var(--radius-xl);overflow:hidden;aspect-ratio:4/3;background:linear-gradient(135deg,var(--primary-dark),var(--primary));display:flex;align-items:center;justify-content:center;font-size:5rem;position:relative;}
.feature-visual::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at 30% 70%,rgba(93,147,49,0.25),transparent 60%);}

/* ── AREAS GRID ── */
.areas-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.area-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:26px;transition:var(--transition);position:relative;overflow:hidden;}
.area-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary),var(--accent));}
.area-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:rgba(2,101,134,0.25);}
.area-card-zip{font-size:0.68rem;font-weight:900;text-transform:uppercase;letter-spacing:0.1em;color:var(--accent);margin-bottom:6px;}
.area-card h3{font-size:1rem;font-weight:800;color:var(--gray-900);margin-bottom:8px;}
.area-card p{font-size:0.84rem;color:var(--gray-500);line-height:1.6;margin-bottom:14px;}
.area-card-link{font-size:0.82rem;font-weight:700;color:var(--primary);}

/* ── BLOG CARDS ── */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.blog-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-lg);overflow:hidden;transition:var(--transition);}
.blog-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);}
.blog-card-img{aspect-ratio:16/9;background:linear-gradient(135deg,var(--primary-dark),var(--primary));display:flex;align-items:center;justify-content:center;font-size:3rem;}
.blog-card-body{padding:22px 22px 24px;}
.blog-card-cat{font-size:0.68rem;font-weight:800;text-transform:uppercase;letter-spacing:0.08em;color:var(--accent);margin-bottom:8px;}
.blog-card h3{font-size:0.97rem;font-weight:800;color:var(--gray-900);line-height:1.35;margin-bottom:8px;}
.blog-card p{font-size:0.84rem;color:var(--gray-500);line-height:1.6;margin-bottom:14px;}
.blog-card-meta{font-size:0.75rem;color:var(--gray-500);font-weight:600;}

/* ── PROCESS STEPS (inner) ── */
.steps-list{display:flex;flex-direction:column;gap:0;}
.step-item{display:flex;gap:24px;padding-bottom:32px;position:relative;}
.step-item:not(:last-child)::after{content:'';position:absolute;left:23px;top:50px;bottom:0;width:2px;background:linear-gradient(180deg,var(--primary),rgba(2,101,134,0.10));}
.step-num{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-light));display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-size:1.1rem;font-weight:900;color:var(--white);flex-shrink:0;box-shadow:0 4px 14px rgba(2,101,134,0.30);}
.step-content h4{font-size:1rem;font-weight:800;color:var(--gray-900);margin-bottom:6px;padding-top:10px;}
.step-content p{font-size:0.87rem;color:var(--gray-500);line-height:1.65;}

/* ── STAT CHIPS ── */
.stat-chips{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
.stat-chip{text-align:center;padding:20px 14px;background:var(--white);border:1px solid var(--gray-100);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);}
.stat-chip-num{font-family:var(--font-heading);font-size:1.9rem;font-weight:900;color:var(--primary);line-height:1;margin-bottom:6px;}
.stat-chip-label{font-size:0.72rem;color:var(--gray-500);font-weight:700;text-transform:uppercase;letter-spacing:0.06em;line-height:1.3;}

/* ── CTA BANNER ── */
.cta-banner{background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary) 60%,var(--primary-light) 100%);padding:80px 0;position:relative;overflow:hidden;}
.cta-banner::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 80% 50%,rgba(93,147,49,0.20),transparent 55%);}
.cta-inner{position:relative;z-index:1;text-align:center;}
.cta-badge{display:inline-block;background:rgba(255,255,255,0.12);border:1px solid rgba(255,255,255,0.22);padding:6px 18px;border-radius:50px;font-size:0.78rem;font-weight:700;color:rgba(255,255,255,0.88);margin-bottom:20px;}
.cta-title{font-family:var(--font-heading);font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:900;color:var(--white);line-height:1.18;letter-spacing:-0.02em;margin-bottom:14px;}
.cta-subtitle{font-size:1rem;color:rgba(255,255,255,0.72);line-height:1.7;max-width:640px;margin:0 auto 32px;}
.cta-actions{display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap;}
.cta-trust-row{display:flex;align-items:center;justify-content:center;gap:24px;margin-top:24px;flex-wrap:wrap;}
.cta-trust-item{font-size:0.8rem;font-weight:700;color:rgba(255,255,255,0.70);}

/* ── FOOTER ── */
footer{background:var(--gray-900);}
.footer-main{padding:64px 0;}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;}
.footer-logo{display:flex;align-items:center;gap:12px;text-decoration:none;margin-bottom:16px;}
.footer-logo-icon{width:40px;height:40px;background:linear-gradient(135deg,var(--primary),var(--primary-light));border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--white);font-family:var(--font-heading);font-weight:900;font-size:0.78rem;}
.footer-logo-text strong{display:block;font-family:var(--font-heading);font-size:0.9rem;font-weight:800;color:var(--white);}
.footer-logo-text span{font-size:0.68rem;color:rgba(255,255,255,0.40);}
.footer-desc{font-size:0.83rem;color:rgba(255,255,255,0.45);line-height:1.7;margin-bottom:20px;}
.footer-social{display:flex;gap:8px;}
.social-btn{width:34px;height:34px;border-radius:var(--radius-sm);background:rgba(255,255,255,0.07);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.50);font-size:0.8rem;font-weight:700;text-decoration:none;transition:var(--transition-fast);}
.social-btn:hover{background:var(--primary);color:var(--white);}
.footer-col h4{font-size:0.78rem;font-weight:800;text-transform:uppercase;letter-spacing:0.08em;color:rgba(255,255,255,0.40);margin-bottom:14px;}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:8px;}
.footer-links a{font-size:0.84rem;color:rgba(255,255,255,0.55);text-decoration:none;transition:var(--transition-fast);}
.footer-links a:hover{color:var(--accent-light);}
.footer-contact-item{display:flex;align-items:flex-start;gap:10px;margin-bottom:10px;font-size:0.84rem;color:rgba(255,255,255,0.55);}
.footer-contact-item a{color:rgba(255,255,255,0.75);text-decoration:none;}
.footer-contact-item a:hover{color:var(--accent-light);}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.07);padding:20px 0;}
.footer-bottom-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;}
.footer-copyright{font-size:0.78rem;color:rgba(255,255,255,0.30);}
.footer-bottom-links{display:flex;gap:20px;}
.footer-bottom-links a{font-size:0.78rem;color:rgba(255,255,255,0.30);text-decoration:none;}
.footer-bottom-links a:hover{color:rgba(255,255,255,0.60);}

/* ── MOBILE FLOAT / STICKY ── */
.sticky-call-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:1080;background:var(--white);border-top:1px solid var(--gray-200);padding:10px 16px;}
.sticky-call-bar-inner{display:flex;gap:10px;}
.sticky-call-btn{flex:1;background:var(--primary);color:var(--white);padding:13px;border-radius:var(--radius-md);font-weight:700;font-size:0.9rem;text-align:center;text-decoration:none;}
.sticky-quote-btn{flex:1;background:var(--accent);color:var(--white);padding:13px;border-radius:var(--radius-md);font-weight:700;font-size:0.9rem;text-align:center;text-decoration:none;}
.float-btn{position:fixed;bottom:24px;right:24px;width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-light));box-shadow:0 10px 26px rgba(93,147,49,0.40);z-index:1090;text-decoration:none;display:flex;align-items:center;justify-content:center;color:var(--white);font-size:1.4rem;transition:var(--transition-fast);}
.float-btn:hover{transform:translateY(-2px);}

/* ── REVEAL ANIMATIONS ── */
.reveal,.reveal-left,.reveal-right{opacity:0;transition:opacity 0.7s ease,transform 0.7s ease;}
.reveal{transform:translateY(28px);}
.reveal-left{transform:translateX(-32px);}
.reveal-right{transform:translateX(32px);}
.reveal.visible,.reveal-left.visible,.reveal-right.visible{opacity:1;transform:none;}
.delay-1{transition-delay:0.1s;}
.delay-2{transition-delay:0.2s;}
.delay-3{transition-delay:0.3s;}
.delay-4{transition-delay:0.4s;}

/* ══════════════════════════════════════════════
   RESPONSIVE — MOBILE FIRST
══════════════════════════════════════════════ */

/* ── TABLET (≤1024px) ── */
@media(max-width:1024px){
  /* Nav */
  .nav-links,.nav-actions .nav-phone,.nav-actions .btn-primary{display:none;}
  .hamburger{display:flex;}

  /* Grids → 2 col */
  .services-grid,.why-grid,.areas-grid,.blog-grid{grid-template-columns:repeat(2,1fr);}
  .footer-grid{grid-template-columns:repeat(2,1fr);}
  .feature-split{grid-template-columns:1fr;gap:40px;}
  .stat-chips{grid-template-columns:repeat(2,1fr);}

  /* Section spacing */
  .section-padding{padding:72px 0;}
  .section-padding-sm{padding:48px 0;}

  /* Page hero */
  .page-hero{padding:60px 0 52px;}
}

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

  /* ── Base ── */
  html{font-size:15px;}
  .container,.container-wide{padding:0 16px;}

  /* ── Announcement bar ── */
  .announcement-bar{padding:8px 0;}
  .announcement-item:nth-child(n+2){display:none;}
  .announcement-item{font-size:0.72rem;}

  /* ── Nav ── */
  .nav-wrapper nav{height:60px;padding:0 16px;}
  .nav-logo-text strong{font-size:0.88rem;}
  .nav-logo-text span{display:none;}
  .nav-logo-icon{width:36px;height:36px;font-size:0.65rem;}
  .hamburger{display:flex;padding:8px;}
  .hamburger span{width:22px;}

  /* ── Mobile nav drawer ── */
  .mobile-nav{padding:20px 16px 24px;}
  .mobile-nav-header{margin-bottom:24px;}
  .mobile-nav-links li a{padding:13px 14px;font-size:0.95rem;}
  .mobile-nav-actions{gap:10px;}
  .mobile-nav-actions a{padding:13px;font-size:0.9rem;justify-content:center;}

  /* ── Buttons ── */
  .btn-primary,.btn-secondary,.btn-outline-dark,.btn-white{
    padding:13px 22px;font-size:0.88rem;width:100%;justify-content:center;
  }
  /* Keep inline buttons natural width */
  .nav-actions .btn-primary,.footer-col .btn-primary,
  .cta-trust-row .btn-primary{width:auto;}

  /* ── Section spacing ── */
  .section-padding{padding:52px 0;}
  .section-padding-sm{padding:36px 0;}

  /* ── Typography ── */
  .section-title{font-size:1.55rem;margin-bottom:12px;}
  .section-subtitle{font-size:0.9rem;}
  .section-label{font-size:0.68rem;}

  /* ── Page hero ── */
  .page-hero{padding:44px 0 40px;}
  .page-hero h1{font-size:1.75rem;line-height:1.15;margin-bottom:14px;}
  .page-hero p{font-size:0.92rem;margin-bottom:22px;}
  .page-hero-actions{flex-direction:column;align-items:stretch;gap:10px;}
  .page-hero-actions a{text-align:center;justify-content:center;}
  .page-hero-trust{gap:10px;margin-top:20px;}
  .page-hero-trust-item{font-size:0.76rem;}
  .page-hero-breadcrumb{font-size:0.72rem;flex-wrap:wrap;gap:4px;}

  /* ── Grids → 1 col ── */
  .services-grid,.why-grid,.areas-grid,.blog-grid,
  .stat-chips,.footer-grid{grid-template-columns:1fr;}

  /* ── Service cards ── */
  .service-card{padding:20px 18px;}

  /* ── Why cards ── */
  .why-grid{gap:14px;}
  .why-card{padding:20px 18px;}

  /* ── Stat chips ── */
  .stat-chips{grid-template-columns:repeat(2,1fr);gap:10px;}
  .stat-chip{padding:16px 10px;}
  .stat-chip-num{font-size:1.6rem;}

  /* ── Feature split ── */
  .feature-split{grid-template-columns:1fr;gap:28px;}
  .feature-visual{aspect-ratio:16/9;}

  /* ── FAQ ── */
  .faq-question{padding:14px 16px;}
  .faq-question span{font-size:0.88rem;}
  .faq-answer-inner{padding:0 16px 14px;font-size:0.85rem;}

  /* ── Forms ── */
  .form-row{grid-template-columns:1fr;}
  .contact-form-wrap{padding:24px 18px;border-radius:16px;}
  .form-group input,.form-group select,.form-group textarea{
    font-size:16px; /* prevents iOS zoom */
    padding:12px 14px;
  }

  /* ── CTA banner ── */
  .cta-banner{padding:52px 0;}
  .cta-title{font-size:1.55rem;}
  .cta-subtitle{font-size:0.88rem;}
  .cta-actions{flex-direction:column;align-items:stretch;gap:10px;}
  .cta-actions a{text-align:center;justify-content:center;}
  .cta-trust-row{gap:12px;margin-top:18px;}
  .cta-trust-item{font-size:0.74rem;}

  /* ── Footer ── */
  .footer-main{padding:44px 0 32px;}
  .footer-grid{gap:28px;}
  .footer-desc{font-size:0.8rem;}
  .footer-col h4{margin-bottom:10px;}
  .footer-links a{font-size:0.82rem;}
  .footer-bottom{padding:16px 0;}
  .footer-bottom-inner{flex-direction:column;text-align:center;gap:10px;}
  .footer-bottom-links{justify-content:center;}

  /* ── Sticky call bar ── */
  .sticky-call-bar{display:block;padding:8px 12px;padding-bottom:calc(8px + env(safe-area-inset-bottom));}
  .sticky-call-btn,.sticky-quote-btn{
    padding:12px 10px;font-size:0.85rem;
    display:flex;align-items:center;justify-content:center;gap:6px;
  }

  /* ── Float button ── */
  .float-btn{display:none;}

  /* ── Blog cards ── */
  .blog-card-body{padding:16px 16px 18px;}
  .blog-card h3{font-size:0.92rem;}

  /* ── Areas grid ── */
  .areas-grid{gap:12px;}
  .area-card{padding:20px 18px;}

  /* ── Info card ── */
  .info-card{padding:20px 18px;}

  /* ── Steps ── */
  .step-item{gap:16px;}
  .step-num{width:40px;height:40px;font-size:0.95rem;flex-shrink:0;}

  /* ── kw-grid (category pages) ── */
  .kw-grid{grid-template-columns:1fr!important;}
  .kw-card{padding:14px 16px;}
  .kw-card span.txt{font-size:0.88rem;}

  /* ── zip pills ── */
  .zip-pills{gap:8px;}
  .zip-pill{padding:6px 12px;font-size:0.8rem;}

  /* ── Sub-service page check-list ── */
  .check-list{grid-template-columns:1fr!important;}
  .check-list li{font-size:0.86rem;padding:9px 12px;}

  /* ── Sub-service why-grid ── */
  .why-grid{grid-template-columns:1fr!important;}

  /* ── Sub-service hero ── */
  .svc-hero{padding:44px 0 36px;}
  .svc-hero h1{font-size:1.7rem;}
  .svc-hero p{font-size:0.9rem;}
  .svc-hero-actions{flex-direction:column;align-items:stretch;gap:10px;}
  .svc-hero-actions a{text-align:center;justify-content:center;}
  .trust-row{gap:10px;}
  .trust-item{font-size:0.76rem;}

  /* ── Cat hero ── */
  .cat-hero{padding:52px 0 44px!important;}
  .cat-hero h1{font-size:1.7rem!important;}
  .cat-hero p{font-size:0.9rem!important;}
  .cat-hero-actions{flex-direction:column;align-items:stretch;gap:10px;}
  .cat-hero-actions a{text-align:center;justify-content:center;}

  /* ── Content sections ── */
  .content-section{padding:44px 0;}
  .content-section h2{font-size:1.4rem;}
  .content-section h3{font-size:0.97rem;}
  .content-section p{font-size:0.88rem;}

  /* ── CTA band (sub-service pages) ── */
  .cta-band{padding:48px 0;}
  .cta-band h2{font-size:1.5rem;}
  .cta-band p{font-size:0.88rem;}
  .cta-actions{flex-direction:column;align-items:stretch;}

  /* ── Price band ── */
  .price-band{flex-direction:column;gap:16px;padding:20px 18px;}
  .price-divider{width:100%;height:1px;}
  .price-value{font-size:1.3rem;}

  /* ── Repair table ── */
  .repair-table{font-size:0.8rem;}
  .repair-table th,.repair-table td{padding:10px 12px;}

  /* ── Brand grid ── */
  .brand-grid{gap:8px;}
  .brand-chip{padding:8px 14px;font-size:0.8rem;}

  /* ── Steps grid ── */
  .steps-grid{grid-template-columns:1fr!important;}

  /* ── Svc detail grid ── */
  .svc-detail-grid{grid-template-columns:1fr!important;gap:28px;padding:44px 0!important;}
  .svc-detail-grid.reverse{direction:ltr!important;}
  .svc-detail-visual{aspect-ratio:16/9;font-size:4rem;}

  /* ── Hero form card (homepage) ── */
  .hero-content{grid-template-columns:1fr!important;gap:32px;padding:52px 16px!important;}
  .hero-form-card{padding:24px 18px;}
  .form-row{grid-template-columns:1fr;}

  /* ── Svc hero grid (services index) ── */
  .svc-hero-grid{grid-template-columns:1fr!important;}

  /* ── Blog sidebar ── */
  .blog-layout{grid-template-columns:1fr!important;}
  .blog-sidebar{display:none;}

  /* ── Reveal animations — disable on mobile for performance ── */
  .reveal,.reveal-left,.reveal-right{opacity:1!important;transform:none!important;}
}

/* ── SMALL MOBILE (≤400px) ── */
@media(max-width:400px){
  .page-hero h1,.svc-hero h1,.cat-hero h1{font-size:1.5rem!important;}
  .section-title,.cta-title,.cta-band h2{font-size:1.35rem;}
  .stat-chips{grid-template-columns:repeat(2,1fr);}
  .container,.container-wide{padding:0 12px;}
  .sticky-call-btn,.sticky-quote-btn{font-size:0.78rem;padding:11px 8px;}
}

/* ── SAFE AREA (notch phones) ── */
@supports(padding:max(0px)){
  .sticky-call-bar{
    padding-bottom:max(8px, env(safe-area-inset-bottom));
  }
  body{
    padding-bottom:env(safe-area-inset-bottom);
  }
}

/* ── INLINE SVG ICON SYSTEM ── */
.emoji-icon {
  width: 1.2em;
  height: 1.2em;
  display: inline-block;
  vertical-align: middle;
  flex-shrink: 0;
}
.btn-icon {
  width: 1em;
  height: 1em;
  display: inline-block;
  vertical-align: middle;
  flex-shrink: 0;
  margin-right: 4px;
}
.svc-hero-card-icon .emoji-icon,
.service-card-icon .emoji-icon,
.why-card-icon .emoji-icon,
.credential-card-icon .emoji-icon {
  width: 2rem;
  height: 2rem;
}
.svc-detail-visual { font-size: 5rem; display: flex; align-items: center; justify-content: center; }
.svc-detail-visual .emoji-icon { width: 4rem; height: 4rem; color: rgba(255,255,255,0.85); }
.blog-featured-thumb .emoji-icon { width: 3.5rem; height: 3.5rem; color: rgba(255,255,255,0.85); }
.blog-card-img .emoji-icon,
.blog-sidebar-icon .emoji-icon { width: 2.2rem; height: 2.2rem; color: rgba(255,255,255,0.85); }
.footer-contact-item .emoji-icon { width: 1rem; height: 1rem; opacity: 0.7; }
.price-icon.emoji-icon, span.price-icon .emoji-icon { width: 1.8rem; height: 1.8rem; }

/* ── MATERIAL ICONS SIZING ── */
.material-icons { font-family: 'Material Icons'; font-weight: normal; font-style: normal; line-height: 1; letter-spacing: normal; text-transform: none; display: inline-block; white-space: nowrap; word-wrap: normal; direction: ltr; -webkit-font-smoothing: antialiased; }
.mi-icon { font-size: 1.4rem; vertical-align: middle; }
.mi-btn  { font-size: 1.1rem; vertical-align: middle; margin-right: 4px; }
/* Context-specific sizes */
.price-icon .mi-icon        { font-size: 1.8rem; }
.stat-icon .mi-icon         { font-size: 1.5rem; color: var(--accent-light, #7ab840); }
.trust-badge-icon .mi-icon  { font-size: 1.1rem; color: white; }
.service-icon .mi-icon      { font-size: 1.5rem; }
.svc-cat-icon-wrap .mi-icon { font-size: 1.3rem; }
.svc-hero-card-icon .mi-icon,
.why-card-icon .mi-icon,
.credential-card-icon .mi-icon { font-size: 1.6rem; }
.svc-detail-visual .mi-icon { font-size: 4rem; color: rgba(255,255,255,0.85); }
.blog-featured-thumb .mi-icon { font-size: 3.5rem; color: rgba(255,255,255,0.85); }
.blog-card-img .mi-icon,
.blog-sidebar-icon .mi-icon { font-size: 2.2rem; color: rgba(255,255,255,0.85); }
.footer-contact-item .mi-icon { font-size: 1rem; opacity: 0.75; }
.rpl-icon .mi-icon { font-size: 1.4rem; }
.post-num .mi-icon { font-size: 1rem; color: white; }

/* ── MATERIAL ICONS EXTRA SIZES ── */
.mi-meta { font-size: 0.95rem; vertical-align: middle; opacity: 0.8; }
.mi-tip  { font-size: 1.1rem; vertical-align: middle; color: var(--accent, #5d9331); }

/* ── TRUST & REVIEW ICON SIZES ── */
.mi-trust { font-size: 0.9rem; vertical-align: middle; }
.mi-check { font-size: 0.95rem; vertical-align: middle; }
.mi-star  { font-size: 0.95rem; vertical-align: middle; color: #f59e0b; }
.mi-area  { font-size: 1.3rem; vertical-align: middle; }
.review-stars { display: inline-flex; gap: 1px; align-items: center; }
.review-stars .mi-star { font-size: 0.85rem; }

/* ══════════════════════════════════════════════
   DARK BACKGROUND — LIGHT ICON OVERRIDES
══════════════════════════════════════════════ */
.btn-primary .material-icons             { color: rgba(255,255,255,0.95); }
.btn-white .material-icons               { color: var(--primary); }
.page-hero-trust-item .material-icons    { color: #7ab840; }
.page-hero .btn-primary .material-icons,
.page-hero .btn-secondary .material-icons { color: currentColor; }
.cta-trust-item .material-icons          { color: rgba(255,255,255,0.90); }
.cta-trust-item .mi-star                 { color: #fbbf24; }
.cta-banner .material-icons             { color: rgba(255,255,255,0.90); }
footer .material-icons                   { color: rgba(255,255,255,0.70); }
footer a .material-icons                 { color: rgba(255,255,255,0.70); }
.trust-badge-icon .material-icons        { color: #ffffff; }
.svc-detail-visual .material-icons       { color: rgba(255,255,255,0.88); }
.svc-cat-icon-wrap .material-icons       { color: #7ab840; }
.mobile-nav .btn-primary .material-icons { color: rgba(255,255,255,0.95); }
/* Blog post specific */
.post-hero .material-icons               { color: rgba(255,255,255,0.85); }
.post-cat-badge .material-icons          { color: #7ab840; }
.post-meta-item .material-icons          { color: rgba(255,255,255,0.65); }
.sidebar-cta-card .material-icons        { color: rgba(255,255,255,0.90); }
.post-bottom-cta .material-icons         { color: rgba(255,255,255,0.90); }
/* Light bg contexts — keep dark/accent */
.why-card-icon .material-icons,
.credential-card-icon .material-icons   { color: var(--primary); }


/* SEO money page card patch */
.svc-dir-card{display:block;background:#fff;border:1px solid var(--gray-200,#D8E1E5);border-radius:18px;padding:24px;text-decoration:none;box-shadow:0 8px 24px rgba(2,101,134,.08);transition:all .25s ease}
.svc-dir-card:hover{transform:translateY(-3px);box-shadow:0 14px 36px rgba(2,101,134,.14)}
.svc-dir-card h3{margin:0 0 10px;color:var(--gray-900,#0D1F27);font-size:1.05rem}
.svc-dir-card p{margin:0;color:var(--gray-600,#455A64);font-size:.9rem;line-height:1.65}
.keyword-links{display:flex;flex-wrap:wrap;gap:10px;margin:22px 0}
.keyword-links a{background:#e8f6fa;border:1px solid #b3dff0;border-radius:999px;padding:9px 14px;color:#014d65;text-decoration:none;font-weight:700;font-size:.84rem}
.include-list .material-icons{font-size:1.05rem;color:#026586;margin-right:8px;vertical-align:middle}


/* =========================================================
   2026-06-18 mobile + favicon reliability patch
   Keeps the site from overflowing on phones and makes CTAs/forms tap-safe.
========================================================= */
html,body{width:100%;max-width:100%;overflow-x:hidden;}
img,svg,video,iframe,canvas{max-width:100%;height:auto;}
a,button,input,select,textarea{touch-action:manipulation;}
input,select,textarea{max-width:100%;}
.nav-wrapper,.navbar,.announcement-bar,.mobile-nav,.sticky-call-bar{max-width:100vw;}
.nav-logo,.nav-logo-text{min-width:0;}
.nav-logo-text strong,.nav-logo-text span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.mobile-nav{overscroll-behavior:contain;-webkit-overflow-scrolling:touch;}
.repair-table,.table-wrap,.content-section table{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;}
.hero-h1,.page-hero h1,.svc-hero h1,.cat-hero h1,.section-title,.cta-title{overflow-wrap:anywhere;hyphens:auto;}
@media (hover:none){.service-card:hover,.area-card:hover,.blog-card:hover,.why-card:hover{transform:none;}}
@media (max-width: 768px){
  .container,.container-wide{width:100%;padding-left:16px;padding-right:16px;}
  .nav-wrapper nav,.navbar{padding-left:14px!important;padding-right:14px!important;}
  .hero-content{width:100%;grid-template-columns:1fr!important;gap:28px!important;padding-left:16px!important;padding-right:16px!important;}
  .hero-form-card,.contact-form-wrap{width:100%;max-width:100%;padding:22px 16px!important;border-radius:18px;}
  .hero-actions,.page-hero-actions,.svc-hero-actions,.cat-hero-actions,.cta-actions{width:100%;align-items:stretch!important;}
  .hero-actions a,.page-hero-actions a,.svc-hero-actions a,.cat-hero-actions a,.cta-actions a,.form-submit,.form-submit-btn{width:100%;justify-content:center;text-align:center;}
  .form-row{grid-template-columns:1fr!important;gap:10px!important;}
  .form-group input,.form-group select,.form-group textarea{font-size:16px!important;line-height:1.35;}
  .services-grid,.why-grid,.blog-grid,.footer-grid{grid-template-columns:1fr!important;}
  .areas-grid{grid-template-columns:1fr!important;}
  .stat-chips,.stats-inner{grid-template-columns:repeat(2,minmax(0,1fr))!important;}
  .announcement-items{white-space:normal;}
  .sticky-call-bar{left:0;right:0;width:100%;}
}
@media (max-width: 420px){
  .container,.container-wide{padding-left:12px!important;padding-right:12px!important;}
  .hero-h1,.page-hero h1,.svc-hero h1,.cat-hero h1{font-size:clamp(1.45rem,8vw,1.85rem)!important;line-height:1.14!important;}
  .section-title,.cta-title{font-size:clamp(1.28rem,7vw,1.55rem)!important;}
  .stat-chips,.stats-inner{grid-template-columns:1fr!important;}
  .btn-primary,.btn-secondary,.btn-outline-dark,.btn-white,.sticky-call-btn,.sticky-quote-btn{white-space:normal!important;}
}
