*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --cream:#fbf7ef;
  --lavender:#aba3ff;
  --lavender-deep:#7c72e8;
  --ink:#1a1625;
  --muted:#5c5670;
  --line:rgba(26,22,37,.1);
  --accent:#ff6b4a;
}
html{scroll-behavior:smooth}
body{
  font-family:'DM Sans',system-ui,sans-serif;
  background:var(--cream);
  color:var(--ink);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
}
a{color:inherit;text-decoration:none}
.wrap{max-width:1080px;margin:0 auto;padding:0 clamp(20px,4vw,40px)}

.badge{
  font-size:.65rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  padding:8px 14px;border-radius:100px;background:var(--lavender);color:var(--ink);
}

.hero{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,6vw,72px);
  align-items:center;padding:clamp(40px,8vw,96px) 0 clamp(64px,10vw,120px);
  min-height:calc(100vh - 100px);
}
@media(max-width:860px){.hero{grid-template-columns:1fr;min-height:auto}}

.hero-copy h1{
  font-size:clamp(2.4rem,6vw,4.2rem);
  line-height:1.02;letter-spacing:-.03em;
  margin-bottom:24px;
}
.hero-copy h1 .light{font-weight:400;display:block}
.hero-copy h1 .bold{font-weight:700;display:block;color:var(--lavender-deep)}

.lede{
  font-size:clamp(1rem,2vw,1.15rem);
  color:var(--muted);
  max-width:34ch;
  margin-bottom:36px;
}

.cta-row{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.btn{
  display:inline-flex;align-items:center;gap:8px;
  font-size:.85rem;font-weight:700;letter-spacing:.04em;
  padding:14px 26px;border-radius:100px;
  background:var(--ink);color:var(--cream);
  transition:transform .2s,background .2s;
}
.btn:hover{background:var(--lavender-deep);transform:translateY(-2px)}
.btn-ghost{
  background:transparent;color:var(--ink);
  border:1.5px solid var(--line);
}
.btn-ghost:hover{background:var(--lavender);border-color:var(--lavender)}

.hero-visual{
  position:relative;display:flex;align-items:center;justify-content:center;
  min-height:320px;
}
.cart-scene{
  width:min(100%,380px);aspect-ratio:1;
  background:linear-gradient(145deg,var(--lavender) 0%,#c4bdff 55%,#ddd8ff 100%);
  border-radius:32px;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 32px 80px rgba(124,114,232,.25);
  position:relative;overflow:hidden;
}
.cart-scene::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 30% 20%,rgba(255,255,255,.45),transparent 55%);
}
.cart-icon{
  font-size:7rem;line-height:1;filter:drop-shadow(0 12px 24px rgba(0,0,0,.12));
  transform:rotate(-8deg);
}
.float-tag{
  position:absolute;background:var(--cream);
  padding:10px 16px;border-radius:14px;
  font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  box-shadow:0 8px 24px rgba(26,22,37,.08);
}
.float-tag.one{top:12%;right:-4%;color:var(--lavender-deep)}
.float-tag.two{bottom:14%;left:-6%;color:var(--accent)}

.landing-stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;
  padding:48px 0;border-top:1px solid var(--line);
}
@media(max-width:640px){.landing-stats{grid-template-columns:1fr}}
.stat-num{
  font-size:clamp(1.6rem,4vw,2.2rem);font-weight:700;
  letter-spacing:-.02em;line-height:1;
}
.stat-label{font-size:.78rem;color:var(--muted);margin-top:8px;max-width:16ch}

.modules{padding:64px 0 96px}
.section-title{
  font-size:.7rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--lavender-deep);margin-bottom:16px;
}
.modules h2{
  font-size:clamp(1.6rem,4vw,2.4rem);letter-spacing:-.02em;
  margin-bottom:40px;max-width:20ch;
}
.module-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:20px;
}
@media(max-width:700px){.module-grid{grid-template-columns:1fr}}
.module{
  background:#fff;border:1px solid var(--line);border-radius:20px;
  padding:28px;transition:border-color .2s,box-shadow .2s;
}
.module:hover{border-color:var(--lavender);box-shadow:0 12px 40px rgba(124,114,232,.1)}
.module-num{font-size:.65rem;font-weight:700;letter-spacing:.12em;color:var(--muted);margin-bottom:12px}
.module h3{font-size:1.05rem;font-weight:700;margin-bottom:8px}
.module p{font-size:.92rem;color:var(--muted)}
.module a{color:var(--lavender-deep);font-weight:600;font-size:.85rem;margin-top:12px;display:inline-block}

.landing-footer{
  padding:32px 0 48px;border-top:1px solid var(--line);
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:16px;
  font-size:.82rem;color:var(--muted);
}
.landing-footer strong{color:var(--ink)}

.nav-badge-wrap{display:flex;align-items:center;gap:12px}
