/* ================================================================
   Good Food CR — Design System
   Replicado de goodfood-website.vercel.app
   Sistema por SynappCR
   ================================================================ */

/* ── GOOGLE FONTS ─────────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800;900&family=DM+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,300;1,400;1,500;1,600;1,700&display=swap');

/* ── COLOR VARIABLES ──────────────────────────────────────────── */
:root {
  --forest:   #1c3a2d;
  --forest-2: #2e5040;
  --leaf:     #2e5040;
  --ink:      #1a1a18;
  --ash:      #6b6b5e;
  --cream:    #fbf6ee;
  --cream-2:  #ece5d5;
  --cream-3:  #f4efe4;
  --citrus:   #c8913a;
  --citrus-2: #daa34a;
  --coral:    #b5523a;
  --blush:    #e8c4b0;
  --lime:     #c4e16b;
  --sky:      #d4ede1;
  --white:    #ffffff;

  /* ── typography scale identical to original ── */
  --font-display: 'Outfit', 'DM Sans', sans-serif;
  --font-body:    'DM Sans', 'Outfit', sans-serif;

  /* spacing */
  --cx-px:   clamp(16px, 5vw, 80px);
  --header-h: 64px;
  --topbar-h: 40px;
}

/* ── RESET ────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);color:var(--forest);background:var(--cream);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button{cursor:pointer;font-family:inherit;background:none;border:none}
input,select,textarea{font-family:inherit}

/* ── LAYOUT ────────────────────────────────────────────────────── */
.container-x{max-width:1200px;margin-inline:auto;padding-inline:var(--cx-px)}
.container-narrow{max-width:760px;margin-inline:auto;padding-inline:var(--cx-px)}

/* ── TYPOGRAPHY ────────────────────────────────────────────────── */
/* Display font = the big headings (Outfit as brandon-grotesque) */
.display{font-family:var(--font-display);font-weight:700;letter-spacing:-0.025em;line-height:1}
.display-black{font-weight:900}
.italic{font-style:italic}
.tnum{font-variant-numeric:tabular-nums}

/* Sizes matching the original site */
.t-hero   {font-size:clamp(44px,6.8vw,92px);line-height:.95;letter-spacing:-0.04em}
.t-section{font-size:clamp(30px,4vw,52px);line-height:1.02;letter-spacing:-0.025em}
.t-sub    {font-size:clamp(20px,2.2vw,28px);line-height:1.15;letter-spacing:-0.015em}
.t-lead   {font-size:clamp(16px,1.2vw,19px);line-height:1.55}
.t-body   {font-size:15.5px;line-height:1.6}

/* Small all-caps label */
.label{font-family:var(--font-display);font-size:11px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;line-height:1}

/* ── SECTIONS ──────────────────────────────────────────────────── */
.section   {padding-block:clamp(56px,8vw,120px)}
.section-sm{padding-block:clamp(40px,5vw,72px)}

/* ── HAIR BORDERS ──────────────────────────────────────────────── */
.hair        {border:1px solid rgba(28,58,45,.10)}
.hair-t      {border-top:1px solid rgba(28,58,45,.10)}
.hair-b      {border-bottom:1px solid rgba(28,58,45,.10)}
.hair-r      {border-right:1px solid rgba(28,58,45,.10)}
.hair-light-t{border-top:1px solid rgba(251,246,238,.12)}
.hair-light-b{border-bottom:1px solid rgba(251,246,238,.12)}

/* ── BUTTONS ───────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  gap:8px;padding:13px 26px;border-radius:999px;
  font-family:var(--font-display);font-size:14px;font-weight:600;
  letter-spacing:0.01em;line-height:1;cursor:pointer;
  transition:all .25s cubic-bezier(.4,0,.2,1);
  text-decoration:none;border:1.5px solid transparent;
  white-space:nowrap;
}
.btn-citrus  {background:var(--citrus);color:var(--forest);border-color:var(--citrus)}
.btn-citrus:hover{background:var(--citrus-2);border-color:var(--citrus-2);transform:translateY(-1px);box-shadow:0 6px 20px rgba(200,145,58,.35)}
.btn-forest  {background:var(--forest);color:var(--cream);border-color:var(--forest)}
.btn-forest:hover{background:var(--forest-2);border-color:var(--forest-2);transform:translateY(-1px);box-shadow:0 6px 20px rgba(28,58,45,.3)}
.btn-cream   {background:var(--cream);color:var(--forest);border-color:transparent}
.btn-cream:hover{background:var(--cream-2);transform:translateY(-1px)}
.btn-ghost-white{background:transparent;color:var(--cream);border-color:rgba(251,246,238,.3)}
.btn-ghost-white:hover{background:rgba(251,246,238,.1);border-color:rgba(251,246,238,.5)}
.btn-ghost-forest{background:transparent;color:var(--forest);border-color:rgba(28,58,45,.25)}
.btn-ghost-forest:hover{background:rgba(28,58,45,.05);border-color:rgba(28,58,45,.4)}

/* Pill = smaller button variant */
.pill{
  display:inline-flex;align-items:center;padding:7px 14px;border-radius:999px;
  font-family:var(--font-display);font-size:12px;font-weight:600;
  letter-spacing:0.01em;cursor:pointer;transition:all .2s;
  border:1px solid transparent;line-height:1;
}

/* ── NOISE TEXTURE ─────────────────────────────────────────────── */
.noise::before{
  content:'';position:absolute;inset:0;opacity:.035;pointer-events:none;z-index:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ── TOPBAR ────────────────────────────────────────────────────── */
.topbar{
  position:relative;z-index:50;
  background:var(--forest);color:rgba(251,246,238,.9);
  border-bottom:1px solid rgba(251,246,238,.05);
}
.topbar-inner{
  padding-block:10px;display:flex;align-items:center;
  justify-content:space-between;gap:16px;
}
.topbar-dot{
  display:inline-block;width:6px;height:6px;border-radius:50%;
  background:var(--citrus);flex-shrink:0;
  animation:pulseDot 2s ease-in-out infinite;
}
.topbar-text{font-size:12.5px;letter-spacing:.04em}
.topbar-close{opacity:.4;font-size:11px;flex-shrink:0;transition:opacity .2s}
.topbar-close:hover{opacity:1}

/* ── HEADER ────────────────────────────────────────────────────── */
/*
 * Header siempre con fondo crema — igual en todas las páginas.
 * Al hacer scroll agrega blur y sombra.
 */
.site-header{
  position:sticky;top:0;z-index:40;
  background:rgba(251,246,238,.97);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(28,58,45,.07);
  transition:box-shadow .3s;
}
.site-header.scrolled{
  box-shadow:0 2px 16px rgba(28,58,45,.10);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding-block:14px;gap:16px;
}

/* ── Desktop nav — hidden below 768px ── */
.header-nav{display:none;align-items:center;gap:2px}
@media(min-width:768px){.header-nav{display:flex}}
.header-nav a{
  font-size:13.5px;font-weight:500;color:rgba(28,58,45,.75);
  padding:8px 14px;border-radius:999px;
  transition:color .2s,background .2s;white-space:nowrap;
}
.header-nav a:hover{color:var(--forest);background:rgba(28,58,45,.04)}
.header-nav a.active{color:var(--forest);font-weight:600;background:rgba(28,58,45,.06)}

/* ── Pedir ahora — hidden below 640px ── */
.header-pedir{
  display:none;align-items:center;gap:6px;
  background:var(--forest);color:var(--cream);
  border-radius:999px;padding:10px 20px;
  font-size:13px;font-weight:600;
  transition:background .2s;white-space:nowrap;
  text-decoration:none;
}
@media(min-width:640px){.header-pedir{display:inline-flex}}
.header-pedir:hover{background:var(--ink)}
.header-pedir-arrow{color:var(--citrus)}

/* ── Hamburger — hidden above 768px ── */
.header-hamburger{
  display:flex;width:40px;height:40px;border-radius:50%;
  background:var(--forest);color:var(--cream);
  align-items:center;justify-content:center;
  flex-shrink:0;cursor:pointer;border:none;
}
@media(min-width:768px){.header-hamburger{display:none}}

/* ── Logo ── */
#headerLogo{height:40px;width:auto;transition:filter .4s ease}

/* on-dark removido — header idéntico en todas las páginas */

.header-actions{display:flex;align-items:center;gap:8px}
.cart-btn{
  position:relative;width:40px;height:40px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:rgba(28,58,45,.8);transition:all .2s;
}
.cart-btn:hover{background:rgba(28,58,45,.05);color:var(--forest)}
.cart-badge{
  position:absolute;top:2px;right:2px;
  background:var(--citrus);color:var(--forest);
  font-size:9px;font-weight:900;border-radius:999px;
  min-width:16px;height:16px;padding:0 4px;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);
}
/* (header-pedir + header-hamburger defined above in header block) */

