/* =========================================================
   ALLURE PROCEDURE-PAGE TEMPLATE (Apr 2026)
   Shared styles for the stem-cell-style procedure template:
     - Why Choose Us 4-stat row
     - Pricing-charts branch (savings band + bar chart +
       modality grids + includes-strip + quote callout)
     - Audience-funnel cards
     - Intro rich section + 3-image grid
     - Testimonial strip
     - .reveal animation primitive

   Depends on the per-page :root --allure-* CSS variables
   defined in the procedure page's own <style> block.

   First adopted: procedure-stem-cell.html
   Mirrored to:   procedure-cosmetic-surgery.html
   Roll out to the other 7 procedure pages by adding the
   <link> tag to their <head> and porting their inline copies.
   ========================================================= */

/* ---------- Reveal / fade-in primitive ---------- */
.reveal { opacity:0; transform:translateY(24px); transition:opacity .7s ease, transform .7s ease; }
.reveal.visible { opacity:1 !important; transform:translateY(0) !important; }

/* ---------- Generic helpers ---------- */
.allure-template-image { width:100%; height:100%; object-fit:cover; display:block; }
.allure-slider-summary { max-width:48rem; margin:1.5rem auto 0; color:rgba(0,17,30,.68); line-height:1.65; text-align:center; }

