/* ===========================================================
   LOYALTY DRAGON — Brand System
   Type: Playfair Display (display/serif) · Hanken Grotesk (body, PP Neue Montreal alt) · Montserrat (UI labels)
   Color: forest green base · orange accent · gold · terracotta · cream
   =========================================================== */
:root{
  --green:#0E3B2E;        /* primary forest */
  --green-2:#16513A;      /* lighter forest */
  --green-3:#0A2C22;      /* deepest */
  --orange:#F26A1B;       /* bright accent */
  --orange-d:#C9501C;
  --gold:#ECB72E;
  --gold-d:#D6A52A;
  --rust:#B0431A;         /* terracotta */
  --cream:#FCE9DC;        /* peach cream */
  --off:#EDF1F0;          /* off white */
  --paper:#FFFFFF;
  --ink:#13211B;
  --mute:#5C6862;
  --mute-on-green:rgba(255,255,255,.66);
  --line:rgba(15,59,46,.12);
  --serif:'Playfair Display',Georgia,serif;
  --sans:'Hanken Grotesk',-apple-system,system-ui,sans-serif;
  --ui:'Montserrat',sans-serif;
  --shadow:0 30px 70px rgba(10,44,34,.16);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--paper);overflow-x:hidden;-webkit-font-smoothing:antialiased;font-size:17px;line-height:1.55}
img{max-width:100%;display:block}
.serif{font-family:var(--serif)}
/* Material Symbols */
.ms{font-family:'Material Symbols Rounded';font-weight:400;font-style:normal;line-height:1;letter-spacing:normal;text-transform:none;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;direction:ltr;font-feature-settings:'liga';-webkit-font-smoothing:antialiased;font-variation-settings:'opsz' 24}
/* anchor framing under sticky nav */
[id]{scroll-margin-top:96px}
.wrap{max-width:1200px;margin:0 auto;padding:0 32px}
.eyebrow{font-family:var(--ui);font-weight:700;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;display:inline-flex;align-items:center;gap:10px;color:var(--orange)}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--orange);display:inline-block}
.eyebrow.center::before{display:none}