/* ── MOBILE DRAWER ─────────────────────────────────────────────── */
.mobile-drawer{
  position:fixed;inset:0;z-index:100;
  display:grid;grid-template-columns:1fr 320px;
  pointer-events:none;opacity:0;
  transition:opacity .3s;
}
.mobile-drawer.open{pointer-events:all;opacity:1}
.drawer-overlay{background:rgba(26,26,24,.5);backdrop-filter:blur(4px)}
.drawer-panel{
  background:var(--cream);padding:28px 24px;
  display:flex;flex-direction:column;gap:4px;
  transform:translateX(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);
  overflow-y:auto;
}
.mobile-drawer.open .drawer-panel{transform:none}
.drawer-close{
  align-self:flex-end;margin-bottom:24px;
  width:36px;height:36px;border-radius:50%;
  background:rgba(28,58,45,.06);color:var(--forest);
  display:flex;align-items:center;justify-content:center;font-size:18px;
}
.drawer-nav a{
  display:block;font-family:var(--font-display);font-size:24px;font-weight:700;
  color:var(--forest);padding:12px 0;
  border-bottom:1px solid rgba(28,58,45,.08);
  transition:color .2s;
}
.drawer-nav a:hover{color:var(--citrus)}
.drawer-cta{margin-top:24px}

/* ── PROGRESS BAR ──────────────────────────────────────────────── */
.progress-bar{
  position:fixed;top:0;left:0;right:0;height:2px;
  background:var(--citrus);z-index:60;pointer-events:none;
  transform-origin:0 50%;transform:scaleX(0);transition:transform .1s linear;
}

/* ── HERO SECTION ──────────────────────────────────────────────── */
.hero-section{
  position:relative;background:var(--forest);color:var(--cream);
  overflow:hidden;
}
.hero-glow-1{
  position:absolute;top:-160px;right:-128px;
  width:420px;height:420px;border-radius:50%;
  background:rgba(46,80,64,.6);filter:blur(140px);pointer-events:none;
}
.hero-glow-2{
  position:absolute;bottom:-80px;left:25%;
  width:320px;height:320px;border-radius:50%;
  background:rgba(200,145,58,.1);filter:blur(140px);pointer-events:none;
}
.hero-inner{
  position:relative;padding-block:clamp(40px,6vw,80px);
}
.hero-grid{
  display:grid;gap:32px 48px;align-items:center;
}
@media(min-width:1024px){
  .hero-grid{grid-template-columns:7fr 5fr}
}
.hero-title{
  font-family:var(--font-display);
  font-size:clamp(44px,6.8vw,92px);
  font-weight:900;line-height:.95;letter-spacing:-0.04em;
  color:var(--cream);
}
.hero-title .italic-accent{
  font-style:italic;color:var(--citrus);
}
.hero-subtitle{
  margin-top:clamp(20px,2vw,28px);
  font-size:clamp(15px,1.5vw,17.5px);
  color:rgba(251,246,238,.75);max-width:440px;line-height:1.55;
}
.hero-btns{margin-top:clamp(24px,3vw,32px);display:flex;flex-wrap:wrap;gap:12px}
.hero-card{
  position:relative;border-radius:20px;overflow:hidden;
  background:var(--forest-2);
  height:clamp(320px,45vw,540px);
}
.hero-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-card-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(28,58,45,.4),transparent);
}
.hero-card-badge{
  position:absolute;bottom:-16px;right:-12px;
  background:var(--citrus);color:var(--forest);
  padding:14px 20px;border-radius:16px;
  box-shadow:0 18px 36px -14px rgba(200,145,58,.5);
  max-width:260px;
}
.hero-card-badge p{font-size:14px;font-weight:700;line-height:1.3;font-family:var(--font-display)}
.hero-dots{
  position:absolute;top:12px;right:12px;
  display:flex;align-items:center;gap:6px;
}
.hero-dot{
  height:6px;border-radius:999px;background:rgba(251,246,238,.4);
  transition:all .5s;cursor:pointer;
}
.hero-dot.active{width:28px;background:var(--citrus)}
.hero-dot:not(.active){width:6px}
.hero-dot:hover:not(.active){background:rgba(251,246,238,.7)}

/* ── MARQUEE ───────────────────────────────────────────────────── */
.marquee{overflow:hidden;will-change:transform}
.marquee-track{
  display:flex;white-space:nowrap;will-change:transform;
  animation:marquee 28s linear infinite;
}
.marquee-track:hover{animation-play-state:paused}
.marquee-item{
  display:inline-flex;align-items:center;gap:32px;padding-right:32px;
  font-family:var(--font-display);font-weight:900;
  font-size:clamp(40px,7vw,96px);letter-spacing:-0.03em;line-height:1;
}
.marquee-dot{color:var(--citrus);font-size:.4em;vertical-align:middle}

/* Second marquee (stats) goes slower */
.marquee-slow .marquee-track{animation-duration:45s}
.marquee-reverse .marquee-track{animation-direction:reverse}

/* ── BIG NAV SECTIONS ──────────────────────────────────────────── */
.big-nav-section{position:relative;background:var(--cream);overflow:hidden}
.big-nav-item{
  display:block;position:relative;overflow:hidden;
  transition:opacity .2s;
}
.big-nav-item:hover .big-nav-arrow{opacity:1;transform:none}
.big-nav-title{
  font-family:var(--font-display);font-weight:900;line-height:1;
  font-size:clamp(56px,12vw,180px);letter-spacing:-0.04em;
  transition:transform .7s cubic-bezier(.4,0,.2,1);
}
.big-nav-item:hover .big-nav-title{transform:translateX(8px)}
.big-nav-inner{
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding-block:clamp(28px,4vw,48px);
}
.big-nav-arrow{
  font-size:clamp(28px,4vw,42px);opacity:.6;
  transition:opacity .5s,transform .5s;
  transform:translateX(-4px);
}
.big-nav-item.market  {background:var(--cream-2);color:var(--forest)}
.big-nav-item.programas{background:var(--blush);color:var(--forest)}
.big-nav-item.cafe    {background:var(--coral);color:var(--cream)}
.big-nav-item.empresas{background:var(--forest);color:var(--cream)}