/* ---------- Rich section primitives ---------- */
.allure-rich-section { padding:6rem 0; }
.allure-rich-soft { background:#f6f8fb; }
.allure-rich-top { display:grid; grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr); gap:3rem; align-items:center; }
.allure-rich-copy { display:grid; gap:1.1rem; }
.allure-rich-copy p { margin:0; color:rgba(0,17,30,.68); line-height:1.75; }
.allure-rich-image-grid { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.allure-rich-image-card { min-height:260px; border-radius:20px; overflow:hidden; background:#e9eef4; box-shadow:0 22px 60px rgba(1,58,101,.1); }
.allure-rich-image-card.rt-tall { min-height:540px; grid-row:span 2; }
.allure-rich-image-card img { width:100%; height:100%; object-fit:cover; display:block; }

/* ---------- Testimonial strip (3-mini cards) ---------- */
.allure-testimonial-strip { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:1rem; }
.allure-testimonial-mini { background:#fff; border:1px solid rgba(1,58,101,.1); border-radius:18px; padding:1.25rem; }
.allure-testimonial-mini p { margin:0; color:rgba(0,17,30,.66); line-height:1.65; }
.allure-avatar-row { display:flex; gap:.65rem; align-items:center; margin-top:1rem; }
.allure-avatar-row img { width:42px; height:42px; border-radius:50%; object-fit:cover; }

/* ---------- Audience funnel cards (gold-accented "Who this is for") ---------- */
.allure-funnel-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:1rem; }
.allure-funnel-card { position:relative; background:#fff; border:1px solid rgba(1,58,101,.1); border-radius:20px; padding:1.5rem; min-height:100%; box-shadow:0 18px 48px rgba(1,58,101,.07); display:flex; flex-direction:column; gap:.85rem; overflow:hidden; }
.allure-funnel-card::before { content:""; position:absolute; left:0; top:1.25rem; bottom:1.25rem; width:3px; background:linear-gradient(180deg, var(--allure-gold), rgba(184,153,104,.2)); border-radius:2px; }
.allure-funnel-card .funnel-eyebrow { font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--allure-gold); font-weight:700; }
.allure-funnel-card .funnel-title { font-weight:700; color:var(--allure-ink); font-size:1.05rem; line-height:1.35; }
.allure-funnel-card .funnel-who { color:rgba(0,17,30,.72); line-height:1.6; font-size:.92rem; }
.allure-funnel-card .funnel-quote { color:var(--allure-navy); font-style:italic; font-weight:600; line-height:1.5; padding:.75rem .85rem; background:rgba(184,153,104,.08); border-left:2px solid var(--allure-gold); border-radius:6px; font-size:.92rem; }

/* =========================================================
   STEM CELL TEMPLATE BUILDOUT
   Why Choose Us stat row + custom pricing-charts branch.
   Static editorial only - no JS chart libraries.
   ========================================================= */

/* Why Choose Us — template-style stat counter row */
.allure-choose-us { padding:6rem 0 5rem; background:#fff; }
.allure-choose-us-head { max-width:48rem; margin:0 auto 3rem; text-align:center; }
.allure-choose-us-head p { margin:1rem 0 0; color:rgba(0,17,30,.66); line-height:1.7; }
.allure-stat-row { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:0; align-items:stretch; border-top:1px solid var(--allure-line); border-bottom:1px solid var(--allure-line); padding:2.5rem 0; }
.allure-stat { position:relative; padding:0 1.75rem; text-align:center; display:flex; flex-direction:column; align-items:center; }
.allure-stat + .allure-stat { border-left:1px solid var(--allure-line); }
.allure-stat-num { font-family:'Plus Jakarta Sans',sans-serif; font-size:3rem; font-weight:800; color:var(--allure-navy); line-height:1; letter-spacing:-.02em; font-variant-numeric:tabular-nums; }
.allure-stat-mark { display:block; width:2rem; height:2px; background:var(--allure-gold); margin:.95rem auto 1rem; border-radius:2px; }
.allure-stat-label { font-size:.76rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--allure-ink); margin-bottom:.45rem; }
.allure-stat-body { font-size:.88rem; color:rgba(0,17,30,.66); line-height:1.55; max-width:14rem; }

/* Pricing-charts branch — section container */
.allure-pricing-branch { padding:6rem 0; background:linear-gradient(180deg,#fff 0%,var(--allure-soft) 100%); }
.allure-branch-head { max-width:50rem; margin:0 auto 3.25rem; text-align:center; }
.allure-branch-head .rt-sub-text { color:var(--allure-gold); }
.allure-branch-head p { margin:1rem 0 0; color:rgba(0,17,30,.66); line-height:1.7; }

/* 3A — Savings hero band (3 oversized stat cards) */
.allure-savings-band { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:1rem; margin:0 auto 4.5rem; max-width:62rem; }
.allure-savings-card { background:#fff; border:1px solid var(--allure-line); border-radius:20px; padding:2rem 1.5rem; text-align:center; box-shadow:0 22px 60px rgba(1,58,101,.08); display:flex; flex-direction:column; align-items:center; }
.allure-savings-card.is-mx { background:var(--allure-navy); border-color:var(--allure-navy); color:#fff; box-shadow:0 28px 70px rgba(1,58,101,.28); }
.allure-savings-card .save-label { font-size:.68rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:rgba(0,17,30,.55); margin-bottom:.95rem; }
.allure-savings-card.is-mx .save-label { color:rgba(255,255,255,.7); }
.allure-savings-card .save-amount { font-family:'Plus Jakarta Sans',sans-serif; font-size:2.4rem; font-weight:800; line-height:1; letter-spacing:-.02em; color:var(--allure-ink); font-variant-numeric:tabular-nums; }
.allure-savings-card.is-mx .save-amount { color:#fff; }
.allure-savings-card .save-amount s { color:rgba(0,17,30,.42); text-decoration-thickness:1.5px; font-weight:700; }
.allure-savings-card .save-foot { margin-top:.95rem; font-size:.82rem; color:rgba(0,17,30,.6); line-height:1.5; }
.allure-savings-card.is-mx .save-foot { color:rgba(255,255,255,.78); }
.allure-savings-card.is-save .save-amount { color:var(--allure-gold); font-size:2.6rem; }

/* 3B — Procedure-by-procedure CSS bar chart */
.allure-bar-chart { background:#fff; border:1px solid var(--allure-line); border-radius:24px; padding:2.25rem 2.5rem; box-shadow:0 24px 70px rgba(1,58,101,.08); margin-bottom:4.5rem; }
.allure-bar-chart-head { display:flex; flex-wrap:wrap; align-items:flex-end; justify-content:space-between; gap:1rem; margin-bottom:2rem; }
.allure-bar-chart-head h3 { margin:0; color:var(--allure-ink); font-size:1.5rem; font-weight:700; line-height:1.3; }
.allure-bar-legend { display:flex; gap:1.25rem; align-items:center; flex-wrap:wrap; font-size:.82rem; color:rgba(0,17,30,.7); }
.allure-bar-legend-dot { display:inline-block; width:.7rem; height:.7rem; border-radius:50%; margin-right:.4rem; vertical-align:middle; }
.allure-bar-legend-dot.is-mx { background:var(--allure-navy); }
.allure-bar-legend-dot.is-us { background:#cbd2dc; }
.allure-bar-row { display:grid; grid-template-columns:minmax(0,.85fr) minmax(0,2.2fr) minmax(0,.55fr); gap:1.5rem; align-items:center; padding:1.25rem 0; border-top:1px dashed var(--allure-line); }
.allure-bar-row:first-of-type { border-top:0; }
.allure-bar-label { font-size:.95rem; font-weight:700; color:var(--allure-ink); line-height:1.35; }
.allure-bar-label small { display:block; font-size:.74rem; font-weight:500; color:rgba(0,17,30,.55); margin-top:.25rem; letter-spacing:.01em; }
.allure-bar-track { display:grid; gap:.55rem; }
.allure-bar { position:relative; height:1.85rem; border-radius:6px; display:flex; align-items:center; padding:0 .75rem; min-width:5.5rem; }
.allure-bar-mx { background:linear-gradient(90deg,var(--allure-navy),#024d85); color:#fff; box-shadow:0 6px 18px rgba(1,58,101,.22); }
.allure-bar-us { background:#e6e9ef; color:rgba(0,17,30,.62); }
.allure-bar-tag { font-size:.66rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase; opacity:.78; margin-right:.6rem; }
.allure-bar-mx .allure-bar-tag { color:rgba(255,255,255,.78); }
.allure-bar-us .allure-bar-tag { color:rgba(0,17,30,.55); }
.allure-bar-amount { font-size:.82rem; font-weight:800; letter-spacing:.01em; font-variant-numeric:tabular-nums; }
.allure-bar-save { display:inline-flex; flex-direction:column; align-items:center; justify-content:center; gap:.2rem; background:rgba(184,153,104,.12); border:1px solid rgba(184,153,104,.32); border-radius:14px; padding:.75rem .65rem; color:#6f5429; }
.allure-bar-save strong { font-size:1.1rem; font-weight:800; line-height:1; color:var(--allure-gold); letter-spacing:-.01em; font-variant-numeric:tabular-nums; }
.allure-bar-save span { font-size:.6rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase; }

/* 3C — Modality grid (5 + 3 layout) */
.allure-modality-section { margin-top:0; }
.allure-modality-section h3 { margin:0 0 .75rem; color:var(--allure-ink); font-size:1.5rem; font-weight:700; line-height:1.3; text-align:center; }
.allure-modality-section p.lead { text-align:center; color:rgba(0,17,30,.66); line-height:1.7; max-width:42rem; margin:0 auto 2.75rem; }
.allure-modality-divider { display:flex; align-items:center; gap:1rem; margin:3rem 0 1.5rem; }
.allure-modality-divider span { font-size:.7rem; font-weight:700; letter-spacing:.2em; text-transform:uppercase; color:var(--allure-gold); white-space:nowrap; }
.allure-modality-divider::before, .allure-modality-divider::after { content:""; flex:1; height:1px; background:var(--allure-line); }
.allure-modality-grid { display:grid; grid-template-columns:repeat(5,minmax(0,1fr)); gap:1rem; }
.allure-modality-grid.is-three { grid-template-columns:repeat(3,minmax(0,1fr)); max-width:62rem; margin:0 auto; }
.allure-modality-card { position:relative; background:#fff; border:1px solid var(--allure-line); border-radius:18px; padding:1.5rem 1.35rem; display:flex; flex-direction:column; gap:.65rem; min-height:100%; box-shadow:0 14px 38px rgba(1,58,101,.06); transition:transform .3s ease, box-shadow .3s ease, border-color .3s ease; }
.allure-modality-card:hover { transform:translateY(-3px); box-shadow:0 22px 52px rgba(1,58,101,.12); border-color:rgba(1,58,101,.28); }
.allure-modality-card.is-quote { background:linear-gradient(180deg,#fff,rgba(184,153,104,.05)); }
.allure-modality-icon { width:2.4rem; height:2.4rem; display:flex; align-items:center; justify-content:center; border-radius:10px; background:rgba(1,58,101,.08); color:var(--allure-navy); }
.allure-modality-card.is-quote .allure-modality-icon { background:rgba(184,153,104,.14); color:#6f5429; }
.allure-modality-icon svg { width:1.25rem; height:1.25rem; }
.allure-modality-title { font-size:1.02rem; font-weight:700; color:var(--allure-ink); line-height:1.3; }
.allure-modality-meta { font-size:.84rem; color:rgba(0,17,30,.62); line-height:1.55; flex:1; }
.allure-modality-price { display:inline-flex; align-items:baseline; gap:.4rem; padding:.55rem .75rem; background:rgba(1,58,101,.07); border:1px solid rgba(1,58,101,.18); border-radius:10px; color:var(--allure-navy); font-weight:800; font-size:.95rem; font-variant-numeric:tabular-nums; width:max-content; }
.allure-modality-price small { font-size:.62rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:rgba(1,58,101,.6); }
.allure-modality-quote { display:inline-flex; align-items:center; gap:.4rem; padding:.55rem .85rem; background:rgba(184,153,104,.12); border:1px solid rgba(184,153,104,.32); border-radius:10px; color:#6f5429; font-weight:700; font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; width:max-content; }
.allure-modality-us { font-size:.78rem; color:rgba(0,17,30,.5); margin-top:-.2rem; }
.allure-modality-us s { color:rgba(0,17,30,.42); }
.allure-modality-save { position:absolute; top:1rem; right:1rem; background:var(--allure-gold); color:#fff; font-size:.6rem; font-weight:800; letter-spacing:.14em; text-transform:uppercase; padding:.32rem .6rem; border-radius:999px; box-shadow:0 6px 16px rgba(184,153,104,.4); }

/* 3D — Inclusions strip */
.allure-includes-section { margin-top:5rem; }
.allure-includes-section h3 { margin:0 0 .75rem; text-align:center; color:var(--allure-ink); font-size:1.5rem; font-weight:700; line-height:1.3; }
.allure-includes-section p.lead { text-align:center; color:rgba(0,17,30,.66); max-width:38rem; margin:0 auto 2.5rem; line-height:1.65; }
.allure-includes-strip { display:grid; grid-template-columns:repeat(6,minmax(0,1fr)); gap:.75rem; }
.allure-includes-item { background:#fff; border:1px solid var(--allure-line); border-radius:16px; padding:1.4rem 1rem; text-align:center; display:flex; flex-direction:column; align-items:center; gap:.7rem; min-height:100%; }
.allure-includes-icon { width:2.4rem; height:2.4rem; display:flex; align-items:center; justify-content:center; border-radius:50%; background:rgba(1,58,101,.08); color:var(--allure-navy); }
.allure-includes-icon svg { width:1.15rem; height:1.15rem; }
.allure-includes-item-title { font-size:.82rem; font-weight:700; color:var(--allure-ink); line-height:1.35; }
.allure-includes-item-body { font-size:.74rem; color:rgba(0,17,30,.58); line-height:1.5; }

/* 3E — Custom-quote callout */
.allure-quote-callout { display:flex; align-items:center; justify-content:space-between; gap:1.5rem; flex-wrap:wrap; background:linear-gradient(135deg,rgba(1,58,101,.04),rgba(184,153,104,.1)); border:1px solid rgba(1,58,101,.14); border-radius:20px; padding:1.85rem 2.25rem; margin-top:5rem; }
.allure-quote-callout-text { display:grid; gap:.4rem; max-width:42rem; }
.allure-quote-callout-eyebrow { font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--allure-gold); font-weight:700; }
.allure-quote-callout-title { color:var(--allure-ink); font-weight:700; font-size:1.15rem; line-height:1.35; }
.allure-quote-callout-body { font-size:.92rem; color:rgba(0,17,30,.66); line-height:1.6; margin:0; }

/* ---------- Inline CTA rows (sprinkled through the pricing branch) ---------- */
.allure-pricing-cta-row { display:flex; flex-direction:column; align-items:center; gap:.9rem; text-align:center; margin:3rem auto 3rem; max-width:46rem; padding:0 1rem; box-sizing:border-box; }
.allure-pricing-cta-row.is-tight { margin-top:2.25rem; }
.allure-pricing-cta-row .allure-pricing-cta-eyebrow { font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color:var(--allure-gold); font-weight:700; }
.allure-pricing-cta-row .allure-pricing-cta-text { color:rgba(0,17,30,.7); font-size:.95rem; line-height:1.6; margin:0; }
.allure-pricing-cta-row .allure-pricing-cta-buttons { display:flex; gap:.85rem; flex-wrap:wrap; justify-content:center; align-items:stretch; margin-top:.5rem; }
/* Match heights between Webflow rt-button and the new secondary outline pill */
.allure-pricing-cta-row .rt-button { min-height:3.25rem; display:inline-flex; align-items:center; justify-content:center; padding:.85rem 1.6rem; box-sizing:border-box; }
.allure-pricing-cta-secondary { display:inline-flex; align-items:center; justify-content:center; min-height:3.25rem; padding:.85rem 1.6rem; border:1.5px solid var(--allure-navy); border-radius:999px; color:var(--allure-navy); font-weight:700; font-size:.88rem; letter-spacing:.01em; text-decoration:none; background:transparent; box-sizing:border-box; transition:background .25s ease, color .25s ease, transform .25s ease, box-shadow .25s ease; }
.allure-pricing-cta-secondary:hover { background:var(--allure-navy); color:#fff; transform:translateY(-1px); box-shadow:0 10px 22px rgba(1,58,101,.18); }
.allure-pricing-cta-secondary:focus-visible { outline:3px solid rgba(184,153,104,.55); outline-offset:2px; }

/* ---------- Responsive — tablet (<=991px) ---------- */
@media (max-width:991px) {
  .allure-rich-top { grid-template-columns:1fr; }
  .allure-testimonial-strip, .allure-funnel-grid { grid-template-columns:repeat(2,minmax(0,1fr)); }

  .allure-choose-us { padding:4.5rem 0 3.5rem; }
  .allure-stat-row { grid-template-columns:repeat(2,minmax(0,1fr)); padding:1.5rem 0; gap:2rem 0; }
  .allure-stat + .allure-stat { border-left:0; }
  .allure-stat:nth-child(odd) { border-right:1px solid var(--allure-line); }
  .allure-stat-num { font-size:2.4rem; }

  .allure-pricing-branch { padding:4.5rem 0; }
  .allure-savings-band { grid-template-columns:1fr; gap:.85rem; max-width:30rem; margin-bottom:3.5rem; }
  .allure-savings-card { padding:1.5rem 1.25rem; }
  .allure-savings-card .save-amount, .allure-savings-card.is-save .save-amount { font-size:2rem; }
  .allure-bar-chart { padding:1.85rem 1.5rem; }
  .allure-bar-chart-head { flex-direction:column; align-items:flex-start; }
  .allure-bar-row { grid-template-columns:1fr; gap:.85rem; padding:1.5rem 0; }
  .allure-bar-save { flex-direction:row; align-self:flex-start; padding:.55rem .9rem; gap:.5rem; }
  .allure-bar-save strong { font-size:1rem; }
  .allure-bar-save span { font-size:.58rem; }
  .allure-modality-grid, .allure-modality-grid.is-three { grid-template-columns:repeat(2,minmax(0,1fr)); max-width:none; }
  .allure-includes-strip { grid-template-columns:repeat(3,minmax(0,1fr)); }
  .allure-quote-callout { flex-direction:column; align-items:flex-start; padding:1.5rem; }
  .allure-pricing-cta-row { margin:2.25rem auto 2.5rem; gap:.75rem; padding:0 1.25rem; }
  .allure-pricing-cta-row.is-tight { margin-top:1.75rem; }
  .allure-pricing-cta-row .allure-pricing-cta-text { font-size:.92rem; }
  .allure-pricing-cta-row .allure-pricing-cta-buttons { flex-direction:column; width:100%; max-width:22rem; gap:.65rem; }
  .allure-pricing-cta-row .allure-pricing-cta-buttons > * { width:100%; min-height:3rem; }
  .allure-pricing-cta-row .rt-button { width:100%; min-height:3rem; padding:.8rem 1.4rem; }
}

/* ---------- Responsive — mobile (<=767px) ---------- */
@media (max-width:767px) {
  .allure-rich-section { padding:4rem 0; }
  .allure-rich-image-grid, .allure-testimonial-strip, .allure-funnel-grid { grid-template-columns:1fr; }
  .allure-rich-image-card.rt-tall { min-height:340px; grid-row:auto; }

  .allure-choose-us-head { margin-bottom:2.25rem; }
  .allure-stat-row { grid-template-columns:1fr; padding:1rem 0; gap:0; }
  .allure-stat:nth-child(odd) { border-right:0; }
  .allure-stat { padding:1.5rem 1rem; }
  .allure-stat + .allure-stat { border-top:1px solid var(--allure-line); }
  .allure-stat-num { font-size:2.6rem; }
  .allure-bar-chart { padding:1.5rem 1.15rem; border-radius:18px; }
  .allure-bar { height:1.65rem; padding:0 .55rem; }
  .allure-bar-amount { font-size:.74rem; }
  .allure-bar-tag { display:none; }
  .allure-modality-grid, .allure-modality-grid.is-three { grid-template-columns:1fr; }
  .allure-includes-strip { grid-template-columns:repeat(2,minmax(0,1fr)); }
  .allure-pricing-cta-row { margin:1.85rem auto 2rem; padding:0 1rem; }
  .allure-pricing-cta-row .allure-pricing-cta-text { font-size:.9rem; line-height:1.55; }
  .allure-pricing-cta-row .allure-pricing-cta-buttons { max-width:none; gap:.6rem; }
  .allure-pricing-cta-row .allure-pricing-cta-buttons > *,
  .allure-pricing-cta-row .rt-button { min-height:3rem; font-size:.9rem; padding:.85rem 1.2rem; }
}
