/* ============================================================
   VITAL — sample funnel stylesheet
   Brand: science-based metabolism / body-recomposition coaching
   Palette: warm off-white, deep ink, ONE coral accent + a fresh green
   (deliberately NOT the portfolio's dark-green/emerald)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,500;9..144,600;9..144,700&family=Inter:wght@400;500;600;700&display=swap');

:root{
  --ink:#1c1a17;          /* deep warm charcoal text */
  --ink-soft:#56514a;     /* secondary text */
  --paper:#fbf7f1;        /* warm off-white bg */
  --paper-2:#f4ede2;      /* slightly deeper section bg */
  --card:#ffffff;
  --line:#e7ddcd;         /* warm hairline */
  --coral:#ff5a3c;        /* primary accent (vital orange/coral) */
  --coral-dk:#e8431f;
  --green:#1f9e6a;        /* fresh confidence green */
  --green-dk:#157a51;
  --gold:#caa14a;
  --shadow:0 18px 50px -22px rgba(28,26,23,.35);
  --shadow-sm:0 8px 24px -12px rgba(28,26,23,.28);
  --r:18px;
  --maxw:680px;
  --disp:'Fraunces',Georgia,serif;
  --body:'Inter',system-ui,-apple-system,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--body);
  color:var(--ink);
  background:var(--paper);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit}

/* ---- sample ribbon (subtle portfolio label) ---- */
.ribbon{
  background:var(--ink);
  color:#f3ede2;
  font-family:var(--body);
  font-size:11.5px;
  letter-spacing:.14em;
  text-transform:uppercase;
  text-align:center;
  padding:7px 14px;
  font-weight:600;
}
.ribbon b{color:#ffb9a8;font-weight:700}

/* ---- layout ---- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.wide{max-width:980px}
section{padding:48px 0}
.tight{padding:30px 0}

/* ---- trust bar ---- */
.trustbar{
  background:var(--paper-2);
  border-bottom:1px solid var(--line);
  padding:14px 0;
}
.trustbar .wrap{display:flex;gap:26px;justify-content:center;flex-wrap:wrap;align-items:center}
.trustbar span{
  font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-soft);font-weight:700;opacity:.85;
}

/* ---- brand mark ---- */
.logo{
  font-family:var(--disp);font-weight:700;letter-spacing:.32em;
  text-transform:uppercase;font-size:20px;color:var(--ink);
  display:inline-flex;align-items:center;gap:9px;
}
.logo .dot{width:9px;height:9px;border-radius:50%;background:var(--coral);display:inline-block}
.topbar{padding:20px 0;text-align:center}

/* ---- headings ---- */
h1{
  font-family:var(--disp);font-weight:600;
  font-size:clamp(31px,7vw,46px);line-height:1.08;
  letter-spacing:-.01em;margin:.2em 0 .4em;color:var(--ink);
}
h1 em{font-style:italic;color:var(--coral)}
h2{
  font-family:var(--disp);font-weight:600;
  font-size:clamp(24px,5vw,33px);line-height:1.14;
  letter-spacing:-.01em;margin:0 0 .5em;
}
h3{font-family:var(--disp);font-weight:600;font-size:21px;margin:0 0 .4em}
.kicker{
  display:inline-block;font-size:12px;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;color:var(--coral);
  margin-bottom:14px;
}
.kicker.green{color:var(--green)}
.lede{font-size:clamp(17px,2.4vw,20px);color:var(--ink-soft);margin:0 0 26px;line-height:1.55}
.eyebrow{font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);font-weight:700}

/* ---- buttons / CTA ---- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--body);font-weight:700;font-size:18px;
  text-decoration:none;border:0;cursor:pointer;
  padding:18px 34px;border-radius:14px;line-height:1.1;
  transition:transform .12s ease,box-shadow .12s ease,background .15s ease;
  text-align:center;
}
.btn.cta{
  background:var(--coral);color:#fff;
  box-shadow:0 12px 26px -10px rgba(255,90,60,.6);width:100%;
  font-size:19px;padding:20px 28px;
}
.btn.cta:hover{background:var(--coral-dk);transform:translateY(-2px)}
.btn.green{background:var(--green);color:#fff;box-shadow:0 12px 26px -10px rgba(31,158,106,.55);width:100%}
.btn.green:hover{background:var(--green-dk);transform:translateY(-2px)}
.btn.ghost{
  background:transparent;color:var(--ink-soft);font-weight:600;font-size:16px;
  padding:14px 20px;text-decoration:underline;text-underline-offset:3px;
}
.btn.ghost:hover{color:var(--ink)}
.cta-sub{text-align:center;font-size:13px;color:var(--ink-soft);margin-top:12px;line-height:1.5}
.cta-sub b{color:var(--ink)}

/* ---- forms ---- */
.field{margin-bottom:14px}
label.fl{display:block;font-size:13px;font-weight:700;color:var(--ink);margin-bottom:6px}
input,select,textarea{
  width:100%;font-family:var(--body);font-size:16px;color:var(--ink);
  padding:15px 16px;border:1.5px solid var(--line);border-radius:12px;
  background:#fff;outline:none;transition:border .15s ease,box-shadow .15s ease;
}
input:focus,select:focus,textarea:focus{border-color:var(--coral);box-shadow:0 0 0 4px rgba(255,90,60,.12)}
.formcard{
  background:var(--card);border:1px solid var(--line);border-radius:var(--r);
  padding:26px;box-shadow:var(--shadow);
}

