
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}

:root{
  --white:#ffffff;
  --off:#fafaf9;
  --ink:#0a0908;
  --ink-2:#1c1b18;
  --ink-3:#3a3832;
  --muted:#0e0e0e;
  --faint:#e8e6e1;
  --faint-2:#f0ede8;
  --green:#12a276;
  --green-pale:#e6f7f2;
  --green-border:#b3e5d4;

  --shadow-xs: 0 1px 3px rgba(10,9,8,.06), 0 1px 2px rgba(10,9,8,.04);
  --shadow-sm: 0 2px 8px rgba(10,9,8,.07), 0 1px 3px rgba(10,9,8,.05);
  --shadow-md: 0 8px 24px rgba(10,9,8,.09), 0 2px 6px rgba(10,9,8,.05);
  --shadow-lg: 0 20px 60px rgba(10,9,8,.12), 0 4px 12px rgba(10,9,8,.06);
  --shadow-xl: 0 40px 100px rgba(10,9,8,.15), 0 8px 24px rgba(10,9,8,.07);
  --shadow-card: 0 1px 2px rgba(10,9,8,.04), 0 4px 16px rgba(10,9,8,.06), 0 12px 32px rgba(10,9,8,.05);
}

html{scroll-behavior:smooth;}
body{
  font-family:'Plus Jakarta Sans',sans-serif;
  background:var(--white);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

/* ── NAV ── */
nav{
  position:sticky;top:0;z-index:200;
  background:rgba(255,255,255,0.88);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--faint);
  box-shadow:0 1px 0 rgba(10,9,8,.04),0 4px 20px rgba(10,9,8,.04);
  padding:0 2.5rem;
  height:66px;
  display:flex;align-items:center;justify-content:space-between;
}
.nav-logo{
  display:flex;align-items:center;gap:10px;
  text-decoration:none;
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:18px;font-weight:700;
  color:var(--ink);letter-spacing:-.2px;
}
.nav-logo-mark{
  width:32px;height:32px;border-radius:9px;
  background:var(--ink);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 2px 8px rgba(10,9,8,.25);
}
.nav-links{display:flex;list-style:none;gap:2px;}
.nav-links a{
  font-size:13.5px;font-weight:400;
  color:var(--muted);text-decoration:none;
  padding:7px 14px;border-radius:8px;
  transition:color .15s,background .15s;
  letter-spacing:.1px;
}
.nav-links a:hover{color:var(--ink);background:var(--faint-2);}
.nav-actions{display:flex;align-items:center;gap:8px;}
.btn-ghost{
  font-family:'Plus Jakarta Sans',sans-serif;font-size:13.5px;font-weight:400;
  color:var(--muted);background:transparent;
  border:none;cursor:pointer;padding:8px 16px;border-radius:8px;
  transition:color .15s,background .15s;
}
.btn-ghost:hover{color:var(--ink);background:var(--faint-2);}
.btn-nav{
  font-family:'Plus Jakarta Sans',sans-serif;font-size:13px;font-weight:700;
  color:var(--white);background:var(--ink);
  border:none;cursor:pointer;padding:9px 20px;border-radius:9px;
  letter-spacing:.1px;
  box-shadow:0 1px 3px rgba(10,9,8,.2),0 4px 12px rgba(10,9,8,.12);
  transition:transform .12s,box-shadow .12s,background .15s;
}
.btn-nav:hover{background:var(--ink-2);box-shadow:0 2px 8px rgba(10,9,8,.25),0 8px 24px rgba(10,9,8,.14);transform:translateY(-1px);}
.btn-nav:active{transform:translateY(0);box-shadow:var(--shadow-xs);}

/* ── HERO ── */
.hero{
  max-width:1220px;margin:0 auto;
  padding:100px 2.5rem 80px;
  display:grid;grid-template-columns:1fr 1fr;
  gap:80px;align-items:center;
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--green-pale);
  border:1px solid var(--green-border);
  color:var(--green);
  font-size:11.5px;font-weight:500;letter-spacing:.6px;
  text-transform:uppercase;
  padding:5px 14px 5px 9px;border-radius:100px;
  margin-bottom:28px;
}
.eyebrow-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--green);
  animation:pulse 2s ease-in-out infinite;
  flex-shrink:0;
}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.5;transform:scale(.85);}}

