/* ============================================
   KELLY HEATING NI — MAIN STYLESHEET v2
   Brand: #06233c / #0068ab / #439ad5
   Warm white: #f7f1e8 | White: #ffffff
   ============================================ */

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

:root {
  --navy:         #06233c;
  --navy-mid:     #0a3560;
  --blue:         #0068ab;
  --blue-lt:      #439ad5;
  --blue-xlt:     #d0e8f5;
  --white:        #ffffff;
  --warm-white:   #f7f1e8;
  --warm-mid:     #ede5d8;
  --whatsapp:     #25d366;
  --whatsapp-dk:  #1da851;
  --text:         #06233c;
  --text-mid:     #2c4a63;
  --text-light:   #5a7a94;
  --border:       #dde6ed;
  --border-warm:  #d9cfc2;
  --font-display: 'Barlow Condensed', 'Arial Narrow', sans-serif;
  --font-body:    'Barlow', Georgia, serif;
  --font-serif:   Georgia, 'Times New Roman', serif;
  --shadow-sm:    0 2px 8px rgba(6,35,60,.07);
  --shadow-md:    0 4px 20px rgba(6,35,60,.11);
  --shadow-lg:    0 8px 40px rgba(6,35,60,.16);
  --radius:       5px;
  --radius-lg:    10px;
  --container:    1140px;
  --header-h:     120px;
  --transition:   0.2s ease;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-body);color:var(--text);background:var(--white);line-height:1.65;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}
.container{max-width:var(--container);margin:0 auto;padding:0 24px}

h1,h2,h3,h4,h5,h6{font-family:var(--font-display);line-height:1.12;font-weight:700;color:var(--navy);letter-spacing:-.01em}
h1{font-size:clamp(2.2rem,5.5vw,3.6rem);font-weight:800}
h2{font-size:clamp(1.7rem,3.5vw,2.6rem)}
h3{font-size:clamp(1.2rem,2.5vw,1.75rem)}
h4{font-size:1.1rem;font-weight:700}
p{margin-bottom:1rem}
p:last-child{margin-bottom:0}
strong{font-weight:600}

