*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --blue:#1a56db;--blue-dark:#1741b0;--blue-light:#eff6ff;
  --orange:#F45800;--orange-dark:#d94d00;--orange-light:#fff4ef;
  --black:#0a0a0a;--white:#fff;
  --gray-light:#f4f5f7;--gray-mid:#e5e7eb;--gray-text:#6b7280;
  --green:#22c55e;--green-light:#f0fdf4;--green-border:#86efac;--green-text:#15803d;
  --navy:#0f1c3f;--navy-mid:#162245;
  --gold:#f59e0b;--radius:20px;--font:'Manrope',sans-serif;
}
html{scroll-behavior:smooth;scroll-padding-top:64px}
body{font-family:var(--font);color:var(--black);background:var(--white);overflow-x:hidden}

/* ── LOGO ── */
.logo-mark{display:inline-flex;align-items:center;text-decoration:none;flex-shrink:0}
.logo-img{height:36px;width:auto;display:block}
@media(min-width:768px){.logo-img{height:46px}}

/* ── NAV ── */
nav{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.95);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid rgba(0,0,0,.07);padding:14px 24px;display:flex;justify-content:space-between;align-items:center;gap:16px}
.nav-left{display:flex;align-items:center;gap:14px;flex:1}
.nav-slogan{display:none;font-size:12px;font-weight:600;color:var(--gray-text);line-height:1.35;border-left:2px solid var(--orange);padding-left:12px}
.nav-slogan strong{display:block;font-size:11px;font-weight:800;color:var(--orange);text-transform:uppercase;letter-spacing:.6px}
.nav-hamburger{display:flex;flex-direction:column;gap:5px;cursor:pointer;padding:4px;flex-shrink:0}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--black);border-radius:2px;transition:all .3s ease}
.nav-links{display:none}

/* ── WHATSAPP WIDGET ── */
.whatsapp-widget{position:fixed;bottom:24px;right:24px;z-index:999;display:flex;flex-direction:column;align-items:flex-end;gap:10px}
.whatsapp-btn{width:58px;height:58px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(37,211,102,.45);text-decoration:none;transition:transform .2s,box-shadow .2s;animation:waPulse 2.5s ease-in-out infinite}
.whatsapp-btn:hover{transform:scale(1.1);box-shadow:0 8px 30px rgba(37,211,102,.55);animation:none}
.whatsapp-btn svg{width:30px;height:30px;fill:white}
.whatsapp-tooltip{background:var(--black);color:white;font-size:13px;font-weight:700;padding:8px 14px;border-radius:10px;white-space:nowrap;opacity:0;transform:translateX(8px);transition:opacity .2s,transform .2s;pointer-events:none;font-family:var(--font)}
.whatsapp-tooltip::after{content:'';position:absolute;right:-6px;top:50%;transform:translateY(-50%);border:6px solid transparent;border-right:none;border-left-color:var(--black)}
.whatsapp-widget:hover .whatsapp-tooltip{opacity:1;transform:translateX(0)}
@keyframes waPulse{0%,100%{box-shadow:0 4px 20px rgba(37,211,102,.45)}50%{box-shadow:0 4px 32px rgba(37,211,102,.7),0 0 0 10px rgba(37,211,102,.1)}}

/* ── MOBILE MENU ── */
.mobile-menu{display:none;position:fixed;inset:0;background:white;z-index:200;flex-direction:column;padding:24px;animation:fadeUp .25s ease both}
.mobile-menu.open{display:flex}
.mobile-menu-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:40px}
.mobile-menu-close{font-size:24px;cursor:pointer;color:var(--black);background:none;border:none;font-family:var(--font);line-height:1}
.mobile-menu a{font-size:26px;font-weight:800;text-decoration:none;color:var(--black);padding:16px 0;border-bottom:1px solid var(--gray-mid);letter-spacing:-.5px}
.mobile-menu .cta-link{margin-top:32px;border-bottom:none;font-size:18px}

/* ── STICKY BOTTOM CTA ── */
.sticky-cta{position:fixed;bottom:0;left:0;right:0;z-index:90;background:white;border-top:1.5px solid var(--gray-mid);padding:12px 24px 22px;box-shadow:0 -4px 20px rgba(0,0,0,.08);transform:translateY(100%);transition:transform .4s ease}
.sticky-cta.visible{transform:translateY(0)}
.sticky-cta .btn-primary{width:100%;padding:16px 20px;font-size:15px}

