/*
Theme Name: FKMS Authentic
Theme URI: https://www.fkmsauthentic.com
Author: FKMS Authentic
Author URI: https://www.fkmsauthentic.com
Description: Premium WooCommerce theme for FKMS Authentic Triple Magnesium Complex. A custom storefront with a designed landing page and full WooCommerce shop, cart, and checkout.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: fkms-authentic
WC requires at least: 7.0
WC tested up to: 9.0
*/

:root{
  --navy:#0B2440; --navy-2:#0F2E52; --blue:#1C6FD0; --blue-600:#1763C2;
  --blue-soft:#5C9BE0; --blue-tint:#EAF2FB; --blue-tint-2:#F4F8FD;
  --gold:#C79A4B; --gold-soft:#E0C075; --cyan:#19C0E0; --aqua:#3DD6EC; --blue-bright:#1C8FE6; --grad:linear-gradient(135deg,#1C6FD0,#19C0E0); --grad-soft:linear-gradient(135deg,#2C86E0,#3DD6EC); --ink:#152639; --ink-2:#475A72;
  --muted:#8090A3; --line:#E7EBF1; --line-2:#D7DEE9; --paper:#FAFBFD; --white:#FFFFFF;
  --ok:#1F9966; --maxw:1180px; --ease:cubic-bezier(.22,.61,.36,1);
  --sh-lg:0 30px 70px -32px rgba(11,36,64,.42); --sh-md:0 16px 40px -22px rgba(11,36,64,.34); --sh-sm:0 8px 22px -14px rgba(11,36,64,.30);
}
*{box-sizing:border-box}
body{margin:0;background:var(--paper);color:var(--ink);font-family:'Inter',system-ui,sans-serif;font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block;height:auto}
::selection{background:var(--blue);color:#fff}
.serif,h1,h2,h3{font-family:'Fraunces',Georgia,serif;font-weight:500;letter-spacing:-.012em;line-height:1.08;color:var(--ink)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
.eyebrow{font-size:12px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);display:inline-flex;align-items:center;gap:11px}
.eyebrow::before{content:"";width:22px;height:1.5px;background:var(--gold)}
.eyebrow.center{justify-content:center}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;cursor:pointer;border:none;font-family:'Inter',sans-serif;font-weight:600;font-size:15px;padding:15px 28px;border-radius:12px;transition:transform .28s var(--ease),box-shadow .28s var(--ease),background .28s,color .25s;white-space:nowrap}
.btn-primary{background:var(--navy);color:#fff;box-shadow:0 14px 30px -14px rgba(11,36,64,.7)}
.btn-primary:hover{transform:translateY(-2px);background:var(--navy-2);box-shadow:0 20px 40px -14px rgba(11,36,64,.7);color:#fff}
.btn-gold{background:linear-gradient(135deg,var(--gold-soft),var(--gold));color:#3a2a0c;box-shadow:0 14px 30px -14px rgba(199,154,75,.6)}
.btn-gold:hover{transform:translateY(-2px);color:#3a2a0c}
.btn-ghost{background:transparent;color:var(--navy);border:1.5px solid var(--line-2)}
.btn-ghost:hover{border-color:var(--navy);transform:translateY(-2px)}
.btn .arr{transition:transform .28s var(--ease)}
.btn:hover .arr{transform:translateX(3px)}

.announce{position:sticky;top:0;z-index:61;height:38px;background:var(--navy);color:#DCE8F6;overflow:hidden;display:flex;align-items:center;border-bottom:1px solid rgba(199,154,75,.45)}
.announce .promo{display:flex;white-space:nowrap;will-change:transform;animation:promoSlide 26s linear infinite}
.announce .seg{display:flex;align-items:center;white-space:nowrap;font-size:12px;letter-spacing:.1em;font-weight:600;color:#D7E4F4;padding-right:44px}
.announce .hl{color:var(--gold);font-weight:700}
@keyframes promoSlide{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.announce .promo{animation:none}}
.announce b{color:var(--gold-soft);font-weight:600}
.announce .dot{color:var(--gold);margin:0 8px}

.site-header{position:sticky;top:38px;z-index:60;overflow:hidden;background:linear-gradient(180deg,rgba(255,255,255,.78),rgba(231,243,252,.6));backdrop-filter:blur(26px) saturate(160%);-webkit-backdrop-filter:blur(26px) saturate(160%);border-bottom:1px solid rgba(255,255,255,.55);box-shadow:inset 0 1px 0 rgba(255,255,255,.75),0 1px 0 rgba(28,111,208,.05);transition:background .3s,box-shadow .3s}
.site-header.scrolled{background:linear-gradient(180deg,rgba(255,255,255,.88),rgba(225,239,251,.74));box-shadow:inset 0 1px 0 rgba(255,255,255,.85),0 14px 36px -18px rgba(11,46,82,.5)}
.site-header .bubbles{position:absolute;inset:0;z-index:0;pointer-events:none}
.site-header .bubbles span{position:absolute;bottom:-14px;border-radius:50%;background:radial-gradient(circle at 35% 30%,rgba(255,255,255,.5),rgba(255,255,255,.12) 42%,rgba(120,200,235,.1) 72%,rgba(255,255,255,0) 100%);filter:blur(1px);animation:bubble linear infinite}
@keyframes bubble{0%{transform:translate(0,0) scale(.55);opacity:0}15%{opacity:.7}50%{transform:translate(3px,-60px) scale(.9)}85%{opacity:.4}100%{transform:translate(-2px,-122px) scale(1.05);opacity:0}}
.nav{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;height:76px}
.brand{display:flex;align-items:center;gap:13px}
.brand .mg{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;background:radial-gradient(circle at 34% 28%,var(--blue-soft),var(--navy));color:#fff;font-family:'Fraunces',serif;font-weight:600;font-size:18px;box-shadow:inset 0 1px 0 rgba(255,255,255,.35),0 8px 18px -10px rgba(11,36,64,.7)}
.brand b{font-family:'Fraunces',serif;font-size:21px;font-weight:600;color:var(--navy);display:block;line-height:1}
.brand small{font-size:9.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);font-weight:600}
.nav-links{display:flex;align-items:center;gap:34px;list-style:none;margin:0;padding:0}
.nav-links a{position:relative;font-size:14px;color:var(--ink-2);font-weight:500;letter-spacing:.02em;transition:color .25s}
.nav-links a::after{content:"";position:absolute;left:0;right:100%;bottom:-6px;height:2px;background:var(--gold);border-radius:2px;transition:right .28s ease}
.nav-links a:hover{color:var(--navy)}
.nav-links a:hover::after{right:0}
.nav-actions{display:flex;align-items:center;gap:13px}
.cart-btn{position:relative;background:#fff;border:1.5px solid var(--line-2);width:46px;height:46px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;color:var(--navy);transition:border-color .25s,transform .25s;flex:none}
.cart-btn:hover{border-color:var(--navy);transform:translateY(-1px)}
.cart-count{position:absolute;top:-7px;right:-7px;min-width:20px;height:20px;padding:0 5px;border-radius:20px;background:var(--gold);color:#3a2a0c;font-size:11px;font-weight:700;display:grid;place-items:center}
.menu-btn{display:none;background:#fff;border:1.5px solid var(--line-2);width:46px;height:46px;border-radius:12px;cursor:pointer;color:var(--navy);align-items:center;justify-content:center;flex:none}
.nav-menu-cta{display:none}
header .btn-aqua{background:linear-gradient(135deg,#1C6FD0 0%,#2B9FE0 100%)}

/* hero */
.hero{position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;z-index:0;background:radial-gradient(900px 560px at 84% 8%,rgba(61,214,236,.22),transparent 60%),radial-gradient(680px 560px at 2% 98%,rgba(28,111,208,.14),transparent 58%),linear-gradient(180deg,#F2FBFE,#FAFBFD)}
.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.04fr .96fr;gap:48px;align-items:center;padding:70px 0 76px}
.rate{display:inline-flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);border-radius:100px;padding:7px 16px 7px 12px;box-shadow:var(--sh-sm);margin-bottom:24px}
.stars{position:relative;display:inline-flex;gap:2px;vertical-align:middle}
.stars .star-base{display:inline-flex;gap:2px}
.stars .star-fill{position:absolute;top:0;left:0;display:inline-flex;gap:2px;overflow:hidden;white-space:nowrap;pointer-events:none}
.stars svg{width:15px;height:15px;flex:none}
.rate span{font-size:13px;color:var(--ink-2);font-weight:500}
.rate b{color:var(--ink)}
.hero h1{font-size:clamp(40px,5.6vw,68px);font-weight:500;margin:0}
.hero h1 .u{position:relative;white-space:nowrap}
.hero h1 .u::after{content:"";position:absolute;left:0;right:0;bottom:.06em;height:.5em;background:linear-gradient(90deg,rgba(25,192,224,.55),rgba(28,111,208,.28));z-index:-1;border-radius:3px}
.hero .lede{font-size:18.5px;color:var(--ink-2);max-width:30em;margin:24px 0 8px}
.hero .lede b{color:var(--ink);font-weight:600}
.pricerow{display:flex;align-items:baseline;gap:13px;margin:26px 0 6px}
.price-now{font-family:'Fraunces',serif;font-size:36px;font-weight:600;color:var(--navy)}
.price-now .price-old{font-size:.64em;font-weight:500;color:#94A3B4;text-decoration:line-through;text-decoration-thickness:1.5px;margin-right:.16em}
.price-now .price-sale{color:var(--navy)}
.price-was{font-size:17px;color:var(--muted);text-decoration:line-through}
.price-save{font-size:12px;font-weight:700;color:#0C6F8C;background:#E1F7FC;padding:4px 10px;border-radius:8px;letter-spacing:.03em}
.btn-aqua{background:var(--grad);color:#fff;box-shadow:0 14px 30px -12px rgba(25,150,210,.65)}
.btn-aqua:hover{transform:translateY(-2px);box-shadow:0 20px 40px -12px rgba(25,150,210,.7)}
.reg{font-size:.5em;vertical-align:.62em;font-weight:600;margin-left:.03em;letter-spacing:0}
.price-unit{font-size:13.5px;color:var(--muted);margin-bottom:22px}
.hero-cta{display:flex;gap:13px;flex-wrap:wrap}
.hero-props{display:flex;flex-wrap:wrap;gap:10px 26px;margin-top:30px;padding-top:26px;border-top:1px solid var(--line)}
.hero-props span{font-size:13.5px;color:var(--ink-2);font-weight:500;display:inline-flex;align-items:center;gap:8px}
.hero-props svg{width:17px;height:17px;flex:none}
.hero-visual{position:relative;display:grid;place-items:center;min-height:520px}
.hero-visual::before{content:"";position:absolute;width:620px;height:620px;border-radius:50%;z-index:0;background:radial-gradient(circle at 50% 40%,rgba(61,214,236,.34),rgba(28,111,208,.13) 42%,transparent 70%)}
.bottle-card{position:relative;z-index:1;width:clamp(290px,36vw,460px);padding:24px;border-radius:34px;display:grid;place-items:center;background:linear-gradient(165deg,#FFFFFF 0%,#F6FAFE 55%,#E8F1FB 100%);box-shadow:0 46px 92px -38px rgba(11,46,82,.55),0 0 0 1px rgba(28,111,208,.12),inset 0 1px 0 #fff,inset 0 -26px 44px -26px rgba(28,111,208,.14);animation:floaty 7s ease-in-out infinite}
.bottle-card::before{content:"";position:absolute;left:16px;right:16px;top:14px;height:120px;border-radius:24px;background:linear-gradient(180deg,rgba(61,214,236,.10),transparent);pointer-events:none}

.ring2{display:none}
.stage-floor{display:none}
.hero-bottle{position:relative;z-index:2;width:100%;height:auto;display:block}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.el-chip{position:absolute;z-index:3;top:26px;left:-4px;background:#fff;border:1px solid var(--line);border-radius:15px;padding:13px 15px;box-shadow:var(--sh-md);animation:floaty 6.5s ease-in-out infinite .5s}
.el-chip .n{font-size:11px;color:var(--muted);font-weight:600}
.el-chip .s{font-family:'Fraunces',serif;font-size:32px;font-weight:600;color:var(--navy);line-height:.95}
.el-chip .m{font-size:10.5px;color:var(--muted);font-weight:500}
.qc{position:absolute;z-index:3;bottom:46px;left:-6px;background:#fff;border:1px solid var(--line);border-radius:15px;padding:13px 16px;box-shadow:var(--sh-md);display:flex;align-items:center;gap:12px;animation:floaty 6.5s ease-in-out infinite .25s}
.qc .ic{width:40px;height:40px;border-radius:11px;background:#FBF1D9;box-shadow:inset 0 0 0 1px #ECD9A8;display:grid;place-items:center;flex:none}
.qc b{font-size:14px;color:var(--ink);display:block;line-height:1.15;font-weight:600}
.qc small{font-size:12px;color:var(--muted)}

.logobar{background:var(--navy);color:#fff}
.logobar .wrap{display:flex;flex-wrap:wrap;justify-content:space-between;gap:18px 12px;padding:24px 32px}
.logobar .it{display:flex;align-items:center;gap:11px;font-size:14px;font-weight:600;color:#E4ECF7}
.logobar .it svg{width:22px;height:22px;color:var(--gold-soft);flex:none}

.sec{padding:clamp(64px,8vw,104px) 0}
.sec-head{max-width:40em;margin:0 auto clamp(40px,5vw,60px);text-align:center}
.sec-head.left{margin-left:0;text-align:left}
.sec-head h2{font-size:clamp(30px,4.4vw,48px);margin:18px 0 0}
.sec-head p{color:var(--ink-2);margin-top:18px;font-size:18px}

.promise{text-align:center;padding:clamp(72px,9vw,110px) 0}
.promise .q{font-family:'Fraunces',serif;font-weight:400;font-style:italic;font-size:clamp(24px,3.4vw,38px);line-height:1.32;color:var(--navy);max-width:18em;margin:22px auto 0}
.promise .q b{font-style:normal;font-weight:600;color:var(--blue-600)}
.promise .sig{margin-top:28px;font-size:14px;color:var(--muted);letter-spacing:.04em}

.forms{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.form{background:#fff;border:1px solid var(--line);border-radius:20px;padding:34px 30px;position:relative;transition:transform .4s var(--ease),box-shadow .4s,border-color .4s}
.form::before{content:"";position:absolute;left:30px;top:0;width:46px;height:3px;border-radius:3px;background:var(--accent,var(--blue));transform:scaleX(.6);transform-origin:left;transition:transform .4s var(--ease)}
.form:hover{transform:translateY(-8px);box-shadow:var(--sh-lg);border-color:var(--line-2)}
.form:hover::before{transform:scaleX(1)}
.form .mol{width:46px;height:46px;margin:14px 0 18px;color:var(--accent,var(--blue))}
.form h3{font-size:25px;margin:0}
.form .tag{font-size:12.5px;color:var(--muted);font-weight:500;margin:4px 0 16px}
.form p{font-size:15px;color:var(--ink-2);margin:0}
.form .role{display:inline-block;margin-top:20px;font-size:11.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent,var(--blue));background:color-mix(in srgb,var(--accent,var(--blue)) 9%,#fff);padding:7px 13px;border-radius:9px}

.feature{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(36px,5vw,64px);align-items:center}
.feature.flip .fig{order:2}
.fig{border-radius:22px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--sh-lg);background:#fff}
.fig img{width:100%}
.feature h2{font-size:clamp(28px,3.8vw,42px);margin:18px 0 0}
.feature p{color:var(--ink-2);margin-top:18px;font-size:17px}
.flist{margin:26px 0 0;padding:0;display:flex;flex-direction:column;gap:14px}
.flist li{list-style:none;display:flex;gap:13px;align-items:flex-start;font-size:15.5px;color:var(--ink);font-weight:500}
.flist .ck{flex:none;width:26px;height:26px;border-radius:50%;background:var(--blue-tint);display:grid;place-items:center;margin-top:1px}
.flist .ck svg{width:13px;height:13px;color:var(--blue-600)}
.cta-row{margin-top:32px;display:flex;gap:13px;flex-wrap:wrap}
.alt{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}

.band{background:linear-gradient(160deg,var(--navy),var(--navy-2));color:#fff}
.mfg{position:relative;border-radius:24px;overflow:hidden;box-shadow:var(--sh-lg)}
.mfg img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.mfg .scrim{position:relative;z-index:1;background:linear-gradient(90deg,rgba(8,28,52,.94) 0%,rgba(8,28,52,.8) 44%,rgba(8,28,52,.12) 100%);padding:clamp(40px,6vw,72px);min-height:440px;display:flex;flex-direction:column;justify-content:center}
.mfg .scrim h2{color:#fff;font-size:clamp(28px,3.8vw,42px);max-width:13em;margin:0}
.mfg .scrim p{color:#CFDEEF;margin-top:18px;max-width:30em;font-size:17px}
.mstats{display:flex;flex-wrap:wrap;gap:38px;margin-top:34px}
.mstat .big{font-family:'Fraunces',serif;font-size:30px;font-weight:600;color:#fff}
.mstat .cap{font-size:12px;color:#A9C0DD;letter-spacing:.1em;text-transform:uppercase;margin-top:5px;font-weight:600}

.story-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(36px,5vw,64px);align-items:center}
.story-card{background:#fff;border:1px solid var(--line);border-radius:22px;padding:clamp(30px,4vw,46px);box-shadow:var(--sh-md)}
.story-card .mark{font-family:'Fraunces',serif;font-size:64px;color:var(--gold);line-height:.6;opacity:.5}
.story-card h2{font-size:clamp(26px,3.6vw,38px);margin:6px 0 0}
.story-card p{color:var(--ink-2);margin-top:18px;font-size:16.5px}
.story-card .who{margin-top:24px;display:flex;align-items:center;gap:13px;padding-top:22px;border-top:1px solid var(--line)}
.story-card .who .av{width:46px;height:46px;border-radius:50%;background:radial-gradient(circle at 34% 28%,var(--blue-soft),var(--navy));color:#fff;display:grid;place-items:center;font-family:'Fraunces',serif;font-weight:600}
.story-card .who b{font-size:14.5px;display:block}
.story-card .who small{font-size:12.5px;color:var(--muted)}
.story-card .who .av-logo{height:50px;width:auto;max-width:150px;object-fit:contain;border-radius:10px;box-shadow:0 5px 14px -6px rgba(11,46,82,.35);flex:none}
.story-side{display:flex;flex-direction:column;gap:16px}
.pill{display:flex;gap:14px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:16px;padding:20px 22px;box-shadow:var(--sh-sm)}
.pill .ic{width:42px;height:42px;border-radius:11px;background:var(--blue-tint);color:var(--blue-600);display:grid;place-items:center;flex:none}
.pill .ic svg{width:21px;height:21px}
.pill b{font-family:'Fraunces',serif;font-size:18px;display:block}
.pill p{font-size:14px;color:var(--ink-2);margin-top:3px}

.compare{max-width:780px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:20px;overflow:hidden;box-shadow:var(--sh-md)}
.crow{display:grid;grid-template-columns:1.5fr 1fr 1fr;align-items:center}
.crow+.crow{border-top:1px solid var(--line)}
.crow>div{padding:18px 22px;font-size:15px}
.crow .lbl{color:var(--ink-2);font-weight:500}
.chead{background:var(--navy)}
.chead>div{color:#D7E2F1;font-size:12px;letter-spacing:.08em;text-transform:uppercase;font-weight:700}
.chead .us{color:var(--gold-soft)}
.cval{display:flex;align-items:center;justify-content:center;gap:8px;text-align:center;font-weight:600}
.cval.us{color:var(--navy)}
.cval.them{color:var(--muted);font-weight:500}
.cval svg{width:18px;height:18px;flex:none}

.facts-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(36px,5vw,56px);align-items:center}
.spec-table{margin-top:8px;border-top:2px solid var(--navy)}
.spec-row{display:flex;justify-content:space-between;gap:18px;padding:14px 0;border-bottom:1px solid var(--line);font-size:15px}
.spec-row .k{color:var(--muted);font-weight:500}
.spec-row .v{color:var(--ink);font-weight:600;text-align:right}
.free-of{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px}
.free-of span{font-size:12.5px;font-weight:600;color:var(--navy);background:var(--blue-tint);border:1px solid var(--line-2);padding:6px 13px;border-radius:9px}

.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.review{background:#fff;border:1px solid var(--line);border-radius:20px;padding:30px;box-shadow:var(--sh-sm)}
.review .stars{margin-bottom:16px}
.review p{font-family:'Fraunces',serif;font-weight:400;font-size:18px;line-height:1.5;color:var(--ink);margin:0}
.review .who{margin-top:22px;display:flex;align-items:center;gap:12px}
.review .av{width:42px;height:42px;border-radius:50%;background:radial-gradient(circle at 34% 28%,var(--blue-soft),var(--navy));color:#fff;display:grid;place-items:center;font-weight:700;font-size:15px}
.review .who b{font-size:14.5px;display:block;line-height:1.1}
.review .who small{font-size:12px;color:var(--ok);font-weight:600}
.review .av-photo{overflow:hidden;background:none!important;padding:0;box-shadow:0 3px 8px rgba(11,46,82,.2),0 0 0 2px #fff;flex:none}

.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.gcard{background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:var(--sh-sm);transition:transform .35s var(--ease),box-shadow .35s}
.gcard:hover{transform:translateY(-6px);box-shadow:var(--sh-lg)}
.gcard .cap{padding:16px 20px;font-size:13.5px;color:var(--ink-2);font-weight:500;border-top:1px solid var(--line)}

.order{background:linear-gradient(180deg,var(--blue-tint-2),var(--paper))}
.order-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:clamp(36px,5vw,56px);align-items:center}
.order-visual{position:relative;border-radius:24px;background:radial-gradient(circle at 50% 38%,#fff,var(--blue-tint) 80%);border:1px solid var(--line);box-shadow:var(--sh-lg);display:grid;place-items:center;padding:30px;min-height:460px;overflow:hidden}
.order-visual img{mix-blend-mode:multiply;max-height:410px;width:auto}
.order-visual .seal{position:absolute;top:22px;left:22px;background:#fff;border:1px solid var(--line);color:var(--navy);font-size:12px;font-weight:700;letter-spacing:.03em;padding:8px 14px;border-radius:10px;box-shadow:var(--sh-sm)}
.order-card{background:#fff;border:1px solid var(--line);border-radius:24px;padding:clamp(28px,3vw,38px);box-shadow:var(--sh-lg)}
.order-card h2{font-size:30px;margin:0}
.order-card .sub{color:var(--ink-2);margin-top:8px;font-size:15px}
.bundles{display:flex;flex-direction:column;gap:12px;margin:26px 0}
.bundle{display:flex;align-items:center;gap:16px;border:1.5px solid var(--line-2);border-radius:15px;padding:17px 18px;cursor:pointer;transition:border-color .25s,background .25s;position:relative}
.bundle:hover{border-color:var(--blue-soft)}
.bundle.active{border-color:var(--navy);background:var(--blue-tint-2)}
.bundle .radio{width:22px;height:22px;border-radius:50%;border:2px solid var(--line-2);flex:none;display:grid;place-items:center;transition:border-color .25s}
.bundle.active .radio{border-color:var(--navy)}
.bundle.active .radio::after{content:"";width:11px;height:11px;border-radius:50%;background:var(--navy)}
.bundle .info{flex:1}
.bundle .info b{font-size:16px;display:block;font-weight:600}
.bundle .info small{font-size:13px;color:var(--muted)}
.bundle .pr{text-align:right}
.bundle .pr .amt{font-family:'Fraunces',serif;font-weight:600;font-size:20px;color:var(--navy)}
.bundle .pr .each{font-size:12px;color:var(--muted)}
.bundle .flag{position:absolute;top:-10px;right:14px;background:var(--gold);color:#3a2a0c;font-size:10px;font-weight:700;letter-spacing:.05em;padding:3px 10px;border-radius:7px}
.order-total{display:flex;align-items:baseline;justify-content:space-between;padding:16px 0;border-top:1px solid var(--line);margin-bottom:18px}
.order-total .lbl{font-size:13px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.1em}
.order-total .val{font-family:'Fraunces',serif;font-size:30px;font-weight:600;color:var(--navy)}
.order-card .btn{width:100%}
.order-reassure{display:flex;flex-wrap:wrap;gap:10px 18px;margin-top:18px;justify-content:center}
.order-reassure span{font-size:12.5px;color:var(--ink-2);display:inline-flex;align-items:center;gap:6px;font-weight:500}
.order-reassure svg{width:15px;height:15px;color:var(--ok)}

.guarantee{text-align:center;max-width:680px;margin:0 auto}
.guarantee .badge{width:84px;height:84px;border-radius:50%;border:1.5px solid var(--gold);display:grid;place-items:center;margin:0 auto 24px;color:var(--gold);background:#fff;box-shadow:var(--sh-sm)}
.guarantee .badge svg{width:38px;height:38px}
.guarantee h2{font-size:clamp(26px,3.6vw,38px);margin:0}
.guarantee p{color:var(--ink-2);margin-top:16px;font-size:17px}

.faq{max-width:840px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;background:none;border:none;cursor:pointer;text-align:left;font-family:'Fraunces',serif;font-weight:500;font-size:20px;color:var(--ink);padding:24px 46px 24px 0;position:relative}
.faq-q .pm{position:absolute;right:4px;top:50%;transform:translateY(-50%);width:22px;height:22px;transition:transform .35s var(--ease)}
.faq-q .pm::before,.faq-q .pm::after{content:"";position:absolute;left:50%;top:50%;background:var(--gold)}
.faq-q .pm::before{width:14px;height:2px;transform:translate(-50%,-50%)}
.faq-q .pm::after{width:2px;height:14px;transform:translate(-50%,-50%);transition:transform .35s var(--ease)}
.faq-item.open .pm::after{transform:translate(-50%,-50%) scaleY(0)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .45s var(--ease)}
.faq-a p{color:var(--ink-2);font-size:15.5px;padding:0 46px 24px 0;margin:0}

.site-footer{background:var(--navy);color:#BFD0E6}
.foot-top{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:36px;padding:clamp(48px,6vw,68px) 0 40px}
.foot-brand .brand b{color:#fff}
.foot-brand .brand small{color:#8AA3C6}
.foot-brand p{margin-top:18px;font-size:14.5px;max-width:27em;color:#A6BDDB}
.foot-contact{margin-top:18px;font-size:13.5px;line-height:1.85;color:#A6BDDB}
.foot-col h4{color:#fff;font-size:12px;letter-spacing:.14em;text-transform:uppercase;margin-bottom:16px;font-weight:700}
.foot-col a{display:block;font-size:14.5px;margin-bottom:11px;color:#BFD0E6;transition:color .2s}
.foot-col a:hover{color:var(--gold-soft)}
.disclaimer{border-top:1px solid rgba(255,255,255,.12);padding:26px 0;font-size:12px;line-height:1.7;color:#7E97BC;max-width:72em}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);padding:22px 0 40px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:13px;color:#7E97BC}

.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ===== WooCommerce pages (shop, product, cart, checkout) ===== */
.fkms-shell{max-width:var(--maxw);margin:0 auto;padding:clamp(40px,6vw,72px) 32px}
.fkms-shell .page-title,.fkms-shell h1.entry-title,.woocommerce-products-header__title{font-family:'Fraunces',serif;font-weight:500;font-size:clamp(30px,4vw,44px);margin:0 0 28px}
.woocommerce .button,.woocommerce a.button,.woocommerce button.button,.woocommerce input.button,.woocommerce #respond input#submit,.woocommerce a.button.alt,.woocommerce button.button.alt{background:var(--navy)!important;color:#fff!important;border-radius:12px!important;font-family:'Inter',sans-serif!important;font-weight:600!important;padding:13px 26px!important;border:none!important;transition:transform .25s,background .25s!important;text-shadow:none!important}
.woocommerce .button:hover,.woocommerce a.button:hover,.woocommerce button.button:hover,.woocommerce #respond input#submit:hover,.woocommerce a.button.alt:hover,.woocommerce button.button.alt:hover{background:var(--navy-2)!important;transform:translateY(-2px)}
.woocommerce ul.products li.product .price,.woocommerce div.product p.price,.woocommerce div.product span.price{color:var(--navy)!important;font-family:'Fraunces',serif;font-weight:600}
.woocommerce ul.products li.product h2,.woocommerce ul.products li.product .woocommerce-loop-product__title,.woocommerce div.product .product_title{font-family:'Fraunces',serif!important;font-weight:500!important;color:var(--ink)!important}
.woocommerce ul.products li.product{background:#fff;border:1px solid var(--line);border-radius:18px;padding:18px;box-shadow:var(--sh-sm);transition:transform .3s,box-shadow .3s}
.woocommerce ul.products li.product:hover{transform:translateY(-5px);box-shadow:var(--sh-lg)}
.woocommerce ul.products li.product img{border-radius:12px}
.woocommerce-message,.woocommerce-info,.woocommerce-error{border-top-color:var(--navy)!important;border-radius:12px;background:#fff;box-shadow:var(--sh-sm)}
.woocommerce-message::before,.woocommerce-info::before{color:var(--navy)!important}
.woocommerce form .form-row input.input-text,.woocommerce form .form-row textarea,.woocommerce .select2-container--default .select2-selection--single,.woocommerce form .form-row select{border:1.5px solid var(--line-2)!important;border-radius:11px!important;padding:12px 14px!important;min-height:auto}
.woocommerce table.shop_table{border-radius:14px;border-color:var(--line)}
.woocommerce-cart table.cart img{border-radius:10px}
.woocommerce .cart-collaterals .cart_totals h2,.woocommerce-checkout h3{font-family:'Fraunces',serif;font-weight:500}
.woocommerce #payment,.woocommerce-checkout #order_review{border-radius:16px}

@media(max-width:980px){
  .hero-grid,.feature,.feature.flip,.story-grid,.facts-grid,.order-grid{grid-template-columns:1fr;gap:40px}
  .feature .fig,.feature.flip .fig{order:-1}
  .hero-visual{min-height:420px;order:-1}
  .forms,.reviews,.gallery{grid-template-columns:1fr 1fr}
  .foot-top{grid-template-columns:1fr 1fr}
  .foot-brand{grid-column:1/-1}
}
@media(max-width:640px){
  body{font-size:16px}
  .wrap{padding:0 20px}
  .nav-links{display:none}
  .menu-btn{display:inline-flex}
  .nav-actions{gap:8px}
  .nav-actions > .btn-aqua{display:inline-flex;padding:9px 14px!important;font-size:13px}
  .cart-btn,.menu-btn{width:42px;height:42px}
  .brand .brand-logo{height:32px}
  .nav-links.open{display:flex;position:fixed;top:114px;left:0;right:0;flex-direction:column;align-items:stretch;background:#fff;padding:18px 20px 22px;gap:15px;border-bottom:1px solid var(--line);box-shadow:0 16px 32px -10px rgba(11,46,82,.22);z-index:70;max-height:calc(100vh - 124px);overflow-y:auto}
  .nav-links.open a{font-size:16px}
  .nav-links.open .nav-menu-cta{display:none}
  .forms,.reviews,.gallery{grid-template-columns:1fr}
  .logobar .wrap{justify-content:flex-start}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important}.reveal{opacity:1;transform:none;transition:none}}

/* logo + bundle savings (v2 pricing) */
.brand .brand-logo{height:42px;width:auto;display:block}
@media(max-width:560px){.brand .brand-logo{height:34px}}
.bundle .was{font-size:12.5px;color:var(--muted);text-decoration:line-through;line-height:1}
.bundle .amt-total{font-weight:700;color:var(--ok)}
.bundle .flag-save{background:var(--ok)!important;color:#fff!important}
.bundle .flag-best{background:var(--gold)!important;color:#231a05!important}

/* rotating benefit badge on hero image */
.benefit-flip{position:absolute;top:14px;right:0;z-index:5;display:flex;flex-direction:column;gap:3px;
  padding:11px 17px;border-radius:16px;text-align:left;min-width:158px;perspective:700px;
  background:linear-gradient(150deg,rgba(13,40,70,.92),rgba(9,28,50,.92));
  border:1px solid rgba(199,154,75,.55);
  box-shadow:0 14px 34px rgba(7,22,40,.38),0 1px 0 rgba(255,255,255,.06) inset;
  animation:bfFloat 5s ease-in-out infinite}
.benefit-flip .bf-top{display:flex;align-items:center;gap:7px;font-size:10px;letter-spacing:.18em;text-transform:uppercase;font-weight:700;color:var(--gold)}
.benefit-flip .bf-dot{width:7px;height:7px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 0 rgba(199,154,75,.6);animation:bfPulse 2s ease-out infinite}
.benefit-flip .bf-word{font-family:'Fraunces',serif;font-size:19px;font-weight:600;color:#fff;line-height:1.15;transform-origin:50% 50%;backface-visibility:hidden}
.benefit-flip .bf-word.flip{animation:bfFlip .6s cubic-bezier(.22,.61,.18,1)}
@keyframes bfFlip{0%{transform:rotateX(88deg);opacity:0}40%{opacity:1}100%{transform:rotateX(0deg);opacity:1}}
@keyframes bfPulse{0%{box-shadow:0 0 0 0 rgba(199,154,75,.55)}70%{box-shadow:0 0 0 9px rgba(199,154,75,0)}100%{box-shadow:0 0 0 0 rgba(199,154,75,0)}}
@keyframes bfFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
@media(max-width:560px){.benefit-flip{top:10px;right:6px;min-width:140px;padding:9px 14px}.benefit-flip .bf-word{font-size:17px}}
@media(prefers-reduced-motion:reduce){.benefit-flip{animation:none}.benefit-flip .bf-dot{animation:none}.benefit-flip .bf-word.flip{animation:none}}

/* flying USA flag chip + footer logo (v8) */
.flag-chip{position:absolute;z-index:3;top:10px;left:-10px;display:flex;flex-direction:column;align-items:flex-start;filter:drop-shadow(0 9px 14px rgba(11,36,64,.24))}
.flag-chip .flag-row{display:flex;align-items:flex-start}
.flag-chip .pole{width:4px;height:94px;border-radius:4px;background:linear-gradient(180deg,#DBDEE5,#9097A4);position:relative;flex:none;z-index:2}
.flag-chip .pole::before{content:"";position:absolute;top:-5px;left:-2.5px;width:9px;height:9px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#F2DCA6,var(--gold));box-shadow:0 1px 2px rgba(0,0,0,.3)}
.flag-chip .us-flag{width:92px;height:auto;margin:5px 0 0 -1px;transform-origin:left center;animation:flagSway 6s ease-in-out infinite}
.flag-chip .us-flag .folds{mix-blend-mode:soft-light;animation:foldMove 4.5s linear infinite}
.flag-chip .made{margin:8px 0 0 10px;font-size:9px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--navy);background:#fff;border:1px solid var(--line);padding:3px 9px;border-radius:20px;box-shadow:var(--sh-sm);white-space:nowrap}
@keyframes flagSway{0%,100%{transform:rotate(0deg) translateY(0)}50%{transform:rotate(-1.5deg) translateY(-2px)}}
@keyframes foldMove{from{transform:translateX(0)}to{transform:translateX(60px)}}
.foot-logo{display:inline-block;background:#fff;padding:11px 16px;border-radius:14px;box-shadow:0 10px 26px -12px rgba(0,0,0,.45)}
.foot-logo img{height:42px;width:auto;display:block}
@media(prefers-reduced-motion:reduce){.flag-chip .us-flag,.flag-chip .us-flag .folds{animation:none}}

/* walking lifestyle band (v9) */
.walk-band{position:relative;overflow:hidden;height:248px;background:linear-gradient(180deg,#E9F6FD,#F7FCFE);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.walk-band::after{content:"";position:absolute;left:0;right:0;bottom:36px;height:2px;background:linear-gradient(90deg,transparent,rgba(28,111,208,.16),transparent)}
.walk-marquee{position:absolute;top:50%;left:0;display:flex;white-space:nowrap;font-family:'Fraunces',Georgia,serif;font-weight:600;font-size:62px;letter-spacing:.01em;color:rgba(28,111,208,.10);transform:translateY(-50%);animation:slideText 24s linear infinite;z-index:1;pointer-events:none}
@keyframes slideText{from{transform:translate(0,-50%)}to{transform:translate(-50%,-50%)}}
.walker{position:absolute;bottom:6px;left:0;height:244px;z-index:2;animation:walkAcross 17s linear infinite}
@keyframes walkAcross{from{transform:translateX(-240px)}to{transform:translateX(calc(100vw + 90px))}}
.lady-bob{animation:ladyBob .5s ease-in-out infinite;transform-origin:50% 100%}
@keyframes ladyBob{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
.lady{height:240px;width:auto;display:block;filter:drop-shadow(0 14px 14px rgba(11,36,64,.18))}
.lady .leg-front,.lady .leg-back{transform-box:fill-box;transform-origin:50% 2%}
.lady .leg-front{animation:legSwing .5s ease-in-out infinite}
.lady .leg-back{animation:legSwing .5s ease-in-out infinite reverse}
@keyframes legSwing{0%,100%{transform:rotate(8deg)}50%{transform:rotate(-8deg)}}
.lady .pony{transform-box:fill-box;transform-origin:90% 10%;animation:ponySway .5s ease-in-out infinite}
@keyframes ponySway{0%,100%{transform:rotate(-5deg)}50%{transform:rotate(4deg)}}
.lady .arm-back{transform-box:fill-box;transform-origin:50% 5%;animation:legSwing .5s ease-in-out infinite}
@media(max-width:560px){.walk-band{height:200px}.walker{height:188px}.lady{height:184px}.walk-marquee{font-size:42px}}
@media(prefers-reduced-motion:reduce){.walker,.lady-bob,.lady .leg-front,.lady .leg-back,.lady .pony,.lady .arm-back,.walk-marquee{animation:none}.walker{transform:translateX(32vw)}}

/* talking speech bubble (v15) */
.speech{position:absolute;top:4px;left:118px;z-index:3;width:auto;max-width:208px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:9px 13px 10px;box-shadow:0 14px 28px -12px rgba(11,46,82,.4);animation:speechPulse 3.2s ease-in-out infinite}
.speech::after{content:"";position:absolute;left:-8px;top:22px;width:0;height:0;border-top:7px solid transparent;border-bottom:7px solid transparent;border-right:9px solid #fff}
.speech .s1{font-family:Inter,system-ui,sans-serif;font-size:12.5px;font-weight:700;color:var(--navy);line-height:1.34;display:block}
@keyframes talk{0%{opacity:0;transform:translateY(3px)}3%{opacity:1;transform:translateY(0)}30%{opacity:1}34%{opacity:0}100%{opacity:0}}
@keyframes speechPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.03)}}
@media(max-width:560px){.speech{left:88px;max-width:176px}}
@media(prefers-reduced-motion:reduce){.speech{animation:none}}

/* promise pillars (v19) */
.pillars{display:flex;flex-wrap:wrap;justify-content:center;gap:30px 24px;margin-top:40px}
.pillar{flex:1 1 200px;max-width:262px;text-align:center;padding:0 6px}
.pillar .pic{width:66px;height:66px;border-radius:50%;display:grid;place-items:center;margin:0 auto 16px;background:radial-gradient(circle at 35% 30%,#EAF3FF,#DCEAFB);color:var(--blue-600);box-shadow:inset 0 0 0 1px rgba(28,111,208,.14),0 10px 22px -14px rgba(28,111,208,.5)}
.pillar .pic svg{width:30px;height:30px}
.pillar h3{font-family:'Fraunces',serif;font-size:18px;font-weight:600;color:var(--navy);margin:0 0 6px}
.pillar p{font-size:13.5px;color:var(--ink-2);line-height:1.55;margin:0 auto;max-width:15em}
@media(max-width:760px){.pillar{flex:1 1 40%;max-width:none}}
@media(max-width:430px){.pillar{flex:1 1 100%}}

/* social product reviews (v20) */
.social .ssub{text-align:center;margin:10px auto 0;color:var(--ink-2);max-width:34em;font-size:16px}
.social-grid{display:flex;gap:18px;overflow-x:auto;padding:30px 4px 16px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
.social-grid::-webkit-scrollbar{height:8px}
.social-grid::-webkit-scrollbar-track{background:transparent}
.social-grid::-webkit-scrollbar-thumb{background:#CBD8E8;border-radius:8px}
.social-grid .vid{flex:0 0 auto;width:300px;border-radius:16px;overflow:hidden;background:#000;box-shadow:0 18px 42px -22px rgba(11,46,82,.5);border:1px solid var(--line);scroll-snap-align:start}
.social-grid .vid video{display:block;width:100%;height:540px;object-fit:cover;background:#000}
.social-grid .vid-slot{flex:0 0 auto;width:300px;height:540px;border-radius:16px;border:2px dashed #C7D6E8;background:linear-gradient(180deg,#F8FBFE,#EDF4FC);display:grid;place-items:center;text-align:center;scroll-snap-align:start}
.social-grid .vid-slot .pic{width:54px;height:54px;border-radius:50%;background:var(--grad);color:#fff;display:grid;place-items:center;margin:0 auto 14px;box-shadow:0 12px 26px -12px rgba(25,150,210,.6)}
.social-grid .vid-slot .pic svg{width:24px;height:24px}
.social-grid .vid-slot b{display:block;color:var(--navy);font-family:'Fraunces',serif;font-size:16px}
.social-grid .vid-slot small{display:block;color:var(--muted);font-size:12.5px;margin-top:3px}

/* social carousel mobile UX (v24) */
.social-wrap{position:relative}
.social-grid{gap:16px!important;scrollbar-width:none;scroll-padding-left:16px;padding:24px 4px 6px!important}
.social-grid::-webkit-scrollbar{display:none!important}
.social-grid .vid video{aspect-ratio:9/16;height:auto!important}
.sgl-arrow{position:absolute;top:46%;transform:translateY(-50%);z-index:6;width:46px;height:46px;border-radius:50%;border:1px solid var(--line);background:rgba(255,255,255,.94);color:var(--navy);font-size:26px;line-height:1;display:grid;place-items:center;cursor:pointer;box-shadow:0 10px 26px -12px rgba(11,46,82,.5)}
.sgl-arrow:hover{background:#fff}
.sgl-arrow.prev{left:-8px}
.sgl-arrow.next{right:-8px}
.social-dots{display:flex;gap:9px;justify-content:center;margin-top:18px}
.social-dots .dot{width:9px;height:9px;border-radius:50%;background:#C6D5E7;cursor:pointer;transition:width .25s,background .25s}
.social-dots .dot.active{width:28px;border-radius:6px;background:var(--grad)}
.swipe-hint{text-align:center;color:var(--blue-600);font-weight:600;font-size:13.5px;margin-top:11px}
.swipe-hint .arrows{display:inline-block;animation:nudge 1.3s ease-in-out infinite}
@keyframes nudge{0%,100%{transform:translateX(0)}50%{transform:translateX(6px)}}
@media(max-width:680px){.social-grid .vid{width:74vw!important;max-width:320px}.sgl-arrow{display:none}.social-grid{padding:18px 4px 4px!important}}

/* magnesium benefits — rising water bubbles (v29) */
.mag-benefits{position:relative;overflow:hidden;min-height:520px;background:linear-gradient(180deg,#0A2A4E 0%,#0E477F 52%,#1A7BBC 100%);color:#fff;padding:92px 0 70px;border-top:1px solid rgba(255,255,255,.08)}
.mag-benefits .mb-head{position:relative;z-index:3;text-align:center}
.mag-benefits .mb-head h2{color:#fff}
.mag-benefits .mb-eb{color:#86E3F6}
.mag-benefits .mb-head p{color:#CFE6F7;max-width:40em;margin:13px auto 0}
.mb-bubbles{position:absolute;inset:0;z-index:1;pointer-events:none}
.bub{position:absolute;bottom:-170px;display:grid;place-items:center;border-radius:50%;background:radial-gradient(circle at 34% 28%,rgba(255,255,255,.30),rgba(255,255,255,.08) 58%,rgba(255,255,255,.03));border:1px solid rgba(255,255,255,.38);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);box-shadow:inset 0 10px 22px rgba(255,255,255,.16),0 10px 30px rgba(6,26,48,.32);color:#fff;text-align:center;animation:rise linear infinite}
.bub b{font-family:'Fraunces',serif;font-weight:600;font-size:15px;line-height:1.15;padding:0 12px;text-shadow:0 1px 7px rgba(6,22,42,.55)}
.bub::after{content:"";position:absolute;top:15%;left:20%;width:28%;height:22%;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.75),transparent 72%);opacity:.7}
@keyframes rise{0%{transform:translateY(0) translateX(0);opacity:0}9%{opacity:1}86%{opacity:1}100%{transform:translateY(-720px) translateX(var(--drift,18px));opacity:0}}
.bub.deco{background:radial-gradient(circle at 34% 28%,rgba(255,255,255,.22),rgba(255,255,255,.04));border-color:rgba(255,255,255,.22)}
.bub.b1{left:5%;width:134px;height:134px;animation-duration:17s;animation-delay:0s;--drift:22px}
.bub.b2{left:23%;width:120px;height:120px;animation-duration:20s;animation-delay:6s;--drift:-16px}
.bub.b3{left:41%;width:150px;height:150px;animation-duration:22s;animation-delay:11s;--drift:18px}
.bub.b4{left:60%;width:124px;height:124px;animation-duration:18.5s;animation-delay:2.5s;--drift:-20px}
.bub.b5{left:77%;width:142px;height:142px;animation-duration:21s;animation-delay:14s;--drift:16px}
.bub.b6{left:14%;width:118px;height:118px;animation-duration:19.5s;animation-delay:9s;--drift:-14px}
.bub.b7{left:66%;width:120px;height:120px;animation-duration:23s;animation-delay:17s;--drift:20px}
.bub.d1{left:12%;width:30px;height:30px;animation-duration:14s;animation-delay:1s;--drift:14px}
.bub.d2{left:34%;width:20px;height:20px;animation-duration:12s;animation-delay:4s;--drift:-10px}
.bub.d3{left:52%;width:38px;height:38px;animation-duration:16s;animation-delay:7s;--drift:12px}
.bub.d4{left:70%;width:24px;height:24px;animation-duration:13s;animation-delay:3s;--drift:-12px}
.bub.d5{left:88%;width:32px;height:32px;animation-duration:15s;animation-delay:10s;--drift:10px}
.bub.d6{left:46%;width:18px;height:18px;animation-duration:11s;animation-delay:5.5s;--drift:-8px}
@media(max-width:560px){.bub b{font-size:12px;padding:0 8px}.bub.b1,.bub.b4,.bub.b6,.bub.b7{width:104px;height:104px}.bub.b2{width:100px;height:100px}.bub.b3,.bub.b5{width:116px;height:116px}.mag-benefits{padding:70px 0 56px;min-height:460px}}
@media(prefers-reduced-motion:reduce){.bub{animation:none;opacity:.92}.bub.deco{display:none}.bub.b1{bottom:auto;top:34%}.bub.b2{bottom:auto;top:58%}.bub.b3{bottom:auto;top:26%}.bub.b4{bottom:auto;top:62%}.bub.b5{bottom:auto;top:32%}.bub.b6{bottom:auto;top:66%}.bub.b7{bottom:auto;top:52%}}