.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 26px;border-radius:var(--radius);font-family:var(--font-display);font-size:1rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;transition:all var(--transition);white-space:nowrap;line-height:1}
.btn-primary{background:var(--blue-lt);color:var(--white)}
.btn-primary:hover{background:var(--blue);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn-navy{background:var(--navy);color:var(--white)}
.btn-navy:hover{background:var(--navy-mid);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn-outline-white{background:transparent;color:var(--white);border:2px solid rgba(255,255,255,.6)}
.btn-outline-white:hover{background:rgba(255,255,255,.12);border-color:var(--white)}
.btn-outline-navy{background:transparent;color:var(--navy);border:2px solid var(--navy)}
.btn-outline-navy:hover{background:var(--navy);color:var(--white)}
.btn-white{background:var(--white);color:var(--navy)}
.btn-white:hover{background:var(--warm-white);transform:translateY(-1px)}
.btn-whatsapp{background:var(--whatsapp);color:var(--white)}
.btn-whatsapp:hover{background:var(--whatsapp-dk);transform:translateY(-1px);box-shadow:0 4px 16px rgba(37,211,102,.35)}
.btn svg{width:17px;height:17px;flex-shrink:0}
.btn-lg{padding:16px 32px;font-size:1.05rem}
.btn-sm{padding:9px 18px;font-size:.85rem}

.mobile-cta-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:1000;background:var(--navy);border-top:3px solid var(--blue-lt)}
.mobile-cta-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;flex:1;padding:10px 6px;font-family:var(--font-display);font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--white);transition:background var(--transition)}
.mobile-cta-btn svg{width:19px;height:19px}
.mobile-cta-call{background:var(--blue-lt)}
.mobile-cta-call:hover{background:var(--blue)}
.mobile-cta-whatsapp{background:var(--whatsapp)}
.mobile-cta-whatsapp:hover{background:var(--whatsapp-dk)}
.mobile-cta-quote{background:var(--navy-mid)}
.mobile-cta-quote:hover{background:#0e4070}

.whatsapp-float{position:fixed;bottom:28px;right:24px;z-index:900;width:54px;height:54px;border-radius:50%;background:var(--whatsapp);color:var(--white);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(37,211,102,.4);transition:transform var(--transition),box-shadow var(--transition)}
.whatsapp-float:hover{transform:scale(1.1);box-shadow:0 6px 24px rgba(37,211,102,.5)}
.whatsapp-float svg{width:27px;height:27px}

.header-spacer{height:var(--header-h)}
.site-header{position:fixed;top:0;left:0;right:0;z-index:800;background:var(--white);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition)}
.site-header.scrolled{box-shadow:var(--shadow-md)}
.header-top{background:#f7f1e8;padding:6px 0;border-bottom:1px solid #d9cfc2}
.header-top .container{display:flex;justify-content:space-between;align-items:center}
.header-tagline{color:var(--text-mid);font-size:.75rem;letter-spacing:.05em;font-family:var(--font-display);font-weight:500;text-transform:uppercase}
.header-phone{display:flex;align-items:center;gap:7px;color:var(--navy);font-weight:700;font-family:var(--font-display);font-size:.95rem;letter-spacing:.03em;transition:color var(--transition)}
.header-phone svg{width:14px;height:14px;color:var(--blue)}
.header-phone:hover{color:var(--blue)}
.header-main{height:84px;display:flex;align-items:center;background:var(--white)}
.header-main-inner{display:flex;align-items:center;justify-content:space-between;width:100%}

.logo{display:flex;align-items:center;gap:10px}
.logo-img{height:72px;width:auto}
.logo-text{display:flex;flex-direction:column;line-height:1.1}
.logo-name{font-family:var(--font-display);font-size:1.2rem;font-weight:800;color:var(--navy);letter-spacing:.02em;text-transform:uppercase}
.logo-sub{font-size:.66rem;color:var(--text-light);font-weight:600;text-transform:uppercase;letter-spacing:.12em}

.main-nav{display:flex}
.nav-list{display:flex;align-items:center;gap:2px}
.nav-link{display:flex;align-items:center;gap:4px;padding:8px 12px;border-radius:var(--radius);font-family:var(--font-display);font-weight:700;font-size:.86rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-mid);transition:all var(--transition)}
.nav-link:hover{color:var(--navy);background:var(--warm-white)}
.nav-link--urgent{color:var(--blue-lt)!important}
.nav-link--urgent:hover{background:var(--blue-xlt)!important;color:var(--blue)!important}
.nav-cta{background:var(--blue-lt);color:var(--white)!important;padding:9px 18px}
.nav-cta:hover{background:var(--blue)!important;color:var(--white)!important}
.has-dropdown{position:relative}
.dropdown{display:none;position:absolute;top:100%;left:0;background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow-lg);min-width:220px;padding:8px;border:1px solid var(--border);z-index:999;padding-top:12px;margin-top:0}
.has-dropdown:hover .dropdown{display:block}
.has-dropdown:hover>.nav-link{color:var(--navy);background:var(--warm-white)}
.dropdown li a{display:block;padding:9px 13px;border-radius:var(--radius);font-size:.86rem;font-weight:700;color:var(--text-mid);font-family:var(--font-display);text-transform:uppercase;letter-spacing:.03em;transition:all var(--transition)}
.dropdown li a:hover{background:var(--warm-white);color:var(--navy)}
.nav-toggle{display:none;flex-direction:column;gap:5px;padding:8px}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--navy);transition:all var(--transition);border-radius:2px}
.nav-toggle.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.nav-toggle.active span:nth-child(2){opacity:0}
.nav-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