/* ── HERO ── */
.hero{animation:fadeUp .7s ease both;display:block;position:relative;overflow:hidden;background:var(--navy);min-height:520px}
.hero-bg-map{position:absolute;inset:0;z-index:0;pointer-events:none}
.hero-bg-map img{width:100%;height:100%;object-fit:cover;object-position:center}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(100deg,rgba(10,20,50,.88) 0%,rgba(10,20,50,.72) 50%,rgba(10,20,50,.55) 100%);z-index:1}
.hero-inner{position:relative;z-index:2;display:flex;flex-direction:column;gap:0}
.hero-content{padding:40px 24px 28px;position:relative;z-index:2}
.hero h1{font-size:36px;font-weight:900;line-height:1.1;letter-spacing:-1.2px;color:white}
.hero h1 .accent{color:var(--orange)}
.hero-sub{font-size:16px;color:rgba(255,255,255,.8);line-height:1.6;margin:18px 0 24px;font-weight:500}
.hero-checks{display:grid;grid-template-columns:1fr 1fr;gap:10px 12px;margin-bottom:32px}
.hero-checks span{font-size:14px;font-weight:700;color:rgba(255,255,255,.9);display:flex;align-items:center;gap:6px}
.hero-checks span::before{content:'✓';font-size:15px;font-weight:900;color:var(--orange)}
.hero-coverage{padding:0 24px 48px;position:relative;z-index:2}