/* ── PROMO CARDS ───────────────────────────────────────────────── */
.promo-grid{display:grid;gap:16px}
@media(min-width:768px){.promo-grid{grid-template-columns:2fr 1fr}}
.promo-card{
  position:relative;border-radius:24px;overflow:hidden;
  transition:transform .3s;
}
.promo-card a.cover{position:absolute;inset:0;z-index:10}
.promo-card:hover{transform:scale(1.01)}
.promo-card:hover .promo-card-img{transform:scale(1.05)}
.promo-card-body{position:relative;height:100%;display:flex;flex-direction:column;justify-content:space-between;padding:clamp(24px,3vw,36px)}
.promo-card-img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:contain;object-position:center;
  transition:transform .7s cubic-bezier(.4,0,.2,1);
}
.promo-col{display:grid;grid-rows:1fr 1fr;gap:16px}

/* ── HOW IT WORKS ──────────────────────────────────────────────── */
.steps-grid{display:grid;gap:16px}
@media(min-width:640px){.steps-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.steps-grid{grid-template-columns:repeat(4,1fr)}}
.step-card{
  border-radius:20px;padding:clamp(24px,3vw,32px);
  background:var(--cream);
  border:1px solid rgba(28,58,45,.10);
  transition:transform .5s,background .3s;
  display:block;text-decoration:none;color:inherit;
}
.step-card:hover{transform:translateY(-4px);background:var(--white)}
.step-num{
  font-family:var(--font-display);font-weight:900;color:var(--citrus);
  font-size:56px;line-height:1;display:block;margin-bottom:24px;
}
.step-title{font-family:var(--font-display);font-size:clamp(18px,2vw,24px);color:var(--forest);line-height:1.2;font-weight:700}
.step-desc{margin-top:12px;font-size:14.5px;color:rgba(28,58,45,.65);line-height:1.6}
.step-more{
  margin-top:24px;display:inline-flex;align-items:center;gap:8px;
  font-size:12.5px;font-weight:700;color:var(--citrus);
  opacity:0;transition:opacity .2s;
}
.step-card:hover .step-more{opacity:1}

/* ── BUNDLES (on dark) ─────────────────────────────────────────── */
.bundles-grid{display:grid;gap:20px}
@media(min-width:768px){.bundles-grid{grid-template-columns:repeat(3,1fr)}}
.bundle-card{
  position:relative;border-radius:16px;overflow:hidden;
  background:rgba(251,246,238,.04);backdrop-filter:blur(12px);
  border:1px solid rgba(251,246,238,.10);
  transition:all .5s;
}
.bundle-card:hover{
  border-color:rgba(200,145,58,.5);transform:translateY(-4px);
}
.bundle-img{position:relative;aspect-ratio:4/3;overflow:hidden}
.bundle-img img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  transition:transform .7s cubic-bezier(.4,0,.2,1);
}
.bundle-card:hover .bundle-img img{transform:scale(1.05)}
.bundle-pill{
  position:absolute;top:16px;left:16px;
  background:var(--cream);color:var(--forest);
  font-family:var(--font-display);font-size:11px;font-weight:700;
  padding:5px 12px;border-radius:999px;
}
.bundle-body{padding:24px}
.bundle-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.bundle-name{font-family:var(--font-display);font-size:22px;font-weight:700;color:var(--cream);line-height:1.2}
.bundle-price{
  font-family:var(--font-display);font-weight:900;
  color:var(--citrus);font-size:19px;white-space:nowrap;
}
.bundle-desc{margin-top:8px;font-size:14px;color:rgba(251,246,238,.65);line-height:1.5}
.bundle-features{margin-top:20px;display:flex;flex-direction:column;gap:6px}
.bundle-feature{font-size:13px;color:rgba(251,246,238,.75);display:flex;align-items:center;gap:8px}
.bundle-feature-dot{width:4px;height:4px;border-radius:50%;background:var(--citrus);flex-shrink:0}

/* ── BODY BENEFITS ─────────────────────────────────────────────── */
.body-grid{display:grid;gap:48px 64px;align-items:center}
@media(min-width:768px){.body-grid{grid-template-columns:5fr 7fr}}
.body-figure{max-width:360px;margin:0 auto}
.body-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:28px}
.body-tab{
  cursor:pointer;border:1px solid rgba(251,246,238,.10);
  color:rgba(251,246,238,.65);background:rgba(251,246,238,.05);
  transition:all .2s;
}
.body-tab.active{background:var(--citrus);color:var(--forest);border-color:var(--citrus)}
.body-tab:hover:not(.active){color:var(--cream);border-color:rgba(251,246,238,.3)}
.body-panel{
  border-radius:16px;background:rgba(251,246,238,.04);
  backdrop-filter:blur(4px);border:1px solid rgba(251,246,238,.10);
  padding:clamp(24px,3vw,40px);
}
.body-panel-label{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.body-panel-title{
  font-family:var(--font-display);font-style:italic;font-weight:900;
  font-size:clamp(28px,4.2vw,52px);line-height:1;color:var(--cream);
}
.body-panel-text{margin-top:20px;font-size:15.5px;color:rgba(251,246,238,.7);line-height:1.7;max-width:520px}
.body-panel-grid{margin-top:36px;display:grid;gap:32px}
@media(min-width:640px){.body-panel-grid{grid-template-columns:2fr 3fr}}
.body-panel-list-title{font-family:var(--font-display);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:rgba(251,246,238,.4);margin-bottom:12px}
.body-panel-list li{font-size:14px;color:rgba(251,246,238,.85);display:flex;align-items:center;gap:10px;padding:3px 0}
.body-panel-list .dot{width:6px;height:6px;border-radius:50%;background:var(--citrus);flex-shrink:0}
.body-product-link{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 0;border-bottom:1px solid rgba(251,246,238,.10);
  transition:border-color .2s;
}
.body-product-link:hover{border-bottom-color:rgba(200,145,58,.6)}
.body-product-name{font-size:15px;color:rgba(251,246,238,.9)}
.body-product-cat{font-size:11px;color:rgba(251,246,238,.4);display:flex;align-items:center;gap:6px;transition:color .2s}
.body-product-link:hover .body-product-cat{color:var(--citrus)}
.body-panel-btns{margin-top:40px;display:flex;flex-wrap:wrap;align-items:center;gap:16px}

/* ── SCROLL TEXT SECTION ───────────────────────────────────────── */
.scroll-section{
  background:var(--forest);color:var(--cream);
  height:400vh;position:relative;
}
.scroll-sticky{
  position:sticky;top:0;height:100vh;
  display:flex;align-items:center;overflow:hidden;
}
.scroll-label{font-family:var(--font-display);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--citrus);margin-bottom:32px}
.scroll-title{
  font-family:var(--font-display);font-weight:900;
  font-size:clamp(48px,9vw,140px);line-height:.95;letter-spacing:-0.04em;
  color:var(--cream);
}
.scroll-word{
  position:absolute;inset:0;font-style:italic;color:var(--citrus);
  font-family:var(--font-display);font-weight:900;
  opacity:0;transform:translateY(40%);transition:none;
}
.scroll-word.active{opacity:1;transform:none}
.scroll-glow-1{position:absolute;top:25%;left:-128px;width:420px;height:420px;border-radius:50%;background:rgba(200,145,58,.1);filter:blur(140px);pointer-events:none}
.scroll-glow-2{position:absolute;bottom:25%;right:-128px;width:360px;height:360px;border-radius:50%;background:rgba(46,80,64,.2);filter:blur(140px);pointer-events:none}
.scroll-dots{margin-top:48px;display:flex;gap:8px}
.scroll-dot{height:4px;border-radius:999px;background:var(--citrus);transition:opacity .3s}