.hero{background:var(--navy);padding:80px 0 72px;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;opacity:.04;background-image:repeating-linear-gradient(45deg,var(--blue-lt) 0px,var(--blue-lt) 1px,transparent 1px,transparent 12px)}
.hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--blue) 0%,var(--blue-lt) 100%)}
.hero-inner{position:relative;z-index:1;display:grid;grid-template-columns:1fr 420px;gap:56px;align-items:center}
.hero-label{display:inline-flex;align-items:center;gap:7px;background:rgba(67,154,213,.18);border:1px solid rgba(67,154,213,.35);color:var(--blue-lt);padding:5px 13px;border-radius:3px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-bottom:18px;font-family:var(--font-display)}
.hero h1{color:var(--white);margin-bottom:18px}
.hero h1 span{color:var(--blue-lt)}
.hero-sub{color:rgba(255,255,255,.75);font-size:1.05rem;margin-bottom:32px;line-height:1.6}
.hero-ctas{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:36px}
.hero-trust{display:flex;flex-wrap:wrap;gap:10px}
.trust-pill{display:flex;align-items:center;gap:6px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);padding:6px 12px;border-radius:3px;color:rgba(255,255,255,.8);font-size:.75rem;font-weight:600;font-family:var(--font-display);text-transform:uppercase;letter-spacing:.05em}
.trust-pill svg{width:13px;height:13px;color:var(--blue-lt);flex-shrink:0}

.hero-panel{background:var(--warm-white);border-radius:var(--radius-lg);padding:32px;border:1px solid var(--warm-mid)}
.hero-panel h3{color:var(--navy);margin-bottom:6px;font-size:1.4rem}
.hero-panel p{color:var(--text-mid);margin-bottom:22px;font-size:.92rem}
.hero-panel .form-group{margin-bottom:13px}
.hero-panel label{display:block;color:var(--text-mid);font-size:.73rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;margin-bottom:5px;font-family:var(--font-display)}
.hero-panel input,.hero-panel select{width:100%;padding:11px 13px;border-radius:var(--radius);border:1.5px solid var(--border-warm);background:var(--white);color:var(--text);font-family:var(--font-body);font-size:.93rem;transition:border-color var(--transition)}
.hero-panel input:focus,.hero-panel select:focus{outline:none;border-color:var(--blue-lt)}
.hero-panel .btn{width:100%;justify-content:center;margin-top:6px}

.trust-bar{background:var(--blue);padding:22px 0}
.trust-bar-inner{display:flex;justify-content:center;flex-wrap:wrap;gap:36px}
.trust-bar-item{display:flex;flex-direction:column;align-items:center;gap:3px;color:var(--white)}
.trust-bar-item strong{font-family:var(--font-display);font-size:1.15rem;font-weight:800;color:var(--white);line-height:1}
.trust-bar-item span{font-size:.68rem;color:rgba(255,255,255,.65);text-transform:uppercase;letter-spacing:.1em;font-family:var(--font-display);font-weight:600}

.section{padding:80px 0}
.section-sm{padding:48px 0}
.section-navy{background:var(--navy);color:var(--white)}
.section-navy h2,.section-navy h3,.section-navy h4{color:var(--white)}
.section-warm{background:var(--warm-white)}
.section-blue-lt{background:var(--blue-xlt)}
.section-label{display:inline-flex;align-items:center;gap:6px;background:var(--blue-xlt);color:var(--blue);padding:4px 12px;border-radius:3px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px;font-family:var(--font-display)}
.section-header{text-align:center;max-width:680px;margin:0 auto 52px}
.section-header p{font-size:1.02rem;color:var(--text-mid);margin-top:12px}
.section-header.left{text-align:left;margin-left:0}

