@import url("https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,700;1,400;1,500&family=Inter+Tight:wght@400;500;600&display=swap");

/* BodyGood Tirzepatide 3-month Program · scoped to .tz-page */
.tz-page {
  --bg-pink:#E880A8;--bg-pink-soft:#F2B6C8;--bg-pink-tint:#FBE4EC;--bg-pink-cream:#FDEDE6;
  --bg-red:#CC0000;--bg-red-deep:#990000;--bg-red-tint:#F5CCCC;
  --bg-white:#FFFFFF;--bg-off:#FAF4EC;--bg-cream:#F6ECE0;--bg-blush:#E8CFC4;--bg-blush-soft:#F1DDD1;
  --bg-charcoal:#26211E;--bg-black:#111111;--bg-ink:#1A1313;
  --bg-grey-50:#F6F4F2;--bg-grey-100:#ECE8E4;--bg-grey-200:#DCD6D1;--bg-grey-300:#C2BAB3;
  --bg-grey-400:#9A918B;--bg-grey-500:#6E6661;--bg-grey-600:#4A433F;--bg-grey-700:#2C2724;
  --fg-1:var(--bg-ink);--fg-2:var(--bg-grey-600);--fg-3:var(--bg-grey-400);
  --border-subtle:var(--bg-grey-100);--border-default:var(--bg-grey-200);
  --font-display:'Playfair Display','Didot','Bodoni 72',Georgia,serif;
  --font-serif:'Playfair Display',Georgia,'Times New Roman',serif;
  --font-sans:'Inter Tight',ui-sans-serif,system-ui,-apple-system,'Helvetica Neue',Arial,sans-serif;
  --shadow-md:0 6px 20px rgba(26,19,19,.08);--shadow-lg:0 20px 48px rgba(26,19,19,.10);
  --ease-out:cubic-bezier(0.2,0.8,0.2,1);
  background:var(--bg-off); color:var(--fg-1);
  font-family:var(--font-sans); -webkit-font-smoothing:antialiased;
  min-height:100vh;
}
.tz-page *, .tz-page *::before, .tz-page *::after { box-sizing:border-box; }
.tz-container { max-width:1200px; margin:0 auto; padding:0 32px; }

/* Nav */
.tz-nav { position:sticky; top:0; z-index:50; background:rgba(250,244,236,.84); backdrop-filter:blur(18px) saturate(120%); border-bottom:1px solid var(--border-subtle); }
.tz-nav-inner { max-width:1200px; margin:0 auto; padding:16px 32px; display:flex; align-items:center; gap:40px; }
.tz-wordmark { font-family:var(--font-display); font-style:italic; font-weight:500; font-size:28px; letter-spacing:-0.01em; line-height:1; user-select:none; }
.tz-wordmark .body { color:var(--bg-pink); }
.tz-wordmark .good { color:var(--bg-red); }
.tz-nav-links { display:flex; gap:32px; margin-left:12px; }
.tz-nav-links a { font-family:var(--font-serif); font-size:15px; color:var(--fg-1); text-decoration:none; cursor:pointer; }
.tz-nav-links a:hover { color:var(--bg-red); }
.tz-nav-cta { margin-left:auto; display:flex; gap:12px; align-items:center; }
.tz-nav-cta .login { font-family:var(--font-serif); font-size:15px; color:var(--fg-1); cursor:pointer; text-decoration:none; }

