/* ============================================================
   SPIRO+ Landing — A+B Hybrid (Premium Apothecary × Vitality)
   ============================================================ */

:root {
  --forest:#15362a; --forest-2:#1d4634; --moss:#2f5d45;
  --fresh:#46b16e; --fresh-deep:#2f9457; --fresh-soft:#e7f1e9;
  --bone:#f4f0e6; --bone-2:#ece6d6; --bone-3:#e4ddcc;
  --sage:#d7e1cf; --ink:#11221b; --ink-soft:#44544a;
  --amber:#f3b24a;
  --line:rgba(21,54,42,.12);
  --line-light:rgba(255,255,255,.14);
  --hk:'Hanken Grotesk',system-ui,-apple-system,sans-serif;
  --news:'Newsreader',Georgia,serif;
  --shadow-sm:0 4px 16px rgba(21,54,42,.08);
  --shadow:0 16px 40px rgba(21,54,42,.14);
  --shadow-lg:0 30px 70px rgba(21,54,42,.20);
  --maxw:1200px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; font-family:var(--hk); color:var(--ink);
  background:var(--bone); -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility; overflow-x:hidden;
}
img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}
button{font-family:inherit; cursor:pointer; border:none}
h1,h2,h3,h4{margin:0; font-weight:600; letter-spacing:-.01em}

