/* ===================== Hong Thai — premium stylesheet ===================== */
:root{
  /* Strict palette: 1 dark green · 1 light green · 1 yellow · white */
  --green:#1f4a3a;       /* primary dark green: all dark sections, footer, buttons, tags */
  --green-deep:#1f4a3a;  /* alias of --green */
  --green-soft:#e9efe6;  /* the single light green: tinted panels */
  --sage:#e9efe6;        /* alias of --green-soft */
  --gold:#FBC63E;        /* the single yellow accent (= --yellow) */
  --gold-soft:#FBE9B0;   /* soft yellow tint */
  --cream:#ffffff;       /* white */
  --bg:#ffffff;          /* white background */
  --ink:#23241d;
  --muted:#1c1c1c;
  --muted2:#1c1c1c;
  --line:#e2ddd0;
  --red:#a39e95;
  --yellow:#FBC63E;
  --yellow-deep:#F0B72A;
  --serif:'Poppins',system-ui,-apple-system,sans-serif;
  --sans:'Poppins',system-ui,-apple-system,sans-serif;
  /* --- design tokens (one system) --- */
  --radius:12px;
  --radius-sm:8px;
  --shadow:none;
  --shadow-lg:0 6px 24px rgba(31,74,58,.07);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:clip}
body{font-family:var(--sans);color:var(--ink);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:clip;max-width:100%}
/* Display headings (Poppins ExtraBold) */
.logo,.title,.hero h1,.hb-title,.hb-em-top,.hb-em-bot,.split h2,.pdp-info h1,.bc-head h2,
.trans-head h2,.tband h2,.guar-title,.guar-eyebrow,.footer-col h4,.footer-news h4,
.leave-out h3,.bcard-name,.bundle h3,.now,.bcard-now,.priceline b,.step .nr,.hs-num,
.tl-marker,.stat .num,.revdist .score .big,.rating-summary .big,.prob-foot,.legal h1,.legal h2{
  font-optical-sizing:auto;font-family:var(--serif)}
img{max-width:100%;display:block}
a{color:inherit}
.wrap{max-width:1240px;margin:0 auto;padding:0 22px}

.btn{display:inline-block;background:var(--green);color:#fff;border:none;font-family:var(--sans);
  font-size:1rem;font-weight:700;padding:15px 34px;border-radius:10px;cursor:pointer;text-decoration:none;
  transition:.2s;letter-spacing:.2px;box-shadow:0 1px 2px rgba(31,74,58,.12);white-space:nowrap}
