/* ═══════════════════════════════════════════════════════════
   CITRUSBURN — LANDING PAGE STYLESHEET
   Modern, dependency-free. No Bootstrap, no Mobirise.
   ═══════════════════════════════════════════════════════════ */

/* ── DESIGN TOKENS ─────────────────────────────────────────── */
:root{
  --orange-900:#7A2A0E;
  --orange-700:#A8390F;
  --orange-600:#C44B1A;   /* primary brand (hero, accents) */
  --orange-500:#E8590C;
  --orange-400:#F36B1F;
  --orange-300:#FFA552;
  --orange-100:#FFE7D2;
  --orange-50:#FFF6EB;

  /* Rust-orange — used for header + section heading strips.
     (Var names kept --teal-* for backwards compatibility with the
     rest of this file; values are rust shades, not teal.) */
  --teal-900:#6E2716;
  --teal-800:#8B3520;
  --teal-700:#B94C33;     /* primary header / strip */
  --teal-600:#C95E45;
  --teal-300:#E8927B;

  --yellow-500:#FFD10A;   /* CTA gold (V2 original — kept for fallback) */
  --yellow-400:#E6BB00;   /* CTA hover */
  --yellow-300:#CCA500;   /* CTA active */

  /* V1 accent palette (migrated for premium feel) */
  --green:#00A836;        /* primary CTA — vibrant action green */
  --green-d:#007A28;      /* CTA hover */
  --green-l:#E6F9ED;      /* soft mint section accent */
  --gold:#C8870A;         /* rating border / quality cue */
  --gold-l:#FEF8E7;       /* rating pill bg */

  --ink-900:#1A1A1A;
  --ink-700:#3A3A3A;
  --ink-500:#5C5C5C;
  --ink-300:#9A9A9A;
  --ink-100:#E8E8E8;
  --paper:#FFFFFF;
  --cream:#FFFBF5;

  --shadow-sm:0 1px 2px rgba(20,10,0,.06),0 2px 6px rgba(20,10,0,.05);
  --shadow-md:0 6px 16px rgba(20,10,0,.08),0 12px 28px rgba(20,10,0,.06);
  --shadow-lg:0 16px 40px rgba(20,10,0,.12),0 30px 60px rgba(20,10,0,.08);

  --r-sm:6px;
  --r-md:10px;
  --r-lg:16px;
  --r-xl:24px;
  --r-pill:999px;

  --container:1200px;
  --gutter:clamp(16px,3vw,32px);

  --font:'Jost',sans-serif;
}

/* ── RESET ────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box}
html{
  scroll-behavior:smooth;
  -webkit-text-size-adjust:100%;
  overflow-x:clip;            /* prevent horizontal scroll on mobile/iPad */
}
body{
  margin:0;
  font-family:var(--font);
  font-size:16px;
  line-height:1.6;
  color:var(--ink-900);
  background:var(--paper);
  overflow-x:clip;            /* defensive: same guard at body level */
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:transparent;color:inherit}
ul{margin:0;padding:0;list-style:none}
h1,h2,h3,h4,h5,h6{margin:0;line-height:1.2;font-weight:700;letter-spacing:-.01em}
p{margin:0 0 1em}