/* ── PROGRAMS ──────────────────────────────────────────────────── */
.programs-grid{display:grid;gap:clamp(32px,5vw,80px);align-items:center}
@media(min-width:768px){.programs-grid{grid-template-columns:1fr 1fr}}
.program-img-wrap{
  position:relative;border-radius:20px;overflow:hidden;
  background:var(--forest);
}
.program-img-inner{position:relative;aspect-ratio:4/5;overflow:hidden}
.program-img-inner img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.program-img-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(28,58,45,.6),transparent)}
.program-img-tag{
  position:absolute;top:20px;left:20px;
  background:var(--citrus);color:var(--forest);
  font-family:var(--font-display);font-size:11px;font-weight:700;
  padding:5px 12px;border-radius:999px;
}
.program-img-badge{
  position:absolute;bottom:20px;left:20px;right:20px;
  background:var(--cream);color:var(--forest);
  padding:16px;border-radius:12px;border:1px solid rgba(28,58,45,.12);
  display:flex;align-items:baseline;gap:12px;
}
.program-badge-num{
  font-family:var(--font-display);font-weight:900;font-size:44px;
  line-height:1;color:var(--forest);
}
.program-badge-info div:first-child{font-family:var(--font-display);font-size:13px;line-height:1;margin-top:4px}
.program-badge-info div:last-child{font-size:11px;color:rgba(28,58,45,.55);margin-top:4px}
.program-badge-price{margin-left:auto;font-family:var(--font-display);font-weight:900;font-size:20px}
.program-days-nav{
  display:flex;align-items:center;gap:0;border-top:1px solid rgba(28,58,45,.10);
  padding-top:20px;margin-top:40px;
}
.day-btn{
  flex:1;text-align:left;padding-right:16px;
  opacity:.4;transition:opacity .2s;cursor:pointer;
}
.day-btn:hover{opacity:.7}
.day-btn.active{opacity:1}
.day-btn-num{
  font-family:var(--font-display);font-weight:900;font-size:18px;
  color:var(--forest);display:block;margin-bottom:8px;
}
.day-btn-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:rgba(28,58,45,.5)}
.day-btn-line{height:2px;border-radius:999px;margin-top:8px;transition:background .3s}
.day-btn.active .day-btn-line{background:var(--citrus)}
.day-btn:not(.active) .day-btn-line{background:rgba(28,58,45,.2)}

/* ── STATS MARQUEE ─────────────────────────────────────────────── */
.stats-marquee-item{
  display:flex;align-items:baseline;gap:12px;white-space:nowrap;padding-right:48px;
}
.stats-num{
  font-family:var(--font-display);font-weight:900;
  font-size:clamp(28px,4vw,42px);color:var(--forest);line-height:1;
}
.stats-label{font-size:clamp(12px,1.2vw,14px);color:rgba(28,58,45,.65)}
.stats-star{color:var(--citrus);margin-inline:16px}

/* ── TESTIMONIALS ──────────────────────────────────────────────── */
.testimonials-scroll{
  display:flex;gap:20px;overflow-x:auto;
  scroll-snap-type:x mandatory;scrollbar-width:none;
  padding-bottom:8px;
}
.testimonials-scroll::-webkit-scrollbar{display:none}
.testimonial-card{
  flex:0 0 85%;max-width:420px;background:var(--cream);
  border-radius:20px;padding:28px;scroll-snap-align:start;
}
@media(min-width:768px){.testimonial-card{flex:0 0 420px}}
.testimonial-stars{color:var(--citrus);font-size:18px;margin-bottom:16px}
.testimonial-quote{
  font-size:16px;font-style:italic;color:rgba(28,58,45,.8);
  line-height:1.7;margin-bottom:24px;
}
.testimonial-quote strong{font-style:normal;color:var(--forest)}
.testimonial-author{display:flex;align-items:center;gap:12px}
.testimonial-avatar{
  width:44px;height:44px;border-radius:50%;overflow:hidden;flex-shrink:0;
  background:var(--cream-2);
}
.testimonial-avatar img{width:100%;height:100%;object-fit:cover}
.testimonial-name{font-weight:600;font-size:14px;color:var(--forest)}
.testimonial-role{font-size:12px;color:rgba(28,58,45,.5)}
.testimonial-tag{
  margin-left:auto;font-family:var(--font-display);font-size:11px;
  background:rgba(28,58,45,.05);color:var(--forest);padding:5px 12px;border-radius:999px;
}
.testimonials-nav{display:flex;gap:12px;margin-bottom:20px}
.testimonials-nav button{
  width:48px;height:48px;border-radius:50%;background:var(--forest);
  color:var(--cream);font-size:18px;transition:background .2s;
  display:flex;align-items:center;justify-content:center;
}
.testimonials-nav button:hover{background:var(--coral)}
.testimonials-nav button:disabled{opacity:.3;cursor:default}

/* ── CTA SECTION ───────────────────────────────────────────────── */
.cta-section{
  position:relative;background:var(--forest);color:var(--cream);
  overflow:hidden;
}
.cta-glow-1{position:absolute;top:0;left:-64px;width:360px;height:360px;border-radius:50%;background:rgba(200,145,58,.12);filter:blur(120px);pointer-events:none}
.cta-glow-2{position:absolute;bottom:0;right:-64px;width:360px;height:360px;border-radius:50%;background:rgba(46,80,64,.3);filter:blur(120px);pointer-events:none}

