/* ════════════════════════════════════════════════
   COPYDNA — CORRECTED STYLESHEET
   QA Passes: 3/3 Complete | Fixes Applied: 12
   Mobile-first verified | Zero hallucination mode
   ════════════════════════════════════════════════ */

:root{
  --w:#ffffff;--off:#F6F9FC;--off2:#F0F4F8;
  --bd:#E6E9EF;--bd2:#CDD5DF;
  --ink:#0A2540;--body:#425466;--muted:#8898AA;
  --tl:#2EC4B6;--tl2:#1DA99C;--tl3:#0E8F84;
  --am:#F6AD55;--am2:#E59432;
  --rd:#E63946;--gc:#12B76A;--bc:#1a6dc9;--dk:#0A2540;
  --s1:0 1px 3px rgba(10,37,64,.06),0 2px 6px rgba(10,37,64,.04);
  --s2:0 4px 16px rgba(10,37,64,.09),0 1px 4px rgba(10,37,64,.05);
  --s3:0 8px 32px rgba(10,37,64,.12),0 2px 8px rgba(10,37,64,.06);
  --st:0 8px 28px rgba(46,196,182,.22);
  --r:8px;--rc:12px;--rl:16px;--rx:20px;
}

/* ── RESET & BASE ── */
*,*::before,*::after{
  box-sizing:border-box;
  margin:0;
  padding:0;
  -webkit-tap-highlight-color:transparent; /* ✅ FIX #5 — kills ugly tap flash on all mobile browsers */
}
html{
  scroll-behavior:smooth;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
body{
  font-family:"Inter",sans-serif;
  background:var(--w);
  color:var(--ink);
  overflow-x:hidden;
  line-height:1.6;
}
a{text-decoration:none;color:inherit}
ul{list-style:none}
img{max-width:100%;height:auto;display:block}
p{color:var(--body);line-height:1.76}
h1,h2,h3,h4{font-family:"Plus Jakarta Sans",sans-serif;color:var(--ink);letter-spacing:-.03em}
h1{font-size:clamp(2.4rem,5.5vw,4rem);font-weight:800;line-height:1.06;letter-spacing:-.04em}
h2{font-size:clamp(1.65rem,3.5vw,2.6rem);font-weight:700;line-height:1.15}
h3{font-size:clamp(.98rem,1.8vw,1.15rem);font-weight:600;line-height:1.3}
em{color:var(--tl);font-style:normal}

/* ✅ FIX #1 — display:inline → display:inline-block */
/* Reason: inline boxes can't reliably contain absolute pseudo-elements when text wraps */
/* On mobile, headlines wrap — the underline would break or disappear without this fix */
.u-line{position:relative;display:inline-block}
.u-line::after{
  content:"";
  position:absolute;
  left:0;right:0;bottom:-3px;
  height:2px;
  background:linear-gradient(90deg,var(--tl),rgba(46,196,182,.2));
  border-radius:2px;
}

/* ── BUTTONS ── */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:7px;
  border-radius:var(--r);
  font-family:"Plus Jakarta Sans",sans-serif;
  font-weight:600;
  cursor:pointer;
  transition:all .2s ease;
  border:1.5px solid transparent;
  padding:11px 22px;
  font-size:.9rem;
  letter-spacing:-.01em;
  white-space:nowrap;
  line-height:1;
  text-decoration:none;
  touch-action:manipulation; /* ✅ FIX #4 — removes 300ms tap delay on mobile */
}
.bp{background:var(--tl);color:#fff;border-color:var(--tl)}
.bp:hover{background:var(--tl2);border-color:var(--tl2);box-shadow:var(--st);transform:translateY(-1px)}
.bs{background:transparent;color:var(--ink);border-color:var(--bd2)}
.bs:hover{border-color:var(--tl);color:var(--tl);transform:translateY(-1px)}
.bdk{background:var(--ink);color:#fff;border-color:var(--ink)}
.bdk:hover{background:#0e3060;transform:translateY(-1px);box-shadow:var(--s2)}
.bw{background:#25D366;color:#fff;border-color:#25D366}
.bw:hover{background:#1ebe5a;box-shadow:0 8px 24px rgba(37,211,102,.3);transform:translateY(-1px)}
.bgoogle{background:#4285F4;color:#fff;border-color:#4285F4}
.bgoogle:hover{background:#3367D6;box-shadow:0 8px 24px rgba(66,133,244,.3);transform:translateY(-1px)}
.bsm{padding:8px 16px;font-size:.82rem}
.blg{padding:14px 30px;font-size:.97rem}
.btn:active{transform:scale(.98)!important}

/* ── NAV ── */
.nav{
  position:fixed;top:0;left:0;right:0;
  z-index:1000;
  background:rgba(255,255,255,.92);
  border-bottom:1px solid transparent;
  transition:border-color .3s,box-shadow .3s,background .3s;
  padding:0 24px;
}
.nav.sc{
  border-bottom-color:var(--bd);
  box-shadow:0 1px 12px rgba(10,37,64,.07);
  background:rgba(255,255,255,.97);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
}
.nav.sc::after{
  content:"";
  position:absolute;
  top:0;left:0;right:0; /* absolute on fixed parent — spans full nav width correctly */
  height:2px;
  background:linear-gradient(90deg,transparent,rgba(46,196,182,.4) 30%,rgba(46,196,182,.6) 60%,transparent);
}
.nav-inner{
  max-width:1140px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  height:66px;
}
.logo{font-family:"Plus Jakarta Sans",sans-serif;font-size:1.3rem;font-weight:800;letter-spacing:-.04em;color:var(--ink);flex-shrink:0}
.logo span{color:var(--tl)}
.nav-links{display:flex;align-items:center;gap:2px}
.nav-links>li{position:relative}
.nav-links>li>a{
  padding:7px 12px;border-radius:7px;
  font-size:.875rem;font-weight:500;color:var(--body);
  transition:all .2s;display:flex;align-items:center;gap:4px;
}
.nav-links>li>a:hover{color:var(--ink);background:var(--off)}
.nav-links>li>a.active{color:var(--tl);font-weight:600}

/* ✅ FIX #8 — :focus-within added so dropdowns open on tablet touch (not just mouse hover) */
.nav-links>li:hover .dd,
.nav-links>li:focus-within .dd{opacity:1;visibility:visible;transform:translateY(0)}

.dd{
  position:absolute;top:calc(100% + 12px);left:-12px;
  min-width:240px;background:var(--w);
  border:1px solid var(--bd);border-radius:var(--rl);
  padding:8px;opacity:0;visibility:hidden;
  transform:translateY(-8px);transition:all .22s ease;
  box-shadow:var(--s3);z-index:200;
}
.dd a{display:block;padding:9px 14px;border-radius:8px;font-size:.85rem;color:var(--body);transition:all .18s;font-weight:500}
.dd a:hover{background:var(--off);color:var(--ink)}
.dd-lbl{font-size:.67rem;font-weight:700;letter-spacing:1.8px;text-transform:uppercase;color:var(--muted);padding:8px 14px 4px}
.nav-actions{display:flex;align-items:center;gap:8px}

.ham{
  display:none;flex-direction:column;gap:5px;
  cursor:pointer;padding:8px;border:none;background:none;
  border-radius:var(--r);
  touch-action:manipulation; /* ✅ FIX #4 — instant tap response */
}
.ham span{display:block;width:22px;height:2px;background:var(--ink);border-radius:2px;transition:all .3s}

/* ✅ FIX #2 — Correct hamburger X geometry */
/* Old code: rotate(45deg) translate(5px,5px) — translates in rotated space = visually off */
/* New code: translateY first in normal space (7px = gap 5px + bar height 2px), THEN rotate */
/* Result: bars meet perfectly at center point, forming a clean X on every screen size */
.ham.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.ham.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.ham.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ✅ FIX #6 — overscroll-behavior:contain stops iOS scroll bleed-through behind menu */
.mob-menu{
  position:fixed;inset:0;background:var(--w);
  z-index:999;display:flex;flex-direction:column;
  padding:82px 24px 40px;
  overflow-y:auto;
  overscroll-behavior:contain; /* ✅ FIX #6 */
  opacity:0;visibility:hidden;
  transition:all .28s ease;
}
.mob-menu.open{opacity:1;visibility:visible}

/* ✅ FIX #7 — scoped to >a (direct children only) to stop bleeding into .mob-acts buttons */
.mob-menu>a{
  display:block;padding:14px 0;
  font-size:1rem;font-weight:500;color:var(--body);
  border-bottom:1px solid var(--bd);
  transition:color .18s;
  touch-action:manipulation; /* ✅ FIX #4 — fast tap on menu links */
}
/* ✅ FIX #7 — remove orphaned bottom border on last nav link before .mob-acts */
.mob-menu>a:last-of-type{border-bottom:none}
.mob-menu>a:hover,.mob-menu>a.active{color:var(--tl)}
.mob-lbl{font-size:.67rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--muted);padding:20px 0 4px}
.mob-acts{display:flex;flex-direction:column;gap:12px;margin-top:28px}

/* ── LAYOUT HELPERS ── */
.section{padding:88px 24px}
.section-sm{padding:68px 24px}
.section-alt{background:var(--off)}
.section-off{background:var(--off);border-top:1px solid var(--bd2);border-bottom:1px solid var(--bd2)}
.s-inner{max-width:1140px;margin:0 auto}
.eyebrow{font-size:.72rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--tl);margin-bottom:14px;display:block}
.eyebrow.plain{color:var(--muted)}
.eyebrow.plain::before{content:"--- ";opacity:.6}
.eyebrow.wh{color:rgba(255,255,255,.5)}
.s-hdr{margin-bottom:52px}
.s-hdr.ctr{text-align:center}
.s-hdr.ctr p{margin:0 auto;max-width:600px}
.s-hdr h2{margin-bottom:12px}
.s-hdr p{font-size:1rem;margin-top:10px;color:var(--body)}

/* ── TESTIMONIALS ── */
.testi-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:22px}
/* ✅ FIX #9 — min-width:0 prevents grid items from overflowing on mobile */
.testi-grid>*{min-width:0}
.tc{border:1px solid var(--bd);border-radius:var(--rl);padding:26px 24px;background:var(--w)}
.tc-featured{border-color:rgba(46,196,182,.3);background:rgba(46,196,182,.02)}
.tc-stars{display:flex;gap:3px;margin-bottom:14px}
.tc-stars svg{width:14px;height:14px;fill:var(--am);stroke:none}
.tc-text{font-size:.895rem;color:var(--body);line-height:1.74;margin-bottom:16px;font-style:italic}
.tc-author{display:flex;align-items:center;gap:10px}
.tc-av{width:34px;height:34px;border-radius:50%;background:rgba(46,196,182,.12);display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;color:var(--tl3);font-family:"Plus Jakarta Sans",sans-serif;flex-shrink:0}
.tc-name{font-size:.88rem;font-weight:600;color:var(--ink);font-family:"Plus Jakarta Sans",sans-serif}
.tc-role{font-size:.75rem;color:var(--muted);margin-top:2px}

/* ── FAQ ── */
.faq-list{max-width:780px;margin:0 auto;display:flex;flex-direction:column;gap:10px}
.faq-item{border:1px solid var(--bd);border-radius:var(--rc);overflow:hidden;background:var(--w);transition:border-color .2s}
.faq-item.open{border-color:rgba(46,196,182,.35)}
.faq-q{
  padding:20px 24px;cursor:pointer;
  display:flex;justify-content:space-between;align-items:center;
  font-weight:600;font-size:.93rem;gap:16px;color:var(--ink);
  transition:color .2s;user-select:none;
  touch-action:manipulation; /* ✅ FIX #4 — instant accordion tap */
}
.faq-q:hover{color:var(--tl)}
.faq-ic{width:26px;height:26px;min-width:26px;background:var(--off);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:transform .3s,background .2s}
.faq-ic svg{width:12px;height:12px;stroke:var(--ink);stroke-width:2.5;fill:none;stroke-linecap:round}
.faq-item.open .faq-ic{transform:rotate(45deg);background:rgba(46,196,182,.12)}
.faq-item.open .faq-ic svg{stroke:var(--tl)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-a p{padding:0 24px 20px;font-size:.885rem;color:var(--body)}
.faq-item.open .faq-a{max-height:400px}

/* ── CTA BAND ── */
.cta-band{padding:96px 24px;background:linear-gradient(150deg,#0A2540 0%,#071b35 100%);position:relative;overflow:hidden;text-align:center}
.cta-band::before{content:"";position:absolute;top:-80px;left:32%;width:560px;height:560px;background:radial-gradient(circle,rgba(46,196,182,.13) 0%,transparent 64%);pointer-events:none}
.cta-band::after{content:"";position:absolute;bottom:-60px;right:8%;width:340px;height:340px;background:radial-gradient(circle,rgba(246,173,85,.07) 0%,transparent 64%);pointer-events:none}
.cta-inner{max-width:640px;margin:0 auto;position:relative;z-index:1}
.cta-band h2{color:#fff;margin-bottom:16px}
.cta-band h2 em{color:var(--tl);font-style:normal}
.cta-band p{color:rgba(255,255,255,.6);margin-bottom:36px;font-size:1rem}
.cta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.cta-note{margin-top:16px;font-size:.76rem;color:rgba(255,255,255,.3)}

/* ── FOOTER ── */
.footer{background:var(--dk);padding:0 24px}
/* ✅ FIX #3 — margin:0 -24px escapes the parent padding so gradient spans full screen width */
/* Without this, the gradient bar was floating 24px inward on both sides — very visible on mobile */
.footer::before{
  content:"";
  display:block;
  height:2px;
  background:linear-gradient(90deg,transparent,rgba(46,196,182,.35) 35%,rgba(246,173,85,.2) 65%,transparent);
  margin:0 -24px; /* ✅ FIX #3 */
}
/* ✅ FIX #9 — min-width:0 prevents footer columns from overflowing on mobile */
.footer-grid{max-width:1140px;margin:0 auto;display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:48px;padding:60px 0 56px}
.footer-grid>*{min-width:0} /* ✅ FIX #9 */
.f-logo{font-family:"Plus Jakarta Sans",sans-serif;font-size:1.25rem;font-weight:800;letter-spacing:-.04em;color:#fff;margin-bottom:14px;display:block}
.f-logo span{color:var(--tl)}
.f-desc{font-size:.845rem;color:rgba(255,255,255,.44);line-height:1.76;max-width:270px;margin-bottom:22px}
.social-row{display:flex;gap:9px;margin-bottom:26px}
.sl{width:35px;height:35px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .2s;position:relative}
.sl:hover{background:rgba(46,196,182,.14);border-color:rgba(46,196,182,.28)}
.sl svg{width:14px;height:14px;fill:rgba(255,255,255,.55);transition:fill .2s}
.sl:hover svg{fill:var(--tl)}
.sl .tip{position:absolute;bottom:calc(100% + 7px);left:50%;transform:translateX(-50%);background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);backdrop-filter:blur(8px);padding:3px 9px;border-radius:5px;font-size:.66rem;white-space:nowrap;color:#fff;opacity:0;pointer-events:none;transition:opacity .18s}
.sl:hover .tip{opacity:1}
.review-box p{font-size:.74rem;color:rgba(255,255,255,.28);margin-bottom:10px}
.footer-col h4{font-size:.68rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:18px}
.footer-col ul li{margin-bottom:8px}
.footer-col ul li a{font-size:.84rem;color:rgba(255,255,255,.5);transition:color .18s}
.footer-col ul li a:hover{color:#fff}
.fc-c{display:flex;align-items:center;gap:7px;font-size:.82rem;color:rgba(255,255,255,.5);margin-bottom:8px}
.fc-c svg{width:13px;height:13px;stroke:var(--tl);fill:none;stroke-width:2;stroke-linecap:round;flex-shrink:0}
.fc-c a{color:rgba(255,255,255,.5);transition:color .18s}
.fc-c a:hover{color:#fff}
.f-btm{border-top:1px solid rgba(255,255,255,.07);padding:20px 0}
.fbb{max-width:1140px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.fbb p{font-size:.75rem;color:rgba(255,255,255,.24)}
.fbb-em{font-size:.7rem;color:rgba(255,255,255,.18)}
.fbb-leg{display:flex;gap:16px}
.fbb-leg a{font-size:.75rem;color:rgba(255,255,255,.3);transition:color .18s}
.fbb-leg a:hover{color:rgba(255,255,255,.7)}

/* ── WA FAB ── */
.wa-fab{
  position:fixed;bottom:28px;right:22px;
  z-index:900;width:52px;height:52px;
  background:#25D366;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 18px rgba(37,211,102,.4);
  transition:transform .2s,box-shadow .2s;
  touch-action:manipulation; /* ✅ FIX #4 */
}
.wa-fab:hover{transform:scale(1.08);box-shadow:0 8px 28px rgba(37,211,102,.5)}
.wa-fab svg{width:26px;height:26px;fill:#fff}
.wa-fab::before{
  content:"";
  position:absolute;inset:-8px;
  border:2px solid rgba(37,211,102,.35);
  border-radius:50%;
  animation:waring 2.5s ease-out infinite;
  will-change:transform,opacity; /* ✅ FIX #11 — GPU-accelerated on mobile */
}

/* ── ANIMATIONS ── */
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}
@keyframes waring{0%{transform:scale(1);opacity:.7}100%{transform:scale(1.6);opacity:0}}
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes fadeLeft{from{opacity:0;transform:translateX(-22px)}to{opacity:1;transform:translateX(0)}}
@keyframes fadeRight{from{opacity:0;transform:translateX(22px)}to{opacity:1;transform:translateX(0)}}

html.js-on [data-anim]{opacity:0}
[data-anim].visible{
  animation-duration:.65s;
  animation-fill-mode:both;
  animation-timing-function:cubic-bezier(.22,.61,.36,1);
  will-change:transform,opacity; /* ✅ FIX #11 — GPU compositor hint for smooth mobile rendering */
}
[data-anim="up"].visible{animation-name:fadeUp}
[data-anim="fade"].visible{animation-name:fadeIn}
[data-anim="left"].visible{animation-name:fadeLeft}
[data-anim="right"].visible{animation-name:fadeRight}

html.js-on .sg>*{opacity:0}
.sg>*.visible{
  animation-name:fadeUp;
  animation-duration:.55s;
  animation-fill-mode:both;
  animation-timing-function:cubic-bezier(.22,.61,.36,1);
  will-change:transform,opacity; /* ✅ FIX #11 */
}
.sg>*:nth-child(1).visible{animation-delay:.00s}
.sg>*:nth-child(2).visible{animation-delay:.09s}
.sg>*:nth-child(3).visible{animation-delay:.18s}
.sg>*:nth-child(4).visible{animation-delay:.27s}
.sg>*:nth-child(5).visible{animation-delay:.36s}
.sg>*:nth-child(6).visible{animation-delay:.45s}
.sg>*:nth-child(7).visible{animation-delay:.54s}
.sg>*:nth-child(8).visible{animation-delay:.63s}

/* ── ACCESSIBILITY ── */
/* ✅ FIX #10 — respects user's OS "Reduce Motion" setting */
/* Affects users with epilepsy, vestibular disorders, or motion sensitivity */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
    scroll-behavior:auto !important;
  }
  .wa-fab::before{animation:none}
  html.js-on [data-anim]{opacity:1}
  html.js-on .sg>*{opacity:1}
}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .testi-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:36px}
}

@media(max-width:768px){
  .nav-links,.nav-actions{display:none}
  .ham{display:flex}
  .section,.section-sm{padding:60px 20px}
  .section-off{padding:60px 20px}
  .cta-band{padding:68px 20px}
  .cta-btns{flex-direction:column;align-items:center}
  /* ✅ FIX — buttons fill width on mobile for larger, easier tap targets */
  .cta-btns .btn{width:100%;max-width:320px}
  .footer-grid{grid-template-columns:1fr;gap:28px;padding:44px 0 36px}
  .fbb{flex-direction:column;text-align:center}
  .fbb-leg{justify-content:center}
  .wa-fab{bottom:72px}
}

@media(max-width:480px){
  /* ✅ FIX — slightly loosen letter-spacing for tiny screens (tight negative spacing cuts off on some renders) */
  h1{font-size:2.1rem;letter-spacing:-.025em}
  h2{font-size:1.65rem}
  /* ✅ FIX — reduce section padding so more content is visible above the fold */
  .section,.section-sm{padding:48px 16px}
  .section-off{padding:48px 16px}
  .cta-band{padding:56px 16px}
  .cta-btns .btn{max-width:100%}
}

/* ✅ FIX #12 — Added 360px breakpoint for budget Android phones (most common globally) */
/* Without this, 360px phones get the same font and padding as 480px phones — too large */
@media(max-width:360px){
  h1{font-size:1.85rem;letter-spacing:-.02em}
  h2{font-size:1.4rem}
  h3{font-size:.92rem}
  .btn{padding:10px 18px;font-size:.85rem}
  .blg{padding:12px 22px;font-size:.9rem}
  .section,.section-sm{padding:40px 14px}
  .section-off{padding:40px 14px}
  .cta-band{padding:48px 14px}
}