/* ── LAYOUT ───────────────────────────────────────────────── */
.container{
  width:100%;
  max-width:var(--container);
  margin:0 auto;
  padding-inline:var(--gutter);
}
.section{padding-block:clamp(56px,8vw,96px)}
.section--tight{padding-block:clamp(32px,5vw,56px)}
.section--cream{background:#fff}

/* ── PER-SECTION BACKGROUND VARIANTS ──────────────────────── */
.bg-white  {background:#FFFFFF}
.bg-cream  {background:#FAF9F6}
.bg-cream-2{background:#F4F2EE}
.bg-blue-l {background:#EFF7FF}
.bg-peach  {background:#FEF0EB}
.section--orange{
  background:linear-gradient(135deg,var(--orange-700) 0%,var(--orange-600) 50%,var(--orange-500) 100%);
  color:#fff;
}

.section-title{
  font-size:clamp(28px,4vw,46px);
  text-align:center;
  margin-bottom:.6em;
  color:var(--teal-700);
}
.section-subtitle{
  font-size:clamp(16px,2vw,20px);
  text-align:center;
  max-width:780px;
  margin:0 auto 2em;
  color:var(--ink-700);
}
.section-orange .section-title,
.section-orange .section-subtitle{color:#fff}

/* ── HEADING STRIP — full-width dark-teal banner (~110px tall on
   desktop, matches AudiFort 1287×109.75 reference). ──────── */
.heading-strip{
  background:var(--teal-700);
  color:#fff;
  padding-block:clamp(22px,2.4vw,32px);
  text-align:center;
}
.heading-strip h2{
  color:#fff;
  font-size:clamp(22px,2.8vw,36px);
  font-weight:800;
  line-height:1.2;
  margin:0;
  letter-spacing:-.01em;
}
.heading-strip p{
  margin:.5em auto 0;
  max-width:760px;
  font-size:clamp(14px,1.4vw,17px);
  color:rgba(255,255,255,.92);
  line-height:1.5;
}

/* ── BUTTONS ──────────────────────────────────────────────── */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.55em;
  padding:.95em 1.8em;
  border-radius:var(--r-pill);
  font-weight:700;
  font-size:1rem;
  letter-spacing:.01em;
  transition:transform .18s ease,box-shadow .18s ease,background .18s ease;
  cursor:pointer;
  white-space:normal;
  text-align:center;
  line-height:1.2;
}
.btn-primary{
  background:var(--green);
  color:#fff;
  box-shadow:0 6px 28px rgba(0,168,54,.28);
  border:0;
  letter-spacing:.02em;
}
.btn-primary:hover{
  transform:translateY(-2px);
  background:var(--green-d);
  color:#fff;
  box-shadow:0 10px 36px rgba(0,168,54,.42);
}
.btn-primary:active{
  transform:translateY(0);
  background:var(--green-d);
  box-shadow:0 4px 12px rgba(0,168,54,.3);
}
/* Pulse only on the primary hero CTA — keeps the page from feeling noisy */
.hero-cta .btn-primary{
  animation:pulse-cta 2.4s ease-in-out infinite;
}
.hero-cta .btn-primary:hover{animation:none}
@keyframes pulse-cta{
  0%,100%{box-shadow:0 4px 20px rgba(0,168,54,.28)}
  50%{box-shadow:0 8px 36px rgba(0,168,54,.48)}
}
.btn-ghost{
  background:#fff;
  color:var(--orange-700);
  border:2px solid var(--orange-600);
}
.btn-ghost:hover{background:var(--orange-50)}

/* Hero dual-CTA: deal magnet (green) + trust trigger (rust-orange) ── */
.btn-deal{
  background:var(--green);
  color:#fff;
  border:0;
  letter-spacing:.02em;
  box-shadow:0 6px 28px rgba(0,168,54,.28);
}
.btn-deal:hover,
.btn-deal:focus-visible{
  transform:translateY(-2px);
  background:var(--green-d);
  color:#fff;
  box-shadow:0 10px 36px rgba(0,168,54,.42);
}
.btn-deal:active{
  transform:translateY(0);
  background:var(--green-d);
  box-shadow:0 4px 12px rgba(0,168,54,.3);
}

.btn-official{
  background:var(--teal-700);   /* rust-orange #B94C33 (token kept as --teal-700) */
  color:#fff;
  border:0;
  letter-spacing:.02em;
  box-shadow:0 6px 18px rgba(185,76,51,.3);
}
.btn-official:hover,
.btn-official:focus-visible{
  transform:translateY(-2px);
  background:var(--teal-800);
  color:#fff;
  box-shadow:0 10px 24px rgba(185,76,51,.4);
}
.btn-official:active{
  transform:translateY(0);
  background:var(--teal-900);
  box-shadow:0 4px 12px rgba(185,76,51,.3);
}

.btn-icon{
  font-size:1em;
  line-height:1;
  display:inline-flex;
  align-items:center;
}
.btn-lg{padding:.9em 1.7em;font-size:1rem}
.btn-xl{padding:1.05em 2em;font-size:1.08rem}

@media (max-width:560px){
  .btn-lg{padding:.85em 1.4em;font-size:.95rem;letter-spacing:.01em}
  .btn-xl{padding:.95em 1.7em;font-size:1rem}
}

/* ── TOP STRIP ────────────────────────────────────────────── */
.top-strip{
  background:linear-gradient(90deg,var(--orange-700),var(--orange-500));
  color:#fff;
  font-size:14px;
  padding:10px 0;
  text-align:center;
}
.top-strip strong{font-weight:700;letter-spacing:.04em}
.top-strip .container{display:flex;align-items:center;justify-content:center;gap:1em;flex-wrap:wrap}
.top-strip a{
  color:var(--yellow-300);
  font-weight:700;
  text-decoration:underline;
  text-underline-offset:3px;
}

/* ── HEADER / NAV ─────────────────────────────────────────── */
.site-header{
  position:sticky;
  top:0;
  z-index:1000;
  background:var(--teal-700);
  color:#fff;
  box-shadow:var(--shadow-sm);
  transition:background .25s ease;
}
.site-header.is-scrolled{
  background:rgba(185,76,51,.97);
  backdrop-filter:saturate(180%) blur(6px);
}
.nav{
  display:flex;
  align-items:center;
  gap:1em;
  padding-block:14px;
}
.nav-brand{
  display:inline-flex;
  align-items:baseline;
  gap:.2em;
  font-size:clamp(24px,3vw,34px);
  font-weight:800;
  color:#fff;
  letter-spacing:-.015em;
}
.nav-brand .brand-tm{font-size:.45em;vertical-align:super;opacity:.85;font-weight:600}

.nav-menu{
  display:flex;
  gap:.3em;
  align-items:center;
  margin-inline-start:auto;   /* push menu + CTA group to the right */
}
.nav-menu a{
  display:inline-block;
  padding:.55em .9em;
  border-radius:var(--r-md);
  font-weight:500;
  font-size:.95rem;
  color:#fff;
  transition:background .18s ease,color .18s ease;
}
.nav-menu a:hover,.nav-menu a:focus-visible{background:rgba(255,255,255,.14)}

/* Compact yellow pill CTA in the desktop header (top-right). */
.nav-cta{
  display:inline-flex;
  align-items:center;
  gap:.45em;
  background:var(--green);
  color:#fff;
  font-weight:700;
  font-size:.95rem;
  padding:.65em 1.3em;
  border-radius:var(--r-pill);
  letter-spacing:.04em;
  text-transform:uppercase;
  white-space:nowrap;
  flex:0 0 auto;
  box-shadow:0 4px 14px rgba(0,168,54,.32);
  transition:transform .18s ease,box-shadow .18s ease,background .18s ease;
}
.nav-cta:hover,
.nav-cta:focus-visible{
  transform:translateY(-1px);
  background:var(--green-d);
  color:#fff;
  box-shadow:0 6px 18px rgba(0,168,54,.45);
}
.nav-cta .btn-icon{font-size:.95em}

.nav-toggle{
  display:none;
  flex-direction:column;
  gap:5px;
  background:transparent;
  border:none;
  padding:9px 8px;
  border-radius:var(--r-sm);
  cursor:pointer;
  transition:background .2s ease;
  flex-shrink:0;
}
.nav-toggle:hover{background:rgba(255,255,255,.12)}
.nav-toggle .bar{
  width:24px;
  height:2px;
  background:#fff;
  border-radius:2px;
  display:block;
  transition:transform .3s ease,opacity .3s ease;
}
.nav-toggle[aria-expanded="true"] .bar:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] .bar:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-toggle[aria-expanded="true"] .bar:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ── MOBILE DRAWER (V1 pattern: dropdown below header,
   white background, nav links + CTA at bottom).
   Positioned absolute so opening/closing does NOT shift the
   page content underneath. ─────────────────────────────── */
.mobile-drawer{
  display:none;
  flex-direction:column;
  position:absolute;
  top:100%;
  left:0;
  right:0;
  z-index:999;
  background:#fff;
  border-top:1px solid var(--ink-100);
  padding:12px 20px 18px;
  gap:4px;
  box-shadow:0 8px 24px rgba(13,27,42,.12);
  max-height:calc(100vh - 100%);
  overflow-y:auto;
}
.mobile-drawer.is-open{display:flex}
.mobile-drawer a{
  font-size:15px;
  font-weight:500;
  color:var(--ink-700);
  padding:12px 16px;
  border-radius:var(--r-md);
  border-left:3px solid transparent;
  transition:background .15s ease,color .15s ease,border-color .15s ease;
}
.mobile-drawer a:hover,
.mobile-drawer a:focus-visible{
  background:var(--orange-50);
  color:var(--orange-700);
  border-left-color:var(--orange-600);
}
.mobile-drawer .mob-cta{
  margin-top:10px;
  background:var(--green);
  color:#fff;
  font-weight:700;
  text-align:center;
  border-radius:var(--r-md);
  padding:14px 20px;
  font-size:15px;
  border-left:0;
  box-shadow:0 4px 14px rgba(0,168,54,.32);
}
.mobile-drawer .mob-cta:hover,
.mobile-drawer .mob-cta:focus-visible{
  background:var(--green-d);
  color:#fff;
  border-left-color:transparent;
  box-shadow:0 6px 18px rgba(0,168,54,.45);
}

/* ── BREAKPOINT — iPad portrait (≤1023px) collapses nav into
   the drawer pattern (V1 behaviour). Desktop CTA hides;
   drawer ships with its own ".mob-cta" full-width button. ── */
@media (max-width:1023px){
  .nav-menu,
  .nav-cta{display:none}
  .nav-toggle{display:flex;margin-inline-start:auto}
}

/* ── HERO ─────────────────────────────────────────────────── */
.hero{
  background:linear-gradient(90deg,#FFF9F6 0%,#F5F8FC 100%);
  color:var(--ink-900);
  padding-block:clamp(48px,7vw,96px);
  position:relative;
}
/* 4px accent bar at top of hero — orange-only (no green) */
.hero::after{
  content:'';
  position:absolute;
  top:0;left:0;right:0;
  height:4px;
  background:linear-gradient(90deg,#C44B1A 0%,#E8520A 100%);
}
.hero-grid{
  display:grid;
  grid-template-columns:1fr 1.1fr;
  gap:clamp(24px,4vw,56px);
  align-items:center;
  position:relative;
}
.hero-image{
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
}
/* The .reveal class on .hero-image adds will-change:transform, which
   creates a new stacking context that traps mix-blend-mode below
   from reaching the .hero gradient. Override it here so the bottle's
   white background can blend through to the gradient correctly. */
.hero-image.reveal{
  opacity:1 !important;
  transform:none !important;
  will-change:auto !important;
}
.hero-image .placeholder,
.hero-image img{
  max-width:100%;
  width:min(520px,100%);
}
/* Hero bottle uses a transparent-background PNG so it sits cleanly
   on the peach gradient without any blend-mode tricks. */
.hero-image .placeholder{
  aspect-ratio:1/1;
  display:grid;
  place-items:center;
  background:var(--orange-50);
  border:2px dashed var(--orange-300);
  border-radius:var(--r-xl);
  color:var(--orange-700);
  text-align:center;
  padding:2em;
  font-size:.9rem;
}
.hero-image .placeholder::before{
  content:'🍊';
  font-size:5rem;
  display:block;
  margin-bottom:.4em;
}

.hero-rating{
  display:inline-flex;
  align-items:center;
  gap:.5em;
  background:var(--gold-l);
  border:1px solid #FDDEA0;
  color:#7A4F00;
  padding:.4em .9em;
  border-radius:var(--r-pill);
  font-size:.85rem;
  font-weight:500;
  line-height:1.3;
  margin-bottom:1.2em;
  max-width:100%;
}
.hero-rating .stars{
  color:#F59E0B;
  letter-spacing:.06em;
  font-size:.95em;
  flex:0 0 auto;
}
.hero-rating .rating-text strong{font-weight:700;color:#7A4F00}
@media (max-width:480px){
  .hero-rating{font-size:.78rem;padding:.35em .8em}
}

.hero-title{
  font-size:clamp(28px,3.8vw,46px);
  line-height:1.1;
  margin-bottom:.25em;
  font-weight:800;
  color:var(--ink-900);
  white-space:nowrap;
}
.hero-title em{
  font-style:normal;
  color:var(--orange-600);
}
.hero-subtitle{
  font-size:clamp(16px,1.7vw,22px);
  font-weight:700;
  line-height:1.3;
  color:var(--orange-600);
  margin:0 0 1em;
  max-width:60ch;
}
@media (max-width:760px){
  .hero-title{
    white-space:normal;
    font-size:clamp(26px,6vw,34px);
  }
}
.hero-text{
  font-size:clamp(15px,1.5vw,18px);
  line-height:1.7;
  margin-bottom:1.5em;
  color:var(--ink-700);
  max-width:60ch;
}
.hero-text strong{color:var(--ink-900)}

.hero-cta{display:flex;flex-wrap:wrap;gap:.8em;align-items:center}
.hero-guarantee{
  margin-top:1.2em;
  font-size:.92rem;
  display:inline-flex;
  align-items:center;
  gap:.5em;
  color:var(--ink-700);
  font-weight:600;
}
.hero-guarantee::before{content:'🛡️'}

@media (max-width:900px){
  .hero-grid{
    grid-template-columns:1fr;
    text-align:center;
    gap:clamp(8px,1.8vw,16px);   /* was clamp(24px,4vw,56px) — tightens
                                    the space between the bottle and
                                    the main H1 on iPad/mobile */
  }
  .hero-cta{justify-content:center}
  .hero-text{margin-inline:auto}
  .hero-image{order:-1}
  .hero-image img{max-width:340px}  /* cap bottle width so it doesn't
                                       eat the whole screen on phones */
}

/* ── TRUST BADGES (Why Choose) ────────────────────────────── */
.badge-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:clamp(16px,2.5vw,28px);
}
.badge-card{
  background:#fff;
  border:1px solid var(--ink-100);
  border-radius:var(--r-lg);
  padding:24px 18px;
  text-align:center;
  box-shadow:var(--shadow-sm);
  transition:transform .2s ease,box-shadow .2s ease;
}
.badge-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.badge-card .badge-img{
  width:140px;
  height:140px;
  margin:0 auto 14px;
  display:grid;
  place-items:center;
}
.badge-card .badge-img img,
.badge-card .badge-img svg{
  width:100%;
  height:100%;
  object-fit:contain;
}
.badge-card h3{
  font-size:1.15rem;
  color:var(--orange-700);
  margin-bottom:.4em;
}
.badge-card p{font-size:.95rem;color:var(--ink-700);margin:0}
@media (max-width:780px){.badge-grid{grid-template-columns:repeat(2,1fr)}}

/* ── REVIEWS GRID ─────────────────────────────────────────── */
.reviews-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:clamp(16px,2.5vw,28px);
}
.review-card{
  background:#fff;
  border-radius:var(--r-lg);
  padding:28px 24px;
  box-shadow:var(--shadow-md);
  border-top:4px solid var(--orange-500);
  display:flex;
  flex-direction:column;
}
.review-stars{color:var(--yellow-500);font-size:1.1rem;margin-bottom:.6em;letter-spacing:.05em}
.review-badge{
  display:inline-flex;
  align-items:center;
  gap:.4em;
  background:var(--orange-50);
  color:var(--orange-700);
  font-weight:700;
  font-size:.78rem;
  text-transform:uppercase;
  letter-spacing:.06em;
  padding:.3em .7em;
  border-radius:var(--r-pill);
  margin-bottom:.8em;
  align-self:flex-start;
}
.review-badge::before{content:'✓';font-weight:900}
.review-quote{
  font-size:1rem;
  line-height:1.65;
  color:var(--ink-900);
  margin-bottom:1.2em;
  flex:1;
}
.review-author{
  display:flex;
  align-items:center;
  gap:.85em;
  padding-top:1em;
  border-top:1px solid var(--ink-100);
}
.review-avatar{
  width:48px;
  height:48px;
  border-radius:50%;
  background:var(--orange-100);
  display:grid;
  place-items:center;
  font-size:1.5rem;
  flex:0 0 auto;
  overflow:hidden;
}
.review-avatar img{width:100%;height:100%;object-fit:cover}
.review-name{font-weight:700;color:var(--ink-900);font-size:.98rem}
.review-loc{font-size:.85rem;color:var(--ink-500)}
@media (max-width:900px){.reviews-grid{grid-template-columns:1fr}}

/* ── WHAT-IS / 2-COL TEXT+IMAGE ───────────────────────────── */
.about-grid{
  display:grid;
  grid-template-columns:.85fr 1.15fr;
  gap:clamp(24px,4vw,56px);
  align-items:center;
}
.about-grid .about-image .placeholder,
.about-grid .about-image img{
  width:100%;
  max-width:480px;
  margin:0 auto;
  border-radius:var(--r-xl);
}
.about-grid .placeholder{
  aspect-ratio:4/3;
  background:var(--orange-50);
  border:2px dashed var(--orange-300);
  display:grid;
  place-items:center;
  color:var(--orange-700);
  font-size:.88rem;
  text-align:center;
  padding:2em;
}
.about-text p{
  font-size:1.05rem;
  line-height:1.75;
  color:var(--ink-700);
  margin-bottom:1.1em;
}
.about-text p strong{color:var(--ink-900)}
@media (max-width:900px){.about-grid{grid-template-columns:1fr}}

/* ── HOW-IT-WORKS LONGFORM ────────────────────────────────── */
.longform{max-width:980px;margin:0 auto}
.longform p{
  font-size:1.05rem;
  line-height:1.8;
  color:var(--ink-700);
  margin-bottom:1.2em;
}

/* ── PRICING GRID — HTML cards (replaces pricing-table.png) ── */
.pricing-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  max-width:1100px;
  margin:0 auto 24px;
  align-items:stretch;
}
.pricing-card{
  position:relative;
  background:#fff;
  border:1px solid var(--ink-100);
  border-radius:var(--r-lg);
  padding:0 22px 26px;
  display:flex;
  flex-direction:column;
  box-shadow:var(--shadow-sm);
  transition:transform .25s ease,box-shadow .25s ease;
  overflow:hidden;
}
.pricing-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-md);
}
.pricing-card--featured{
  border:2px solid var(--orange-600);
  box-shadow:var(--shadow-lg);
  background:linear-gradient(180deg,#FFF6E0 0%,#FFFEF7 65%);
  z-index:2;
}
@media (min-width:881px){
  .pricing-card--featured{transform:scale(1.04)}
  .pricing-card--featured:hover{transform:scale(1.04) translateY(-4px)}
}
/* legacy fallback variant */
.pricing-card--bestvalue{
  border:2px solid var(--green);
  box-shadow:var(--shadow-md);
  background:linear-gradient(180deg,#F0FBF4 0%,#fff 60%);
}

/* Tier label (BASIC / BUNDLE / MOST POPULAR) — top of card */
.pricing-tier-label{
  background:#E5E7EB;
  color:var(--ink-700);
  text-align:center;
  padding:10px 14px;
  margin:0 -22px 14px;
  font-size:.78rem;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  line-height:1;
}
.pricing-tier-label--popular{
  background:linear-gradient(90deg,#E8590C 0%,var(--orange-600) 100%);
  color:#fff;
  font-size:.86rem;
  letter-spacing:.10em;
  padding:12px 14px;
  margin-bottom:16px;
  box-shadow:0 2px 6px rgba(196,75,26,.25);
}

/* Product image at top of card */
.pricing-product-img-link{
  display:block;
  text-align:center;
  margin:0 0 8px;
  padding:8px 0;
  border-radius:8px;
  transition:transform .25s ease;
}
.pricing-product-img-link:hover{transform:scale(1.03)}
.pricing-product-img{
  display:inline-block;
  max-height:170px;
  width:auto;
  max-width:100%;
  margin:0 auto;
  object-fit:contain;
  mix-blend-mode:multiply;
}

/* Legacy badge (kept for backward compat — currently unused in pricing cards) */
.pricing-badge{
  position:absolute;
  top:-12px;
  left:50%;
  transform:translateX(-50%);
  background:var(--orange-600);
  color:#fff;
  padding:5px 16px;
  border-radius:var(--r-pill);
  font-size:.75rem;
  font-weight:700;
  letter-spacing:.04em;
  white-space:nowrap;
  box-shadow:var(--shadow-sm);
}
.pricing-badge--best{background:var(--green)}
.pricing-pack-name{
  font-size:1.45rem;
  color:var(--ink-900);
  margin:4px 0 2px;
  text-align:center;
}
.pricing-duration{
  text-align:center;
  font-size:.86rem;
  color:var(--ink-500);
  margin:0 0 14px;
  font-weight:500;
}
.pricing-price{
  text-align:center;
  margin:0 0 8px;
  display:flex;
  align-items:baseline;
  justify-content:center;
  gap:2px;
  line-height:1;
}
.pricing-currency{
  font-size:1.4rem;
  color:var(--orange-700);
  font-weight:700;
}
.pricing-amount{
  font-size:3.4rem;
  font-weight:800;
  color:var(--orange-700);
  letter-spacing:-.02em;
}
.pricing-card--bestvalue .pricing-currency,
.pricing-card--bestvalue .pricing-amount{color:var(--green-d)}
.pricing-per{
  font-size:.92rem;
  color:var(--ink-500);
  font-weight:500;
}
.pricing-total{
  text-align:center;
  font-size:.92rem;
  color:var(--ink-700);
  margin:0 0 8px;
  font-weight:500;
  display:flex;
  flex-wrap:wrap;
  align-items:baseline;
  justify-content:center;
  gap:6px 8px;
}
.pricing-total-strike{
  text-decoration:line-through;
  text-decoration-thickness:2px;
  color:var(--ink-300);
  font-weight:600;
}
.pricing-total-now{
  font-size:1.18rem;
  font-weight:800;
  color:var(--ink-900);
  letter-spacing:-.01em;
}
.pricing-total-ship{
  font-size:.82rem;
  color:var(--ink-500);
  font-weight:500;
  width:100%;
  text-align:center;
}
.pricing-savings{
  text-align:center;
  font-size:.88rem;
  color:#C44A4A;
  font-weight:700;
  margin:0 0 14px;
  background:#FFEEEE;
  padding:6px 10px;
  border-radius:var(--r-sm);
}
.pricing-savings--big{
  font-size:.92rem;
  background:#FFE7D2;
  color:#A8390F;
}
.pricing-features{
  list-style:none;
  padding:0;
  margin:0 0 18px;
  font-size:.9rem;
  color:var(--ink-700);
  line-height:1.5;
  flex:1;
}
.pricing-features li{
  padding:6px 0 6px 22px;
  position:relative;
  border-bottom:1px solid var(--ink-100);
}
.pricing-features li:last-child{border-bottom:0}
.pricing-features li::before{
  content:"✓";
  color:var(--green);
  font-weight:700;
  position:absolute;
  left:0;
}
.pricing-cta-btn{
  display:block;
  width:100%;
  text-align:center;
  margin-top:auto;
}
.pricing-trust-row{
  text-align:center;
  font-size:.86rem;
  color:var(--ink-500);
  margin:8px auto 0;
  max-width:780px;
  line-height:1.6;
}

@media (max-width:880px){
  .pricing-grid{
    grid-template-columns:1fr;
    gap:18px;
    max-width:520px;
  }
  .pricing-amount{font-size:3rem}
}

/* ── PRICING IMAGE BLOCKS (legacy — kept for fallback) ─────── */
.pricing-image{display:block;max-width:1100px;margin:0 auto}
.pricing-image img,
.pricing-image .placeholder{
  width:100%;
  border-radius:var(--r-lg);
  box-shadow:var(--shadow-md);
}
.pricing-image .placeholder{
  aspect-ratio:1341/864;
  background:linear-gradient(135deg,var(--orange-50),var(--cream));
  border:2px dashed var(--orange-300);
  display:grid;
  place-items:center;
  color:var(--orange-700);
  font-weight:600;
  text-align:center;
  padding:2em;
}
.pricing-image:hover img{box-shadow:var(--shadow-lg)}

/* Buying-intent CTA below each pricing image (keyword anchor text) */
.pricing-cta{
  text-align:center;
  margin-top:clamp(24px,3vw,40px);
}

/* ── INGREDIENTS LIST ─────────────────────────────────────── */
.ing-list{
  max-width:920px;
  margin:0 auto;
  display:flex;
  flex-direction:column;
  gap:24px;
}
.ing-item{
  display:flex;
  gap:24px;
  align-items:flex-start;
  background:#fff;
  border:1px solid var(--ink-100);
  border-radius:var(--r-lg);
  padding:24px;
  box-shadow:var(--shadow-sm);
}
.ing-step{
  flex:0 0 auto;
  width:64px;
  height:64px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--orange-600),var(--orange-500));
  color:#fff;
  display:grid;
  place-items:center;
  font-size:1.6rem;
  font-weight:800;
  box-shadow:0 8px 18px rgba(196,75,26,.3);
}
.ing-body h3{
  font-size:1.2rem;
  color:var(--orange-700);
  margin-bottom:.5em;
}
.ing-body p{
  font-size:1rem;
  line-height:1.7;
  color:var(--ink-700);
  margin:0;
}
@media (max-width:560px){
  .ing-item{flex-direction:column;align-items:center;text-align:center}
}

/* ── GUARANTEE BLOCK ──────────────────────────────────────── */
.guarantee{
  display:grid;
  grid-template-columns:.7fr 1.3fr;
  gap:clamp(20px,4vw,48px);
  align-items:center;
  background:linear-gradient(135deg,var(--orange-50),var(--cream));
  border-radius:var(--r-xl);
  padding:clamp(24px,4vw,48px);
  border:1px solid var(--orange-100);
}
.guarantee-image .placeholder,
.guarantee-image img{
  width:100%;
  max-width:280px;
  margin:0 auto;
}
.guarantee-image .placeholder{
  aspect-ratio:1/1;
  border-radius:50%;
  background:radial-gradient(circle,var(--yellow-300),var(--yellow-500));
  display:grid;
  place-items:center;
  color:var(--orange-900);
  text-align:center;
  font-weight:800;
  padding:1em;
  box-shadow:var(--shadow-md);
  font-size:.95rem;
}
.guarantee-image .placeholder::before{
  content:'🛡️';
  display:block;
  font-size:3rem;
  margin-bottom:.2em;
}
.guarantee-text h2{
  font-size:clamp(20px,2.4vw,28px);
  color:var(--orange-700);
  margin-bottom:.6em;
  line-height:1.25;
  letter-spacing:-.015em;
}
@media (min-width:900px){
  .guarantee-text h2{
    white-space:nowrap;
  }
}
.guarantee-text p{
  font-size:1.02rem;
  line-height:1.7;
  color:var(--ink-700);
}
@media (max-width:780px){.guarantee{grid-template-columns:1fr;text-align:center}}

/* ── BENEFITS LIST ────────────────────────────────────────── */
.benefit-list{
  max-width:840px;
  margin:0 auto;
  display:flex;
  flex-direction:column;
  gap:14px;
}
.benefit-list li{
  display:flex;
  gap:16px;
  align-items:flex-start;
  background:#fff;
  border:1px solid var(--ink-100);
  border-left:4px solid var(--orange-500);
  border-radius:var(--r-md);
  padding:18px 22px;
  font-size:1.05rem;
  line-height:1.6;
  color:var(--ink-700);
  box-shadow:var(--shadow-sm);
}
.benefit-list li::before{
  content:'✓';
  flex:0 0 auto;
  width:30px;
  height:30px;
  border-radius:50%;
  background:var(--orange-500);
  color:#fff;
  display:grid;
  place-items:center;
  font-weight:900;
  font-size:.95rem;
}
.benefit-list strong{color:var(--ink-900);font-weight:700}

/* ── STOCK WARNING ────────────────────────────────────────── */
.stock-warning{
  max-width:900px;
  margin:0 auto;
  padding:24px;
  background:linear-gradient(135deg,#fff4d6,#ffe7a8);
  border:2px solid var(--yellow-500);
  border-radius:var(--r-lg);
  text-align:center;
  font-size:1.05rem;
  color:var(--orange-900);
  font-weight:600;
  box-shadow:var(--shadow-sm);
}
.stock-warning strong{color:#a83a09;letter-spacing:.02em}

/* ── FAQ ──────────────────────────────────────────────────── */
.faq{max-width:880px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.faq details{
  background:#fff;
  border:1px solid var(--ink-100);
  border-radius:var(--r-md);
  box-shadow:var(--shadow-sm);
  overflow:hidden;
  transition:box-shadow .2s ease;
}
.faq details[open]{box-shadow:var(--shadow-md)}
.faq summary{
  cursor:pointer;
  list-style:none;
  padding:18px 24px;
  font-size:1.05rem;
  font-weight:600;
  color:var(--ink-900);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1em;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:'+';
  width:30px;
  height:30px;
  border-radius:50%;
  background:var(--orange-500);
  color:#fff;
  display:grid;
  place-items:center;
  font-weight:800;
  font-size:1.2rem;
  flex:0 0 auto;
  transition:transform .2s ease,background .2s ease;
}
.faq details[open] summary::after{
  content:'−';
  background:var(--orange-700);
  transform:rotate(180deg);
}
.faq-body{
  padding:0 24px 22px;
  font-size:1rem;
  line-height:1.7;
  color:var(--ink-700);
}

/* ── BONUS CARDS (multi-bottle free guides) ──────────────── */
.bonus-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:clamp(20px,3vw,32px);
  max-width:960px;
  margin:0 auto;
}
.bonus-card{
  background:#fff;
  border:2px solid var(--orange-100);
  border-radius:var(--r-lg);
  padding:clamp(24px,3vw,36px) clamp(20px,2.5vw,28px);
  text-align:center;
  box-shadow:var(--shadow-md);
  position:relative;
  transition:transform .2s ease,box-shadow .2s ease;
}
.bonus-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-lg);
}
.bonus-tag{
  display:inline-block;
  background:var(--orange-600);
  color:#fff;
  font-weight:800;
  letter-spacing:.06em;
  padding:.35em .85em;
  border-radius:var(--r-pill);
  font-size:.78rem;
  margin-bottom:1em;
}
/* Bonus ebook cover image — sits between the BONUS tag and the heading.
   Centered, max ~240px tall so it fits comfortably regardless of native size. */
.bonus-card .bonus-img{
  display:block;
  width:auto;
  max-width:80%;
  max-height:240px;
  height:auto;
  margin:.4em auto 1.2em;
  object-fit:contain;
  filter:drop-shadow(0 12px 24px rgba(196,75,26,.18));
}
.bonus-card h3{
  font-size:clamp(18px,2vw,22px);
  color:var(--orange-700);
  margin-bottom:.6em;
  line-height:1.25;
}
.bonus-card p{
  font-size:.97rem;
  color:var(--ink-700);
  line-height:1.65;
  margin:0 0 .8em;
}
.bonus-price{
  margin-top:1.2em !important;
  font-size:1.25rem;
  font-weight:600;
  color:var(--ink-500);
}
.bonus-price s{margin-right:.5em}
.bonus-price strong{
  color:var(--orange-600);
  font-weight:800;
  letter-spacing:.04em;
}
@media (max-width:680px){
  .bonus-grid{grid-template-columns:1fr}
}

/* ── WHO-SHOULD / PROS-CONS — two-column comparison layouts ── */
.who-grid,
.proscons-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:clamp(20px,3vw,32px);
  max-width:1080px;
  margin:0 auto;
}
.who-card,
.proscons-card{
  background:#fff;
  border-radius:var(--r-lg);
  padding:clamp(24px,3vw,36px);
  box-shadow:var(--shadow-md);
  border-top:5px solid;
}
.who-yes,.pros-card{border-top-color:#3D8B3D}
.who-no,.cons-card{border-top-color:var(--orange-600)}
.who-card h3,
.proscons-card h3{
  font-size:clamp(17px,1.8vw,21px);
  margin-bottom:1em;
  line-height:1.3;
  text-wrap:balance;
}
.who-yes h3,.pros-card h3{color:#2D6A2D}
.who-no h3,.cons-card h3{color:var(--orange-700)}
.who-card ul,
.proscons-card ul{
  list-style:none;
  padding:0;
  margin:0;
  display:flex;
  flex-direction:column;
  gap:.75em;
}
.who-card li,
.proscons-card li{
  position:relative;
  padding-left:1.7em;
  font-size:.97rem;
  line-height:1.6;
  color:var(--ink-700);
}
.who-yes li::before,
.pros-card li::before{
  content:'✓';
  position:absolute;
  left:0;
  top:0;
  color:#3D8B3D;
  font-weight:900;
  font-size:1.05em;
}
.who-no li::before,
.cons-card li::before{
  content:'✗';
  position:absolute;
  left:0;
  top:0;
  color:var(--orange-600);
  font-weight:900;
  font-size:1.05em;
}
@media (max-width:780px){
  .who-grid,.proscons-grid{grid-template-columns:1fr}
}

/* ── AUTHOR BYLINE / E-E-A-T BLOCK ─────────────────────────── */
.author-byline{
  display:flex;
  gap:24px;
  align-items:center;
  max-width:880px;
  margin:0 auto;
  background:#fff;
  border:1px solid var(--ink-100);
  border-radius:var(--r-lg);
  padding:24px 28px;
  box-shadow:var(--shadow-sm);
}
.author-photo{
  position:relative;
  flex:0 0 96px;
  width:96px;
  height:96px;
  border-radius:50%;
  overflow:hidden;
  background:linear-gradient(135deg,var(--orange-300),var(--orange-600));
  display:flex;
  align-items:center;
  justify-content:center;
  border:3px solid var(--orange-100);
}
.author-photo img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  position:absolute;
  inset:0;
  z-index:1;
}
.author-initials{
  font-size:2rem;
  font-weight:700;
  color:#fff;
  letter-spacing:.02em;
  z-index:0;
}
.author-photo.no-photo img{display:none}
.author-meta{flex:1;min-width:0}
.author-label{
  font-size:.78rem;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:var(--ink-500);
  margin:0 0 4px;
  font-weight:600;
}
.author-name{
  font-size:clamp(20px,2.4vw,26px);
  color:var(--ink-900);
  margin:0 0 4px;
  line-height:1.2;
}
.author-title{
  font-size:.95rem;
  color:var(--orange-700);
  font-weight:600;
  margin:0 0 10px;
}
.author-bio{
  font-size:.94rem;
  color:var(--ink-700);
  line-height:1.55;
  margin:0 0 10px;
}
.author-meta-row{
  font-size:.82rem;
  color:var(--ink-500);
  margin:0;
  display:flex;
  flex-wrap:wrap;
  gap:6px 12px;
  align-items:center;
}
.author-sep{color:var(--ink-300)}

@media (max-width:640px){
  .author-byline{
    flex-direction:column;
    text-align:center;
    padding:20px 18px;
    gap:14px;
  }
  .author-photo{flex:0 0 84px;width:84px;height:84px}
  .author-meta-row{justify-content:center}
}

/* ── EXPLORE MORE / RELATED ARTICLES (silo cards) ──────────── */
.more-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:20px;
  max-width:1100px;
  margin:0 auto;
}
.more-card{
  display:flex;
  flex-direction:column;
  padding:28px 24px;
  background:#fff;
  border:1px solid var(--ink-100);
  border-radius:var(--r-lg);
  text-decoration:none;
  color:inherit;
  transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;
  box-shadow:var(--shadow-sm);
  position:relative;
  overflow:hidden;
}
.more-card::before{
  content:"";
  position:absolute;
  top:0;left:0;right:0;
  height:4px;
  background:linear-gradient(90deg,var(--orange-400),var(--orange-600));
  opacity:0;
  transition:opacity .25s ease;
}
.more-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-md);
  border-color:var(--orange-600);
}
.more-card:hover::before{opacity:1}
.more-card-icon{
  font-size:2.4rem;
  line-height:1;
  margin-bottom:14px;
}
.more-card-title{
  font-size:1.18rem;
  color:var(--ink-900);
  margin:0 0 10px;
  line-height:1.3;
  font-weight:700;
  letter-spacing:-.005em;
}
.more-card-desc{
  font-size:.94rem;
  color:var(--ink-700);
  line-height:1.6;
  margin:0 0 18px;
  flex:1;
}
.more-card-cta{
  display:inline-block;
  font-size:.92rem;
  color:var(--orange-700);
  font-weight:700;
  letter-spacing:.01em;
}
.more-card:hover .more-card-cta{color:var(--orange-900)}
.more-card-cta span{
  display:inline-block;
  transition:transform .2s ease;
}
.more-card:hover .more-card-cta span{transform:translateX(3px)}

@media (max-width:640px){
  .more-grid{grid-template-columns:1fr;gap:14px}
  .more-card{padding:22px 20px}
  .more-card-icon{font-size:2rem;margin-bottom:10px}
}

/* ── COMPARISON TABLE — CitrusBurn vs alternatives ─────────── */
.compare-wrap{
  max-width:1100px;
  margin:0 auto;
}

/* Desktop / tablet table */
.compare-table{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  background:#fff;
  border-radius:var(--r-lg);
  overflow:hidden;
  box-shadow:var(--shadow-md);
  font-size:.95rem;
  text-align:left;
}
.compare-table th,
.compare-table td{
  padding:14px 12px;
  border-bottom:1px solid var(--ink-100);
  vertical-align:top;
  line-height:1.4;
}
.compare-table thead th{
  background:var(--ink-900);
  color:#fff;
  font-weight:700;
  font-size:.96rem;
  text-align:center;
  border-bottom:0;
  vertical-align:middle;
}
.compare-table thead th.compare-th-label{
  background:var(--ink-700);
  text-align:left;
}
.compare-table thead th.compare-th--winner{
  background:var(--orange-600);
  position:relative;
}
.compare-winner-tag{
  display:block;
  font-size:.72rem;
  font-weight:600;
  margin-top:4px;
  letter-spacing:.02em;
  opacity:.95;
}
.compare-table tbody th{
  font-weight:600;
  color:var(--ink-900);
  background:var(--cream);
  width:22%;
}
.compare-table tbody td{
  text-align:center;
  color:var(--ink-700);
}
.compare-table tbody td.compare-td--winner{
  background:#FFF6EB;
  color:var(--ink-900);
  font-weight:600;
  border-left:2px solid var(--orange-600);
  border-right:2px solid var(--orange-600);
}
.compare-table tbody tr:last-child td.compare-td--winner{
  border-bottom:2px solid var(--orange-600);
}
.compare-table tbody tr:last-child th,
.compare-table tbody tr:last-child td{
  border-bottom:0;
}
.compare-yes{color:var(--green);font-weight:700;font-size:1.08em;margin-right:2px}
.compare-no{color:#C44A4A;font-weight:700;font-size:1.08em;margin-right:2px}
.compare-na{color:var(--ink-500);font-weight:700;font-size:1.08em;margin-right:2px}

/* Mobile cards (hidden by default) */
.compare-mobile{display:none}

/* Disclaimer */
.compare-disclaimer{
  margin-top:1.4em;
  font-size:.86rem;
  color:var(--ink-500);
  text-align:center;
  line-height:1.5;
  max-width:780px;
  margin-left:auto;
  margin-right:auto;
}

/* Tablet narrow: keep table but smaller */
@media (max-width:880px) and (min-width:641px){
  .compare-table{font-size:.86rem}
  .compare-table th,
  .compare-table td{padding:10px 8px}
  .compare-winner-tag{font-size:.66rem}
}

/* Mobile (<640px): stacked cards, no horizontal scroll */
@media (max-width:640px){
  .compare-table{display:none}
  .compare-mobile{
    display:grid;
    gap:16px;
  }
  .compare-card{
    background:#fff;
    border-radius:var(--r-lg);
    box-shadow:var(--shadow-sm);
    padding:18px 16px;
    border:1px solid var(--ink-100);
  }
  .compare-card--winner{
    background:linear-gradient(180deg,#FFF6EB 0%,#fff 60%);
    border:2px solid var(--orange-600);
    box-shadow:var(--shadow-md);
  }
  .compare-card-title{
    font-size:1.15rem;
    color:var(--ink-900);
    margin:0 0 12px;
    padding-bottom:10px;
    border-bottom:1px solid var(--ink-100);
  }
  .compare-card--winner .compare-card-title{
    color:var(--orange-700);
    border-bottom-color:var(--orange-300);
  }
  .compare-card .compare-winner-tag{
    color:var(--orange-700);
    font-size:.74rem;
    margin-top:3px;
    font-weight:600;
  }
  .compare-card-list{margin:0;padding:0}
  .compare-card-list > div{
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
    gap:12px;
    padding:8px 0;
    border-bottom:1px dashed var(--ink-100);
    font-size:.93rem;
  }
  .compare-card-list > div:last-child{border-bottom:0}
  .compare-card-list dt{
    color:var(--ink-500);
    font-weight:500;
    flex:0 0 45%;
  }
  .compare-card-list dd{
    margin:0;
    color:var(--ink-900);
    font-weight:600;
    text-align:right;
    flex:1;
  }
}

/* ── LONGFORM SUB-HEADINGS (used in new content sections) ── */
.longform h3{
  color:var(--orange-700);
  font-size:clamp(18px,2vw,22px);
  margin:1.6em 0 .6em;
  line-height:1.3;
}
.longform .callout-note{
  margin-top:1.8em;
  padding:1.2em 1.4em;
  background:var(--orange-50);
  border-left:4px solid var(--orange-300);
  border-radius:8px;
  font-size:.96rem;
  line-height:1.65;
}
.how-link-row{
  margin-top:2em;
  padding:1em 1.2em;
  background:var(--cream);
  border-radius:var(--r-md);
  font-size:.94rem;
  line-height:1.6;
  color:var(--ink-700);
}
.how-link-row a{
  color:var(--orange-700);
  font-weight:600;
  border-bottom:1px solid var(--orange-300);
}
.how-link-row a:hover{color:var(--orange-900);border-bottom-color:var(--orange-700)}

/* ── BUY-INFO BULLETS ─────────────────────────────────────── */
.buy-info{
  max-width:920px;
  margin:0 auto;
  display:flex;
  flex-direction:column;
  gap:14px;
}
.buy-info li{
  background:#fff;
  border-radius:var(--r-md);
  padding:18px 22px;
  font-size:1rem;
  line-height:1.65;
  border-left:4px solid var(--yellow-500);
  box-shadow:var(--shadow-sm);
  color:var(--ink-700);
}
.buy-info li strong{color:var(--orange-700);font-weight:700}

/* ── FINAL CTA CARD ───────────────────────────────────────── */
.final-cta{
  max-width:760px;
  margin:0 auto;
  background:#fff;
  border-radius:var(--r-xl);
  padding:clamp(28px,5vw,48px);
  text-align:center;
  box-shadow:var(--shadow-lg);
  border:2px solid var(--orange-100);
}
.final-cta .strike{
  font-size:1.1rem;
  color:var(--ink-500);
  text-decoration:line-through;
  margin-bottom:.3em;
}
.final-cta .price{
  font-size:clamp(36px,5vw,56px);
  color:var(--orange-700);
  font-weight:800;
  margin-bottom:.4em;
  letter-spacing:-.01em;
}
.final-cta .price small{font-size:.55em;color:var(--ink-500);font-weight:600}
.final-cta .save{
  display:inline-block;
  background:var(--yellow-500);
  color:var(--orange-900);
  font-weight:800;
  padding:.4em 1em;
  border-radius:var(--r-pill);
  margin-bottom:1.2em;
  font-size:.95rem;
  letter-spacing:.04em;
}

/* ── FOOTER ───────────────────────────────────────────────── */
.site-footer{
  background:#1a0d05;
  color:#cfc6bd;
  padding-block:48px 28px;
  font-size:.92rem;
  line-height:1.7;
}
.site-footer a{color:#fff;text-decoration:underline;text-underline-offset:3px}
.site-footer p{margin-bottom:1em}
.footer-disclaimer{
  max-width:980px;
  margin:0 auto 1.5em;
  font-size:.85rem;
  color:#a59c93;
}
.footer-meta{
  border-top:1px solid #3a2c20;
  padding-top:1.2em;
  text-align:center;
  font-size:.85rem;
  color:#a59c93;
}
.footer-links{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:.4em 1.2em;
  margin-bottom:.8em;
}

/* ── STICKY BOTTOM CTA ────────────────────────────────────── */
.sticky-bottom-cta{
  position:fixed;
  bottom:0;
  left:0;
  right:0;
  z-index:997;
  background:#EFF7FF;
  color:var(--ink-900);
  padding:12px 16px;
  border-top:1px solid rgba(13,27,42,.08);
  box-shadow:0 -8px 24px rgba(13,27,42,.1);
  transform:translateY(100%);
  visibility:hidden;
  transition:transform .35s cubic-bezier(.22,1,.36,1),visibility .35s ease;
}
.sticky-bottom-cta.visible{
  transform:translateY(0);
  visibility:visible;
}
.sticky-cta-inner{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:1.2em;
  max-width:var(--container);
  margin:0 auto;
  flex-wrap:wrap;
}
.sticky-cta-text{
  margin:0;
  display:inline-flex;
  flex-wrap:wrap;             /* lets LIVE badge + text wrap if too narrow */
  align-items:center;
  justify-content:center;
  gap:.6em .75em;
  font-size:.96rem;
  color:var(--ink-900);
  font-weight:500;
  line-height:1.25;
  max-width:100%;
}
.sticky-cta-text strong{
  color:var(--orange-700);   /* discount stands out in brand orange */
  font-weight:800;
  font-size:1.08em;
  letter-spacing:.01em;
}
.sticky-live-badge{
  display:inline-flex;
  align-items:center;
  gap:.4em;
  background:var(--ink-900);
  border:0;
  padding:.32em .75em;
  border-radius:var(--r-pill);
  font-size:.7rem;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:#fff;
}
.sticky-live-dot{
  display:inline-block;
  width:8px;
  height:8px;
  border-radius:50%;
  background:#FF3B30;
  box-shadow:0 0 0 0 rgba(255,59,48,.7);
  animation:sticky-pulse 1.4s ease-in-out infinite;
}
@keyframes sticky-pulse{
  0%,100%{box-shadow:0 0 0 0 rgba(255,59,48,.7)}
  50%{box-shadow:0 0 0 7px rgba(255,59,48,0)}
}
.sticky-cta-btn{
  display:inline-flex;
  align-items:center;
  gap:.4em;
  background:var(--green);
  color:#fff;
  font-weight:700;
  padding:.65em 1.3em;
  border-radius:var(--r-pill);
  letter-spacing:.02em;
  white-space:nowrap;
  box-shadow:0 4px 14px rgba(0,168,54,.35);
  transition:transform .18s ease,background .18s ease,box-shadow .18s ease;
}
.sticky-cta-btn:hover,
.sticky-cta-btn:focus-visible{
  background:var(--green-d);
  color:#fff;
  transform:translateY(-1px);
  box-shadow:0 6px 18px rgba(0,168,54,.5);
}
.sticky-cta-close{
  background:transparent;
  border:0;
  color:rgba(13,27,42,.55);
  font-size:1.15rem;
  cursor:pointer;
  padding:.3em .55em;
  line-height:1;
  border-radius:var(--r-sm);
  transition:color .18s ease,background .18s ease;
}
.sticky-cta-close:hover,
.sticky-cta-close:focus-visible{
  color:var(--ink-900);
  background:rgba(13,27,42,.08);
}

/* When sticky CTA is visible, push the scroll-top button up so they
   don't overlap on the bottom-right corner. */
body.has-sticky-cta .scroll-top.visible{
  bottom:90px;
}

@media (max-width:560px){
  .sticky-bottom-cta{padding:10px 12px}
  .sticky-cta-inner{gap:.7em}
  .sticky-cta-text{font-size:.85rem;gap:.5em}
  .sticky-live-badge{font-size:.62rem;padding:.22em .55em}
  .sticky-live-dot{width:7px;height:7px}
  .sticky-cta-btn{font-size:.85rem;padding:.55em 1.05em}
  .sticky-cta-close{font-size:1rem;padding:.25em .45em}
  body.has-sticky-cta .scroll-top.visible{bottom:78px}
}

/* ── SCROLL-TO-TOP BUTTON ─────────────────────────────────── */
.scroll-top{
  position:fixed;
  bottom:24px;
  right:20px;
  z-index:998;
  width:48px;
  height:48px;
  border-radius:50%;
  background:var(--green);
  color:#fff;
  border:0;
  cursor:pointer;
  box-shadow:0 6px 18px rgba(0,168,54,.35);
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:0;
  visibility:hidden;
  transform:translateY(10px);
  transition:opacity .3s ease,transform .3s ease,visibility .3s ease,background .2s ease;
}
.scroll-top.visible{
  opacity:1;
  visibility:visible;
  transform:translateY(0);
}
.scroll-top:hover,
.scroll-top:focus-visible{
  background:var(--green-d);
  transform:translateY(-3px);
  box-shadow:0 10px 24px rgba(0,168,54,.45);
}
.scroll-top svg{
  width:22px;
  height:22px;
  display:block;
}
@media (max-width:560px){
  .scroll-top{bottom:18px;right:14px;width:44px;height:44px}
  .scroll-top svg{width:20px;height:20px}
}

/* ── REVEAL ANIMATION (lightweight) ───────────────────────── */
.reveal{
  opacity:0;
  transform:translateY(18px);
  transition:opacity .7s ease,transform .7s ease;
  will-change:opacity,transform;
}
.reveal.visible,
.reveal.is-visible{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none}
  *{scroll-behavior:auto !important;animation:none !important;transition:none !important}
}

/* ── SCREEN-READER UTIL ───────────────────────────────────── */
.sr-only{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0;
}

/* ── FOCUS RING ───────────────────────────────────────────── */
:focus-visible{outline:3px solid var(--yellow-500);outline-offset:3px;border-radius:6px}