.hero-title{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:clamp(42px,5.5vw,52px);
  font-weight:300;
  line-height:.95;
  letter-spacing:-1px;
  color:var(--ink);
  margin-bottom:24px;
  text-transform:uppercase;
}
.hero-title em{font-style:normal;color:var(--green);}
.hero-title strong{font-style:normal;font-weight:800;}

.hero-sub{
  font-size:16.5px;line-height:1.22;
  color:var(--muted);font-weight:300;
  max-width:420px;margin-bottom:44px;
  letter-spacing:.05px;
}

.hero-ctas{display:flex;align-items:center;gap:12px;margin-bottom:36px;}

.cta-main{
  font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;font-weight:700;
  background:var(--ink);color:var(--white);
  border:none;cursor:pointer;
  padding:14px 28px;border-radius:11px;
  display:flex;align-items:center;gap:9px;
  letter-spacing:.1px;
  box-shadow:0 2px 4px rgba(10,9,8,.15),0 8px 28px rgba(10,9,8,.18),0 20px 50px rgba(10,9,8,.1);
  transition:transform .15s cubic-bezier(.34,1.56,.64,1),box-shadow .15s;
}
.cta-main:hover{transform:translateY(-2px);box-shadow:0 4px 8px rgba(10,9,8,.18),0 12px 40px rgba(10,9,8,.2),0 28px 60px rgba(10,9,8,.12);}
.cta-main:active{transform:translateY(0);}

.cta-alt{
  font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;font-weight:500;
  color:var(--ink-3);background:var(--white);
  border:1.5px solid var(--faint);cursor:pointer;
  padding:13px 22px;border-radius:11px;
  display:flex;align-items:center;gap:8px;
  box-shadow:var(--shadow-sm);
  transition:border-color .15s,box-shadow .15s,transform .15s;
}
.cta-alt:hover{border-color:var(--faint);box-shadow:var(--shadow-md);transform:translateY(-1px);}