/* ---------- Buttons ---------- */
.btn{font-family:var(--ui);font-weight:700;font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;padding:15px 30px;border-radius:6px;border:none;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:9px;transition:transform .18s cubic-bezier(.2,.8,.2,1),box-shadow .25s}
.btn-orange{background:var(--orange);color:#fff;box-shadow:0 12px 30px rgba(242,106,27,.32)}
.btn-orange:hover{transform:translateY(-3px);box-shadow:0 18px 40px rgba(242,106,27,.45);background:#ff7322}
.btn-green{background:var(--green);color:#fff}
.btn-green:hover{transform:translateY(-3px);box-shadow:0 16px 36px rgba(14,59,46,.32)}
.btn-ghost{background:transparent;color:var(--green);border:1.5px solid var(--line)}
.btn-ghost:hover{border-color:var(--green);background:var(--green);color:#fff}
.btn-ghost-on{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.3)}
.btn-ghost-on:hover{border-color:var(--orange);color:var(--orange)}
.btn-arrow{transition:transform .2s}
.btn:hover .btn-arrow{transform:translateX(4px)}

/* ---------- Logo ---------- */
.logo{display:flex;align-items:center;gap:11px;text-decoration:none}
.logo img{height:36px;width:auto;display:block}
.foot-logo{height:42px;width:auto;display:block;margin-bottom:4px}
.logo .mark{width:42px;height:42px;border-radius:50%;background:var(--orange);display:grid;place-items:center;flex-shrink:0}
.logo .mark svg{width:24px;height:24px}
.logo .word{font-family:var(--ui);font-weight:800;font-size:1.18rem;line-height:.92;color:var(--orange);letter-spacing:-.01em}
.logo .word small{display:block;font-size:.98rem;font-weight:800}

/* ---------- Nav ---------- */
nav{position:sticky;top:0;z-index:60;backdrop-filter:blur(16px);background:rgba(255,255,255,.86);border-bottom:1px solid var(--line);transition:background .3s,border-color .3s}
nav.scrolled{box-shadow:0 8px 30px rgba(10,44,34,.07)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:78px}
.nav-links{display:flex;gap:34px;align-items:center}
.nav-links a{font-family:var(--ui);font-weight:600;font-size:.84rem;letter-spacing:.02em;color:var(--green);text-decoration:none;opacity:.82;transition:opacity .2s,color .2s}
.nav-links a:hover{opacity:1;color:var(--orange)}
.nav-right{display:flex;align-items:center;gap:18px}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.burger span{width:26px;height:2.5px;background:var(--green);border-radius:2px;transition:.3s}

/* ---------- Mobile menu ---------- */
.menu-overlay{position:fixed;inset:0;z-index:80;background:var(--green);transform:translateX(100%);transition:transform .4s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;padding:0 28px}
.menu-overlay.open{transform:translateX(0)}
.menu-head{display:flex;align-items:center;justify-content:space-between;height:78px;border-bottom:1px solid rgba(255,255,255,.12)}
.menu-close{background:none;border:none;font-size:2rem;cursor:pointer;line-height:1;color:#fff}
.menu-list{flex:1;padding-top:14px}
.menu-list a{display:block;font-family:var(--serif);font-size:2rem;color:#fff;text-decoration:none;padding:16px 0;border-bottom:1px solid rgba(255,255,255,.1)}
.menu-list a:hover{color:var(--orange)}
.menu-cta{padding:26px 0 44px}
.menu-cta .btn{width:100%;justify-content:center;font-size:.95rem;padding:18px}

/* ===========================================================
   HERO
   =========================================================== */
.hero{position:relative;background:var(--green);color:#fff;overflow:hidden;padding:84px 0 96px}
.hero-arc{position:absolute;border-radius:50%;z-index:0;pointer-events:none}
.hero-arc.a1{width:760px;height:760px;border:1px solid rgba(255,255,255,.06);right:-220px;top:-180px}
.hero-arc.a2{width:480px;height:480px;background:radial-gradient(circle,rgba(236,183,46,.14),transparent 68%);right:-120px;top:60px}
.hero-arc.a3{width:300px;height:300px;background:radial-gradient(circle,rgba(242,106,27,.16),transparent 70%);left:-90px;bottom:-90px}
.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.hero h1{font-family:var(--serif);font-weight:900;font-size:clamp(2.9rem,5.4vw,4.6rem);line-height:1.02;letter-spacing:-.015em;margin:24px 0 0}
.hero h1 em{font-style:italic;color:var(--orange)}
.hero .lead{color:rgba(255,255,255,.78);font-size:1.16rem;line-height:1.55;max-width:520px;margin:24px 0 32px}
.hero .lead b{color:var(--gold);font-weight:700}

/* Email capture */
.email-cta{display:flex;align-items:center;background:#fff;border-radius:8px;padding:7px 7px 7px 8px;max-width:520px;box-shadow:0 18px 44px rgba(0,0,0,.22)}
.email-cta input{flex:1;border:none;outline:none;font-family:var(--sans);font-size:1rem;color:var(--ink);background:transparent;min-width:0;padding:0 16px}
.email-cta input::placeholder{color:var(--mute)}
.email-note{font-size:.86rem;color:rgba(255,255,255,.55);margin-top:14px;display:flex;align-items:center;gap:8px}
.email-ok{display:none;margin-top:16px;color:var(--gold);font-weight:600;font-size:1rem}

/* ---------- Hero dashboard mockup ---------- */
.mock{position:relative}
.mock-card{background:#fff;border-radius:22px;padding:24px;box-shadow:0 50px 100px rgba(0,0,0,.38);color:var(--ink);position:relative;z-index:3}
.mock-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}
.mock-user{display:flex;align-items:center;gap:11px}
.mock-avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--orange));display:grid;place-items:center;color:#fff;font-family:var(--serif);font-weight:700;font-size:1.1rem}
.mock-user b{font-size:.98rem;font-weight:700;display:block}
.mock-user span{font-size:.76rem;color:var(--mute)}
.mock-tier{font-family:var(--ui);background:var(--green);color:#fff;font-size:.62rem;font-weight:700;letter-spacing:.08em;padding:7px 13px;border-radius:999px}
.points-box{background:var(--green);border-radius:18px;padding:22px;color:#fff;position:relative;overflow:hidden;margin-bottom:16px}
.points-box::after{content:"";position:absolute;right:-40px;bottom:-40px;width:170px;height:170px;background:radial-gradient(circle,rgba(236,183,46,.4),transparent 70%)}
.points-box .lbl{font-family:var(--ui);font-size:.64rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;opacity:.7;position:relative}
.points-box .pts{font-family:var(--serif);font-weight:900;font-size:2.7rem;margin-top:4px;position:relative;line-height:1}
.points-box .pts small{font-family:var(--sans);font-size:.92rem;font-weight:600;opacity:.7}
.prog{height:7px;background:rgba(255,255,255,.18);border-radius:999px;margin-top:16px;overflow:hidden;position:relative}
.prog i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--gold),var(--orange));border-radius:999px;transition:width 1.4s cubic-bezier(.2,.8,.2,1)}
.points-box .next{font-size:.74rem;opacity:.72;margin-top:9px;position:relative}
.feed-title{font-family:var(--ui);font-size:.64rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--mute);margin:4px 0 6px}
.prow{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--line)}
.prow:last-child{border:none}
.prow .ic{width:36px;height:36px;border-radius:10px;background:var(--off);display:grid;place-items:center;font-size:1rem;flex-shrink:0}
.prow .tx{flex:1;min-width:0}
.prow .tx b{font-size:.86rem;font-weight:700;display:block}
.prow .tx s{font-size:.72rem;color:var(--mute);text-decoration:none}
.prow .pp{font-family:var(--ui);font-weight:700;color:var(--green);font-size:.82rem}
.prow .pp.o{color:var(--orange)}
/* floating chips */
.float-chip{position:absolute;z-index:5;background:#fff;border-radius:13px;padding:12px 16px;box-shadow:0 22px 44px rgba(0,0,0,.28);display:flex;align-items:center;gap:11px;animation:floaty 5s ease-in-out infinite}
.float-chip .fc-ic{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;font-size:1.1rem;color:#fff}
.float-chip b{font-size:.8rem;font-weight:700;display:block;color:var(--ink);white-space:nowrap}
.float-chip>span:last-child{display:flex;flex-direction:column;line-height:1.3}
.float-chip>span:last-child>span{font-size:.68rem;color:var(--mute);white-space:nowrap}
.fc-gift{top:-26px;left:-34px;animation-delay:0s}
.fc-gift .fc-ic{background:var(--orange)}
.fc-ref{bottom:36px;right:-44px;animation-delay:-2.5s}
.fc-ref .fc-ic{background:var(--gold);color:var(--green)}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

/* ---------- Hero slider ---------- */
.hero-slider{position:relative}
.hslides{position:relative;height:560px}
.hslide{position:absolute;inset:0;opacity:0;transform:scale(.98);transition:opacity .8s ease,transform .8s ease;pointer-events:none;display:grid;place-items:center}
.hslide.active{opacity:1;transform:none;pointer-events:auto}
.hs-photo{width:100%;height:100%;border-radius:24px;overflow:hidden;box-shadow:0 40px 90px rgba(0,0,0,.4)}
.hs-photo img{width:100%;height:100%;object-fit:cover}
.hs-card{width:100%;max-width:430px}
.hslide .float-chip,.hslide .float-card{animation:floaty 5s ease-in-out infinite}
.fc-reward{bottom:40px;left:-30px}
.fc-reward .fc-ic{background:var(--gold);color:var(--green)}
/* floating activity card (slide 2) */
.float-card{position:absolute;z-index:5;background:#fff;color:var(--ink);border-radius:16px;padding:14px 16px;width:280px;
  box-shadow:0 26px 50px rgba(0,0,0,.3);bottom:-22px;right:-26px}
.float-card .feed-title{margin:0 0 4px}
.float-card .prow{padding:8px 0}
.float-card .prow .ic{width:32px;height:32px;font-size:.95rem}
/* dots */
.hs-dots{display:flex;gap:9px;justify-content:center;margin-top:22px}
.hs-dot{width:9px;height:9px;border-radius:999px;border:none;background:rgba(255,255,255,.32);cursor:pointer;padding:0;transition:width .3s,background .3s}
.hs-dot.active{width:28px;background:var(--orange)}

/* ===========================================================
   INTEGRATIONS MARQUEE
   =========================================================== */
.trust{background:var(--green-3);color:#fff;padding:30px 0;overflow:hidden}
.trust-in{display:flex;align-items:center;gap:38px}
.trust-lbl{font-family:var(--ui);font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.5);white-space:nowrap;flex-shrink:0}
.marquee{flex:1;overflow:hidden;position:relative;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee-track{display:flex;gap:54px;width:max-content;animation:scrollx 26s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.mq-item{font-family:var(--ui);font-weight:700;font-size:1.05rem;letter-spacing:.02em;color:rgba(255,255,255,.62);white-space:nowrap;display:flex;align-items:center;gap:9px}
.mq-item .dot{width:7px;height:7px;border-radius:50%;background:var(--orange)}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* ===========================================================
   STATS BAND
   =========================================================== */
.stats{background:var(--cream);padding:84px 0}
.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.stat{text-align:center;padding:0 14px}
.stat .num{font-family:var(--serif);font-weight:900;font-size:clamp(3rem,6vw,4.8rem);line-height:1;color:var(--green);letter-spacing:-.02em}
.stat .num .u{color:var(--orange)}
.stat p{color:var(--mute);font-size:1rem;margin-top:14px;max-width:300px;margin-inline:auto;line-height:1.5}
.stat .sep{width:42px;height:3px;background:var(--gold);margin:18px auto 0;border-radius:2px}

/* ===========================================================
   SECTION SHELL
   =========================================================== */
section{padding:104px 0}
.sec-head{max-width:720px;margin-bottom:60px}
.sec-head.center{margin-inline:auto;text-align:center}
.sec-head.center .eyebrow{justify-content:center}
.sec-head h2{font-family:var(--serif);font-weight:900;font-size:clamp(2.1rem,4vw,3.3rem);line-height:1.06;letter-spacing:-.015em;margin-top:18px;color:var(--green)}
.sec-head h2 em{font-style:italic;color:var(--orange)}
.sec-head p{color:var(--mute);font-size:1.14rem;margin-top:18px;line-height:1.55}

/* ---------- 3 Programs ---------- */
.programs{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.pcard{border-radius:22px;padding:38px 32px;position:relative;overflow:hidden;transition:transform .3s cubic-bezier(.2,.8,.2,1),box-shadow .3s;border:1px solid var(--line);background:var(--paper)}
.pcard:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.pcard .pic{width:60px;height:60px;border-radius:16px;display:grid;place-items:center;font-size:1.7rem;margin-bottom:22px}
.pcard:nth-child(1) .pic{background:rgba(14,59,46,.1);color:var(--green)}
.pcard:nth-child(2) .pic{background:rgba(242,106,27,.13);color:var(--orange)}
.pcard:nth-child(3) .pic{background:rgba(236,183,46,.2);color:var(--gold-d)}
.pcard .pic .ms{font-size:1.8rem}
.pcard h3{font-family:var(--serif);font-weight:700;font-size:1.55rem;color:var(--green);margin-bottom:12px}
.pcard p{color:var(--mute);font-size:.98rem;line-height:1.55}
.pcard .plink{font-family:var(--ui);font-weight:700;font-size:.76rem;letter-spacing:.06em;text-transform:uppercase;color:var(--orange);margin-top:20px;display:inline-flex;align-items:center;gap:7px;text-decoration:none}
.pcard .plink .a{transition:transform .2s}
.pcard:hover .plink .a{transform:translateX(4px)}

/* ---------- Two blocks (Giftcards / Loyalty & Referrals) ---------- */
.blocks{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.block{border-radius:28px;padding:48px 42px;color:#fff;position:relative;overflow:hidden;transition:transform .3s cubic-bezier(.2,.8,.2,1),box-shadow .3s}
.block.orange{background:var(--orange)}
.block.green{background:var(--green)}
.block:hover{transform:translateY(-6px)}
.block.orange:hover{box-shadow:0 28px 60px rgba(242,106,27,.32)}
.block.green:hover{box-shadow:0 28px 60px rgba(10,44,34,.34)}
.block .bic{width:64px;height:64px;border-radius:18px;display:grid;place-items:center;margin-bottom:24px;background:rgba(255,255,255,.18);font-size:1.9rem}
.block .bic .ms{font-size:2rem;color:#fff}
.block h3{font-family:var(--serif);font-weight:700;font-size:2.1rem;margin-bottom:14px}
.block .blead{font-size:1.04rem;line-height:1.55;opacity:.95;margin-bottom:26px;max-width:440px}
.subitems{list-style:none;display:flex;flex-direction:column;gap:12px}
.subitem{display:flex;gap:14px;align-items:flex-start;background:rgba(255,255,255,.12);padding:15px 17px;border-radius:14px;transition:background .25s}
.subitem:hover{background:rgba(255,255,255,.18)}
.subitem .si-ic{flex-shrink:0;width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.16);display:grid;place-items:center;font-size:1.15rem}
.subitem .si-ic.ms{font-size:1.2rem;color:#fff}
.subitem .si-tx b{display:block;font-size:1rem;font-weight:700;margin-bottom:3px}
.subitem .si-tx span{font-size:.9rem;opacity:.86;line-height:1.45}

/* ===========================================================
   PRODUCT SHOWCASE (tabs)
   =========================================================== */
.showcase{background:var(--green);color:#fff;overflow:hidden}
.showcase .sec-head h2{color:#fff}
.showcase .sec-head p{color:var(--mute-on-green)}
.tabs{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:44px}
.tab{font-family:var(--ui);font-weight:600;font-size:.86rem;letter-spacing:.02em;padding:13px 24px;border-radius:999px;border:1.5px solid rgba(255,255,255,.2);background:transparent;color:#fff;cursor:pointer;transition:.25s;display:flex;align-items:center;gap:9px}
.tab:hover{border-color:rgba(255,255,255,.5)}
.tab.active{background:var(--orange);border-color:var(--orange);color:#fff}
.tab .ti{font-size:1rem}
.panel{display:none;grid-template-columns:1fr 1fr;gap:56px;align-items:center;animation:fadeUp .5s ease}
.panel.active{display:grid}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
.panel h3{font-family:var(--serif);font-weight:700;font-size:2rem;margin-bottom:18px}
.panel .pdesc{color:var(--mute-on-green);font-size:1.05rem;line-height:1.6;margin-bottom:24px}
.checklist{list-style:none;display:flex;flex-direction:column;gap:14px}
.checklist li{display:flex;gap:13px;align-items:flex-start;font-size:1rem;line-height:1.45}
.checklist .ck{width:24px;height:24px;border-radius:50%;background:rgba(236,183,46,.2);color:var(--gold);display:grid;place-items:center;flex-shrink:0;font-size:.8rem;font-weight:700;margin-top:1px}
.checklist b{color:#fff;font-weight:700}
.checklist span{color:var(--mute-on-green)}

/* Showcase visual cards */
.viz{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:24px;padding:30px;min-height:380px;position:relative;overflow:hidden}
.viz-h{font-family:var(--ui);font-size:.66rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-bottom:18px}
/* giftcard viz */
.giftcard{border-radius:18px;padding:26px;color:#fff;position:relative;overflow:hidden;box-shadow:0 24px 50px rgba(0,0,0,.3);background:linear-gradient(135deg,var(--orange),var(--rust))}
.giftcard.alt{background:linear-gradient(135deg,var(--green-2),var(--green-3));margin-top:-40px;margin-left:48px}
.giftcard .gc-top{display:flex;justify-content:space-between;align-items:center;font-family:var(--ui);font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;opacity:.85}
.giftcard .gc-bal{font-family:var(--serif);font-weight:900;font-size:2.2rem;margin:26px 0 4px}
.giftcard .gc-bal small{font-family:var(--ui);font-size:.9rem;font-weight:600;opacity:.7}
.giftcard .gc-no{font-family:var(--ui);font-size:.78rem;letter-spacing:.22em;opacity:.7}
/* tier ladder */
.ladder{display:flex;flex-direction:column;gap:12px}
.rung{display:flex;align-items:center;gap:15px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:14px 18px;transition:.3s}
.rung.cur{background:rgba(242,106,27,.16);border-color:var(--orange)}
.rung .rb{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;font-size:1.1rem;flex-shrink:0;color:#fff}
.rung .rb .ms{font-size:1.25rem}
.tab .ti.ms{font-size:1.2rem}
.giftcard .gc-top .ms{font-size:1.3rem}
.foot-contact .cl.ms{font-size:1.25rem}
.rung .rt{flex:1}
.rung .rt b{display:block;font-weight:700;font-size:.98rem}
.rung .rt span{font-size:.76rem;color:var(--mute-on-green)}
.rung .rp{font-family:var(--ui);font-weight:700;font-size:.8rem;color:var(--gold)}
/* points ring */
.ring-wrap{display:flex;align-items:center;gap:26px;margin-bottom:24px}
.ring{position:relative;width:130px;height:130px;flex-shrink:0}
.ring svg{transform:rotate(-90deg)}
.ring .rc-bg{fill:none;stroke:rgba(255,255,255,.12);stroke-width:11}
.ring .rc-fg{fill:none;stroke:var(--gold);stroke-width:11;stroke-linecap:round;stroke-dasharray:339.292;stroke-dashoffset:339.292;transition:stroke-dashoffset 1.6s cubic-bezier(.2,.8,.2,1)}
.ring .rc-txt{position:absolute;inset:0;display:grid;place-items:center;text-align:center}
.ring .rc-txt b{font-family:var(--serif);font-weight:900;font-size:1.7rem;line-height:1}
.ring .rc-txt span{font-size:.62rem;color:var(--mute-on-green);text-transform:uppercase;letter-spacing:.08em}
.bardata{display:flex;flex-direction:column;gap:14px}
.bardata .br{}
.bardata .br-top{display:flex;justify-content:space-between;font-size:.82rem;margin-bottom:6px}
.bardata .br-top b{font-weight:700}
.bardata .br-top span{color:var(--mute-on-green)}
.bardata .br-bar{height:8px;background:rgba(255,255,255,.12);border-radius:999px;overflow:hidden}
.bardata .br-bar i{display:block;height:100%;width:0;border-radius:999px;transition:width 1.3s cubic-bezier(.2,.8,.2,1)}

/* ===========================================================
   BENEFITS
   =========================================================== */
.benefits-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:22px;overflow:hidden}
.bcard{background:var(--paper);padding:38px 32px;transition:background .3s}
.bcard:hover{background:var(--cream)}
.bcard .bn{font-family:var(--serif);font-weight:900;font-size:1.4rem;color:var(--orange);display:flex;align-items:center;gap:12px;margin-bottom:16px}
.bcard .bn .bnc{width:38px;height:38px;border-radius:50%;border:2px solid var(--orange);display:grid;place-items:center;font-size:1.05rem;flex-shrink:0}
.bcard h4{font-family:var(--ui);font-weight:700;font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;color:var(--green);margin-bottom:10px}
.bcard p{color:var(--mute);font-size:.95rem;line-height:1.55}

/* ===========================================================
   FEATURES (servicio)
   =========================================================== */
.features{background:var(--off)}
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.fcard{background:var(--paper);border-radius:18px;padding:32px 28px;border:1px solid var(--line);transition:transform .25s,box-shadow .25s}
.fcard:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.fcard .fic{width:50px;height:50px;border-radius:13px;background:rgba(14,59,46,.08);display:grid;place-items:center;font-size:1.4rem;margin-bottom:18px;color:var(--green)}
.fcard .fic .ms{font-size:1.55rem}
.fcard h4{font-family:var(--serif);font-weight:700;font-size:1.3rem;color:var(--green);margin-bottom:9px}
.fcard p{color:var(--mute);font-size:.94rem;line-height:1.55}

/* ===========================================================
   HOW
   =========================================================== */
/* .how-grid layout → Tailwind utilities en el HTML */
.step{position:relative}
.step .snum{font-family:var(--serif);font-weight:900;font-size:3.4rem;line-height:1;color:transparent;-webkit-text-stroke:1.5px var(--gold);margin-bottom:18px}
.step h3{font-family:var(--serif);font-weight:700;font-size:1.4rem;color:var(--green);margin-bottom:10px}
.step p{color:var(--mute);font-size:.98rem;line-height:1.55}

/* ===========================================================
   QUOTE
   =========================================================== */
.quote{background:var(--green);color:#fff;text-align:center;position:relative;overflow:hidden}
.quote .qmark{font-family:var(--serif);font-size:9rem;color:var(--orange);line-height:.5;height:50px;opacity:.9}
.quote blockquote{font-family:var(--serif);font-weight:900;font-style:italic;font-size:clamp(2rem,4.6vw,3.6rem);line-height:1.14;letter-spacing:-.01em;max-width:980px;margin:24px auto 0}
.quote blockquote em{color:var(--gold);font-style:italic}
.quote .qsrc{font-family:var(--ui);font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--mute-on-green);margin-top:30px}

/* ===========================================================
   PRICING
   =========================================================== */
/* Calculadora / recomendador */
.price-calc{display:grid;grid-template-columns:1.5fr 1fr;gap:30px;align-items:center;background:var(--paper);border:1px solid var(--line);border-radius:24px;padding:34px 36px;margin-bottom:40px;box-shadow:0 18px 50px rgba(10,44,34,.07)}
.pc-top{display:flex;justify-content:space-between;align-items:baseline;gap:16px;margin-bottom:18px}
.pc-label{font-family:var(--ui);font-weight:700;font-size:.92rem;color:var(--green)}
.pc-count{font-family:var(--serif);font-weight:900;font-size:1.9rem;color:var(--orange);line-height:1;white-space:nowrap}
.pc-range{-webkit-appearance:none;appearance:none;width:100%;height:8px;border-radius:999px;background:linear-gradient(90deg,var(--orange) 0%,var(--orange) var(--fill,18%),var(--off) var(--fill,18%),var(--off) 100%);outline:none;cursor:pointer}
.pc-range::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:26px;height:26px;border-radius:50%;background:#fff;border:4px solid var(--orange);box-shadow:0 4px 12px rgba(242,106,27,.4);cursor:grab;transition:transform .15s}
.pc-range::-webkit-slider-thumb:active{transform:scale(1.12);cursor:grabbing}
.pc-range::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:#fff;border:4px solid var(--orange);box-shadow:0 4px 12px rgba(242,106,27,.4);cursor:grab}
.pc-scale{position:relative;height:1.4em;margin-top:12px;font-family:var(--ui);font-size:.72rem;font-weight:600;color:var(--mute)}
.pc-scale span{position:absolute;white-space:nowrap;transform:translateX(-50%)}
.pc-scale span:nth-child(1){left:calc(0%   + 13px)}
.pc-scale span:nth-child(2){left:calc(20%  + 7.8px)}
.pc-scale span:nth-child(3){left:calc(40%  + 2.6px)}
.pc-scale span:nth-child(4){left:calc(60%  - 2.6px)}
.pc-scale span:nth-child(5){left:calc(80%  - 7.8px)}
.pc-scale span:nth-child(6){left:calc(100% - 13px)}
.pc-reco{background:var(--green);color:#fff;border-radius:18px;padding:22px 24px;text-align:center;position:relative;overflow:hidden}
.pc-reco-lbl{font-family:var(--ui);font-size:.66rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);display:block}
.pc-reco-plan{font-family:var(--serif);font-weight:900;font-size:1.9rem;display:block;margin:4px 0 2px}
.pc-reco-price{font-family:var(--ui);font-weight:700;font-size:1.05rem;color:rgba(255,255,255,.82);display:block;margin-bottom:16px}
.pc-reco-price .per{font-weight:500;font-size:.82rem;opacity:.7}
.pc-cta{width:100%;justify-content:center}

/* Planes */
.price-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;align-items:stretch}
.plan{display:flex;flex-direction:column;border:1.5px solid var(--line);border-radius:20px;padding:28px 22px;background:var(--paper);position:relative;transition:transform .3s,box-shadow .3s,border-color .3s}
.plan:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.plan .ribbon{display:none;position:absolute;top:-13px;left:50%;transform:translateX(-50%);font-family:var(--ui);font-size:.62rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;background:var(--orange);color:#fff;padding:6px 14px;border-radius:999px;white-space:nowrap;box-shadow:0 8px 20px rgba(242,106,27,.4)}
.plan.is-reco{border-color:var(--orange);box-shadow:0 26px 60px rgba(242,106,27,.22);transform:translateY(-8px)}
.plan.is-reco .ribbon{display:block}
.plan .pname{font-family:var(--ui);font-weight:800;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:var(--orange);margin-bottom:10px}
.plan .ph{font-family:var(--serif);font-weight:900;font-size:1.55rem;color:var(--green);line-height:1.05;margin-bottom:8px;white-space:nowrap}
.plan .ph .per{font-family:var(--sans);font-size:.8rem;font-weight:600;color:var(--mute)}
.plan .psub{color:var(--mute);font-size:.86rem;line-height:1.45;margin-bottom:20px;min-height:62px}
.plan .pfeat{list-style:none;display:flex;flex-direction:column;gap:9px;margin-bottom:18px;flex:1}
.plan .pfeat li{display:flex;justify-content:space-between;gap:10px;align-items:center;font-size:.82rem;line-height:1.3;padding-bottom:9px;border-bottom:1px solid var(--line)}
.plan .pfeat li:last-child{border:none}
.plan .pf-l{color:var(--mute);font-weight:600}
.plan .pf-v{font-family:var(--ui);font-weight:700;color:var(--green);white-space:nowrap}
.plan .pf-v.ok{color:var(--orange);font-size:.95rem}
.plan .ph.custom-ph{color:var(--orange);font-size:1.5rem}
.plan .pnote{font-size:.72rem;color:var(--mute);margin-bottom:18px;line-height:1.4}
.plan .btn{width:100%;justify-content:center;margin-top:auto}
.plan.is-reco .btn{background:var(--orange);color:#fff;border-color:var(--orange);box-shadow:0 12px 30px rgba(242,106,27,.32)}

/* Extras */
/* Extras — layout con utilidades Tailwind; aquí solo el estilo de cada chip */
.price-extras .pe{display:flex;align-items:center;gap:10px;background:var(--paper);border:1px solid var(--line);border-radius:999px;padding:11px 20px;font-size:.88rem;color:var(--mute)}
.price-extras .pe b{color:var(--green);font-weight:700}
.price-extras .pe .ms{font-size:1.15rem;color:var(--orange)}

/* ===========================================================
   FINAL CTA
   =========================================================== */
.final{padding:104px 0}
.cta-box{background:var(--orange);border-radius:32px;padding:80px 56px;text-align:center;color:#fff;position:relative;overflow:hidden}
.cta-box .cc{position:absolute;border-radius:50%;pointer-events:none}
.cta-box .cc1{width:200px;height:200px;background:var(--gold);opacity:.32;right:-40px;bottom:-70px}
.cta-box .cc2{width:120px;height:120px;background:rgba(255,255,255,.16);left:50px;top:40px}
.cta-box .cc3{width:340px;height:340px;border:1px solid rgba(255,255,255,.18);left:-120px;bottom:-160px}
.cta-box .eyebrow{color:#fff}
.cta-box .eyebrow::before{background:#fff}
.cta-box h2{font-family:var(--serif);font-weight:900;font-size:clamp(2.2rem,4.6vw,3.6rem);line-height:1.05;position:relative;margin-top:14px}
.cta-box p{font-size:1.18rem;opacity:.94;max-width:560px;margin:20px auto 32px;position:relative}
.cta-email{display:flex;align-items:center;background:#fff;border-radius:8px;padding:7px 7px 7px 8px;max-width:540px;margin:0 auto;position:relative;box-shadow:0 20px 50px rgba(0,0,0,.18)}
.cta-email input{flex:1;border:none;outline:none;font-family:var(--sans);font-size:1rem;background:transparent;min-width:0;padding:0 16px;color:var(--ink)}

/* ===========================================================
   FOOTER
   =========================================================== */
footer{background:var(--green-3);color:rgba(255,255,255,.6);padding:72px 0 40px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.1)}
.foot-grid .logo .word{color:#fff}
.foot-about{font-size:.95rem;line-height:1.6;color:rgba(255,255,255,.55);margin-top:20px;max-width:300px}
.foot-col h5{font-family:var(--ui);font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#fff;margin-bottom:18px}
.foot-col a{display:block;color:rgba(255,255,255,.6);text-decoration:none;font-size:.94rem;padding:6px 0;transition:color .2s}
.foot-col a:hover{color:var(--orange)}
.foot-contact .ci{display:flex;gap:11px;align-items:flex-start;margin-bottom:14px;font-size:.92rem;color:rgba(255,255,255,.7)}
.foot-contact .ci .cl{color:var(--orange);flex-shrink:0}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;padding-top:30px;font-size:.84rem}

/* ===========================================================
   REVEAL
   =========================================================== */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s cubic-bezier(.2,.8,.2,1),transform .8s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ===========================================================
   LANGUAGE SWITCHER (floating, Yotpo-style)
   =========================================================== */
.lang-switch{position:fixed;right:22px;bottom:22px;z-index:65;display:flex;align-items:center;gap:3px;
  background:var(--green);color:#fff;border:1px solid rgba(255,255,255,.16);border-radius:999px;
  padding:6px 8px 6px 13px;box-shadow:0 16px 38px rgba(10,44,34,.34);
  animation:langIn .5s .4s cubic-bezier(.2,.8,.2,1) both}
.lang-switch .lang-globe{font-size:1.15rem;color:var(--gold);margin-right:5px}
.lang-opt{font-family:var(--ui);font-weight:700;font-size:.74rem;letter-spacing:.05em;border:none;background:transparent;
  color:rgba(255,255,255,.65);cursor:pointer;padding:7px 12px;border-radius:999px;transition:color .2s,background .2s}
.lang-opt:hover{color:#fff}
.lang-opt.active{background:var(--orange);color:#fff}
@keyframes langIn{from{opacity:0;transform:translateY(16px) scale(.92)}to{opacity:1;transform:none}}

/* ===========================================================
   DEMO MODAL
   =========================================================== */
.modal{position:fixed;inset:0;z-index:120;display:none;align-items:center;justify-content:center;padding:28px}
.modal.open{display:flex}
.modal-overlay{position:absolute;inset:0;background:rgba(10,28,22,.62);backdrop-filter:blur(6px);animation:mFade .3s ease}
.modal-card{position:relative;z-index:2;width:100%;max-width:960px;max-height:92vh;overflow:hidden;background:var(--paper);border-radius:24px;box-shadow:0 50px 120px rgba(0,0,0,.5);animation:mPop .42s cubic-bezier(.2,.8,.2,1)}
@keyframes mFade{from{opacity:0}to{opacity:1}}
@keyframes mPop{from{opacity:0;transform:translateY(28px) scale(.97)}to{opacity:1;transform:none}}
.modal-close{position:absolute;top:16px;right:18px;z-index:5;width:42px;height:42px;border-radius:50%;border:none;background:var(--off);color:var(--green);font-size:1.7rem;line-height:1;cursor:pointer;display:grid;place-items:center;transition:background .2s,transform .2s}
.modal-close:hover{background:#dfe6e3;transform:rotate(90deg)}
.modal-grid{display:grid;grid-template-columns:.82fr 1fr;max-height:92vh}
.modal-aside{background:var(--green);color:#fff;padding:46px 38px;position:relative;overflow:hidden;display:flex;flex-direction:column}
.modal-aside::after{content:"";position:absolute;right:-90px;bottom:-90px;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(236,183,46,.22),transparent 70%)}
.modal-logo{height:34px;width:auto;margin-bottom:30px;position:relative}
.modal-aside h2{font-family:var(--serif);font-weight:900;font-size:1.95rem;line-height:1.1;margin-bottom:16px;position:relative}
.modal-aside h2 em{font-style:italic;color:var(--gold)}
.modal-aside > p{color:rgba(255,255,255,.78);font-size:1rem;line-height:1.55;position:relative}
.modal-points{list-style:none;margin-top:auto;padding-top:30px;display:flex;flex-direction:column;gap:13px;position:relative}
.modal-points li{display:flex;gap:11px;align-items:flex-start;font-size:.92rem;line-height:1.4;color:rgba(255,255,255,.9)}
.modal-points .ms{color:var(--gold);font-size:1.2rem;flex-shrink:0}
.modal-body{padding:44px 40px;overflow-y:auto;max-height:92vh}
.demo-form{display:flex;flex-direction:column;gap:15px}
.df-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.df-field{display:flex;flex-direction:column;gap:6px}
.df-field label{font-family:var(--ui);font-weight:600;font-size:.8rem;color:var(--green)}
.df-field .df-opt{color:var(--mute);font-weight:500;text-transform:none;letter-spacing:0}
.df-field input,.df-field select,.df-field textarea{font-family:var(--sans);font-size:.96rem;color:var(--ink);background:var(--paper);border:1.5px solid var(--line);border-radius:9px;padding:12px 14px;outline:none;transition:border-color .2s,box-shadow .2s;width:100%}
.df-field input:focus,.df-field select:focus,.df-field textarea:focus{border-color:var(--orange);box-shadow:0 0 0 3px rgba(242,106,27,.14)}
.df-field input.err,.df-field select.err{border-color:#d8442a;box-shadow:0 0 0 3px rgba(216,68,42,.13)}
.df-field textarea{resize:vertical;min-height:70px}
.df-field select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%230E3B2E' stroke-width='2.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:38px;cursor:pointer}
.df-check{display:flex;gap:11px;align-items:flex-start;font-size:.84rem;line-height:1.45;color:var(--mute);cursor:pointer;margin-top:2px}
.df-check input{width:19px;height:19px;flex-shrink:0;accent-color:var(--orange);margin-top:1px;cursor:pointer}
.df-check.err span{color:#d8442a}
.df-submit{margin-top:6px;justify-content:center;font-size:.9rem;padding:16px}
.df-foot{font-size:.76rem;color:var(--mute);text-align:center;line-height:1.4}
.df-success{display:none;flex-direction:column;align-items:center;text-align:center;gap:14px;padding:30px 10px;animation:mPop .4s ease}
.df-success.show{display:flex}
.demo-form.hide{display:none}
.df-success-ic{font-size:3.4rem;color:var(--orange)}
.df-success h3{font-family:var(--serif);font-weight:900;font-size:1.8rem;color:var(--green)}
.df-success h3 em,.df-success h3 span{color:var(--orange)}
.df-success p{color:var(--mute);font-size:1rem;line-height:1.55;max-width:380px}
@media(max-width:760px){
  .modal{padding:0}
  .modal-card{max-width:100%;max-height:100vh;height:100vh;border-radius:0}
  .modal-grid{grid-template-columns:1fr;max-height:100vh;overflow-y:auto}
  .modal-aside{padding:34px 26px 28px}
  .modal-aside h2{font-size:1.6rem}
  .modal-points{margin-top:24px}
  .modal-body{padding:30px 26px 40px;max-height:none;overflow:visible}
  .modal-close{background:rgba(0,0,0,.25);color:#fff}
}
@media(max-width:760px){
  .lang-switch{right:14px;bottom:14px;padding:5px 7px 5px 11px}
  .lang-opt{padding:6px 10px;font-size:.7rem}
}

/* ===========================================================
   RESPONSIVE
   =========================================================== */
@media(max-width:980px){
  .hero-grid,.panel.active{grid-template-columns:1fr;gap:40px}
  .hero-copy{order:-1}
  .programs,.benefits-grid,.feat-grid{grid-template-columns:repeat(2,1fr)}
  .stats-grid,.blocks{grid-template-columns:1fr}
  .price-grid{grid-template-columns:repeat(3,1fr)}
  .price-calc{grid-template-columns:1fr;gap:24px}
  .benefits-grid{border-radius:22px}
  .plan.feat{transform:none}
  .plan.feat:hover{transform:translateY(-6px)}
  .foot-grid{grid-template-columns:1fr 1fr}
  .hero-slider{max-width:440px;margin:0 auto;width:100%}
}
@media(max-width:760px){
  body{font-size:16px}
  .nav-links{display:none}
  .nav-right .btn:not(.burger){display:none}
  .burger{display:flex}
  .logo img{height:32px}
  .programs,.benefits-grid,.feat-grid{grid-template-columns:1fr}
  .price-grid{grid-template-columns:1fr}
  .plan.is-reco{transform:none}
  section{padding:72px 0}
  .stats{padding:60px 0}
  .hero{padding:60px 0 72px}
  .trust-in{flex-direction:column;gap:18px;align-items:flex-start}
  .float-chip,.float-card{display:none}
  .hslides{height:420px}
  .giftcard.alt{margin-left:0}
  .cta-box{padding:56px 26px}
  .foot-grid{grid-template-columns:1fr;gap:30px}
  .email-cta,.cta-email{flex-direction:column;align-items:stretch;border-radius:14px;padding:10px}
  .email-cta input,.cta-email input{padding:14px 16px}
  .email-cta .btn,.cta-email .btn{width:100%;justify-content:center}
  .ring-wrap{flex-direction:column;align-items:flex-start}
}
