  :root{
    --navy:#22326b;
    --navy-soft:#46568f;
    --grape:#7a4f9e;
    --purple:#8a5cb0;
    --purple-deep:#6f4a92;
    --lilac:#a98fc9;
    --lilac-200:#d9cdec;
    --lilac-100:#ece6f5;
    --lavender:#f4f0fa;
    --green:#7cb98c;
    --green-deep:#5a9c6c;
    --sage:#a7d3b2;
    --sage-soft:#dcefe1;
    --blue:#6b9fd4;
    --blue-soft:#d2e2f3;
    --heart:#c98fd0;
    --cream:#fbf9fc;
    --white:#ffffff;
    --ink-60:#5f5d7a;
    --ink-40:#8a88a3;
    --shadow:0 24px 60px -18px rgba(60,70,120,.26);
    --shadow-sm:0 10px 30px -12px rgba(60,70,120,.22);
  }
  *{margin:0;padding:0;box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{
    font-family:'Nunito',sans-serif;
    color:var(--navy);
    background:var(--cream);
    line-height:1.6;
    overflow-x:hidden;
    -webkit-font-smoothing:antialiased;
  }
  h1,h2,h3,h4{font-family:'Baloo 2',sans-serif;line-height:1.08;letter-spacing:-.01em}
  .script{font-family:'Caveat',cursive;font-weight:700}
  .wrap{max-width:1180px;margin:0 auto;padding:0 24px}
  a{text-decoration:none;color:inherit}
  .grad-text{background:linear-gradient(100deg,var(--grape),var(--lilac));-webkit-background-clip:text;background-clip:text;color:transparent}

  /* ---------- buttons ---------- */
  .btn{
    display:inline-flex;align-items:center;gap:9px;justify-content:center;
    font-family:'Baloo 2',sans-serif;font-weight:700;font-size:1.02rem;
    padding:15px 30px;border-radius:60px;border:none;cursor:pointer;
    transition:transform .18s ease, box-shadow .18s ease;
  }
  .btn-primary{
    background:linear-gradient(120deg,var(--purple),var(--grape));
    color:#fff;box-shadow:0 16px 34px -12px rgba(122,46,150,.6);
  }
  .btn-primary:hover{transform:translateY(-3px);box-shadow:0 22px 40px -12px rgba(122,46,150,.65)}
  .btn-ghost{background:#fff;color:var(--grape);border:2px solid var(--lilac-200)}
  .btn-ghost:hover{transform:translateY(-3px);border-color:var(--lilac)}

  /* ---------- decorative blobs ---------- */
  .blob{position:absolute;z-index:0;pointer-events:none;filter:blur(.2px)}

  /* ---------- header ---------- */
  header{position:sticky;top:0;z-index:60;transition:.3s}
  .nav{
    display:flex;align-items:center;justify-content:space-between;
    padding:16px 0;
  }
  header.scrolled{background:rgba(252,249,253,.86);backdrop-filter:blur(14px);box-shadow:0 6px 24px -16px rgba(74,42,110,.4)}
  .logo{display:flex;align-items:center;gap:8px;font-family:'Baloo 2';font-weight:800;font-size:1.5rem;color:var(--navy)}
  .logo .pres{font-family:'Caveat';font-weight:700;color:var(--lilac);font-size:1.85rem;margin-left:-2px}
  .nav-links{display:flex;gap:30px;font-weight:700;font-size:.97rem;color:var(--navy-soft)}
  .nav-links a{position:relative;transition:color .2s}
  .nav-links a:hover{color:var(--grape)}
  .nav-links a::after{content:"";position:absolute;left:0;bottom:-6px;height:3px;width:0;border-radius:3px;background:var(--lilac);transition:width .25s}
  .nav-links a:hover::after{width:100%}
  .nav-cta{display:flex;align-items:center;gap:14px}
  .menu-btn{display:none;background:none;border:none;cursor:pointer;color:var(--navy)}

  /* ---------- hero ---------- */
  .hero{position:relative;padding:54px 0 70px;overflow:hidden}
  .hero-grid{display:grid;grid-template-columns:1fr;gap:48px;align-items:center;position:relative;z-index:2;justify-items:center;text-align:center}
  .badge{
    display:inline-flex;align-items:center;gap:8px;background:var(--lilac-100);
    color:var(--grape);font-weight:800;font-size:.82rem;padding:8px 16px;border-radius:60px;
    text-transform:uppercase;letter-spacing:.04em;margin-bottom:22px;
  }
  .badge .dot{width:8px;height:8px;border-radius:50%;background:var(--sage)}
  .hero h1{font-size:clamp(2.5rem,5vw,3.85rem);font-weight:800}
  .hero h1 .hl{
    display:inline-block;background:#86b395;color:#fff;padding:0 14px;border-radius:14px;
    transform:rotate(-1.2deg);box-shadow:0 10px 24px -10px rgba(110,150,120,.45)
  }
  .hero .sub-script{font-family:'Caveat';color:var(--grape);font-size:2.2rem;font-weight:700;display:block;margin-top:6px;transform:rotate(-1deg)}
  .hero p.lead{font-size:1.18rem;color:var(--navy-soft);margin:22px 0 30px;max-width:620px;font-weight:500}
  .hero-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center;justify-content:center}
  .hero-pills{display:flex;gap:10px;flex-wrap:wrap;margin-top:30px;justify-content:center}
  .pill{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1.5px solid var(--lilac-100);padding:9px 16px;border-radius:50px;font-weight:700;font-size:.88rem;color:var(--navy-soft);box-shadow:var(--shadow-sm)}
  .pill svg{color:var(--lilac)}

  /* ---------- phone ---------- */
  .phone-stage{position:relative;display:flex;justify-content:center}
  .phone{
    width:330px;background:#fff;border-radius:44px;padding:12px;
    box-shadow:0 40px 90px -30px rgba(74,42,110,.55), 0 0 0 10px #efe6f7;
    position:relative;z-index:3;
  }
  .phone-screen{background:#fff;border-radius:34px;overflow:hidden;height:660px;display:flex;flex-direction:column}
  .statusbar{display:flex;justify-content:space-between;align-items:center;padding:14px 22px 6px;font-weight:800;font-size:.85rem;color:var(--navy)}
  .statusbar .icons{display:flex;gap:6px;align-items:center}
  .chat-head{display:flex;align-items:center;gap:11px;padding:6px 16px 14px;border-bottom:1px solid #f1ecf7}
  .chat-head .back{color:var(--navy);font-size:1.2rem;font-weight:800}
  .avatar{width:46px;height:46px;border-radius:50%;flex-shrink:0;overflow:hidden;box-shadow:0 4px 10px -3px rgba(74,42,110,.4)}
  .chat-head .who{flex:1;min-width:0}
  .chat-head .who .name{display:flex;align-items:center;gap:7px;font-family:'Baloo 2';font-weight:700;font-size:1.05rem}
  .ia-tag{background:var(--purple);color:#fff;font-size:.62rem;font-weight:800;padding:2px 7px;border-radius:6px;font-family:'Nunito'}
  .chat-head .who .role{font-size:.72rem;color:var(--ink-40);line-height:1.2;font-weight:600}
  .chat-head .who .on{font-size:.72rem;color:#3bbf7e;font-weight:800;display:flex;align-items:center;gap:5px;margin-top:2px}
  .chat-head .who .on::before{content:"";width:7px;height:7px;border-radius:50%;background:#3bbf7e}
  .chat-head .htools{display:flex;gap:7px}
  .htool{width:32px;height:32px;border-radius:50%;border:1.5px solid #eadcf6;display:grid;place-items:center;color:var(--lilac)}
  .msgs{flex:1;overflow-y:auto;padding:14px 14px 8px;display:flex;flex-direction:column;gap:12px;background:linear-gradient(#fff,#fcf9fe)}
  .msgs::-webkit-scrollbar{width:5px}
  .msgs::-webkit-scrollbar-thumb{background:#e3d4f2;border-radius:5px}
  .safe{display:flex;gap:10px;background:var(--lilac-100);border-radius:16px;padding:12px;align-items:flex-start}
  .safe .ico{width:34px;height:34px;border-radius:10px;background:var(--purple);display:grid;place-items:center;color:#fff;flex-shrink:0}
  .safe b{font-size:.84rem;display:block;color:var(--navy)}
  .safe p{font-size:.78rem;color:var(--navy-soft);font-weight:600}
  .datechip{align-self:center;background:#f0eaf7;color:var(--ink-40);font-size:.68rem;font-weight:800;padding:4px 12px;border-radius:30px}
  .bubble{max-width:80%;padding:11px 13px;border-radius:16px;font-size:.82rem;font-weight:600;box-shadow:0 4px 12px -8px rgba(74,42,110,.4)}
  .bubble.me{align-self:flex-end;background:var(--lilac-200);color:var(--navy);border-bottom-right-radius:5px}
  .bubble .time{display:block;text-align:right;font-size:.62rem;color:var(--ink-40);margin-top:4px;font-weight:700}
  .ai-row{display:flex;gap:8px;align-items:flex-end}
  .ai-row .mini{width:26px;height:26px;border-radius:50%;overflow:hidden;flex-shrink:0}
  .bubble.ai{background:#f5f0fb;color:var(--navy);border-bottom-left-radius:5px}
  .bubble.ai .lead2{font-weight:800;margin-bottom:4px}
  .strat{display:flex;gap:7px;align-items:flex-start;margin:6px 0;font-size:.78rem}
  .strat .ck{width:17px;height:17px;border-radius:50%;background:var(--purple);color:#fff;display:grid;place-items:center;flex-shrink:0;font-size:.6rem;margin-top:2px}
  .chips{display:flex;gap:7px;flex-wrap:wrap;padding:4px 14px 8px}
  .chip{border:1.5px solid var(--lilac-200);color:var(--grape);font-size:.74rem;font-weight:800;padding:7px 12px;border-radius:30px;background:#fff}
  .inputbar{display:flex;align-items:center;gap:9px;padding:10px 12px 6px;border-top:1px solid #f1ecf7}
  .inputbar .field{flex:1;background:#f4eefb;border-radius:30px;padding:11px 16px;color:var(--ink-40);font-size:.82rem;font-weight:600;display:flex;justify-content:space-between;align-items:center}
  .inputbar .mic{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--purple),var(--grape));color:#fff;display:grid;place-items:center;flex-shrink:0;box-shadow:0 8px 18px -8px rgba(122,46,150,.7)}
  .botnav{display:flex;justify-content:space-around;padding:10px 6px 14px;border-top:1px solid #f1ecf7;background:#fff}
  .botnav .item{display:flex;flex-direction:column;align-items:center;gap:3px;font-size:.62rem;font-weight:800;color:var(--ink-40)}
  .botnav .item.active{color:var(--purple)}
  .botnav .item.active .ic{background:linear-gradient(135deg,var(--purple),var(--grape));color:#fff;border-radius:14px}
  .botnav .ic{width:30px;height:30px;display:grid;place-items:center}

  /* chat animation */
  .field{position:relative;align-items:flex-start}
  .ftext{flex:1;min-width:0;line-height:1.4}
  #typed{color:var(--navy);font-weight:600}
  #convo{display:flex;flex-direction:column;gap:12px}
  .caret{display:inline-block;width:2px;height:13px;background:var(--purple);margin-left:1px;vertical-align:text-bottom;opacity:0}
  .caret.blink{animation:blink 1.05s steps(2,jump-none) infinite}
  @keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
  #sendBtn{transition:transform .15s ease}
  #sendBtn.pop{animation:pop .3s ease}
  @keyframes pop{40%{transform:scale(.82)}100%{transform:scale(1)}}
  .enter{animation:bubbleIn .42s cubic-bezier(.18,.9,.3,1.2) both}
  @keyframes bubbleIn{from{opacity:0;transform:translateY(14px) scale(.96)}to{opacity:1;transform:none}}
  .strat{opacity:0;animation:fadeUp .4s ease forwards}
  @keyframes fadeUp{to{opacity:1}}
  /* typing dots */
  .typing{display:flex;gap:5px;padding:14px 15px;align-items:center}
  .typing i{width:8px;height:8px;border-radius:50%;background:var(--lilac);display:inline-block;animation:dot 1.2s infinite ease-in-out}
  .typing i:nth-child(2){animation-delay:.18s}
  .typing i:nth-child(3){animation-delay:.36s}
  @keyframes dot{0%,60%,100%{transform:translateY(0);opacity:.4}30%{transform:translateY(-6px);opacity:1}}

  /* floating cards near phone */
  .float{position:absolute;background:#fff;border-radius:18px;padding:12px 15px;box-shadow:var(--shadow);z-index:4;display:flex;gap:10px;align-items:center;font-weight:700}
  .float .fi{width:38px;height:38px;border-radius:12px;display:grid;place-items:center;color:#fff;flex-shrink:0}
  .float small{display:block;font-size:.7rem;color:var(--ink-40);font-weight:700}
  .float b{font-size:.9rem;color:var(--navy)}
  .f1{top:38px;left:-26px}
  .f2{bottom:54px;right:-30px}

  /* ---------- marquee ---------- */
  .marquee{background:var(--navy);color:#fff;padding:16px 0;overflow:hidden;position:relative}
  .track{display:flex;gap:0;white-space:nowrap;width:max-content;animation:scroll 28s linear infinite}
  .track span{padding:0 28px;font-weight:800;font-size:.96rem;display:inline-flex;align-items:center;gap:28px}
  .track span::after{content:"✦";color:var(--lilac)}
  @keyframes scroll{to{transform:translateX(-50%)}}

  /* ---------- sections ---------- */
  section.feat{padding:84px 0;position:relative}
  .eyebrow{display:inline-flex;align-items:center;gap:8px;color:var(--purple);font-weight:800;text-transform:uppercase;letter-spacing:.08em;font-size:.82rem;margin-bottom:14px}
  .eyebrow::before{content:"";width:22px;height:3px;border-radius:3px;background:var(--lilac)}
  .feat h2{font-size:clamp(1.9rem,3.4vw,2.7rem);font-weight:800;max-width:620px}
  .feat .twocol{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
  .feat .lead{font-size:1.1rem;color:var(--navy-soft);margin:18px 0 24px;font-weight:500}
  .checklist{list-style:none;display:flex;flex-direction:column;gap:13px}
  .checklist li{display:flex;gap:12px;align-items:flex-start;font-weight:700;color:var(--navy)}
  .checklist .ck{width:26px;height:26px;border-radius:9px;background:var(--sage-soft);color:#2f9d62;display:grid;place-items:center;flex-shrink:0}

  /* generic visual card */
  .vcard{background:#fff;border-radius:28px;padding:26px;box-shadow:var(--shadow);position:relative;z-index:2}
  .soft-bg{background:var(--lavender)}

  /* routine visual */
  .routine .day{display:flex;gap:12px;align-items:center;padding:13px 14px;border-radius:16px;background:#faf6fe;margin-bottom:10px;border:1.5px solid #f0e7fa}
  .routine .t{font-family:'Baloo 2';font-weight:700;color:var(--purple);width:54px;flex-shrink:0}
  .routine .emo{width:36px;height:36px;border-radius:11px;background:var(--lilac-100);display:grid;place-items:center;font-size:1.1rem;flex-shrink:0}
  .routine .lbl b{display:block;font-size:.95rem}
  .routine .lbl small{color:var(--ink-40);font-weight:700}

  /* library grid */
  .lib-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px}
  .matcard{background:#fff;border-radius:20px;padding:18px;box-shadow:var(--shadow-sm);border:1.5px solid #f1e9fa;transition:.2s}
  .matcard:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
  .matcard .thumb{height:96px;border-radius:14px;display:grid;place-items:center;font-size:2.2rem;margin-bottom:12px}
  .matcard b{display:block;font-size:.98rem}
  .matcard small{color:var(--ink-40);font-weight:700}

  /* reminder visual */
  .remind{background:#fff;border-radius:18px;padding:16px;box-shadow:var(--shadow-sm);display:flex;gap:13px;align-items:center;margin-bottom:12px;border:1.5px solid #f1e9fa}
  .remind .bell{width:44px;height:44px;border-radius:13px;background:linear-gradient(135deg,var(--lilac),var(--purple));color:#fff;display:grid;place-items:center;flex-shrink:0}
  .remind .sent{margin-left:auto;background:var(--sage-soft);color:#2f9d62;font-size:.72rem;font-weight:800;padding:5px 11px;border-radius:30px}

  /* steps */
  .steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:46px}
  .step{background:#fff;border-radius:22px;padding:26px 22px;box-shadow:var(--shadow-sm);position:relative;border-top:5px solid var(--lilac)}
  .step .num{font-family:'Baloo 2';font-weight:800;font-size:2.4rem;color:var(--lilac-200);line-height:1}
  .step h4{font-size:1.15rem;margin:6px 0 8px}
  .step p{font-size:.92rem;color:var(--navy-soft);font-weight:600}

  /* stats */
  .stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:42px}
  .stat{text-align:center}
  .stat b{font-family:'Baloo 2';font-weight:800;font-size:2.4rem;display:block;line-height:1}
  .stat span{color:var(--navy-soft);font-weight:700;font-size:.92rem}

  /* testimonials */
  .tgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:42px}
  .tcard{background:#fff;border-radius:22px;padding:26px;box-shadow:var(--shadow-sm);border:1.5px solid #f3ecfb}
  .tcard .stars{color:#f7b500;margin-bottom:10px;letter-spacing:2px}
  .tcard p{font-weight:600;color:var(--navy);font-size:.98rem}
  .tcard .person{display:flex;gap:11px;align-items:center;margin-top:16px}
  .tcard .pa{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--lilac),var(--sage));display:grid;place-items:center;color:#fff;font-family:'Baloo 2';font-weight:700}
  .tcard .person b{font-size:.95rem}
  .tcard .person small{color:var(--ink-40);font-weight:700;display:block}

  /* pricing */
  .pricing{background:linear-gradient(180deg,var(--lavender),var(--cream));position:relative}
  .price-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;max-width:820px;margin:46px auto 0}
  .plan{background:#fff;border-radius:26px;padding:34px;box-shadow:var(--shadow-sm);position:relative;border:2px solid #efe6f8}
  .plan.best{border-color:var(--purple);box-shadow:var(--shadow);transform:scale(1.02)}
  .best-tag{position:absolute;top:-15px;left:50%;transform:translateX(-50%);background:linear-gradient(120deg,var(--purple),var(--grape));color:#fff;font-weight:800;font-size:.78rem;padding:7px 18px;border-radius:30px;display:flex;gap:6px;align-items:center}
  .plan .pname{font-family:'Baloo 2';font-weight:700;font-size:1.3rem;color:var(--grape)}
  .plan .price{font-family:'Baloo 2';font-weight:800;font-size:3rem;color:var(--navy);margin:8px 0 2px;line-height:1}
  .plan .price small{font-size:1.1rem;color:var(--ink-40);font-weight:700}
  .plan .per{color:var(--ink-40);font-weight:700;margin-bottom:20px}
  .plan ul{list-style:none;display:flex;flex-direction:column;gap:11px;margin-bottom:24px}
  .plan li{display:flex;gap:9px;font-weight:700;font-size:.95rem}
  .plan li svg{color:#2f9d62;flex-shrink:0}
  .plan .btn{width:100%}
  .guarantees{display:flex;justify-content:center;gap:30px;flex-wrap:wrap;margin-top:30px;color:var(--navy-soft);font-weight:700;font-size:.9rem}
  .guarantees span{display:flex;gap:8px;align-items:center}
  .guarantees svg{color:var(--lilac)}

  /* faq */
  .faq{max-width:760px;margin:40px auto 0}
  .qa{background:#fff;border-radius:18px;margin-bottom:14px;box-shadow:var(--shadow-sm);overflow:hidden;border:1.5px solid #f3ecfb}
  .qa button{width:100%;text-align:left;background:none;border:none;cursor:pointer;padding:20px 24px;font-family:'Baloo 2';font-weight:700;font-size:1.08rem;color:var(--navy);display:flex;justify-content:space-between;align-items:center;gap:14px}
  .qa .ans{max-height:0;overflow:hidden;transition:max-height .3s ease;padding:0 24px}
  .qa .ans p{padding-bottom:20px;color:var(--navy-soft);font-weight:600}
  .qa.open .ans{max-height:280px}
  .qa .toggle{transition:transform .3s;color:var(--purple);flex-shrink:0}
  .qa.open .toggle{transform:rotate(45deg)}

  /* cta band */
  .ctaband{background:linear-gradient(120deg,var(--navy),var(--purple-deep));color:#fff;border-radius:34px;padding:60px 40px;text-align:center;position:relative;overflow:hidden;margin:40px auto;max-width:1000px}
  .ctaband h2{font-size:clamp(1.8rem,3.4vw,2.6rem);max-width:680px;margin:0 auto 14px}
  .ctaband p{opacity:.92;font-weight:600;max-width:520px;margin:0 auto 26px}
  .ctaband .btn-primary{background:#fff;color:var(--grape)}

  /* footer */
  footer{background:var(--navy);color:#fff;padding:64px 0 28px;margin-top:30px}
  .fgrid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.3fr;gap:36px}
  .footer .logo{color:#fff}
  footer p.fdesc{color:#b7b0d6;font-weight:600;margin:16px 0;max-width:280px}
  .ftags{display:flex;gap:8px;flex-wrap:wrap}
  .ftag{background:rgba(255,255,255,.1);padding:6px 12px;border-radius:30px;font-size:.78rem;font-weight:700}
  footer h5{font-family:'Baloo 2';font-weight:700;margin-bottom:16px;font-size:1.05rem}
  footer .flist a{display:block;color:#b7b0d6;font-weight:600;margin-bottom:10px;transition:.2s}
  footer .flist a:hover{color:var(--lilac-200)}
  .fbottom{border-top:1px solid rgba(255,255,255,.12);margin-top:40px;padding-top:22px;color:#9089b5;font-size:.85rem;font-weight:600;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px}

  /* reveal */
  .reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
  .reveal.in{opacity:1;transform:none}

  /* responsive */
  @media(max-width:920px){
    .nav-links{display:none}
    .menu-btn{display:block}
    .feat .twocol{grid-template-columns:1fr;gap:40px}
    .steps{grid-template-columns:repeat(2,1fr)}
    .stats{grid-template-columns:repeat(2,1fr)}
    .tgrid{grid-template-columns:1fr}
    .price-grid{grid-template-columns:1fr}
    .fgrid{grid-template-columns:1fr 1fr}
    .plan.best{transform:none}
    .f1,.f2{display:none}
  }
  @media(max-width:560px){
    .lib-grid{grid-template-columns:1fr 1fr}
    .steps,.stats,.fgrid{grid-template-columns:1fr}
  }
