:root {
  --purple: #927397;
  --purple-dark: #6f5276;
  --pink: #d6809c;
  --peach: #fddfd5;
  --cream: #faf5ef;
  --grey: #7f7f7f;
  --ink: #302b31;
  --white: #fffdfb;
  --line: rgba(111, 82, 118, .14);
  --shadow: 0 18px 48px rgba(63, 46, 62, .10);
  --radius: 26px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--ink);
  background: var(--white);
  font-family: 'Montserrat', Arial, sans-serif;
  line-height: 1.6;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
p { margin: 0 0 1rem; }
h1,h2,h3 { margin: 0 0 1rem; line-height: 1.13; color: var(--ink); }
h1,h2 { font-family: 'Fraunces', Georgia, serif; letter-spacing: -.025em; }
h1 { font-size: clamp(2.8rem, 5.7vw, 4.65rem); }
h2 { font-size: clamp(2rem, 3.5vw, 3rem); }
h3 { font-size: 1.15rem; }
.container { width: min(1160px, calc(100% - 42px)); margin: 0 auto; }
.narrow { max-width: 820px; }
.center { text-align: center; }
.section { padding: clamp(4rem, 7vw, 6.3rem) 0; }
.section--tint { background: var(--peach); }
.section--cream { background: var(--cream); }
.section--purple { background: var(--purple-dark); color: var(--white); }
.section--purple h2, .section--purple h3 { color: var(--white); }
.eyebrow {
  color: var(--pink);
  font-size: .79rem;
  font-weight: 800;
  letter-spacing: .13em;
  text-transform: uppercase;
  margin-bottom: 1rem;
}
.eyebrow--light { color: var(--peach); }
.bold { font-weight: 700; }
.button {
  min-height: 54px;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  padding: .88rem 1.5rem;
  border-radius: 999px;
  color: #fff;
  background: var(--purple-dark);
  font-weight: 750;
  letter-spacing: -.01em;
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
  box-shadow: 0 10px 22px rgba(111,82,118,.20);
}
.button:hover { transform: translateY(-2px); background: var(--purple); box-shadow: 0 15px 29px rgba(111,82,118,.27); }
.button--small { min-height: 44px; padding: .65rem 1.15rem; font-size: .93rem; }
.button--wide { width: 100%; }
.button--light { background: var(--white); color: var(--purple-dark); }
.button--light:hover { color: #fff; }
.text-link { color: var(--purple-dark); font-weight: 650; padding: .9rem .1rem; }
.text-link:hover { color: var(--pink); }
.announcement { background: var(--purple-dark); color: white; font-size: .89rem; }
.announcement__inner { display: flex; min-height: 47px; justify-content: center; align-items: center; gap: 1rem; flex-wrap: wrap; padding: .5rem 0; }
.announcement__divider { width: 1px; height: 18px; background: rgba(255,255,255,.35); }
.pill { border: 1px solid rgba(255,255,255,.4); border-radius: 999px; padding: .15rem .8rem; font-size: .78rem; font-weight: 600; }
.site-header { position: sticky; top: 0; z-index: 10; background: rgba(255,253,251,.92); backdrop-filter: blur(12px); border-bottom: 1px solid var(--line); }
.site-header__inner { height: 80px; display: flex; align-items: center; gap: 2.2rem; }
.brand { margin-right: auto; }
.brand img { width: 185px; height: auto; }
.desktop-nav { display: flex; gap: 1.7rem; color: var(--grey); font-size: .92rem; font-weight: 600; }
.desktop-nav a:hover { color: var(--purple-dark); }
.hero { position: relative; overflow: hidden; padding: clamp(3.6rem, 7vw, 6rem) 0; background: linear-gradient(115deg, var(--cream) 0%, #fffdfb 58%, #f8eef1 100%); }
.hero::before, .hero::after { content: ''; position: absolute; border-radius: 50%; pointer-events: none; }
.hero::before { width: 360px; height: 360px; right: -140px; top: -160px; background: var(--peach); opacity: .6; }
.hero::after { width: 215px; height: 215px; left: -120px; bottom: -90px; background: rgba(214,128,156,.14); }
.hero__grid { position: relative; display: grid; grid-template-columns: 1.05fr .7fr; gap: clamp(2rem, 5vw, 5rem); align-items: center; }
.hero__claim { color: var(--purple-dark); font-size: clamp(1.38rem, 2.4vw, 1.86rem); font-weight: 700; line-height: 1.3; margin: -0.3rem 0 1.3rem; }
.hero__claim span { color: var(--pink); }
.hero__text { max-width: 625px; font-size: 1.05rem; margin-bottom: 1.55rem; }
.check-list { list-style: none; margin: 0; padding: 0; }
.check-list li { position: relative; padding-left: 1.8rem; margin-bottom: .65rem; }
.check-list li::before { content: '✓'; position: absolute; left: 0; top: -.04rem; color: var(--pink); font-weight: 800; }
.hero__checks { margin-bottom: 2rem; }
.hero__actions { display: flex; align-items: center; gap: 1.35rem; flex-wrap: wrap; }
.offer-card { position: relative; background: white; border-radius: var(--radius); padding: clamp(1.6rem, 4vw, 2.35rem); box-shadow: var(--shadow); border: 1px solid rgba(146,115,151,.10); }
.offer-card__badge { display: inline-block; color: var(--purple-dark); background: var(--peach); padding: .4rem .8rem; border-radius: 999px; font-size: .76rem; font-weight: 750; margin-bottom: 1.25rem; text-transform: uppercase; letter-spacing: .05em; }
.offer-card h2 { font-size: clamp(2rem, 3vw, 2.6rem); margin-bottom: .25rem; }
.offer-card__subtitle { color: var(--grey); margin-bottom: 1.5rem; }
.pricing { display: grid; grid-template-columns: auto auto; align-items: baseline; justify-content: start; column-gap: .75rem; margin: 1.5rem 0; padding: 1.2rem 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.pricing__label { grid-column: span 2; color: var(--grey); font-size: .86rem; }
.pricing__old { font-size: 1.13rem; color: var(--grey); text-decoration: line-through; }
.pricing__today { color: var(--purple-dark); font-weight: 800; font-size: 3.1rem; line-height: 1; }
.pricing__note { grid-column: span 2; font-size: .82rem; color: var(--pink); font-weight: 700; margin-top: .3rem; }
.offer-detail { margin: 0 0 1.55rem; }
.offer-detail div { display: flex; justify-content: space-between; gap: 1rem; border-bottom: 1px dashed rgba(127,127,127,.26); padding: .55rem 0; font-size: .91rem; }
.offer-detail span { color: var(--grey); }
.secure { color: var(--grey); text-align: center; font-size: .77rem; margin: .9rem 0 0; }
.pain { background: #fffdfb; padding-top: clamp(3.8rem, 7vw, 5.7rem); padding-bottom: clamp(3.8rem, 7vw, 5.7rem); }
.pain__intro { max-width: 890px; margin: 0 auto 2.4rem; text-align: center; }
.pain__intro h2 { max-width: 830px; margin: 0 auto 1.25rem; }
.pain__intro > p:not(.eyebrow):not(.pain__lead) { max-width: 735px; margin: 0 auto; color: #625965; font-size: 1.02rem; }
.pain__lead { font-size: clamp(1.12rem, 2vw, 1.27rem); color: var(--purple-dark); margin: 0 auto 1.1rem; }
.pain-grid { max-width: 1050px; margin: 0 auto; display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; }
.pain-item { background: var(--cream); border: 1px solid rgba(146,115,151,.10); border-radius: 18px; padding: 1.45rem 1.25rem; min-height: 184px; }
.pain-item span { display: block; font-size: 1.45rem; margin-bottom: .75rem; }
.pain-item p { color: #514952; font-size: .92rem; line-height: 1.55; margin: 0; }
.pain__turn { max-width: 875px; margin: 2.3rem auto 0; padding: clamp(1.45rem, 4vw, 2.05rem) clamp(1.35rem, 4vw, 2.6rem); border-radius: 22px; background: var(--peach); text-align: center; }
.pain__turn h3 { font-family: 'Fraunces', Georgia, serif; color: var(--purple-dark); font-size: clamp(1.35rem, 2.3vw, 1.7rem); margin-bottom: .65rem; }
.pain__turn p { max-width: 710px; margin: 0 auto; color: #514952; }
.metrics { background: white; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.metrics__grid { display: grid; grid-template-columns: repeat(4, 1fr); }
.metrics__grid div { padding: 1.9rem 1.2rem; text-align: center; border-right: 1px solid var(--line); }
.metrics__grid div:last-child { border: 0; }
.metrics strong { display: block; color: var(--purple-dark); font-size: clamp(1.45rem, 3vw, 1.9rem); font-family: 'Fraunces', Georgia, serif; }
.metrics span { color: var(--grey); font-size: .9rem; }
.summer h2 { margin-bottom: 1.3rem; }
.summer p:not(.eyebrow) { font-size: 1.06rem; }
.statement { margin: 2.6rem auto 0; padding: 1.6rem 2rem; border-radius: 18px; background: var(--cream); color: var(--purple-dark); font-size: clamp(1.15rem, 2.2vw, 1.36rem); }
.two-column { display: grid; grid-template-columns: .82fr 1fr; gap: clamp(2.3rem, 6vw, 5rem); align-items: start; }
.pillar-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1rem; }
.pillar { background: rgba(255,253,251,.76); border-radius: 20px; padding: 1.4rem; min-height: 177px; }
.pillar span { font-size: 1.45rem; }
.pillar h3 { margin: .6rem 0 .4rem; }
.pillar p { font-size: .91rem; margin: 0; color: #625965; }
.callout { max-width: 990px; background: #fff; border: 2px solid var(--peach); border-radius: var(--radius); padding: clamp(2rem, 5vw, 3.2rem); display: grid; grid-template-columns: 62px 1fr; gap: 1.5rem; align-items: start; box-shadow: 0 9px 40px rgba(54,45,54,.05); }
.callout__icon { width: 62px; height: 62px; background: var(--peach); border-radius: 50%; display: grid; place-items: center; font-size: 1.45rem; }
.callout p:last-child { margin-bottom: 0; }
.section-heading { max-width: 770px; margin: 0 auto clamp(2.5rem,5vw,3.7rem); }
.section-heading p:not(.eyebrow) { font-size: 1rem; }
.included__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.1rem; }
.feature { background: white; border-radius: 19px; padding: 1.65rem 1.5rem; min-height: 210px; border: 1px solid rgba(146,115,151,.09); }
.feature--highlight { background: var(--purple-dark); color: white; }
.feature--highlight h3 { color: white; }
.feature__number { color: var(--pink); font-size: .75rem; letter-spacing: .12em; font-weight: 800; margin-bottom: 1rem; }
.feature h3 { margin-bottom: .65rem; }
.feature p { font-size: .93rem; margin: 0; }
.weeks__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: .95rem; max-width: 980px; margin: 0 auto; }
.week { background: var(--cream); padding: 0; border-radius: 16px; overflow: hidden; border: 1px solid rgba(146,115,151,.10); }
.week summary { cursor: pointer; padding: 1.15rem 1.25rem; font-weight: 680; list-style: none; display: flex; align-items: center; gap: .65rem; }
.week summary::-webkit-details-marker { display: none; }
.week summary::after { content: '+'; color: var(--purple); font-size: 1.3rem; margin-left: auto; }
.week[open] summary::after { content: '–'; }
.week summary span { background: var(--peach); color: var(--purple-dark); padding: .25rem .55rem; font-size: .75rem; font-weight: 800; border-radius: 999px; }
.week ul { margin: 0; padding: 0 1.35rem 1.35rem 2.35rem; color: #625965; font-size: .91rem; }
.week li { margin-bottom: .43rem; }
.movement__grid { display: grid; grid-template-columns: 1fr .7fr; gap: clamp(2rem, 5vw, 5rem); align-items: center; }
.movement p:not(.eyebrow) { opacity: .92; }
.check-list--light li::before { color: var(--peach); }
.live-card { background: rgba(255,255,255,.10); border: 1px solid rgba(255,255,255,.21); border-radius: var(--radius); padding: clamp(1.6rem,4vw,2.5rem); }
.live-card__tag { display: inline-block; color: var(--purple-dark); background: var(--peach); border-radius: 999px; padding: .28rem .72rem; font-weight: 800; font-size: .75rem; letter-spacing: .1em; }
.live-card__line { padding: .75rem 0; display: flex; justify-content: space-between; border-top: 1px solid rgba(255,255,255,.18); }
.bonus__header { display: flex; justify-content: space-between; align-items: end; gap: 2rem; margin-bottom: 3rem; }
.bonus__header > div { max-width: 710px; }
.bonus__stamp { width: 116px; height: 116px; flex: 0 0 116px; display: grid; place-items: center; text-align: center; background: var(--pink); color: white; font-weight: 800; border-radius: 50%; text-transform: uppercase; font-size: .8rem; transform: rotate(-8deg); }
.ebook-grid { display: grid; grid-template-columns: repeat(3, 1fr) .9fr; gap: 1.25rem; align-items: center; }
.ebook { margin: 0; }
.ebook img { width: 100%; border-radius: 9px; box-shadow: 0 14px 32px rgba(57,48,54,.14); }
.ebook figcaption { font-weight: 700; text-align: center; font-size: .91rem; padding: .9rem 0 0; color: var(--purple-dark); }
.ebook--lifted { transform: translateY(-16px); }
.bonus-list { padding: 1.3rem 0 1.3rem 1.2rem; }
.bonus-list p { font-size: .9rem; color: var(--grey); margin-top: 1.4rem; }
.audience__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.15rem; }
.audience-card { padding: clamp(1.7rem,4vw,2.5rem); border-radius: var(--radius); background: white; }
.audience-card--yes { border-top: 5px solid var(--pink); }
.audience-card--gentle { border-top: 5px solid var(--purple); }
.gentle-list { list-style: none; padding: 0; margin: 0; }
.gentle-list li { position: relative; padding-left: 1.8rem; margin: 0 0 .65rem; }
.gentle-list li::before { content: '→'; position: absolute; left: 0; color: var(--purple); font-weight: 700; }
.who__inner { max-width: 820px; text-align: center; margin: 0 auto; }
.who__inner p:not(.eyebrow):not(.signature) { font-size: 1.06rem; }
.signature { margin-top: 1.7rem; color: var(--pink); font-weight: 700; letter-spacing: .22em; text-transform: uppercase; font-size: .82rem; }
.checkout__box { display: grid; grid-template-columns: 1fr 360px; gap: clamp(2rem,5vw,4rem); align-items: center; background: white; border-radius: var(--radius); padding: clamp(2rem,5vw,3.4rem); box-shadow: var(--shadow); }
.checkout__offer { text-align: center; border-left: 1px solid var(--line); padding-left: clamp(1.5rem,4vw,3rem); }
.checkout__value { color: var(--grey); margin-bottom: 0; }
.checkout__price { font-family: 'Fraunces', Georgia, serif; color: var(--purple-dark); font-size: 4.5rem; font-weight: 700; line-height: 1.1; margin: .2rem 0; }
.checkout__caption { font-size: .84rem; color: var(--grey); }
.faq details { border-bottom: 1px solid var(--line); }
.faq summary { cursor: pointer; list-style: none; padding: 1.25rem .4rem; display: flex; gap: 1rem; align-items: center; font-weight: 680; }
.faq summary::after { content: '+'; margin-left: auto; font-size: 1.4rem; color: var(--pink); }
.faq details[open] summary::after { content: '–'; }
.faq summary::-webkit-details-marker { display:none; }
.faq details p { padding: 0 2rem 1.35rem .4rem; color: #5c555c; }
.final-cta { padding: clamp(4.5rem,8vw,7rem) 0; background: var(--purple-dark); color: white; }
.final-cta h2 { color: white; font-size: clamp(2.2rem,4vw,3.3rem); }
.final-cta p:not(.eyebrow) { font-size: 1.07rem; max-width: 640px; margin: 0 auto 2rem; opacity: .9; }
.site-footer { padding: 2.7rem 0 6rem; background: #fff; border-top: 1px solid var(--line); }
.site-footer__inner { display: flex; flex-direction: column; align-items: center; text-align: center; gap: .85rem; color: var(--grey); font-size: .84rem; }
.site-footer__logo { width: 168px; margin-bottom: .4rem; }
.legal-note { max-width: 560px; margin: 0; }
.footer-links { display: flex; gap: 1.25rem; margin-top: .4rem; }
.footer-links a:hover { color: var(--purple-dark); }
.mobile-buybar { display: none; }
@media (max-width: 930px) {
  .pain-grid { grid-template-columns: repeat(2, 1fr); }
  .pain-item { min-height: 0; }
  .desktop-nav { display: none; }
  .hero__grid, .two-column, .movement__grid, .checkout__box { grid-template-columns: 1fr; }
  .hero__content { order: 0; }
  .offer-card { max-width: 520px; }
  .included__grid { grid-template-columns: repeat(2, 1fr); }
  .ebook-grid { grid-template-columns: repeat(3,1fr); }
  .bonus-list { grid-column: 1 / -1; padding-left: 0; }
  .checkout__offer { border: 0; border-top: 1px solid var(--line); padding: 1.6rem 0 0; }
}
@media (max-width: 680px) {
  body { padding-bottom: 72px; }
  .container { width: min(100% - 32px, 1160px); }
  .announcement__inner { gap: .4rem .75rem; font-size: .79rem; }
  .announcement__divider { display: none; }
  .site-header__inner { height: 68px; }
  .brand img { width: 145px; }
  .site-header .button { display: none; }
  .hero { padding: 2.8rem 0 3.2rem; }
  .hero__text { font-size: .97rem; }
  .hero__actions .button { width: 100%; }
  .hero__actions { justify-content: center; }
  .metrics__grid { grid-template-columns: repeat(2, 1fr); }
  .metrics__grid div:nth-child(2) { border-right: 0; }
  .metrics__grid div:nth-child(1), .metrics__grid div:nth-child(2) { border-bottom: 1px solid var(--line); }
  .pillar-grid, .included__grid, .weeks__grid, .audience__grid, .pain-grid { grid-template-columns: 1fr; }
  .callout { display: block; }
  .callout__icon { margin-bottom: 1.4rem; }
  .bonus__header { align-items: start; }
  .bonus__stamp { width: 88px; height: 88px; flex-basis: 88px; font-size: .68rem; }
  .ebook-grid { gap: .6rem; }
  .ebook figcaption { font-size: .75rem; }
  .ebook--lifted { transform: translateY(-8px); }
  .mobile-buybar { position: fixed; z-index: 20; bottom: 0; left: 0; right: 0; background: white; display: flex; gap: 1rem; align-items: center; justify-content: space-between; padding: .55rem 1rem; box-shadow: 0 -7px 24px rgba(45,37,46,.12); }
  .mobile-buybar div span { display: block; font-size: .68rem; color: var(--grey); }
  .mobile-buybar div strong { display: block; color: var(--purple-dark); font-size: 1.3rem; line-height: 1.1; }
  .mobile-buybar .button { min-height: 48px; padding: .7rem 1.22rem; font-size: .9rem; }
}
