
  :root{
    --grape:#5B2A9D;
    --grape-deep:#3D1A6B;
    --lilac:#C9A8F0;
    --wash:#F3ECFC;
    --white:#FFFFFF;
    --ink:#241433;
    --muted:#6B5A80;
    --line:#E6D9F5;
    --radius:22px;
    --maxw:1120px;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{
    font-family:'Plus Jakarta Sans',system-ui,sans-serif;
    color:var(--ink);
    background:var(--white);
    line-height:1.55;
    -webkit-font-smoothing:antialiased;
  }
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
  h1,h2,h3{font-family:'Fraunces',Georgia,serif;font-weight:500;line-height:1.08;letter-spacing:-.01em}
  a{color:inherit;text-decoration:none}
  .accent{color:var(--grape)}

  /* nav */
  header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.85);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
  nav{display:flex;align-items:center;justify-content:space-between;height:72px}
  .logo{display:inline-flex;align-items:center}
  .logo svg{height:30px;width:auto;display:block}
  .foot .logo svg{height:32px}
  .nav-links{display:flex;gap:30px;align-items:center;font-weight:500;font-size:15px}
  .nav-links a{color:var(--muted);transition:color .2s}
  .nav-links a:hover{color:var(--grape)}
  .btn{display:inline-flex;align-items:center;gap:8px;padding:13px 24px;border-radius:100px;font-weight:600;font-size:15px;font-family:'Plus Jakarta Sans';cursor:pointer;border:none;transition:transform .15s,box-shadow .2s}
  .btn-primary{background:var(--grape);color:#fff;box-shadow:0 8px 24px rgba(91,42,157,.28)}
  .btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(91,42,157,.36)}
  .btn-ghost{background:var(--wash);color:var(--grape)}
  .btn-ghost:hover{background:var(--lilac)}
  .btn-white{background:#fff;color:var(--grape);border:1.5px solid var(--grape)}
  .btn-white:hover{background:var(--grape);color:#fff!important;transform:translateY(-2px)}
  @media(max-width:760px){.nav-links a:not(.btn){display:none}}

  /* hero */
  .hero{position:relative;overflow:hidden;padding:104px 0 110px;text-align:center;background:#fff}
  .hero-bg{position:absolute;inset:0;z-index:0;pointer-events:none}
  .hero-bg svg{width:100%;height:100%}
  /* soft white veil so text always sits cleanly on the image */
  .hero::before{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
    background:radial-gradient(120% 90% at 50% 38%, rgba(255,255,255,.78) 0%, rgba(255,255,255,.5) 42%, rgba(255,255,255,.15) 100%);}
  .hero .wrap{position:relative;z-index:2}
  @keyframes drift1{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(40px,-30px) scale(1.12)}}
  @keyframes drift2{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-50px,30px) scale(1.08)}}
  @keyframes drift3{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(30px,40px) scale(1.15)}}
  .blob1{animation:drift1 16s ease-in-out infinite;transform-origin:center}
  .blob2{animation:drift2 20s ease-in-out infinite;transform-origin:center}
  .blob3{animation:drift3 18s ease-in-out infinite;transform-origin:center}
  .pill{display:inline-flex;align-items:center;gap:8px;padding:7px 16px;background:rgba(255,255,255,.7);backdrop-filter:blur(6px);border:1px solid var(--line);border-radius:100px;font-size:13.5px;font-weight:600;color:var(--grape);margin-bottom:26px}
  .pill .dot{width:7px;height:7px;border-radius:50%;background:#3ec98a;box-shadow:0 0 0 3px rgba(62,201,138,.2)}
  .hero h1{font-size:clamp(40px,7vw,78px);max-width:14ch;margin:0 auto 22px}
  .hero p{font-size:clamp(17px,2.2vw,21px);color:var(--muted);max-width:54ch;margin:0 auto 34px}
  .hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
  .micro{margin-top:20px;font-size:13.5px;color:var(--muted)}

  /* marquee logos / trust */
  .trust{padding:48px 0 18px;text-align:center}
  .trust .label{font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:26px}
  .marquee{position:relative;overflow:hidden;width:100%;
    -webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);
    mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);}
  .marquee-track{display:flex;width:max-content;align-items:center;
    animation:scrollLeft 38s linear infinite;}
  .marquee:hover .marquee-track{animation-play-state:paused}
  @keyframes scrollLeft{from{transform:translateX(0)}to{transform:translateX(-50%)}}
  .brand{white-space:nowrap;display:flex;align-items:center;justify-content:center;padding:0 30px;height:48px}
  .brand img{max-height:30px;width:auto;max-width:150px;object-fit:contain;display:block;
    opacity:.8;transition:opacity .25s}
  .marquee:hover .brand img{opacity:1}
  @media(prefers-reduced-motion:reduce){.marquee-track{animation:none;justify-content:center;flex-wrap:wrap}}

  /* section scaffold */
  section{padding:88px 0}
  .eyebrow{font-size:13px;letter-spacing:.16em;text-transform:uppercase;font-weight:700;color:var(--lilac);margin-bottom:14px}
  .lilac-strong{color:#9763d6}
  .sec-head{max-width:60ch}
  .sec-head h2{font-size:clamp(30px,4.5vw,46px);margin-bottom:14px}
  .sec-head p{color:var(--muted);font-size:17px}
  .center{text-align:center;margin-left:auto;margin-right:auto}

  /* steps */
  .steps{display:grid;grid-template-columns:repeat(3,1fr);gap:48px;margin-top:62px}
  .step{text-align:center;display:flex;flex-direction:column;align-items:center}
  .step .icon{width:104px;height:104px;display:grid;place-items:center;margin-bottom:24px;color:var(--grape);
    background:radial-gradient(circle at 50% 45%, var(--wash) 0%, rgba(243,236,252,0) 72%);border-radius:50%}
  .step .icon svg{width:62px;height:62px;overflow:visible}
  .step:hover .icon svg{animation:bob .6s ease}
  @keyframes bob{0%,100%{transform:translateY(0)}40%{transform:translateY(-6px)}}
  .step h3{font-size:23px;margin:0 0 10px;color:var(--ink)}
  .step p{color:var(--muted);font-size:15.5px;max-width:34ch}
  @media(max-width:840px){.steps{grid-template-columns:1fr;gap:44px}}

  /* services grid */
  .services{background:var(--grape-deep);color:#fff;border-radius:34px;padding:64px 48px;margin-top:0}
  .services .eyebrow{color:var(--lilac)}
  .services h2{color:#fff;font-size:clamp(28px,4vw,42px)}
  .services p.intro{color:#d8c6f0;max-width:56ch}
  .chips{display:flex;flex-wrap:wrap;gap:12px;margin-top:38px}
  .chip{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);padding:11px 18px;border-radius:100px;font-size:14.5px;font-weight:500}
  .chip:hover{background:rgba(255,255,255,.16)}
  .services-cta{margin-top:36px;background:#fff;color:var(--grape)}
  .services-cta:hover{background:var(--wash);transform:translateY(-2px)}
  @media(max-width:760px){.services{padding:46px 26px}}

  /* pricing */
  .plans{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:50px;align-items:stretch}
  .plan{border:1px solid var(--line);border-radius:var(--radius);padding:34px 30px;display:flex;flex-direction:column;background:#fff}
  .plan.featured{background:linear-gradient(180deg,var(--grape),var(--grape-deep));color:#fff;border:none;box-shadow:0 20px 50px rgba(91,42,157,.34);transform:translateY(-8px)}
  .plan .tag{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--lilac)}
  .plan.featured .tag{color:#e9d8ff}
  .plan h3{font-size:24px;margin:10px 0 4px}
  .price{font-family:'Fraunces',serif;font-size:46px;font-weight:600;margin:14px 0 2px}
  .price small{font-size:16px;font-family:'Plus Jakarta Sans';color:var(--muted);font-weight:500}
  .plan.featured .price small{color:#d8c6f0}
  .plan ul{list-style:none;margin:22px 0 28px;display:flex;flex-direction:column;gap:11px;flex:1}
  .plan li{font-size:15px;display:flex;gap:10px;align-items:flex-start}
  .plan li svg{flex:none;margin-top:3px}
  .plan .btn{width:100%;justify-content:center}
  .featured .btn-primary{background:#fff;color:var(--grape)}
  .featured .btn-primary:hover{background:var(--wash)}
  @media(max-width:840px){.plans{grid-template-columns:1fr}.plan.featured{transform:none}}

  /* ara callout */
  .ara{background:var(--ink);color:#fff;border-radius:34px;padding:56px 52px;display:flex;align-items:center;justify-content:space-between;gap:40px;position:relative;overflow:hidden}
  .ara::after{content:"";position:absolute;right:-80px;top:-80px;width:300px;height:300px;background:radial-gradient(circle,rgba(201,168,240,.4),transparent 65%)}
  .ara .txt{position:relative;z-index:1;max-width:60ch}
  .ara .eyebrow{color:var(--lilac)}
  .ara h2{font-size:clamp(26px,3.6vw,38px);color:#fff;margin-bottom:12px}
  .ara p{color:#c5b9d4;font-size:16.5px}
  .ara .btn{position:relative;z-index:1;background:var(--lilac);color:var(--ink);white-space:nowrap}
  .ara .btn:hover{background:#fff}
  @media(max-width:840px){.ara{flex-direction:column;text-align:center;padding:44px 28px}}

  /* faq */
  .faq-list{margin-top:44px;border-top:1px solid var(--line)}
  details{border-bottom:1px solid var(--line)}
  summary{cursor:pointer;list-style:none;padding:24px 4px;font-weight:600;font-size:18px;display:flex;justify-content:space-between;align-items:center;gap:20px}
  summary::-webkit-details-marker{display:none}
  summary .plus{font-size:24px;color:var(--grape);transition:transform .25s;font-weight:400}
  details[open] summary .plus{transform:rotate(45deg)}
  details p{padding:0 4px 24px;color:var(--muted);font-size:15.5px;max-width:70ch}

  /* reviews */
  .reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:52px}
  .review{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px 26px;
    display:flex;flex-direction:column;transition:transform .25s,box-shadow .25s}
  .review:hover{transform:translateY(-5px);box-shadow:0 16px 36px rgba(91,42,157,.13)}
  .stars{color:#f0b429;font-size:16px;letter-spacing:2px;margin-bottom:14px}
  .review p{color:var(--ink);font-size:15.5px;line-height:1.6;flex:1;margin:0 0 20px}
  .reviewer{display:flex;align-items:center;gap:12px}
  .avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--grape),var(--lilac));
    display:grid;place-items:center;color:#fff;font-weight:700;font-size:16px;font-family:'Plus Jakarta Sans';flex:none}
  .reviewer .who{line-height:1.3}
  .reviewer .name{font-weight:600;font-size:14.5px;color:var(--ink)}
  .reviewer .role{font-size:13px;color:var(--muted)}
  @media(max-width:840px){.reviews{grid-template-columns:1fr}}

  /* popup toast */
  .toast{position:fixed;left:24px;bottom:24px;z-index:200;max-width:330px;
    background:#fff;border:1px solid var(--line);border-radius:18px;padding:16px 18px;
    box-shadow:0 18px 50px rgba(36,20,51,.22);display:flex;gap:14px;align-items:center;
    transform:translateY(160%);opacity:0;transition:transform .55s cubic-bezier(.16,1,.3,1),opacity .4s}
  .toast.show{transform:translateY(0);opacity:1}
  .toast .tlogo{width:46px;height:46px;border-radius:12px;background:var(--wash);flex:none;
    display:grid;place-items:center;padding:7px}
  .toast .tlogo img{max-width:100%;max-height:100%;object-fit:contain}
  .toast .ttext{font-size:13.5px;color:var(--ink);line-height:1.4}
  .toast .ttext b{color:var(--grape)}
  .toast .tclose{position:absolute;top:8px;right:10px;cursor:pointer;border:none;background:none;
    font-size:17px;color:var(--muted);line-height:1;padding:2px}
  .toast .tclose:hover{color:var(--ink)}

  /* footer */
  footer{background:var(--wash);border-top:1px solid var(--line);padding:56px 0 40px;margin-top:48px}
  .foot-cta{background:linear-gradient(135deg,var(--grape),var(--grape-deep));color:#fff;
    border-radius:28px;padding:48px 52px;margin:0 auto 52px;max-width:var(--maxw);position:relative;
    display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap;
    box-shadow:0 24px 60px rgba(91,42,157,.32)}
  .foot-cta h3{font-size:clamp(24px,3.5vw,34px);color:#fff;margin:0 0 6px}
  .foot-cta p{color:#d8c6f0;font-size:16px;margin:0;max-width:46ch}
  .foot-cta .btn{background:#fff;color:var(--grape);white-space:nowrap}
  .foot-cta .btn:hover{background:var(--wash)}
  .foot-inner{padding-top:8px}
  .foot{display:flex;justify-content:space-between;flex-wrap:wrap;gap:40px}
  .foot .logo{margin-bottom:12px}
  .foot p{color:var(--muted);font-size:14.5px;max-width:34ch}
  .foot-social{display:flex;gap:12px;margin-top:18px}
  .foot-social a{width:36px;height:36px;border-radius:10px;background:#fff;border:1px solid var(--line);
    display:grid;place-items:center;color:var(--grape);transition:background .2s,color .2s}
  .foot-social a:hover{background:var(--grape);color:#fff}
  .foot-social svg{width:18px;height:18px}
  .foot-links{display:flex;gap:60px;flex-wrap:wrap}
  .foot-col h4{font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);margin-bottom:14px;font-family:'Plus Jakarta Sans';font-weight:700}
  .foot-col a{display:block;color:var(--muted);font-size:14.5px;margin-bottom:9px}
  .foot-col a:hover{color:var(--grape)}
  .copy{margin-top:40px;padding-top:24px;border-top:1px solid var(--line);font-size:13.5px;color:var(--muted);display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px}
  @media(max-width:760px){.foot-cta{padding:36px 28px;margin:-50px 24px 44px;text-align:center;justify-content:center}}

  .heart{color:#c9a8f0}
  *:focus-visible{outline:3px solid var(--lilac);outline-offset:3px;border-radius:6px}
  @media(prefers-reduced-motion:reduce){*{transition:none!important;scroll-behavior:auto}}

/* ===== blog index ===== */
.blog-hero{text-align:center;padding:88px 0 50px;position:relative;overflow:hidden}
.blog-hero .wrap{position:relative;z-index:2}
.posts{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;padding:24px 0 30px}
@media(max-width:880px){.posts{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.posts{grid-template-columns:1fr}}
.pcard{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#fff;transition:transform .25s,box-shadow .25s}
.pcard:hover{transform:translateY(-6px);box-shadow:0 18px 44px rgba(91,42,157,.16)}
.pcard .thumb{height:152px;position:relative}
.pcard .thumb.v1{background:linear-gradient(135deg,var(--grape),var(--lilac))}
.pcard .thumb.v2{background:linear-gradient(135deg,#7C3FCB,#E3CDFA)}
.pcard .thumb.v3{background:linear-gradient(135deg,var(--grape-deep),var(--grape))}
.pcard .thumb.v4{background:linear-gradient(135deg,#9763d6,#F3ECFC)}
.pcard .thumb.v5{background:linear-gradient(135deg,var(--grape),#B98BF0)}
.pcard .thumb span{position:absolute;left:18px;bottom:14px;color:#fff;font-size:12.5px;font-weight:600;letter-spacing:.04em;background:rgba(0,0,0,.2);padding:5px 12px;border-radius:100px}
.pcard .pbody{padding:24px 24px 26px;display:flex;flex-direction:column;flex:1}
.pcard h3{font-size:20px;margin-bottom:10px;line-height:1.25}
.pcard p{color:var(--muted);font-size:14.5px;flex:1;margin-bottom:16px}
.pcard .read{color:var(--grape);font-weight:600;font-size:14px}

/* ===== article ===== */
.article{max-width:760px;margin:0 auto;padding:54px 24px 30px}
.article .crumb{font-size:14px;color:var(--muted);margin-bottom:22px}
.article .crumb a{color:var(--grape);font-weight:600}
.article .ameta{font-size:13.5px;letter-spacing:.05em;color:#9763d6;font-weight:700;text-transform:uppercase;margin-bottom:14px}
.article h1{font-size:clamp(32px,5vw,48px);line-height:1.12;margin-bottom:20px}
.article .lead{font-size:19px;color:var(--muted);margin-bottom:8px;line-height:1.6}
.article .hr{height:1px;background:var(--line);margin:34px 0}
.article h2{font-size:27px;margin:38px 0 14px}
.article h3{font-size:20px;margin:26px 0 10px}
.article p{font-size:16.5px;color:#3a2b4d;margin-bottom:18px;line-height:1.7}
.article ul,.article ol{margin:0 0 18px 22px;color:#3a2b4d;font-size:16.5px;line-height:1.7}
.article li{margin-bottom:9px}
.article strong{color:var(--ink)}
.article blockquote{border-left:3px solid var(--lilac);padding:6px 0 6px 22px;margin:24px 0;color:var(--muted);font-style:italic;font-size:18px}
.cta-box{background:linear-gradient(135deg,var(--grape),var(--grape-deep));color:#fff;border-radius:28px;padding:44px 40px;margin:46px 0 10px;text-align:center;box-shadow:0 20px 50px rgba(91,42,157,.28)}
.cta-box h3{color:#fff;font-size:28px;margin-bottom:10px}
.cta-box p{color:#d8c6f0;margin-bottom:24px;font-size:16px}
.cta-box .btn{background:#fff;color:var(--grape)}
.cta-box .btn:hover{background:var(--wash)}

/* ===== legal ===== */
.legal{max-width:780px;margin:0 auto;padding:54px 24px 30px}
.legal h1{font-size:clamp(30px,5vw,46px);margin-bottom:10px}
.legal .updated{color:var(--muted);font-size:14px;margin-bottom:30px}
.legal h2{font-size:24px;margin:34px 0 12px}
.legal p{font-size:16px;color:#3a2b4d;margin-bottom:16px;line-height:1.7}
.legal ul{margin:0 0 16px 22px;color:#3a2b4d;font-size:16px;line-height:1.7}
.legal li{margin-bottom:8px}
.legal a{color:var(--grape);font-weight:600}
.page-hero{position:relative;overflow:hidden;text-align:center;padding:80px 0 10px}
.page-hero .wrap{position:relative;z-index:2}
.page-hero .eyebrow{margin-bottom:12px}

/* ===== thank-you page ===== */
.ty{position:relative;overflow:hidden;color:#fff;min-height:calc(100vh - 72px);display:flex;align-items:center;padding:60px 0}
.ty-bg{position:absolute;inset:0;z-index:0}
.ty-bg svg{width:100%;height:100%}
.ty::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(120deg,rgba(36,20,51,.55),rgba(61,26,107,.35))}
.ty-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center}
@media(max-width:900px){.ty-grid{grid-template-columns:1fr;gap:36px}}
.ty-check{width:74px;height:74px;border-radius:50%;background:#fff;color:var(--grape);display:grid;place-items:center;margin-bottom:28px;box-shadow:0 12px 30px rgba(0,0,0,.2)}
.ty-check svg{width:38px;height:38px}
.ty-left h1{font-size:clamp(40px,6vw,68px);line-height:1.05;color:#fff;margin-bottom:22px}
.ty-left p{font-size:18px;color:#e3d6f5;max-width:46ch;margin-bottom:30px;line-height:1.6}
.btn-light{background:#fff;color:var(--grape)}
.btn-light:hover{background:var(--wash);transform:translateY(-2px)}
.ty-panel{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.16);border-radius:28px;padding:38px 36px;backdrop-filter:blur(8px)}
.ty-intro{font-size:19px;font-weight:600;color:#fff;margin-bottom:28px;line-height:1.4}
.ty-steps{list-style:none;margin:0;padding:0;position:relative;display:flex;flex-direction:column;gap:26px}
.ty-steps li{display:flex;gap:18px;align-items:flex-start;position:relative}
.ty-steps li:not(:last-child)::before{content:"";position:absolute;left:21px;top:46px;bottom:-26px;width:2px;background:rgba(255,255,255,.18)}
.ty-steps .si{width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);color:#fff;display:grid;place-items:center;flex:none}
.ty-steps .si svg{width:22px;height:22px}
.ty-steps .st{font-size:15.5px;color:#e3d6f5;line-height:1.5;padding-top:11px}