.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px}
.services-grid--six{grid-template-columns:repeat(3,1fr)}
.service-card{background:var(--white);border-radius:var(--radius-lg);border:1.5px solid var(--border);padding:30px;transition:all var(--transition);position:relative;overflow:hidden}
.service-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--blue-lt);transform:scaleX(0);transform-origin:left;transition:transform var(--transition)}
.service-card:hover{border-color:var(--blue-lt);box-shadow:var(--shadow-md);transform:translateY(-3px)}
.service-card:hover::after{transform:scaleX(1)}
.service-card--urgent{border-color:var(--blue-lt);background:linear-gradient(135deg,var(--white) 0%,var(--blue-xlt) 100%)}
.service-card--urgent::after{transform:scaleX(1)}
.service-icon{width:50px;height:50px;background:var(--blue-xlt);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.service-icon svg{width:24px;height:24px;color:var(--blue)}
.service-card h3{font-size:1.2rem;margin-bottom:8px;color:var(--navy)}
.service-card p{font-size:.9rem;color:var(--text-mid);margin-bottom:18px}
.service-link{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-display);font-weight:700;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;color:var(--blue);transition:gap var(--transition)}
.service-link:hover{gap:10px;color:var(--navy)}
.service-link svg{width:13px;height:13px}

.reviews-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}
.review-card{background:var(--white);border-radius:var(--radius-lg);padding:28px;box-shadow:var(--shadow-sm);border:1px solid var(--border)}
.review-stars{display:flex;gap:3px;margin-bottom:12px}
.review-stars svg{width:17px;height:17px;color:#f4a012}
.review-text{font-size:.9rem;color:var(--text-mid);margin-bottom:16px;font-style:italic;line-height:1.6}
.review-author{font-weight:700;font-size:.83rem;color:var(--navy);font-family:var(--font-display);text-transform:uppercase;letter-spacing:.05em}
.reviews-cta{text-align:center;margin-top:36px}

.cta-block{background:var(--navy);padding:64px 0;text-align:center}
.cta-block h2{color:var(--white);margin-bottom:12px}
.cta-block p{color:rgba(255,255,255,.75);font-size:1.02rem;margin-bottom:32px;max-width:580px;margin-left:auto;margin-right:auto}
.cta-btns{display:flex;justify-content:center;flex-wrap:wrap;gap:14px}

.cta-band{background:var(--navy);padding:36px 0;color:white}
.cta-band-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.cta-band h3{color:white !important;margin-bottom:4px}
.cta-band p{color:rgba(255,255,255,.75) !important;margin:0;font-size:.95rem}
.cta-band-btns{display:flex;gap:12px;flex-wrap:wrap;flex-shrink:0}

.areas-band{background:var(--blue);padding:36px 0}
.areas-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.areas-label{color:rgba(255,255,255,.65);font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;font-weight:700;margin-bottom:8px;font-family:var(--font-display)}
.areas-list{display:flex;flex-wrap:wrap;gap:8px}
.area-tag{background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.25);color:var(--white);padding:5px 14px;border-radius:3px;font-size:.8rem;font-weight:700;font-family:var(--font-display);text-transform:uppercase;letter-spacing:.05em}

