:root {
  --ink: #21332c;
  --forest: #294a3d;
  --forest-dark: #18352b;
  --sage: #9caf8f;
  --sage-soft: #dbe2d4;
  --cream: #f5f0e7;
  --paper: #fbf8f2;
  --sand: #e8dece;
  --terracotta: #c16d4e;
  --muted: #6f786f;
  --white: #fffdf9;
  --serif: "Manrope", sans-serif;
  --sans: "DM Sans", sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: var(--paper); font-family: var(--sans); }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
.shell { width: min(1160px, calc(100% - 48px)); margin-inline: auto; }

.topbar { height: 34px; background: var(--forest-dark); color: #dfe8df; display: flex; align-items: center; justify-content: center; gap: 18px; font-size: 11px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; }
.topbar span { width: 3px; height: 3px; border-radius: 50%; background: var(--sage); }
.nav { height: 86px; display: flex; align-items: center; justify-content: space-between; }
.brand { display: inline-flex; align-items: center; gap: 10px; font-family: var(--serif); font-size: 17px; letter-spacing: -.04em; }
.brand strong { font-weight: 600; color: var(--terracotta); }
.brand-mark { width: 34px; height: 34px; display: grid; place-items: center; border: 1px solid var(--forest); border-radius: 50% 50% 44% 56%; font-family: Georgia, serif; font-style: italic; }
.nav-link { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; border-bottom: 1px solid var(--ink); padding: 8px 0; }
.nav-link span { margin-left: 12px; }

.hero { min-height: 680px; display: grid; grid-template-columns: .95fr 1.05fr; align-items: center; gap: 60px; padding-bottom: 65px; }
.eyebrow, .kicker { color: var(--terracotta); font-size: 11px; letter-spacing: .14em; font-weight: 700; text-transform: uppercase; }
.eyebrow { display: flex; align-items: center; gap: 10px; }
.eyebrow i { width: 22px; height: 1px; background: var(--terracotta); }
h1, h2 { margin: 20px 0; font-family: var(--serif); font-weight: 500; letter-spacing: -.055em; line-height: .98; }
h1 { font-size: clamp(54px, 5.6vw, 79px); }
h2 { font-size: clamp(42px, 4.5vw, 64px); }
h1 em, h2 em { color: var(--terracotta); font-family: Georgia, serif; font-weight: 400; }
.hero-text { max-width: 510px; color: var(--muted); font-size: 16px; line-height: 1.75; }
.hero-checks { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 22px; max-width: 560px; }
.hero-checks span { background: #fff8ef; border: 1px solid #eadccc; color: var(--forest); padding: 9px 12px; border-radius: 999px; font-size: 11px; font-weight: 700; }
.hero-action { display: flex; align-items: center; gap: 24px; margin-top: 30px; }
.button { min-height: 54px; display: inline-flex; align-items: center; justify-content: center; gap: 34px; padding: 0 26px; font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .07em; transition: transform .2s, background .2s; }
.button:hover { transform: translateY(-2px); }
.button-primary { background: var(--forest); color: var(--white); }
.button-primary:hover { background: var(--forest-dark); }
.mini-proof { display: flex; align-items: center; }
.avatars { display: flex; }
.avatars b { width: 33px; height: 33px; display: grid; place-items: center; border-radius: 50%; background: var(--sand); border: 2px solid var(--paper); margin-left: -9px; font-size: 9px; color: var(--forest); }
.avatars b:first-child { margin: 0; background: #c6d1bf; }
.mini-proof p { font-size: 10px; line-height: 1.4; margin-left: 10px; color: var(--muted); }
.mini-proof strong { color: var(--ink); }
.rating { margin-top: 23px; color: var(--muted); font-size: 11px; }
.rating span { color: var(--terracotta); letter-spacing: 3px; margin-right: 8px; }
.rating strong { color: var(--ink); }

.hero-visual { position: relative; height: 620px; }
.hero-visual .arch { position: absolute; inset: 0 14px 0 22px; background: var(--sage-soft); border-radius: 240px 240px 10px 10px; }
.hero-visual img { position: absolute; width: calc(100% - 72px); height: 568px; right: 0; bottom: 0; object-fit: cover; object-position: 54% center; border-radius: 215px 215px 4px 4px; filter: saturate(.86) contrast(.98); }
.float-card { position: absolute; background: rgba(255,253,249,.96); box-shadow: 0 12px 35px rgba(32,49,43,.12); display: flex; align-items: center; z-index: 2; }
.float-top { right: -10px; top: 116px; padding: 15px 18px; gap: 12px; }
.float-card p { margin: 0; font-size: 11px; line-height: 1.35; }
.float-card small { color: var(--muted); }
.icon-circle { display: grid; place-items: center; width: 31px; height: 31px; border-radius: 50%; background: var(--sage-soft); color: var(--forest); }
.float-bottom { left: 0; bottom: 52px; padding: 18px 23px; gap: 10px; }
.float-bottom > strong { font-family: Georgia, serif; font-size: 38px; color: var(--terracotta); font-weight: 400; }
.scribble { position: absolute; right: 10px; bottom: 8px; color: var(--terracotta); font-size: 38px; transform: rotate(22deg); }

.pain-section { background: #eee8dd; padding: 110px 0; }
.pain-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 120px; }
.section-number { display: inline-block; border-bottom: 1px solid #b8b1a6; padding-bottom: 8px; font-size: 11px; color: var(--muted); margin-bottom: 56px; }
.kicker { margin: 0; }
.section-heading h2 { font-size: clamp(40px, 4vw, 59px); }
.pain-list article { display: grid; grid-template-columns: 45px 1fr; gap: 15px; border-top: 1px solid #cfc7ba; padding: 25px 0; }
.pain-list article > span { font-size: 10px; color: var(--terracotta); padding-top: 4px; }
.pain-list h3 { margin: 0 0 9px; font-family: var(--serif); font-size: 20px; font-weight: 600; }
.pain-list p { margin: 0; max-width: 380px; color: var(--muted); font-size: 13px; line-height: 1.6; }

.audience { padding: 105px 0 20px; }
.audience-intro { display: grid; grid-template-columns: .9fr 1.1fr; align-items: end; gap: 90px; }
.audience-intro h2 { margin-bottom: 0; font-size: clamp(40px, 4vw, 58px); }
.audience-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-top: 55px; }
.audience-grid article { background: var(--white); border: 1px solid #e4ddd1; padding: 28px 24px; box-shadow: 0 16px 36px rgba(33,51,44,.05); }
.audience-grid span { display: grid; place-items: center; width: 30px; height: 30px; border-radius: 50%; background: var(--forest); color: var(--white); font-size: 12px; margin-bottom: 42px; }
.audience-grid h3 { margin: 0 0 10px; font-family: var(--serif); font-size: 21px; }
.audience-grid p { margin: 0; color: var(--muted); font-size: 12px; line-height: 1.6; }

.program { padding: 115px 0; }
.program-intro { display: grid; grid-template-columns: 1fr 1fr; align-items: end; gap: 100px; }
.program-intro h2 { margin-bottom: 0; }
.program-intro > p { color: var(--muted); line-height: 1.7; max-width: 440px; padding-bottom: 10px; }
.benefit-grid { display: grid; grid-template-columns: repeat(3, 1fr); margin-top: 70px; border: 1px solid #ded8ce; }
.benefit-card { min-height: 330px; padding: 36px; border-right: 1px solid #ded8ce; display: flex; flex-direction: column; }
.benefit-card:last-child { border: 0; }
.benefit-card.featured { background: var(--forest); color: white; }
.line-icon { font-family: Georgia, serif; font-size: 40px; color: var(--terracotta); margin-bottom: auto; }
.featured .line-icon { color: #d6dfce; }
.benefit-card > span { font-size: 9px; letter-spacing: .1em; color: var(--terracotta); }
.featured > span { color: #cbd8c4; }
.benefit-card h3 { font-family: var(--serif); font-size: 22px; margin: 13px 0; }
.benefit-card p { color: var(--muted); font-size: 13px; line-height: 1.6; margin: 0; }
.featured p { color: #cbd8cf; }

.roadmap { background: var(--forest-dark); color: var(--white); padding: 110px 0; }
.roadmap-heading { display: grid; grid-template-columns: 1fr 1fr; align-items: end; gap: 100px; }
.kicker.light { color: #b5c8b5; }
.roadmap-heading h2 { margin-bottom: 0; }
.roadmap-heading h2 em { color: #d89a7e; }
.roadmap-heading > p { max-width: 410px; color: #aebbb4; line-height: 1.7; }
.weeks { display: grid; grid-template-columns: repeat(4, 1fr); margin-top: 70px; border-top: 1px solid #557066; }
.weeks article { min-height: 260px; position: relative; padding: 35px 28px 20px 0; border-right: 1px solid #557066; }
.weeks article:not(:first-child) { padding-left: 28px; }
.weeks span { font-size: 9px; letter-spacing: .1em; color: #9cb0a6; }
.weeks h3 { font-family: var(--serif); font-size: 23px; margin: 45px 0 12px; }
.weeks p { color: #aebbb4; font-size: 12px; line-height: 1.6; }
.weeks b { position: absolute; right: 18px; bottom: 0; color: #385248; font-family: Georgia, serif; font-size: 70px; font-weight: 400; }

.testimonials { padding: 120px 0; }
.testimonials-head { display: grid; grid-template-columns: .75fr 1fr .75fr; align-items: end; gap: 50px; margin-bottom: 55px; }
.testimonials-head h2 { margin: 0; font-size: clamp(40px, 4vw, 58px); }
.testimonials-head > p:last-child { margin: 0; color: var(--muted); font-size: 13px; line-height: 1.7; }
.testimonial-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.testimonial-grid article { min-height: 330px; background: var(--white); border: 1px solid #e3dace; padding: 30px 24px; display: flex; flex-direction: column; box-shadow: 0 18px 40px rgba(33,51,44,.06); }
.stars { color: var(--terracotta); letter-spacing: 3px; font-size: 12px; margin-bottom: 24px; }
blockquote { margin: 0 0 28px; font-family: var(--serif); font-size: 18px; line-height: 1.55; letter-spacing: -.02em; }
.author { display: flex; align-items: center; gap: 13px; }
.author > b { width: 42px; height: 42px; display: grid; place-items: center; border-radius: 50%; background: var(--sage-soft); font-size: 11px; }
.author p { margin: 0; font-size: 11px; line-height: 1.5; }
.author span { color: var(--muted); }
.testimonial-grid .author { margin-top: auto; }
.proof-strip { display: grid; grid-template-columns: repeat(3, 1fr); border: 1px solid #ded8ce; margin-top: 24px; background: #f2ece2; }
.proof-strip div { padding: 26px 32px; border-right: 1px solid #ded8ce; }
.proof-strip div:last-child { border-right: 0; }
.proof-strip strong { color: var(--terracotta); font-family: Georgia, serif; font-size: 34px; font-weight: 400; }
.proof-strip p { margin: 5px 0 0; color: var(--muted); font-size: 11px; text-transform: uppercase; letter-spacing: .08em; font-weight: 700; }

.offer-section { padding: 110px 0; background: var(--forest); color: white; }
.offer-grid { display: grid; grid-template-columns: 1fr 470px; align-items: center; gap: 120px; }
.offer-copy h2 { margin-bottom: 25px; }
.offer-copy h2 em { color: #e0a085; }
.offer-copy > p:not(.kicker) { max-width: 500px; color: #c7d3cc; line-height: 1.7; }
.offer-copy ul { list-style: none; padding: 0; margin: 35px 0 0; display: grid; gap: 15px; }
.offer-copy li { font-size: 13px; color: #e2eae4; }
.offer-copy li i { display: inline-grid; place-items: center; width: 21px; height: 21px; margin-right: 11px; background: #547164; color: white; border-radius: 50%; font-style: normal; font-size: 10px; }
.bonus-stack { margin-top: 34px; padding: 26px; border: 1px solid rgba(255,255,255,.18); background: rgba(255,255,255,.06); }
.bonus-stack h3 { margin: 0 0 15px; font-family: var(--serif); font-size: 24px; }
.bonus-stack p { margin: 11px 0 0; color: #d8e2dc; font-size: 12px; line-height: 1.55; }
.bonus-stack strong { color: white; }
.price-card { position: relative; background: var(--paper); color: var(--ink); padding: 48px 48px 38px; box-shadow: 0 20px 60px rgba(0,0,0,.18); }
.best-choice { position: absolute; top: 0; right: 0; background: var(--terracotta); color: white; padding: 10px 18px; font-size: 9px; font-weight: 700; letter-spacing: .1em; }
.product-label { font-size: 10px; font-weight: 700; letter-spacing: .1em; margin: 4px 0 38px; }
.value-list { border: 1px solid #e2d9cc; margin-bottom: 24px; }
.value-list p { display: flex; justify-content: space-between; gap: 20px; margin: 0; padding: 12px 14px; border-bottom: 1px solid #e2d9cc; color: var(--muted); font-size: 11px; }
.value-list p:last-child { border-bottom: 0; }
.value-list strong { color: var(--forest); }
.old-price { color: var(--muted); font-size: 12px; }
.price { display: flex; align-items: flex-start; margin: 8px 0; }
.price small { margin: 14px 8px 0 0; font-weight: 700; }
.price strong { font-family: Georgia, serif; font-size: 64px; font-weight: 400; line-height: 1; }
.price sup { font-size: 27px; }
.cash { color: var(--muted); font-size: 11px; margin: 0 0 27px; }
.button-dark { width: 100%; background: var(--forest-dark); color: white; }
.secure { text-align: center; color: var(--muted); font-size: 9px; margin: 14px 0 26px; }
.guarantee { display: flex; align-items: center; gap: 18px; border-top: 1px solid #ded8ce; padding-top: 24px; }
.guarantee > b { width: 52px; height: 52px; flex: 0 0 52px; display: grid; place-items: center; border: 1px solid var(--terracotta); border-radius: 50%; color: var(--terracotta); font-family: Georgia, serif; font-size: 25px; }
.guarantee p { color: var(--muted); font-size: 9px; line-height: 1.5; margin: 0; }
.guarantee strong { color: var(--ink); font-size: 10px; letter-spacing: .08em; }

.faq { padding: 115px 0; display: grid; grid-template-columns: .85fr 1.15fr; gap: 120px; }
.faq-heading h2 { font-size: clamp(40px, 4vw, 57px); }
.faq-list details { border-top: 1px solid #d7d0c5; padding: 23px 0; }
.faq-list details:last-child { border-bottom: 1px solid #d7d0c5; }
.faq-list summary { display: flex; align-items: center; justify-content: space-between; cursor: pointer; list-style: none; font-family: var(--serif); font-size: 17px; font-weight: 600; }
.faq-list summary::-webkit-details-marker { display: none; }
.faq-list summary span { font-family: var(--sans); color: var(--terracotta); font-size: 22px; font-weight: 400; transition: transform .2s; }
.faq-list details[open] summary span { transform: rotate(45deg); }
.faq-list details p { max-width: 590px; color: var(--muted); font-size: 13px; line-height: 1.7; padding-right: 40px; }

.final-cta { text-align: center; background: #e7ded1; padding: 85px 0; }
.final-cta p { font-size: 12px; text-transform: uppercase; letter-spacing: .12em; color: var(--muted); }
.final-cta h2 { margin: 10px 0 30px; }
.final-cta .button-light { border: 1px solid var(--forest); }
footer { min-height: 110px; display: flex; align-items: center; justify-content: space-between; color: var(--muted); font-size: 10px; }
footer .brand { color: var(--ink); }
footer div { display: flex; gap: 22px; }

@media (max-width: 900px) {
  .hero { grid-template-columns: 1fr; padding-top: 45px; }
  .hero-copy { text-align: center; }
  .eyebrow, .hero-action { justify-content: center; }
  .hero-checks { justify-content: center; margin-inline: auto; }
  .hero-text { margin-inline: auto; }
  .rating { text-align: center; }
  .hero-visual { width: min(600px, 100%); margin-inline: auto; }
  .pain-grid, .audience-intro, .program-intro, .roadmap-heading, .offer-grid, .faq { grid-template-columns: 1fr; gap: 55px; }
  .audience-grid, .testimonial-grid { grid-template-columns: 1fr 1fr; }
  .testimonials-head { grid-template-columns: 1fr; gap: 22px; }
  .benefit-grid { grid-template-columns: 1fr; }
  .benefit-card { border-right: 0; border-bottom: 1px solid #ded8ce; }
  .weeks { grid-template-columns: 1fr 1fr; }
  .proof-strip { grid-template-columns: 1fr; }
  .proof-strip div { border-right: 0; border-bottom: 1px solid #ded8ce; }
  .proof-strip div:last-child { border-bottom: 0; }
  .offer-grid { max-width: 650px; }
  .faq { padding-top: 90px; }
}

@media (max-width: 600px) {
  .shell { width: min(100% - 32px, 1160px); }
  .topbar { font-size: 8px; gap: 9px; }
  .nav { height: 70px; }
  .nav-link { font-size: 0; }
  .nav-link span { font-size: 20px; }
  .hero { padding-top: 25px; gap: 35px; }
  h1 { font-size: 49px; }
  .hero-action { flex-direction: column; }
  .hero-visual { height: 480px; }
  .hero-visual img { height: 445px; width: calc(100% - 25px); }
  .hero-visual .arch { left: 0; }
  .float-top { right: -5px; top: 85px; }
  .float-bottom { left: -4px; bottom: 30px; }
  .pain-section, .audience, .program, .roadmap, .testimonials, .offer-section, .faq { padding-top: 78px; padding-bottom: 78px; }
  .audience-grid, .testimonial-grid { grid-template-columns: 1fr; }
  .audience-grid span { margin-bottom: 30px; }
  .section-number { margin-bottom: 34px; }
  .weeks { grid-template-columns: 1fr; }
  .weeks article, .weeks article:not(:first-child) { padding-left: 0; border-right: 0; border-bottom: 1px solid #557066; min-height: 220px; }
  .price-card { padding: 44px 26px 30px; }
  .price strong { font-size: 57px; }
  .offer-grid { gap: 50px; }
  footer { flex-direction: column; justify-content: center; gap: 18px; padding: 30px 0; text-align: center; }
}
