/* WOLVERHAMPTON FIBRE v4.3 — SECTION CONTRAST · INTER TIGHT · PREMIUM */
:root{
  --w:#FFFFFF;--g1:#F7F7F9;--g2:#EFEFF3;--g3:#E0E0E8;
  --pk:#FF2D78;--pk2:#FF6EA3;--pk3:rgba(255,45,120,.06);--pk4:rgba(255,45,120,.14);
  --p1:rgba(255,45,120,.03);--p2:rgba(255,45,120,.08);
  --t1:#09090B;--t2:#52525B;--t3:#A1A1AA;
  --bdr:rgba(0,0,0,.06);--bdr2:rgba(0,0,0,.1);
  --fh:'Inter Tight','Inter',system-ui,-apple-system,sans-serif;
  --fb:'Inter',system-ui,-apple-system,sans-serif;
  --sh:0 1px 2px rgba(0,0,0,.05),0 4px 20px rgba(0,0,0,.04);
  --sh2:0 8px 40px rgba(0,0,0,.09);
  --dk:#08080C;--dk2:#0E0E14;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--fb);background:var(--w);color:var(--t1);overflow-x:hidden;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}

/* ═══ NAV ═══ */
#nav{position:fixed;top:0;left:0;right:0;z-index:800;height:60px;display:flex;align-items:center;justify-content:space-between;padding:0 5%;background:rgba(255,255,255,.92);backdrop-filter:blur(24px) saturate(180%);border-bottom:1px solid rgba(0,0,0,.05);transition:all .3s}
#nav.scrolled{background:rgba(255,255,255,.98);box-shadow:0 1px 0 rgba(0,0,0,.06)}
.nbrand{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--t1);font-family:var(--fh);font-size:.88rem;font-weight:800;letter-spacing:-.03em;flex-shrink:0}
.nmark{width:28px;height:28px;border-radius:7px;background:var(--pk);display:flex;align-items:center;justify-content:center;font-size:.56rem;font-weight:900;color:#fff}
.nlinks{display:none;list-style:none;align-items:center;gap:1px}
@media(min-width:960px){.nlinks{display:flex}}
.nlinks a{text-decoration:none;color:var(--t2);font-size:.8rem;font-weight:500;padding:6px 11px;border-radius:7px;transition:color .12s,background .12s;white-space:nowrap}
.nlinks a:hover,.nlinks a.act{color:var(--t1);background:var(--g1)}
.ndrop{position:relative}
.ndrop>a::after{content:' ▾';font-size:.5rem;opacity:.4}
.ddrop{position:absolute;top:calc(100% + 8px);left:0;background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:14px;padding:5px;min-width:210px;opacity:0;pointer-events:none;transform:translateY(-6px);transition:opacity .15s,transform .15s;box-shadow:0 16px 48px rgba(0,0,0,.11);z-index:100}
.ndrop:hover .ddrop{opacity:1;pointer-events:all;transform:translateY(0)}
.ddrop a{display:block;padding:8px 11px;border-radius:8px;font-size:.79rem;color:var(--t2);text-decoration:none;transition:background .1s,color .1s}
.ddrop a:hover{background:var(--g1);color:var(--t1)}
.nright{display:flex;align-items:center;gap:10px}
.ntel{font-size:.78rem;font-weight:600;color:var(--t2);text-decoration:none;display:none;white-space:nowrap;transition:color .12s}
@media(min-width:700px){.ntel{display:block}}
.ntel:hover{color:var(--t1)}
.ncta{background:var(--pk);color:#fff;padding:7px 18px;border-radius:100px;font-size:.78rem;font-weight:600;text-decoration:none;transition:all .18s;white-space:nowrap;letter-spacing:-.01em}
.ncta:hover{background:#e0185e;box-shadow:0 6px 20px rgba(255,45,120,.32)}
.hbg{display:flex;flex-direction:column;gap:4.5px;cursor:pointer;padding:6px;border:none;background:transparent}
@media(min-width:960px){.hbg{display:none}}
.hbg span{display:block;width:19px;height:1.5px;background:var(--t1);border-radius:2px;transition:all .22s}
.hbg.open span:nth-child(1){transform:rotate(45deg) translate(4.5px,4.5px)}
.hbg.open span:nth-child(2){opacity:0}
.hbg.open span:nth-child(3){transform:rotate(-45deg) translate(4.5px,-4.5px)}
.mmenu{position:fixed;top:60px;left:0;right:0;bottom:0;background:#fff;padding:20px 5% 120px;z-index:799;overflow-y:auto;transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);border-top:1px solid var(--bdr)}
.mmenu.open{transform:translateX(0)}
.mmenu a{display:block;padding:12px 0;font-size:.97rem;font-weight:500;color:var(--t2);text-decoration:none;border-bottom:1px solid var(--g1);transition:color .12s}
.mmenu a:hover,.mmenu a.hl{color:var(--t1)}.mmenu a.hl{font-weight:700;color:var(--pk)}
.mbar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:700;background:rgba(255,255,255,.97);backdrop-filter:blur(20px);border-top:1px solid var(--bdr);padding:10px 16px 20px;grid-template-columns:1fr 1fr 1fr;gap:8px}
@media(max-width:959px){.mbar{display:grid}}
.mbtn{display:flex;flex-direction:column;align-items:center;gap:3px;padding:9px 8px;border-radius:11px;text-decoration:none;font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;transition:opacity .12s;border:none;cursor:pointer}
.mbic{font-size:1.05rem}.mbtn:active{opacity:.6}
.mb-c{background:var(--g1);border:1px solid var(--g3);color:var(--t2)}
.mb-w{background:rgba(37,211,102,.07);border:1px solid rgba(37,211,102,.18);color:#1a9c45}
.mb-q{background:var(--pk);color:#fff}

/* ═══ HERO ═══ */
.hero{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:92px 5% 64px;background:var(--w);overflow:hidden;text-align:center}
#hcanvas{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}
.hinner{position:relative;z-index:2;max-width:980px;margin:0 auto;width:100%}
.htag{display:inline-flex;align-items:center;gap:7px;background:var(--pk3);border:1px solid var(--pk4);color:var(--pk);padding:5px 16px;border-radius:100px;font-size:.67rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;margin-bottom:14px}
.hpulse{width:5px;height:5px;border-radius:50%;background:var(--pk);animation:pls 2s infinite}
@keyframes pls{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.7)}}
h1.cin{font-family:var(--fh);font-size:clamp(2.8rem,6vw,5.8rem);font-weight:900;letter-spacing:-.055em;line-height:.92;margin-bottom:0;color:var(--t1)}
h1.cin .pk{
  background:linear-gradient(135deg,var(--pk),var(--pk2));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text
}
.hproviders{font-size:clamp(.74rem,1.1vw,.84rem);color:var(--t3);font-weight:500;margin:16px 0 8px;line-height:1.9;letter-spacing:.01em}
.hproviders strong{color:var(--t2);font-weight:600}
.hdesc{font-size:clamp(.86rem,1.3vw,.97rem);color:var(--t2);line-height:1.65;max-width:500px;margin:0 auto 20px;font-weight:400}
.hbtns{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-bottom:48px}
.htrust{display:flex;flex-wrap:wrap;gap:7px;justify-content:center;align-items:center}
.htrust-l{font-size:.59rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--t3);margin-right:3px}
.hnet{font-size:.67rem;font-weight:500;color:var(--t3);padding:3px 10px;border:1px solid var(--g2);border-radius:100px}
.hscroll{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:4px;opacity:.3;z-index:2}
.hscroll-bar{width:1px;height:30px;background:var(--t1);animation:scrl 2.5s ease-in-out infinite}
.hscroll-lbl{font-size:.57rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--t1)}
@keyframes scrl{0%,100%{transform:scaleY(1)}50%{transform:scaleY(.5)}}


/* ═══ HERO QUICK FORM ═══ */
.hform{background:#fff;border:1px solid var(--bdr);border-radius:18px;padding:18px 20px;max-width:560px;margin:18px auto 0;box-shadow:0 8px 40px rgba(0,0,0,.1);position:relative;z-index:2;text-align:left}
.hform-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:8px}
@media(max-width:540px){.hform-row{grid-template-columns:1fr}}
.hform input{width:100%;background:var(--g1);border:1.5px solid var(--g2);border-radius:10px;padding:10px 14px;color:var(--t1);font-family:var(--fb);font-size:.9rem;outline:none;transition:border-color .15s,box-shadow .15s}
.hform input::placeholder{color:var(--t3)}
.hform input:focus{border-color:var(--pk);box-shadow:0 0 0 3px rgba(255,45,120,.08);background:#fff}
.hform-btn{width:100%;padding:11px;border:none;border-radius:100px;cursor:pointer;background:var(--pk);color:#fff;font-family:var(--fh);font-weight:800;font-size:.9rem;letter-spacing:-.02em;transition:all .18s}
.hform-btn:hover{background:#e0185e;box-shadow:0 10px 28px rgba(255,45,120,.35)}
.hform-trust{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:8px;font-size:.67rem;color:var(--t3)}
.hform-lbl{font-size:.62rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--pk);margin-bottom:8px}

/* ═══ TICKER ═══ */
.tkr{background:var(--g1);border-top:1px solid var(--g2);border-bottom:1px solid var(--g2);overflow:hidden;white-space:nowrap;padding:9px 0}
.ttr{display:inline-flex;animation:tick 55s linear infinite}
.ti{font-size:.74rem;font-weight:500;letter-spacing:.03em;padding:0 22px;color:var(--t3)}
.ts{color:var(--pk);padding:0 3px;opacity:.4}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ═══ SECTION SYSTEM — THE KEY DESIGN ELEMENT ═══ */
/* Pure white */
.sW{background:var(--w);color:var(--t1);padding:140px 5%;position:relative;overflow:hidden}
/* Light grey — clear separation */
.sG{background:var(--g1);color:var(--t1);padding:140px 5%;border-top:1px solid var(--g2);border-bottom:1px solid var(--g2);position:relative;overflow:hidden}
/* Light pink tint — for coverage, CTA build-up */
.sP{background:var(--p1);color:var(--t1);padding:140px 5%;border-top:1px solid var(--p2);border-bottom:1px solid var(--p2);position:relative;overflow:hidden}
/* Pink gradient CTA — the finale before footer */
.sCTA{padding:140px 5%;text-align:center;position:relative;overflow:hidden;background:linear-gradient(135deg,var(--pk) 0%,#FF4E8A 50%,var(--pk2) 100%)}
.sCTA::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 80% at 50% 0%,rgba(255,255,255,.12),transparent);pointer-events:none}
.sCTA h2{font-family:var(--fh);font-size:clamp(2.8rem,5.5vw,5.5rem);font-weight:900;letter-spacing:-.055em;line-height:.9;margin-bottom:18px;color:#fff;position:relative}
.sCTA p{font-size:1rem;color:rgba(255,255,255,.75);margin-bottom:38px;position:relative}
.ctabtns{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;position:relative}
/* Dark — sparingly, only for comparison table context */
.sDk{background:var(--dk);color:#fff;padding:140px 5%;position:relative;overflow:hidden}
@media(max-width:640px){.sW,.sG,.sP,.sCTA,.sDk{padding:88px 5%}.hero{padding:80px 5% 60px}}
@media(max-width:959px){.sCTA{padding-bottom:108px}}

/* ═══ LAYOUT ═══ */
.mx{max-width:1280px;margin:0 auto}
.g2{display:grid;grid-template-columns:1fr 1fr;gap:32px}
.g3{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}
.g4{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:16px}
@media(max-width:700px){.g2{grid-template-columns:1fr}}

/* ═══ EYEBROWS + HEADINGS ═══ */
.ey{display:inline-block;font-size:.64rem;font-weight:600;text-transform:uppercase;letter-spacing:.14em;color:var(--pk);margin-bottom:14px}
.ey-w{display:inline-block;font-size:.64rem;font-weight:600;text-transform:uppercase;letter-spacing:.14em;color:rgba(255,255,255,.6);margin-bottom:14px}
.hH{font-family:var(--fh);font-size:clamp(2.4rem,4.5vw,4.2rem);font-weight:900;letter-spacing:-.055em;line-height:.91;color:var(--t1);margin-bottom:18px}
.hHw{font-family:var(--fh);font-size:clamp(2.4rem,4.5vw,4.2rem);font-weight:900;letter-spacing:-.055em;line-height:.91;color:#fff;margin-bottom:18px}
/* Gradient pink on headings — more premium than flat pink */
.hH .a{background:linear-gradient(135deg,var(--pk),var(--pk2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hHw .a{color:rgba(255,255,255,.75)}
.sub{font-size:.97rem;color:var(--t2);line-height:1.78;max-width:520px}
.subw{font-size:.97rem;color:rgba(255,255,255,.65);line-height:1.78;max-width:520px}

/* ═══ STATS ROW ═══ */
.stbar{border-top:1px solid var(--g2);border-bottom:1px solid var(--g2);background:var(--w)}
.strow{display:grid;grid-template-columns:repeat(2,1fr);max-width:1280px;margin:0 auto}
@media(min-width:700px){.strow{grid-template-columns:repeat(4,1fr)}}
.stbl{padding:40px 24px;text-align:center;border-right:1px solid var(--g2)}.stbl:last-child{border-right:none}
.stn{font-family:var(--fh);font-size:3.4rem;font-weight:900;letter-spacing:-.06em;line-height:1;background:linear-gradient(135deg,var(--pk),var(--pk2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.stn sup{font-size:1.5rem}
.stl{font-size:.61rem;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.12em;margin-top:5px}

/* ═══ CARDS ═══ */
.cw{background:#fff;border:1px solid var(--bdr);border-radius:18px;padding:28px 24px;box-shadow:var(--sh);transition:box-shadow .2s,transform .2s,border-color .2s}
.cw:hover{box-shadow:var(--sh2);transform:translateY(-3px);border-color:rgba(255,45,120,.15)}
.cg{background:var(--w);border:1px solid var(--g2);border-radius:18px;padding:28px 24px;transition:box-shadow .2s,transform .2s,border-color .2s}
.cg:hover{box-shadow:var(--sh);border-color:rgba(255,45,120,.2);transform:translateY(-3px)}
.cd{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:28px 24px;transition:border-color .2s,transform .2s}
.cd:hover{border-color:rgba(255,45,120,.3);transform:translateY(-3px)}

/* ═══ CARD TEXT ═══ */
.wt{font-family:var(--fh);font-size:.97rem;font-weight:700;letter-spacing:-.03em;color:var(--t1);margin-bottom:8px}
.wt-w{font-family:var(--fh);font-size:.97rem;font-weight:700;letter-spacing:-.03em;color:var(--t1);margin-bottom:8px}
.pt{font-size:.84rem;color:var(--t2);line-height:1.72}
.pt-w{font-size:.84rem;color:var(--t2);line-height:1.72}

/* ═══ ICON ═══ */
.ico{width:44px;height:44px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;margin-bottom:18px;background:var(--pk3);border:1px solid var(--pk4);flex-shrink:0}

/* ═══ BUTTONS ═══ */
.btn{display:inline-flex;align-items:center;gap:7px;padding:12px 28px;border-radius:100px;font-family:var(--fb);font-weight:600;font-size:.87rem;text-decoration:none;transition:all .18s;border:none;cursor:pointer;white-space:nowrap;letter-spacing:-.01em}
.bn-pk{background:var(--pk);color:#fff}.bn-pk:hover{background:#e0185e;box-shadow:0 8px 28px rgba(255,45,120,.35)}
.bn-ol{background:transparent;color:var(--t1);border:1.5px solid var(--g3)}.bn-ol:hover{border-color:var(--pk);color:var(--pk)}
.bn-wh{background:#fff;color:var(--t1)}.bn-wh:hover{background:rgba(255,255,255,.92);box-shadow:0 6px 20px rgba(0,0,0,.12)}
.bn-wh-ol{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.3)}.bn-wh-ol:hover{border-color:rgba(255,255,255,.7);background:rgba(255,255,255,.08)}
.bn-sm{padding:9px 22px;font-size:.81rem}
.bn-pk-soft{background:var(--pk3);color:var(--pk);border:1px solid var(--pk4)}.bn-pk-soft:hover{background:var(--pk);color:#fff}

/* ═══ FORM ═══ */
.fc{background:#fff;border:1px solid var(--bdr);border-radius:22px;padding:32px 28px;position:relative;box-shadow:var(--sh2);overflow:hidden}
.fc::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--pk),var(--pk2))}
.fst{display:none}.fst.on{display:block}
.fprog{display:flex;gap:5px;margin-bottom:22px}
.fpdot{flex:1;height:3px;border-radius:100px;background:var(--g2);transition:background .3s}
.fpdot.dn{background:var(--pk)}.fpdot.cu{background:var(--pk2)}
.ftit{font-family:var(--fh);font-size:1.2rem;font-weight:900;letter-spacing:-.05em;margin-bottom:3px;color:var(--t1)}
.fsub{font-size:.73rem;color:var(--t3);margin-bottom:18px}
.frow2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(max-width:480px){.frow2{grid-template-columns:1fr}}
.fg{margin-bottom:10px}
.fg label{display:block;font-size:.62rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--t3);margin-bottom:6px}
.fg input,.fg select,.fg textarea{width:100%;background:#fff;border:1.5px solid var(--g2);border-radius:10px;padding:11px 14px;color:var(--t1);font-family:var(--fb);font-size:.88rem;outline:none;-webkit-appearance:none;appearance:none;transition:border-color .15s,box-shadow .15s}
.fg input::placeholder,.fg textarea::placeholder{color:var(--t3)}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--pk);box-shadow:0 0 0 3px rgba(255,45,120,.08)}
.fg select option{background:#fff;color:#111}.fg textarea{resize:vertical;min-height:70px}
.fbtn{width:100%;padding:13px;border:none;border-radius:100px;cursor:pointer;background:var(--pk);color:#fff;font-family:var(--fb);font-weight:700;font-size:.93rem;transition:all .18s;margin-top:6px}
.fbtn:hover{background:#e0185e;box-shadow:0 10px 28px rgba(255,45,120,.35)}
.fnbtn{width:100%;padding:11px;border:1.5px solid var(--g2);border-radius:100px;cursor:pointer;background:#fff;color:var(--t1);font-family:var(--fb);font-weight:600;font-size:.88rem;transition:all .18s;margin-top:6px}
.fnbtn:hover{border-color:var(--pk);color:var(--pk)}
.fbck{background:none;border:none;cursor:pointer;color:var(--t3);font-size:.75rem;font-weight:600;margin-bottom:12px;padding:0;font-family:var(--fb);transition:color .12s}
.fbck:hover{color:var(--t2)}
.ffoot{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:12px;font-size:.67rem;color:var(--t3)}
.sbox{display:none;flex-direction:column;align-items:center;text-align:center;gap:12px;padding:16px 0}
.sico{width:64px;height:64px;border-radius:50%;background:var(--pk3);border:2px solid var(--pk);display:flex;align-items:center;justify-content:center;font-size:1.8rem;margin:0 auto}

/* ═══ POSTCODE CHECKER ═══ */
.ckd{background:var(--g1);border:1px solid var(--g2);border-radius:18px;padding:28px 24px}
.ckrow{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
.ckin{flex:1;min-width:140px;background:#fff;border:1.5px solid var(--g2);border-radius:11px;padding:11px 16px;color:var(--t1);font-family:var(--fb);font-size:.9rem;outline:none;transition:border-color .15s}
.ckin:focus{border-color:var(--pk)}.ckin::placeholder{color:var(--t3)}
.ckbtn{background:var(--pk);color:#fff;border:none;border-radius:100px;padding:11px 24px;cursor:pointer;font-family:var(--fb);font-weight:600;font-size:.84rem;transition:all .18s}
.ckbtn:hover{background:#e0185e;box-shadow:0 6px 20px rgba(255,45,120,.3)}
.ckres{display:none;margin-top:12px;background:#fff;border:1.5px solid var(--pk4);border-radius:11px;padding:13px 16px;font-size:.84rem;color:var(--t1);line-height:1.7}

/* ═══ WV GRID ═══ */
.pcd{background:#fff;border:1.5px solid var(--bdr);border-radius:13px;padding:16px 18px;transition:border-color .18s,transform .18s,box-shadow .18s}
.pcd:hover{border-color:rgba(255,45,120,.2);transform:translateY(-2px);box-shadow:var(--sh)}
.pccd{font-family:var(--fh);font-size:1.05rem;font-weight:800;letter-spacing:-.03em;color:var(--pk);margin-bottom:2px}
.pcarea{font-weight:600;font-size:.84rem;color:var(--t1);margin-bottom:3px}
.pchoods{font-size:.68rem;color:var(--t3);line-height:1.5}
.pctags{display:flex;flex-wrap:wrap;gap:3px;margin-top:8px}
.pctag{background:var(--g1);border:1px solid var(--g2);color:var(--t2);padding:2px 8px;border-radius:100px;font-size:.59rem;font-weight:500}
.pctag.pk{background:var(--pk3);border-color:var(--pk4);color:var(--pk)}

/* ═══ COMPARISON TABLE ═══ */
.tw{overflow-x:auto;border-radius:16px;border:1px solid var(--g2)}
table.ct{width:100%;border-collapse:collapse;background:#fff}
table.ct th{background:var(--g1);padding:13px 16px;text-align:left;font-size:.61rem;text-transform:uppercase;letter-spacing:.1em;font-weight:600;color:var(--t3);border-bottom:1px solid var(--g2);white-space:nowrap}
table.ct td{padding:13px 16px;font-size:.84rem;border-bottom:1px solid var(--g1);vertical-align:middle;color:var(--t2)}
table.ct td strong{color:var(--t1)}
table.ct tr:last-child td{border-bottom:none}
table.ct tr:hover td{background:rgba(255,45,120,.02)}
.brec{background:var(--pk);color:#fff;font-size:.54rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:2px 7px;border-radius:100px;margin-left:6px}
.bpop{background:var(--g2);color:var(--t2);font-size:.54rem;font-weight:600;text-transform:uppercase;padding:2px 7px;border-radius:100px;margin-left:6px}
.bw{display:flex;align-items:center;gap:8px}
.sb{height:3px;border-radius:100px;transition:width 1.2s cubic-bezier(.4,0,.2,1)}
.tdd{color:var(--pk);font-weight:600}.tsh{color:var(--t3)}.ck2{color:#16a34a;font-weight:600}.cx{color:var(--g2)}

/* ═══ FAQ ═══ */
.fqw details,.fqd details{padding:17px 0;cursor:pointer}
.fqw details{border-bottom:1px solid var(--g2)}
.fqd details{border-bottom:1px solid rgba(255,255,255,.07)}
details summary{font-family:var(--fh);font-weight:700;font-size:.92rem;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px;user-select:none}
.fqw summary{color:var(--t1)}.fqd summary{color:#fff}
details summary::-webkit-details-marker{display:none}
.fi{color:var(--pk);font-size:1.1rem;flex-shrink:0;transition:transform .2s;font-weight:300}
details[open] .fi{transform:rotate(45deg)}
.fqw details p{font-size:.84rem;color:var(--t2);line-height:1.78;margin-top:10px;font-family:var(--fb)}
.fqd details p{font-size:.84rem;color:rgba(255,255,255,.62);line-height:1.78;margin-top:10px}

/* ═══ TESTIMONIALS ═══ */
.tlt{background:#fff;border:1px solid var(--bdr);border-radius:18px;padding:26px;box-shadow:var(--sh);transition:box-shadow .2s,transform .2s}
.tlt:hover{box-shadow:var(--sh2);transform:translateY(-3px)}
.tstr{color:var(--pk);font-size:.73rem;letter-spacing:3px;margin-bottom:12px}
.tq{font-size:.87rem;color:var(--t2);line-height:1.75;font-style:italic;margin-bottom:16px}
.tau{display:flex;align-items:center;gap:10px}
.tav{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.76rem;font-weight:700;color:#fff;flex-shrink:0}
.tnm{font-family:var(--fh);font-weight:700;font-size:.83rem;color:var(--t1);letter-spacing:-.02em}
.tbiz{font-size:.69rem;color:var(--t3)}

/* ═══ PROVIDER CARDS ═══ */
.plog{width:46px;height:46px;border-radius:11px;margin:0 auto 13px;display:flex;align-items:center;justify-content:center;font-size:.64rem;font-weight:700;color:#fff}
.pnm{font-family:var(--fh);font-size:.88rem;font-weight:700;letter-spacing:-.03em;color:var(--t1);margin-bottom:4px}
.pds{font-size:.72rem;color:var(--t3);margin-bottom:8px;line-height:1.5}
.spd{display:inline-block;background:var(--pk3);border:1px solid var(--pk4);color:var(--pk);padding:2px 9px;border-radius:100px;font-size:.63rem;font-weight:600}
.ntb{display:inline-block;margin-top:4px;background:var(--g1);color:var(--t3);border:1px solid var(--g2);padding:2px 8px;border-radius:100px;font-size:.59rem;font-weight:500}

/* ═══ BLOG ═══ */
.bcl{background:#fff;border:1px solid var(--bdr);border-radius:16px;overflow:hidden;box-shadow:var(--sh);transition:transform .2s,box-shadow .2s;text-decoration:none;display:block;color:inherit}
.bcl:hover{transform:translateY(-4px);box-shadow:var(--sh2)}
.bimg{height:100px;background:linear-gradient(135deg,var(--pk3),rgba(255,110,163,.04));display:flex;align-items:center;justify-content:center;font-size:2rem;border-bottom:1px solid var(--bdr)}
.bbody{padding:20px}
.bcat{font-size:.61rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--pk);margin-bottom:7px}
.bttl{font-family:var(--fh);font-size:.98rem;font-weight:700;letter-spacing:-.03em;line-height:1.2;margin-bottom:8px;color:var(--t1)}
.bex{font-size:.8rem;color:var(--t2);line-height:1.62}

/* ═══ BREADCRUMB + PAGE HERO ═══ */
.bcrumb{padding:10px 5%;font-size:.75rem;color:var(--t3);background:var(--g1);border-bottom:1px solid var(--g2);margin-top:60px}
.bcrumb a{color:var(--t3);text-decoration:none;transition:color .12s}.bcrumb a:hover{color:var(--pk)}
.bcrumb span{margin:0 7px;opacity:.35}
.ph{padding:64px 5% 52px;background:#fff;border-bottom:1px solid var(--g2);text-align:center;margin-top:60px;position:relative;overflow:hidden}
.ph::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--pk),var(--pk2))}
.ph::after{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:80px;height:1px;background:linear-gradient(90deg,transparent,var(--pk),transparent)}
.phi{max-width:760px;margin:0 auto;position:relative}
.phi h1{font-family:var(--fh);font-size:clamp(2.4rem,5vw,4.5rem);font-weight:900;letter-spacing:-.06em;line-height:.92;margin-bottom:16px;color:var(--t1)}
.phi h1 span{color:var(--pk)}
.phi p{font-size:.95rem;color:var(--t2);line-height:1.72;max-width:560px;margin:0 auto 20px}
.phi .btn{margin-top:4px}

/* ═══ PROSE ═══ */
.prose{max-width:760px;margin:0 auto}
.prose h2{font-family:var(--fh);color:var(--t1);font-size:clamp(1.5rem,2.2vw,1.9rem);font-weight:800;letter-spacing:-.05em;margin:36px 0 12px}
.prose h3{font-family:var(--fh);color:var(--t1);font-size:clamp(1.05rem,1.5vw,1.25rem);font-weight:700;margin:24px 0 8px}
.prose p{font-size:.93rem;color:var(--t2);line-height:1.87;margin-bottom:16px}
.prose strong{color:var(--t1)}.prose a{color:var(--pk);text-decoration:none}
.prose ul{margin:12px 0 18px 18px}
.prose li{font-size:.91rem;color:var(--t2);line-height:1.8;margin-bottom:6px}
.prose.d h2,.prose.d h3{color:#fff}.prose.d p,.prose.d li{color:rgba(255,255,255,.6)}.prose.d strong{color:#fff}

/* ═══ FOOTER ═══ */
footer{background:var(--dk);color:#fff;padding:72px 5% 40px}
.fgrid{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1fr;gap:44px}
@media(min-width:640px){.fgrid{grid-template-columns:1.5fr 1fr 1fr 1fr}}
.fbrand{font-family:var(--fh);font-size:.92rem;font-weight:800;letter-spacing:-.025em;margin-bottom:10px}
.fdesc{font-size:.79rem;color:rgba(255,255,255,.38);line-height:1.72}
.fhead{font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.11em;color:rgba(255,255,255,.28);margin-bottom:14px}
.flinks{list-style:none}.flinks li{margin-bottom:8px}
.flinks a{font-size:.79rem;color:rgba(255,255,255,.42);text-decoration:none;transition:color .12s}
.flinks a:hover{color:rgba(255,255,255,.82)}
.fbot{max-width:1280px;margin:36px auto 0;padding-top:22px;border-top:1px solid rgba(255,255,255,.06);display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;align-items:center}
.fleg{font-size:.68rem;color:rgba(255,255,255,.18);line-height:1.6}
.fseo{font-size:.55rem;color:rgba(255,255,255,.04);line-height:1.6;margin-top:14px;max-width:1280px;margin-left:auto;margin-right:auto}

/* ═══ ANIMATIONS ═══ */
.fu{opacity:0;transform:translateY(14px);transition:opacity .55s ease,transform .55s ease}
.fu.vis{opacity:1;transform:translateY(0)}
@media(max-width:959px){footer{padding-bottom:100px}}

/* ═══ COMPATIBILITY ALIASES — fixes all inner pages ═══ */

/* .sD = light grey section — consistent light design */
.sD{background:var(--g1);color:var(--t1);padding:140px 5%;border-top:1px solid var(--g2);border-bottom:1px solid var(--g2);position:relative;overflow:hidden}
@media(max-width:640px){.sD{padding:88px 5%}}

/* .ctas = CTA section (pink gradient, consistent with homepage .sCTA) */
.ctas{padding:120px 5%;text-align:center;position:relative;overflow:hidden;background:linear-gradient(135deg,var(--pk) 0%,#FF4E8A 50%,var(--pk2) 100%)}
.ctas::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 80% at 50% 0%,rgba(255,255,255,.12),transparent);pointer-events:none}
.ctas h2{font-family:var(--fh);font-size:clamp(2.4rem,5vw,4.5rem);font-weight:900;letter-spacing:-.055em;line-height:.92;margin-bottom:16px;color:#fff;position:relative}
.ctas p{font-size:.97rem;color:rgba(255,255,255,.78);margin-bottom:36px;position:relative}
@media(max-width:640px){.ctas{padding:80px 5%}}
@media(max-width:959px){.ctas{padding-bottom:108px}}

/* .bn-od = outlined on dark/pink background (white outline) */
.bn-od{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.35)}.bn-od:hover{border-color:rgba(255,255,255,.75);background:rgba(255,255,255,.1)}

/* .bn-ow = same as .bn-od */
.bn-ow{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.35)}.bn-ow:hover{border-color:rgba(255,255,255,.75);background:rgba(255,255,255,.1)}

/* sD is now light — dark text */
.sD .hH{color:var(--t1)}
.sD .hH .a{background:linear-gradient(135deg,var(--pk),var(--pk2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.sD .sub{color:var(--t2)}
.sD .ey{color:var(--pk)}

/* sD on light bg — standard card styles */
.sD .cw{background:#fff;border-color:var(--bdr)}
.sD .wt{color:var(--t1)}
.sD .pt{color:var(--t2)}
.sD .ico{background:var(--pk3);border-color:var(--pk4)}

/* sD links — dark text */

/* ph (page hero) headings */
.ph .hH,.ph h2{color:var(--t1)}


/* First section after page hero — tighter so form is close to hero */
.ph + .sD, .ph + .sG, .ph + .sW, .ph + .sP{padding-top:52px}


/* ════════════════════════════════════════
   ELITE 2026 EFFECTS
   ════════════════════════════════════════ */

/* ── Effect 1: Enhanced frosted glass nav ── */
#nav{
  backdrop-filter:blur(24px) saturate(200%);
  -webkit-backdrop-filter:blur(24px) saturate(200%);
  background:rgba(255,255,255,.72);
  border-bottom:1px solid rgba(255,255,255,.5);
  transition:background .4s,box-shadow .4s,border-color .4s
}
#nav.scrolled{
  background:rgba(255,255,255,.92);
  border-bottom:1px solid rgba(0,0,0,.06);
  box-shadow:0 1px 0 rgba(0,0,0,.05),0 4px 24px rgba(0,0,0,.04)
}

/* ── Effect 2: Floating glass cards ── */
.cw,.cg{
  backdrop-filter:blur(8px) saturate(140%);
  -webkit-backdrop-filter:blur(8px) saturate(140%);
  box-shadow:0 1px 2px rgba(0,0,0,.04),0 4px 16px rgba(0,0,0,.04),inset 0 1px 0 rgba(255,255,255,.9)
}
.cw:hover{
  transform:translateY(-5px);
  box-shadow:0 2px 4px rgba(0,0,0,.04),0 12px 40px rgba(0,0,0,.06),0 0 0 1px rgba(255,45,120,.12),inset 0 1px 0 rgba(255,255,255,1)
}
.cg:hover{
  transform:translateY(-5px);
  box-shadow:0 2px 4px rgba(0,0,0,.03),0 12px 32px rgba(255,45,120,.08),0 0 0 1px rgba(255,45,120,.14)
}

/* ── Effect 3: Ambient pink glow behind sections ── */
.sW{position:relative;overflow:hidden}
.sW::after{
  content:'';position:absolute;
  width:900px;height:900px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,45,120,.05),transparent 65%);
  top:50%;right:-350px;transform:translateY(-50%);
  pointer-events:none;z-index:0
}
.sW > .mx{position:relative;z-index:1}
.sG{position:relative;overflow:hidden}
.sG::before{
  content:'';position:absolute;
  width:700px;height:700px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,45,120,.04),transparent 65%);
  bottom:-300px;left:-200px;
  pointer-events:none;z-index:0
}
.sG > .mx{position:relative;z-index:1}
.sP{position:relative;overflow:hidden}
.sP::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 80% 80% at 60% 50%,rgba(255,45,120,.07),transparent 70%);
  pointer-events:none;z-index:0
}
.sP > .mx{position:relative;z-index:1}

/* ── Effect 4: Scroll reveal — smoother ── */
.fu{
  opacity:0;
  transform:translateY(20px);
  transition:opacity .65s cubic-bezier(.22,1,.36,1),transform .65s cubic-bezier(.22,1,.36,1)
}
.fu.vis{opacity:1;transform:translateY(0)}

/* ── Effect 7: Animated stats ── */
.stn{
  font-family:var(--fh);font-size:3.4rem;font-weight:900;letter-spacing:-.06em;line-height:1;
  background:linear-gradient(135deg,var(--pk),var(--pk2));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  display:inline-block
}

/* ── Effect 8: Glass quote form ── */
.fc{
  background:rgba(255,255,255,.85);
  backdrop-filter:blur(24px) saturate(180%);
  -webkit-backdrop-filter:blur(24px) saturate(180%);
  border:1px solid rgba(255,255,255,.7);
  box-shadow:0 4px 12px rgba(0,0,0,.04),0 20px 60px rgba(0,0,0,.07),inset 0 1px 0 rgba(255,255,255,.95)
}

/* ── Effect 9: Moving gradient buttons ── */
@keyframes pkFlow{
  0%{background-position:0% 50%}
  50%{background-position:100% 50%}
  100%{background-position:0% 50%}
}
.bn-pk{
  background:linear-gradient(270deg,#FF2D78,#E0185E,#FF5896,#FF2D78);
  background-size:300% 300%;
  animation:pkFlow 5s ease infinite
}
.bn-pk:hover{
  animation:pkFlow 2s ease infinite;
  box-shadow:0 8px 28px rgba(255,45,120,.4)
}

/* CTA pink gradient buttons same treatment */
.ctas .btn,.sCTA .btn{
  animation:none
}
.ctas .btn.bn-wh,.sCTA .btn.bn-wh{
  background:#fff;color:var(--t1);
  transition:all .2s
}
.ctas .btn.bn-wh:hover,.sCTA .btn.bn-wh:hover{
  background:rgba(255,255,255,.92);
  box-shadow:0 8px 24px rgba(0,0,0,.15);
  transform:translateY(-2px)
}

/* ── Effect 10: Section depth lines ── */
.sG{border-top:1px solid var(--g2);border-bottom:1px solid var(--g2)}
.sP{border-top:1px solid rgba(255,45,120,.1);border-bottom:1px solid rgba(255,45,120,.1)}

/* ── Ticker enhancement ── */
.tkr{
  background:var(--g1);
  border-top:1px solid var(--g2);
  border-bottom:1px solid var(--g2)
}
.ti{
  font-size:.75rem;font-weight:600;letter-spacing:.05em;
  color:var(--t3);padding:0 24px;
  transition:color .2s
}
.ti:hover{color:var(--pk)}

/* ── Hero form glass ── */
.hform{
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(24px) saturate(180%);
  -webkit-backdrop-filter:blur(24px) saturate(180%);
  border:1px solid rgba(255,255,255,.75);
  box-shadow:0 4px 12px rgba(0,0,0,.04),0 24px 60px rgba(0,0,0,.08)
}

/* ── Premium nav CTA button ── */
.ncta{
  background:linear-gradient(270deg,#FF2D78,#E0185E,#FF5896,#FF2D78);
  background-size:300% 300%;
  animation:pkFlow 5s ease infinite;
  border:none
}
.ncta:hover{
  animation:pkFlow 1.5s ease infinite;
  box-shadow:0 6px 20px rgba(255,45,120,.35)
}

/* ── Connectivity Index styles ── */
.ci-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1px;border:1px solid var(--g2);border-radius:20px;overflow:hidden;background:var(--g2)}
.ci-cell{background:#fff;padding:28px 24px;position:relative;overflow:hidden;transition:background .2s}
.ci-cell:hover{background:var(--g1)}
.ci-cell::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--pk),transparent);opacity:0;transition:opacity .3s}
.ci-cell:hover::before{opacity:1}
.ci-n{font-family:var(--fh);font-size:2.4rem;font-weight:900;letter-spacing:-.06em;line-height:1;margin-bottom:4px;background:linear-gradient(135deg,var(--pk),var(--pk2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.ci-l{font-size:.63rem;font-weight:600;text-transform:uppercase;letter-spacing:.11em;color:var(--t3);margin-bottom:8px}
.ci-d{font-size:.8rem;color:var(--t2);line-height:1.6}
.ci-bar{height:3px;background:var(--g2);border-radius:100px;margin-top:12px;overflow:hidden}
.ci-fill{height:100%;border-radius:100px;background:linear-gradient(90deg,var(--pk),var(--pk2));width:0;transition:width 1.4s cubic-bezier(.4,0,.2,1)}

/* ── Page hero premium ── */
.ph{
  background:linear-gradient(180deg,#fff 0%,rgba(255,45,120,.03) 100%);
}

/* ── Inner page quick form input polish ── */
.phi input[type=text]{
  background:#fff;border:1.5px solid var(--g2);border-radius:100px;
  backdrop-filter:blur(8px)
}


/* ════════════════════════════════════════
   COMPREHENSIVE MOBILE OPTIMISATION
   Tested: iOS Safari · Chrome Android · Firefox Mobile
   Breakpoints: 320 · 375 · 414 · 480 · 640 · 768 · 959
   ════════════════════════════════════════ */

/* ── Global mobile resets ── */
*{
  -webkit-tap-highlight-color:transparent;
  -webkit-touch-callout:none
}
input,select,textarea,button{
  touch-action:manipulation /* prevents 300ms tap delay */
}
html{
  -webkit-text-size-adjust:100%; /* prevent iOS font scaling on rotate */
  text-size-adjust:100%
}

/* ── iOS safe areas (notch/home bar) ── */
.mbar{
  padding-bottom:calc(16px + env(safe-area-inset-bottom, 0px));
  padding-left:calc(16px + env(safe-area-inset-left, 0px));
  padding-right:calc(16px + env(safe-area-inset-right, 0px))
}
footer{
  padding-bottom:calc(40px + env(safe-area-inset-bottom, 0px))
}
@media(max-width:959px){
  footer{padding-bottom:calc(100px + env(safe-area-inset-bottom, 0px))}
}

/* ── iOS input zoom fix — ALL inputs must be ≥16px on mobile ── */
@media(max-width:959px){
  input,select,textarea{
    font-size:16px !important
  }
  .fg input,.fg select,.fg textarea{
    font-size:16px !important;
    padding:13px 16px
  }
  .ckin{font-size:16px !important}
  .hform input{font-size:16px !important}
}

/* ── Touch targets — minimum 44×44px ── */
@media(max-width:959px){
  .btn{min-height:44px;padding:12px 22px}
  .mbtn{min-height:48px}
  .ckbtn{min-height:44px;padding:12px 20px}
  .hform-btn{min-height:48px;padding:14px}
  .fnbtn,.fbtn{min-height:48px}
  details summary{min-height:44px;padding:14px 0}
  .ncta{min-height:40px}
}

/* ── HERO — mobile ── */
@media(max-width:640px){
  .hero{padding:74px 5% 36px}
  h1.cin{font-size:clamp(2.2rem,10vw,3rem);letter-spacing:-.045em;line-height:.94}
  .htag{font-size:.6rem;padding:4px 13px;margin-bottom:14px}
  .hproviders{font-size:.7rem;margin:10px 0 4px;line-height:1.75}
  .hdesc{font-size:.88rem;margin-bottom:14px}
  .hbtns{gap:8px;margin-bottom:20px}
  .hbtns .btn{flex:1;min-width:0;justify-content:center;padding:12px 14px;font-size:.83rem}
  .htrust{gap:5px}
  .hnet{font-size:.62rem;padding:3px 8px}
  .hform{padding:14px 16px;margin:10px auto 0;border-radius:16px}
  .hform-lbl{font-size:.6rem;margin-bottom:7px}
  .hform-btn{font-size:.86rem;padding:12px}
  .hform-trust{font-size:.63rem}
}
@media(max-width:375px){
  h1.cin{font-size:2rem}
  .hbtns .btn{font-size:.78rem}
}

/* ── STATS BAR — mobile ── */
@media(max-width:480px){
  .strow{grid-template-columns:repeat(2,1fr)}
  .stbl:nth-child(2){border-right:none}
  .stbl:nth-child(3){border-top:1px solid var(--g2)}
  .stbl:nth-child(4){border-top:1px solid var(--g2)}
  .stn{font-size:2.4rem}
  .stbl{padding:24px 16px}
}

/* ── SECTION PADDING — mobile ── */
@media(max-width:640px){
  .sW,.sG,.sP,.sDk,.sD{padding:64px 5%}
  .ctas,.sCTA{padding:64px 5% 108px}
  .ph{padding:48px 5% 36px}
}
@media(max-width:375px){
  .sW,.sG,.sP,.sDk,.sD{padding:52px 4%}
  .ctas,.sCTA{padding:52px 4% 100px}
}

/* ── TYPOGRAPHY — mobile ── */
@media(max-width:640px){
  .hH,.hHw{font-size:clamp(1.9rem,7.5vw,2.8rem);letter-spacing:-.045em}
  .ctas h2,.sCTA h2{font-size:clamp(2rem,8vw,3rem)}
  .sub,.subw{font-size:.9rem}
  .phi h1{font-size:clamp(1.9rem,7vw,2.8rem);letter-spacing:-.045em}
}
@media(max-width:375px){
  .hH,.hHw{font-size:1.9rem}
}

/* ── GRID LAYOUTS — mobile ── */
@media(max-width:640px){
  .g2,.g3,.g4{grid-template-columns:1fr;gap:14px}
}
@media(min-width:641px) and (max-width:900px){
  .g3{grid-template-columns:repeat(2,1fr)}
  .g4{grid-template-columns:repeat(2,1fr)}
}

/* ── FORM — mobile ── */
@media(max-width:640px){
  .fc{padding:22px 18px;border-radius:18px}
  .ftit{font-size:1.05rem}
  .frow2{grid-template-columns:1fr}
  .fbtn,.fnbtn{font-size:.9rem}
  /* Quote section left column */
  .g2[style*="get-quote"]{gap:32px}
}

/* ── POSTCODE CHECKER — mobile ── */
@media(max-width:480px){
  .ckrow{flex-direction:column}
  .ckin{min-width:0;width:100%}
  .ckbtn{width:100%}
  .ckd{padding:20px 18px}
}

/* ── COMPARISON TABLE — mobile ── */
.tw{-webkit-overflow-scrolling:touch}
@media(max-width:768px){
  table.ct th,table.ct td{
    padding:10px 12px;font-size:.78rem;white-space:nowrap
  }
  table.ct th:last-child,table.ct td:last-child{
    min-width:120px
  }
}
@media(max-width:480px){
  table.ct th,table.ct td{padding:8px 10px;font-size:.73rem}
}

/* ── CONNECTIVITY INDEX — mobile ── */
@media(max-width:640px){
  .ci-grid{grid-template-columns:repeat(2,1fr)}
  .ci-cell{padding:18px 16px}
  .ci-n{font-size:1.8rem}
}
@media(max-width:375px){
  .ci-grid{grid-template-columns:1fr}
}

/* ── CARDS — mobile touch ── */
@media(max-width:959px){
  /* disable magnetic tilt on touch devices */
  .cw:hover,.cg:hover{
    transform:translateY(-3px)
  }
  .cw,.cg{
    -webkit-backdrop-filter:blur(8px) saturate(140%);
  }
}

/* ── NAV — mobile ── */
@media(max-width:959px){
  .nlinks{display:none}
  #nav{padding:0 4%}
  .nright{gap:8px}
  .ncta{padding:7px 14px;font-size:.75rem}
  .ntel{display:none}
}
.mmenu{
  padding:20px 5% calc(120px + env(safe-area-inset-bottom, 0px))
}

/* ── PAGE HERO — mobile ── */
@media(max-width:640px){
  .ph{margin-top:60px;padding:44px 5% 28px}
  .phi{text-align:center}
}
/* Quick postcode strip in page heroes */
@media(max-width:540px){
  .phi > div[style*="flex"]{flex-direction:column;align-items:stretch}
  .phi input{width:100%}
  .phi button{width:100%}
}

/* ── INDUSTRY GLASS CARDS — mobile ── */
@media(max-width:640px){
  .ind-grid{grid-template-columns:1fr}
  .ind-card{border-radius:18px;padding:22px 18px}
  .ind-quick{flex-direction:column}
  .ind-quick input,.ind-quick button{width:100%}
}
@media(min-width:641px) and (max-width:900px){
  .ind-grid{grid-template-columns:repeat(2,1fr)}
}

/* ── NETWORK GLASS CARDS — mobile ── */
@media(max-width:640px){
  .net-grid{grid-template-columns:1fr}
  .nc{border-radius:18px;padding:22px 18px}
  .nc-meta{grid-template-columns:1fr 1fr}
  .spd-strip{grid-template-columns:repeat(3,1fr)}
}
@media(min-width:641px) and (max-width:900px){
  .net-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:375px){
  .spd-strip{grid-template-columns:repeat(2,1fr)}
}

/* ── COVERAGE MAP — mobile ── */
@media(max-width:900px){
  .map-wrap{grid-template-columns:1fr}
}

/* ── FOOTER — mobile ── */
@media(max-width:640px){
  .fgrid{grid-template-columns:1fr;gap:28px}
  footer{padding:48px 5% calc(100px + env(safe-area-inset-bottom, 0px))}
  .fbot{flex-direction:column;gap:8px;text-align:center}
  .fleg{font-size:.65rem}
}

/* ── CTA SECTIONS — mobile button stack ── */
@media(max-width:480px){
  .ctabtns{flex-direction:column;align-items:center}
  .ctabtns .btn{width:100%;max-width:300px;justify-content:center}
  .hbtns{flex-direction:column;align-items:stretch}
  .hbtns .btn{justify-content:center}
}

/* ── BREADCRUMB — mobile ── */
@media(max-width:480px){
  .bcrumb{font-size:.7rem;padding:8px 4%}
}

/* ── COVERAGE MAP HEX — mobile ── */
@media(max-width:640px){
  .info-panel{position:static;margin-top:16px}
}

/* ── WHY DIFFERENT GRID — mobile ── */
@media(max-width:640px){
  /* the 3x2 grid in why section */
  div[style*="minmax(280px,1fr)"]{
    grid-template-columns:1fr !important
  }
}

/* ── AUTHORITY BLOCK ON HOMEPAGE — mobile ── */
@media(max-width:640px){
  .ind-auth{grid-template-columns:repeat(2,1fr)}
  .ind-auth-item:nth-child(2n){border-right:none}
  .ind-auth-n{font-size:1.8rem}
}

/* ── TICKER — mobile ── */
@media(max-width:480px){
  .ti{font-size:.68rem;padding:0 16px}
}

/* ── SCROLLBAR STYLING — webkit ── */
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--g3);border-radius:100px}
::-webkit-scrollbar-thumb:hover{background:var(--pk2)}

/* ── SELECTION COLOUR ── */
::selection{background:rgba(255,45,120,.15);color:var(--t1)}
::-moz-selection{background:rgba(255,45,120,.15);color:var(--t1)}

/* ── FOCUS VISIBLE — accessibility ── */
*:focus-visible{
  outline:2px solid var(--pk);
  outline-offset:3px;
  border-radius:4px
}
a:focus-visible,button:focus-visible{outline-offset:4px}

/* ── REDUCED MOTION — accessibility ── */
@media(prefers-reduced-motion:reduce){
  *{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important
  }
  .fu{opacity:1 !important;transform:none !important}
}

/* ── PRINT STYLES ── */
@media print{
  .mbar,.mmenu,#nav,.hbg,.hform,#hcanvas,.tkr{display:none !important}
  .sW,.sG,.sP,.sD{padding:20px 0}
  a[href]::after{content:" (" attr(href) ")";font-size:.7rem;color:#666}
}

/* ── Mobile button tap fix — explicit clickable ── */
.mb-q,.mb-c,.mb-w,.ncta{
  -webkit-tap-highlight-color:rgba(255,45,120,.15);
  position:relative;
  cursor:pointer
}
.mbar{
  z-index:700;
  /* ensure clicks reach buttons */
  pointer-events:auto
}
.mbar a,.mbar button{
  pointer-events:auto;
  cursor:pointer;
  display:flex
}
/* Bigger tap zone on mobile buttons */
@media(max-width:959px){
  .ncta{
    min-height:40px;
    display:inline-flex;
    align-items:center
  }
}

/* ════════════════════════════════════════
   QUOTE MODAL — ELITE BOTTOM SHEET
   ════════════════════════════════════════ */

.qm-overlay{
  position:fixed;inset:0;z-index:2000;
  background:rgba(9,9,11,.55);
  backdrop-filter:blur(12px) saturate(150%);
  -webkit-backdrop-filter:blur(12px) saturate(150%);
  display:flex;align-items:flex-end;justify-content:center;
  opacity:0;pointer-events:none;
  transition:opacity .3s cubic-bezier(.4,0,.2,1)
}
.qm-overlay.open{opacity:1;pointer-events:all}

.qm-sheet{
  background:#fff;
  border-radius:28px 28px 0 0;
  padding:0 0 env(safe-area-inset-bottom,20px);
  width:100%;max-width:560px;
  max-height:92svh;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  position:relative;
  transform:translateY(100%);
  transition:transform .38s cubic-bezier(.32,0,.67,0);
  box-shadow:0 -8px 40px rgba(0,0,0,.18),0 -2px 8px rgba(0,0,0,.08)
}
.qm-overlay.open .qm-sheet{
  transform:translateY(0);
  transition:transform .42s cubic-bezier(.22,1,.36,1)
}

/* Drag handle */
.qm-handle{
  width:40px;height:4px;border-radius:100px;
  background:var(--g3);margin:14px auto 0
}

/* Header */
.qm-hd{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 24px 0
}
.qm-title{
  font-family:var(--fh);font-size:1.05rem;font-weight:800;
  letter-spacing:-.04em;color:var(--t1)
}
.qm-sub{
  font-size:.72rem;color:var(--t3);margin-top:1px
}
.qm-x{
  width:32px;height:32px;border-radius:50%;
  background:var(--g1);border:1px solid var(--g2);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;font-size:1rem;color:var(--t2);
  transition:all .15s;flex-shrink:0;border:none
}
.qm-x:hover{background:var(--g2);color:var(--t1)}

/* Pink top accent */
.qm-accent{
  height:3px;background:linear-gradient(90deg,var(--pk),var(--pk2));
  border-radius:0 0 3px 3px;margin:14px 24px 0
}

/* Form inside modal */
.qm-body{padding:20px 24px 32px}
.qm-body .fprog{margin-bottom:18px}
.qm-body .ftit{font-size:1rem}
.qm-body .fsub{font-size:.7rem;margin-bottom:14px}
.qm-body .fg{margin-bottom:9px}
.qm-body .fbtn{font-size:.9rem;padding:13px}
.qm-body .fnbtn{font-size:.87rem;padding:12px}

/* Success state */
.qm-success{
  display:none;flex-direction:column;align-items:center;
  text-align:center;padding:36px 24px 40px;gap:12px
}
.qm-success.on{display:flex}
.qm-sico{
  width:72px;height:72px;border-radius:50%;
  background:var(--pk3);border:2px solid var(--pk4);
  display:flex;align-items:center;justify-content:center;
  font-size:2rem;margin-bottom:4px
}
.qm-stitle{
  font-family:var(--fh);font-size:1.2rem;font-weight:900;
  letter-spacing:-.04em;color:var(--t1)
}
.qm-sdesc{font-size:.86rem;color:var(--t2);line-height:1.65;max-width:300px}
.qm-strust{font-size:.69rem;color:var(--t3)}

/* Desktop — centered card not bottom sheet */
@media(min-width:640px){
  .qm-overlay{align-items:center;padding:20px}
  .qm-sheet{
    border-radius:24px;
    max-height:88svh;
    transform:scale(.94) translateY(16px);
    transition:transform .3s cubic-bezier(.4,0,.2,1);
    box-shadow:0 24px 80px rgba(0,0,0,.2),0 8px 24px rgba(0,0,0,.1)
  }
  .qm-overlay.open .qm-sheet{
    transform:scale(1) translateY(0);
    transition:transform .4s cubic-bezier(.22,1,.36,1)
  }
  .qm-handle{display:none}
  .qm-sheet{padding-bottom:0}
}

/* ── Footer 5-column grid ── */
.fgrid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1fr;gap:28px}
@media(max-width:960px){.fgrid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:640px){.fgrid{grid-template-columns:repeat(2,1fr);gap:20px}}
@media(max-width:400px){.fgrid{grid-template-columns:1fr}}
.flinks li{margin-bottom:5px}
.flinks a{font-size:.77rem}