/* Buttons */
.tz-page .btn { font-family:var(--font-sans); font-size:15px; font-weight:500; border-radius:999px; padding:12px 22px; border:0; cursor:pointer; display:inline-flex; align-items:center; gap:8px; transition:all 220ms var(--ease-out); text-decoration:none; white-space:nowrap; }
.tz-page .btn-primary { background:var(--bg-red); color:#fff; }
.tz-page .btn-primary:hover { background:var(--bg-red-deep); }
.tz-page .btn-secondary { background:var(--bg-white); color:var(--fg-1); border:1px solid var(--border-default); border-radius:12px; }
.tz-page .btn-ghost { background:transparent; color:var(--fg-1); }
.tz-page .btn-ghost:hover { color:var(--bg-red); }
.tz-page .btn-lg { font-size:16px; padding:16px 28px; }
.tz-page .btn-xl { font-size:17px; padding:18px 32px; }

.tz-page .eyebrow { font-family:var(--font-sans); font-weight:500; font-size:11px; letter-spacing:0.18em; text-transform:uppercase; color:var(--bg-red); }
.tz-page .eyebrow-pink { color:var(--bg-pink); }

/* Hero (variant A) */
.tz-hero { display:grid; grid-template-columns:1.05fr 0.95fr; gap:64px; align-items:center; padding:56px 0 88px; }
.tz-hero h1 { font-family:var(--font-display); font-weight:500; font-size:84px; line-height:1.0; letter-spacing:-0.014em; margin:18px 0 24px; color:var(--fg-1); text-wrap:balance; }
.tz-hero h1 em { font-style:italic; color:var(--bg-red); font-weight:500; }
.tz-hero p.lede { font-family:var(--font-serif); font-size:21px; line-height:1.55; color:var(--fg-2); max-width:480px; margin:0 0 28px; }
.tz-hero-cta { display:flex; gap:12px; align-items:center; flex-wrap:wrap; }
.tz-hero-image { position:relative; aspect-ratio:4/5; border-radius:24px; overflow:hidden; background:var(--bg-pink-cream); }
.tz-hero-image img { width:100%; height:100%; object-fit:cover; display:block; }
.tz-hero-meta { display:flex; gap:40px; margin-top:32px; padding-top:28px; border-top:1px solid var(--border-subtle); }
.tz-hero-meta .stat { display:flex; flex-direction:column; gap:4px; }
.tz-hero-meta .n { font-family:var(--font-display); font-style:italic; font-weight:500; font-size:36px; color:var(--fg-1); line-height:1; }
.tz-hero-meta .l { font-size:11px; letter-spacing:0.16em; text-transform:uppercase; color:var(--fg-3); }

/* Trust bar */
.tz-trust { background:transparent; border-top:1px solid var(--border-subtle); border-bottom:1px solid var(--border-subtle); padding:24px 0; }
.tz-trust .row { display:flex; justify-content:space-between; align-items:center; gap:24px; flex-wrap:wrap; }
.tz-trust .item { display:flex; align-items:center; gap:10px; font-family:var(--font-sans); font-size:13px; color:var(--fg-2); letter-spacing:0.02em; }
.tz-trust .item svg { width:18px; height:18px; stroke:var(--bg-red); stroke-width:1.5; flex-shrink:0; }

/* Section heads */
.tz-section-head { max-width:760px; margin:0 0 48px; }
.tz-section-head h2 { font-family:var(--font-display); font-weight:500; font-size:56px; line-height:1.04; letter-spacing:-0.01em; margin:12px 0 16px; color:var(--fg-1); text-wrap:balance; }
.tz-section-head h2 em { font-style:italic; color:var(--bg-red); font-weight:500; }
.tz-section-head p { font-family:var(--font-serif); font-size:19px; line-height:1.55; color:var(--fg-2); margin:0; }

/* How it works */
.tz-how { background:var(--bg-blush-soft); padding:120px 0; }
.tz-how-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:40px; margin-top:56px; }
.tz-month { background:transparent; display:flex; flex-direction:column; gap:12px; padding:32px 28px 32px 0; border-top:1px solid rgba(26,19,19,.12); position:relative; }
.tz-month .month-label { font-family:var(--font-sans); font-size:11px; letter-spacing:0.18em; text-transform:uppercase; color:var(--bg-red); font-weight:500; }
.tz-month .n { font-family:var(--font-display); font-style:italic; font-weight:500; font-size:96px; line-height:1; color:var(--fg-1); letter-spacing:-0.02em; margin-top:4px; }
.tz-month h3 { font-family:var(--font-display); font-weight:500; font-size:28px; line-height:1.15; letter-spacing:-0.005em; margin:8px 0 0; color:var(--fg-1); }
.tz-month p { font-family:var(--font-serif); font-size:17px; line-height:1.55; color:var(--fg-2); margin:4px 0 0; }
.tz-month .points { list-style:none; padding:0; margin:16px 0 0; display:flex; flex-direction:column; gap:8px; }
.tz-month .points li { font-family:var(--font-sans); font-size:14px; color:var(--fg-2); display:flex; align-items:flex-start; gap:10px; }
.tz-month .points li::before { content:'·'; color:var(--bg-red); font-size:24px; line-height:0.8; margin-top:4px; }

/* Chart */
.tz-chart-wrap { margin-top:48px; padding:32px; background:var(--bg-white); border:1px solid var(--border-subtle); border-radius:20px; }
.tz-chart-head { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:24px; flex-wrap:wrap; gap:12px; }
.tz-chart-head h4 { font-family:var(--font-display); font-weight:500; font-size:22px; margin:0; letter-spacing:-0.005em; }
.tz-chart-head .legend { display:flex; gap:16px; font-family:var(--font-sans); font-size:12px; color:var(--fg-3); }
.tz-chart-head .legend .dot { display:inline-block; width:8px; height:8px; border-radius:50%; margin-right:6px; vertical-align:middle; }
.tz-chart svg { width:100%; height:auto; display:block; }