/* ── FOOTER ────────────────────────────────────────────────────── */
.site-footer{background:var(--ink);color:rgba(251,246,238,.85)}
.footer-grid{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:clamp(32px,5vw,48px) 24px;
  padding-block:clamp(40px,6vw,80px);
}
@media(min-width:768px){.footer-grid{grid-template-columns:4fr 2fr 3fr 3fr}}
.footer-brand-col{grid-column:1/-1}
@media(min-width:768px){.footer-brand-col{grid-column:auto}}
.footer-logo{
  height:64px;width:auto;
  filter:invert(95%) sepia(7%) saturate(330%) hue-rotate(8deg) brightness(110%);
}
.footer-tagline{margin-top:20px;font-size:14px;color:rgba(251,246,238,.7);max-width:340px;line-height:1.6}
.footer-tagline-2{margin-top:12px;font-size:13px;color:rgba(251,246,238,.55);font-style:italic;max-width:340px}
.footer-social{margin-top:24px;display:flex;gap:10px}
.footer-social a{
  width:40px;height:40px;border-radius:50%;
  border:1px solid rgba(251,246,238,.2);
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:700;
  transition:background .2s,border-color .2s,color .2s;
}
.footer-social a:hover{background:var(--citrus);color:var(--forest);border-color:var(--citrus)}
.footer-col-title{font-family:var(--font-display);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:rgba(251,246,238,.45);margin-bottom:16px}
.footer-col ul{display:flex;flex-direction:column;gap:10px}
.footer-col a{font-size:14px;color:rgba(251,246,238,.85);transition:color .2s}
.footer-col a:hover{color:var(--citrus)}
.footer-bottom{
  border-top:1px solid rgba(251,246,238,.1);
  padding-block:20px;display:flex;flex-wrap:wrap;
  justify-content:space-between;align-items:center;gap:12px;
}
.footer-copy{font-size:11.5px;color:rgba(251,246,238,.5)}
.footer-payments{display:flex;gap:16px;font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:rgba(251,246,238,.5)}