/* ── BUTTONS ── */
.btn-primary{display:inline-flex;align-items:center;justify-content:center;background:var(--orange);color:white;border:none;border-radius:50px;padding:18px 32px;font-size:16px;font-weight:700;font-family:var(--font);cursor:pointer;text-decoration:none;transition:background .2s,transform .15s,box-shadow .2s;box-shadow:0 4px 20px rgba(244,88,0,.28)}
.btn-primary:hover{background:var(--orange-dark);transform:translateY(-2px);box-shadow:0 8px 30px rgba(244,88,0,.38)}
.btn-primary:active{transform:translateY(0)}
.btn-secondary{display:inline-flex;align-items:center;justify-content:center;background:transparent;color:var(--gray-text);border:none;border-radius:50px;padding:18px 32px;font-size:15px;font-weight:600;font-family:var(--font);cursor:pointer;text-decoration:none;transition:color .2s}
.btn-secondary:hover{color:var(--black)}
.btn-white{display:inline-flex;align-items:center;justify-content:center;background:white;color:var(--black);border:none;border-radius:50px;padding:18px 32px;font-size:16px;font-weight:700;font-family:var(--font);cursor:pointer;text-decoration:none;transition:background .2s,transform .15s;width:100%}
.btn-white:hover{background:#f0f0f0;transform:translateY(-1px)}

/* ── COVERAGE BOX ── */
.coverage-box{background:var(--gray-light);border-radius:var(--radius);padding:22px;position:relative}
.coverage-input-row{display:flex;gap:10px;margin-bottom:14px}
.coverage-input-row input{flex:1;padding:15px 16px;border:2px solid transparent;border-radius:14px;background:white;font-size:15px;font-family:var(--font);color:var(--black);outline:none;box-shadow:0 1px 4px rgba(0,0,0,.06);transition:border-color .2s}
.coverage-input-row input::placeholder{color:#9ca3af}
.coverage-input-row input:focus{border-color:var(--orange)}
.coverage-input-row input.error{border-color:#f87171;animation:shake .35s ease}
@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}
.coverage-input-row button{background:var(--orange);color:white;border:none;border-radius:14px;padding:0 22px;font-size:14px;font-weight:800;font-family:var(--font);cursor:pointer;letter-spacing:.5px;transition:background .2s,transform .15s}
.coverage-input-row button:hover{background:var(--orange-dark);transform:scale(1.03)}

/* Coverage result card */
.coverage-result-card{display:none;flex-direction:column;align-items:center;text-align:center;padding:32px 24px 24px;background:white;border-radius:18px;box-shadow:0 4px 30px rgba(0,0,0,.10);margin-top:12px}
.coverage-result-card.show{display:flex;animation:popIn .45s cubic-bezier(.175,.885,.32,1.275) both}
@keyframes popIn{from{opacity:0;transform:scale(.88)}to{opacity:1;transform:scale(1)}}
.result-tick-big{width:56px;height:56px;background:var(--green);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 18px;flex-shrink:0;box-shadow:0 4px 16px rgba(34,197,94,.3)}
.result-tick-big svg{width:26px;height:26px;stroke:white;fill:none;stroke-width:3;stroke-linecap:round;stroke-linejoin:round}
.result-headline{font-size:17px;font-weight:800;color:var(--black);margin-bottom:6px;line-height:1.35}
.result-postcode-big{font-size:26px;font-weight:900;color:var(--orange);letter-spacing:1px;margin-bottom:12px}
.result-guarantee{font-size:14px;color:var(--gray-text);font-weight:500;margin-bottom:22px}
.result-actions{display:flex;align-items:center;gap:16px;width:100%;flex-direction:column}
.result-actions .btn-primary{width:100%;padding:15px 24px;font-size:15px;font-weight:800}
.result-recheck{font-size:14px;color:var(--gray-text);cursor:pointer;font-weight:600;text-decoration:underline;background:none;border:none;font-family:var(--font)}
.result-recheck:hover{color:var(--black)}

.coverage-bullets{display:flex;flex-wrap:wrap;gap:6px 16px;margin-bottom:10px}
.coverage-bullets span{font-size:13px;font-weight:600;color:var(--blue);display:flex;align-items:center;gap:5px}
.coverage-bullets span::before{content:'●';font-size:8px}
.coverage-note{font-size:13px;color:var(--gray-text);line-height:1.5;font-weight:500}

/* ── SECTION HEADING ── */
.section-heading{font-size:28px;font-weight:900;line-height:1.1;letter-spacing:-.8px;text-align:center;padding:48px 24px 32px}

/* ── HOW IT WORKS ── */
.steps-section{padding:0 24px 60px}
.step-card{background:white;border:1.5px solid var(--gray-mid);border-radius:var(--radius);padding:36px 24px;margin-bottom:16px;text-align:center;opacity:0;transform:translateY(30px);transition:opacity .55s ease,transform .55s ease,box-shadow .2s}
.step-card:hover{box-shadow:0 8px 32px rgba(0,0,0,.07)}
.step-card.visible{opacity:1;transform:translateY(0)}
.step-number{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--orange);color:white;border-radius:50%;font-size:12px;font-weight:900;margin-bottom:16px}
.step-icon{width:72px;height:72px;background:var(--orange-light);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px}
.step-icon svg{width:30px;height:30px;fill:none;stroke:var(--orange);stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.step-card h3{font-size:22px;font-weight:800;margin-bottom:10px;letter-spacing:-.5px}
.step-card p{font-size:15px;color:var(--gray-text);line-height:1.6;font-weight:500}

/* ── LIFESTYLE SECTION ── */
.lifestyle-section{padding:0 24px 64px;background:var(--white)}
.lifestyle-heading{font-size:26px;font-weight:900;letter-spacing:-.6px;line-height:1.15;text-align:center;margin-bottom:8px}
.lifestyle-sub{font-size:15px;color:var(--gray-text);text-align:center;margin-bottom:36px;font-weight:500}
.lifestyle-grid{display:grid;grid-template-columns:1fr;gap:20px}
.lifestyle-card{border-radius:22px;overflow:hidden;position:relative;height:260px;display:flex;align-items:flex-end;opacity:0;transform:translateY(28px);transition:opacity .55s ease,transform .55s ease;background-size:cover;background-position:center;background-repeat:no-repeat}
.lifestyle-card:hover{transform:translateY(-4px) scale(1.01)}
.lifestyle-card.visible{opacity:1;transform:translateY(0)}
.lifestyle-card.visible:hover{transform:translateY(-4px) scale(1.01)}
.lifestyle-card-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.05) 0%,rgba(0,0,0,.55) 70%,rgba(0,0,0,.75) 100%)}
.lifestyle-label{position:relative;z-index:2;padding:22px 24px;width:100%;color:white}
.lifestyle-label strong{font-size:17px;font-weight:800;display:block;letter-spacing:-.3px;margin-bottom:4px;text-shadow:0 1px 4px rgba(0,0,0,.4)}
.lifestyle-label span{font-size:13px;opacity:.85;font-weight:500;text-shadow:0 1px 3px rgba(0,0,0,.3)}
.lifestyle-pill{display:inline-flex;align-items:center;gap:5px;background:var(--orange);color:white;font-size:11px;font-weight:800;padding:4px 10px;border-radius:50px;margin-bottom:8px;letter-spacing:.3px;text-transform:uppercase}

