/* ============================================================
   THRIVE — Funnel design system
   Aesthetic: modern wellness editorial / apothecary
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=Courier+Prime:wght@400;700&display=swap');

:root{
  --paper:#FCFBF8; --cream:#F4EEE4; --sage:#E7F4EC; --mint:#EAF7EF;
  --ink:#0F1419; --ink-soft:#39414A; --gray:#5C6670;
  --green:#2FAD64; --green-d:#1B7E45; --green-deep:#0C5128;
  --white:#FFFFFF; --line:rgba(15,20,25,.10); --line-2:rgba(15,20,25,.16);
  --serif:'Playfair Display',Georgia,serif;
  --sans:'Plus Jakarta Sans',system-ui,sans-serif;
  --mono:'Courier Prime',monospace;
  --shadow-sm:0 2px 10px rgba(15,20,25,.05);
  --shadow:0 22px 50px rgba(15,20,25,.10);
  --shadow-lg:0 40px 80px rgba(15,20,25,.16);
  --r:18px; --r-lg:26px;
  --maxw:1180px;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  font-family:var(--sans); background:var(--paper); color:var(--ink);
  line-height:1.65; font-size:17px; -webkit-font-smoothing:antialiased;
  overflow-x:hidden; position:relative;
}
/* grain overlay */
body::after{
  content:""; position:fixed; inset:0; pointer-events:none; z-index:9999; opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;}

/* ---- type ---- */
h1,h2,h3{font-family:var(--serif);font-weight:700;line-height:1.04;letter-spacing:-.015em;}
.display{font-size:clamp(46px,7.2vw,90px);}
h2{font-size:clamp(34px,4.6vw,56px);}
h3{font-size:clamp(21px,2.4vw,27px);line-height:1.18;}
.serif-it{font-family:var(--serif);font-style:italic;font-weight:500;}
.lead{font-size:clamp(18px,2vw,21px);color:var(--ink-soft);line-height:1.6;}
.eyebrow{
  font-family:var(--mono);font-weight:700;font-size:13px;letter-spacing:.28em;
  text-transform:uppercase;color:var(--green-d);display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--green);}
.eyebrow.center::before{display:none;}

/* ---- buttons ---- */
.btn{
  display:inline-flex;align-items:center;gap:11px;font-family:var(--sans);font-weight:700;
  font-size:16px;padding:17px 30px;border-radius:50px;border:none;cursor:pointer;
  transition:transform .25s cubic-bezier(.2,.8,.2,1),box-shadow .25s,background .25s;
  letter-spacing:.005em;text-align:center;
}
.btn svg{width:17px;height:17px;}
.btn-primary{background:var(--ink);color:var(--paper);box-shadow:0 12px 26px rgba(15,20,25,.20);}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 20px 38px rgba(15,20,25,.28);}
.btn-green{background:var(--green);color:#fff;box-shadow:0 12px 26px rgba(47,173,100,.35);}
.btn-green:hover{transform:translateY(-3px);box-shadow:0 20px 40px rgba(47,173,100,.45);background:var(--green-d);}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line-2);}
.btn-ghost:hover{border-color:var(--ink);transform:translateY(-2px);}
.btn-block{width:100%;justify-content:center;}

/* ---- nav ---- */
.nav{position:sticky;top:0;z-index:100;background:rgba(252,251,248,.82);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:74px;}
.nav img{height:30px;}
.nav-cta{font-family:var(--mono);font-weight:700;font-size:12.5px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--gray);display:flex;align-items:center;gap:18px;}
.nav-cta a.pill{background:var(--ink);color:var(--paper);padding:9px 18px;border-radius:40px;letter-spacing:.12em;
  transition:transform .2s;}
.nav-cta a.pill:hover{transform:translateY(-2px);}

/* ---- announcement ---- */
.ann{background:var(--ink);color:var(--paper);text-align:center;font-family:var(--mono);
  font-size:12.5px;letter-spacing:.18em;text-transform:uppercase;padding:9px;}
.ann b{color:#6FE39C;}

/* ---- organic blobs / atmosphere ---- */
.blob{position:absolute;border-radius:50%;filter:blur(2px);z-index:0;pointer-events:none;}
.blob.g{background:radial-gradient(circle at 35% 35%,rgba(47,173,100,.22),rgba(47,173,100,.05));}
.blob.s{background:radial-gradient(circle at 40% 40%,rgba(47,173,100,.12),transparent 70%);}

/* ---- sections ---- */
section{position:relative;z-index:1;}
.pad{padding:clamp(70px,9vw,128px) 0;}
.pad-sm{padding:clamp(48px,6vw,80px) 0;}
.cream{background:var(--cream);}
.ink-bg{background:var(--ink);color:var(--paper);}
.ink-bg .lead{color:rgba(252,251,248,.72);}
.center{text-align:center;}
.center .eyebrow{justify-content:center;}

/* ---- hero (opt-in) ---- */
.hero{position:relative;overflow:hidden;}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center;
  padding:clamp(48px,7vw,96px) 0 clamp(60px,8vw,110px);}