.btn:hover{background:var(--green-deep);transform:translateY(-1px);box-shadow:0 4px 12px rgba(31,74,58,.18)}
.btn-gold{background:var(--yellow);color:#1a1a14;box-shadow:0 1px 2px rgba(176,130,20,.22)}
.btn-gold:hover{background:var(--yellow-deep);color:#1a1a14}
.btn--sm{padding:11px 22px;font-size:.92rem}
.stars{color:var(--gold);letter-spacing:2px}
.icon{width:20px;height:20px;display:inline-block;vertical-align:-4px;fill:none;stroke:currentColor;
  stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.icon-sm{width:15px;height:15px;vertical-align:-2px}
.icon-lg{width:30px;height:30px}
.icon-seal{width:56px;height:56px;stroke-width:1.4}
.icon--fill{fill:currentColor;stroke:none}
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ---- Countdown deal bar ---- */
.deal{background:var(--green-deep);color:#fff;text-align:center;padding:10px 14px;font-size:.92rem;font-weight:500;letter-spacing:.2px}
.deal b{color:#f1d9a8;font-weight:700;font-variant-numeric:tabular-nums}
.deal .cd-box{display:inline-block;min-width:25px;text-align:center;background:rgba(255,255,255,.15);
  border:1px solid rgba(255,255,255,.22);border-radius:6px;padding:2px 6px;margin:0 1px;color:#fff;
  font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:.5px}
.deal .cd-sep{color:#f1d9a8;font-weight:700;margin:0 2px}

/* ---- Moving marquee ---- */
.marquee{background:var(--cream);border-bottom:1px solid var(--line);overflow:hidden;white-space:nowrap;padding:9px 0}
.marquee .track{display:inline-block;animation:scroll 28s linear infinite}
.marquee span{margin:0 14px;font-size:.82rem;font-weight:600;color:var(--green);letter-spacing:.6px;text-transform:uppercase}
.marquee .dot{color:var(--gold);margin:0 2px}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---- Trust marquee bar (dark green moving strip) ---- */
.trust-bar{background:var(--green);overflow:hidden;white-space:nowrap;padding:16px 0}
.tb-track{display:flex;align-items:center;width:max-content;animation:tb-scroll 34s linear infinite;will-change:transform}
.trust-bar:hover .tb-track{animation-play-state:paused}
.tb-item{display:inline-flex;align-items:center;gap:9px;margin:0 27px;color:#fff;font-size:.82rem;font-weight:700;letter-spacing:1.3px;text-transform:uppercase;line-height:1;white-space:nowrap}
.tb-ic{color:var(--yellow);width:18px;height:18px;flex:none;vertical-align:0}
@keyframes tb-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(max-width:560px){
  .trust-bar{padding:13px 0}
  .tb-item{font-size:.75rem;letter-spacing:1px;margin:0 18px;gap:7px}
  .tb-ic{width:16px;height:16px}
}
@media(prefers-reduced-motion:reduce){.tb-track{animation:none}}

/* ---- Header ---- */
header{background:rgba(255,255,255,.9);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:60}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:15px 22px;max-width:1240px;margin:0 auto}
.logo{font-family:var(--serif);font-size:1.55rem;font-weight:700;color:var(--green);letter-spacing:-.4px;text-decoration:none}
.logo span{color:var(--gold)}
.nav{display:flex;gap:22px;align-items:center}
.nav a.link{text-decoration:none;font-size:.92rem;font-weight:500;color:var(--ink);opacity:.8}
.nav a.link:hover{opacity:1;color:var(--green)}
.ccy{font-family:var(--sans);font-size:.86rem;font-weight:600;color:var(--ink);background:#fff;
  border:1px solid var(--line);border-radius:7px;padding:8px 10px;cursor:pointer}
@media(max-width:720px){.nav .link{display:none}}

/* ---- Hero ---- */
.hero{display:grid;grid-template-columns:1.05fr 1fr;gap:54px;align-items:center;padding:64px 0}
.eyebrow{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:1.8px;text-transform:uppercase;
  color:var(--green);margin-bottom:14px}
.hero h1{font-family:var(--serif);font-size:3rem;line-height:1.06;color:var(--green);font-weight:700;margin-bottom:18px;letter-spacing:-1.4px}
.hero p.sub{font-size:1.16rem;color:var(--muted);margin-bottom:22px;max-width:42ch}
.hero ul{list-style:none;margin:22px 0}
.hero li{padding:5px 0 5px 30px;position:relative;font-weight:500}
.hero li::before{content:"✓";position:absolute;left:0;color:var(--gold);font-weight:700}
.priceline{margin:24px 0 10px;font-size:1.05rem;color:var(--muted)}
.priceline b{font-size:1.6rem;color:var(--green);font-family:var(--serif)}
.priceline .was{text-decoration:line-through;margin-left:6px;font-size:1rem}
.cta-row{display:flex;gap:14px;align-items:center;flex-wrap:wrap;margin-top:10px}
.cta-note{color:var(--muted);font-size:.9rem}
.cta-note .icon{color:var(--green);vertical-align:-2px}
.reviewline{display:flex;align-items:center;gap:10px;margin-bottom:6px;font-size:.95rem;color:var(--muted)}
.reviewline .stars{font-size:1.1rem}
.hero-photo{aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(ellipse at center,rgba(251,198,62,.14),transparent 66%)}
.hero-photo img{filter:drop-shadow(0 26px 40px rgba(31,74,58,.24));max-height:94%;width:auto}
@media(max-width:820px){.hero{grid-template-columns:1fr;gap:24px;padding:34px 0;text-align:center}
  .hero h1{font-size:2.2rem}.hero p.sub{margin-left:auto;margin-right:auto}.hero ul{display:inline-block;text-align:left}
  .cta-row,.reviewline{justify-content:center}}
@media(min-width:1100px){.hero{gap:64px;padding:78px 0}.hero h1{font-size:3.5rem}}

/* ---- Hero banner (Herbies-style, full-bleed blue) ---- */
.hero-banner{background:linear-gradient(180deg, #3c6da8 0%, #4f7cb4 42%, #6a9aca 100%);color:#fff;text-align:center;padding:48px 26px 56px;overflow:hidden}
.hb-inner{max-width:640px;margin:0 auto;display:flex;flex-direction:column;align-items:center}
.hb-emblem{width:196px;max-width:58%;margin:2px auto 20px}
.hb-emblem svg{width:100%;height:auto}
.hb-em-top,.hb-em-bot{font-family:var(--serif);fill:#fff;font-weight:700;font-size:17px}
.hb-title{font-family:var(--serif);font-weight:700;color:#fff;font-size:2.6rem;line-height:1.06;letter-spacing:-.8px;margin:0}
.hb-title em{display:block;font-style:italic;color:var(--yellow);font-weight:700}
.hb-photo{margin:22px auto 20px;width:100%;max-width:272px}
.hb-photo img{width:auto;max-width:100%;max-height:200px;filter:drop-shadow(0 20px 30px rgba(18,38,68,.4))}
.hb-sub{font-size:1.18rem;line-height:1.58;color:rgba(255,255,255,.94);max-width:33ch;margin:0 auto 20px}
.hb-rating{display:flex;align-items:center;justify-content:center;gap:11px;font-size:1.02rem;color:rgba(255,255,255,.95);margin-bottom:22px}
.hb-rating .hb-stars{color:var(--yellow);font-size:1.18rem;letter-spacing:2px}
.hb-rating b{font-weight:700}
.hb-cta{display:block;width:100%;max-width:560px;margin:0 auto;background:var(--green-deep);color:#fff;font-weight:700;text-decoration:none;text-transform:uppercase;letter-spacing:1.6px;font-size:1.02rem;padding:20px 24px;border-radius:10px;box-shadow:0 14px 30px rgba(18,38,68,.26);transition:transform .15s ease,box-shadow .15s ease}
.hb-cta:hover{transform:translateY(-2px);box-shadow:0 18px 36px rgba(18,38,68,.38)}
.hb-cta.ghost{background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.42);color:#fff;box-shadow:none;backdrop-filter:blur(4px);margin-top:11px}
.hb-cta.ghost:hover{background:rgba(255,255,255,.26);transform:translateY(-2px);box-shadow:none}
.hb-checks{list-style:none;margin:24px 0 2px;padding:0;display:flex;flex-direction:column;align-items:center;gap:11px}
.hb-checks li{display:flex;align-items:center;gap:10px;font-size:.82rem;font-weight:700;letter-spacing:1.4px;text-transform:uppercase;color:rgba(255,255,255,.84)}
.hb-checks li::before{content:"✓";color:var(--yellow);font-weight:700;font-size:1.02rem}
@media(min-width:721px){
  .hero-banner{padding:56px 26px 60px}
  .hb-title{font-size:3.05rem}
  .hb-photo{max-width:288px;margin:24px auto 22px}
  .hb-photo img{max-height:220px}
  .hb-checks{margin-top:28px;gap:12px}
}
@media(max-width:560px){
  .hero-banner{padding:34px 22px 40px}
  .hb-title{font-size:2.2rem;letter-spacing:-.6px}
  .hb-sub{font-size:1.04rem;margin-bottom:18px}
  .hb-emblem{width:178px;margin-bottom:18px}
  .hb-photo{max-width:228px;margin:18px auto 18px}
  .hb-photo img{max-height:176px}
  .hb-rating{margin-bottom:20px}
  .hb-cta{font-size:.95rem;padding:18px 20px;letter-spacing:1.3px}
  .hb-checks{margin-top:22px;gap:10px}
  .hb-checks li{font-size:.76rem;letter-spacing:1.1px}
}

/* ---- Trust strip ---- */
.trust{background:var(--green);color:#fff;padding:24px 0}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center}
.trust-grid div b{display:block;font-size:1.02rem}
.trust-grid small{opacity:.82}
@media(max-width:720px){.trust-grid{grid-template-columns:repeat(2,1fr);gap:22px}}

/* ---- Sections ---- */
section.block{padding-top:88px;padding-bottom:88px}
.title{text-align:center;font-family:var(--serif);font-size:1.72rem;color:var(--green);font-weight:700;margin-bottom:14px;letter-spacing:-.4px;line-height:1.12}
.subtitle{text-align:center;color:var(--muted2);max-width:560px;margin:0 auto 46px;font-size:.85rem;line-height:1.65;font-weight:400}

/* ---- Benefits ---- */
.benefits{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.benefit{background:transparent;border:none;border-radius:var(--radius);padding:18px 14px;text-align:center;transition:.25s}
.benefit:hover{transform:none}
.benefit .ico{color:var(--gold);margin-bottom:12px;line-height:1}
.benefit h3{color:var(--green);font-size:1.06rem;margin-bottom:6px}
.benefit p{font-size:.92rem;color:var(--muted)}
@media(max-width:720px){.benefits{grid-template-columns:1fr 1fr}}

/* ---- Steps ---- */
/* ---- How it works (dark-green, photo step bars) ---- */
.how{background:var(--green)}
.how .title{color:#fff}
.how .subtitle{color:rgba(255,255,255,.86)}
.how-steps{max-width:660px;margin:0 auto;display:flex;flex-direction:column;align-items:center}
.how-step{width:100%;display:flex;align-items:center;gap:20px;background:rgba(255,255,255,.05);border:none;border-radius:var(--radius);padding:18px 20px}
.hs-num{flex:none;width:46px;height:46px;border-radius:50%;background:var(--yellow);color:var(--green-deep);font-family:var(--serif);font-weight:700;font-size:1.2rem;display:flex;align-items:center;justify-content:center}
.hs-body{flex:1;min-width:0}
.hs-body h3{color:#fff;font-size:1.18rem;margin-bottom:4px}
.hs-body p{color:rgba(255,255,255,.78);font-size:.95rem;line-height:1.5}
.hs-photo{flex:none;width:104px;height:104px;border-radius:14px;overflow:hidden;border:2px solid rgba(255,255,255,.18)}
.hs-photo img{width:100%;height:100%;object-fit:cover}
.how-arrow{display:flex;justify-content:center;color:var(--yellow);padding:9px 0}
.how-arrow svg{width:26px;height:26px}
@media(max-width:560px){
  .how-step{gap:13px;padding:14px}
  .hs-num{width:40px;height:40px;font-size:1.05rem}
  .hs-body h3{font-size:1.04rem}
  .hs-body p{font-size:.88rem}
  .hs-photo{width:82px;height:82px}
  .how-arrow{padding:7px 0}
  .how-arrow svg{width:22px;height:22px}
}

.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.step{background:transparent;border:none;border-radius:var(--radius);padding:24px 20px;text-align:center}
.step .nr{width:48px;height:48px;border-radius:50%;background:var(--green);color:#fff;font-weight:700;font-family:var(--serif);
  display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-size:1.25rem}
.step h3{color:var(--green);margin-bottom:8px}
.step p{color:var(--muted)}
@media(max-width:720px){.steps{grid-template-columns:1fr}}

/* ---- Story / split ---- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:52px;align-items:center}
.split .photo-box{background:radial-gradient(ellipse at center,rgba(251,198,62,.12),transparent 68%);
  aspect-ratio:1/1;display:flex;align-items:center;justify-content:center}
.split .photo-box img{max-height:92%;width:auto;filter:drop-shadow(0 22px 32px rgba(31,74,58,.20))}
.split h2{font-family:var(--serif);color:var(--green);font-size:1.72rem;font-weight:700;letter-spacing:-.4px;margin-bottom:16px;line-height:1.15}
.split p{color:var(--muted);margin-bottom:14px}
.split .btn{margin-top:8px}
@media(max-width:820px){.split{grid-template-columns:1fr;gap:24px}}

/* ---- Comparison ---- */
.compare{max-width:760px;margin:0 auto;background:transparent;border:none;border-radius:var(--radius);overflow:hidden}
.compare table{width:100%;border-collapse:collapse}
.compare th,.compare td{padding:16px 18px;text-align:left;border-bottom:1px solid var(--line)}
.compare thead th{background:var(--green);color:#fff;font-weight:600;font-size:.95rem;text-align:center}
.compare thead th:first-child{text-align:left;background:var(--green-deep)}
.compare tbody td{text-align:center;font-weight:700}
.compare tbody td:first-child{text-align:left;font-weight:500;color:var(--ink)}
.compare .yes{color:var(--green)}
.compare .no{color:var(--red)}
.compare tr:last-child td{border-bottom:none}
.compare .us{background:var(--green-soft)}

/* ---- Bundles ---- */
.bundles{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;align-items:stretch}
.bundle{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:34px 22px 30px;text-align:center;position:relative;display:flex;flex-direction:column;box-shadow:var(--shadow)}
.bundle.popular{border:2px solid var(--gold);box-shadow:var(--shadow-lg)}
.badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--gold);color:#1a1a14;
  font-size:.72rem;font-weight:700;letter-spacing:.5px;padding:5px 15px;border-radius:50px;white-space:nowrap}
.badge.alt{background:var(--gold)}
.secure-note{text-align:center;margin-top:22px;color:var(--muted);font-size:.9rem}
.secure-note .icon{vertical-align:-2px}
.bundle h3{color:var(--green);font-size:1.3rem;font-weight:700;margin-bottom:8px;font-family:var(--serif)}
.was{color:var(--muted);text-decoration:line-through;font-size:.95rem}
.now{font-size:1.9rem;font-weight:700;color:var(--green);margin:2px 0;font-family:var(--serif);letter-spacing:-.5px}
.each{font-size:.85rem;color:var(--muted);margin-bottom:18px}
.bundle .btn{margin-top:auto;width:100%;padding:14px 0;font-size:1rem}
@media(max-width:720px){.bundles{grid-template-columns:1fr 1fr;gap:14px}}

/* ---- Reviews ---- */
.rating-summary{display:flex;align-items:center;justify-content:center;gap:14px;margin-bottom:38px;flex-wrap:wrap}
.rating-summary .big{font-family:var(--serif);font-size:2.6rem;color:var(--green);font-weight:700;line-height:1}
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.review{background:transparent;border:none;border-radius:var(--radius);padding:0}
.review .stars{font-size:1rem;margin-bottom:10px}
.review p{margin-bottom:14px}
.review .name{font-weight:700;color:var(--green)}
.review .verified{font-size:.8rem;color:var(--muted)}
@media(max-width:720px){.reviews{grid-template-columns:1fr}}

/* ---- Guarantee (risk-free, premium) ---- */
.guarantee{background:#fff;text-align:center}
.guar-inner{max-width:600px;margin:0 auto;display:flex;flex-direction:column;align-items:center}
.guar-seal{width:60px;margin:0 auto 16px}
.guar-seal svg{width:100%;height:auto;display:block;filter:drop-shadow(0 8px 16px rgba(31,74,58,.18))}
.guar-eyebrow{color:var(--green);font-weight:700;text-transform:uppercase;letter-spacing:.5px;font-size:2rem;line-height:1.05;margin:0 0 4px}
.guar-title{color:#1b1b1b;font-weight:700;text-transform:uppercase;letter-spacing:-.6px;font-size:2.55rem;line-height:1.02;margin:0 0 28px}
.guar-text{color:var(--muted);font-weight:400;font-size:1.08rem;line-height:1.65;max-width:34ch;margin:0 auto 28px}
.guar-cta{display:block;width:100%;max-width:560px;margin:0 auto;background:var(--yellow);color:#1b1b1b;font-weight:700;text-decoration:none;font-size:1.02rem;letter-spacing:.2px;padding:18px 24px;border-radius:10px;box-shadow:0 2px 8px rgba(245,200,78,.28);transition:transform .15s ease,box-shadow .15s ease}
.guar-cta:hover{transform:translateY(-2px);box-shadow:0 14px 30px rgba(245,200,78,.55)}
.guar-feats{list-style:none;display:flex;justify-content:center;gap:40px;padding:0;margin:24px 0 0;flex-wrap:wrap}
.guar-feats li{display:flex;align-items:center;gap:10px;color:var(--ink);font-weight:600;font-size:1rem;line-height:1.18;text-align:left}
.gf-check{color:var(--green);font-weight:700;font-size:1.1rem;flex:none}
@media(max-width:560px){
  .guar-eyebrow{font-size:1.6rem}
  .guar-title{font-size:1.72rem}
  .guar-text{font-size:1rem;max-width:30ch}
  .guar-feats{gap:22px}
  .guar-feats li{font-size:.92rem}
}

/* ---- FAQ ---- */
.faq{max-width:760px;margin:0 auto}
.faq details{background:transparent;border:none;border-bottom:1px solid var(--line);border-radius:0;margin-bottom:0;padding:4px 0}
.faq summary{cursor:pointer;font-weight:600;color:var(--green);padding:16px 0;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";float:right;font-size:1.4rem;color:var(--green);line-height:1}
.faq details[open] summary::after{content:"–"}
.faq p{padding:0 0 16px;color:var(--muted)}

/* ---- Footer ---- */
footer{background:var(--green-deep);color:#fff;text-align:center;padding:48px 22px}
footer .logo{color:#fff}
footer p{margin-top:8px;opacity:.85}
footer small{opacity:.65;display:block;margin-top:16px}

/* ---- Sticky bottom CTA ---- */
.sticky-cta{position:fixed;left:0;right:0;bottom:0;z-index:70;background:rgba(255,255,255,.94);
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid var(--line);
  box-shadow:0 -10px 30px rgba(31,74,58,.10);transform:translateY(110%);transition:transform .35s ease}
.sticky-cta.show{transform:none}
.sticky-cta .inner{max-width:1240px;margin:0 auto;padding:11px 22px;display:flex;align-items:center;gap:14px}
.sticky-cta .sc-pic{width:46px;height:46px;flex:none;border-radius:12px;object-fit:contain;
  background:var(--green-soft);border:1px solid var(--line);padding:4px}
.sticky-cta .info{font-weight:700;color:var(--green);line-height:1.25;margin-right:auto}
.sticky-cta .info small{display:block;color:var(--muted);font-weight:500}
.sticky-cta .info .sc-stars{color:var(--gold);letter-spacing:1px}
.sticky-cta .btn{padding:13px 30px;flex:none}
@media(max-width:560px){
  .sticky-cta .inner{padding:9px 22px;gap:11px}
  .sticky-cta .sc-pic{width:40px;height:40px}
  .sticky-cta .info small{display:none}
  .sticky-cta .info{font-size:.98rem}
  .sticky-cta .btn{padding:13px 22px}
}

/* ===================== Product page (PDP) ===================== */
.pdp{display:grid;grid-template-columns:1fr 1fr;gap:52px;padding:48px 0;align-items:start}
.gallery{position:sticky;top:24px;align-self:start}
.slides{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;
  -webkit-overflow-scrolling:touch;touch-action:pan-x;overscroll-behavior-x:contain;
  border-radius:var(--radius);aspect-ratio:1/1;scrollbar-width:none}
.slides::-webkit-scrollbar{display:none}
.slide{flex:0 0 100%;min-width:100%;scroll-snap-align:center;scroll-snap-stop:always;
  background:var(--sage);
  border-radius:12px;display:flex;align-items:center;justify-content:center}
.slide img{max-height:88%;max-width:88%;width:auto;filter:drop-shadow(0 8px 16px rgba(31,74,58,.12));pointer-events:none}
.dots{display:flex;justify-content:center;gap:9px;margin-top:14px}
.dot{width:8px;height:8px;border-radius:50%;border:none;padding:0;cursor:pointer;background:var(--line);transition:.2s}
.dot.active{background:var(--gold);transform:scale(1.25)}
.thumbs{display:flex;gap:12px;margin-top:14px}
.thumbs img{width:76px;height:76px;object-fit:contain;background:var(--green-soft);border:1px solid var(--line);
  border-radius:12px;padding:7px;cursor:pointer;transition:.2s}
.thumbs img:hover,.thumbs img.active{border-color:var(--gold)}
.pdp-info h1{font-family:var(--serif);color:var(--green);font-size:1.92rem;font-weight:700;letter-spacing:-.5px;line-height:1.12;margin-bottom:10px}
.pdp-info .reviewline{margin-bottom:16px}
.pdp-info .lead{color:var(--muted);font-size:.95rem;margin-bottom:22px}
.opt-label{font-weight:600;color:var(--green);margin-bottom:10px}
/* 4-up bundle cards */
.bundle-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin:0 0 18px}
.bcard{position:relative;border:2px solid var(--line);border-radius:var(--radius);cursor:pointer;background:#fff;
  overflow:hidden;transition:.18s;display:flex;flex-direction:column}
.bcard:hover{border-color:var(--gold)}
.bcard.active{border-color:var(--green);box-shadow:inset 0 0 0 1px var(--green)}
.bcard-tag{min-height:21px;display:flex;align-items:center;justify-content:center;line-height:1;
  font-size:.6rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase;color:#1a1a14;
  background:var(--gold);padding:5px 3px;text-align:center}
.bcard-tag.best{background:var(--gold);color:#1a1a14}
.bcard-tag.empty{background:transparent}
.bcard-body{padding:10px 8px 14px;text-align:center;display:flex;flex-direction:column;align-items:center;flex:1}
.bcard-img{width:100%;aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;margin-bottom:6px}
.bcard-img img{max-width:100%;max-height:100%;object-fit:contain}
.bcard-name{font-family:var(--serif);font-weight:700;color:var(--green);font-size:1.02rem;margin-bottom:6px;line-height:1.15}
.bcard-was{display:block;color:var(--muted);text-decoration:line-through;font-size:.82rem;margin-bottom:1px}
.bcard-now{font-weight:700;color:var(--ink);font-size:1.14rem;font-family:var(--serif);letter-spacing:-.3px}
.bcard-save{margin-top:8px;font-size:.72rem;font-weight:700;color:var(--green);background:transparent;
  padding:2px 0 0;letter-spacing:.02em}
.buybar{margin-top:8px}
.btn-buy{width:100%;margin:0 auto;min-height:60px;border:none;cursor:pointer;background:var(--yellow);border-radius:10px;
  padding:0 18px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
  font-family:var(--sans);box-shadow:0 10px 24px rgba(251,198,62,.36);transition:background .2s,transform .15s,box-shadow .15s}
.btn-buy:hover{background:var(--yellow-deep);transform:translateY(-2px);box-shadow:0 14px 30px rgba(251,198,62,.5)}
.btn-buy .buy-main{font-size:1.2rem;font-weight:700;letter-spacing:.005em;text-transform:uppercase;color:#1A1A1A;line-height:1}
.btn-buy .buy-sub{font-size:.78rem;font-weight:400;color:#1A1A1A;line-height:1}
.assurances{display:flex;justify-content:center;gap:18px;flex-wrap:wrap;margin-top:18px;color:var(--muted);font-size:.9rem}
/* PDP info accordions (Lymphoria-style, under the buy box) */
.pdp-accordion{margin-top:26px;border-top:1px solid var(--line)}
.pdp-accordion details{border-bottom:1px solid var(--line)}
.pdp-accordion summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;
  gap:12px;padding:17px 2px;font-weight:700;color:var(--green);font-size:1.02rem;font-family:var(--serif)}
.pdp-accordion summary::-webkit-details-marker{display:none}
.pdp-accordion summary::after{content:"+";font-size:1.5rem;line-height:1;color:var(--green);font-weight:400;transition:.2s}
.pdp-accordion details[open] summary::after{content:"–"}
.pdp-accordion .ac-body{padding:0 2px 18px}
.pdp-accordion p{color:var(--muted);font-size:.95rem;line-height:1.65;margin-bottom:10px}
.pdp-accordion p:last-child{margin-bottom:0}
.pdp-accordion ul{margin:0;padding-left:20px;color:var(--muted);font-size:.95rem;line-height:1.7}
@media(max-width:820px){.pdp{grid-template-columns:1fr;gap:26px}}

/* ===================== Full transparency section ===================== */
.transparency{background:var(--green-deep);color:#fff;padding:84px 0}
.transparency .wrap{max-width:1100px}
.trans-head{text-align:center;max-width:680px;margin:0 auto 50px}
.eyebrow-light{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:1.8px;text-transform:uppercase;
  color:var(--gold);margin-bottom:14px}
.trans-head h2{font-family:var(--serif);font-size:1.72rem;font-weight:700;letter-spacing:-.4px;line-height:1.12;margin-bottom:14px}
.trans-head p{color:rgba(255,255,255,.7);font-size:1.06rem}
.trans-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:30px;align-items:start}
.ingredients-list{display:flex;flex-direction:column;gap:14px}
.ing{display:flex;gap:16px;background:rgba(255,255,255,.04);border:none;
  border-radius:var(--radius);padding:18px 20px}
.ing-ic{flex:none;width:46px;height:46px;border-radius:12px;background:rgba(251,198,62,.18);color:var(--gold);
  display:flex;align-items:center;justify-content:center}
.ing h3{font-size:1.12rem;font-weight:700;margin-bottom:4px}
.ing p{color:rgba(255,255,255,.68);font-size:.94rem;line-height:1.55}
.leave-out{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.10);border-radius:var(--radius);padding:30px 28px}
.leave-out h3{font-family:var(--serif);font-size:1.5rem;font-weight:700;text-align:center;margin-bottom:22px}
.pills{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:26px}
.pill{display:inline-flex;align-items:center;gap:8px;background:#fff;color:var(--ink);border-radius:50px;
  padding:9px 16px;font-size:.9rem;font-weight:600}
.pill s{color:var(--muted);text-decoration-color:var(--red)}
.pill .x{color:var(--red);font-weight:700}
.leave-out .btn{width:100%;text-align:center}
.leave-out .lo-note{display:block;text-align:center;color:rgba(255,255,255,.6);font-size:.84rem;margin-top:12px}
@media(max-width:820px){.trans-grid{grid-template-columns:1fr;gap:20px}.trans-head h2{font-size:2rem}}

/* ===================== Footer (herbies-style) ===================== */
.site-footer{background:var(--green-deep);color:#fff;padding:60px 0 0;text-align:left;border-top:1px solid rgba(255,255,255,.08)}
.footer-top{max-width:620px;display:flex;flex-direction:column;gap:42px;padding-bottom:44px}
.footer-brand .logo{color:#fff;font-size:1.95rem;display:inline-block;margin-bottom:20px}
.footer-brand p{color:rgba(255,255,255,.62);font-size:1rem;line-height:1.7;margin:0}
.footer-col h4,.footer-news h4{font-family:var(--serif);font-size:1.5rem;font-weight:700;color:#fff;margin:0 0 16px;letter-spacing:-.01em}
.footer-col a{display:block;color:rgba(255,255,255,.72);text-decoration:none;font-size:1.02rem;padding:9px 0;transition:.2s}
.footer-col a:hover{color:#fff}
.footer-news p{color:rgba(255,255,255,.62);font-size:1rem;margin:0 0 20px;line-height:1.6}
.footer-news input{width:100%;border:none;background:#fff;color:var(--ink);border-radius:10px;
  padding:18px 20px;font-size:1rem;font-family:var(--sans);outline:none;margin-bottom:14px}
.footer-news input::placeholder{color:#8a8a82}
.footer-signup{width:100%;border:none;cursor:pointer;background:var(--yellow);color:#1a1a14;
  font-family:var(--sans);font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  font-size:1rem;padding:18px 0;border-radius:10px;transition:.2s}
.footer-signup:hover{background:var(--yellow-deep)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding:30px 0 8px;text-align:center}
.footer-bottom .copy{display:block;color:rgba(255,255,255,.6);font-size:.95rem;margin-bottom:22px}
.footer-legal{display:flex;justify-content:center;gap:18px 40px;flex-wrap:wrap}
.footer-legal a{color:rgba(255,255,255,.85);text-decoration:none;font-size:1rem;transition:.2s}
.footer-legal a:hover{color:var(--gold)}
.footer-disclaimer{padding:30px 0 36px;text-align:left;
  color:rgba(255,255,255,.5);font-size:.92rem;line-height:1.65;margin:0}

/* nicer ingredient cards */
.ing{transition:transform .2s,border-color .2s,background .2s}
.ing:hover{transform:translateY(-3px);border-color:rgba(251,198,62,.45);background:rgba(255,255,255,.07)}

/* ===================== Reviews + UGC (real people) ===================== */
.tp-row{display:flex;align-items:center;justify-content:center;gap:11px;flex-wrap:wrap;margin:2px 0 11px}
.tp-stars{display:inline-flex;gap:4px}
.tp-stars i{width:26px;height:26px;background:#00b67a;display:inline-flex;align-items:center;justify-content:center;
  border-radius:4px;color:#fff;font-size:15px;font-style:normal;line-height:1}
.tp-score{font-weight:700;color:var(--ink);font-size:1.14rem;letter-spacing:-.3px}
.tp-sub{color:var(--muted);font-size:.95rem;line-height:1.5;letter-spacing:.1px;text-align:center}
.tp-logo{font-weight:700;color:var(--ink);letter-spacing:-.2px;white-space:nowrap}
.tp-logo b{color:#00b67a}

/* --- Auto-moving photo strip (real people) --- */
.ugc-marquee{overflow:hidden;margin-top:18px;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 3%,#000 97%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 3%,#000 97%,transparent)}
.ugc-track{display:flex;width:max-content;animation:ugcScroll 50s linear infinite}
.ugc-marquee:hover .ugc-track{animation-play-state:paused}
@keyframes ugcScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.ugc-card{position:relative;flex:0 0 auto;width:226px;aspect-ratio:3/4;margin-right:16px;
  border-radius:var(--radius);overflow:hidden;box-shadow:0 10px 26px rgba(31,74,58,.16)}
.ugc-card img{width:100%;height:100%;object-fit:cover;display:block}
.ugc-card .ov{position:absolute;inset:auto 0 0 0;padding:38px 16px 14px;color:#fff;
  background:linear-gradient(to top,rgba(31,74,58,.92),rgba(31,74,58,.45) 55%,rgba(31,74,58,0))}
.ugc-card .ov .s{color:#ffc94d;font-size:.84rem;letter-spacing:1.5px}
.ugc-card .ov p{font-size:.87rem;line-height:1.42;margin:5px 0 6px;font-weight:500}
.ugc-card .ov .nm{font-size:.78rem;opacity:.85}
.ugc-hint{text-align:center;color:var(--muted);font-size:.82rem;margin-top:10px}

/* --- Reviews carousel (arrows on desktop, swipe on mobile) --- */
.rev-carousel{position:relative;margin-top:30px}
.rev-track{display:flex;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;
  padding:6px 2px 12px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.rev-track::-webkit-scrollbar{display:none}
.rev-card{flex:0 0 340px;scroll-snap-align:start;background:var(--green-soft);border:none;border-radius:var(--radius);
  padding:24px;text-align:left}
.rev-top{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.rev-top img{width:48px;height:48px;border-radius:50%;object-fit:cover;flex:none}
.rev-top .nm{font-weight:700;color:var(--green);font-size:.95rem;line-height:1.2}
.rev-top .loc{color:var(--muted);font-size:.8rem}
.rev-card .rstars{color:#ffb100;font-size:.98rem;margin-bottom:8px;letter-spacing:1px}
.rev-card p{color:var(--ink);opacity:.9;font-size:.95rem;line-height:1.6;margin-bottom:12px}
.rev-card .vf{display:inline-flex;align-items:center;gap:6px;color:#00b67a;font-size:.82rem;font-weight:600}
.rev-nav{position:absolute;top:50%;transform:translateY(-50%);width:46px;height:46px;border-radius:50%;
  background:#fff;border:1px solid var(--line);box-shadow:0 8px 20px rgba(31,74,58,.16);cursor:pointer;
  display:flex;align-items:center;justify-content:center;color:var(--green);z-index:3;transition:.18s}
.rev-nav svg{width:20px;height:20px}
.rev-nav:hover{background:var(--green);color:#fff;border-color:var(--green)}
.rev-nav.prev{left:-14px}
.rev-nav.next{right:-14px}
@media(max-width:820px){
  .rev-nav{display:none}
  .rev-card{flex:0 0 84%}
  .ugc-card{width:184px;margin-right:12px}
}

/* ===================== Tablet (iPad portrait) ===================== */
@media(max-width:900px){
  .benefits{grid-template-columns:1fr 1fr;gap:18px}
  .bundles{grid-template-columns:1fr 1fr;gap:18px;row-gap:28px}
  .trust-grid{grid-template-columns:repeat(2,1fr);gap:22px}
  .reviews{grid-template-columns:1fr 1fr}
}

/* ===================== Mobile polish ===================== */
@media(max-width:560px){
  /* Failsafe: never leave a section stuck invisible on phones */
  .reveal{opacity:1!important;transform:none!important;transition:none!important}

  .wrap{padding:0 22px}

  /* Header — compact, solid, single line, no overlap */
  header{background:rgba(255,255,255,.96)}
  .header-inner{padding:11px 22px;gap:8px}
  .logo{font-size:1.12rem;white-space:nowrap;line-height:1}
  .nav{gap:8px}
  .ccy{padding:7px 8px;font-size:.76rem}
  header .nav .btn{padding:10px 14px!important;font-size:.82rem!important}

  /* Section rhythm */
  section.block{padding-top:58px;padding-bottom:58px}
  .title,.split h2,.bc-head h2,.trans-head h2{font-size:1.7rem;letter-spacing:-.5px}
  .subtitle{font-size:.82rem;margin-bottom:22px}
  .deal{font-size:.74rem;padding:9px 12px}

  /* Hero — product photo first, tight & premium (like Huel/AG1) */
  .marquee{display:none}
  .hero{display:flex;flex-direction:column;gap:16px;padding:18px 0 6px}
  .hero-photo{order:-1;aspect-ratio:1/1;width:100%}
  .hero .eyebrow{margin-bottom:10px}
  .hero h1{font-size:2rem;margin-bottom:10px}
  .hero p.sub{font-size:1.02rem;margin-bottom:12px}
  .hero ul{display:none}
  .priceline{margin:4px 0 8px}
  .priceline b{font-size:1.4rem}
  .cta-row{margin-top:4px}
  .cta-row .btn{width:100%;text-align:center}

  /* Benefits */
  .benefits{grid-template-columns:1fr 1fr;gap:12px}
  .benefit{padding:22px 14px}
  .benefit h3{font-size:.98rem}
  .benefit p{font-size:.85rem}

  /* Homepage bundle grid */
  .bundles{grid-template-columns:1fr 1fr;gap:12px;row-gap:24px}
  .bundle{padding:26px 12px 18px}
  .bundle h3{font-size:1.02rem}
  .now{font-size:1.5rem}
  .each{font-size:.78rem;margin-bottom:12px}
  .was{font-size:.85rem}
  .bundle .btn{padding:12px 0;font-size:.9rem}
  .badge{font-size:.6rem;padding:4px 10px;top:-11px}

  /* Steps */
  .step{padding:26px 20px}

  /* Product page */
  .pdp{padding:18px 0;gap:22px}
  .pdp-info h1{font-size:1.85rem}
  .gallery{position:static}
  .thumbs img{width:56px;height:56px}
  .bundle-cards{grid-template-columns:repeat(4,1fr);gap:6px}
  .bcard{border-radius:var(--radius)}
  .bcard-tag{min-height:17px;font-size:.42rem;padding:3px 1px;letter-spacing:0}
  .bcard-body{padding:7px 3px 11px}
  .bcard-img{margin-bottom:4px}
  .bcard-name{font-size:.82rem;margin-bottom:3px}
  .bcard-was{font-size:.66rem}
  .bcard-now{font-size:.92rem}
  .bcard-save{margin-top:5px;font-size:.64rem;padding:0}
  .btn-buy{width:100%;min-height:54px;padding:0 14px;border-radius:12px;gap:3px}
  .btn-buy .buy-main{font-size:1.05rem}
  .btn-buy .buy-sub{font-size:.74rem}
  .assurances{gap:10px 14px;font-size:.82rem}

  /* Trust strip */
  .trust{padding:20px 0}
  .trust-grid{gap:16px}
  .trust-grid div b{font-size:.92rem}
  .trust-grid small{font-size:.78rem}

  /* Transparency / dark section */
  .transparency{padding:48px 0}
  .trans-head{margin-bottom:30px}
  .trans-head h2{font-size:1.7rem}
  .trans-head p{font-size:.96rem}
  .ing{padding:18px 16px;gap:13px}
  .ing-ic{width:40px;height:40px}
  .ing h3{font-size:1.02rem}
  .leave-out{padding:24px 18px}

  /* Reviews */
  .tp-sub{font-size:.84rem}
  .rev-card{padding:18px}

  /* Compare table */
  .compare th,.compare td{padding:11px 9px;font-size:.82rem}

  /* FAQ + guarantee */
  .faq details{padding:2px 18px}
  .guarantee p{font-size:.96rem}

  /* Footer — clean left-aligned single column */
  .site-footer{padding:46px 0 0}
  .footer-top{max-width:none;gap:36px}
  .footer-legal{gap:14px 28px}
}

/* ===================== Better Choice comparison ===================== */
.bcompare{background:var(--cream)}
.bc-wrap{display:grid;grid-template-columns:.9fr 1.1fr;gap:54px;align-items:center}
.bc-head .eyebrow{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:1.8px;text-transform:uppercase;
  color:var(--green);margin-bottom:14px}
.bc-head h2{font-family:var(--serif);font-size:1.72rem;line-height:1.12;color:var(--green);
  font-weight:700;letter-spacing:-.4px;margin-bottom:18px}
.bc-head p{color:var(--muted);font-size:1.05rem;line-height:1.65;max-width:400px}
.bc-cols{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.bc-col{border-radius:var(--radius);overflow:hidden}
.bc-col.ours{background:var(--green-deep);color:#fff;box-shadow:0 20px 44px rgba(31,74,58,.24)}
.bc-col.theirs{background:#fff;border:1px solid var(--line)}
.bc-photo{display:flex;justify-content:center;padding:24px 0 4px}
.bc-photo img{width:122px;height:122px;object-fit:cover;border-radius:var(--radius);
  box-shadow:0 10px 24px rgba(0,0,0,.22)}
.bc-body{padding:8px 22px 24px}
.bc-col h3{text-align:center;font-size:1.3rem;font-weight:700;margin:10px 0 14px;letter-spacing:-.3px}
.bc-col.ours h3{color:#fff}
.bc-col.theirs h3{color:var(--ink)}
.bc-col ul{list-style:none;margin:0;padding:0}
.bc-col li{display:flex;align-items:center;gap:11px;font-size:.93rem;line-height:1.35;
  padding:13px 0;min-height:60px}
.bc-col.ours li{border-bottom:1px solid rgba(255,255,255,.12)}
.bc-col.theirs li{border-bottom:1px solid var(--line);color:var(--muted)}
.bc-col li:last-child{border-bottom:none}
.bc-ic{flex:none;width:24px;height:24px;border-radius:50%;display:inline-flex;align-items:center;
  justify-content:center;font-size:.78rem;font-weight:700}
.bc-ic.yes{background:rgba(251,198,62,.32);color:#fff}
.bc-ic.no{background:#ededeb;color:var(--red)}
@media(max-width:820px){
  .bc-wrap{grid-template-columns:1fr;gap:30px}
  .bc-head{text-align:center}
  .bc-head p{max-width:none;margin:0 auto}
}
@media(max-width:560px){
  .bc-cols{gap:10px}
  .bc-body{padding:6px 12px 16px}
  .bc-col li{font-size:.78rem;min-height:66px;gap:8px}
  .bc-photo img{width:96px;height:96px}
  .bc-col h3{font-size:1.05rem}
  .bc-ic{width:20px;height:20px;font-size:.68rem}
}

/* ===================== Herbies-style long-form PDP blocks ===================== */

/* --- Repeated mid-page CTA --- */
.cta-band{text-align:center}
.cta-band .btn{padding:17px 50px;font-size:1.06rem}
.cta-band .note{display:block;margin-top:13px;color:var(--muted);font-size:.86rem}
.cta-band .note .icon{vertical-align:-2px}
.cta-band.on-dark .note{color:rgba(255,255,255,.62)}

/* --- Big testimonial band (dark) --- */
.tband{background:var(--green-deep);color:#fff;padding:80px 0}
.tband-grid{display:grid;grid-template-columns:.82fr 1.18fr;gap:50px;align-items:center}
.tband-photo{border-radius:var(--radius);overflow:hidden;aspect-ratio:4/5;box-shadow:0 28px 56px rgba(0,0,0,.34)}
.tband-photo img{width:100%;height:100%;object-fit:cover}
.tband .stars{font-size:1.15rem;margin-bottom:14px;display:block}
.tband h2{font-family:var(--serif);font-size:1.72rem;font-weight:700;letter-spacing:-.4px;line-height:1.16;margin-bottom:18px}
.tband p{color:rgba(255,255,255,.74);font-size:1.08rem;line-height:1.7;margin-bottom:16px}
.tband .who{display:flex;align-items:center;gap:12px;margin-top:22px}
.tband .who img{width:46px;height:46px;border-radius:50%;object-fit:cover;border:2px solid rgba(255,255,255,.25)}
.tband .who b{display:block;font-size:.98rem}
.tband .who span{color:rgba(255,255,255,.6);font-size:.85rem}

/* --- Problem / agitation --- */
.problem{background:var(--cream)}
.prob-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.prob-card{background:transparent;border:none;border-radius:var(--radius);padding:6px 8px}
.prob-card .pico{width:48px;height:48px;border-radius:12px;background:rgba(31,74,58,.10);color:var(--red);
  display:flex;align-items:center;justify-content:center;margin-bottom:16px;font-size:1.4rem;font-weight:700}
.prob-card h3{color:var(--green);font-size:1.1rem;margin-bottom:8px}
.prob-card p{color:var(--muted);font-size:.95rem;line-height:1.6}
.prob-foot{text-align:center;max-width:640px;margin:42px auto 0;color:var(--green);font-size:1.2rem;
  font-weight:700;font-family:var(--serif);line-height:1.4}
@media(max-width:820px){.prob-grid{grid-template-columns:1fr}}

/* --- Customer stories (real photos) --- */
.stories-row{display:flex;gap:18px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;
  padding:6px 2px 14px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.stories-row::-webkit-scrollbar{display:none}
.story{flex:0 0 300px;scroll-snap-align:start;position:relative;border-radius:var(--radius);overflow:hidden;
  aspect-ratio:4/5;box-shadow:var(--shadow)}
.story img{width:100%;height:100%;object-fit:cover}
.story .cap{position:absolute;inset:auto 0 0 0;padding:46px 18px 16px;color:#fff;
  background:linear-gradient(to top,rgba(31,74,58,.94),rgba(31,74,58,.4) 60%,transparent)}
.story .cap .s{color:#ffc94d;font-size:.86rem;letter-spacing:1.5px}
.story .cap p{font-size:.96rem;line-height:1.45;margin:6px 0 8px;font-weight:500}
.story .cap .nm{font-size:.82rem;opacity:.85}
.stories-hint{text-align:center;color:var(--muted);font-size:.82rem;margin-top:8px}
@media(max-width:560px){.story{flex:0 0 78%}}

/* --- Research / stats band (dark) --- */
.stats{background:var(--green);color:#fff;padding:78px 0}
.stats .trans-head h2{color:#fff}
.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-bottom:44px}
.stat{background:transparent;border:none;border-radius:var(--radius);
  padding:18px 18px;text-align:center}
.stat .num{font-family:var(--serif);font-size:3.1rem;font-weight:700;color:#fff;letter-spacing:-1.5px;line-height:1}
.stat .lab{color:rgba(255,255,255,.74);margin-top:10px;font-size:.96rem;line-height:1.5}
@media(max-width:820px){.stat-grid{grid-template-columns:1fr;gap:16px;max-width:420px;margin-left:auto;margin-right:auto}
  .stat{padding:24px 20px}.stat .num{font-size:2.6rem}}

/* --- Timeline: when will you feel it --- */
.timeline{max-width:660px;margin:0 auto}
.tl-step{display:flex;gap:22px;position:relative;padding-bottom:30px}
.tl-step:last-child{padding-bottom:0}
.tl-step::before{content:"";position:absolute;left:26px;top:56px;bottom:-2px;width:2px;background:var(--line)}
.tl-step:last-child::before{display:none}
.tl-marker{flex:none;width:54px;height:54px;border-radius:50%;background:var(--green);color:#fff;z-index:2;
  display:flex;align-items:center;justify-content:center;font-weight:700;font-family:var(--serif);font-size:.82rem;text-align:center;line-height:1.05}
.tl-body{background:transparent;border:none;border-radius:var(--radius);padding:2px 0 0 2px;flex:1}
.tl-body h3{color:var(--green);font-size:1.08rem;margin-bottom:4px}
.tl-body p{color:var(--muted);font-size:.94rem}

/* --- Review distribution bars --- */
.revdist{max-width:640px;margin:0 auto 40px;display:grid;grid-template-columns:auto 1fr;gap:34px;align-items:center}
.revdist .score{text-align:center;flex:none}
.revdist .score .big{font-family:var(--serif);font-size:3.6rem;font-weight:700;color:var(--green);line-height:1}
.revdist .score .stars{display:block;font-size:1.05rem;margin:6px 0 2px}
.revdist .score small{color:var(--muted);font-size:.82rem}
.revdist .bars{display:flex;flex-direction:column;gap:8px;width:100%}
.revbar{display:flex;align-items:center;gap:11px;font-size:.84rem;color:var(--muted)}
.revbar .lab{width:38px;white-space:nowrap}
.revbar .track{flex:1;height:9px;background:var(--green-soft);border-radius:50px;overflow:hidden}
.revbar .fill{height:100%;background:var(--gold);border-radius:50px}
.revbar .pct{width:38px;text-align:right}
@media(max-width:560px){.revdist{grid-template-columns:1fr;gap:18px;text-align:center}
  .revdist .bars{max-width:340px;margin:0 auto}}

/* --- Mobile polish for new blocks --- */
@media(max-width:560px){
  .tband{padding:46px 0}
  .tband-grid{grid-template-columns:1fr;gap:24px}
  .tband-photo{aspect-ratio:4/3;max-width:420px;margin:0 auto}
  .tband h2{font-size:1.7rem}
  .tband p{font-size:1rem}
  .problem,.stats{padding:46px 0}
  .prob-foot{font-size:1.05rem;margin-top:28px}
  .cta-band .btn{width:100%;padding:16px 0}
  .tl-marker{width:46px;height:46px;font-size:.74rem}
  .tl-step::before{left:22px;top:48px}
  .tl-body{padding:14px 16px}
}
@media(min-width:561px) and (max-width:820px){
  .tband-grid{grid-template-columns:1fr;gap:30px}
  .tband-photo{max-width:460px;margin:0 auto;aspect-ratio:16/10}
}

/* ===================== Legal / info pages ===================== */
.legal{max-width:780px;margin:0 auto;padding:56px 22px 72px}
.legal h1{font-family:var(--serif);color:var(--green);font-size:2.4rem;font-weight:700;letter-spacing:-1px;margin-bottom:6px}
.legal .updated{color:var(--muted);font-size:.9rem;margin-bottom:32px}
.legal h2{font-family:var(--serif);color:var(--green);font-size:1.35rem;font-weight:700;margin:30px 0 10px}
.legal p,.legal li{color:var(--ink);opacity:.88;margin-bottom:12px;line-height:1.7}
.legal ul{padding-left:22px;margin-bottom:12px}
.legal a{color:var(--green);font-weight:600}
.legal .back{display:inline-block;margin-bottom:26px;color:var(--green);text-decoration:none;font-weight:600;font-size:.92rem}

/* ===================== Lymphoria-style blocks ===================== */

/* --- Photo benefit cards (lifestyle photo + label overlay) --- */
.benefit-photos{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.bp-card{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:3/4;box-shadow:var(--shadow)}
.bp-card img{width:100%;height:100%;object-fit:cover;display:block}
.bp-label{position:absolute;inset:auto 12px 12px 12px;background:rgba(255,255,255,.93);
  -webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:12px;padding:12px 14px;text-align:center;
  font-family:var(--serif);font-weight:700;color:var(--green);font-size:1rem;line-height:1.25;
  box-shadow:0 8px 20px rgba(31,74,58,.12)}
@media(max-width:820px){.benefit-photos{grid-template-columns:1fr 1fr;gap:12px}}
@media(max-width:560px){.bp-label{font-size:.84rem;padding:9px 10px;inset:auto 8px 8px 8px}}

/* --- Your Daily Ritual (lifestyle step cards) --- */
.ritual{background:var(--cream)}
.ritual-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.ritual-step{background:transparent;border:none;border-radius:var(--radius);overflow:hidden}
.ritual-photo{aspect-ratio:4/3;overflow:hidden}
.ritual-photo img{width:100%;height:100%;object-fit:cover;display:block}
.ritual-body{padding:22px}
.ritual-tag{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:1.4px;text-transform:uppercase;
  color:var(--green);margin-bottom:8px}
.ritual-body h3{font-family:var(--serif);color:var(--green);font-size:1.3rem;font-weight:700;margin-bottom:6px}
.ritual-body p{color:var(--muted);font-size:.95rem;line-height:1.6}
@media(max-width:820px){.ritual-steps{grid-template-columns:1fr;gap:16px}}


/* ===================== Premium top section (hero rebuild) ===================== */
/* Promo bar */
.promo{background:var(--green-deep);color:#fff}
.promo-inner{max-width:1240px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:9px 18px}
.promo-msg{display:flex;align-items:center;gap:9px;font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;white-space:nowrap}
.promo-msg b{font-weight:700;color:#fff}
.promo-msg .pm-ic{width:16px;height:16px;flex:none;fill:none;stroke:var(--yellow);stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.promo-msg .pm-sep{opacity:.4;font-weight:300}
.promo-msg .pm-accent{color:var(--yellow)}
.promo-timer{display:flex;align-items:center;gap:9px}
.pt-box{display:flex;flex-direction:column;align-items:center;line-height:1;min-width:24px}
.pt-box b{font-size:.96rem;font-weight:700;font-variant-numeric:tabular-nums}
.pt-box i{font-size:.5rem;font-style:normal;letter-spacing:.14em;color:var(--yellow);margin-top:3px}
.pt-colon{opacity:.3;font-weight:300;align-self:flex-start}
@media(max-width:560px){
  .promo-inner{padding:8px 14px;gap:8px}
  .promo-msg{font-size:.64rem;gap:6px;letter-spacing:.05em}
  .promo-msg .pm-ic{width:13px;height:13px}
  .pt-box b{font-size:.8rem}.pt-box i{font-size:.44rem}.promo-timer{gap:7px}
}

/* Header */
.hdr{background:#fff;position:sticky;top:0;z-index:60;border-bottom:1px solid var(--line)}
.hdr-inner{max-width:1240px;margin:0 auto;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:14px 18px}
.hdr-burger,.hdr-cart{background:none;border:none;cursor:pointer;color:var(--green);padding:6px;display:inline-flex;align-items:center}
.hdr-burger{justify-self:start}.hdr-cart{justify-self:end;position:relative}
.hdr-burger svg,.hdr-cart svg{width:24px;height:24px}
.hdr-logo{justify-self:center;display:inline-flex;align-items:center;gap:9px;text-decoration:none;color:var(--green)}
.hdr-logo .lg-mark{width:27px;height:27px;flex:none;color:var(--green)}
.hdr-logo .lg-text{font-family:var(--serif);font-weight:700;font-size:1.12rem;letter-spacing:.16em;text-transform:uppercase}
.cart-count{position:absolute;top:-3px;right:-5px;background:var(--green);color:#fff;font-size:.58rem;font-weight:700;min-width:16px;height:16px;border-radius:50%;display:none;align-items:center;justify-content:center;padding:0 4px}
.cart-count.show{display:flex}
@media(max-width:560px){
  .hdr-inner{padding:12px 16px}
  .hdr-logo .lg-text{font-size:.96rem;letter-spacing:.12em}
  .hdr-logo .lg-mark{width:23px;height:23px}
}

/* Drawers + overlay */
.overlay{position:fixed;inset:0;background:rgba(15,28,20,.5);opacity:0;visibility:hidden;transition:opacity .3s;z-index:90}
.overlay.show{opacity:1;visibility:visible}
.side-menu,.cart-drawer{position:fixed;top:0;bottom:0;background:#fff;z-index:100;display:flex;flex-direction:column;transition:transform .32s cubic-bezier(.4,0,.2,1)}
.side-menu{left:0;width:min(82vw,320px);padding:22px;transform:translateX(-100%)}
.side-menu.open{transform:none}
.cart-drawer{right:0;width:min(90vw,380px);transform:translateX(100%)}
.cart-drawer.open{transform:none}
.sm-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.sm-head .dh-title{font-family:var(--serif);font-weight:700;font-size:.95rem;letter-spacing:.12em;text-transform:uppercase;color:var(--green)}
.drawer-close{background:none;border:none;font-size:1.4rem;line-height:1;cursor:pointer;color:var(--green);padding:4px}
.sm-nav{display:flex;flex-direction:column}
.sm-nav a{padding:17px 2px;font-size:1.04rem;font-weight:600;color:var(--ink);text-decoration:none;border-bottom:1px solid var(--line)}
.sm-nav a:hover{color:var(--green)}
.drawer-head{display:flex;align-items:center;justify-content:space-between;padding:20px 22px;border-bottom:1px solid var(--line)}
.drawer-head h3{font-family:var(--serif);font-weight:700;font-size:.95rem;letter-spacing:.12em;text-transform:uppercase;color:var(--green)}
.cd-body{flex:1;display:flex;flex-direction:column}
.cd-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px 30px}
.cd-empty svg{width:44px;height:44px;color:var(--green);opacity:.4;margin-bottom:14px}
.cd-empty h4{font-family:var(--serif);font-weight:700;font-size:1.15rem;color:var(--green);margin-bottom:6px}
.cd-empty p{color:var(--muted2);font-size:.9rem;margin-bottom:22px;max-width:24ch}
.cd-empty .btn{width:100%}

/* Hero (premium editorial split: cream text panel blends into lifestyle photo) */
.hero2{background:#dfc599;color:var(--ink);display:flex;flex-direction:column}
.hero2-text{width:100%;max-width:600px;margin:0 auto;padding:46px 24px 26px;display:flex;flex-direction:column;align-items:flex-start}
.hero2-badge{display:inline-flex;align-items:center;gap:10px;font-size:.72rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--green);margin-bottom:22px}
.hero2-badge .laurel{width:13px;height:18px;fill:none;stroke:currentColor;stroke-width:1.5;opacity:.75}
.hero2-badge .laurel.flip{transform:scaleX(-1)}
.hero2-title{font-family:'Playfair Display',Georgia,serif;font-weight:600;font-size:3rem;line-height:1.04;letter-spacing:-.5px;color:var(--green);margin:0}
.hero2-title em{display:block;font-style:normal;color:#b67e12}
.hero2-rule{display:block;width:58px;height:2px;background:#b67e12;opacity:.8;margin:20px 0 22px}
.hero2-sub{font-size:1.04rem;line-height:1.62;color:#33312b;max-width:36ch;margin:0 0 28px}
.hero2-cta{display:inline-flex;align-items:center;gap:11px;background:var(--green);color:#fff;font-weight:700;letter-spacing:.1em;text-transform:uppercase;font-size:.9rem;padding:18px 34px;border-radius:10px;text-decoration:none;box-shadow:0 12px 26px rgba(31,74,58,.25);transition:.2s}
.hero2-cta:hover{background:var(--green-deep);transform:translateY(-2px)}
.hero2-rating{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:22px;font-size:.92rem;color:#33312b}
.hero2-rating .h2-stars{color:#caa12f;letter-spacing:2px}
.hero2-rating b{font-weight:700}
.hero2-photo{width:100%;height:56vh;min-height:330px}
.hero2-photo img{width:100%;height:100%;object-fit:cover;object-position:64% center;display:block}
@media(min-width:768px){
  .hero2{flex-direction:row;align-items:stretch;min-height:90vh}
  .hero2-text{flex:1;max-width:none;margin:0;justify-content:center;padding:0 clamp(28px,5vw,72px)}
  .hero2-photo{flex:1.12;height:auto;min-height:0}
  .hero2-photo img{object-position:left center}
  .hero2-title{font-size:4rem}
}
@media(min-width:1150px){ .hero2-title{font-size:4.5rem} .hero2-text{flex:.92} }
@media(max-width:560px){
  .hero2-text{padding:34px 22px 22px}
  .hero2-title{font-size:2.55rem}
  .hero2-sub{font-size:.98rem}
  .hero2-photo{height:50vh}
}

/* USP strip */
.usp{background:#fff;border-bottom:1px solid var(--line)}
.usp-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);padding:26px 8px}
.usp-item{text-align:center;padding:6px 14px;display:flex;flex-direction:column;align-items:center;gap:8px}
.usp-item + .usp-item{border-left:1px solid var(--line)}
.usp-ic{width:40px;height:40px;display:flex;align-items:center;justify-content:center;color:var(--green)}
.usp-ic.circle{background:var(--green);color:#fff;border-radius:50%}
.usp-ic svg{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.usp-item h4{font-family:var(--serif);font-weight:700;font-size:.86rem;color:var(--green);line-height:1.25}
.usp-item p{font-size:.72rem;color:var(--muted2)}
@media(max-width:560px){
  .usp-inner{padding:18px 2px}
  .usp-item{padding:4px 7px;gap:6px}
  .usp-item h4{font-size:.72rem}.usp-item p{font-size:.62rem}
  .usp-ic{width:34px;height:34px}.usp-ic svg{width:17px;height:17px}
}