.hero-social{
  display:flex;align-items:center;gap:12px;
  font-size:13px;color:var(--muted);
}
.avatars{display:flex;}
.av{
  width:30px;height:30px;border-radius:50%;
  border:2.5px solid var(--white);
  display:flex;align-items:center;justify-content:center;
  font-size:10px;font-weight:600;
  margin-left:-10px;
  box-shadow:0 1px 4px rgba(10,9,8,.12);
}
.av:first-child{margin-left:0;}
.av-a{background:#dbeafe;color:#1d40af;}
.av-b{background:#fef3c7;color:#92400e;}
.av-c{background:#ede9fe;color:#6d28d9;}
.av-d{background:#dcfce7;color:#15803d;}

/* ── HERO VISUAL ── */
.hero-visual{
  position:relative;
  display:flex;align-items:center;justify-content:center;
}
.hero-video-wrap{
  width:100%;
  line-height:0;font-size:0;
  background:transparent;
}
.hero-video{
  width:100%;
  display:block;
  background:transparent;
  border:none;outline:none;
  border-radius:0;
  pointer-events:none;
  user-select:none;
  -webkit-user-select:none;
  -webkit-mask-image:-webkit-radial-gradient(white,black);
  -webkit-transform:translateZ(0);
  transform:translateZ(0);
}
.hero-video:focus,.hero-video:focus-visible{outline:none!important;border:none!important;box-shadow:none!important;}







/* ══════════════════════════════════════
   MOBILE APP SECTION — FULL REDESIGN
══════════════════════════════════════ */
.app-section-wrap{
  background:linear-gradient(145deg,#0a0608 0%,#1a0510 35%,#2d0a1a 65%,#0d0608 100%);
  padding:100px 0;
  position:relative;
  overflow:hidden;
}
.app-section-wrap::before{
  content:'';
  position:absolute;
  inset:0;
  background:
    radial-gradient(ellipse 65% 55% at 75% 45%, rgba(141,27,61,.45) 0%, transparent 65%),
    radial-gradient(ellipse 45% 50% at 15% 60%, rgba(141,27,61,.2) 0%, transparent 60%),
    radial-gradient(ellipse 30% 30% at 50% 10%, rgba(255,255,255,.04) 0%, transparent 60%);
  pointer-events:none;
}

/* MOBILE APP SECTION */
.app-section{max-width:1160px;margin:0 auto;padding:0 3rem;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;position:relative;z-index:1}
.app-left{}
.app-eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:10.5px;font-weight:700;color:#e8607a;letter-spacing:2px;text-transform:uppercase;margin-bottom:22px;background:rgba(141,27,61,.2);border:1px solid rgba(141,27,61,.35);padding:6px 14px;border-radius:20px}
.app-eyebrow::before{content:'';width:5px;height:5px;border-radius:50%;background:#e8607a;flex-shrink:0;box-shadow:0 0 8px rgba(232,96,122,.7)}
.app-title{font-size:clamp(28px,3vw,46px);font-weight:800;letter-spacing:-2px;line-height:1.06;color:#fff;margin-bottom:18px}
.app-title em{font-style:normal;background:linear-gradient(135deg,#e8607a,#fff 80%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.app-desc{font-size:15px;line-height:1.75;color:rgba(255,255,255,.55);font-weight:400;margin-bottom:40px;max-width:400px}
.app-features{display:flex;flex-direction:column;gap:6px;margin-bottom:44px}
.app-feat{display:flex;align-items:flex-start;gap:14px;padding:16px 18px;border-radius:16px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);transition:background .2s,border-color .2s}
.app-feat:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.14)}
.app-feat-icon{width:36px;height:36px;border-radius:10px;background:rgba(109,5,75,.35);border:1px solid rgba(109,5,75,.4);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.app-feat-icon svg path,.app-feat-icon svg rect,.app-feat-icon svg circle{stroke:#d97fc2}
.app-feat-title{font-size:13.5px;font-weight:700;color:#fff;margin-bottom:3px;letter-spacing:-0.2px}
.app-feat-desc{font-size:12.5px;line-height:1.55;color:rgba(255,255,255,.45)}
.app-store-btns{display:flex;gap:10px;flex-wrap:wrap}
.app-store-btn{display:flex;align-items:center;gap:11px;background:rgba(255,255,255,.1);backdrop-filter:blur(12px);color:#fff;padding:13px 22px;border-radius:14px;text-decoration:none;border:1px solid rgba(255,255,255,.18);transition:background .2s,transform .15s,box-shadow .15s;cursor:pointer;font-family:'Plus Jakarta Sans',sans-serif}
.app-store-btn:hover{background:rgba(255,255,255,.18);transform:translateY(-2px);box-shadow:0 12px 32px rgba(0,0,0,.4)}
.app-store-btn:active{transform:scale(.97)}
.app-store-btn-label{font-size:10px;font-weight:400;opacity:.6;line-height:1;letter-spacing:.4px}
.app-store-btn-name{font-size:14px;font-weight:700;line-height:1;letter-spacing:-0.3px}

/* PHONE MOCKUP */
.app-right{display:flex;align-items:center;justify-content:center;position:relative}
.phone-outer{
  width:260px;
  background:linear-gradient(160deg,#1a1a1a 0%,#0a0a0a 100%);
  border-radius:44px;
  padding:10px;
  box-shadow:
    0 0 0 1px rgba(255,255,255,.08),
    0 32px 80px rgba(0,0,0,.5),
    0 8px 24px rgba(0,0,0,.3),
    inset 0 0 0 1px rgba(255,255,255,.04);
  position:relative;
  z-index:2;
}
.phone-screen{
  background:#fff;
  border-radius:36px;
  overflow:hidden;
  position:relative;
}
.phone-notch{
  width:90px;height:28px;
  background:linear-gradient(160deg,#1a1a1a 0%,#0a0a0a 100%);
  border-radius:0 0 18px 18px;
  margin:0 auto;
  position:relative;z-index:2;
}
.phone-notch::after{
  content:'';position:absolute;top:8px;left:50%;transform:translateX(-50%);
  width:10px;height:10px;border-radius:50%;
  background:rgba(0,0,0,.5);
}
.phone-content{padding:0 0 20px}
/* Status bar */
.ps-statusbar{display:flex;justify-content:space-between;align-items:center;padding:6px 18px 8px;font-size:10px;font-weight:600;color:#111}
/* Header */
.ps-header{padding:4px 18px 14px;border-bottom:1px solid #f0f0f0}
.ps-greeting{font-size:11px;color:#aaa;font-weight:400;margin-bottom:2px}
.ps-name{font-size:17px;font-weight:800;color:#0a0a0a;letter-spacing:-.5px}
/* Revenue card */
.ps-rev-card{margin:14px 14px 0;border-radius:18px;background:linear-gradient(135deg,#6d054b 0%,#a0096e 60%,#c40d87 100%);padding:18px 18px 16px;box-shadow:0 8px 24px rgba(109,5,75,.35)}
.ps-rev-label{font-size:10px;color:rgba(255,255,255,.7);font-weight:500;margin-bottom:4px;letter-spacing:.3px}
.ps-rev-amount{font-size:28px;font-weight:800;color:#fff;letter-spacing:-1.2px;line-height:1}
.ps-rev-change{display:flex;align-items:center;gap:4px;margin-top:6px}
.ps-rev-change-pill{background:rgba(255,255,255,.2);border-radius:100px;padding:2px 8px;font-size:10px;font-weight:600;color:#fff}
.ps-rev-sub{font-size:10px;color:rgba(255,255,255,.6);margin-left:4px}
/* Mini chart bars */
.ps-bars{display:flex;align-items:flex-end;gap:5px;height:36px;margin-top:14px}
.ps-bar{flex:1;border-radius:3px 3px 0 0;background:rgba(255,255,255,.25)}
.ps-bar.hi{background:rgba(255,255,255,.9)}
/* Quick stats row */
.ps-stats-row{display:flex;gap:8px;padding:12px 14px 0}
.ps-stat{flex:1;background:#f8f8f8;border-radius:12px;padding:10px 10px 9px;text-align:center}
.ps-stat-val{font-size:14px;font-weight:800;color:#0a0a0a;letter-spacing:-.5px}
.ps-stat-lbl{font-size:9px;color:#aaa;font-weight:500;margin-top:1px}
/* Services list */
.ps-section-title{padding:14px 18px 8px;font-size:11px;font-weight:700;color:#0a0a0a;letter-spacing:-.2px}
.ps-service-row{display:flex;align-items:center;gap:10px;padding:8px 18px}
.ps-svc-icon{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0}
.ps-svc-name{font-size:12px;font-weight:600;color:#0a0a0a;flex:1}
.ps-svc-amt{font-size:12px;font-weight:700;color:#0a0a0a}
.ps-svc-count{font-size:10px;color:#aaa;display:block}
/* Bottom nav */
.ps-bottom-nav{display:flex;justify-content:space-around;padding:10px 10px 6px;border-top:1px solid #f0f0f0;margin-top:10px}
.ps-nav-item{display:flex;flex-direction:column;align-items:center;gap:2px}
.ps-nav-dot{width:4px;height:4px;border-radius:50%;background:var(--accent);margin-top:1px}

/* glow behind phone */
.phone-glow{
  position:absolute;
  width:380px;height:380px;
  border-radius:50%;
  background:radial-gradient(ellipse,rgba(141,27,61,.55) 0%,rgba(180,40,80,.2) 50%,transparent 70%);
  top:50%;left:50%;transform:translate(-50%,-50%);
  z-index:1;
  pointer-events:none;
  filter:blur(2px);
}
/* floating notif card */
.phone-notif{
  position:absolute;
  right:-60px;top:60px;
  background:rgba(20,16,30,.85);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,.12);
  border-radius:16px;
  padding:13px 16px;
  box-shadow:0 16px 48px rgba(0,0,0,.5),0 2px 8px rgba(0,0,0,.3);
  width:170px;z-index:3;
  animation:floatY 3.5s ease-in-out infinite;
}
.phone-notif2{
  position:absolute;
  left:-56px;bottom:80px;
  background:rgba(20,16,30,.85);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,.12);
  border-radius:16px;
  padding:13px 16px;
  box-shadow:0 16px 48px rgba(0,0,0,.5),0 2px 8px rgba(0,0,0,.3);
  width:154px;z-index:3;
  animation:floatY 4s 1s ease-in-out infinite;
}
@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.notif-label{font-size:9.5px;font-weight:600;color:rgba(255,255,255,.4);letter-spacing:.5px;text-transform:uppercase;margin-bottom:5px}
.notif-val{font-size:17px;font-weight:800;color:#fff;letter-spacing:-.5px}
.notif-sub{font-size:10.5px;color:#12a276;font-weight:600;margin-top:2px}
.notif-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:#12a276;margin-right:4px;animation:pulse 2s ease-in-out infinite;box-shadow:0 0 6px #12a276}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}






/* ── LOGOS ── */
.logos-strip{
  border-top:1px solid var(--faint);
  border-bottom:1px solid var(--faint);
  padding:24px 2.5rem;
  background:var(--off);
}
.logos-inner{
  max-width:1220px;margin:0 auto;
  display:flex;align-items:center;gap:36px;
}
.logos-label{font-size:11.5px;color:var(--muted);white-space:nowrap;letter-spacing:.5px;text-transform:uppercase;flex-shrink:0;}
.logos-div{width:1px;height:18px;background:var(--faint);flex-shrink:0;}
.logos-list{display:flex;align-items:center;gap:32px;flex-wrap:wrap;}
.logo-name{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:12.5px;font-weight:700;
  color:#c4c2bb;letter-spacing:.6px;
  transition:color .2s;
}
.logo-name:hover{color:var(--muted);}

/* ── FEATURES ── */
.features{
  max-width:1220px;margin:0 auto;
  padding:10px 2.5rem;
}

.section-kicker{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:11px;font-weight:700;
  color:var(--green);letter-spacing:1.2px;text-transform:uppercase;
  margin-bottom:14px;
  display:flex;align-items:center;gap:8px;
}
.section-kicker::before{content:'';width:20px;height:1.5px;background:var(--green);display:inline-block;}
.section-heading{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:clamp(36px,3.4vw,54px);
  font-weight:700;line-height:1.0;letter-spacing:-.2px;
  text-transform:uppercase;
  color:var(--ink);
  max-width:560px;margin-bottom:60px;
}
.section-heading em{font-style:normal;color:var(--green);}

.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.fc{
  background:var(--white);
  border:1px solid var(--faint);
  border-radius:18px;
  padding:32px;
  box-shadow:var(--shadow-card);
  transition:box-shadow .25s,transform .25s,border-color .25s;
  position:relative;overflow:hidden;
}
.fc::after{
  content:'';
  position:absolute;inset:0;border-radius:18px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.8);
  pointer-events:none;
}
.fc:hover{
  box-shadow:0 4px 8px rgba(10,9,8,.05),0 12px 40px rgba(10,9,8,.1),0 32px 80px rgba(10,9,8,.08);
  transform:translateY(-3px);
  border-color:#dddbd6;
}
.fc-icon{
  width:44px;height:44px;border-radius:12px;
  background:var(--off);border:1px solid var(--faint);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:22px;
  box-shadow:var(--shadow-xs);
}
.fc-name{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:19.5px;font-weight:600;
  color:var(--ink);margin-bottom:10px;letter-spacing:-.1px;
}
.fc-desc{
  font-size:16.0px;line-height:1.3;
  color:var(--muted);font-weight:300;
}
.fc-num{
  position:absolute;top:24px;right:28px;
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:44px;font-weight:800;
  color:var(--faint);letter-spacing:-1px;
  line-height:1;pointer-events:none;
}

/* ── STATS ── */
.stats-outer{padding:0 2.5rem;max-width:1220px;margin:0 auto 100px;}
.stats-band{
  background:var(--ink);
  border-radius:24px;
  padding:0 64px;
  box-shadow:0 8px 20px rgba(10,9,8,.12),0 32px 80px rgba(10,9,8,.2),0 60px 120px rgba(10,9,8,.12);
  position:relative;overflow:hidden;
}
.stats-band::before{
  content:'';
  position:absolute;inset:0;
  background:radial-gradient(ellipse at 50% -30%,rgba(18,162,118,.12) 0%,transparent 60%);
  pointer-events:none;
}
.stats-grid{
  display:grid;grid-template-columns:1fr 1px 1fr 1px 1fr;
  align-items:center;
}
.stat-item{text-align:center;padding:64px 24px;}
.stat-num{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:60px;font-weight:800;
  color:var(--white);letter-spacing:-1px;
  line-height:1;margin-bottom:10px;text-transform:uppercase;
}
.stat-label{font-size:13px;color:rgba(255,255,255,.4);font-weight:300;letter-spacing:.3px;}
.stat-sep{background:rgba(255,255,255,.08);height:70px;width:1px;}

/* ── TESTIMONIALS ── */
.testimonials{
  max-width:1220px;margin:0 auto;
  padding:100px 2.5rem;
}
.test-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:60px;}
.tcard{
  background:var(--white);
  border:1px solid var(--faint);
  border-radius:18px;
  padding:30px;
  box-shadow:var(--shadow-card);
  transition:transform .2s,box-shadow .2s;
}
.tcard:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);}
.tcard-stars{display:flex;gap:3px;margin-bottom:16px;}
.star{
  width:14px;height:14px;
  background:var(--ink);
  clip-path:polygon(50% 0%,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%);
}
.tcard-quote{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:15px;font-style:italic;font-weight:300;
  color:var(--ink-3);line-height:1.65;
  margin-bottom:22px;
}
.tcard-author{display:flex;align-items:center;gap:10px;}
.tcard-av{
  width:34px;height:34px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:600;
  box-shadow:var(--shadow-xs);
}
.tcard-name{font-size:13px;font-weight:500;color:var(--ink);}
.tcard-role{font-size:11.5px;color:var(--muted);}

/* ── CTA SECTION ── */
.cta-section{
  max-width:1220px;margin:0 auto;
  padding:0 2.5rem 100px;
}
.cta-box{
  background:var(--white);
  border:1px solid var(--faint);
  border-radius:28px;
  padding:80px 56px;
  text-align:center;
  position:relative;overflow:hidden;
  box-shadow:0 1px 2px rgba(10,9,8,.03),0 8px 32px rgba(10,9,8,.07),0 32px 80px rgba(10,9,8,.06);
}
.cta-bg{
  position:absolute;bottom:-80px;left:50%;transform:translateX(-50%);
  width:600px;height:300px;
  background:radial-gradient(ellipse,rgba(18,162,118,.08) 0%,transparent 65%);
  pointer-events:none;
}
.cta-bg2{
  position:absolute;top:-60px;left:20%;
  width:200px;height:200px;
  background:radial-gradient(ellipse,rgba(10,9,8,.04) 0%,transparent 70%);
  pointer-events:none;
}
.cta-title{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:clamp(38px,3.8vw,60px);
  font-weight:800;letter-spacing:-.2px;
  text-transform:uppercase;
  color:var(--ink);margin-bottom:16px;line-height:1.0;
}
.cta-title em{font-style:normal;color:var(--green);}
.cta-sub{
  font-size:16px;color:var(--muted);
  margin-bottom:40px;font-weight:300;
}
.cta-btns{display:flex;align-items:center;justify-content:center;gap:12px;}
.cta-fine{font-size:12px;color:#aaa9a4;margin-top:20px;}
.cta-fine span{color:var(--green);}

/* ── FOOTER ── */
footer{
  border-top:1px solid var(--faint);
  padding:32px 2.5rem;
  max-width:1220px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
}
.footer-logo{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:15px;font-weight:700;color:var(--ink);
}
footer p{font-size:12.5px;color:var(--muted);}
.footer-links{display:flex;gap:24px;}
.footer-links a{font-size:12.5px;color:var(--muted);text-decoration:none;transition:color .15s;}
.footer-links a:hover{color:var(--ink);}

/* ── ANIMATIONS ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);}}
.hero-left>*{animation:fadeUp .6s ease backwards;}
.hero-eyebrow{animation-delay:.06s;}
.hero-title{animation-delay:.14s;}
.hero-sub{animation-delay:.2s;}
.hero-ctas{animation-delay:.26s;}
.hero-social{animation-delay:.32s;}
.hero-visual{animation:fadeUp .7s .35s ease backwards;}
.stat-item{animation:fadeUp .5s ease backwards;}
.stat-item:nth-child(1){animation-delay:.05s;}
.stat-item:nth-child(3){animation-delay:.1s;}
.stat-item:nth-child(5){animation-delay:.15s;}

/* ── RESPONSIVE ── */
@media(max-width:960px){
  .features-grid{grid-template-columns:repeat(2,1fr);}
  .test-grid{grid-template-columns:1fr;}
}
@media(max-width:768px){
  nav{padding:0 1.25rem;}
  .nav-links{display:none;}
  .btn-ghost{display:none;}
  /* ── HERO MOBILE ── */
  .hero{
    grid-template-columns:1fr;
    padding:48px 1.25rem 32px;
    gap:32px;
    text-align:left;
  }
  .hero-eyebrow{margin-left:0;margin-right:auto;}
  .hero-title{
    font-size:clamp(36px,10vw,44px);
    letter-spacing:-1px;
    line-height:1.0;
    margin-bottom:16px;
  }
  .hero-sub{
    font-size:14px;
    line-height:1.6;
    margin-bottom:28px;
    margin-left:0;
    margin-right:auto;
  }
  .hero-ctas{
    flex-direction:row;
    align-items:center;
    justify-content:flex-start;
    gap:10px;
    flex-wrap:wrap;
  }
  .cta-main{
    padding:13px 22px;
    font-size:13.5px;
    border-radius:12px;
    flex:1;
    min-width:0;
    justify-content:center;
  }
  .cta-alt{
    padding:12px 18px;
    font-size:13.5px;
    border-radius:12px;
    flex:1;
    min-width:0;
    justify-content:center;
  }
  .hero-social{justify-content:flex-start;font-size:12px;}
  .logos-strip{padding:20px 1.25rem;}
  .logos-inner{flex-wrap:wrap;gap:12px;}
  .logos-div{display:none;}
  .logos-label{width:100%;text-align:center;}
  .logos-list{justify-content:center;gap:18px;}
  .features{padding:60px 1.25rem;}
  .section-heading{max-width:100%;}
  .features-grid{grid-template-columns:1fr;gap:10px;}
  .stats-outer{padding:0 1.25rem;margin-bottom:60px;}
  .stats-band{padding:0 24px;}
  .stats-grid{grid-template-columns:1fr;gap:0;}
  .stat-item{padding:40px 16px;}
  .stat-sep{display:none;}
  .stat-num{font-size:42px;}
  .testimonials{padding:60px 1.25rem;}
  .cta-section{padding:0 1.25rem 60px;}
  .cta-box{padding:48px 24px;border-radius:20px;}
  .cta-btns{flex-direction:column;align-items:stretch;}
  .cta-btns .cta-main,.cta-btns .cta-alt{justify-content:center;}
  footer{padding:24px 1.25rem;flex-direction:column;gap:16px;text-align:center;}

  /* ── APP SECTION MOBILE ── */
  .app-section-wrap{ padding:70px 0; }
  .app-section{
    grid-template-columns:1fr;
    padding:0 1.25rem;
    gap:52px;
  }
  .app-left{ text-align:center; }
  .app-eyebrow{ margin:0 auto 22px; }
  .app-title{
    font-size:clamp(28px,7.5vw,36px);
    letter-spacing:-1.5px;
  }
  .app-desc{
    margin-left:auto;
    margin-right:auto;
    font-size:14px;
  }
  .app-feat{ text-align:left; }
  .app-features{ gap:6px; }
  .app-store-btns{ justify-content:center; }

  /* Reposition badges to sit ON the phone edges, not outside */
  .phone-notif{
    right:-10px;
    top:40px;
    width:140px;
    padding:9px 12px;
  }
  .notif-val{ font-size:14px; }
  .phone-notif2{
    left:-10px;
    bottom:60px;
    width:130px;
    padding:9px 12px;
  }

  /* Centre phone and give room for badges */
  .app-right{
    width:100%;
    padding:0 2rem;
    overflow:visible;
  }
  .phone-outer{
    width:min(230px, 58vw);
    margin:0 auto;
  }
  .phone-glow{
    width:200px;
    height:200px;
  }
}