:root{
  --lav:#B57EDC;        /* bright lavender */
  --violet:#7C3AED;     /* vivid violet, buttons */
  --violet-d:#6D28D9;
  --lilac:#D6BCFA;      /* soft lilac */
  --lilac-soft:#EADDFD;
  --pale:#F5F0FF;       /* page bg */
  --plum:#2E1A47;       /* dark text */
  --plum-soft:#4A2E6B;
  --white:#fff;
  --ink:#3a2b52;
  --shadow:0 20px 55px rgba(46,26,71,.16);
  --shadow-sm:0 10px 28px rgba(46,26,71,.12);
  --radius:26px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,-apple-system,sans-serif;color:var(--ink);background:var(--pale);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,h4,.mont{font-family:'Montserrat',sans-serif;color:var(--plum);line-height:1.12}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:min(1140px,91%);margin:0 auto}
.script{font-family:'Dancing Script',cursive;font-weight:700}
.lav{color:var(--violet)}
.center{text-align:center}

/* ---------- BUTTONS ---------- */
.btn{display:inline-flex;align-items:center;gap:.5em;font-family:'Montserrat',sans-serif;font-weight:700;border-radius:999px;padding:16px 32px;font-size:1.02rem;cursor:pointer;border:none;transition:transform .16s ease, box-shadow .22s ease;letter-spacing:.2px;text-align:center}
.btn:hover{transform:translateY(-3px)}
.btn-primary{background:var(--violet);color:#fff;box-shadow:0 12px 28px rgba(124,58,237,.42)}
.btn-primary:hover{box-shadow:0 18px 38px rgba(124,58,237,.55)}
.btn-ghost{background:rgba(255,255,255,.75);color:var(--violet);border:2px solid var(--violet)}
.btn-ghost:hover{background:#fff}
.btn-light{background:#fff;color:var(--violet)}
.btn-sm{padding:11px 22px;font-size:.92rem}

/* ---------- NAV ---------- */
.site-header{position:sticky;top:0;z-index:80;background:rgba(245,240,255,.82);backdrop-filter:blur(12px);border-bottom:1px solid rgba(124,58,237,.12)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:15px 0;gap:18px}
.brand{font-family:'Dancing Script',cursive;font-weight:700;font-size:2rem;color:var(--violet);line-height:1}
.nav-links{display:flex;gap:26px;align-items:center}
.nav-links a{font-weight:600;font-size:.97rem;color:var(--plum-soft);transition:color .18s}
.nav-links a:hover{color:var(--violet)}
.nav-cb{display:none}
.hamburger{display:none;font-size:1.7rem;color:var(--violet);cursor:pointer;line-height:1;user-select:none}

/* ---------- HERO ---------- */
.hero{position:relative;min-height:90vh;display:flex;align-items:center;overflow:hidden;background:linear-gradient(105deg,rgba(245,240,255,.30) 0%,rgba(245,240,255,.62) 50%,rgba(245,240,255,.95) 72%),url('images/bloom.png');background-size:cover;background-position:center}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;align-items:center;gap:20px;padding:60px 0}
.hero-copy{max-width:580px}
.eyebrow{display:inline-block;font-family:'Montserrat',sans-serif;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;font-size:.74rem;color:var(--violet);background:rgba(255,255,255,.7);padding:8px 17px;border-radius:999px;margin-bottom:22px}
.hero .wordmark{font-family:'Dancing Script',cursive;font-weight:700;font-size:clamp(3.4rem,8vw,6rem);color:var(--violet);line-height:.9;margin-bottom:6px;filter:drop-shadow(0 8px 22px rgba(124,58,237,.22))}
.hero h1{font-weight:800;font-size:clamp(1.7rem,3.4vw,2.5rem);color:var(--plum);margin:14px 0 18px}
.hero p.lede{font-size:1.22rem;color:var(--plum-soft);margin-bottom:32px;max-width:500px}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap}
.hero-art{position:relative;display:flex;justify-content:center;align-items:flex-end}
.hero-art img{max-height:560px;width:auto;filter:drop-shadow(0 24px 40px rgba(46,26,71,.28))}

/* ---------- SECTIONS ---------- */
section{padding:92px 0;position:relative}
.eyebrow-c{display:block;text-align:center;font-family:'Montserrat',sans-serif;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;font-size:.8rem;color:var(--violet);margin-bottom:14px}
.section-title{font-weight:800;font-size:clamp(1.9rem,4vw,2.9rem);text-align:center;max-width:820px;margin:0 auto 18px}
.section-sub{text-align:center;font-size:1.14rem;max-width:660px;margin:0 auto 56px;color:var(--plum-soft)}
.bg-white{background:var(--white)}
.bg-lilac{background:linear-gradient(160deg,var(--lilac-soft),var(--pale))}
.bg-violet{background:linear-gradient(150deg,var(--violet),var(--lav));color:#fff}
.bg-violet .section-title,.bg-violet .eyebrow-c{color:#fff}
.bg-violet .section-sub{color:rgba(255,255,255,.9)}

/* split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:58px;align-items:center}
.split h2{font-weight:800;font-size:clamp(1.7rem,3.3vw,2.5rem);margin-bottom:20px}
.split p{font-size:1.12rem;margin-bottom:16px;color:var(--plum-soft)}
.split .hl{color:var(--violet);font-weight:700}
.art-card{position:relative;display:flex;justify-content:center;align-items:flex-end;background:linear-gradient(160deg,var(--lilac),var(--lav));border-radius:30px;min-height:430px;padding:0 22px;box-shadow:var(--shadow);overflow:hidden}
.art-card img{max-height:450px;width:auto;filter:drop-shadow(0 18px 30px rgba(46,26,71,.26));position:relative;z-index:2}

/* mockup */
.mockup-wrap{max-width:880px;margin:0 auto 50px;filter:drop-shadow(0 30px 55px rgba(46,26,71,.22))}

/* hub grid */
.hub-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.hub{background:var(--white);border-radius:22px;padding:30px 24px;text-align:center;transition:transform .2s,box-shadow .2s;border:1px solid rgba(124,58,237,.08)}
.hub:hover{transform:translateY(-7px);box-shadow:var(--shadow-sm)}
.hub .ico{width:62px;height:62px;margin:0 auto 18px;border-radius:50%;background:linear-gradient(150deg,var(--violet),var(--lav));display:flex;align-items:center;justify-content:center;font-size:1.7rem}
.hub h3{font-size:1.2rem;margin-bottom:9px}
.hub p{font-size:.96rem;color:var(--plum-soft)}
.hub ul{list-style:none;margin-top:10px;text-align:left;display:inline-block}
.hub ul li{font-size:.9rem;color:var(--plum-soft);padding-left:16px;position:relative;margin-bottom:5px}
.hub ul li::before{content:'';position:absolute;left:0;top:8px;width:7px;height:7px;border-radius:50%;background:var(--lav)}

/* pricing */
.pricing{display:flex;gap:24px;justify-content:center;flex-wrap:wrap;margin-top:8px}
.price-card{background:#fff;border-radius:24px;padding:36px 32px;width:300px;box-shadow:var(--shadow-sm);border:1px solid rgba(124,58,237,.1);display:flex;flex-direction:column;position:relative}
.price-card.featured{background:linear-gradient(160deg,var(--violet),var(--lav));color:#fff;box-shadow:var(--shadow);transform:scale(1.04)}
.price-card .tier{font-family:'Montserrat',sans-serif;font-weight:700;font-size:.78rem;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:14px;color:var(--violet)}
.price-card.featured .tier{color:#fff}
.price-card .amt{font-family:'Montserrat',sans-serif;font-weight:800;font-size:2.6rem;margin-bottom:6px}
.price-card .amt small{font-size:1rem;font-weight:600;opacity:.75}
.price-card p{font-size:1rem;margin-bottom:22px;color:var(--plum-soft);flex-grow:1}
.price-card.featured p{color:rgba(255,255,255,.92)}
.badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--plum);color:#fff;font-family:'Montserrat',sans-serif;font-weight:700;font-size:.68rem;letter-spacing:1px;text-transform:uppercase;padding:6px 16px;border-radius:999px;white-space:nowrap}

/* feature list */
.flist{list-style:none}
.flist li{padding-left:30px;position:relative;margin-bottom:11px;font-size:1.02rem}
.flist li::before{content:'\2713';position:absolute;left:0;top:0;color:var(--violet);font-weight:800}
.price-card.featured .flist li::before{color:#fff}

/* trio cards */
.trio{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.tcard{background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.3);border-radius:22px;padding:32px 26px}
.tcard .ico{font-size:2rem;margin-bottom:14px}
.tcard h3{color:#fff;font-size:1.25rem;margin-bottom:10px}
.tcard p{color:rgba(255,255,255,.9);font-size:1rem}

/* quote */
.quote-band{max-width:880px;margin:0 auto;text-align:center}
.quote-band blockquote{font-family:'Montserrat',sans-serif;font-weight:700;font-size:clamp(1.4rem,3vw,2.1rem);color:var(--plum);line-height:1.3;margin-bottom:30px}
.quote-band blockquote .lav{color:var(--violet)}

/* faq */
.faq{max-width:760px;margin:0 auto}
.faq details{background:#fff;border-radius:16px;padding:4px 24px;margin-bottom:14px;box-shadow:var(--shadow-sm);border:1px solid rgba(124,58,237,.08)}
.faq summary{font-family:'Montserrat',sans-serif;font-weight:700;font-size:1.06rem;color:var(--plum);cursor:pointer;padding:18px 0;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'+';float:right;color:var(--violet);font-size:1.4rem;line-height:1}
.faq details[open] summary::after{content:'\2013'}
.faq details p{padding:0 0 20px;color:var(--plum-soft);font-size:1.02rem}

/* whats-inside list */
.inside{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:920px;margin:0 auto}
.icard{background:#fff;border-radius:22px;padding:30px 26px;box-shadow:var(--shadow-sm);border:1px solid rgba(124,58,237,.08)}
.icard .ico{width:54px;height:54px;border-radius:14px;background:var(--lilac-soft);display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:16px}
.icard h3{font-size:1.18rem;margin-bottom:8px}
.icard p{font-size:.98rem;color:var(--plum-soft)}

/* final cta */
.cta-band{text-align:center}
.cta-band h2{font-weight:800;font-size:clamp(2rem,4.2vw,3rem);margin-bottom:18px}
.cta-band p{font-size:1.18rem;color:var(--plum-soft);max-width:560px;margin:0 auto 32px}
.bg-violet.cta-band p{color:rgba(255,255,255,.92)}
.cta-ctas{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* page hero (inner pages) */
.page-hero{padding:80px 0 40px;text-align:center;position:relative}
.page-hero .eyebrow{margin-bottom:18px}
.page-hero h1{font-weight:800;font-size:clamp(2.2rem,5vw,3.4rem);max-width:880px;margin:0 auto 18px}
.page-hero p{font-size:1.2rem;color:var(--plum-soft);max-width:620px;margin:0 auto}

/* decorative blobs */
.blob{position:absolute;border-radius:50%;filter:blur(60px);opacity:.5;z-index:0;pointer-events:none}
.blob-1{width:340px;height:340px;background:var(--lilac);top:-80px;right:-60px}
.blob-2{width:280px;height:280px;background:var(--lav);bottom:-90px;left:-70px;opacity:.35}
section > .container{position:relative;z-index:2}

/* ---------- FOOTER ---------- */
.site-footer{background:var(--plum);color:#e9def7;padding:64px 0 30px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:36px}
.footer-brand .brand{color:#fff}
.footer-brand p{margin-top:10px;color:#c9b8e6;max-width:280px}
.footer-col h4{font-size:.84rem;letter-spacing:1.5px;text-transform:uppercase;color:#b9a3df;margin-bottom:16px;font-family:'Montserrat',sans-serif}
.footer-col a{display:block;color:#e3d6f7;margin-bottom:11px;font-size:.98rem;transition:color .16s}
.footer-col a:hover{color:#fff}
.footer-bottom{margin-top:48px;padding-top:24px;border-top:1px solid rgba(255,255,255,.12);font-size:.9rem;color:#b9a3df;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* ---------- RESPONSIVE ---------- */
@media(max-width:860px){
  .hamburger{display:block}
  .nav-links{position:absolute;top:100%;left:0;right:0;background:rgba(245,240,255,.98);backdrop-filter:blur(12px);flex-direction:column;align-items:flex-start;gap:0;padding:8px 0;display:none;box-shadow:var(--shadow-sm)}
  .nav-links a{padding:14px 6%;width:100%;font-size:1.05rem}
  .nav-cb:checked ~ .nav-links{display:flex}
  .hero-grid,.split,.inside,.trio{grid-template-columns:1fr;gap:36px}
  .hero-art{order:-1}
  .hero-art img{max-height:360px}
  .hub-grid{grid-template-columns:1fr 1fr}
  section{padding:64px 0}
  .footer-grid{grid-template-columns:1fr 1fr}
  .price-card.featured{transform:none}
}
@media(max-width:520px){
  .hub-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .btn{padding:14px 26px}
}

/* ---------- WORDMARK IMAGES ---------- */
.brand img{height:32px;width:auto;display:block}
.hero .wordmark{margin-bottom:8px}
.hero .wordmark img{height:clamp(60px,11vw,116px);width:auto}
.footer-brand .brand img{height:42px;width:auto}

/* ---------- PRICING (grid) ---------- */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:stretch;max-width:980px;margin:0 auto}
.price-card h3{font-family:'Montserrat',sans-serif;font-weight:800;font-size:1.05rem;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:10px;color:var(--violet)}
.price-card.featured h3{color:#fff}
.price-note{font-size:1rem;margin:0 0 18px;color:var(--plum-soft)}
.price-card.featured .price-note{color:rgba(255,255,255,.92)}
.price-card ul{list-style:none;margin:6px 0 24px;flex-grow:1}
.price-card ul li{padding-left:26px;position:relative;margin-bottom:10px;font-size:1rem;color:var(--plum-soft)}
.price-card ul li::before{content:'\2713';position:absolute;left:0;top:0;color:var(--violet);font-weight:800}
.price-card.featured ul li{color:rgba(255,255,255,.95)}
.price-card.featured ul li::before{color:#fff}
.promo-code{background:rgba(255,255,255,.20);border:1px solid rgba(255,255,255,.45);border-radius:12px;padding:11px 14px;font-size:.95rem;margin-bottom:20px;text-align:center}
.promo-code strong{font-family:'Montserrat',sans-serif;letter-spacing:1px}
.btn-ghost-light{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.7)}
.btn-ghost-light:hover{background:rgba(255,255,255,.12)}

@media(max-width:860px){
  .price-grid{grid-template-columns:1fr;max-width:420px}
  .price-card.featured{transform:none}
}

/* ---------- READABILITY FIXES ---------- */
/* trio cards on LIGHT sections need dark text + solid cards */
.bg-white .tcard,.bg-lilac .tcard{background:#fff;border:1px solid rgba(124,58,237,.12);box-shadow:var(--shadow-sm)}
.bg-white .tcard h3,.bg-lilac .tcard h3{color:var(--plum)}
.bg-white .tcard p,.bg-lilac .tcard p{color:var(--plum-soft)}

/* lighten avatar cards so the line-art reads cleanly */
.art-card{background:linear-gradient(160deg,#F3ECFF,#E4D6FB)}

/* narrow column + Our Story prose */
.narrow{max-width:720px;margin:0 auto}
.story{max-width:700px}
.story p{font-size:1.16rem;line-height:1.85;color:var(--plum-soft);margin-bottom:22px}
.story p .hl{color:var(--violet);font-weight:700}
.story p:first-of-type::first-letter{float:left;font-family:'Montserrat',sans-serif;font-weight:800;font-size:3.6rem;line-height:.82;padding:8px 14px 0 0;color:var(--violet)}