.why-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:32px}
.why-item{text-align:center}
.why-icon{width:62px;height:62px;background:var(--blue-xlt);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.why-icon svg{width:28px;height:28px;color:var(--blue)}
.why-item h4{margin-bottom:8px;color:var(--navy)}
.why-item p{font-size:.9rem;color:var(--text-mid)}

.page-hero{background:var(--navy);padding:56px 0;position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;opacity:.04;background-image:repeating-linear-gradient(45deg,var(--blue-lt) 0px,var(--blue-lt) 1px,transparent 1px,transparent 12px)}
.page-hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--blue) 0%,var(--blue-lt) 100%)}
.page-hero-inner{position:relative;z-index:1}
.page-hero .breadcrumb{display:flex;gap:8px;align-items:center;color:rgba(255,255,255,.4);font-size:.75rem;margin-bottom:16px;font-family:var(--font-display);text-transform:uppercase;letter-spacing:.06em}
.page-hero .breadcrumb a{color:rgba(255,255,255,.4);transition:color var(--transition)}
.page-hero .breadcrumb a:hover{color:var(--blue-lt)}
.page-hero .breadcrumb span{color:rgba(255,255,255,.25)}
.page-hero h1{color:var(--white);margin-bottom:14px}
.page-hero p{color:rgba(255,255,255,.75);font-size:1.02rem;max-width:640px;margin-bottom:24px}
.page-hero-ctas{display:flex;flex-wrap:wrap;gap:12px}
.page-hero--urgent{background:linear-gradient(135deg,#04182a 0%,var(--navy) 60%,#0a3560 100%)}

.content-layout{display:grid;grid-template-columns:1fr 340px;gap:52px;align-items:start}
.aside-card{background:var(--white);border-radius:var(--radius-lg);border:1.5px solid var(--border);padding:26px}
.aside-card+.aside-card{margin-top:18px}
.aside-card h4{margin-bottom:16px;padding-bottom:12px;border-bottom:2px solid var(--warm-white);color:var(--navy);font-size:1rem}
.aside-card .btn{width:100%;justify-content:center;margin-bottom:9px}
.aside-links{display:flex;flex-direction:column;gap:6px}
.aside-links a{display:flex;align-items:center;gap:8px;padding:9px 12px;border-radius:var(--radius);background:var(--warm-white);font-size:.84rem;font-weight:700;color:var(--text-mid);font-family:var(--font-display);text-transform:uppercase;letter-spacing:.03em;transition:all var(--transition)}
.aside-links a:hover{background:var(--blue-xlt);color:var(--navy)}
.aside-links a svg{width:13px;height:13px;color:var(--blue-lt);flex-shrink:0}
.aside-phone{text-align:center;padding:20px;background:var(--navy);border-radius:var(--radius-lg);color:var(--white);margin-top:18px}
.aside-phone a{display:block;font-family:var(--font-display);font-size:1.4rem;font-weight:800;color:var(--blue-lt);margin-top:6px}

.content-body h2{margin:40px 0 14px;padding-top:8px;border-top:1px solid var(--border)}
.content-body h2:first-child{margin-top:0;border-top:none}
.content-body h3{margin:26px 0 10px;color:var(--navy)}
.content-body p{color:var(--text-mid);margin-bottom:1rem}
.content-body ul,.content-body ol{padding-left:20px;margin-bottom:1rem}
.content-body li{color:var(--text-mid);margin-bottom:6px}
.content-body ul li{list-style:disc}
.content-body ol li{list-style:decimal}

.check-list{list-style:none!important;padding-left:0!important}
.check-list li{padding-left:26px;position:relative;margin-bottom:9px;color:var(--text-mid);font-size:.94rem}
.check-list li::before{content:'';position:absolute;left:0;top:5px;width:15px;height:15px;background:url("data:image/svg+xml,%3Csvg viewBox='0 0 16 16' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='8' cy='8' r='8' fill='%23439ad5'/%3E%3Cpath d='M4.5 8l2.5 2.5 4.5-5' stroke='white' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat center/contain}

.process-steps{display:flex;flex-direction:column;gap:18px;margin:22px 0}
.process-step{display:flex;gap:18px;align-items:flex-start}
.step-num{width:38px;height:38px;border-radius:50%;background:var(--blue-lt);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:.95rem;font-weight:800;color:var(--white);flex-shrink:0}
.step-content h4{margin-bottom:3px;font-size:1rem}
.step-content p{font-size:.9rem;color:var(--text-mid);margin:0}

.faq-list{display:flex;flex-direction:column;gap:2px}
.faq-item{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;padding:16px 18px;background:var(--white);text-align:left;font-family:var(--font-display);font-size:.98rem;font-weight:700;color:var(--navy);transition:background var(--transition)}
.faq-question:hover{background:var(--warm-white)}
.faq-question.active{background:var(--navy);color:var(--white)}
.faq-question svg{width:18px;height:18px;flex-shrink:0;transition:transform var(--transition);color:var(--blue-lt)}
.faq-question.active svg{transform:rotate(180deg)}
.faq-answer{display:none;padding:0 18px 16px;background:var(--white)}
.faq-answer p{color:var(--text-mid);font-size:.91rem;margin-top:10px}

.contact-form{background:var(--white);border-radius:var(--radius-lg);padding:36px;box-shadow:var(--shadow-sm);border:1.5px solid var(--border)}
.contact-form h3{margin-bottom:6px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-group{margin-bottom:14px}
.form-group label{display:block;font-weight:700;font-size:.73rem;text-transform:uppercase;letter-spacing:.07em;color:var(--text-mid);margin-bottom:5px;font-family:var(--font-display)}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 14px;border-radius:var(--radius);border:1.5px solid var(--border);font-family:var(--font-body);font-size:.93rem;color:var(--text);background:var(--white);transition:border-color var(--transition)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--blue-lt)}
.form-group textarea{resize:vertical;min-height:100px}
.form-group .required{color:var(--blue-lt);margin-left:2px}
.hp-field{display:none!important}
.divider{border:none;border-top:1px solid var(--border);margin:36px 0}

.site-footer{background:var(--navy);color:var(--white)}
.footer-main{padding:60px 0 44px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px}
.footer-logo{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.footer-logo-img{height:70px;width:auto}
.footer-tagline{color:rgba(255,255,255,.55);font-size:.88rem;margin-bottom:22px;line-height:1.6;font-style:italic;font-family:var(--font-serif)}
.footer-badges{display:flex;flex-direction:column;gap:8px}
.badge-item{display:flex;align-items:center;gap:8px}
.badge-item strong{color:var(--blue-lt);font-size:.8rem;font-weight:700;min-width:70px;font-family:var(--font-display);text-transform:uppercase;letter-spacing:.04em}
.badge-item span{color:rgba(255,255,255,0.8);font-size:.76rem}
.footer-heading{font-family:var(--font-display);font-size:.88rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.85);margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer-links{display:flex;flex-direction:column;gap:8px}
.footer-links a{color:rgba(255,255,255,0.8);font-size:.84rem;transition:color var(--transition)}
.footer-links a:hover{color:var(--blue-lt)}
.footer-area-note{color:rgba(255,255,255,0.8);font-size:.74rem;margin-top:12px;line-height:1.5}
.footer-contact-items{display:flex;flex-direction:column;gap:10px;margin-bottom:18px}
.footer-contact-item{display:flex;align-items:center;gap:10px;color:rgba(255,255,255,.65);font-size:.84rem;transition:color var(--transition)}
.footer-contact-item:hover{color:var(--white)}
.footer-contact-item svg{width:15px;height:15px;color:var(--blue-lt);flex-shrink:0}
.footer-hours{color:rgba(255,255,255,.45);font-size:.78rem;line-height:1.8}
.footer-hours strong{color:rgba(255,255,255,.65)}
.footer-hours em{font-style:italic}
.footer-bottom{background:rgba(0,0,0,.25);padding:14px 0}
.footer-bottom-inner{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.footer-bottom p,.footer-bottom a{color:rgba(255,255,255,.3);font-size:.74rem;margin:0}
.footer-bottom a:hover{color:var(--blue-lt)}

.text-center{text-align:center}
.text-blue{color:var(--blue-lt)}
.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mt-32{margin-top:32px}.mb-0{margin-bottom:0}

.fade-up{opacity:0;transform:translateY(22px);transition:opacity .5s ease,transform .5s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}

@media(max-width:1024px){
  .footer-grid{grid-template-columns:1fr 1fr}
  .content-layout{grid-template-columns:1fr}
  .content-aside{display:none}
  .hero-inner{grid-template-columns:1fr}
  .hero-panel{display:none}
}
@media(max-width:768px){
  :root{--header-h:60px}
  .header-top{display:none}
  .header-main{height:var(--header-h)}
  .logo-img{height:44px}
  .logo-name{font-size:1rem}
  .nav-toggle{display:flex}
  .main-nav{display:none;position:absolute;top:100%;left:0;right:0;background:var(--white);box-shadow:var(--shadow-lg);padding:12px;border-top:3px solid var(--blue-lt)}
  .main-nav.open{display:block}
  .nav-list{flex-direction:column;gap:3px}
  .nav-link{width:100%;padding:12px 14px;font-size:.95rem}
  .dropdown{position:static;box-shadow:none;border:none;background:var(--warm-white);margin-top:3px;display:none}
  .has-dropdown:hover .dropdown{display:none}
  .has-dropdown.open .dropdown{display:block}
  .mobile-cta-bar{display:flex}
  .whatsapp-float{display:none}
  .site-footer{margin-bottom:60px}
  .hero{padding:44px 0}
  .section{padding:52px 0}
  .footer-grid{grid-template-columns:1fr;gap:28px}
  .form-row{grid-template-columns:1fr}
  .cta-band-inner,.areas-inner{flex-direction:column;align-items:flex-start}
  .hero-ctas,.page-hero-ctas{flex-direction:column}
  .hero-ctas .btn,.page-hero-ctas .btn{width:100%;justify-content:center}
  .trust-bar-inner{gap:18px}
  /* Collapse all inline 2-col grids on mobile */
  [style*="grid-template-columns:1fr 1fr"],[style*="grid-template-columns:1fr 2fr"],[style*="grid-template-columns:2fr 1fr"],[style*="grid-template-columns:repeat(2"]{grid-template-columns:1fr !important}
  .services-grid--six{grid-template-columns:1fr 1fr !important}
  .process-steps{gap:16px}
  .why-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:480px){
  .container{padding:0 16px}
  h1{font-size:1.9rem}
  h2{font-size:1.55rem}
  .services-grid{grid-template-columns:1fr}
  .services-grid--six{grid-template-columns:1fr !important}
  [style*="grid-template-columns:1fr 1fr"],[style*="grid-template-columns:repeat(2"]{grid-template-columns:1fr !important}
  .why-grid{grid-template-columns:1fr}
}

/* =============================================
   DROPDOWN — heading labels, dividers, hover fix
   ============================================= */

/* Bridge gap between nav-link and dropdown so
   mouse movement from trigger to panel doesn't
   close the menu */
.has-dropdown::after {
  content: '';
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  height: 12px; /* covers the gap */
  background: transparent;
}

/* Section headings inside dropdown */
.dropdown-heading {
  display: block;
  padding: 6px 14px 4px;
  font-family: var(--font-display);
  font-size: .68rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--text-light);
  pointer-events: none;
  margin-top: 4px;
}
.dropdown-heading:first-child { margin-top: 0; }

/* Divider line between dropdown sections */
.dropdown-divider {
  border: none;
  border-top: 1px solid var(--border);
  margin: 6px 8px;
  display: block;
}

/* Wider dropdown for boiler installation (more links) */
.has-dropdown:first-child .dropdown {
  min-width: 260px;
}

/* =============================================
   HEADER — 120px total desktop/tablet depth
   top-bar ~36px + header-main 84px = 120px
   ============================================= */
@media (min-width: 769px) {
  :root { --header-h: 136px; }
  .header-main { height: 100px; }
  .logo-img { height: 88px; }
}

/* Tablet (769–1024px) — keep 120px */
@media (max-width: 1024px) and (min-width: 769px) {
  :root { --header-h: 136px; }
  .header-main { height: 100px; }
  .logo-img { height: 80px; }
  /* Tighten nav spacing slightly on tablet */
  .nav-link { padding: 7px 9px; font-size: .8rem; }
  .nav-cta  { padding: 8px 14px; }
}