/* ---- card ---- */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-sm)}
.pad{padding:28px}

/* ---- value stack ---- */
.stack{list-style:none;margin:0;padding:0}
.stack li{
  display:flex;gap:13px;align-items:flex-start;padding:14px 0;
  border-bottom:1px solid var(--line);
}
.stack li:last-child{border-bottom:0}
.stack .ck{
  flex:0 0 24px;width:24px;height:24px;border-radius:50%;
  background:var(--green);color:#fff;display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:800;margin-top:2px;
}
.stack .vt{font-weight:700;color:var(--ink)}
.stack .vd{display:block;font-weight:400;color:var(--ink-soft);font-size:15px;margin-top:2px}
.stack .vp{margin-left:auto;font-weight:700;color:var(--ink-soft);white-space:nowrap;font-size:14px;padding-left:10px}

/* ---- price block ---- */
.price{text-align:center;margin:24px 0}
.price .anchor{font-size:19px;color:var(--ink-soft);text-decoration:line-through;text-decoration-color:var(--coral);text-decoration-thickness:2px}
.price .now{font-family:var(--disp);font-weight:700;font-size:54px;line-height:1;color:var(--ink);display:block;margin-top:2px}
.price .now small{font-size:22px;vertical-align:super;color:var(--ink-soft)}
.price .note{font-size:13px;color:var(--ink-soft);margin-top:6px}
.totalrow{
  display:flex;justify-content:space-between;align-items:baseline;
  padding:16px 0 4px;border-top:2px solid var(--ink);margin-top:6px;
}
.totalrow .lab{font-weight:700}
.totalrow .old{color:var(--ink-soft);text-decoration:line-through;font-size:15px;margin-right:8px}
.totalrow .new{font-family:var(--disp);font-weight:700;font-size:30px;color:var(--coral)}

/* ---- order bump ---- */
.bump{
  border:2px dashed var(--coral);background:#fff6f3;border-radius:14px;
  padding:18px 18px;margin:22px 0;
}
.bump label{display:flex;gap:13px;align-items:flex-start;cursor:pointer}
.bump input[type=checkbox]{
  width:24px;height:24px;flex:0 0 24px;accent-color:var(--coral);margin-top:2px;cursor:pointer;
}
.bump .bt{font-weight:800;color:var(--coral-dk);display:block;margin-bottom:3px}
.bump .bd{font-size:14.5px;color:var(--ink-soft);line-height:1.5}
.bump .bd b{color:var(--ink)}

/* ---- guarantee badge ---- */
.guarantee{
  display:flex;gap:16px;align-items:center;background:var(--paper-2);
  border:1px solid var(--line);border-radius:14px;padding:18px 20px;margin:22px 0;
}
.guarantee .seal{
  flex:0 0 58px;width:58px;height:58px;border-radius:50%;
  background:radial-gradient(circle at 50% 38%,var(--green),var(--green-dk));
  color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;
  font-family:var(--disp);font-weight:700;line-height:1;text-align:center;
  box-shadow:0 6px 16px -6px rgba(21,122,81,.6);
}
.guarantee .seal b{font-size:18px}
.guarantee .seal i{font-size:8px;font-style:normal;letter-spacing:.1em;margin-top:2px}
.guarantee p{margin:0;font-size:14.5px;color:var(--ink-soft);line-height:1.5}
.guarantee p b{color:var(--ink)}