.hero h1{margin:22px 0 20px;padding-bottom:.24em;}
.hero h1 .u{position:relative;white-space:nowrap;}
.hero h1 .u::after{content:"";position:absolute;left:0;right:0;bottom:-.2em;height:.07em;background:var(--green);border-radius:3px;opacity:.9;}
.hero .mock-wrap{position:relative;display:flex;justify-content:center;}
.hero .mock{width:min(86%,400px);border-radius:12px;border:10px solid #fff;box-shadow:var(--shadow-lg);
  transform:rotate(4deg);}
.hero .mock-tag{position:absolute;left:4%;bottom:6%;background:#fff;border:1px solid var(--line);
  box-shadow:var(--shadow);border-radius:14px;padding:13px 18px;display:flex;align-items:center;gap:11px;
  font-weight:700;font-size:14px;transform:rotate(-4deg);}
.hero .mock-tag .dot{width:11px;height:11px;border-radius:50%;background:var(--green);}

/* ---- opt-in form ---- */
.optin{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);
  box-shadow:var(--shadow);padding:30px 28px;margin-top:30px;max-width:460px;}
.optin .field{margin-bottom:14px;}
.optin label{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--gray);display:block;margin-bottom:7px;}
.optin input{width:100%;padding:15px 17px;border:1.5px solid var(--line-2);border-radius:13px;
  font-family:var(--sans);font-size:16px;color:var(--ink);background:var(--paper);transition:border .2s,box-shadow .2s;}
.optin input:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 4px rgba(47,173,100,.13);}
.optin .micro{font-size:13px;color:var(--gray);text-align:center;margin-top:13px;}
.optin .ok{display:none;text-align:center;padding:14px 0;}
.optin.done .form-body{display:none;}
.optin.done .ok{display:block;}
.optin .ok .check{width:54px;height:54px;border-radius:50%;background:var(--mint);display:flex;align-items:center;
  justify-content:center;margin:0 auto 14px;}
.optin .ok h3{margin-bottom:6px;}

/* ---- value cards ---- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:54px;}
.card{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);padding:34px 30px;
  transition:transform .3s cubic-bezier(.2,.8,.2,1),box-shadow .3s;position:relative;overflow:hidden;}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);}
.card .num{font-family:var(--mono);font-weight:700;font-size:13px;letter-spacing:.2em;color:var(--green-d);}
.card .ic{width:52px;height:52px;border-radius:14px;background:var(--mint);display:flex;align-items:center;
  justify-content:center;margin:14px 0 18px;}
.card .ic svg{width:26px;height:26px;stroke:var(--green-d);}
.card h3{margin-bottom:9px;}
.card p{color:var(--gray);font-size:15.5px;line-height:1.6;}

/* ---- steps ---- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:54px;counter-reset:s;}
.step{position:relative;padding-top:18px;}
.step::before{counter-increment:s;content:"0" counter(s);font-family:var(--serif);font-weight:700;
  font-size:60px;color:var(--green);opacity:.22;line-height:1;}
.step h3{margin:8px 0 8px;}
.step p{color:var(--gray);font-size:15.5px;}

/* ---- inside list (sales) ---- */
.inside{display:grid;grid-template-columns:repeat(2,1fr);gap:22px 40px;margin-top:48px;}
.inside li{list-style:none;display:flex;gap:16px;align-items:flex-start;}
.inside .tick{flex-shrink:0;width:30px;height:30px;border-radius:50%;background:var(--mint);
  display:flex;align-items:center;justify-content:center;margin-top:2px;}
.inside .tick svg{width:16px;height:16px;stroke:var(--green-d);}
.inside b{font-weight:700;display:block;font-size:17px;}
.inside span{color:var(--gray);font-size:15px;line-height:1.55;}

/* ---- pricing ---- */
.price-card{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);
  box-shadow:var(--shadow-lg);max-width:560px;margin:0 auto;overflow:hidden;}
.price-head{background:var(--ink);color:var(--paper);padding:34px 40px 30px;position:relative;overflow:hidden;}
.price-head::after{content:"";position:absolute;top:-50px;right:-40px;width:200px;height:200px;border-radius:50%;
  background:rgba(47,173,100,.2);}