/* Pricing builder */
.tz-pricing { padding:120px 0; background:var(--bg-off); }
.tz-builder { display:grid; grid-template-columns:1.4fr 1fr; gap:32px; align-items:stretch; }
.tz-builder-months { display:flex; flex-direction:column; gap:16px; }
.tz-builder-month { background:var(--bg-white); border:1px solid var(--border-subtle); border-radius:20px; padding:28px 32px 24px; display:flex; flex-direction:column; gap:20px; }
.tz-builder-month .month-head { display:flex; align-items:baseline; gap:16px; flex-wrap:wrap; }
.tz-builder-month .label { font-family:var(--font-sans); font-size:11px; font-weight:500; letter-spacing:0.18em; text-transform:uppercase; color:var(--bg-red); }
.tz-builder-month .sub { font-family:var(--font-display); font-style:italic; font-weight:500; font-size:26px; color:var(--fg-1); letter-spacing:-0.005em; line-height:1.1; }
.tz-builder-month .dose-ladder { display:grid; grid-template-columns:repeat(6,1fr); gap:10px; }
.tz-builder-month .dose-pill { background:var(--bg-white); border:1px solid var(--border-default); border-radius:14px; padding:14px 8px 12px; cursor:pointer; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:4px; transition:all 180ms var(--ease-out); font-family:var(--font-sans); position:relative; }
.tz-builder-month .dose-pill:hover { border-color:var(--bg-ink); }
.tz-builder-month .dose-pill .mg { font-family:var(--font-display); font-style:italic; font-weight:500; font-size:22px; color:var(--fg-1); line-height:1; letter-spacing:-0.005em; }
.tz-builder-month .dose-pill .px { font-size:12px; color:var(--fg-3); letter-spacing:0.04em; font-weight:500; }
.tz-builder-month .dose-pill.active { background:var(--bg-ink); border-color:var(--bg-ink); }
.tz-builder-month .dose-pill.active .mg { color:#fff; }
.tz-builder-month .dose-pill.active .px { color:var(--bg-pink-soft); }
.tz-builder-month .dose-pill.tier-high::after { content:''; position:absolute; top:8px; right:8px; width:6px; height:6px; border-radius:50%; background:var(--bg-red); opacity:.5; }
.tz-builder-month .dose-pill.active.tier-high::after { background:var(--bg-pink-soft); opacity:1; }
.tz-builder-month .month-foot { display:flex; justify-content:space-between; align-items:baseline; gap:16px; padding-top:16px; border-top:1px solid var(--border-subtle); }
.tz-builder-month .month-foot .rec { font-family:var(--font-serif); font-size:14px; color:var(--fg-3); font-style:italic; }
.tz-builder-month .month-foot .rec em { color:var(--fg-2); font-weight:500; font-style:italic; }
.tz-builder-month .month-price { font-family:var(--font-display); font-style:italic; font-weight:500; font-size:32px; color:var(--fg-1); letter-spacing:-0.01em; line-height:1; white-space:nowrap; }
.tz-builder-month .month-price span { font-family:var(--font-sans); font-size:12px; color:var(--fg-3); font-style:normal; font-weight:400; letter-spacing:0.04em; margin-left:4px; }

.tz-builder-total { background:var(--bg-ink); color:#fff; border-radius:24px; padding:36px; display:flex; flex-direction:column; gap:20px; position:sticky; top:96px; align-self:start; }
.tz-builder-total .total-head { display:flex; flex-direction:column; gap:6px; padding-bottom:20px; border-bottom:1px solid rgba(255,255,255,.12); }
.tz-builder-total .eyebrow { color:var(--bg-pink-soft); }
.tz-builder-total .total-price { display:flex; align-items:baseline; gap:8px; margin-top:6px; }
.tz-builder-total .total-price .amount { font-family:var(--font-display); font-style:italic; font-weight:500; font-size:72px; line-height:1; color:#fff; letter-spacing:-0.02em; }
.tz-builder-total .total-price .per { font-family:var(--font-sans); font-size:14px; color:rgba(255,255,255,.6); letter-spacing:0.04em; }
.tz-builder-total .avg { font-family:var(--font-serif); font-style:italic; font-size:15px; color:rgba(255,255,255,.7); margin-top:4px; }
.tz-builder-total .included { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:10px; }
.tz-builder-total .included li { font-family:var(--font-sans); font-size:14px; color:rgba(255,255,255,.85); display:flex; gap:10px; align-items:flex-start; line-height:1.45; }
.tz-builder-total .included li svg { width:16px; height:16px; stroke:var(--bg-pink-soft); stroke-width:1.8; flex-shrink:0; margin-top:2px; }
.tz-builder-total .btn-primary { background:#fff; color:var(--bg-ink); }
.tz-builder-total .btn-primary:hover { background:var(--bg-pink-cream); }
.tz-builder-total .footnote { font-family:var(--font-serif); font-style:italic; font-size:12px; line-height:1.5; color:rgba(255,255,255,.55); }

@media (max-width:1100px) { .tz-page .tz-builder-month .dose-ladder { grid-template-columns:repeat(3,1fr); } }
@media (max-width:960px) { .tz-page .tz-builder { grid-template-columns:1fr; } .tz-page .tz-builder-total { position:relative; top:0; } }

/* Testimonials */
.tz-testimonials { padding:120px 0; background:var(--bg-pink-cream); }
.tz-test-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:56px; }
.tz-test-card { background:var(--bg-white); border-radius:20px; overflow:hidden; display:flex; flex-direction:column; border:1px solid var(--border-subtle); }
.tz-test-card .img { aspect-ratio:3/4; overflow:hidden; background:var(--bg-grey-50); }
.tz-test-card .img img { width:100%; height:100%; object-fit:cover; display:block; }
.tz-test-card .body { padding:28px 28px 32px; display:flex; flex-direction:column; gap:14px; }
.tz-test-card .qmark { font-family:var(--font-display); font-style:italic; font-size:56px; line-height:0.5; color:var(--bg-red); height:18px; }
.tz-test-card blockquote { font-family:var(--font-display); font-style:italic; font-weight:400; font-size:22px; line-height:1.3; color:var(--fg-1); margin:0; letter-spacing:-0.005em; }
.tz-test-card .meta { display:flex; flex-direction:column; gap:2px; margin-top:8px; padding-top:14px; border-top:1px solid var(--border-subtle); }
.tz-test-card .meta .name { font-family:var(--font-sans); font-weight:500; font-size:14px; color:var(--fg-1); }
.tz-test-card .meta .stat { font-family:var(--font-serif); font-size:13px; color:var(--bg-red); font-style:italic; }

/* Clinician */
.tz-clinician { padding:120px 0; }
.tz-clinician-grid { display:grid; grid-template-columns:0.85fr 1.15fr; gap:80px; align-items:center; }
.tz-clinician-img { aspect-ratio:4/5; border-radius:24px; overflow:hidden; background:var(--bg-grey-50); }
.tz-clinician-img img { width:100%; height:100%; object-fit:cover; display:block; }
.tz-clinician-copy h2 { font-family:var(--font-display); font-weight:500; font-size:56px; line-height:1.04; letter-spacing:-0.01em; margin:16px 0 20px; text-wrap:balance; }
.tz-clinician-copy h2 em { font-style:italic; color:var(--bg-red); }
.tz-clinician-copy p { font-family:var(--font-serif); font-size:19px; line-height:1.6; color:var(--fg-2); margin:0 0 16px; max-width:520px; }
.tz-clinician-creds { display:flex; gap:32px; margin-top:28px; padding-top:28px; border-top:1px solid var(--border-subtle); }
.tz-clinician-creds .c { display:flex; flex-direction:column; gap:2px; }
.tz-clinician-creds .c .v { font-family:var(--font-display); font-style:italic; font-weight:500; font-size:28px; color:var(--fg-1); }
.tz-clinician-creds .c .l { font-size:11px; letter-spacing:0.16em; text-transform:uppercase; color:var(--fg-3); }

/* FAQ */
.tz-faq { padding:120px 0; }
.tz-faq-grid { display:grid; grid-template-columns:0.45fr 0.55fr; gap:64px; }
.tz-faq h2 { font-family:var(--font-display); font-weight:500; font-size:56px; line-height:1.04; letter-spacing:-0.01em; margin:12px 0 16px; }
.tz-faq h2 em { font-style:italic; color:var(--bg-red); }
.tz-faq .left p { font-family:var(--font-serif); font-size:17px; line-height:1.55; color:var(--fg-2); }
.tz-faq-items { display:flex; flex-direction:column; }
.tz-faq-item { border-top:1px solid var(--border-default); padding:24px 0; cursor:pointer; }
.tz-faq-item:last-child { border-bottom:1px solid var(--border-default); }
.tz-faq-item .q { display:flex; justify-content:space-between; align-items:center; gap:24px; }
.tz-faq-item .q h4 { font-family:var(--font-serif); font-weight:500; font-size:19px; color:var(--fg-1); margin:0; line-height:1.35; }
.tz-faq-item .plus { font-family:var(--font-display); font-style:italic; font-weight:500; font-size:32px; color:var(--bg-red); line-height:1; transition:transform 220ms var(--ease-out); flex-shrink:0; }
.tz-faq-item.open .plus { transform:rotate(45deg); }
.tz-faq-item .a { font-family:var(--font-serif); font-size:16px; line-height:1.6; color:var(--fg-2); max-height:0; overflow:hidden; transition:max-height 320ms var(--ease-out), padding 220ms var(--ease-out); padding-right:48px; }
.tz-faq-item.open .a { max-height:400px; padding-top:12px; }

/* Final CTA */
.tz-final { background:var(--bg-ink); color:#fff; padding:120px 0; }
.tz-final .center { text-align:center; max-width:800px; margin:0 auto; }
.tz-final h2 { font-family:var(--font-display); font-weight:500; font-style:italic; font-size:80px; line-height:1.0; letter-spacing:-0.018em; color:#fff; margin:16px 0 24px; text-wrap:balance; }
.tz-final h2 .accent { color:var(--bg-pink-soft); }
.tz-final p { font-family:var(--font-serif); font-size:20px; line-height:1.55; color:rgba(255,255,255,.75); margin:0 0 32px; }
.tz-final .btn-primary { background:#fff; color:var(--bg-ink); }
.tz-final .btn-primary:hover { background:var(--bg-pink-cream); }
.tz-final .eyebrow { color:var(--bg-pink-soft); }
.tz-final .micro { font-family:var(--font-sans); font-size:12px; letter-spacing:0.14em; text-transform:uppercase; color:rgba(255,255,255,.5); margin-top:24px; }

/* Footer */
.tz-footer { background:var(--bg-cream); padding:56px 0 32px; border-top:1px solid var(--border-subtle); }
.tz-footer-grid { display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:32px; }
.tz-footer .brand { font-family:var(--font-display); font-style:italic; font-weight:500; font-size:32px; letter-spacing:-0.01em; }
.tz-footer .brand .body { color:var(--bg-pink); }
.tz-footer .brand .good { color:var(--bg-red); }
.tz-footer h4 { font-family:var(--font-sans); font-size:11px; letter-spacing:0.18em; text-transform:uppercase; color:var(--fg-2); margin:0 0 16px; font-weight:500; }
.tz-footer ul { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:10px; }
.tz-footer a { font-family:var(--font-serif); font-size:15px; color:var(--fg-2); text-decoration:none; }
.tz-footer a:hover { color:var(--bg-red); }
.tz-footer .fine { grid-column:1/-1; padding-top:32px; margin-top:32px; border-top:1px solid var(--border-subtle); display:flex; justify-content:space-between; font-family:var(--font-sans); font-size:12px; color:var(--fg-3); flex-wrap:wrap; gap:12px; }

/* Sticky CTA */
.tz-sticky-cta { position:fixed; bottom:24px; left:50%; transform:translate(-50%,120%); z-index:60; background:var(--bg-ink); color:#fff; padding:12px 12px 12px 24px; border-radius:999px; display:flex; align-items:center; gap:16px; box-shadow:var(--shadow-lg); opacity:0; transition:opacity 320ms var(--ease-out), transform 320ms var(--ease-out); }
.tz-sticky-cta.visible { transform:translate(-50%,0); opacity:1; }
.tz-sticky-cta .label { font-family:var(--font-serif); font-style:italic; font-size:16px; }
.tz-sticky-cta .btn { background:var(--bg-red); color:#fff; padding:10px 18px; font-size:14px; }
.tz-sticky-cta .btn:hover { background:var(--bg-red-deep); }

@media (max-width:960px) {
  .tz-page .tz-hero, .tz-page .tz-clinician-grid, .tz-page .tz-faq-grid, .tz-page .tz-how-grid, .tz-page .tz-test-grid, .tz-page .tz-footer-grid { grid-template-columns:1fr; gap:32px; }
  .tz-page .tz-hero h1, .tz-page .tz-final h2 { font-size:56px; }
  .tz-page .tz-section-head h2, .tz-page .tz-clinician-copy h2, .tz-page .tz-faq h2 { font-size:40px; }
  .tz-page .tz-nav-links { display:none; }
}