/* ── PLANS ── */
.plans-section{background:var(--gray-light);padding:60px 24px;position:relative;overflow:hidden}
.plans-section::before{content:'';position:absolute;top:0;left:-30%;width:160%;height:220px;background:linear-gradient(180deg,rgba(244,88,0,.06) 0%,transparent 100%);pointer-events:none}
.plans-section .section-heading{padding-top:0}
.uk-delivery-badge{display:inline-flex;align-items:center;gap:6px;background:var(--orange-light);border:1px solid rgba(244,88,0,.2);color:var(--orange);font-size:13px;font-weight:700;padding:7px 16px;border-radius:50px;margin-bottom:20px}
.plans-explainer{font-size:15px;line-height:1.75;color:#444;font-weight:500;background:white;border-radius:var(--radius);padding:22px 24px;margin-bottom:24px;border:1.5px solid var(--gray-mid)}
.plan-card{background:white;border:1.5px solid var(--gray-mid);border-radius:var(--radius);padding:28px;margin-bottom:16px;opacity:0;transform:translateY(30px);transition:opacity .55s ease,transform .55s ease,box-shadow .2s}
.plan-card:hover{box-shadow:0 12px 40px rgba(0,0,0,.1)}
.plan-card.visible{opacity:1;transform:translateY(0)}
.plan-card.featured{background:var(--navy);border-color:var(--navy);color:white}
.plan-badge{display:inline-block;font-size:11px;font-weight:800;background:var(--orange);color:white;padding:3px 10px;border-radius:50px;letter-spacing:.5px;margin-bottom:10px;text-transform:uppercase}
.plan-label{font-size:13px;font-weight:700;color:var(--gray-text);margin-bottom:6px}
.plan-card.featured .plan-label{color:rgba(255,255,255,.55)}
.plan-was{font-size:14px;color:var(--gray-text);text-decoration:line-through;margin-bottom:2px;font-weight:600;height:20px}
.plan-card.featured .plan-was{color:rgba(255,255,255,.4)}
.plan-price{font-size:38px;font-weight:900;color:var(--orange);letter-spacing:-1.5px;margin-bottom:4px;line-height:1}
.plan-card.featured .plan-price{color:white}
.plan-name{font-size:14px;font-weight:700;color:var(--black);margin-bottom:2px}
.plan-card.featured .plan-name{color:rgba(255,255,255,.9)}
.plan-speed{font-size:14px;color:var(--gray-text);font-weight:600;margin-bottom:20px}
.plan-card.featured .plan-speed{color:rgba(255,255,255,.55)}
.plan-divider{height:1px;background:var(--gray-mid);margin-bottom:20px}
.plan-card.featured .plan-divider{background:rgba(255,255,255,.15)}
.plan-features{list-style:none;margin-bottom:28px}
.plan-features li{font-size:15px;font-weight:600;padding:9px 0;display:flex;align-items:center;gap:10px;color:#1a1a1a}
.plan-card.featured .plan-features li{color:white}
.plan-features li::before{content:'';width:20px;height:20px;border:2px solid var(--gray-mid);border-radius:50%;flex-shrink:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23F45800' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center;background-size:11px}
.plan-card.featured .plan-features li::before{border-color:rgba(255,255,255,.25);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E")}
.plan-cta-orange{display:inline-flex;align-items:center;justify-content:center;width:100%;background:var(--orange);color:white;border:none;border-radius:50px;padding:16px 24px;font-size:15px;font-weight:800;font-family:var(--font);cursor:pointer;text-decoration:none;transition:background .2s,transform .15s,box-shadow .2s;box-shadow:0 4px 16px rgba(244,88,0,.25)}
.plan-cta-orange:hover{background:var(--orange-dark);transform:translateY(-1px)}

/* "Powered by" badge */
.powered-by-strip{margin-top:36px;display:flex;justify-content:center}
.powered-by-inner{display:inline-flex;align-items:center;gap:20px;flex-wrap:wrap;justify-content:center}
.powered-by-badge{display:inline-flex;align-items:center;gap:10px;background:white;border:1.5px solid var(--gray-mid);border-radius:14px;padding:12px 18px;flex-shrink:0}
.powered-by-desc{font-size:13px;color:var(--gray-text);font-weight:500;line-height:1.5;max-width:340px}
.powered-by-text{font-size:13px;color:var(--gray-text);font-weight:600;margin-right:8px}
.powered-by-divider{width:1px;height:24px;background:var(--gray-mid);margin:0 4px}

/* ── WHY SECTION ── */
.why-section{background:var(--navy);color:white;padding:64px 24px;position:relative;overflow:hidden}
.why-section::before{content:'';position:absolute;top:-100px;right:-80px;width:350px;height:350px;background:rgba(244,88,0,.06);border-radius:50%;pointer-events:none}
.why-section::after{content:'';position:absolute;bottom:-80px;left:-60px;width:250px;height:250px;background:rgba(244,88,0,.04);border-radius:50%;pointer-events:none}
.why-section .section-heading{color:white;text-align:center;padding:0 0 36px;font-size:28px}
.why-item{margin-bottom:40px;opacity:0;transform:translateY(22px);transition:opacity .55s ease,transform .55s ease;text-align:center;display:flex;flex-direction:column;align-items:center}
.why-item.visible{opacity:1;transform:translateY(0)}
.why-icon{width:48px;height:48px;background:rgba(244,88,0,.15);border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:14px;flex-shrink:0}
.why-icon svg{width:22px;height:22px;fill:none;stroke:var(--orange);stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.why-item h3{font-size:20px;font-weight:800;margin-bottom:8px;letter-spacing:-.3px}
.why-item p{font-size:15px;color:rgba(255,255,255,.62);line-height:1.6;font-weight:500;text-align:center}

/* ── TESTIMONIALS ── */
.testimonials-section{padding:64px 0 48px;background:white}
.testimonials-section .section-heading{padding:0 24px 36px}
.testimonials-track-wrapper{overflow:hidden;padding:6px 0 24px}
.testimonials-track{display:flex;gap:16px;padding:6px 24px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;scroll-padding-left:24px}
.testimonials-track::-webkit-scrollbar{display:none}
.testimonial-card{min-width:290px;max-width:290px;background:white;border:1.5px solid var(--gray-mid);border-radius:var(--radius);padding:22px;scroll-snap-align:start;flex-shrink:0;opacity:0;transform:translateY(20px);transition:opacity .55s ease,transform .55s ease,box-shadow .2s}
.testimonial-card:hover{box-shadow:0 8px 28px rgba(0,0,0,.08)}
.testimonial-card.visible{opacity:1;transform:translateY(0)}
.testimonial-header{display:flex;align-items:center;gap:12px;margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid var(--gray-mid)}
.testimonial-avatar{width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:900;color:white;font-size:15px;flex-shrink:0}
.testimonial-name{font-size:15px;font-weight:800;color:var(--blue);margin-bottom:2px}
.stars{color:var(--gold);font-size:12px;letter-spacing:1px}
.testimonial-card blockquote{font-size:14px;color:#3a3a3a;line-height:1.65;font-style:italic;font-weight:500}
.testimonial-dots{display:flex;justify-content:center;gap:8px;margin-top:20px}
.testimonial-dots span{width:8px;height:8px;border-radius:50%;background:var(--gray-mid);transition:background .3s,transform .3s;cursor:pointer}
.testimonial-dots span.active{background:var(--orange);transform:scale(1.3)}

/* ── FAQ ── */
.faq-section{padding:64px 24px}
.faq-header{margin-bottom:40px}
.faq-header h2{font-size:32px;font-weight:900;letter-spacing:-1px;line-height:1.1;margin-bottom:16px}
.faq-item{border-bottom:1.5px solid var(--gray-mid);padding:20px 0}
.faq-question{display:flex;justify-content:space-between;align-items:center;cursor:pointer;gap:16px}
.faq-question h4{font-size:16px;font-weight:700;line-height:1.4;letter-spacing:-.2px}
.faq-toggle{width:28px;height:28px;border-radius:50%;border:2px solid var(--orange);color:var(--orange);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:20px;font-weight:300;transition:transform .3s ease,background .2s;cursor:pointer;background:none;font-family:var(--font);line-height:1}
.faq-item.open .faq-toggle{transform:rotate(45deg);background:var(--orange);color:white}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .38s ease}
.faq-answer p{font-size:15px;color:var(--gray-text);line-height:1.65;padding-top:14px;font-weight:500}

/* ── FOOTER ── */
footer{background:var(--navy);color:white;padding:56px 24px 40px}
.footer-inner{max-width:1100px;margin:0 auto;display:flex;flex-direction:column;gap:40px}
.footer-left-col{}
.logo-footer{filter:brightness(0) invert(1);opacity:.85}
.footer-brand{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.footer-tagline{font-size:14px;color:rgba(255,255,255,.5);font-weight:500;margin-bottom:32px;line-height:1.6;max-width:320px}
.footer-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px 24px;margin-bottom:40px}
.footer-col h5{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:1.2px;color:rgba(255,255,255,.4);margin-bottom:14px}
.footer-col a{display:block;font-size:14px;font-weight:600;color:rgba(255,255,255,.7);text-decoration:none;margin-bottom:10px;transition:color .2s}
.footer-col a:hover{color:var(--orange)}
.footer-divider{border:none;border-top:1px solid rgba(255,255,255,.1);margin:0 0 28px}
.footer-bottom{display:flex;flex-direction:column;gap:16px}
.powered-by-footer{display:inline-flex;align-items:center;gap:10px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:10px 16px;align-self:flex-start}
.powered-by-footer span{font-size:12px;font-weight:600;color:rgba(255,255,255,.5)}
.footer-legal{font-size:12px;color:rgba(255,255,255,.3);line-height:1.6}
.footer-legal a{color:rgba(255,255,255,.45);text-decoration:none}
.footer-legal a:hover{color:rgba(255,255,255,.8)}
.footer-trust-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}
.footer-trust-pill{display:inline-flex;align-items:center;gap:5px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:50px;padding:6px 12px;font-size:12px;font-weight:600;color:rgba(255,255,255,.55)}
.footer-trust-pill::before{content:'✓';color:var(--green);font-weight:900;font-size:11px}
.footer-phone{display:inline-flex;align-items:center;gap:8px;background:var(--orange);color:white;border-radius:12px;padding:12px 18px;font-size:14px;font-weight:700;text-decoration:none;margin-bottom:20px;transition:background .2s}
.footer-phone:hover{background:var(--orange-dark)}
.footer-phone svg{width:16px;height:16px;fill:none;stroke:white;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* ── ANIMATIONS ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}

/* ── MOBILE IMPROVEMENTS ── */
@media(max-width:767px){
  .plans-explainer{font-size:14px;line-height:1.65}
  .hero-overlay{background:linear-gradient(180deg,rgba(10,20,50,.75) 0%,rgba(10,20,50,.55) 50%,rgba(10,20,50,.70) 100%)}
  .hero-bg-map img{object-position:center center}
  .hero-sub{font-size:15px}
  .coverage-box{border-radius:16px;padding:18px}
  .step-card{padding:28px 20px}
  .plan-card{padding:22px 20px}
  .why-section{padding:48px 20px}
  .lifestyle-section{padding:0 20px 48px}
  .steps-section{padding:0 20px 48px}
  .faq-section{padding:48px 20px}
  .testimonials-section{padding:48px 0 36px}
  .footer-phone{font-size:13px;padding:10px 14px}
}

/* ── MOBILE NAV PILL ── */
.nav-action-btn{display:inline-flex;align-items:center;background:var(--orange);color:white;border:none;border-radius:50px;padding:9px 16px;font-size:13px;font-weight:800;font-family:var(--font);cursor:pointer;text-decoration:none;white-space:nowrap;box-shadow:0 2px 10px rgba(244,88,0,.28);transition:background .2s}
.nav-action-btn:hover{background:var(--orange-dark)}

/* ════════════════════════
   DESKTOP — 768px+
════════════════════════ */
.container{width:100%;max-width:1100px;margin:0 auto;padding:0 48px}

@media(min-width:768px){
  nav{padding:16px 48px}
  .nav-slogan{display:block}
  .nav-hamburger{display:none}
  .nav-links{display:flex;align-items:center;gap:32px}
  .nav-links a{font-size:14px;font-weight:700;color:var(--black);text-decoration:none;opacity:.7;transition:opacity .2s}
  .nav-links a:hover{opacity:1}
  .nav-links .nav-cta{opacity:1;background:var(--orange);color:white;padding:10px 22px;border-radius:50px;font-size:14px;font-weight:700;box-shadow:0 2px 12px rgba(244,88,0,.25)}
  .nav-links .nav-cta:hover{background:var(--orange-dark)}
  .sticky-cta{display:none}
  .nav-action-btn{display:inline-flex;align-items:center;gap:8px;background:var(--orange);color:white;border:none;border-radius:12px;padding:12px 22px;font-size:14px;font-weight:800;font-family:var(--font);cursor:pointer;text-decoration:none;white-space:nowrap;letter-spacing:-.1px;box-shadow:0 4px 16px rgba(244,88,0,.35);transition:background .2s,transform .15s,box-shadow .2s;flex-shrink:0}
  .nav-action-btn:hover{background:var(--orange-dark);transform:translateY(-1px);box-shadow:0 6px 20px rgba(244,88,0,.45)}
  .nav-action-btn svg{width:16px;height:16px;fill:none;stroke:white;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}
  .hero{min-height:620px}
  .hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;max-width:1100px;margin:0 auto;padding:70px 48px}
  .hero-content{padding:0}
  .hero-coverage{padding:0;margin-top:0}
  .hero h1{font-size:60px;letter-spacing:-2.5px}
  .hero-sub{font-size:17px}
  .hero-checks{gap:12px 20px}
  .hero-coverage .coverage-box{margin:0;background:rgba(255,255,255,.12);backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.2)}
  .coverage-input-row input{background:rgba(255,255,255,.9);color:var(--black)}
  .coverage-bullets span{color:rgba(255,255,255,.8)}
  .coverage-note{color:rgba(255,255,255,.6)}
  .coverage-result-card{background:rgba(255,255,255,.95)}
  .section-heading{font-size:48px;padding:80px 48px 48px}
  .steps-section{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;padding:0 48px 80px;max-width:1100px;margin:0 auto}
  .step-card{margin-bottom:0}

  /* Lifestyle */
  .lifestyle-section{padding:0 48px 80px;max-width:1100px;margin:0 auto}
  .lifestyle-grid{grid-template-columns:repeat(3,1fr);gap:20px}
  .lifestyle-card{height:320px}

  /* Plans */
  .plans-section{padding:80px 48px}
  .plans-section .section-heading{padding-top:0;padding-left:0;padding-right:0}
  .plans-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1100px;margin:0 auto}
  .plan-card{margin-bottom:0}
  .plans-explainer{max-width:1100px;margin:0 auto 32px}
  .plans-badge-wrap{text-align:center;margin-bottom:24px}

  /* Why */
  .why-section{padding:80px 48px}
  .why-section .section-heading{padding:0 0 56px;font-size:48px}
  .why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:48px 40px;max-width:1100px;margin:0 auto}
  .why-item{margin-bottom:0}

  /* Testimonials */
  .testimonials-section{padding:80px 48px 64px}
  .testimonials-section .section-heading{padding:0 0 48px}
  .testimonials-track-wrapper{overflow:visible;padding:0}
  .testimonials-track{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;padding:0;overflow:visible;scroll-snap-type:none;max-width:1100px;margin:0 auto}
  .testimonial-card{min-width:0;max-width:none;scroll-snap-align:none;flex-shrink:unset}
  .testimonial-dots{display:none}

  /* FAQ */
  .faq-section{padding:80px 48px;max-width:1100px;margin:0 auto}
  .faq-layout{display:grid;grid-template-columns:280px 1fr;gap:80px;align-items:start}
  .faq-header{margin-bottom:0;position:sticky;top:100px}
  .faq-header h2{font-size:52px}

  /* Footer */
  footer{padding:64px 48px 40px}
  .footer-inner{flex-direction:row;gap:64px;align-items:flex-start}
  .footer-left-col{flex:0 0 280px}
  .footer-right-col{flex:1}
  .footer-grid{grid-template-columns:repeat(3,1fr)}
  .footer-bottom{flex-direction:row;align-items:center;justify-content:space-between}
  .result-actions{flex-direction:row}
}

@media(min-width:1024px){
  .hero h1{font-size:68px;letter-spacing:-3px}
}
