/* MyAfya Profile — landing page styles */
:root{
  --blue-50:#eff6ff; --blue-100:#dbeafe; --blue-200:#bfdbfe; --blue-500:#3b82f6;
  --blue-600:#2563eb; --blue-700:#1d4ed8; --blue-800:#1e40af; --blue-900:#1e3a8a;
  --amber:#fbbf24; --amber-600:#f59e0b;
  --ink:#0b1220; --text:#1e293b; --body:#475569; --muted:#64748b; --mute2:#94a3b8;
  --line:#e6ebf2; --line2:#f1f5f9; --bg:#ffffff; --soft:#f6f9fc;
  --shadow-sm:0 2px 8px -2px rgba(15,23,42,.08);
  --shadow:0 18px 50px -24px rgba(15,23,42,.28);
  --shadow-blue:0 24px 60px -24px rgba(37,99,235,.45);
  --r:18px; --maxw:1200px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; background:var(--bg); color:var(--text);
  font-family:"Plus Jakarta Sans",-apple-system,BlinkMacSystemFont,system-ui,sans-serif;
  -webkit-font-smoothing:antialiased; line-height:1.6; overflow-x:hidden;
}
a{color:inherit; text-decoration:none}
img{max-width:100%; display:block}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 28px}
.eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  font-size:12.5px; font-weight:700; letter-spacing:.08em; text-transform:uppercase;
  color:var(--blue-700); background:var(--blue-50);
  padding:7px 14px; border-radius:99px; border:1px solid var(--blue-100);
}
h1,h2,h3{margin:0; letter-spacing:-.02em; color:var(--ink); font-weight:800}
.h2{font-size:clamp(28px,3.4vw,44px); line-height:1.1}
.lead{font-size:clamp(16px,1.3vw,18px); color:var(--body); line-height:1.65}
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  height:52px; padding:0 26px; border-radius:14px; border:1px solid transparent;
  font-weight:700; font-size:15.5px; cursor:pointer; font-family:inherit;
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease;
}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--blue-600); color:#fff; box-shadow:var(--shadow-blue)}
.btn-primary:hover{background:var(--blue-700)}
.btn-ghost{background:#fff; color:var(--ink); border-color:var(--line)}
.btn-ghost:hover{border-color:var(--blue-200); background:var(--blue-50)}

/* ── Nav ─────────────────────────────────── */
.nav{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,.92); backdrop-filter:blur(16px) saturate(180%);
  border-bottom:1px solid transparent; transition:border-color .2s, box-shadow .2s;
}
.nav.scrolled{border-color:var(--line); box-shadow:0 4px 20px -12px rgba(15,23,42,.2)}
.nav-in{display:flex; align-items:center; gap:24px; height:72px; min-width:0}
.logo{
  display:flex; align-items:center; gap:10px; font-weight:800; font-size:19px; color:var(--ink);
  flex-shrink:0; min-width:0;
}
.logo-img{height:42px; width:auto; max-width:100%; display:block; object-fit:contain; object-position:left center}
.footer .logo-img{height:46px}
.logo-mark{
  width:38px; height:38px; border-radius:11px;
  background:linear-gradient(140deg,var(--blue-500),var(--blue-700));
  display:grid; place-items:center; box-shadow:var(--shadow-blue);
}
.nav-links{display:flex; gap:30px; margin-left:18px}
.nav-links a{font-size:14.5px; font-weight:600; color:var(--body); transition:color .15s}
.nav-links a:hover{color:var(--blue-700)}
.nav-cta{margin-left:auto; display:flex; align-items:center; gap:12px}
.nav-cta .btn{height:44px; padding:0 20px; font-size:14.5px}
.nav-signin{border:0; background:transparent; box-shadow:none}
.nav-actions{display:none; align-items:center; gap:8px; margin-left:auto; flex-shrink:0}
.nav-book-compact{
  display:inline-flex; height:40px; padding:0 16px; font-size:14px; font-weight:700;
  white-space:nowrap; border-radius:12px; line-height:1;
}
.menu-btn{
  display:none; width:40px; height:40px; padding:0; border:1px solid var(--line);
  border-radius:12px; background:#fff; cursor:pointer; place-items:center; flex-shrink:0;
  transition:border-color .15s, background .15s;
}
.menu-btn:hover{border-color:var(--blue-200); background:var(--blue-50)}
.menu-icon{
  display:block; width:18px; height:2px; background:var(--ink); border-radius:99px;
  position:relative; transition:background .15s;
}
.menu-icon::before,.menu-icon::after{
  content:""; position:absolute; left:0; width:18px; height:2px; border-radius:99px;
  background:var(--ink); transition:transform .2s ease, top .2s ease;
}
.menu-icon::before{top:-6px}
.menu-icon::after{top:6px}
.nav.menu-open .menu-icon{background:transparent}
.nav.menu-open .menu-icon::before{top:0; transform:rotate(45deg)}
.nav.menu-open .menu-icon::after{top:0; transform:rotate(-45deg)}
.nav-drawer{
  position:absolute; left:0; right:0; top:100%; z-index:49;
  background:#fff; border-bottom:1px solid var(--line);
  box-shadow:0 18px 40px -24px rgba(15,23,42,.28);
  padding:18px 28px 24px;
}
.nav-drawer-links{display:flex; flex-direction:column; gap:4px}
.nav-drawer-links a{
  display:block; padding:14px 12px; border-radius:12px;
  font-size:16px; font-weight:700; color:var(--ink);
}
.nav-drawer-links a:hover{background:var(--blue-50); color:var(--blue-700)}
.nav-drawer-cta{display:grid; gap:10px; margin-top:16px; padding-top:16px; border-top:1px solid var(--line2)}
.nav-drawer-cta .btn{width:100%; height:48px}
.nav-backdrop{
  position:fixed; inset:0; z-index:40; background:rgba(15,23,42,.42);
  backdrop-filter:blur(2px);
}
body.nav-open{overflow:hidden}
.btn-lg{height:52px; padding:0 26px; font-size:16px}
.btn-cta-light{background:#fff; color:var(--ink); font-weight:800}
.btn-cta-outline{background:transparent; color:#fff; border:1.5px solid rgba(255,255,255,.4)}

/* ── Hero ─────────────────────────────────── */
.hero{position:relative; padding:64px 0 90px; overflow:hidden}
.hero-bg{
  position:absolute; inset:0; z-index:0; pointer-events:none;
}
.hero-bg .blob{position:absolute; border-radius:50%; filter:blur(10px)}
.hero-grid{
  position:relative; z-index:1;
  display:grid; grid-template-columns:1.05fr .95fr; gap:48px; align-items:center;
}
.hero h1{font-size:clamp(34px,4.6vw,60px); line-height:1.04; margin:20px 0 0}
.hero h1 .hl{color:var(--blue-600); position:relative; white-space:nowrap}
.hero .lead{margin:22px 0 0; max-width:520px}
.hero-cta{display:flex; gap:14px; margin-top:32px; flex-wrap:wrap}
.stores{display:flex; gap:12px; margin-top:26px; flex-wrap:wrap}
.store{
  display:flex; align-items:center; gap:11px; height:54px; padding:0 18px;
  background:var(--ink); color:#fff; border-radius:13px; transition:transform .15s, opacity .15s;
}
.store:hover{transform:translateY(-2px)}
.store small{display:block; font-size:10.5px; opacity:.75; line-height:1.1; font-weight:600}
.store b{font-size:16px; font-weight:700; letter-spacing:-.01em}
.trust{display:flex; align-items:center; gap:22px; margin-top:34px; flex-wrap:wrap}
.trust .avs{display:flex}
.trust .avs span{
  width:38px; height:38px; border-radius:50%; margin-left:-10px;
  border:2.5px solid #fff; display:grid; place-items:center;
  font-size:13px; font-weight:800; color:#fff;
}
.trust .avs span:first-child{margin-left:0}
.trust-txt{font-size:13.5px; color:var(--muted); font-weight:500}
.trust-txt b{color:var(--ink)}

/* ── Phone mockup ─────────────────────────── */
.phone-stage{position:relative; display:grid; place-items:center; min-height:560px}
.phone{
  position:relative; width:296px; height:602px; border-radius:46px;
  background:#0b1220; padding:11px; z-index:2;
  box-shadow:0 50px 90px -30px rgba(15,23,42,.55), 0 0 0 1px rgba(15,23,42,.1);
}
.phone-screen{
  width:100%; height:100%; border-radius:36px; overflow:hidden;
  background:var(--soft); position:relative;
}
.phone-notch{
  position:absolute; top:11px; left:50%; transform:translateX(-50%);
  width:104px; height:30px; border-radius:20px; background:#0b1220; z-index:5;
}
.float-card{
  position:absolute; z-index:3; background:#fff; border-radius:16px;
  box-shadow:var(--shadow); padding:13px 15px; display:flex; align-items:center; gap:11px;
  border:1px solid var(--line);
}
.float-card .ic{width:38px; height:38px; border-radius:11px; display:grid; place-items:center; flex-shrink:0}
.float-card .t1{font-size:13px; font-weight:800; color:var(--ink); line-height:1.2}
.float-card .t2{font-size:11.5px; color:var(--muted)}
.fc-a{top:64px; left:-26px; animation:floaty 5s ease-in-out infinite}
.fc-b{bottom:96px; right:-30px; animation:floaty 6s ease-in-out infinite .8s}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

/* in-phone home preview */
.pv{font-size:11px; color:var(--text)}
.pv-hd{
  background:linear-gradient(160deg,var(--blue-500),var(--blue-700));
  padding:34px 16px 40px; border-radius:0 0 26px 26px; color:#fff; position:relative; overflow:hidden;
}
.pv-hd .pvblob{position:absolute; border-radius:50%; background:rgba(255,255,255,.12)}
.pv-row{display:flex; align-items:center; gap:8px; position:relative}
.pv-av{width:30px; height:30px; border-radius:50%; background:rgba(255,255,255,.92); display:grid; place-items:center; color:var(--blue-700); font-weight:800; font-size:12px}
.pv-hello{font-size:9.5px; opacity:.85}
.pv-loc{font-size:11px; font-weight:700; display:flex; align-items:center; gap:3px}
.pv-h1{font-size:17px; font-weight:800; letter-spacing:-.02em; margin-top:14px; line-height:1.15; position:relative}
.pv-h1 i{color:var(--amber); font-style:normal}
.pv-search{margin-top:12px; background:#fff; border-radius:12px; height:38px; display:flex; align-items:center; gap:8px; padding:0 11px; position:relative; box-shadow:0 8px 18px -10px rgba(0,0,0,.4)}
.pv-search .dot{width:26px; height:26px; border-radius:8px; background:var(--blue-600); margin-left:auto}
.pv-card{
  margin:-22px 14px 0; background:#fff; border:1px solid var(--line); border-radius:16px;
  padding:11px 12px; box-shadow:var(--shadow); position:relative; z-index:2;
}
.pv-tag{font-size:8px; font-weight:800; letter-spacing:.06em; color:var(--muted); text-transform:uppercase}
.pv-appt{display:flex; align-items:center; gap:9px; margin-top:8px}
.pv-appt .a{width:34px; height:34px; border-radius:50%; background:#fee2e2; display:grid; place-items:center; font-weight:800; color:#991b1b; font-size:11px}
.pv-appt .nm{font-size:11.5px; font-weight:800; color:var(--ink)}
.pv-appt .mt{font-size:9.5px; color:var(--muted)}
.pv-join{margin-left:auto; background:var(--blue-600); color:#fff; font-size:10px; font-weight:800; padding:6px 12px; border-radius:99px}
.pv-quick{display:grid; grid-template-columns:repeat(4,1fr); gap:7px; padding:14px 14px 0}
.pv-q{background:#fff; border:1px solid var(--line); border-radius:13px; padding:9px 2px; display:flex; flex-direction:column; align-items:center; gap:5px}
.pv-q .qi{width:30px; height:30px; border-radius:10px; display:grid; place-items:center}
.pv-q small{font-size:8.5px; font-weight:700; color:var(--text)}
.pv-sec{font-size:12px; font-weight:800; color:var(--ink); padding:16px 14px 0; display:flex; align-items:center; justify-content:space-between}
.pv-sec span{font-size:9.5px; color:var(--blue-600); font-weight:700}
.pv-docs{display:flex; gap:9px; padding:10px 14px 0; overflow:hidden}
.pv-doc{flex:none; width:108px; background:#fff; border:1px solid var(--line); border-radius:14px; overflow:hidden}
.pv-doc .band{height:30px}
.pv-doc .bd{padding:0 9px 10px; margin-top:-14px}
.pv-doc .da{width:28px; height:28px; border-radius:50%; border:2px solid #fff; display:grid; place-items:center; font-weight:800; font-size:10px; color:#1e3a8a}
.pv-doc .dn{font-size:10px; font-weight:800; color:var(--ink); margin-top:5px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.pv-doc .ds{font-size:8.5px; color:var(--muted)}
.pv-doc .df{font-size:10px; font-weight:800; color:var(--blue-700); margin-top:6px}

/* ── Logo strip ──────────────────────────── */
.strip{padding:30px 0 8px; border-top:1px solid var(--line2)}
.strip p{text-align:center; font-size:12.5px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--mute2); margin:0 0 18px}
.strip-row{display:flex; align-items:center; justify-content:center; gap:46px; flex-wrap:wrap; opacity:.8}
.strip-row .li{font-weight:800; font-size:17px; color:var(--muted); display:flex; align-items:center; gap:8px}

/* ── Section ─────────────────────────────── */
.section{padding:88px 0}
.section.soft{background:var(--soft)}
.sec-head{max-width:680px; margin:0 auto 52px; text-align:center}
.sec-head .lead{margin:16px auto 0}

/* ── Stats ───────────────────────────────── */
.stats{display:grid; grid-template-columns:repeat(4,1fr); gap:24px}
.stat{text-align:center; padding:10px}
.stat .num{font-size:clamp(32px,3.6vw,46px); font-weight:800; color:var(--blue-700); letter-spacing:-.03em; line-height:1}
.stat .lbl{font-size:14px; color:var(--muted); font-weight:600; margin-top:8px}

/* ── Features bento ──────────────────────── */
.bento{display:grid; grid-template-columns:repeat(6,1fr); gap:18px}
.feat{
  background:#fff; border:1px solid var(--line); border-radius:24px; padding:26px;
  position:relative; overflow:hidden; transition:transform .2s, box-shadow .2s, border-color .2s;
}
.feat:hover{transform:translateY(-4px); box-shadow:var(--shadow); border-color:var(--blue-200)}
.feat.lg{grid-column:span 3}
.feat.sm{grid-column:span 2}
.feat.wide{grid-column:span 3}
.feat .fi{width:50px; height:50px; border-radius:15px; display:grid; place-items:center; margin-bottom:16px}
.feat h3{font-size:19px; margin-bottom:8px}
.feat p{margin:0; font-size:14.5px; color:var(--body); line-height:1.6}
.feat .deco{position:absolute; right:-20px; bottom:-20px; opacity:.06}

/* ── Showcase gallery ────────────────────── */
.showcase{padding:88px 0 96px}
.gallery{
  display:flex; gap:30px; align-items:flex-start; justify-content:flex-start;
  padding:20px 28px 24px; margin:0 -28px;
  overflow-x:auto; scroll-snap-type:x mandatory; scrollbar-width:none;
}
.gallery::-webkit-scrollbar{display:none}
.gallery > div{scroll-snap-align:center; flex:0 0 auto}
.mock{
  position:relative; width:240px; height:506px; border-radius:40px;
  background:#0b1220; padding:9px; flex-shrink:0;
  box-shadow:0 40px 70px -34px rgba(15,23,42,.5), 0 0 0 1px rgba(15,23,42,.08);
  transition:transform .25s ease;
}
.mock:hover{transform:translateY(-8px)}
.mock.tall{width:240px; height:506px}
.mock-notch{position:absolute; top:9px; left:50%; transform:translateX(-50%); width:84px; height:24px; border-radius:16px; background:#0b1220; z-index:6}
.mock-screen{width:100%; height:100%; border-radius:30px; overflow:hidden; background:#f6f9fc; position:relative; font-size:10px}
.mock-label{
  position:absolute; left:50%; bottom:-2px; transform:translateX(-50%);
  display:flex; align-items:center; gap:6px; white-space:nowrap;
}
.mock-cap{text-align:center; margin-top:26px}
.mock-cap b{font-size:14px; font-weight:800; color:var(--ink); display:block}
.mock-cap small{font-size:12px; color:var(--muted)}

/* generic in-mock chrome */
.m-top{padding:30px 14px 0; display:flex; align-items:center; gap:8px}
.m-title{font-size:15px; font-weight:800; color:var(--ink)}
.m-ic{width:30px; height:30px; border-radius:9px; background:#eef2f7; display:grid; place-items:center; flex-shrink:0}
.m-search{margin:12px 14px 0; height:34px; border-radius:11px; background:#eef2f7; display:flex; align-items:center; gap:7px; padding:0 11px; color:#94a3b8; font-size:9.5px}
.m-chips{display:flex; gap:6px; padding:11px 14px 0; overflow:hidden}
.m-chip{font-size:9px; font-weight:700; padding:6px 11px; border-radius:99px; background:#eef2f7; color:#475569; white-space:nowrap}
.m-chip.on{background:var(--blue-600); color:#fff}
.m-doc{display:flex; gap:10px; align-items:center; margin:11px 14px 0; padding:11px; background:#fff; border:1px solid var(--line); border-radius:14px}
.m-da{width:42px; height:42px; border-radius:50%; display:grid; place-items:center; font-weight:800; font-size:13px; flex-shrink:0; position:relative}
.m-da i{position:absolute; bottom:0; right:0; width:11px; height:11px; border-radius:50%; background:#22c55e; border:2px solid #fff}
.m-dn{font-size:11.5px; font-weight:800; color:var(--ink)}
.m-ds{font-size:9px; color:var(--muted); margin-top:2px}
.m-dmeta{font-size:9px; color:#475569; margin-top:5px; display:flex; align-items:center; gap:5px}
.m-price{font-size:10.5px; font-weight:800; color:var(--blue-700)}

/* booking */
.m-dates{display:flex; gap:7px; padding:14px 14px 0; overflow:hidden}
.m-date{width:38px; flex-shrink:0; border-radius:11px; background:#fff; border:1px solid var(--line); text-align:center; padding:8px 0}
.m-date.on{background:var(--blue-600); border-color:var(--blue-600); color:#fff; box-shadow:0 8px 14px -8px rgba(37,99,235,.6)}
.m-date small{font-size:8px; font-weight:700; opacity:.7; display:block}
.m-date b{font-size:14px; font-weight:800; display:block}
.m-slots{display:grid; grid-template-columns:repeat(3,1fr); gap:7px; padding:14px 14px 0}
.m-slot{padding:9px 0; border-radius:9px; background:#fff; border:1px solid var(--line); text-align:center; font-size:10px; font-weight:700; color:#1e293b}
.m-slot.on{background:var(--blue-600); border-color:var(--blue-600); color:#fff}
.m-slot.off{color:#cbd5e1; text-decoration:line-through}
.m-seclabel{font-size:8.5px; font-weight:800; letter-spacing:.5px; text-transform:uppercase; color:#94a3b8; padding:14px 14px 0}

/* pharmacy grid */
.m-pgrid{display:grid; grid-template-columns:1fr 1fr; gap:9px; padding:13px 14px 0}
.m-pc{background:#fff; border:1px solid var(--line); border-radius:13px; padding:9px}
.m-pimg{height:48px; border-radius:9px; display:grid; place-items:center; margin-bottom:7px}
.m-ptag{font-size:7px; font-weight:800; letter-spacing:.4px; text-transform:uppercase; padding:2px 6px; border-radius:99px; display:inline-block}
.m-pn{font-size:9.5px; font-weight:800; color:var(--ink); margin-top:5px; line-height:1.2}
.m-pp{font-size:10px; font-weight:800; color:var(--blue-700); margin-top:5px; display:flex; align-items:center; justify-content:space-between}
.m-padd{width:22px; height:22px; border-radius:7px; background:var(--blue-600); display:grid; place-items:center}

/* video */
.m-video{position:absolute; inset:0; background:linear-gradient(160deg,#0c1e3c,#1e3a8a 45%,#0f172a); display:grid; place-items:center}
.m-vcenter{text-align:center; color:#fff; position:relative; z-index:2}
.m-vav{width:84px; height:84px; border-radius:50%; margin:0 auto; display:grid; place-items:center; font-weight:800; font-size:24px; color:#1e3a8a; background:#fff}
.m-vname{font-size:14px; font-weight:800; margin-top:12px}
.m-vsub{font-size:10px; opacity:.7; margin-top:2px}
.m-vring{position:absolute; border-radius:50%; border:1.5px solid rgba(59,130,246,.4); left:50%; top:42%; transform:translate(-50%,-50%)}
.m-vbar{position:absolute; left:14px; right:14px; bottom:18px; height:54px; border-radius:18px; background:rgba(15,23,42,.55); backdrop-filter:blur(10px); border:1px solid rgba(255,255,255,.1); display:flex; align-items:center; justify-content:space-around; z-index:3}
.m-vbtn{width:36px; height:36px; border-radius:50%; background:rgba(255,255,255,.14); display:grid; place-items:center}
.m-vbtn.end{width:46px; background:#dc2626}
.m-vpip{position:absolute; top:14px; right:14px; width:54px; height:74px; border-radius:12px; background:linear-gradient(160deg,#1c2430,#0b1015); border:1.5px solid rgba(255,255,255,.2); display:grid; place-items:center; z-index:3}

/* records */
.m-vitals{margin:14px 14px 0; border-radius:16px; padding:13px; color:#fff; background:linear-gradient(135deg,var(--blue-700),var(--blue-600)); position:relative; overflow:hidden}
.m-vrow{display:grid; grid-template-columns:repeat(4,1fr); gap:6px; margin-top:10px; position:relative}
.m-vk{font-size:8px; opacity:.85}
.m-vv{font-size:14px; font-weight:800; margin-top:1px}
.m-vu{font-size:7px; opacity:.7}
.m-seg{display:flex; gap:4px; margin:14px 14px 0; padding:3px; background:#e8edf3; border-radius:11px}
.m-segb{flex:1; text-align:center; font-size:9.5px; font-weight:700; padding:7px 0; border-radius:8px; color:#475569}
.m-segb.on{background:#fff; color:var(--blue-700); box-shadow:0 1px 3px rgba(0,0,0,.1)}
.m-rec{display:flex; gap:10px; align-items:center; margin:10px 14px 0; padding:11px; background:#fff; border:1px solid var(--line); border-radius:13px}
.m-rd{width:38px; flex-shrink:0; border-radius:9px; background:#f6f9fc; border:1px solid var(--line); text-align:center; padding:6px 0}
.m-rd small{font-size:7.5px; font-weight:800; color:#94a3b8; text-transform:uppercase; display:block}
.m-rd b{font-size:14px; font-weight:800; color:var(--ink); display:block}
.m-rn{font-size:10.5px; font-weight:800; color:var(--ink)}
.m-rs{font-size:9px; color:var(--muted); margin-top:2px}

@media(max-width:980px){
  .gallery{gap:22px}
  .mock, .mock.tall{width:230px; height:486px}
}

/* ── How it works ────────────────────────── */
.steps{display:grid; grid-template-columns:repeat(3,1fr); gap:22px; counter-reset:step}
.step{
  background:#fff; border:1px solid var(--line); border-radius:22px; padding:30px 26px; position:relative;
}
.step::before{
  counter-increment:step; content:"0" counter(step);
  font-size:54px; font-weight:800; color:var(--blue-100); letter-spacing:-.04em; line-height:.8;
  display:block; margin-bottom:14px;
}
.step h3{font-size:18px; margin-bottom:8px}
.step p{margin:0; font-size:14px; color:var(--body)}
.step .si{position:absolute; top:30px; right:26px; width:42px; height:42px; border-radius:12px; background:var(--blue-50); display:grid; place-items:center}

/* ── Specialties ─────────────────────────── */
.specs{display:grid; grid-template-columns:repeat(7,1fr); gap:14px}
.spec{
  background:#fff; border:1px solid var(--line); border-radius:18px; padding:20px 10px;
  text-align:center; transition:transform .18s, box-shadow .18s;
}
.spec:hover{transform:translateY(-3px); box-shadow:var(--shadow-sm)}
.spec .xi{width:46px; height:46px; border-radius:14px; margin:0 auto 12px; display:grid; place-items:center}
.spec b{font-size:13.5px; color:var(--ink); display:block}
.spec small{font-size:11.5px; color:var(--muted)}

/* ── Payments ────────────────────────────── */
.pay-grid{display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center}
.pay-cards{display:flex; flex-direction:column; gap:12px}
.pay-card{
  display:flex; align-items:center; gap:15px; padding:16px 18px;
  background:#fff; border:1px solid var(--line); border-radius:16px; transition:transform .15s, box-shadow .15s;
}
.pay-card:hover{transform:translateX(4px); box-shadow:var(--shadow-sm)}
.pay-logo{
  width:50px; height:50px; border-radius:13px; display:grid; place-items:center;
  color:#fff; font-weight:900; flex-shrink:0; flex-direction:column; line-height:1;
}
.pay-card .pn{font-weight:800; font-size:15.5px; color:var(--ink)}
.pay-card .pd{font-size:13px; color:var(--muted)}
.pay-card .chk{margin-left:auto; width:24px; height:24px; border-radius:50%; background:var(--blue-600); display:grid; place-items:center}

/* ── Testimonials ────────────────────────── */
.tests{display:grid; grid-template-columns:repeat(3,1fr); gap:20px}
.test{background:#fff; border:1px solid var(--line); border-radius:22px; padding:28px}
.test .stars{display:flex; gap:3px; margin-bottom:14px}
.test p{margin:0 0 18px; font-size:15px; color:var(--text); line-height:1.65}
.test .who{display:flex; align-items:center; gap:12px}
.test .wa{width:44px; height:44px; border-radius:50%; display:grid; place-items:center; font-weight:800; color:#1e3a8a}
.test .wn{font-weight:800; font-size:14px; color:var(--ink)}
.test .wl{font-size:12.5px; color:var(--muted)}

/* ── CTA ─────────────────────────────────── */
.cta{
  position:relative; border-radius:32px; overflow:hidden; padding:64px 56px;
  background:linear-gradient(150deg,var(--blue-600) 0%,var(--blue-800) 60%,var(--blue-900) 100%);
  color:#fff; text-align:center;
}
.cta h2{color:#fff; font-size:clamp(28px,3.4vw,42px); max-width:640px; margin:0 auto}
.cta p{color:rgba(255,255,255,.82); font-size:17px; margin:16px auto 0; max-width:520px}
.cta .stores{justify-content:center; margin-top:30px}
.cta .store{background:#fff; color:var(--ink)}
.cta .store small{opacity:.6}
.cta .blob{position:absolute; border-radius:50%; background:rgba(255,255,255,.08)}

/* ── Footer ──────────────────────────────── */
.footer{
  position:relative; overflow:hidden;
  background:#0a1020; color:#93a2b8;
  padding:74px 0 30px; margin-top:8px;
  border-top:1px solid rgba(255,255,255,.06);
}
.foot-glow{
  position:absolute; top:-42%; left:50%; transform:translateX(-50%);
  width:960px; height:560px; pointer-events:none; z-index:0;
  background:radial-gradient(58% 58% at 50% 0%, rgba(37,99,235,.30), transparent 72%);
  filter:blur(24px);
}
.foot-inner{position:relative; z-index:1}
.foot-grid{display:grid; grid-template-columns:1.75fr 1fr 1fr 1fr; gap:48px}
.foot-brand{max-width:370px}
.foot-logo{display:inline-flex; background:#fff; padding:11px 18px; border-radius:15px; box-shadow:0 14px 34px -14px rgba(0,0,0,.7)}
.foot-logo img{height:36px; width:auto; display:block}
.foot-brand p{font-size:14.5px; color:#93a2b8; line-height:1.7; margin:20px 0 0}
.foot-contact{list-style:none; margin:22px 0 0; padding:0; display:flex; flex-direction:column; gap:12px}
.foot-contact li{display:flex; align-items:center; gap:12px; font-size:13.5px; color:#b7c2d2; line-height:1.5}
.foot-contact a{color:#b7c2d2; transition:color .15s}
.foot-contact a:hover{color:#fff}
.fc-ic{width:32px; height:32px; border-radius:10px; flex-shrink:0; display:grid; place-items:center; background:rgba(96,165,250,.1); border:1px solid rgba(96,165,250,.18); color:#7cb0f7}
.foot-soc{display:flex; gap:10px; margin-top:24px}
.foot-soc a{width:40px; height:40px; border-radius:12px; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.09); display:grid; place-items:center; color:#aeb9c9; transition:transform .18s, background .18s, border-color .18s, color .18s}
.foot-soc a:hover{background:var(--blue-600); border-color:var(--blue-600); color:#fff; transform:translateY(-3px)}
.foot-soc svg{width:18px; height:18px}
.foot-col h4{font-size:12px; font-weight:800; text-transform:uppercase; letter-spacing:.1em; color:#fff; margin:4px 0 18px}
.foot-col a{display:block; font-size:14px; color:#93a2b8; padding:7px 0; width:fit-content; transition:color .15s, transform .15s}
.foot-col a:hover{color:#fff; transform:translateX(4px)}
.foot-pay{
  display:flex; align-items:center; gap:16px; flex-wrap:wrap;
  margin-top:54px; padding-top:28px; border-top:1px solid rgba(255,255,255,.07);
}
.fp-label{font-size:11.5px; font-weight:800; text-transform:uppercase; letter-spacing:.1em; color:#67748c}
.fp-badges{display:flex; gap:10px; flex-wrap:wrap}
.fp-badge{font-size:13px; font-weight:700; color:#cdd8e6; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.1); padding:7px 14px; border-radius:10px}
.fp-reg{margin-left:auto; font-size:13px; font-weight:600; color:#93a2b8; display:flex; align-items:center; gap:7px}
.foot-bot{
  display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:14px;
  margin-top:26px; padding-top:22px; border-top:1px solid rgba(255,255,255,.07);
}
.foot-bot small{font-size:12.5px; color:#67748c}
.foot-legal{display:flex; gap:6px; align-items:center}
.foot-legal a{font-size:12.5px; color:#93a2b8; padding:5px 11px; border-radius:8px; transition:color .15s, background .15s}
.foot-legal a:hover{color:#fff; background:rgba(255,255,255,.06)}

/* ── FAQ ─────────────────────────────────── */
.faq-list{max-width:760px; margin:0 auto; display:flex; flex-direction:column; gap:12px}
.faq-item{
  background:#fff; border:1px solid var(--line); border-radius:18px; padding:0 22px;
  transition:border-color .15s, box-shadow .15s;
}
.faq-item[open]{border-color:var(--blue-200); box-shadow:var(--shadow-sm)}
.faq-item summary{
  cursor:pointer; list-style:none; font-size:16px; font-weight:800; color:var(--ink);
  padding:20px 0; display:flex; align-items:center; justify-content:space-between; gap:16px;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:"+"; flex-shrink:0; width:28px; height:28px; border-radius:8px;
  background:var(--blue-50); color:var(--blue-700); display:grid; place-items:center; font-size:18px; font-weight:700;
}
.faq-item[open] summary::after{content:"−"}
.faq-item p{margin:0 0 20px; font-size:15px; color:var(--body); line-height:1.65}

/* reveal */
.reveal{opacity:0; transform:translateY(26px); transition:opacity .7s cubic-bezier(.2,.7,.3,1), transform .7s cubic-bezier(.2,.7,.3,1)}
.reveal.in{opacity:1; transform:none}

/* ── Responsive ──────────────────────────── */
@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr; gap:30px}
  .phone-stage{order:-1; min-height:auto; margin-bottom:10px}
  .bento{grid-template-columns:1fr 1fr}
  .feat.lg,.feat.sm,.feat.wide{grid-column:span 1}
  .steps{grid-template-columns:1fr}
  .specs{grid-template-columns:repeat(3,1fr)}
  .stats{grid-template-columns:repeat(2,1fr); gap:34px}
  .pay-grid{grid-template-columns:1fr; gap:30px}
  .tests{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr; gap:38px}
  .foot-brand{grid-column:1 / -1; max-width:520px}
  .fp-reg{margin-left:0; width:100%}
}

@media(max-width:900px){
  .wrap{padding:0 20px}
  .nav-in{
    height:60px; gap:12px;
    justify-content:space-between;
  }
  .logo{flex:1 1 auto; min-width:0; max-width:calc(100% - 118px)}
  .logo-img{height:34px; max-width:min(168px, 46vw)}
  .nav-links,.nav-cta{display:none !important}
  .nav-actions{display:flex}
  .nav-book-compact{height:38px; padding:0 14px; font-size:13px}
  .menu-btn{display:grid; width:38px; height:38px}
  .nav-drawer{padding-left:20px; padding-right:20px}
}

@media(max-width:560px){
  .wrap{padding:0 16px}
  .nav-in{height:56px; gap:10px}
  .logo{max-width:calc(100% - 108px)}
  .logo-img{height:30px; max-width:min(150px, 44vw)}
  .nav-actions{gap:6px}
  .nav-book-compact{height:36px; padding:0 12px; font-size:12.5px; border-radius:10px}
  .menu-btn{width:36px; height:36px; border-radius:10px}
  .specs{grid-template-columns:repeat(2,1fr)}
  .stats{grid-template-columns:1fr 1fr; gap:20px}
  .foot-grid{grid-template-columns:1fr; gap:32px}
  .foot-brand{grid-column:auto}
  .foot-bot{flex-direction:column; align-items:flex-start}
  .section{padding:56px 0}
  .step{padding:24px 20px}
  .test{padding:22px}
  .pay-card{padding:14px}
  .eyebrow{font-size:11.5px; padding:6px 12px}
}

@media(max-width:720px){
  .hero{padding:40px 0 64px}
  .hero h1{font-size:clamp(30px,8.5vw,42px)}
  .hero h1 .hl{white-space:normal}
  .hero .lead{font-size:16px; max-width:none}
  .hero-stores,.cta-stores,.stores{flex-direction:column; align-items:stretch; width:100%}
  .hero-stores .btn,.cta-stores .btn,.stores .btn{width:100%}
  .trust{gap:14px}
  .bento{grid-template-columns:1fr; gap:14px}
  .feat{padding:22px}
  .feat h3{font-size:17px}
  .feat p{font-size:14px}
  .phone-stage{min-height:480px; margin-bottom:0}
  .phone{width:min(280px, 88vw); height:auto; aspect-ratio:296/602}
  .fc-a,.fc-b{display:none}
  .gallery{margin:0 -20px; padding:16px 20px 20px}
  .mock,.mock.tall{width:210px; height:448px}
  .sec-head{margin-bottom:36px}
  .section{padding:64px 0}
  .showcase{padding:64px 0 72px}
  .cta{padding:44px 22px; border-radius:24px}
  .cta p{font-size:16px}
  .strip-row{gap:24px}
}