/* ── ALERTS & FLASH ────────────────────────────────────────────── */
.alert{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;border-radius:12px;font-size:14px;margin-bottom:12px}
.alert--success{background:#e8f5ee;color:#166534;border:1px solid rgba(22,101,52,.2)}
.alert--error  {background:rgba(181,82,58,.1);color:var(--coral);border:1px solid rgba(181,82,58,.2)}
.alert--warning{background:rgba(200,145,58,.1);color:#7c5a0a;border:1px solid rgba(200,145,58,.25)}
.alert--info   {background:rgba(28,58,45,.07);color:var(--forest);border:1px solid rgba(28,58,45,.12)}
.alert__close  {font-size:18px;opacity:.6;cursor:pointer;flex-shrink:0}
.flash-container{position:fixed;top:80px;right:20px;z-index:500;width:360px;max-width:calc(100vw - 40px)}

/* ── BADGES ────────────────────────────────────────────────────── */
.badge{display:inline-block;font-size:11px;font-weight:700;padding:3px 8px;border-radius:999px}
.badge--green {background:#e8f5ee;color:#166534}
.badge--yellow{background:rgba(200,145,58,.12);color:#7c5a0a}
.badge--red   {background:rgba(181,82,58,.1);color:var(--coral)}
.badge--blue  {background:rgba(28,58,45,.08);color:var(--forest)}
.badge--gray  {background:var(--cream-3);color:var(--ash)}

/* ── BREADCRUMB ────────────────────────────────────────────────── */
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ash);padding-block:16px}
.breadcrumb a:hover{color:var(--forest)}
.breadcrumb-sep{color:rgba(28,58,45,.25)}

/* ── CART ──────────────────────────────────────────────────────── */
.cart-layout{display:grid;gap:40px;align-items:start}
@media(min-width:768px){.cart-layout{grid-template-columns:1fr 380px}}
.cart-items{display:flex;flex-direction:column;border:1px solid rgba(28,58,45,.10);border-radius:20px;overflow:hidden}
.cart-item{display:grid;grid-template-columns:80px 1fr auto;gap:16px;align-items:center;padding:20px;background:var(--white)}
.cart-item+.cart-item{border-top:1px solid rgba(28,58,45,.08)}
.cart-item-img{width:80px;height:80px;border-radius:12px;object-fit:cover;background:var(--cream-3)}
.cart-item-name{font-size:15px;font-weight:700;color:var(--forest);margin-bottom:2px}
.cart-item-price{font-size:13px;color:var(--ash)}
.qty-controls{display:flex;align-items:center;gap:8px;margin-top:8px}
.qty-btn{width:30px;height:30px;border-radius:50%;border:1.5px solid rgba(28,58,45,.15);display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--forest);transition:all .2s;cursor:pointer}
.qty-btn:hover{border-color:var(--forest);background:rgba(28,58,45,.06)}
.qty-input{width:36px;text-align:center;font-size:16px;font-weight:700;border:none;outline:none;background:transparent;color:var(--forest)}
.cart-remove{color:var(--ash);font-size:20px;padding:4px;transition:color .2s;cursor:pointer}
.cart-remove:hover{color:var(--coral)}
.cart-subtotal{font-size:16px;font-weight:800;text-align:right;min-width:100px;color:var(--forest)}
.cart-summary{position:sticky;top:80px;background:var(--white);border:1px solid rgba(28,58,45,.10);border-radius:20px;padding:28px}
.cart-summary-title{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--forest);margin-bottom:20px}
.cart-summary-row{display:flex;justify-content:space-between;align-items:center;font-size:14px;padding:10px 0;border-bottom:1px solid rgba(28,58,45,.07)}
.cart-summary-row:last-child{border-bottom:none}
.cart-summary-total{font-size:20px;font-weight:800;padding-top:16px}
.cart-shipping-free{font-size:13px;color:#166534;font-weight:600}
.coupon-row{display:flex;gap:8px;margin:14px 0}
.coupon-input{flex:1;padding:9px 14px;border:1.5px solid rgba(28,58,45,.15);border-radius:10px;font-size:13px;outline:none;transition:border-color .2s;color:var(--forest);background:var(--cream)}
.coupon-input:focus{border-color:var(--forest)}

/* ── CHECKOUT ──────────────────────────────────────────────────── */
.checkout-layout{display:grid;gap:48px;align-items:start}
@media(min-width:768px){.checkout-layout{grid-template-columns:1fr 420px}}
.form-section{background:var(--white);border-radius:20px;border:1px solid rgba(28,58,45,.10);padding:28px;margin-bottom:20px}
.form-section-title{font-family:var(--font-display);font-size:17px;font-weight:700;color:var(--forest);margin-bottom:20px;display:flex;align-items:center;gap:10px}
.form-section-title svg{color:var(--citrus)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group{display:flex;flex-direction:column;gap:5px}
.form-group label{font-size:13px;font-weight:600;color:var(--forest)}
.form-group input,.form-group select,.form-group textarea{padding:11px 14px;border:1.5px solid rgba(28,58,45,.15);border-radius:10px;font-size:14px;outline:none;transition:all .2s;background:var(--cream);color:var(--forest)}
.form-group input::placeholder,.form-group textarea::placeholder{color:rgba(28,58,45,.35)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--forest);box-shadow:0 0 0 3px rgba(28,58,45,.08);background:var(--white)}
.form-group textarea{resize:vertical;min-height:80px}
.form-hint{font-size:12px;color:var(--ash)}
.form-error{font-size:12px;color:var(--coral)}
.payment-options{display:flex;flex-direction:column;gap:10px}
.payment-option{display:flex;align-items:center;gap:12px;padding:14px 18px;border:1.5px solid rgba(28,58,45,.12);border-radius:12px;cursor:pointer;transition:all .2s;background:var(--cream)}
.payment-option.selected,.payment-option:hover{border-color:var(--forest);background:rgba(28,58,45,.04)}
.payment-option input[type=radio]{accent-color:var(--forest);width:16px;height:16px}
.payment-option-name{font-weight:600;font-size:14px;color:var(--forest)}
.payment-option-desc{font-size:12px;color:var(--ash)}
.sinpe-info{background:rgba(28,58,45,.04);border:1px solid rgba(28,58,45,.10);border-radius:12px;padding:20px;margin-top:14px}
.sinpe-number{font-family:var(--font-display);font-size:26px;font-weight:900;color:var(--forest);letter-spacing:2px}
.sinpe-name{font-size:13px;color:var(--ash);margin-top:4px}
.order-summary{position:sticky;top:80px}
.order-items{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}
.order-item{display:flex;align-items:center;gap:12px}
.order-item-img{position:relative;width:56px;height:56px;border-radius:8px;overflow:hidden;border:1px solid rgba(28,58,45,.10);flex-shrink:0;background:var(--cream-3)}
.order-item-img img{width:100%;height:100%;object-fit:cover}
.order-qty-badge{position:absolute;top:-8px;right:-8px;background:var(--forest);color:var(--cream);font-size:11px;font-weight:700;min-width:20px;height:20px;border-radius:999px;display:flex;align-items:center;justify-content:center;padding:0 4px}
.order-item-name{font-size:13px;font-weight:600;color:var(--forest);line-height:1.3}
.order-item-price{font-size:12px;color:var(--ash)}
.order-item-total{font-size:14px;font-weight:700;color:var(--forest);margin-left:auto}
.order-item-info{flex:1}

/* ── EMPTY STATE ───────────────────────────────────────────────── */
.empty-state{text-align:center;padding:80px 20px}
.empty-icon{font-size:56px;margin-bottom:20px}
.empty-title{font-family:var(--font-display);font-size:22px;font-weight:700;color:var(--forest);margin-bottom:10px}
.empty-desc{font-size:15px;color:var(--ash);margin-bottom:24px}

/* ── CONFIRM ───────────────────────────────────────────────────── */
.confirm-check{width:80px;height:80px;border-radius:50%;background:#e8f5ee;color:#166534;display:flex;align-items:center;justify-content:center;margin:0 auto 24px;font-size:36px}
.confirm-box{background:var(--cream-3);border-radius:20px;padding:24px;margin:24px 0}
.confirm-row{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px solid rgba(28,58,45,.08);font-size:14px}
.confirm-row:last-child{border:none}
.confirm-label{color:var(--ash)}
.confirm-value{font-weight:700;color:var(--forest)}

/* ── LEGAL ARTICLE PAGES ───────────────────────────────────────── */
.legal-back{
  font-size:12.5px;letter-spacing:.1em;text-transform:uppercase;
  color:rgba(28,58,45,.55);font-weight:600;
  transition:color .2s;display:inline-block;margin-bottom:24px;
}
.legal-back:hover{color:var(--citrus)}
.legal-label{margin-bottom:16px}
.legal-h1{
  font-family:var(--font-display);font-weight:900;
  font-size:clamp(32px,4.6vw,56px);line-height:1.05;
  letter-spacing:-.025em;color:var(--forest);
}
.legal-intro{
  margin-top:20px;font-size:15.5px;line-height:1.6;
  color:rgba(28,58,45,.65);max-width:680px;
}
.legal-date{margin-top:12px;font-size:12px;color:rgba(28,58,45,.4)}
.legal-body{
  margin-top:40px;border-top:1px solid rgba(28,58,45,.10);
  padding-top:32px;
}
.legal-body h2{
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(20px,2.4vw,26px);letter-spacing:-.02em;
  color:var(--forest);margin-top:36px;margin-bottom:12px;
}
.legal-body h2:first-child{margin-top:0}
.legal-body p{
  font-size:clamp(15px,1.2vw,16px);line-height:1.7;
  color:rgba(28,58,45,.85);margin-bottom:12px;
}
.legal-body a{color:var(--citrus);text-decoration:underline;text-underline-offset:3px}
.legal-footer-nav{
  margin-top:56px;border-top:1px solid rgba(28,58,45,.10);
  padding-top:24px;display:grid;grid-template-columns:1fr 1fr;gap:16px;
}
.legal-footer-nav a{
  font-size:13px;color:rgba(28,58,45,.65);transition:color .2s;
}
.legal-footer-nav a:hover{color:var(--citrus)}

/* ── PAGINATION ────────────────────────────────────────────────── */
.pagination{display:flex;justify-content:center;gap:4px;margin-top:40px}
.pagination li a{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;border:1px solid rgba(28,58,45,.12);font-size:13px;font-weight:600;color:var(--ash);transition:all .15s}
.pagination li.active a,.pagination li a:hover{background:var(--forest);color:var(--cream);border-color:var(--forest)}

/* ── ANIMATIONS ────────────────────────────────────────────────── */
@keyframes marquee{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}
@keyframes pulseDot{
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.5;transform:scale(1.4)}
}
@keyframes heartbeat{
  0%,100%{transform:scale(1)}
  14%{transform:scale(1.08)}
  28%{transform:scale(1)}
  42%{transform:scale(1.05)}
  70%{transform:scale(1)}
}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
@keyframes scaleIn{from{opacity:0;transform:scale(.95)}to{opacity:1;transform:none}}

.animate-fadein{animation:fadeUp .5s ease both}
.heartbeat{animation:heartbeat 2.5s ease-in-out infinite}

/* ── WA FLOAT ──────────────────────────────────────────────────── */
.wa-float{position:fixed;bottom:28px;right:28px;width:56px;height:56px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;z-index:400;box-shadow:0 4px 20px rgba(37,211,102,.5);transition:all .25s}
.wa-float:hover{background:#1ea952;transform:scale(1.1)}

/* ── UTILITY ───────────────────────────────────────────────────── */
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}
.text-center{text-align:center}
.text-citrus{color:var(--citrus)}
.text-cream{color:var(--cream)}
.text-forest{color:var(--forest)}
.text-coral{color:var(--coral)}
.text-lime{color:var(--lime)}

/* ── RESPONSIVE ────────────────────────────────────────────────── */
@media(max-width:768px){
  :root{--header-h:60px}
  .md-hidden{display:none!important}
  .form-row{grid-template-columns:1fr}
  .mobile-show{display:flex!important}
}
@media(min-width:768px){
  .mobile-only{display:none!important}
}
@media(max-width:480px){
  .container-x,.container{padding-inline:16px}
  .flash-container{right:10px;left:10px;width:auto}
}


/* ================================================================
   COMPATIBILIDAD — mapea clases antiguas (BEM __) a los estilos
   del sistema de diseño actual. No eliminar.
   SynappCR
   ================================================================ */

/* ── CONTAINER ─────────────────────────────────────────────────── */
.container{max-width:1200px;margin-inline:auto;padding-inline:clamp(16px,5vw,80px)}
.container--narrow,.container-narrow{max-width:760px;margin-inline:auto;padding-inline:clamp(16px,5vw,80px)}

/* ── BOTONES LEGACY (btn--*) ───────────────────────────────────── */
.btn--primary{background:var(--forest);color:var(--cream);border-color:var(--forest)}
.btn--primary:hover{background:var(--forest-2);border-color:var(--forest-2);transform:translateY(-1px);box-shadow:0 6px 20px rgba(28,58,45,.3)}
.btn--secondary{background:transparent;color:var(--forest);border-color:var(--forest)}
.btn--secondary:hover{background:var(--forest);color:var(--cream);transform:translateY(-1px)}
.btn--accent{background:var(--citrus);color:var(--forest);border-color:var(--citrus)}
.btn--accent:hover{background:var(--citrus-2);border-color:var(--citrus-2);transform:translateY(-1px)}
.btn--ghost{background:rgba(251,246,238,.12);color:var(--cream);border-color:rgba(251,246,238,.35)}
.btn--ghost:hover{background:rgba(251,246,238,.22)}
.btn--dark{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.btn--dark:hover{background:#333;transform:translateY(-1px)}
.btn--sm{padding:9px 20px;font-size:13px}
.btn--lg{padding:16px 36px;font-size:16px}
.btn--full{width:100%;justify-content:center}
.btn--loading{opacity:.7;pointer-events:none}
.btn--loading::after{content:'';width:15px;height:15px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite;margin-left:4px}

/* ── SECTION HELPERS ───────────────────────────────────────────── */
.section--gray{background:var(--cream-3)}
.section--cream{background:var(--cream)}
.section--green{background:var(--forest);color:var(--cream)}
.section--dark{background:var(--ink);color:var(--cream)}
.section-header{text-align:center;margin-bottom:clamp(36px,5vw,56px)}
.section-tag{display:inline-block;background:rgba(200,145,58,.12);color:var(--citrus);border:1px solid rgba(200,145,58,.2);font-family:var(--font-display);font-size:11px;font-weight:700;padding:5px 14px;border-radius:999px;margin-bottom:12px;letter-spacing:.06em;text-transform:uppercase}
.section-tag--white{background:rgba(251,246,238,.15);color:var(--cream);border-color:rgba(251,246,238,.25)}
.section-title{font-family:var(--font-display);font-size:clamp(28px,4vw,44px);font-weight:800;letter-spacing:-.025em;color:var(--forest)}
.section-subtitle{font-size:17px;color:var(--ash);margin-top:14px;max-width:560px;margin-left:auto;margin-right:auto;line-height:1.7}
.section-subtitle--white,.section--green .section-subtitle{color:rgba(251,246,238,.75)}
.section--green .section-title{color:var(--cream)}

/* ── CARDS GRID ────────────────────────────────────────────────── */
.cards-grid{display:grid;gap:clamp(16px,2vw,24px)}
.cards-grid--2{grid-template-columns:repeat(2,1fr)}
.cards-grid--3{grid-template-columns:repeat(3,1fr)}
.cards-grid--4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){
  .cards-grid--3{grid-template-columns:repeat(2,1fr)}
  .cards-grid--4{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:600px){
  .cards-grid--2,.cards-grid--3,.cards-grid--4{grid-template-columns:1fr}
}

/* ── PRODUCT CARD ──────────────────────────────────────────────── */
.product-card{background:var(--white);border-radius:16px;overflow:hidden;border:1px solid rgba(28,58,45,.08);box-shadow:0 2px 8px rgba(28,58,45,.06);transition:box-shadow .3s,transform .3s;display:flex;flex-direction:column}
.product-card:hover{box-shadow:0 16px 40px rgba(28,58,45,.13);transform:translateY(-4px)}
.product-card__image{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--cream-3)}
.product-card__image img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.product-card:hover .product-card__image img{transform:scale(1.05)}
.product-card__badge{position:absolute;top:12px;left:12px;background:var(--forest);color:var(--cream);font-family:var(--font-display);font-size:10px;font-weight:700;padding:4px 10px;border-radius:999px;text-transform:uppercase;letter-spacing:.05em}
.product-card__badge--accent{background:var(--citrus)}
.product-card__tags{position:absolute;bottom:12px;left:12px;display:flex;gap:6px;flex-wrap:wrap}
.product-card__tag{background:rgba(251,246,238,.92);backdrop-filter:blur(6px);color:var(--forest);font-size:11px;font-weight:600;padding:3px 9px;border-radius:999px;border:1px solid rgba(28,58,45,.08)}
.product-card__body{padding:18px 18px 10px;flex:1;display:flex;flex-direction:column;gap:6px}
.product-card__title{font-family:var(--font-display);font-size:16px;font-weight:700;line-height:1.3;color:var(--forest)}
.product-card__title a{color:inherit;transition:color .2s}
.product-card__title a:hover{color:var(--citrus)}
.product-card__desc{font-size:13px;color:var(--ash);line-height:1.5;flex:1}
.product-card__footer{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-top:1px solid rgba(28,58,45,.07)}
.product-card__price{display:flex;flex-direction:column}
.product-card__price-current{font-family:var(--font-display);font-size:21px;font-weight:900;color:var(--forest)}
.product-card__price-old{font-size:12px;color:var(--ash);text-decoration:line-through}
.product-card__add{width:42px;height:42px;border-radius:50%;background:var(--forest);color:var(--cream);display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:300;line-height:1;transition:background .2s,transform .2s;flex-shrink:0;cursor:pointer;border:none}
.product-card__add:hover{background:var(--citrus);color:var(--forest);transform:scale(1.1) rotate(90deg)}

/* ─��� PROGRAM CARD ──────────────────────────────────────────────── */
.program-card{background:var(--white);border-radius:20px;overflow:hidden;border:1.5px solid rgba(28,58,45,.08);box-shadow:0 4px 16px rgba(28,58,45,.08);transition:box-shadow .3s,transform .3s}
.program-card.featured{border-color:var(--forest)}
.program-card:hover{box-shadow:0 20px 48px rgba(28,58,45,.14);transform:translateY(-6px)}
.program-card__header{padding:28px;text-align:center;background:var(--cream-3)}
.program-card.featured .program-card__header{background:var(--forest);color:var(--cream)}
.program-card__days{font-family:var(--font-display);font-size:52px;font-weight:900;line-height:1;color:var(--forest)}
.program-card.featured .program-card__days{color:var(--cream)}
.program-card__label{font-size:13px;font-weight:600;color:var(--ash);margin-top:4px}
.program-card.featured .program-card__label{color:rgba(251,246,238,.7)}
.program-card__popular{display:inline-block;background:var(--citrus);color:var(--forest);font-family:var(--font-display);font-size:11px;font-weight:700;padding:4px 12px;border-radius:999px;margin-top:12px;text-transform:uppercase;letter-spacing:.04em}
.program-card__body{padding:24px}
.program-card__price{font-family:var(--font-display);font-size:32px;font-weight:900;color:var(--forest);text-align:center;margin-bottom:20px}
.program-card__features{display:flex;flex-direction:column;gap:10px;margin-bottom:24px}
.program-card__feature{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--ash)}
.program-card__feature svg{color:var(--forest);flex-shrink:0}

/* ── CHECKOUT STEPS ────────────────────────────────────────────── */
.checkout-steps{display:flex;margin-bottom:40px}
.checkout-step{flex:1;text-align:center;position:relative}
.checkout-step::after{content:'';position:absolute;top:20px;left:50%;width:100%;height:2px;background:rgba(28,58,45,.1);z-index:0}
.checkout-step:last-child::after{display:none}
.checkout-step__circle{width:40px;height:40px;border-radius:50%;background:rgba(28,58,45,.08);color:var(--ash);font-family:var(--font-display);font-weight:700;display:flex;align-items:center;justify-content:center;margin:0 auto 8px;position:relative;z-index:1;font-size:14px;transition:background .3s,color .3s}
.checkout-step.active .checkout-step__circle{background:var(--forest);color:var(--cream)}
.checkout-step.done .checkout-step__circle{background:#166534;color:#fff}
.checkout-step__label{font-size:12px;font-weight:600;color:var(--ash)}
.checkout-step.active .checkout-step__label{color:var(--forest)}
@media(max-width:640px){.checkout-steps{display:none}}

/* ── FORM SECTION TITLE ALIAS ──────────────────────────────────── */
.form-section__title{font-family:var(--font-display);font-size:17px;font-weight:700;color:var(--forest);margin-bottom:20px;display:flex;align-items:center;gap:10px}
.form-section__title svg{color:var(--citrus)}
.hint{font-size:12px;color:var(--ash)}

/* ── PAYMENT METHODS (old names) ───────────────────────────────── */
.payment-methods{display:flex;flex-direction:column;gap:10px}
.payment-method{display:flex;align-items:center;gap:12px;padding:14px 18px;border:1.5px solid rgba(28,58,45,.12);border-radius:12px;cursor:pointer;transition:all .2s;background:var(--cream)}
.payment-method.selected,.payment-method:hover{border-color:var(--forest);background:rgba(28,58,45,.04)}
.payment-method input[type=radio]{accent-color:var(--forest);width:16px;height:16px}
.payment-method__label{flex:1}
.payment-method__name{font-weight:600;font-size:14px;color:var(--forest)}
.payment-method__desc{font-size:12px;color:var(--ash)}
.payment-method__icon{font-size:22px}

/* ── SINPE BOX (old name) ──────────────────────────────────────── */
.sinpe-box{background:rgba(28,58,45,.04);border:1px solid rgba(28,58,45,.10);border-radius:12px;padding:20px;margin-top:14px}
.sinpe-box__number{font-family:var(--font-display);font-size:26px;font-weight:900;color:var(--forest);letter-spacing:2px}
.sinpe-box__name{font-size:13px;color:var(--ash);margin-top:4px}

/* ���─ COUPON FORM (old name) ────────────────────────────────────── */
.coupon-form{display:flex;gap:8px;margin:14px 0}
.coupon-form input{flex:1;padding:9px 14px;border:1.5px solid rgba(28,58,45,.15);border-radius:10px;font-size:13px;outline:none;transition:border-color .2s;color:var(--forest);background:var(--cream)}
.coupon-form input:focus{border-color:var(--forest)}

/* ── CART ITEM ALIASES (__ → single -) ────────────────────────── */
.cart-item__image{width:80px;height:80px;border-radius:12px;object-fit:cover;background:var(--cream-3)}
.cart-item__title{font-size:15px;font-weight:700;color:var(--forest);margin-bottom:2px}
.cart-item__price{font-size:13px;color:var(--ash)}
.cart-item__controls{display:flex;align-items:center;gap:8px;margin-top:8px}
.cart-item__remove{color:var(--ash);font-size:20px;padding:4px;transition:color .2s;cursor:pointer;background:none;border:none}
.cart-item__remove:hover{color:var(--coral)}
.cart-item__subtotal{font-size:16px;font-weight:800;text-align:right;min-width:100px;color:var(--forest)}
.qty-decrease,.qty-increase{width:30px;height:30px;border-radius:50%;border:1.5px solid rgba(28,58,45,.15);display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--forest);transition:all .2s;cursor:pointer;background:transparent}
.qty-decrease:hover,.qty-increase:hover{border-color:var(--forest);background:rgba(28,58,45,.06)}

/* ── CART SUMMARY ALIASES ──────────────────────────────────────── */
.cart-summary__title{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--forest);margin-bottom:20px}
.cart-summary__row{display:flex;justify-content:space-between;align-items:center;font-size:14px;padding:10px 0;border-bottom:1px solid rgba(28,58,45,.07)}
.cart-summary__row:last-child{border-bottom:none}
.cart-summary__row--total{font-size:20px;font-weight:800;padding-top:16px}
.cart-summary__row--total .label{color:var(--forest)}
.cart-summary__row--total .value{color:var(--forest)}
.cart-summary__shipping{font-size:13px;color:#166534;font-weight:600}

/* ── EMPTY STATE ALIASES ───────────────────────────────────────── */
.empty-state__icon{font-size:56px;margin-bottom:20px}
.empty-state__title{font-family:var(--font-display);font-size:22px;font-weight:700;color:var(--forest);margin-bottom:10px}
.empty-state__desc{font-size:15px;color:var(--ash);margin-bottom:24px}

/* ── CONFIRM ALIASES ───────────────────────────────────────────── */
.confirm-icon{width:80px;height:80px;border-radius:50%;background:#e8f5ee;color:#166534;display:flex;align-items:center;justify-content:center;margin:0 auto 24px;font-size:36px}
.confirm-details{background:var(--cream-3);border-radius:20px;padding:24px;margin:24px 0}
.confirm-details__row{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px solid rgba(28,58,45,.08);font-size:14px}
.confirm-details__row:last-child{border-bottom:none}
.confirm-details__row .label{color:var(--ash)}
.confirm-details__row .value{font-weight:700;color:var(--forest)}

/* ── ORDER SUMMARY ALIASES ─────────────────────────────────────── */
.order-summary__items{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}
.order-summary__item{display:flex;align-items:center;gap:12px}
.order-summary__item-image{position:relative;width:56px;height:56px;border-radius:8px;overflow:hidden;border:1px solid rgba(28,58,45,.10);flex-shrink:0;background:var(--cream-3)}
.order-summary__item-image img{width:100%;height:100%;object-fit:cover}
.order-summary__item-info{flex:1}
.order-summary__item-name{font-size:13px;font-weight:600;color:var(--forest);line-height:1.3}
.order-summary__item-price{font-size:12px;color:var(--ash)}
.order-summary__item-total{font-size:14px;font-weight:700;color:var(--forest);margin-left:auto}
.qty-badge{position:absolute;top:-8px;right:-8px;background:var(--forest);color:var(--cream);font-size:11px;font-weight:700;min-width:20px;height:20px;border-radius:999px;display:flex;align-items:center;justify-content:center;padding:0 4px}

/* ── BREADCRUMB ALIAS ──────────────────────────────────────────── */
.breadcrumb__sep{color:rgba(28,58,45,.25)}

/* (on-dark header-pedir rules defined in header section above) */

/* ── MARKET SIDEBAR NAV ACTIVE ─────────────────────────────────── */
a[style*="font-weight:700"][style*="color:var(--color-primary)"]{color:var(--forest)!important}

/* ���─ RESPONSIVE CARDS ──────────────────────────────────────────── */
@media(max-width:900px){
  .cards-grid--3{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:600px){
  .cards-grid--3,.cards-grid--2{grid-template-columns:1fr}
  .checkout-layout{grid-template-columns:1fr}
  .cart-layout{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
}