.price-head .badge{display:inline-block;background:var(--green);color:#fff;font-family:var(--mono);font-weight:700;
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;padding:6px 14px;border-radius:30px;position:relative;}
.price-head .amt{font-family:var(--serif);font-size:64px;font-weight:700;line-height:1;margin-top:16px;position:relative;}
.price-head .amt s{font-size:26px;color:rgba(252,251,248,.5);font-weight:400;margin-left:10px;}
.price-head .amt .per{font-family:var(--sans);font-size:15px;color:rgba(252,251,248,.7);font-weight:500;}
.price-body{padding:32px 40px 38px;}
.price-body ul{list-style:none;margin-bottom:24px;}
.price-body li{display:flex;gap:12px;align-items:flex-start;padding:9px 0;border-bottom:1px solid var(--line);font-size:16px;}
.price-body li:last-child{border:none;}
.price-body li svg{width:18px;height:18px;stroke:var(--green-d);flex-shrink:0;margin-top:4px;}
.guarantee{display:flex;gap:13px;align-items:center;background:var(--sage);border-radius:14px;padding:15px 18px;
  margin-top:18px;font-size:14.5px;color:var(--green-deep);}
.guarantee svg{width:24px;height:24px;stroke:var(--green-d);flex-shrink:0;}

/* ---- FAQ ---- */
.faq{max-width:780px;margin:48px auto 0;}
.q{border-bottom:1px solid var(--line-2);}
.q summary{list-style:none;cursor:pointer;padding:24px 4px;display:flex;justify-content:space-between;
  align-items:center;gap:20px;font-family:var(--serif);font-weight:600;font-size:20px;}
.q summary::-webkit-details-marker{display:none;}
.q summary .pl{flex-shrink:0;width:30px;height:30px;border-radius:50%;border:1.5px solid var(--line-2);
  display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--green-d);transition:transform .3s,background .3s;}
.q[open] summary .pl{transform:rotate(45deg);background:var(--mint);border-color:var(--mint);}
.q p{padding:0 4px 26px;color:var(--gray);font-size:16px;max-width:660px;}

/* ---- testimonial / quote ---- */
.quote{max-width:840px;margin:0 auto;text-align:center;}
.quote .mark{font-family:var(--serif);font-size:90px;color:var(--green);line-height:.5;opacity:.5;}
.quote p{font-family:var(--serif);font-style:italic;font-size:clamp(24px,3.4vw,38px);line-height:1.3;color:var(--ink);}

/* ---- CTA band ---- */
.cta-band{position:relative;overflow:hidden;border-radius:var(--r-lg);padding:clamp(48px,6vw,80px) 40px;
  background:var(--ink);color:var(--paper);text-align:center;}
.cta-band h2{color:var(--paper);}
.cta-band .blob{opacity:.7;}

/* ---- footer ---- */
.foot{background:var(--ink);color:rgba(252,251,248,.6);padding:60px 0 36px;}
.foot-top{display:flex;justify-content:space-between;align-items:flex-start;gap:40px;flex-wrap:wrap;
  padding-bottom:30px;border-bottom:1px solid rgba(252,251,248,.12);}
.foot img{height:34px;margin-bottom:14px;}
.foot .tag{font-family:var(--serif);font-style:italic;font-size:20px;color:rgba(252,251,248,.85);max-width:320px;}
.foot .links{display:flex;gap:14px;flex-wrap:wrap;font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;}
.foot .links a:hover{color:#6FE39C;}
.foot .disc{font-size:12.5px;line-height:1.6;margin-top:26px;max-width:680px;}
.foot .copy{font-family:var(--mono);font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;margin-top:18px;}

/* ---- reveal animation ---- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s cubic-bezier(.2,.8,.2,1),transform .8s cubic-bezier(.2,.8,.2,1);}
.reveal.in{opacity:1;transform:none;}
.stagger>*{opacity:0;transform:translateY(22px);animation:rise .9s cubic-bezier(.2,.8,.2,1) forwards;}
.stagger>*:nth-child(1){animation-delay:.05s;}
.stagger>*:nth-child(2){animation-delay:.16s;}
.stagger>*:nth-child(3){animation-delay:.27s;}
.stagger>*:nth-child(4){animation-delay:.38s;}
.stagger>*:nth-child(5){animation-delay:.49s;}
.stagger>*:nth-child(6){animation-delay:.6s;}
@keyframes rise{to{opacity:1;transform:none;}}
@media (prefers-reduced-motion:reduce){.reveal,.stagger>*{opacity:1!important;transform:none!important;animation:none!important;}}

/* ---- responsive ---- */
@media(max-width:900px){
  .hero-grid{grid-template-columns:1fr;gap:30px;}
  .hero .mock-wrap{order:-1;}
  .hero .mock{width:min(70%,300px);transform:rotate(3deg);}
  .cards,.steps,.inside{grid-template-columns:1fr;}
  .nav-cta span.hide{display:none;}
}
@media(max-width:560px){
  body{font-size:16px;}
  .wrap{padding:0 20px;}
  .display{font-size:42px;line-height:1.06;}
  .hero-grid{padding-top:26px;}
  .optin{padding:24px 20px;margin-top:24px;}
  .foot-top{flex-direction:column;}
  .ann{font-size:11px;letter-spacing:.06em;}
}