/* ---- countdown / scarcity ---- */
.scarcity{
  background:var(--ink);color:#f3ede2;border-radius:14px;
  padding:16px 20px;text-align:center;margin:0 0 24px;
}
.scarcity .lab{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:#ffb9a8;font-weight:700}
.scarcity .clock{font-family:var(--disp);font-weight:700;font-size:30px;letter-spacing:.04em;margin-top:4px}
.scarcity .clock span{color:#ff8e78}
.scarbar{
  background:var(--coral);color:#fff;text-align:center;
  font-size:13.5px;font-weight:600;padding:9px 14px;
}
.scarbar b{font-weight:800}

/* ---- video placeholder ---- */
.vsl{
  position:relative;border-radius:var(--r);overflow:hidden;
  background:linear-gradient(135deg,#231f1a 0%,#3a322a 60%,#4a3b2c 100%);
  aspect-ratio:16/9;box-shadow:var(--shadow);display:flex;
  align-items:center;justify-content:center;flex-direction:column;color:#f3ede2;
}
.vsl .play{
  width:78px;height:78px;border-radius:50%;background:var(--coral);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 14px 34px -10px rgba(255,90,60,.7);margin-bottom:14px;
}
.vsl .play::after{content:"";border-left:24px solid #fff;border-top:15px solid transparent;border-bottom:15px solid transparent;margin-left:6px}
.vsl .vlab{font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:#e9d8b6;font-weight:700}
.vsl .vsub{font-size:13px;color:#cbb89a;margin-top:5px}

/* ---- avatars / testimonials ---- */
.avi{
  flex:0 0 48px;width:48px;height:48px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--disp);font-weight:700;color:#fff;font-size:18px;
}
.a1{background:#d98a5b}.a2{background:#5b8fd9}.a3{background:#7aab5b}.a4{background:#b06ba8}.a5{background:#d9b25b}
.quote{display:flex;gap:15px;align-items:flex-start;padding:20px 0;border-bottom:1px solid var(--line)}
.quote:last-child{border-bottom:0}
.quote .qt{margin:0 0 6px;font-size:16px;line-height:1.55}
.quote .qa{font-size:13px;color:var(--ink-soft);font-weight:600}
.stars{color:var(--gold);font-size:14px;letter-spacing:1px;margin-bottom:4px}

/* ---- proof stats ---- */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:8px 0}
.stat{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:18px 12px;text-align:center}
.stat .n{font-family:var(--disp);font-weight:700;font-size:30px;color:var(--green);line-height:1}
.stat .l{font-size:12px;color:var(--ink-soft);margin-top:6px;line-height:1.3}

/* ---- FAQ accordion ---- */
.faq{border-top:1px solid var(--line)}
.faq details{border-bottom:1px solid var(--line)}
.faq summary{
  list-style:none;cursor:pointer;padding:18px 2px;font-weight:700;
  font-size:16.5px;display:flex;justify-content:space-between;gap:14px;align-items:center;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:var(--disp);font-size:24px;color:var(--coral);transition:transform .2s ease}
.faq details[open] summary::after{content:"\2013"}
.faq .fa{padding:0 2px 20px;color:var(--ink-soft);font-size:15.5px;line-height:1.6}

/* ---- divider w/ label ---- */
.orline{display:flex;align-items:center;gap:14px;color:var(--ink-soft);font-size:13px;font-weight:600;margin:8px 0}
.orline::before,.orline::after{content:"";height:1px;background:var(--line);flex:1}

/* ---- as-seen-in strip (text only) ---- */
.seenin{text-align:center;padding:6px 0}
.seenin .lab{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);font-weight:700;margin-bottom:12px}
.seenin .names{display:flex;gap:24px;justify-content:center;flex-wrap:wrap;align-items:center}
.seenin .names span{font-family:var(--disp);font-weight:600;font-size:17px;color:#9b9388;letter-spacing:.02em}

/* ---- bullets inline ---- */
.bul{list-style:none;margin:18px 0;padding:0}
.bul li{position:relative;padding:8px 0 8px 30px;line-height:1.55}
.bul li::before{content:"\2713";position:absolute;left:0;top:8px;color:var(--green);font-weight:800}
.bul.x li::before{content:"\2715";color:var(--coral)}

/* ---- callout ---- */
.callout{background:var(--paper-2);border-left:4px solid var(--coral);border-radius:0 12px 12px 0;padding:18px 20px;margin:22px 0;font-size:16px}
.callout b{color:var(--ink)}

/* ---- sticky cta (mobile) ---- */
.sticky{
  position:sticky;bottom:0;left:0;right:0;z-index:50;
  background:rgba(251,247,241,.94);backdrop-filter:blur(8px);
  border-top:1px solid var(--line);padding:12px 0;
  box-shadow:0 -10px 30px -18px rgba(28,26,23,.4);
}
.sticky .wrap{display:flex;gap:14px;align-items:center}
.sticky .sp{flex:1;min-width:0}
.sticky .sp .st{font-weight:800;font-size:15px;line-height:1.1}
.sticky .sp .sd{font-size:12px;color:var(--ink-soft)}
.sticky .btn.cta{width:auto;flex:0 0 auto;font-size:16px;padding:15px 22px}

/* ---- progress steps ---- */
.steps{display:flex;gap:6px;justify-content:center;margin:0 auto 4px;max-width:340px}
.steps i{flex:1;height:5px;border-radius:3px;background:var(--line)}
.steps i.on{background:var(--coral)}
.steps i.done{background:var(--green)}

/* ---- footer ---- */
footer.fz{background:var(--ink);color:#c9c0b3;padding:30px 0;font-size:13px;line-height:1.6}
footer.fz .wrap{text-align:center}
footer.fz a{color:#ffb9a8;text-decoration:none}
footer.fz .fl{font-size:11px;color:#8a8276;margin-top:10px;letter-spacing:.04em}
footer.fz .disc{font-size:11px;color:#7d7568;margin-top:14px;max-width:560px;margin-left:auto;margin-right:auto}

/* ---- misc ---- */
.center{text-align:center}
.mt0{margin-top:0}.mb0{margin-bottom:0}
.small{font-size:14px;color:var(--ink-soft)}
.hide-d{display:none}
.spacer{height:8px}

@media(max-width:560px){
  .stats{grid-template-columns:1fr 1fr 1fr;gap:8px}
  .stat .n{font-size:24px}
  section{padding:38px 0}
  .pad{padding:22px}
}