.wrap{max-width:var(--maxw); margin:0 auto; padding:0 28px}
.serif{font-family:var(--news)}
.eyebrow{
  font-weight:700; letter-spacing:.16em; text-transform:uppercase;
  font-size:12.5px; color:var(--fresh-deep); display:inline-flex;
  align-items:center; gap:10px;
}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--fresh);box-shadow:0 0 0 4px rgba(70,177,110,.18)}
.eyebrow.on-dark{color:#8fd6a8}
.eyebrow .ln{width:26px;height:2px;background:var(--fresh)}
.stars{color:var(--amber); letter-spacing:2px}

.section{padding:96px 0}
.section-head{max-width:760px; margin:0 auto 56px; text-align:center}
.section-head h2{font-family:var(--news); font-weight:500; font-size:46px; line-height:1.12; color:var(--forest); margin-top:16px; padding-bottom:.1em; text-wrap:balance}
.section-head h2 em{font-style:italic; color:var(--fresh-deep)}
.section-head p{font-size:17.5px; line-height:1.6; color:var(--ink-soft); margin:18px auto 0; max-width:620px}
.on-forest{background:var(--forest); color:#e9f0ea}
.on-forest .section-head h2{color:#fff}
.on-forest .section-head h2 em{color:var(--fresh)}
.on-forest .section-head p{color:#bcd0c2}

/* buttons */
.btn{display:inline-flex; align-items:center; justify-content:center; gap:10px; border-radius:999px; font-weight:700; font-size:15.5px; transition:transform .15s ease, box-shadow .2s ease, background .2s ease; line-height:1}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--fresh); color:#07291a; padding:18px 32px; box-shadow:0 12px 28px rgba(70,177,110,.34)}
.btn-primary:hover{background:#54c47d; box-shadow:0 16px 34px rgba(70,177,110,.42)}
.btn-dark{background:var(--forest); color:var(--bone); padding:18px 32px}
.btn-dark:hover{background:var(--forest-2)}
.btn-ghost{color:var(--moss); font-weight:700; border-bottom:2px solid rgba(47,93,69,.3); padding-bottom:3px; border-radius:0; font-size:14.5px}
.btn-ghost.on-dark{color:#fff; border-color:rgba(255,255,255,.4)}
.btn-lg{padding:21px 40px; font-size:17px}

/* ============ ANNOUNCEMENT + HEADER ============ */
.announce{
  color:#fff; font-size:13px; font-weight:600; overflow:hidden;
  background:linear-gradient(90deg,#15362a,#2f5d45,#2f9457,#2f5d45,#15362a);
  background-size:200% 100%;
  animation:announceGradient 9s ease-in-out infinite;
}
.announce-track{display:flex; width:max-content; animation:announceScroll 30s linear infinite; will-change:transform}
.announce:hover .announce-track{animation-play-state:paused}
.announce-group{display:flex; align-items:center; gap:18px; height:42px; white-space:nowrap; padding:0 28px; flex:none}
.announce b{color:var(--amber)}
@keyframes announceScroll{from{transform:translateX(0)} to{transform:translateX(-50%)}}
@keyframes announceGradient{0%{background-position:0% 50%} 50%{background-position:100% 50%} 100%{background-position:0% 50%}}
@media (prefers-reduced-motion: reduce){
  .announce-track{animation:none; justify-content:center; width:100%}
  .announce{animation:none; background-position:50% 50%}
}
.countdown{display:inline-flex; align-items:center; gap:6px; font-weight:700}
.countdown .seg{background:#07291a; color:var(--fresh); border-radius:6px; padding:3px 7px; font-variant-numeric:tabular-nums; min-width:30px; text-align:center; font-size:12.5px}

header.nav{position:sticky; top:0; z-index:50; background:rgba(244,240,230,.86); backdrop-filter:blur(12px); border-bottom:1px solid var(--line); transition:transform .3s ease}
.nav-inner{display:flex; align-items:center; justify-content:space-between; height:68px}
.logo{font-family:var(--news); font-size:23px; font-weight:600; letter-spacing:.06em; color:var(--forest); display:flex; align-items:center}
.logo img{height:34px; width:auto; display:block}
.nav-links{display:flex; gap:30px; font-size:14.5px; font-weight:600; color:var(--moss)}
.nav-links a:hover{color:var(--forest)}
.nav-cta{display:flex; align-items:center; gap:16px}
.nav-mini{background:var(--forest); color:var(--bone); padding:11px 20px; border-radius:999px; font-size:14px; font-weight:700}
.nav-mini:hover{background:var(--forest-2)}
.burger{display:none; flex-direction:column; gap:5px; padding:8px; background:none}
.burger span{width:22px; height:2px; background:var(--forest); border-radius:2px; transition:transform .25s, opacity .2s}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ============ MOBILE NAV MENU ============ */
.mobile-menu{position:fixed; top:0; right:0; bottom:0; width:min(82vw,340px); z-index:55; background:var(--bone); box-shadow:-12px 0 40px rgba(21,54,42,.18); transform:translateX(100%); transition:transform .32s cubic-bezier(.16,1,.3,1); display:flex; flex-direction:column; padding:96px 28px 32px; overflow-y:auto}
.mobile-menu.open{transform:none}
.mm-links{display:flex; flex-direction:column; gap:2px; margin-bottom:24px}
.mm-links a{font-family:var(--news); font-size:21px; font-weight:500; color:var(--forest); padding:13px 0; border-bottom:1px solid var(--line)}
.mm-links a:active{color:var(--fresh-deep)}
.mm-cta{width:100%; margin-bottom:14px}
.mm-wa{display:block; text-align:center; font-size:14px; font-weight:700; color:var(--fresh-deep); padding:12px}
.menu-backdrop{position:fixed; inset:0; z-index:54; background:rgba(17,34,27,.4); opacity:0; pointer-events:none; transition:opacity .3s}
.menu-backdrop.open{opacity:1; pointer-events:auto}

/* ============ HERO (centered, bottle behind headline) ============ */
.hero{background:radial-gradient(120% 80% at 50% 0%, #f8f5ec 0%, var(--bone) 55%); position:relative; overflow:hidden}
.hero-inner{display:flex; flex-direction:column; align-items:center; text-align:center; padding:30px 0 56px}
.hero-rating{display:inline-flex; align-items:center; gap:10px; background:#fff; border:1px solid var(--line); border-radius:999px; padding:7px 16px 7px 8px; font-size:13px; font-weight:600; color:var(--ink-soft); box-shadow:var(--shadow-sm)}
.hero-rating .avs{display:flex}
.hero-rating .avs i{width:24px;height:24px;border-radius:50%;border:2px solid #fff;margin-left:-9px;background-size:cover;background-position:center}
.hero-rating .avs i:first-child{margin-left:0}
.hero-rating b{color:var(--forest)}

.hero-feature{position:relative; width:100%; display:flex; align-items:center; justify-content:center; margin:14px 0 6px; min-height:380px}
.hero-glow{position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:min(560px,92vw); height:min(560px,92vw); border-radius:50%; background:radial-gradient(circle, rgba(70,177,110,.18), rgba(70,177,110,0) 62%); z-index:0}
.hero-bottle{position:absolute; top:55%; left:50%; transform:translate(-50%,-50%); height:min(400px,66vw); width:auto; aspect-ratio:892/1300; z-index:1; filter:drop-shadow(0 30px 46px rgba(21,54,42,.30)); animation:floaty 6s ease-in-out infinite}
@keyframes floaty{0%,100%{transform:translate(-50%,-50%)}50%{transform:translate(-50%,calc(-50% - 14px))}}
.hero h1{position:relative; z-index:2; font-family:var(--news); font-weight:500; font-size:clamp(40px,9vw,76px); line-height:.98; letter-spacing:-.02em; color:var(--forest); margin:0; text-shadow:0 2px 22px rgba(248,245,236,.92), 0 0 46px rgba(248,245,236,.85), 0 0 14px rgba(248,245,236,.95)}
.hero h1 em{font-style:italic; color:var(--fresh-deep)}
.hero-badge{position:absolute; z-index:3; background:rgba(255,255,255,.9); backdrop-filter:blur(4px); border:1px solid var(--line); border-radius:999px; padding:7px 13px; font-size:11px; font-weight:800; letter-spacing:.05em; color:var(--moss); text-transform:uppercase; box-shadow:var(--shadow-sm)}
.hero-badge.b1{top:8%; left:6%}
.hero-badge.b2{top:20%; right:5%}
.hero-badge.b3{bottom:12%; left:9%}

.hero-sub{font-size:clamp(15.5px,2.2vw,18px); line-height:1.55; color:var(--ink-soft); max-width:520px; margin:8px auto 24px}
.hero-sub b{color:var(--forest)}
.hero-checks{display:flex; flex-wrap:wrap; justify-content:center; gap:10px 18px; margin-bottom:26px; max-width:560px}
.hero-check{display:flex; align-items:center; gap:9px; font-size:14px; font-weight:600; color:#2a3a31}
.hero-check .ck{width:20px;height:20px;border-radius:50%;background:var(--sage);color:var(--forest);display:grid;place-items:center;font-size:11px;font-weight:800;flex:none}
.hero-ctas{display:flex; flex-direction:column; align-items:center; gap:14px}
.hero-ctas .btn-primary{font-size:17px; padding:19px 38px}
.hero-trustline{margin-top:24px; display:flex; align-items:center; justify-content:center; gap:10px; flex-wrap:wrap}
.hero-pill{background:#fff; border:1px solid var(--line); border-radius:999px; padding:9px 16px; box-shadow:var(--shadow-sm); font-size:13px; font-weight:600; color:#5e6e64}
.hero-pill b{color:var(--fresh-deep); font-family:var(--news); font-size:17px; margin-right:2px}
@media (min-width:760px){
  .hero-feature{min-height:480px; margin-top:20px}
  .hero-checks{gap:12px 26px}
}

/* ============ TRUST MARQUEE ============ */
.trust{background:var(--forest); padding:26px 0; overflow:hidden}
.trust-track{display:flex; gap:54px; white-space:nowrap; animation:marquee 28s linear infinite; width:max-content}
.trust:hover .trust-track{animation-play-state:paused}
.trust-item{display:inline-flex; align-items:center; gap:11px; color:#a9c4b2; font-size:14px; font-weight:700; letter-spacing:.03em}
.trust-item svg{width:20px;height:20px;flex:none;color:var(--fresh)}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============ PROBLEM (dark) ============ */
.problem{background:var(--forest); color:#e9f0ea; position:relative; overflow:hidden}
.problem::before{content:""; position:absolute; inset:0; background:radial-gradient(60% 50% at 80% 10%, rgba(70,177,110,.14), transparent 60%)}
.problem .wrap{position:relative; z-index:2}
.problem-head{max-width:780px}
.problem h2{font-family:var(--news); font-weight:500; font-size:50px; line-height:1.05; color:#fff; margin-top:18px}
.problem h2 em{font-style:italic; color:var(--fresh)}
.problem-lead{font-size:19px; line-height:1.6; color:#c4d6cb; margin:24px 0 0; max-width:620px}
.problem-tried{display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin:48px 0}
.tried-card{background:rgba(255,255,255,.05); border:1px solid var(--line-light); border-radius:18px; padding:26px 22px}
.tried-card .ic{font-size:30px; margin-bottom:14px}
.tried-card h4{font-size:16px; color:#fff; margin-bottom:8px}
.tried-card p{font-size:13.5px; line-height:1.5; color:#a9c4b2; margin:0}
.problem-turn{margin-top:40px; border-top:1px solid var(--line-light); padding-top:40px; display:grid; grid-template-columns:1fr 1fr; gap:46px; align-items:center}
.problem-turn .big{font-family:var(--news); font-weight:500; font-size:34px; line-height:1.18; color:#fff}
.problem-turn .big span{color:var(--fresh)}
.problem-turn ul{list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:14px}
.problem-turn li{display:flex; gap:13px; font-size:16px; color:#d3e2d8; align-items:flex-start}
.problem-turn li .x{width:24px;height:24px;border-radius:50%;background:rgba(220,90,80,.18);color:#f0a89f;display:grid;place-items:center;font-size:12px;font-weight:800;flex:none;margin-top:1px}
.problem-note{margin-top:30px; font-size:18px; color:#fff; font-weight:600}
.problem-note b{color:var(--fresh)}

/* ============ WHY NOTHING WORKS ============ */
.why{background:var(--bone)}
.why-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:18px}
.why-card{background:#fff; border:1px solid var(--line); border-radius:20px; padding:28px 24px; box-shadow:var(--shadow-sm)}
.why-card .ic{font-size:28px; margin-bottom:14px}
.why-card h4{font-size:18px; color:var(--forest); margin-bottom:14px}
.why-card ul{list-style:none; margin:0 0 16px; padding:0; display:flex; flex-direction:column; gap:9px}
.why-card li{display:flex; gap:9px; font-size:13.5px; color:var(--ink-soft); align-items:flex-start; line-height:1.4}
.why-card li .x{color:#cf6a5e; font-weight:800; flex:none}
.why-card .tag{font-size:13px; font-weight:700; color:var(--moss); padding-top:14px; border-top:1px solid var(--line)}
.why-foot{text-align:center; margin-top:50px}
.why-foot .big{font-family:var(--news); font-size:30px; color:var(--forest); font-weight:500; line-height:1.3; max-width:680px; margin:0 auto}
.why-foot .big em{font-style:italic; color:var(--fresh-deep)}

/* ============ WHO IS IT FOR ============ */
.who{background:var(--bone-2)}
.who-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:20px}
.who-card{background:#fff; border-radius:22px; overflow:hidden; box-shadow:var(--shadow-sm); border:1px solid var(--line); transition:transform .2s ease, box-shadow .2s ease}
.who-card:hover{transform:translateY(-4px); box-shadow:var(--shadow)}
.who-photo{aspect-ratio:16/11; background:var(--sage); background-size:cover; background-position:center; position:relative}
.who-tag{position:absolute; top:14px; left:14px; background:rgba(7,41,26,.82); backdrop-filter:blur(3px); color:#dff0e4; font-size:11.5px; font-weight:700; letter-spacing:.04em; padding:6px 12px; border-radius:999px; text-transform:uppercase}
.who-body{padding:22px 24px 26px}
.who-body h3{font-family:var(--news); font-size:23px; color:var(--forest); font-weight:600; font-style:italic; margin-bottom:14px}
.who-body ul{list-style:none; margin:0 0 18px; padding:0; display:flex; flex-direction:column; gap:8px}
.who-body li{display:flex; gap:9px; font-size:14px; color:var(--ink-soft); align-items:flex-start; line-height:1.4}
.who-body li .x{color:#cf6a5e; font-weight:800; flex:none}
.who-result{display:inline-flex; align-items:center; gap:8px; background:var(--fresh-soft); color:var(--fresh-deep); font-size:13px; font-weight:800; padding:9px 15px; border-radius:999px}
.who-result::before{content:"→"; font-weight:800}

/* ============ MECHANISM (dark) ============ */
.mech{background:var(--forest); color:#e9f0ea; overflow:hidden}
.mech-metaphor{text-align:center; max-width:720px; margin:0 auto 60px}
.mech-metaphor h2{font-family:var(--news); font-weight:500; font-size:46px; line-height:1.08; color:#fff; margin-top:16px}
.mech-metaphor h2 em{font-style:italic; color:var(--fresh)}
.mech-metaphor p{font-size:18px; line-height:1.6; color:#bcd0c2; margin-top:20px}
.mech-stages{display:grid; grid-template-columns:repeat(3,1fr); gap:22px}
.stage{background:rgba(255,255,255,.05); border:1px solid var(--line-light); border-radius:22px; overflow:hidden}
.stage-img{aspect-ratio:16/10; background:#0f2a20; background-size:cover; background-position:center; position:relative}
.stage-num{position:absolute; top:14px; left:14px; background:var(--fresh); color:#07291a; font-size:12px; font-weight:800; padding:5px 12px; border-radius:999px; letter-spacing:.04em}
.stage-body{padding:24px 24px 28px}
.stage-body .ic{font-size:26px; margin-bottom:12px}
.stage-body h3{font-size:21px; color:#fff; margin-bottom:10px}
.stage-body p{font-size:14.5px; line-height:1.55; color:#bcd0c2; margin:0 0 16px}
.stage-body .out{display:inline-flex; align-items:center; gap:8px; color:var(--fresh); font-size:13.5px; font-weight:800}
.stage-body .out::before{content:"✓"}

/* ============ INGREDIENTS (carousel) ============ */
.ingr{background:var(--bone); overflow:hidden}
.rail-hint{text-align:center; font-size:13px; font-weight:700; letter-spacing:.04em; color:var(--moss); margin-top:-26px; margin-bottom:30px; opacity:.8}
.ingr-rail{display:flex; gap:18px; overflow-x:auto; scroll-snap-type:x mandatory; padding:4px max(28px,calc((100vw - var(--maxw))/2 + 28px)) 26px; scrollbar-width:none}
.ingr-rail::-webkit-scrollbar{display:none}
.ingr-card{flex:0 0 290px; scroll-snap-align:center; background:#fff; border:1px solid var(--line); border-radius:22px; overflow:hidden; box-shadow:var(--shadow-sm); display:flex; flex-direction:column}
.ingr-card.hero{border:2px solid var(--fresh); box-shadow:var(--shadow)}
.ingr-card .img{aspect-ratio:4/3; background:var(--sage); background-size:cover; background-position:center; position:relative}
.ingr-ribbon{position:absolute; top:12px; left:12px; background:var(--fresh); color:#07291a; font-size:11.5px; font-weight:800; padding:6px 13px; border-radius:999px; letter-spacing:.03em}
.ingr-card .b{padding:20px 22px 24px; flex:1; display:flex; flex-direction:column}
.ingr-card h4{font-family:var(--news); font-size:22px; color:var(--forest); font-weight:600; margin-bottom:4px}
.ingr-card .nick{font-style:italic; font-family:var(--news); font-size:15px; color:var(--fresh-deep); margin-bottom:10px}
.ingr-card .role{font-size:12px; font-weight:800; color:var(--fresh-deep); text-transform:uppercase; letter-spacing:.04em; margin-bottom:10px}
.ingr-card p{font-size:13.5px; line-height:1.55; color:var(--ink-soft); margin:0}
.ingr-tags{display:flex; flex-wrap:wrap; gap:7px; margin-top:14px}
.ingr-tags span{background:var(--bone-2); color:var(--moss); font-size:11.5px; font-weight:700; padding:6px 11px; border-radius:999px}

/* ============ TRANSPARENCY (supplement facts + certs) ============ */
.trans{background:var(--bone-2); overflow:hidden}
.trans-grid{display:grid; grid-template-columns:1fr 1fr; gap:26px; align-items:start; margin-bottom:36px}
.trans-facts{background:#fff; border:1px solid var(--line); border-radius:22px; padding:24px; box-shadow:var(--shadow-sm)}
.tf-head{display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:16px; flex-wrap:wrap}
.tf-head h3{font-family:var(--news); font-size:24px; color:var(--forest); font-weight:600}
.tf-pill{background:var(--bone-2); color:var(--moss); font-size:12px; font-weight:700; padding:7px 13px; border-radius:999px}
.tf-img{position:relative; display:block; border-radius:14px; overflow:hidden; border:1px solid var(--line); cursor:zoom-in}
.tf-img img{width:100%; display:block}
.tf-zoom{position:absolute; bottom:12px; right:12px; background:rgba(7,41,26,.82); backdrop-filter:blur(3px); color:#fff; font-size:12px; font-weight:700; padding:7px 13px; border-radius:999px}
.trans-side{display:flex; flex-direction:column; gap:20px; position:sticky; top:90px}
.trans-actives{background:var(--forest); color:#e9f0ea; border-radius:22px; padding:28px 30px}
.trans-actives h4{font-family:var(--news); font-size:22px; color:#fff; font-weight:600; margin-bottom:18px}
.trans-actives ul{list-style:none; margin:0 0 20px; padding:0; display:flex; flex-direction:column}
.trans-actives li{display:flex; align-items:center; justify-content:space-between; gap:14px; padding:13px 0; border-bottom:1px solid rgba(255,255,255,.12)}
.trans-actives li:last-child{border-bottom:none}
.trans-actives li span{font-size:14.5px; color:#dbe7df; font-weight:600}
.trans-actives li small{display:block; font-size:12px; color:#9fbaa8; font-weight:500; margin-top:2px}
.trans-actives li b{font-family:var(--news); font-size:19px; color:var(--fresh); white-space:nowrap}
.trans-free{background:rgba(70,177,110,.14); border:1px solid rgba(70,177,110,.3); border-radius:13px; padding:13px 16px; font-size:13px; font-weight:600; color:#cdeed7; line-height:1.4}

.cert-band{background:#fff; border:1px solid var(--line); border-radius:24px; padding:30px; box-shadow:var(--shadow-sm)}
.cert-band-head{text-align:center; margin-bottom:24px}
.cert-band-head h3{font-family:var(--news); font-size:26px; color:var(--forest); font-weight:600; margin-bottom:6px}
.cert-band-head p{font-size:14px; color:var(--ink-soft); margin:0}
.cert-rail{display:flex; gap:16px; overflow-x:auto; scroll-snap-type:x mandatory; padding:4px 4px 22px; scrollbar-width:none}
.cert-rail::-webkit-scrollbar{display:none}
.cert-card{flex:0 0 230px; scroll-snap-align:center; border:1px solid var(--line); border-radius:16px; overflow:hidden; background:var(--forest); cursor:zoom-in; transition:transform .18s ease, box-shadow .2s ease; display:flex; flex-direction:column}
.cert-card:hover{transform:translateY(-4px); box-shadow:var(--shadow)}
.cert-card img{width:100%; aspect-ratio:1/1; object-fit:cover; object-position:center; display:block}
.cert-cap{padding:14px 15px 16px; text-align:center; background:#fff; flex:1; display:flex; flex-direction:column; justify-content:center}
.cert-cap b{display:block; font-size:13.5px; color:var(--forest); margin-bottom:3px; line-height:1.25}
.cert-cap span{font-size:11.5px; color:#7a897f}

/* ============ LIGHTBOX ============ */
.lightbox{position:fixed; inset:0; z-index:95; background:rgba(8,18,13,.88); backdrop-filter:blur(6px); display:none; align-items:center; justify-content:center; padding:32px; cursor:zoom-out}
.lightbox.open{display:flex}
.lightbox img{max-width:96%; max-height:92vh; border-radius:12px; box-shadow:0 30px 80px rgba(0,0,0,.6)}
.lightbox-close{position:absolute; top:20px; right:24px; width:44px; height:44px; border-radius:50%; background:rgba(255,255,255,.14); color:#fff; font-size:26px; line-height:1; display:grid; place-items:center}
.lightbox-close:hover{background:rgba(255,255,255,.26)}
.timeline{background:var(--bone-2)}
.tl-track{display:grid; grid-template-columns:repeat(5,1fr); gap:16px; position:relative}
.tl-track::before{content:""; position:absolute; top:34px; left:6%; right:6%; height:2px; background:linear-gradient(90deg,var(--sage),var(--fresh),var(--fresh-deep)); z-index:0}
.tl-step{position:relative; z-index:1; text-align:center}
.tl-dot{width:68px; height:68px; border-radius:50%; background:#fff; border:2px solid var(--fresh); display:grid; place-items:center; font-size:28px; margin:0 auto 18px; box-shadow:var(--shadow-sm)}
.tl-day{font-size:12px; font-weight:800; letter-spacing:.08em; color:var(--fresh-deep); text-transform:uppercase}
.tl-step h4{font-size:17px; color:var(--forest); margin:8px 0 8px; line-height:1.2}
.tl-step p{font-size:13.5px; line-height:1.5; color:var(--ink-soft); margin:0 0 10px}
.tl-feel{display:inline-block; font-size:12px; font-weight:700; color:var(--moss); background:#fff; border:1px solid var(--line); padding:6px 12px; border-radius:999px}
.tl-report{margin-top:54px; background:var(--forest); color:#e9f0ea; border-radius:24px; padding:40px 44px; display:grid; grid-template-columns:auto 1fr; gap:36px; align-items:center}
.tl-report .big{font-family:var(--news); font-size:26px; color:#fff; font-weight:500; line-height:1.3; max-width:280px}
.tl-report ul{list-style:none; margin:0; padding:0; display:grid; grid-template-columns:1fr 1fr; gap:14px}
.tl-report li{display:flex; gap:11px; font-size:15px; color:#d3e2d8; align-items:flex-start; line-height:1.4}
.tl-report li .c{color:var(--fresh); font-weight:800; flex:none}

/* ============ COMPARISON (dark) ============ */
.compare{background:var(--forest); color:#e9f0ea}
.cmp-table{max-width:920px; margin:0 auto; background:rgba(255,255,255,.04); border:1px solid var(--line-light); border-radius:24px; overflow:hidden}
.cmp-row{display:grid; grid-template-columns:1.3fr 1fr 1fr; border-bottom:1px solid var(--line-light)}
.cmp-row:last-child{border-bottom:none}
.cmp-row > div{padding:20px 24px; display:flex; flex-direction:column; gap:3px; justify-content:center}
.cmp-row.head > div{padding:24px}
.cmp-feature{font-size:15px; font-weight:700; color:#fff}
.cmp-head-spiro{background:var(--fresh); color:#07291a; text-align:center; align-items:center}
.cmp-head-spiro .t{font-family:var(--news); font-size:22px; font-weight:600}
.cmp-head-spiro .s{font-size:11px; font-weight:800; letter-spacing:.08em; text-transform:uppercase; opacity:.8}
.cmp-head-gen{text-align:center; align-items:center; color:#a9c4b2}
.cmp-head-gen .t{font-size:18px; font-weight:700; color:#cdddd3}
.cmp-val{text-align:center; align-items:center}
.cmp-val .good{color:#fff; font-weight:700; font-size:15px; display:flex; gap:7px; align-items:center; justify-content:center}
.cmp-val .good .c{color:var(--fresh); font-weight:800}
.cmp-val .sub{font-size:12px; color:#9fbaa8}
.cmp-val .bad{color:#8aa597; font-weight:600; font-size:14.5px; display:flex; gap:7px; align-items:center; justify-content:center}
.cmp-val .bad .x{color:#cf7a6e}
.cmp-spiro-col{background:rgba(70,177,110,.07)}

/* ============ PROOF / STATS ============ */
.proof{background:var(--bone)}
.stats-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-bottom:30px}
.stat{background:#fff; border:1px solid var(--line); border-radius:20px; padding:34px 26px; text-align:center; box-shadow:var(--shadow-sm)}
.stat .n{font-family:var(--news); font-size:52px; font-weight:600; color:var(--fresh-deep); line-height:.9}
.stat .l{font-size:14px; font-weight:700; color:var(--forest); margin-top:12px}
.stat .src{font-size:11.5px; color:#7a897f; margin-top:8px; line-height:1.4}
.proof-note{text-align:center; font-size:13px; color:#7a897f; max-width:640px; margin:0 auto}

/* ============ ADVISORY ============ */
.advisory{background:var(--bone-2)}
.adv-rail{display:flex; gap:20px; overflow-x:auto; scroll-snap-type:x mandatory; padding:6px 4px 24px; scrollbar-width:none}
.adv-rail::-webkit-scrollbar{display:none}
.adv-card{flex:0 0 282px; scroll-snap-align:start; background:#fff; border:1px solid var(--line); border-radius:22px; overflow:hidden; box-shadow:var(--shadow-sm); display:flex; flex-direction:column}
.adv-photo{height:256px; background:linear-gradient(180deg,#f1f5ee 0%,var(--sage) 100%); display:flex; align-items:flex-end; justify-content:center; position:relative; overflow:hidden}
.adv-photo::after{content:""; position:absolute; left:14%; right:14%; bottom:0; height:8px; background:rgba(21,54,42,.12); filter:blur(7px); border-radius:50%}
.adv-photo img{position:relative; z-index:1; height:99%; width:auto; max-width:100%; object-fit:contain; object-position:bottom center; filter:drop-shadow(0 10px 14px rgba(21,54,42,.14))}
.adv-b{background:var(--forest); color:#e9f0ea; padding:20px 22px 24px; flex:1; display:flex; flex-direction:column; gap:9px}
.adv-b h4{font-family:var(--news); font-size:20px; color:#fff; font-weight:600; line-height:1.1}
.adv-b .role{font-size:11px; font-weight:800; letter-spacing:.05em; text-transform:uppercase; color:var(--fresh); margin-top:-4px}
.adv-b p{font-size:12px; line-height:1.55; color:#b6cabd; margin:0}
.adv-count{text-align:center; font-size:13px; color:#7a897f; font-weight:600; margin-top:8px}

/* ============ BEFORE / AFTER ============ */
.results{background:var(--bone)}
.ba-rail{display:flex; gap:20px; overflow-x:auto; scroll-snap-type:x mandatory; padding:6px 4px 22px; scrollbar-width:none}
.ba-rail::-webkit-scrollbar{display:none}
.ba-card{flex:0 0 320px; scroll-snap-align:start; background:#fff; border:1px solid var(--line); border-radius:22px; overflow:hidden; box-shadow:var(--shadow-sm)}
.ba-img{aspect-ratio:4/3; background:var(--sage); background-size:cover; background-position:center; position:relative}
.ba-img.sq{aspect-ratio:1/1; background-color:var(--bone)}
/* ---- image-save deterrent (whole page) ---- */
img,.ba-img,.who-photo,.ugc-img,.bonus-img,.hero-bottle,.fb-card img,.ingr-card .img{
  -webkit-user-drag:none; -khtml-user-drag:none; user-drag:none;
  -webkit-user-select:none; -moz-user-select:none; user-select:none;
  -webkit-touch-callout:none;
}
.ba-badge{position:absolute; bottom:12px; left:12px; background:rgba(7,41,26,.82); color:#dff0e4; font-size:11px; font-weight:700; padding:6px 11px; border-radius:999px}
.ba-b{padding:18px 22px 22px}
.ba-b .nm{font-size:16px; font-weight:800; color:var(--forest)}
.ba-b .qt{font-size:14px; line-height:1.5; color:var(--ink-soft); margin:8px 0 12px; font-style:italic}
.ba-b .tr{font-size:12px; font-weight:700; color:var(--fresh-deep)}
.rail-ctrls{display:flex; gap:10px; justify-content:center; margin-top:14px}
.rail-btn{width:46px;height:46px;border-radius:50%;background:#fff;border:1px solid var(--line);color:var(--forest);font-size:18px;display:grid;place-items:center;box-shadow:var(--shadow-sm); transition:background .15s}
.rail-btn:hover{background:var(--bone-2)}
.ba-stats{display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:46px; text-align:center}
.ba-stats .n{font-family:var(--news); font-size:40px; color:var(--forest); font-weight:600}
.ba-stats .l{font-size:13.5px; color:var(--ink-soft); margin-top:4px; font-weight:600}

/* ============ REVIEWS (rail) ============ */
.reviews{background:var(--bone-2); overflow:hidden}
.rev-rail{display:flex; gap:18px; overflow-x:auto; scroll-snap-type:x mandatory; padding:6px 4px 24px; scrollbar-width:none}
.rev-rail::-webkit-scrollbar{display:none}
.rev-card{flex:0 0 340px; scroll-snap-align:start; background:#fff; border:1px solid var(--line); border-radius:18px; padding:26px; box-shadow:var(--shadow-sm); display:flex; flex-direction:column}
.rev-card .stars{font-size:13px; margin-bottom:12px}
.rev-card h4{font-size:17px; color:var(--forest); margin-bottom:8px; font-family:var(--news); font-style:italic; font-weight:600}
.rev-card p{font-size:14px; line-height:1.55; color:var(--ink-soft); margin:0 0 16px; flex:1}
.rev-who{display:flex; align-items:center; gap:11px}
.rev-av{width:38px;height:38px;border-radius:50%;background:var(--sage);color:var(--forest);display:grid;place-items:center;font-weight:800;font-size:14px}
.rev-who .nm{font-size:13.5px; font-weight:800; color:var(--ink)}
.rev-who .loc{font-size:12px; color:#7a897f}
.rev-verified{margin-left:auto; font-size:11px; font-weight:700; color:var(--fresh-deep); display:flex; align-items:center; gap:4px}

/* ============ UGC ============ */
.ugc{background:var(--bone); overflow:hidden}
.ugc-marquee{overflow:hidden; padding:4px 0 22px; -webkit-mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent); mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent)}
.ugc-track{display:flex; gap:14px; width:max-content; animation:ugcScroll 30s linear infinite; will-change:transform; transform:translateZ(0); backface-visibility:hidden}
.ugc-marquee:hover .ugc-track{animation-play-state:paused}
@keyframes ugcScroll{from{transform:translate3d(0,0,0)} to{transform:translate3d(-50%,0,0)}}
@media (prefers-reduced-motion: reduce){ .ugc-track{animation:none} .ugc-marquee{overflow-x:auto}}
/* Mobile: drop the GPU-expensive mask so the marquee stays smooth */
@media (max-width:768px){ .ugc-marquee{-webkit-mask-image:none; mask-image:none} .ugc-track{animation-duration:20s} }
.ugc-card{flex:0 0 230px; margin:0; position:relative; border-radius:18px; overflow:hidden; box-shadow:var(--shadow-sm)}
.ugc-img{aspect-ratio:4/5; background:var(--sage); background-size:cover; background-position:center}
.ugc-card figcaption{position:absolute; bottom:10px; left:10px; background:rgba(7,41,26,.9); color:#fff; font-size:12px; font-weight:700; padding:6px 12px; border-radius:999px}

/* ============ DM FEEDBACK ============ */
.feedback{background:var(--bone-2); overflow:hidden}
.fb-rail{display:flex; gap:16px; overflow-x:auto; scroll-snap-type:x mandatory; padding:4px max(28px,calc((100vw - var(--maxw))/2 + 28px)) 24px; scrollbar-width:none}
.fb-rail::-webkit-scrollbar{display:none}
.fb-card{position:relative; flex:0 0 250px; scroll-snap-align:center; border-radius:18px; overflow:hidden; background:#fff; border:1px solid var(--line); box-shadow:var(--shadow-sm); height:340px; cursor:zoom-in; transition:transform .18s ease, box-shadow .2s ease}
.fb-card:hover{transform:translateY(-4px); box-shadow:var(--shadow)}
.fb-card img{width:100%; height:100%; object-fit:cover; object-position:top center; display:block}
.fb-card::after{content:""; position:absolute; left:0; right:0; bottom:0; height:80px; background:linear-gradient(to top, rgba(255,255,255,.96), rgba(255,255,255,0))}
.fb-zoom{position:absolute; left:50%; bottom:14px; transform:translateX(-50%); z-index:2; background:var(--forest); color:#fff; font-size:12px; font-weight:700; padding:8px 15px; border-radius:999px; white-space:nowrap; box-shadow:var(--shadow-sm)}
.fb-note{text-align:center; font-size:12.5px; color:#7a897f; margin-top:6px}

/* ============ PRICING ============ */
.price-showcase{display:flex; flex-direction:column; align-items:center; gap:18px; margin:-14px auto 34px; max-width:560px}
.price-showcase img{height:200px; width:auto; filter:drop-shadow(0 22px 36px rgba(0,0,0,.4))}
.ps-tags{display:flex; flex-wrap:wrap; justify-content:center; gap:10px}
.ps-tags span{background:rgba(255,255,255,.08); border:1px solid var(--line-light); color:#dbe7df; font-size:13px; font-weight:700; padding:9px 15px; border-radius:999px}
.pricing{background:var(--forest); color:#e9f0ea}
.price-urgency{text-align:center; color:var(--amber); font-weight:700; font-size:14px; margin-bottom:24px; display:flex; align-items:center; justify-content:center; gap:8px}
.price-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:20px; max-width:980px; margin:0 auto; align-items:stretch}
.price-card{background:rgba(255,255,255,.05); border:1.5px solid var(--line-light); border-radius:24px; padding:30px 28px; position:relative; cursor:pointer; transition:transform .2s ease, border-color .2s ease, background .2s ease; display:flex; flex-direction:column}
.price-card:hover{transform:translateY(-4px)}
.price-card.featured{background:#fff; color:var(--ink); border-color:var(--fresh); box-shadow:var(--shadow-lg)}
.price-tagtop{position:absolute; top:-13px; left:50%; transform:translateX(-50%); background:var(--fresh); color:#07291a; font-size:12px; font-weight:800; padding:6px 16px; border-radius:999px; letter-spacing:.04em; white-space:nowrap}
.price-card .pname{font-size:14px; font-weight:800; letter-spacing:.04em; text-transform:uppercase; color:#9fbaa8}
.price-card.featured .pname{color:var(--fresh-deep)}
.price-card .pqty{font-family:var(--news); font-size:26px; font-weight:600; color:#fff; margin:6px 0 4px}
.price-card.featured .pqty{color:var(--forest)}
.price-card .pdesc{font-size:13px; color:#9fbaa8; margin-bottom:20px}
.price-card.featured .pdesc{color:var(--ink-soft)}
.price-amounts{display:flex; align-items:baseline; gap:10px; margin-bottom:6px}
.price-now{font-family:var(--news); font-size:44px; font-weight:600; color:#fff}
.price-card.featured .price-now{color:var(--forest)}
.price-was{font-size:18px; color:#7e988a; text-decoration:line-through}
.price-per{font-size:13px; color:#9fbaa8; margin-bottom:22px}
.price-card.featured .price-per{color:var(--ink-soft)}
.price-save{display:inline-block; background:var(--fresh-soft); color:var(--fresh-deep); font-size:12.5px; font-weight:800; padding:6px 13px; border-radius:999px; margin-bottom:18px; align-self:flex-start}
.price-atome{font-size:12.5px; color:#9fbaa8; font-weight:600; margin:-12px 0 14px}
.price-card.featured .price-atome{color:var(--ink-soft)}
.price-feats{list-style:none; margin:0 0 18px; padding:0; display:flex; flex-direction:column; gap:9px}
.price-feats li{position:relative; padding-left:24px; font-size:13.5px; line-height:1.4; color:#c8d8cd}
.price-card.featured .price-feats li{color:var(--ink-soft)}
.price-feats li b{color:#fff}
.price-card.featured .price-feats li b{color:var(--forest)}
.price-feats li::before{content:"✓"; position:absolute; left:0; top:0; color:var(--fresh); font-weight:800}
.price-ships{font-size:12.5px; color:#9fbaa8; font-weight:600; margin-bottom:16px}
.price-card.featured .price-ships{color:var(--fresh-deep)}
.price-stock{margin-bottom:18px}
.price-stock .bar{height:8px; border-radius:999px; background:rgba(21,54,42,.12); overflow:hidden; margin-bottom:7px}
.price-stock .bar span{display:block; height:100%; background:linear-gradient(90deg,var(--amber),#e8893f); border-radius:999px}
.price-stock .lbl{font-size:12px; font-weight:700; color:#c0682f}
.price-cta{margin-top:auto; width:100%; text-align:center; padding:16px; border-radius:14px; font-weight:800; font-size:15px; background:rgba(255,255,255,.1); color:#fff; transition:background .2s}
.price-card.featured .price-cta{background:var(--fresh); color:#07291a}
.price-card.featured .price-cta:hover{background:#54c47d}
.price-card:not(.featured) .price-cta:hover{background:rgba(255,255,255,.18)}
.price-trust{display:flex; justify-content:center; gap:26px; margin-top:34px; flex-wrap:wrap; font-size:13px; color:#bcd0c2; font-weight:600}
.price-trust span{display:flex; align-items:center; gap:8px}
.price-pay{display:flex; justify-content:center; gap:10px; margin-top:18px; opacity:.85; font-size:12px; color:#9fbaa8; font-weight:700; flex-wrap:wrap}

/* ============ BONUS STACK ============ */
.bonus{background:var(--bone)}
.bonus-wrap{display:grid; grid-template-columns:.9fr 1.1fr; gap:40px; align-items:center; background:#fff; border:1px solid var(--line); border-radius:26px; padding:14px; box-shadow:var(--shadow-sm); overflow:hidden}
.bonus-img{aspect-ratio:1/1; border-radius:18px; background:var(--sage) center/cover}
.bonus-info{padding:26px 34px 26px 0}
.bonus-info h2{font-family:var(--news); font-size:34px; color:var(--forest); font-weight:500; margin-bottom:6px}
.bonus-info > p{font-size:15px; color:var(--ink-soft); margin:0 0 22px}
.bonus-list{display:flex; flex-direction:column; gap:14px; margin-bottom:24px}
.bonus-item{display:flex; align-items:center; gap:14px; padding-bottom:14px; border-bottom:1px solid var(--line)}
.bonus-item:last-child{border-bottom:none; padding-bottom:0}
.bonus-ic{width:42px;height:42px;border-radius:12px;background:var(--fresh-soft);color:var(--fresh-deep);display:grid;place-items:center;font-size:20px;flex:none}
.bonus-item .bt{flex:1}
.bonus-item h4{font-size:15.5px; color:var(--forest); margin-bottom:2px}
.bonus-item p{font-size:13px; color:var(--ink-soft); margin:0}
.bonus-val{font-size:14px; font-weight:800; color:var(--fresh-deep); white-space:nowrap}
.bonus-val .was{color:#a99; text-decoration:line-through; font-size:12.5px; margin-right:6px}
.bonus-total{display:flex; align-items:center; justify-content:space-between; background:var(--forest); color:#fff; border-radius:16px; padding:18px 24px}
.bonus-total .tt{font-size:15px; font-weight:700}
.bonus-total .tv{font-family:var(--news); font-size:26px; font-weight:600; color:var(--fresh)}

/* ============ BUY WITH CONFIDENCE ============ */
.confidence{background:var(--sage)}
.conf-wrap{display:grid; grid-template-columns:1fr 1fr; gap:46px; align-items:center; max-width:980px; margin:0 auto}
.conf-left{display:flex; flex-direction:column}
.conf-seal{margin-bottom:22px}
.conf-seal .ring{width:128px; height:128px; border-radius:50%; background:#fff; border:3px solid var(--fresh); display:flex; flex-direction:column; align-items:center; justify-content:center; box-shadow:var(--shadow); text-align:center}
.conf-seal .pct{font-family:var(--news); font-size:34px; font-weight:600; color:var(--fresh-deep); line-height:.9}
.conf-seal .word{font-size:12px; font-weight:800; letter-spacing:.1em; text-transform:uppercase; color:var(--forest); margin-top:4px}
.conf-left h2{font-family:var(--news); font-size:36px; color:var(--forest); font-weight:500; margin:14px 0; padding-bottom:.08em}
.conf-left p{font-size:16px; line-height:1.6; color:var(--ink-soft); margin:0 0 20px}
.conf-left p b{color:var(--forest)}
.conf-exchange{background:rgba(255,255,255,.7); border:1px solid rgba(21,54,42,.12); border-radius:14px; padding:14px 18px; font-size:14px; color:var(--ink-soft)}
.conf-exchange b{color:var(--forest)}
.conf-right{display:flex; flex-direction:column; gap:14px}
.conf-item{display:flex; gap:16px; background:#fff; border:1px solid var(--line); border-radius:18px; padding:22px 24px; box-shadow:var(--shadow-sm)}
.conf-item .num{width:34px; height:34px; border-radius:50%; background:var(--forest); color:#fff; display:grid; place-items:center; font-weight:800; font-size:15px; flex:none}
.conf-item h4{font-size:17px; color:var(--forest); margin-bottom:5px}
.conf-item p{font-size:14px; line-height:1.5; color:var(--ink-soft); margin:0}

/* ============ FAQ ============ */
.faq{background:var(--bone)}
.faq-tabs{display:flex; gap:10px; justify-content:center; margin-bottom:32px; flex-wrap:wrap}
.faq-tab{background:#fff; border:1px solid var(--line); color:var(--moss); padding:11px 22px; border-radius:999px; font-size:14px; font-weight:700; transition:all .15s}
.faq-tab.active{background:var(--forest); color:var(--bone); border-color:var(--forest)}
.faq-list{max-width:780px; margin:0 auto}
.faq-item{background:#fff; border:1px solid var(--line); border-radius:16px; margin-bottom:12px; overflow:hidden}
.faq-q{display:flex; align-items:center; justify-content:space-between; gap:16px; padding:22px 26px; font-size:16px; font-weight:700; color:var(--forest); cursor:pointer; background:none; width:100%; text-align:left}
.faq-q .pm{width:26px;height:26px;border-radius:50%;background:var(--bone-2);color:var(--forest);display:grid;place-items:center;font-size:18px;flex:none;transition:transform .25s}
.faq-item.open .faq-q .pm{transform:rotate(45deg); background:var(--fresh); color:#fff}
.faq-a{max-height:0; overflow:hidden; transition:max-height .3s ease}
.faq-a p{padding:0 26px 24px; font-size:15px; line-height:1.6; color:var(--ink-soft); margin:0}
.faq-grp{display:none}
.faq-grp.active{display:block}
.faq-more{text-align:center; margin-top:30px; font-size:15px; color:var(--ink-soft)}

/* ============ FINAL CTA ============ */
.final{background:var(--forest); color:#e9f0ea; text-align:center; position:relative; overflow:hidden}
.final::before{content:""; position:absolute; inset:0; background:radial-gradient(50% 60% at 50% 0%, rgba(70,177,110,.18), transparent 60%)}
.final .wrap{position:relative; z-index:2; max-width:760px}
.final h2{font-family:var(--news); font-weight:500; font-size:52px; line-height:1.05; color:#fff; margin:18px 0 22px}
.final h2 em{font-style:italic; color:var(--fresh)}
.final p{font-size:18px; line-height:1.6; color:#c4d6cb; margin:0 auto 34px; max-width:600px}
.final-meta{margin-top:26px; font-size:14px; color:#bcd0c2; display:flex; gap:24px; justify-content:center; flex-wrap:wrap; font-weight:600}
.final-meta span{display:flex; align-items:center; gap:8px}

/* ============ WHATSAPP ============ */
.wa{background:var(--bone)}
.wa-card{background:#fff; border:1px solid var(--line); border-radius:24px; padding:44px; text-align:center; max-width:680px; margin:0 auto; box-shadow:var(--shadow-sm)}
.wa-card .ic{width:64px;height:64px;border-radius:50%;background:var(--fresh-soft);display:grid;place-items:center;font-size:30px;margin:0 auto 20px}
.wa-card h3{font-family:var(--news); font-size:28px; color:var(--forest); font-weight:500; margin-bottom:12px}
.wa-card p{font-size:15.5px; line-height:1.6; color:var(--ink-soft); margin:0 auto 24px; max-width:480px}
.wa-card .reply{margin-top:16px; font-size:13px; color:#7a897f; font-weight:600}

/* ============ FOOTER ============ */
footer.ft{background:var(--ink); color:#a9b8af; padding:60px 0 32px}
.ft-grid{display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:40px; padding-bottom:36px; border-bottom:1px solid rgba(255,255,255,.1)}
.ft-logoimg{height:30px; width:auto; margin-bottom:16px; filter:brightness(0) invert(1); opacity:.95}
.ft-grid p{font-size:14px; line-height:1.6; margin:0 0 18px; max-width:320px}
.ft-trust{display:flex; flex-direction:column; gap:8px; margin-bottom:18px}
.ft-trust span{font-size:13px; color:#c2cfc7}
.ft-social{display:flex; gap:14px; flex-wrap:wrap}
.ft-social a{font-size:13px; font-weight:700; color:#dfe8e2; background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.1); padding:9px 14px; border-radius:999px}
.ft-social a:hover{background:rgba(255,255,255,.14)}
.ft-col h5{font-size:13px; font-weight:800; letter-spacing:.06em; text-transform:uppercase; color:#dfe8e2; margin-bottom:16px}
.ft-col a{display:block; font-size:14px; margin-bottom:11px; color:#a9b8af}
.ft-col a:hover{color:#fff}
.ft-pay{padding:22px 0; font-size:13px; color:#c2cfc7; border-bottom:1px solid rgba(255,255,255,.1)}
.ft-pay span{font-weight:700; color:#8fa399; margin-right:6px}
.ft-bottom{display:flex; justify-content:space-between; align-items:center; padding-top:24px; font-size:12.5px; flex-wrap:wrap; gap:14px}
.ft-bottom span:last-child{max-width:560px; text-align:right; opacity:.8}

/* ============ STICKY MOBILE CTA ============ */
.sticky-cta{position:fixed; bottom:0; left:0; right:0; z-index:60; background:rgba(244,240,230,.95); backdrop-filter:blur(12px); border-top:1px solid var(--line); padding:12px 18px; display:none; align-items:center; gap:14px; box-shadow:0 -8px 24px rgba(21,54,42,.1)}
.sticky-cta .info{flex:1}
.sticky-cta .info .p{font-weight:800; color:var(--forest); font-size:16px}
.sticky-cta .info .p .was{color:#a99; text-decoration:line-through; font-size:13px; font-weight:600; margin-left:6px}
.sticky-cta .info .s{font-size:11.5px; color:var(--fresh-deep); font-weight:700}
.sticky-cta .btn{padding:15px 26px; font-size:15px}

/* ============ FLOATING CONTACT FAB (WhatsApp) ============ */
.fab-wa{position:fixed; right:20px; bottom:24px; z-index:70; display:inline-flex; align-items:center; gap:10px; background:#25D366; color:#063d1b; font-weight:800; font-size:14.5px; padding:13px 20px 13px 16px; border-radius:999px; box-shadow:0 12px 30px rgba(37,211,102,.42); transition:transform .15s, box-shadow .2s}
.fab-wa:hover{transform:translateY(-2px); box-shadow:0 16px 36px rgba(37,211,102,.5)}
.fab-ic{font-size:20px; line-height:1}
.fab-badge{display:none; position:absolute; top:-7px; right:-6px; background:var(--forest); color:#fff; font-size:10px; font-weight:800; letter-spacing:.03em; padding:3px 8px; border-radius:999px; box-shadow:var(--shadow-sm)}

/* ============ LIVE ORDER TOAST (slides from left) ============ */
.order-toast{position:fixed; left:20px; bottom:24px; z-index:65; display:flex; align-items:center; gap:13px; background:#fff; border:1px solid var(--line); border-radius:16px; padding:13px 16px 13px 13px; box-shadow:var(--shadow-lg); max-width:330px; transform:translateX(-130%); opacity:0; transition:transform .5s cubic-bezier(.16,1,.3,1), opacity .4s}
.order-toast.show{transform:none; opacity:1}
.ot-av{width:44px;height:44px;border-radius:50%;background:var(--sage) center/cover;flex:none;border:2px solid #fff;box-shadow:var(--shadow-sm);display:grid;place-items:center;color:#fff;font-weight:800;font-size:15px;letter-spacing:.02em}
.ot-line{font-size:13.5px; color:var(--ink); font-weight:600; line-height:1.35}
.ot-line b{color:var(--forest)}
.ot-meta{font-size:11.5px; color:#7a897f; margin-top:3px; display:flex; align-items:center; gap:6px}
.ot-meta .v{color:var(--fresh-deep); font-weight:700}
.ot-close{position:absolute; top:6px; right:8px; background:none; color:#b8c3bb; font-size:18px; line-height:1; padding:2px}

/* ============ INFO MODALS ============ */
.modal-overlay{position:fixed; inset:0; z-index:90; background:rgba(17,34,27,.55); backdrop-filter:blur(4px); display:none; align-items:center; justify-content:center; padding:24px; opacity:0; transition:opacity .25s}
.modal-overlay.open{display:flex; opacity:1}
.modal{background:var(--bone); border-radius:22px; max-width:560px; width:100%; max-height:84vh; overflow:hidden; position:relative; box-shadow:var(--shadow-lg); transform:translateY(16px); transition:transform .3s cubic-bezier(.16,1,.3,1); display:flex; flex-direction:column}
.modal-overlay.open .modal{transform:none}
.modal-close{position:absolute; top:14px; right:16px; z-index:3; width:40px; height:40px; border-radius:50%; background:var(--bone-2); color:var(--forest); font-size:24px; line-height:1; display:grid; place-items:center; box-shadow:var(--shadow-sm)}
.modal-close:hover{background:var(--sage)}
.modal-close:active{transform:scale(.92)}
.modal-body{overflow-y:auto; padding:40px 38px 36px; -webkit-overflow-scrolling:touch}
.modal-body h3{font-family:var(--news); font-size:28px; font-weight:600; color:var(--forest); margin-bottom:16px; padding-right:36px}
.modal-body p{font-size:15px; line-height:1.65; color:var(--ink-soft); margin:0 0 14px}
.modal-body ul{margin:0 0 16px; padding-left:0; list-style:none; display:flex; flex-direction:column; gap:11px}
.modal-body li{position:relative; padding-left:24px; font-size:14.5px; line-height:1.55; color:var(--ink-soft)}
.modal-body li::before{content:"✓"; position:absolute; left:0; top:0; color:var(--fresh-deep); font-weight:800}
.modal-body li b{color:var(--forest)}
.modal-body a{color:var(--fresh-deep); font-weight:700; border-bottom:1px solid rgba(47,93,69,.3)}
@media (max-width:820px){
  .order-toast{left:12px; bottom:84px; max-width:74vw}
  .fab-wa{right:14px; bottom:84px}
  .fab-wa .fab-label{display:none}
  .fab-wa{padding:14px; width:56px; height:56px; justify-content:center}
  .fab-ic{font-size:24px}
  .fab-badge{display:block}
}

/* ============ REVEAL ANIM ============ */
.reveal{opacity:0; transform:translateY(24px); transition:opacity .7s ease, transform .7s ease}
.reveal.in{opacity:1; transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1; transform:none; transition:none}
  .hero-bottle{animation:none}
}

/* ============ RESPONSIVE ============ */
@media (max-width:1080px){
  .stats-grid,.problem-tried,.why-grid{grid-template-columns:repeat(2,1fr)}
  .who-grid,.mech-stages{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:820px){
  .section{padding:60px 0}
  .wrap{padding:0 20px}
  .nav-links{display:none}
  .burger{display:flex}
  .section-head{margin-bottom:38px}
  .section-head h2,.problem h2,.mech-metaphor h2,.final h2{font-size:32px}
  .problem-turn,.tl-report,.conf-wrap,.bonus-wrap{grid-template-columns:1fr; gap:26px}
  .tl-report ul{grid-template-columns:1fr}
  .tl-track{grid-template-columns:1fr; gap:14px}
  .tl-track::before{display:none}
  .tl-step{display:grid; grid-template-columns:68px 1fr; gap:16px; text-align:left; align-items:center; background:#fff; border:1px solid var(--line); border-radius:18px; padding:14px}
  .tl-dot{margin:0}
  .ingr-hero .info,.bonus-info{padding:24px}
  .cmp-row{grid-template-columns:1.2fr 1fr 1fr}
  .cmp-row > div{padding:14px 12px}
  .cmp-feature{font-size:13px}
  .conf-wrap{text-align:center; justify-items:center}
  .conf-left{align-items:center}
  .conf-right{text-align:left}
  .trans-grid{grid-template-columns:1fr; gap:20px}
  .trans-side{position:static}
  .ft-grid{grid-template-columns:1fr 1fr}
  .ft-brand{grid-column:1 / -1}
  .ft-bottom span:last-child{text-align:left; max-width:none}
  .nav-mini{display:none}
}
@media (max-width:560px){
  .problem-tried,.mech-stages,.stats-grid{grid-template-columns:1fr}
  .who-grid{grid-template-columns:1fr 1fr; gap:12px}
  .why-grid{grid-template-columns:1fr 1fr; gap:12px}
  .cert-card{flex-basis:72vw}
  .price-grid{grid-template-columns:1fr; max-width:380px}
  .cmp-row{grid-template-columns:1.1fr .9fr .9fr}
  .ba-card{flex-basis:78vw}
  .ingr-card{flex-basis:80vw}
  .rev-card{flex-basis:84vw}
  .adv-card{flex-basis:74vw}
  .fb-card{flex-basis:72vw; height:78vw; max-height:420px}
  .hero-feature{min-height:330px}
  .announce-group{font-size:11px; gap:8px; padding:0 16px}
  .ba-stats{grid-template-columns:1fr 1fr}
  /* compact who + why cards on mobile */
  .who-body{padding:14px 14px 16px}
  .who-body h3{font-size:18px; margin-bottom:9px}
  .who-body ul{gap:6px; margin-bottom:12px}
  .who-body li{font-size:12.5px}
  .who-result{font-size:11.5px; padding:7px 11px}
  .who-tag{font-size:10px; padding:5px 9px}
  .why-card{padding:18px 16px}
  .why-card h4{font-size:16px}
  .why-card li{font-size:12.5px}
}
