/* ================================================================
   Continental Best — AAA Stylesheet
   v1.0 · 2026-05-08
   Editorial / cinematic feel · Hand-built, no framework
   ================================================================ */

/* ---------- Design tokens ---------- */
:root {
  /* CHOCOLATE — heritage palette */
  --cb-ink:         #1A1410;        /* near-black, base text on cream */
  --cb-brown-dark:  #3D2817;        /* primary brand brown */
  --cb-brown:       #5A3D24;        /* secondary brown */
  --cb-brown-warm:  #7A4F2E;        /* warm brown accent */
  --cb-gold:        #B8985A;        /* primary gold */
  --cb-gold-light:  #D4B978;        /* highlight gold */
  --cb-gold-glow:   #E6CB94;        /* gold glow for animations */
  --cb-cream:       #F5EBDC;        /* main cream background */
  --cb-cream-warm:  #EFE0CC;        /* warm cream */
  --cb-cream-deep:  #E8D9BE;        /* card/panel cream */
  --cb-paper:       #FAF4EA;        /* lightest cream */
  --cb-white:       #FFFFFF;

  /* DÁTIL — premium launch palette */
  --datil-wine:       #7A1F2E;
  --datil-wine-deep:  #5A1521;
  --datil-wine-glow:  #9B2A3E;
  --datil-pink:       #E89A9E;
  --datil-pink-light: #F5BCC0;
  --datil-cream:      #F0EAE3;
  --datil-rosegold:   #C4969D;

  /* SYSTEM */
  --whatsapp-green:   #25D366;
  --whatsapp-deep:    #128C7E;

  /* Shadows — chocolate-themed */
  --shadow-xs:    0 1px 3px rgba(26, 20, 16, .08);
  --shadow-sm:    0 4px 14px rgba(26, 20, 16, .08), 0 2px 4px rgba(26, 20, 16, .06);
  --shadow-md:    0 12px 32px rgba(26, 20, 16, .14), 0 4px 8px rgba(26, 20, 16, .08);
  --shadow-lg:    0 24px 60px rgba(26, 20, 16, .22), 0 8px 16px rgba(26, 20, 16, .12);
  --shadow-xl:    0 40px 100px rgba(26, 20, 16, .28), 0 16px 32px rgba(26, 20, 16, .14);
  --shadow-gold:  0 20px 60px rgba(184, 152, 90, .35), 0 6px 14px rgba(184, 152, 90, .18);
  --shadow-gold-lg: 0 30px 80px rgba(184, 152, 90, .45), 0 10px 20px rgba(184, 152, 90, .28);
  --shadow-datil: 0 20px 60px rgba(122, 31, 46, .30), 0 6px 14px rgba(122, 31, 46, .18);
  --shadow-inset: inset 0 2px 12px rgba(0, 0, 0, .05);
  --shadow-inner-gold: inset 0 0 0 1px rgba(184, 152, 90, .3);

  /* Radii */
  --r-xs: 4px;
  --r-sm: 8px;
  --r-md: 14px;
  --r-lg: 24px;
  --r-xl: 36px;
  --r-pill: 999px;

  /* Spacing — fluid */
  --sp-1: clamp(4px, 0.5vw, 6px);
  --sp-2: clamp(8px, 1vw, 12px);
  --sp-3: clamp(12px, 1.5vw, 18px);
  --sp-4: clamp(16px, 2vw, 24px);
  --sp-5: clamp(24px, 3vw, 36px);
  --sp-6: clamp(36px, 4.5vw, 56px);
  --sp-7: clamp(56px, 7vw, 96px);
  --sp-8: clamp(80px, 10vw, 140px);
  --sp-9: clamp(120px, 14vw, 200px);

  /* Container */
  --container-max: 1320px;
  --container-pad: clamp(20px, 5vw, 64px);
  --container-tight: 880px;
  --container-prose: 720px;

  /* Type scale — calibrated, less jumpy */
  --fs-xs:   clamp(11px, 0.75vw, 12px);
  --fs-sm:   clamp(13px, 0.9vw, 14px);
  --fs-base: clamp(15px, 1vw, 16px);
  --fs-md:   clamp(17px, 1.15vw, 19px);
  --fs-lg:   clamp(19px, 1.35vw, 22px);
  --fs-xl:   clamp(22px, 1.65vw, 28px);
  --fs-2xl:  clamp(28px, 2.6vw, 38px);
  --fs-3xl:  clamp(34px, 3.6vw, 52px);
  --fs-4xl:  clamp(40px, 4.8vw, 72px);
  --fs-5xl:  clamp(60px, 9vw, 140px);     /* watermarks */
  --fs-hero: clamp(40px, 5.6vw, 84px);

  /* Header height (set by JS or static) */
  --header-h: 88px;

  /* Fonts */
  --f-script:  'Allura', cursive;
  --f-spaced:  'Cinzel', 'Playfair Display', serif;
  --f-display: 'Playfair Display', Georgia, serif;
  --f-sans:    'Inter', -apple-system, sans-serif;
  --f-mono:    'JetBrains Mono', monospace;

  /* Easings */
  --ease-out-expo: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-out-quart: cubic-bezier(0.25, 1, 0.5, 1);
  --ease-in-out-quart: cubic-bezier(0.76, 0, 0.24, 1);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);

  /* Durations */
  --d-fast: 200ms;
  --d-base: 350ms;
  --d-slow: 600ms;
  --d-slower: 900ms;
  --d-cinematic: 1400ms;
}

/* ---------- Anti-FOUC ---------- */
html { background: var(--cb-cream); scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
html.is-loading body { opacity: 0; }
body { transition: opacity 0.4s ease-out; }

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
body {
  font: 400 var(--fs-base)/1.65 var(--f-sans);
  color: var(--cb-ink);
  background: var(--cb-cream);
  overflow-x: clip;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
img, picture, video, svg { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; border: 0; background: none; color: inherit; }
input, textarea, select { font: inherit; }
ul { list-style: none; }
::selection { background: var(--cb-gold); color: var(--cb-brown-dark); }

/* ---------- Scroll progress bar (top) ---------- */
.scroll-progress {
  position: fixed;
  top: 0; left: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--cb-gold), var(--cb-gold-light));
  z-index: 9999;
  width: 0;
  transition: width 80ms linear;
  box-shadow: 0 0 10px rgba(184, 152, 90, .5);
}

/* ================================================================
   TYPOGRAPHY — editorial system
   ================================================================ */
.h-script {
  font: 400 var(--fs-3xl)/0.9 var(--f-script);
  color: var(--cb-brown-dark);
  font-weight: 400;
}
.h-display {
  font: 700 var(--fs-3xl)/1.05 var(--f-display);
  letter-spacing: -0.02em;
  color: var(--cb-brown-dark);
  text-wrap: balance;
}
.h-display-italic {
  font: italic 400 var(--fs-3xl)/1.05 var(--f-display);
  letter-spacing: -0.02em;
  color: var(--cb-brown-dark);
}
.h-hero {
  font: 700 var(--fs-hero)/0.98 var(--f-display);
  letter-spacing: -0.035em;
  color: var(--cb-cream);
  text-wrap: balance;
}
.h2 {
  font: 700 var(--fs-2xl)/1.1 var(--f-display);
  color: var(--cb-brown-dark);
  margin-bottom: var(--sp-3);
  letter-spacing: -0.015em;
  text-wrap: balance;
}
.h3 {
  font: 600 var(--fs-xl)/1.25 var(--f-display);
  color: var(--cb-brown-dark);
  margin-bottom: var(--sp-2);
  letter-spacing: -0.01em;
}
.lead {
  font-size: var(--fs-lg);
  line-height: 1.5;
  color: var(--cb-brown);
  max-width: 60ch;
  font-weight: 400;
}
.eyebrow {
  font: 600 11px/1.4 var(--f-spaced);
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--cb-gold);
  display: inline-block;
  margin: 0;
}
.eyebrow--marked {
  display: inline-flex;
  align-items: center;
  gap: 14px;
}
.eyebrow--marked::before, .eyebrow--marked::after {
  content: '';
  width: 24px;
  height: 1.5px;
  background: currentColor;
  display: inline-block;
  opacity: 0.55;
}
.brand-script  { font: 400 1.15em var(--f-script); color: var(--cb-gold); }
.brand-spaced  { font: 400 0.7em/1 var(--f-spaced); letter-spacing: 0.42em; text-transform: uppercase; }

/* Italic emphasis inside headlines */
.h-display em, .h-hero em, .h2 em {
  font: italic 400 1em var(--f-display);
  color: var(--cb-gold);
  font-style: italic;
}

/* ================================================================
   LAYOUT
   ================================================================ */
.container {
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--container-pad);
  width: 100%;
}
.container-tight  { max-width: var(--container-tight); margin-inline: auto; padding-inline: var(--container-pad); }
.container-prose  { max-width: var(--container-prose); margin-inline: auto; padding-inline: var(--container-pad); }

.section {
  padding-block: var(--sp-8);
  position: relative;
}
/* First section on internal pages needs clearance from fixed header */
main > .section--page-hero,
main > .section:first-child {
  padding-top: calc(var(--header-h) + var(--sp-7));
}
.has-hero main > .section:first-child {
  padding-top: var(--sp-8);  /* hero already handles clearance */
}
.section--cream { background: var(--cb-cream); }
.section--paper { background: var(--cb-paper); }
.section--brown { background: var(--cb-brown-dark); color: var(--cb-cream); }
.section--ink   { background: var(--cb-ink); color: var(--cb-cream); }
.section--datil { background: var(--datil-cream); color: var(--cb-ink); }

.section--brown .h2,
.section--ink .h2 { color: var(--cb-cream); }
.section--brown .lead,
.section--ink .lead { color: var(--cb-cream-deep); }
.section--datil .h2 { color: var(--datil-wine); }
.section--datil .eyebrow { color: var(--datil-wine); }

.grid { display: grid; gap: var(--sp-5); }
.grid--2 { grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); }
.grid--3 { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }
.grid--4 { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }

/* ================================================================
   DECORATIVE ELEMENTS
   ================================================================ */

/* Watermark — gigantic background number/word */
.watermark {
  position: absolute;
  font: 800 var(--fs-5xl)/0.85 var(--f-display);
  letter-spacing: -0.05em;
  color: var(--cb-brown-dark);
  opacity: 0.04;
  pointer-events: none;
  user-select: none;
  z-index: 0;
  white-space: nowrap;
}
.watermark--script {
  font: 400 var(--fs-5xl)/0.8 var(--f-script);
  opacity: 0.06;
  letter-spacing: 0;
}
.watermark--top-right { top: -0.2em; right: -0.1em; }
.watermark--top-left  { top: -0.2em; left: -0.1em; }
.watermark--bottom-right { bottom: -0.2em; right: -0.1em; }
.watermark--center { top: 50%; left: 50%; transform: translate(-50%, -50%); opacity: 0.025; }

/* Decorative gold rule */
.rule-gold {
  display: inline-block;
  width: 60px;
  height: 1.5px;
  background: linear-gradient(90deg, transparent, var(--cb-gold), transparent);
  margin-block: var(--sp-3);
}

/* Section dividers (SVG curves between sections) */
.divider {
  display: block;
  width: 100%;
  height: 80px;
  margin: 0;
  pointer-events: none;
}
.divider svg { display: block; width: 100%; height: 100%; }

/* Cacao decorative pattern (SVG bg) */
.decor-cacao {
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='480' viewBox='0 0 240 480'><g fill='none' stroke='%23B8985A' stroke-width='1.2'><path d='M50 20 Q30 70 45 130 Q60 190 35 250 Q15 310 45 360 Q65 410 40 470'/><ellipse cx='40' cy='90' rx='12' ry='22' transform='rotate(-12 40 90)' stroke-width='1.5'/><ellipse cx='30' cy='180' rx='14' ry='24' transform='rotate(18 30 180)' stroke-width='1.5'/><ellipse cx='45' cy='280' rx='12' ry='22' transform='rotate(-8 45 280)' stroke-width='1.5'/><ellipse cx='35' cy='380' rx='13' ry='23' transform='rotate(15 35 380)' stroke-width='1.5'/></g></svg>");
  background-size: 240px 480px;
  background-repeat: repeat-y;
  background-position: left top;
  opacity: 0.18;
  pointer-events: none;
}

/* Palm frond decorative (línea Dátil) */
.decor-palm {
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='400' height='400' viewBox='0 0 400 400'><g fill='none' stroke='%23E89A9E' stroke-width='1.5' opacity='0.6'><path d='M200 50 Q150 100 130 180 Q110 260 140 340'/><path d='M200 50 Q220 90 260 130 Q300 170 280 230'/><path d='M200 50 Q170 80 140 110 Q110 140 130 180'/><path d='M200 50 Q230 80 260 110 Q290 140 270 180'/><path d='M200 50 L 180 110 M200 50 L 220 110 M200 50 L 160 130 M200 50 L 240 130'/></g></svg>");
  background-size: 400px;
  background-repeat: no-repeat;
  background-position: center top;
  opacity: 0.4;
  pointer-events: none;
}

/* Sello "Pasión por el chocolate · Desde 1964" — circular badge */
.seal-1964 {
  width: 140px; height: 140px;
  border-radius: 50%;
  background: var(--cb-brown-dark);
  color: var(--cb-gold);
  display: grid;
  place-items: center;
  position: relative;
  font: 700 11px/1 var(--f-spaced);
  letter-spacing: .2em;
  text-transform: uppercase;
  box-shadow: var(--shadow-md), 0 0 0 6px var(--cb-cream-deep), 0 0 0 7px var(--cb-gold);
  flex-shrink: 0;
}
.seal-1964 .seal-num { font: 800 28px/1 var(--f-display); letter-spacing: 0.05em; color: var(--cb-gold-light); }
.seal-1964 .seal-text-top, .seal-1964 .seal-text-bottom { position: absolute; left: 0; right: 0; text-align: center; font-size: 9px; }
.seal-1964 .seal-text-top { top: 12px; }
.seal-1964 .seal-text-bottom { bottom: 12px; }

/* ================================================================
   BUTTONS — magnetic + cinematic
   ================================================================ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 16px 32px;
  border-radius: var(--r-pill);
  font: 600 14px/1 var(--f-sans);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  text-decoration: none;
  position: relative;
  overflow: hidden;
  isolation: isolate;
  transition: transform var(--d-base) var(--ease-out-expo),
              box-shadow var(--d-base) var(--ease-out-expo),
              color var(--d-base) var(--ease-out-expo);
  cursor: pointer;
  white-space: nowrap;
  will-change: transform;
}
.btn::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--btn-bg, var(--cb-gold));
  transition: transform var(--d-slow) var(--ease-out-expo);
  z-index: -2;
}
.btn::after {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--btn-bg-hover, var(--cb-brown-dark));
  transform: translateY(101%);
  transition: transform var(--d-slow) var(--ease-out-expo);
  z-index: -1;
}
.btn:hover::after { transform: translateY(0); }
.btn:hover { transform: translateY(-2px); }
.btn:active { transform: translateY(0); }

.btn--primary {
  --btn-bg: linear-gradient(135deg, var(--cb-gold) 0%, var(--cb-gold-light) 100%);
  --btn-bg-hover: var(--cb-brown-dark);
  color: var(--cb-brown-dark);
  box-shadow: var(--shadow-gold);
}
.btn--primary:hover { color: var(--cb-gold-light); box-shadow: var(--shadow-gold-lg); }

.btn--whatsapp {
  --btn-bg: var(--whatsapp-green);
  --btn-bg-hover: var(--whatsapp-deep);
  color: #fff;
  box-shadow: 0 12px 28px rgba(37, 211, 102, .40), 0 4px 8px rgba(37, 211, 102, .25);
}
.btn--whatsapp:hover { color: #fff; }
.btn--whatsapp svg { width: 18px; height: 18px; flex-shrink: 0; }

.btn--datil {
  --btn-bg: linear-gradient(135deg, var(--datil-wine) 0%, var(--datil-wine-deep) 100%);
  --btn-bg-hover: var(--datil-pink);
  color: #fff;
  box-shadow: var(--shadow-datil);
}
.btn--datil:hover { color: var(--datil-wine-deep); }

.btn--outline {
  background: transparent;
  border: 1.5px solid var(--cb-brown-dark);
  color: var(--cb-brown-dark);
  --btn-bg: transparent;
  --btn-bg-hover: var(--cb-brown-dark);
}
.btn--outline::before { background: transparent; }
.btn--outline:hover { color: var(--cb-cream); border-color: var(--cb-brown-dark); }

.btn--ghost {
  background: transparent;
  color: var(--cb-cream);
  --btn-bg: transparent;
  --btn-bg-hover: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.3);
}
.btn--ghost::before { background: transparent; }

.btn--lg { padding: 20px 40px; font-size: 15px; }
.btn--sm { padding: 12px 24px; font-size: 12px; }

/* Magnetic hover effect (JS adds transform via mousemove) */
.btn[data-magnetic] { transition: transform 80ms ease-out, box-shadow var(--d-base) var(--ease-out-expo); }

/* ================================================================
   HEADER — sticky, glass-blur, dynamic on scroll
   ================================================================ */
.site-header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 100;
  background: rgba(250, 244, 234, 0.92);
  backdrop-filter: blur(16px) saturate(140%);
  -webkit-backdrop-filter: blur(16px) saturate(140%);
  box-shadow: 0 1px 0 rgba(184, 152, 90, .15), 0 6px 20px rgba(26, 20, 16, .05);
  transition: box-shadow var(--d-base) var(--ease-out-expo),
              transform var(--d-base) var(--ease-out-expo);
}
.site-header.is-scrolled {
  background: rgba(250, 244, 234, 0.96);
  box-shadow: 0 1px 0 rgba(184, 152, 90, .18), 0 12px 30px rgba(26, 20, 16, .10);
}
.site-header.is-hidden { transform: translateY(-100%); }
body { padding-top: 0; }

.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-block: var(--sp-3);
  gap: var(--sp-5);
}
.site-header__logo { display: flex; align-items: center; flex-shrink: 0; }
.site-header__logo-img {
  height: 50px;
  width: auto;
  object-fit: contain;
  display: block;
  transition: filter var(--d-base) var(--ease-out-expo);
}

.site-nav {
  display: flex;
  align-items: center;
  gap: var(--sp-5);
  flex: 1;
  justify-content: center;
}
.site-nav a {
  font: 500 13px/1 var(--f-sans);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--cb-brown-dark);
  position: relative;
  padding: 10px 0;
  transition: color var(--d-base) var(--ease-out-expo);
}
.site-nav a::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0;
  height: 1.5px;
  background: var(--cb-gold);
  transition: width var(--d-base) var(--ease-out-expo);
}
.site-nav a:hover { color: var(--cb-gold); }
.site-nav a:hover::after { width: 100%; }

.site-header__cta {
  display: flex;
  gap: var(--sp-2);
  align-items: center;
}
.site-header__phone {
  font: 600 13px/1 var(--f-sans);
  color: var(--cb-brown-dark);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  letter-spacing: .04em;
  padding: 12px 22px;
  border: 1.5px solid var(--cb-brown-dark);
  border-radius: var(--r-pill);
  transition: background var(--d-base) var(--ease-out-expo),
              color var(--d-base) var(--ease-out-expo);
}
.site-header__phone:hover {
  background: var(--cb-brown-dark);
  color: var(--cb-cream);
}
.site-header__phone svg { flex-shrink: 0; }
.site-header.is-scrolled .site-header__phone {
  border-color: var(--cb-brown-dark);
}

.burger {
  display: none;
  width: 44px;
  height: 44px;
  align-items: center;
  justify-content: center;
  position: relative;
}
.burger span,
.burger span::before,
.burger span::after {
  display: block;
  width: 26px;
  height: 1.8px;
  background: var(--cb-brown-dark);
  transition: all var(--d-base) var(--ease-out-expo);
}
.burger span { position: relative; }
.burger span::before, .burger span::after {
  content: ''; position: absolute; left: 0;
}
.burger span::before { top: -8px; }
.burger span::after  { top:  8px; }

@media (max-width: 1024px) {
  .site-nav, .site-header__phone { display: none; }
  .burger { display: inline-flex; }
}

/* Mobile drawer */
.mobile-drawer {
  position: fixed;
  top: 0; right: 0; bottom: 0;
  width: min(360px, 90vw);
  background: var(--cb-paper);
  z-index: 200;
  transform: translateX(100%);
  transition: transform var(--d-slow) var(--ease-out-expo);
  padding: var(--sp-6) var(--sp-5);
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
  box-shadow: var(--shadow-xl);
}
.mobile-drawer.is-open { transform: translateX(0); }
.mobile-drawer a {
  font: 600 16px/1 var(--f-sans);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--cb-brown-dark);
  padding: 14px 0;
  border-bottom: 1px solid rgba(184, 152, 90, .15);
}
.mobile-drawer__cta {
  margin-top: auto;
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}
.mobile-drawer__cta .btn { width: 100%; }

.mobile-drawer-overlay {
  position: fixed;
  inset: 0;
  background: rgba(26, 20, 16, .5);
  backdrop-filter: blur(4px);
  z-index: 150;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--d-slow) var(--ease-out-expo);
}
.mobile-drawer-overlay.is-open { opacity: 1; pointer-events: auto; }

/* ================================================================
   HERO — cinematic full-screen slider
   ================================================================ */
.hero {
  position: relative;
  min-height: 100vh;
  min-height: 100svh;
  background: var(--cb-ink);
  overflow: hidden;
  isolation: isolate;
}
.hero-swiper, .swiper {
  width: 100%;
  height: 100vh;
  height: 100svh;
}
.hero-slide {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  background: var(--cb-ink);
  overflow: hidden;
}
.hero-slide__bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  z-index: 0;
  transform: scale(1.08);
  transition: transform 7s ease-out;
}
.hero-swiper .swiper-slide-active .hero-slide__bg { transform: scale(1.0); }
.hero-slide__overlay {
  position: absolute; inset: 0; z-index: 1;
  background:
    linear-gradient(180deg, rgba(26,20,16,.55) 0%, rgba(26,20,16,.30) 30%, rgba(26,20,16,.10) 60%, rgba(26,20,16,.55) 100%),
    linear-gradient(100deg, rgba(26, 20, 16, .85) 0%, rgba(26, 20, 16, .55) 40%, rgba(26, 20, 16, .15) 75%, transparent 100%);
}
.hero-slide--datil .hero-slide__overlay {
  background:
    linear-gradient(180deg, rgba(90,21,33,.55) 0%, rgba(90,21,33,.30) 30%, rgba(90,21,33,.10) 60%, rgba(90,21,33,.55) 100%),
    linear-gradient(100deg, rgba(90, 21, 33, .92) 0%, rgba(122, 31, 46, .60) 40%, rgba(122, 31, 46, .15) 75%, transparent 100%);
}
.hero-slide__content {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--container-pad);
  color: var(--cb-cream);
  padding-top: calc(var(--header-h) + var(--sp-5));
  padding-bottom: var(--sp-7);
}
.hero-slide__inner { max-width: 880px; }
.hero-slide__eyebrow {
  font: 600 11px/1 var(--f-spaced);
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--cb-gold-light);
  margin-bottom: var(--sp-4);
  display: inline-flex;
  align-items: center;
  gap: 14px;
  opacity: 0;
  transform: translateY(20px);
  padding: 8px 16px 8px 0;
}
.hero-slide__eyebrow::before {
  content: '';
  width: 40px;
  height: 1.5px;
  background: var(--cb-gold-light);
  display: inline-block;
  flex-shrink: 0;
}
.hero-slide__title {
  font: 700 var(--fs-hero)/1.02 var(--f-display);
  letter-spacing: -0.03em;
  margin-bottom: var(--sp-4);
  text-wrap: balance;
  opacity: 0;
  transform: translateY(30px);
  text-shadow: 0 4px 20px rgba(0, 0, 0, .35);
}
.hero-slide__title em {
  font: italic 400 1em var(--f-display);
  color: var(--cb-gold-light);
}
.hero-slide__sub {
  font: 400 var(--fs-md)/1.55 var(--f-sans);
  max-width: 56ch;
  margin-bottom: var(--sp-5);
  opacity: 0;
  transform: translateY(20px);
  color: var(--cb-cream-deep);
  text-shadow: 0 2px 12px rgba(0, 0, 0, .35);
}
.hero-slide__ctas {
  display: flex;
  gap: var(--sp-3);
  flex-wrap: wrap;
  opacity: 0;
  transform: translateY(20px);
}

/* Animation keyframes — orchestrated reveal */
.swiper-slide-active .hero-slide__eyebrow { animation: cb-fade-up 800ms var(--ease-out-expo) 150ms forwards; }
.swiper-slide-active .hero-slide__title   { animation: cb-fade-up 1000ms var(--ease-out-expo) 350ms forwards; }
.swiper-slide-active .hero-slide__sub     { animation: cb-fade-up 800ms var(--ease-out-expo) 700ms forwards; }
.swiper-slide-active .hero-slide__ctas    { animation: cb-fade-up 800ms var(--ease-out-expo) 950ms forwards; }

@keyframes cb-fade-up {
  from { opacity: 0; transform: translateY(28px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Hero progress + counter */
.hero-pagination {
  position: absolute !important;
  bottom: 36px !important;
  left: 50%;
  transform: translateX(-50%);
  width: min(420px, 60vw) !important;
  height: 2px !important;
  background: rgba(255,255,255,.15) !important;
  z-index: 5;
  border-radius: 2px;
  overflow: hidden;
}
.hero-pagination .swiper-pagination-progressbar-fill {
  background: linear-gradient(90deg, var(--cb-gold), var(--cb-gold-light)) !important;
}
.hero-counter {
  position: absolute;
  bottom: 30px;
  right: var(--container-pad);
  z-index: 5;
  color: rgba(255,255,255,.85);
  font: 600 11px/1 var(--f-spaced);
  letter-spacing: .35em;
}
.hero-scroll-hint {
  position: absolute;
  bottom: 30px;
  left: var(--container-pad);
  z-index: 5;
  color: rgba(255,255,255,.6);
  font: 500 11px/1 var(--f-spaced);
  letter-spacing: .35em;
  display: flex;
  align-items: center;
  gap: 12px;
  text-transform: uppercase;
}
.hero-scroll-hint::after {
  content: '';
  width: 1px;
  height: 30px;
  background: linear-gradient(to bottom, transparent, currentColor);
  animation: scroll-bounce 2s ease-in-out infinite;
}
@keyframes scroll-bounce {
  0%, 100% { transform: scaleY(1); transform-origin: top; }
  50%      { transform: scaleY(0.4); transform-origin: top; }
}

/* ================================================================
   PAGE HERO — cinematic sub-page hero
   ================================================================ */
.page-hero {
  position: relative;
  min-height: clamp(420px, 60vh, 620px);
  display: flex;
  align-items: flex-end;
  background: var(--cb-ink);
  overflow: hidden;
  isolation: isolate;
  padding-top: calc(var(--header-h) + var(--sp-6));
  padding-bottom: var(--sp-7);
  color: var(--cb-cream);
  margin-top: 0;
}
.page-hero__bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  z-index: 0;
  transform: scale(1.08);
  animation: page-hero-zoom 14s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}
@keyframes page-hero-zoom {
  to { transform: scale(1.0); }
}
.page-hero__overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(180deg, rgba(26,20,16,.55) 0%, rgba(26,20,16,.20) 35%, rgba(26,20,16,.85) 100%),
    linear-gradient(100deg, rgba(26,20,16,.75) 0%, rgba(26,20,16,.30) 50%, transparent 100%);
}
.page-hero__overlay--datil {
  background:
    linear-gradient(180deg, rgba(90,21,33,.55) 0%, rgba(90,21,33,.20) 35%, rgba(90,21,33,.85) 100%),
    linear-gradient(100deg, rgba(90,21,33,.85) 0%, rgba(122,31,46,.35) 50%, transparent 100%);
}
.page-hero__watermark {
  position: absolute;
  bottom: -6%;
  right: -3%;
  font: 700 22vw/0.85 var(--f-display);
  color: var(--cb-cream);
  opacity: 0.05;
  pointer-events: none;
  user-select: none;
  z-index: 1;
  letter-spacing: -0.05em;
  white-space: nowrap;
}
.page-hero__content {
  position: relative;
  z-index: 2;
  max-width: 820px;
  width: 100%;
}
.page-hero__breadcrumb {
  font: 600 11px/1 var(--f-spaced);
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--cb-gold-light);
  margin-bottom: var(--sp-3);
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.page-hero__breadcrumb a {
  color: rgba(245, 235, 220, .55);
  transition: color var(--d-base) var(--ease-out-expo);
}
.page-hero__breadcrumb a:hover { color: var(--cb-gold-light); }
.page-hero__breadcrumb-sep {
  opacity: 0.4;
  color: var(--cb-cream);
}
.page-hero__current { color: var(--cb-gold-light); }
.page-hero__title {
  font: 700 clamp(36px, 5.4vw, 72px)/1.0 var(--f-display);
  letter-spacing: -0.035em;
  text-wrap: balance;
  color: var(--cb-cream);
  margin-bottom: var(--sp-3);
  text-shadow: 0 4px 24px rgba(0,0,0,.4);
}
.page-hero__title em {
  font-style: italic;
  color: var(--cb-gold-light);
  font-weight: 400;
}
.page-hero__sub {
  font: 400 var(--fs-md)/1.55 var(--f-sans);
  color: var(--cb-cream-deep);
  max-width: 62ch;
  text-shadow: 0 2px 12px rgba(0,0,0,.35);
}
.page-hero__meta {
  display: flex;
  gap: var(--sp-4);
  flex-wrap: wrap;
  margin-top: var(--sp-4);
  padding-top: var(--sp-3);
  border-top: 1px solid rgba(184, 152, 90, .25);
}
.page-hero__meta-item {
  font: 600 11px/1.3 var(--f-spaced);
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--cb-cream-deep);
  display: flex;
  align-items: center;
  gap: 8px;
}
.page-hero__meta-item::before {
  content: '★';
  color: var(--cb-gold);
  font-size: 14px;
}

/* When page has a page-hero, kill the page-hero clearance from main > .section--page-hero */
.page-hero ~ main > .section:first-child,
main > .page-hero + .section { padding-top: var(--sp-8); }

/* ================================================================
   ESTABLISHMENT STRIPE — under hero
   ================================================================ */
.estab-stripe {
  background: var(--cb-brown-dark);
  color: var(--cb-cream);
  padding-block: var(--sp-4);
  position: relative;
  overflow: hidden;
}
.estab-stripe__inner {
  display: flex;
  align-items: center;
  justify-content: space-around;
  flex-wrap: wrap;
  gap: var(--sp-5);
}
.estab-stripe__item {
  display: flex;
  align-items: center;
  gap: 12px;
  font: 600 12px/1 var(--f-spaced);
  letter-spacing: .35em;
  text-transform: uppercase;
  color: var(--cb-gold-light);
}
.estab-stripe__icon {
  font-size: 18px;
  color: var(--cb-gold);
}

/* ================================================================
   PILLARS — premium 3-column
   ================================================================ */
.pillars {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--sp-5);
}
.pillar {
  background: var(--cb-white);
  padding: var(--sp-6) var(--sp-5);
  border-radius: var(--r-lg);
  position: relative;
  transition: transform var(--d-slow) var(--ease-out-expo),
              box-shadow var(--d-slow) var(--ease-out-expo);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}
.pillar::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, transparent, var(--cb-gold), transparent);
  transform: scaleX(0);
  transform-origin: center;
  transition: transform var(--d-slow) var(--ease-out-expo);
}
.pillar:hover {
  transform: translateY(-8px);
  box-shadow: var(--shadow-lg);
}
.pillar:hover::before { transform: scaleX(1); }
.pillar__icon {
  width: 64px; height: 64px;
  background: linear-gradient(135deg, var(--cb-cream-deep), var(--cb-cream));
  border-radius: var(--r-md);
  display: grid; place-items: center;
  margin-bottom: var(--sp-3);
  font-size: 30px;
  box-shadow: inset 0 0 0 1px rgba(184, 152, 90, .25);
}
.pillar__num {
  position: absolute;
  top: var(--sp-4);
  right: var(--sp-4);
  font: 800 80px/1 var(--f-display);
  color: var(--cb-cream);
  opacity: 0.7;
  letter-spacing: -0.05em;
  pointer-events: none;
}
.pillar__title {
  font: 600 var(--fs-lg)/1.2 var(--f-display);
  color: var(--cb-brown-dark);
  margin-bottom: var(--sp-2);
  letter-spacing: -0.01em;
}
.pillar__desc { color: var(--cb-brown); font-size: var(--fs-base); line-height: 1.55; }

/* ================================================================
   STEPS — programa en 4 pasos, magazine timeline
   ================================================================ */
.steps {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--sp-5);
  position: relative;
}
.steps::before {
  content: '';
  position: absolute;
  top: 30px;
  left: 5%;
  right: 5%;
  height: 1px;
  background: repeating-linear-gradient(90deg, var(--cb-gold) 0 12px, transparent 12px 24px);
  z-index: 0;
}
.step {
  position: relative;
  text-align: center;
  z-index: 1;
}
.step__num {
  width: 60px; height: 60px;
  background: var(--cb-cream);
  color: var(--cb-brown-dark);
  border-radius: 50%;
  display: grid; place-items: center;
  font: 800 22px/1 var(--f-display);
  margin: 0 auto var(--sp-3);
  box-shadow: 0 0 0 6px var(--cb-cream), 0 0 0 7px var(--cb-gold);
  transition: transform var(--d-slow) var(--ease-out-expo);
}
.step:hover .step__num {
  transform: rotate(-8deg) scale(1.1);
  background: var(--cb-gold);
  color: var(--cb-cream);
}
.step__title {
  font: 600 var(--fs-md)/1.25 var(--f-display);
  color: var(--cb-brown-dark);
  margin-bottom: var(--sp-2);
}
.step__desc { color: var(--cb-brown); font-size: var(--fs-sm); line-height: 1.5; }

/* ================================================================
   CATALOG CARD — magazine product showcase
   ================================================================ */
.catalog-card {
  background: var(--cb-white);
  border-radius: var(--r-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition: transform var(--d-slow) var(--ease-out-expo),
              box-shadow var(--d-slow) var(--ease-out-expo);
  display: flex;
  flex-direction: column;
  position: relative;
  isolation: isolate;
}
.catalog-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 60%, rgba(184, 152, 90, .04));
  pointer-events: none;
  z-index: 1;
}
.catalog-card:hover {
  transform: translateY(-12px);
  box-shadow: var(--shadow-xl);
}
.catalog-card__media {
  aspect-ratio: 4/2.4;
  background: linear-gradient(135deg, var(--cb-paper) 0%, var(--cb-cream-deep) 100%);
  display: grid; place-items: center;
  overflow: hidden;
  position: relative;
  padding: var(--sp-4);
}
.catalog-card__media::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at center, transparent 30%, rgba(61, 40, 23, .08) 100%);
  pointer-events: none;
}
.catalog-card__media img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  transition: transform var(--d-cinematic) var(--ease-out-expo);
  filter: drop-shadow(0 12px 24px rgba(61, 40, 23, .25));
  position: relative;
  z-index: 1;
}
.catalog-card:hover .catalog-card__media img {
  transform: scale(1.08) rotate(-2deg);
}
.catalog-card__badge {
  position: absolute;
  top: 14px; right: 14px;
  background: var(--cb-brown-dark);
  color: var(--cb-gold-light);
  padding: 6px 14px;
  border-radius: var(--r-pill);
  font: 700 10px/1 var(--f-spaced);
  letter-spacing: .2em;
  text-transform: uppercase;
  z-index: 2;
  box-shadow: var(--shadow-sm);
}
.catalog-card__body {
  padding: var(--sp-5) var(--sp-5);
  flex: 1;
  display: flex;
  flex-direction: column;
  position: relative;
  z-index: 2;
}
.catalog-card__title {
  font: 600 var(--fs-lg)/1.2 var(--f-display);
  color: var(--cb-brown-dark);
  margin-bottom: 8px;
  letter-spacing: -0.01em;
}
.catalog-card__desc {
  color: var(--cb-brown);
  font-size: var(--fs-sm);
  line-height: 1.55;
  flex: 1;
  margin-bottom: var(--sp-3);
}
.catalog-card__ctas {
  display: flex;
  gap: var(--sp-2);
  flex-wrap: wrap;
}
.catalog-card__ctas .btn { padding: 12px 18px; font-size: 11px; flex: 1; min-width: 110px; }

.catalog-card--datil .catalog-card__title { color: var(--datil-wine); }
.catalog-card--datil { border-top: 3px solid var(--datil-wine); }
.catalog-card--datil-hero .catalog-card__media {
  aspect-ratio: 16/10;
  padding: 0;
  background: linear-gradient(135deg, #f5e8e9 0%, #e89a9e 100%);
}
.catalog-card--datil-hero .catalog-card__media img {
  max-width: 100%; max-height: 100%; object-fit: cover;
  filter: none;
}
.catalog-card--datil-hero:hover .catalog-card__media img {
  transform: scale(1.05) rotate(0deg);
}

/* ================================================================
   DÁTIL BANNER — dramatic dark section
   ================================================================ */
.datil-banner {
  background: linear-gradient(135deg, var(--datil-wine) 0%, var(--datil-wine-deep) 70%, var(--cb-ink) 100%);
  color: #fff;
  border-radius: var(--r-xl);
  padding: clamp(40px, 8vw, 96px);
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: var(--sp-6);
  align-items: center;
  position: relative;
  overflow: hidden;
  isolation: isolate;
  box-shadow: var(--shadow-xl);
}
.datil-banner::before {
  content: '';
  position: absolute;
  top: -50%; right: -20%;
  width: 80%;
  height: 200%;
  background: radial-gradient(ellipse, rgba(232, 154, 158, .15) 0%, transparent 70%);
  pointer-events: none;
}
.datil-banner__content { position: relative; z-index: 2; }
.datil-banner__title {
  font: 700 var(--fs-3xl)/1 var(--f-display);
  margin-block: var(--sp-3);
  letter-spacing: -0.025em;
}
.datil-banner__sub {
  font: 600 var(--fs-md)/1.4 var(--f-sans);
  opacity: .9;
}
.datil-moments {
  display: flex;
  gap: var(--sp-2);
  flex-wrap: wrap;
  margin-block: var(--sp-4);
}
.datil-moments span {
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(232, 154, 158, .35);
  padding: 10px 18px;
  border-radius: var(--r-pill);
  font: 600 12px/1 var(--f-sans);
  letter-spacing: .04em;
  backdrop-filter: blur(10px);
}
.datil-benefits {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  margin-top: var(--sp-3);
}
.datil-benefit {
  display: flex; align-items: center; gap: 10px;
  font: 500 var(--fs-sm)/1.3 var(--f-sans);
}
.datil-benefit::before {
  content: '';
  width: 22px; height: 22px;
  background: var(--datil-pink);
  border-radius: 50%;
  flex-shrink: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235A1521' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");
  background-size: 14px;
  background-repeat: no-repeat;
  background-position: center;
}
.datil-banner__visual {
  position: relative;
  text-align: center;
}
.datil-banner__visual img {
  max-width: 100%;
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-xl), 0 0 0 1px rgba(232, 154, 158, .3);
  transform: rotate(-2deg);
  transition: transform var(--d-slow) var(--ease-out-expo);
}
.datil-banner__visual:hover img { transform: rotate(0deg) scale(1.02); }
.datil-banner__seal {
  position: absolute;
  top: -20px; right: -20px;
  width: 100px; height: 100px;
  border-radius: 50%;
  background: var(--datil-pink);
  color: var(--datil-wine-deep);
  display: grid; place-items: center;
  font: 800 11px/1.2 var(--f-display);
  text-align: center;
  text-transform: uppercase;
  letter-spacing: .15em;
  box-shadow: var(--shadow-md);
  transform: rotate(8deg);
  z-index: 2;
}

@media (max-width: 720px) {
  .datil-banner { grid-template-columns: 1fr; }
}

/* ================================================================
   CAUSES — magazine grid
   ================================================================ */
.causes {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: var(--sp-3);
}
.cause {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  aspect-ratio: 4/5;
  border-radius: var(--r-md);
  overflow: hidden;
  cursor: pointer;
  isolation: isolate;
  background: var(--cb-brown-dark);
  box-shadow: var(--shadow-sm);
  transition: transform var(--d-slow) var(--ease-out-expo),
              box-shadow var(--d-slow) var(--ease-out-expo);
  padding: var(--sp-3);
  text-align: left;
  color: var(--cb-cream);
}
.cause::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--cause-bg, linear-gradient(135deg, var(--cb-brown-dark), var(--cb-brown)));
  background-size: cover;
  background-position: center;
  transition: transform var(--d-cinematic) var(--ease-out-expo);
  z-index: -2;
}
.cause::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg,
    rgba(26, 20, 16, 0.20) 0%,
    rgba(26, 20, 16, 0.40) 50%,
    rgba(26, 20, 16, 0.95) 100%);
  z-index: -1;
  transition: opacity var(--d-base);
}
.cause:hover {
  transform: translateY(-8px);
  box-shadow: var(--shadow-lg);
}
.cause:hover::before { transform: scale(1.1); }
.cause:hover .cause__name { color: var(--cb-gold-light); }
.cause__icon {
  font-size: 32px;
  margin-bottom: var(--sp-2);
  display: block;
  width: 50px; height: 50px;
  background: rgba(245, 235, 220, .12);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(184, 152, 90, .35);
  border-radius: 50%;
  display: grid; place-items: center;
  font-size: 24px;
  transition: transform var(--d-slow) var(--ease-spring), background var(--d-slow);
}
.cause:hover .cause__icon {
  transform: scale(1.1) rotate(-5deg);
  background: var(--cb-gold);
  border-color: var(--cb-gold);
}
.cause__name {
  font: 700 var(--fs-md)/1.2 var(--f-display);
  color: var(--cb-cream);
  letter-spacing: -0.01em;
  transition: color var(--d-base);
  text-wrap: balance;
}
.cause__sub {
  font: 500 11px/1.3 var(--f-spaced);
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--cb-gold-light);
  margin-top: 6px;
  opacity: 0.85;
}

/* ================================================================
   GALLERY — masonry magazine grid for /casos/
   ================================================================ */
.gallery {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-auto-rows: clamp(140px, 16vw, 220px);
  gap: var(--sp-3);
  position: relative;
}
.gallery__cell {
  position: relative;
  overflow: hidden;
  border-radius: var(--r-md);
  cursor: pointer;
  isolation: isolate;
  background: var(--cb-brown-dark);
  box-shadow: var(--shadow-sm);
  transition: transform var(--d-slow) var(--ease-out-expo),
              box-shadow var(--d-slow) var(--ease-out-expo);
}
.gallery__cell::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--cell-bg);
  background-size: cover;
  background-position: center;
  transition: transform var(--d-cinematic) var(--ease-out-expo);
  z-index: 0;
}
.gallery__cell::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg,
    rgba(26, 20, 16, 0.05) 0%,
    rgba(26, 20, 16, 0.3) 60%,
    rgba(26, 20, 16, 0.92) 100%);
  z-index: 1;
}
.gallery__cell:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-xl);
}
.gallery__cell:hover::before { transform: scale(1.1); }
.gallery__cell-content {
  position: absolute;
  inset: 0;
  z-index: 2;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: var(--sp-4);
  color: var(--cb-cream);
}
.gallery__cell-num {
  font: 800 13px/1 var(--f-spaced);
  letter-spacing: .35em;
  text-transform: uppercase;
  color: var(--cb-gold-light);
  margin-bottom: 8px;
}
.gallery__cell-title {
  font: 700 var(--fs-lg)/1.15 var(--f-display);
  color: #fff;
  letter-spacing: -0.01em;
  margin-bottom: 4px;
  text-wrap: balance;
}
.gallery__cell-desc {
  font: 400 var(--fs-sm)/1.4 var(--f-sans);
  color: var(--cb-cream-deep);
  opacity: 0.92;
  display: none;
}
.gallery__cell:hover .gallery__cell-desc { display: block; }

/* Magazine layout: irregular grid */
.gallery__cell--lg-2x2 { grid-column: span 6; grid-row: span 2; }
.gallery__cell--lg-2x1 { grid-column: span 6; grid-row: span 1; }
.gallery__cell--md-1x2 { grid-column: span 4; grid-row: span 2; }
.gallery__cell--md      { grid-column: span 4; grid-row: span 1; }
.gallery__cell--sm      { grid-column: span 3; grid-row: span 1; }
.gallery__cell--sm-1x2  { grid-column: span 3; grid-row: span 2; }
.gallery__cell--full    { grid-column: span 12; grid-row: span 2; }

@media (max-width: 880px) {
  .gallery { grid-template-columns: repeat(6, 1fr); grid-auto-rows: 200px; }
  .gallery__cell--lg-2x2 { grid-column: span 6; grid-row: span 2; }
  .gallery__cell--lg-2x1 { grid-column: span 6; grid-row: span 1; }
  .gallery__cell--md-1x2 { grid-column: span 3; grid-row: span 2; }
  .gallery__cell--md      { grid-column: span 3; grid-row: span 1; }
  .gallery__cell--sm      { grid-column: span 3; grid-row: span 1; }
  .gallery__cell--sm-1x2  { grid-column: span 3; grid-row: span 2; }
  .gallery__cell--full    { grid-column: span 6; grid-row: span 2; }
}

/* ================================================================
   MACRO SECTION DIVIDER — full-bleed cinemascope
   ================================================================ */
.macro-divider {
  width: 100%;
  height: clamp(220px, 40vh, 380px);
  background-size: cover;
  background-position: center;
  background-attachment: fixed;
  position: relative;
  isolation: isolate;
}
@media (max-width: 768px) { .macro-divider { background-attachment: scroll; } }
.macro-divider::after {
  content: '';
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(26, 20, 16, .25) 0%, rgba(26, 20, 16, .15) 50%, rgba(26, 20, 16, .25) 100%);
  z-index: 1;
}
.macro-divider__quote {
  position: relative;
  z-index: 2;
  height: 100%;
  display: grid;
  place-items: center;
  text-align: center;
  padding: var(--sp-5);
}
.macro-divider__quote-text {
  font: italic 700 clamp(24px, 3vw, 44px)/1.25 var(--f-display);
  color: var(--cb-cream);
  text-shadow: 0 4px 24px rgba(0,0,0,.6);
  max-width: 800px;
  text-wrap: balance;
}
.macro-divider__quote-text em {
  color: var(--cb-gold-light);
}

/* ================================================================
   ALLIES STRIP — refined
   ================================================================ */
.allies-strip {
  display: flex; flex-wrap: wrap; gap: var(--sp-7);
  align-items: center; justify-content: center;
}
.allies-strip__item {
  font: 700 var(--fs-md)/1 var(--f-display);
  color: var(--cb-brown);
  letter-spacing: -.01em;
  opacity: 0.7;
  transition: opacity var(--d-base);
  white-space: nowrap;
}
.allies-strip__item:hover { opacity: 1; color: var(--cb-gold); }

/* ================================================================
   QUOTE — manifesto block
   ================================================================ */
.manifesto {
  text-align: center;
  max-width: var(--container-prose);
  margin-inline: auto;
  position: relative;
  padding-top: var(--sp-6);
}
.manifesto::before {
  content: '"';
  position: absolute;
  top: -0.15em;
  left: 50%;
  transform: translateX(-50%);
  font: 700 clamp(120px, 13vw, 180px)/0.6 var(--f-display);
  color: var(--cb-gold);
  opacity: 0.18;
  pointer-events: none;
}
.manifesto__quote {
  font: italic 400 var(--fs-xl)/1.45 var(--f-display);
  color: var(--cb-brown-dark);
  margin-block: var(--sp-4);
  text-wrap: balance;
}
.manifesto__cite {
  font: 600 12px/1 var(--f-spaced);
  letter-spacing: .35em;
  text-transform: uppercase;
  color: var(--cb-gold);
  display: inline-flex;
  align-items: center;
  gap: 14px;
}
.manifesto__cite::before, .manifesto__cite::after {
  content: '';
  width: 30px;
  height: 1.5px;
  background: currentColor;
}

/* ================================================================
   FINAL CTA — dramatic
   ================================================================ */
.final-cta {
  background: linear-gradient(135deg, var(--cb-ink) 0%, var(--cb-brown-dark) 60%, var(--cb-brown) 100%);
  color: var(--cb-cream);
  padding-block: var(--sp-9);
  text-align: center;
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.final-cta::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 20% 30%, rgba(184, 152, 90, .18) 0%, transparent 50%),
    radial-gradient(circle at 80% 70%, rgba(184, 152, 90, .12) 0%, transparent 50%);
  pointer-events: none;
}
.final-cta::after {
  content: 'B';
  position: absolute;
  bottom: -30%;
  right: -5%;
  font: 400 70vh/0.8 var(--f-script);
  color: var(--cb-gold);
  opacity: 0.04;
  pointer-events: none;
  user-select: none;
}
.final-cta__inner { position: relative; z-index: 2; max-width: 800px; margin-inline: auto; padding-inline: var(--container-pad); }
.final-cta h2 { color: var(--cb-cream); margin-bottom: var(--sp-3); }
.final-cta__ctas {
  display: flex;
  gap: var(--sp-3);
  justify-content: center;
  flex-wrap: wrap;
  margin-top: var(--sp-5);
}

/* ================================================================
   FOOTER — premium 5-column
   ================================================================ */
.site-footer {
  background: var(--cb-ink);
  color: var(--cb-cream);
  padding-top: var(--sp-7);
  position: relative;
  overflow: hidden;
}
.site-footer::before {
  content: 'Continental Best';
  position: absolute;
  bottom: -2vw;
  left: 50%;
  transform: translateX(-50%);
  font: 400 18vw/0.8 var(--f-script);
  color: var(--cb-gold);
  opacity: 0.04;
  pointer-events: none;
  white-space: nowrap;
}
.site-footer__cols {
  display: grid;
  grid-template-columns: 1.4fr repeat(4, 1fr);
  gap: var(--sp-5);
  padding-bottom: var(--sp-6);
  border-bottom: 1px solid rgba(245, 235, 220, .08);
  position: relative;
  z-index: 2;
}
@media (max-width: 880px) {
  .site-footer__cols { grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); }
}
.site-footer h4 {
  font: 700 11px/1 var(--f-spaced);
  letter-spacing: .35em;
  text-transform: uppercase;
  color: var(--cb-gold);
  margin-bottom: var(--sp-3);
}
.site-footer ul li { margin-bottom: 10px; }
.site-footer a {
  color: var(--cb-cream);
  opacity: .75;
  transition: opacity var(--d-base) var(--ease-out-expo), color var(--d-base);
  font-size: var(--fs-sm);
}
.site-footer a:hover { opacity: 1; color: var(--cb-gold-light); }

.site-footer__brand { position: relative; z-index: 2; }
.site-footer__brand img { height: 60px; width: auto; margin-bottom: var(--sp-3); filter: brightness(0) invert(1); opacity: .9; }
.site-footer__brand p { color: rgba(245, 235, 220, .7); font-size: var(--fs-sm); line-height: 1.6; max-width: 30ch; }
.site-footer__seal {
  margin-top: var(--sp-3);
  padding: 8px 18px;
  border: 1px solid var(--cb-gold);
  border-radius: var(--r-pill);
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font: 600 10px/1 var(--f-spaced);
  letter-spacing: .3em;
  color: var(--cb-gold-light);
  text-transform: uppercase;
}
.site-footer__seal::before { content: '★'; color: var(--cb-gold); }

.site-footer__social {
  display: flex;
  gap: 10px;
  margin-top: var(--sp-3);
}
.site-footer__social a {
  width: 36px; height: 36px;
  border: 1px solid rgba(184, 152, 90, .3);
  border-radius: 50%;
  display: grid; place-items: center;
  transition: all var(--d-base);
  opacity: 1;
}
.site-footer__social a:hover {
  background: var(--cb-gold);
  border-color: var(--cb-gold);
  color: var(--cb-brown-dark);
  transform: translateY(-3px);
}

.site-footer__bottom {
  text-align: center;
  padding-block: var(--sp-4);
  font-size: 11px;
  color: rgba(245, 235, 220, .42);
  position: relative;
  z-index: 2;
  letter-spacing: .04em;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}
.site-footer__copy { line-height: 1.5; }
.site-footer__credit {
  font: 500 11px/1.4 var(--f-spaced);
  letter-spacing: .25em;
  text-transform: uppercase;
  color: rgba(245, 235, 220, .55);
  padding-top: var(--sp-3);
  border-top: 1px solid rgba(184, 152, 90, .18);
  width: 100%;
  max-width: 520px;
}
.site-footer__credit-link {
  color: var(--cb-gold-light) !important;
  opacity: 1 !important;
  text-decoration: none;
  position: relative;
  transition: color var(--d-base) var(--ease-out-expo);
}
.site-footer__credit-link::after {
  content: '↗';
  display: inline-block;
  margin-left: 4px;
  transition: transform var(--d-base) var(--ease-out-expo);
}
.site-footer__credit-link:hover { color: var(--cb-gold) !important; }
.site-footer__credit-link:hover::after { transform: translate(2px, -2px); }
/* "Ext." inside footer phone numbers */
.site-footer ul li small {
  font-size: 0.85em;
  opacity: 0.7;
  font-weight: 400;
  letter-spacing: 0.04em;
}

/* ================================================================
   RFQ FORM — refined
   ================================================================ */
.rfq-form {
  background: var(--cb-white);
  padding: clamp(28px, 5vw, 56px);
  border-radius: var(--r-xl);
  box-shadow: var(--shadow-lg);
  display: grid;
  gap: var(--sp-3);
  max-width: 800px;
  margin-inline: auto;
  position: relative;
  border-top: 4px solid var(--cb-gold);
}
.rfq-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-3); }
.rfq-field { display: flex; flex-direction: column; gap: 6px; position: relative; }
.rfq-field label {
  font: 600 12px/1 var(--f-sans);
  color: var(--cb-brown);
  letter-spacing: .08em;
  text-transform: uppercase;
}
.rfq-field label .req { color: #c0392b; }
.rfq-field input,
.rfq-field select,
.rfq-field textarea {
  border: 1.5px solid var(--cb-cream-deep);
  border-radius: var(--r-sm);
  padding: 14px 16px;
  font: 400 var(--fs-base)/1.4 var(--f-sans);
  background: var(--cb-paper);
  color: var(--cb-brown-dark);
  transition: border-color var(--d-base), background var(--d-base), box-shadow var(--d-base);
  font-family: inherit;
}
.rfq-field input:focus,
.rfq-field select:focus,
.rfq-field textarea:focus {
  outline: none;
  border-color: var(--cb-gold);
  background: var(--cb-white);
  box-shadow: 0 0 0 4px rgba(184, 152, 90, .15);
}
.rfq-field textarea { resize: vertical; min-height: 120px; }
.rfq-field--full { grid-column: 1 / -1; }
.rfq-honeypot { position: absolute; left: -10000px; opacity: 0; }
.rfq-radios { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: var(--sp-2); }
.rfq-radio {
  border: 1.5px solid var(--cb-cream-deep);
  border-radius: var(--r-sm);
  padding: 14px;
  cursor: pointer;
  text-align: center;
  transition: all var(--d-base);
  font: 600 12px/1.2 var(--f-sans);
  color: var(--cb-brown);
  background: var(--cb-paper);
  letter-spacing: .04em;
  text-transform: uppercase;
}
.rfq-radio input { display: none; }
.rfq-radio:has(input:checked) {
  background: var(--cb-brown-dark);
  color: var(--cb-gold-light);
  border-color: var(--cb-brown-dark);
  box-shadow: var(--shadow-md);
}
.rfq-checkbox { display: flex; gap: 12px; align-items: flex-start; font-size: var(--fs-sm); color: var(--cb-brown); line-height: 1.5; }
.rfq-checkbox input { margin-top: 4px; flex-shrink: 0; }
.rfq-checkbox a { color: var(--cb-gold); text-decoration: underline; }
.rfq-actions { display: flex; gap: var(--sp-3); flex-wrap: wrap; justify-content: center; padding-top: var(--sp-2); }
.rfq-actions .btn { flex: 1; justify-content: center; min-width: 220px; }
.rfq-error { color: #c0392b; font-size: 12px; margin-top: 4px; display: none; }
.rfq-field.has-error input,
.rfq-field.has-error select,
.rfq-field.has-error textarea { border-color: #c0392b; box-shadow: 0 0 0 4px rgba(192, 57, 43, .1); }
.rfq-field.has-error .rfq-error { display: block; }

@media (max-width: 600px) { .rfq-row { grid-template-columns: 1fr; } }

/* ================================================================
   ENCUESTAS — Rating scales (1-5 stars + NPS 0-10)
   ================================================================ */
.rfq-scale {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.rfq-scale__option {
  flex: 1;
  min-width: 48px;
  cursor: pointer;
  text-align: center;
  border: 1.5px solid var(--cb-cream-deep);
  background: var(--cb-paper);
  border-radius: var(--r-sm);
  padding: 12px 6px;
  font: 700 18px/1 var(--f-display);
  color: var(--cb-brown);
  transition: all var(--d-base) var(--ease-out-expo);
  position: relative;
}
.rfq-scale__option input { display: none; }
.rfq-scale__option-label {
  display: block;
  font: 600 9px/1.2 var(--f-spaced);
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--cb-brown);
  opacity: 0.6;
  margin-top: 4px;
}
.rfq-scale__option:hover {
  border-color: var(--cb-gold);
  transform: translateY(-2px);
}
.rfq-scale__option:has(input:checked) {
  background: linear-gradient(135deg, var(--cb-gold), var(--cb-gold-light));
  color: var(--cb-brown-dark);
  border-color: var(--cb-gold);
  box-shadow: var(--shadow-gold);
}
.rfq-scale__option:has(input:checked) .rfq-scale__option-label {
  color: var(--cb-brown-dark);
  opacity: 1;
}

/* NPS — 0-10 horizontal */
.rfq-nps {
  display: flex;
  gap: 4px;
  flex-wrap: nowrap;
  overflow-x: auto;
  padding-bottom: 4px;
}
.rfq-nps__option {
  flex: 1 0 36px;
  cursor: pointer;
  text-align: center;
  border: 1.5px solid var(--cb-cream-deep);
  background: var(--cb-paper);
  border-radius: var(--r-sm);
  padding: 12px 0;
  font: 700 14px/1 var(--f-display);
  color: var(--cb-brown);
  transition: all var(--d-base) var(--ease-out-expo);
  min-width: 36px;
}
.rfq-nps__option input { display: none; }
.rfq-nps__option:hover {
  border-color: var(--cb-gold);
  transform: translateY(-2px);
}
.rfq-nps__option:has(input:checked) {
  background: var(--cb-brown-dark);
  color: var(--cb-gold-light);
  border-color: var(--cb-brown-dark);
}
/* color-coded zones for NPS */
.rfq-nps__option[data-zone="detractor"]:hover { border-color: #c0392b; }
.rfq-nps__option[data-zone="passive"]:hover   { border-color: #f39c12; }
.rfq-nps__option[data-zone="promoter"]:hover  { border-color: #27ae60; }
.rfq-nps__option[data-zone="detractor"]:has(input:checked) { background: #c0392b; color: #fff; border-color: #c0392b; }
.rfq-nps__option[data-zone="passive"]:has(input:checked)   { background: #f39c12; color: #fff; border-color: #f39c12; }
.rfq-nps__option[data-zone="promoter"]:has(input:checked)  { background: #27ae60; color: #fff; border-color: #27ae60; }
.rfq-nps__legend {
  display: flex;
  justify-content: space-between;
  font: 500 10px/1 var(--f-spaced);
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--cb-brown);
  opacity: 0.6;
  margin-top: 8px;
}

/* ================================================================
   FAB WhatsApp (always visible, premium expanding label on desktop)
   ================================================================ */
.fab-whatsapp {
  position: fixed;
  bottom: clamp(20px, 3vw, 32px);
  right: clamp(20px, 3vw, 32px);
  z-index: 95;
  height: 64px;
  background: var(--whatsapp-green);
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  gap: 0;
  padding: 0;
  text-decoration: none;
  color: #fff;
  font: 700 14px/1 var(--f-sans);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  box-shadow:
    0 16px 40px rgba(37, 211, 102, .45),
    0 6px 14px rgba(37, 211, 102, .30),
    0 2px 4px rgba(0, 0, 0, .12),
    inset 0 1px 0 rgba(255, 255, 255, .25);
  overflow: hidden;
  transition: transform var(--d-slow) var(--ease-out-expo),
              box-shadow var(--d-slow) var(--ease-out-expo),
              gap var(--d-slow) var(--ease-out-expo),
              padding var(--d-slow) var(--ease-out-expo);
  white-space: nowrap;
  isolation: isolate;
}
.fab-whatsapp__icon {
  width: 64px; height: 64px;
  display: grid;
  place-items: center;
  flex-shrink: 0;
  border-radius: 50%;
  position: relative;
  z-index: 2;
}
.fab-whatsapp__icon::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: var(--whatsapp-green);
  z-index: -1;
  animation: fab-ring 2.4s ease-out infinite;
}
@keyframes fab-ring {
  0%   { transform: scale(1);   opacity: 0.6; }
  100% { transform: scale(1.7); opacity: 0;   }
}
.fab-whatsapp__icon svg { width: 30px; height: 30px; fill: #fff; }
.fab-whatsapp__label {
  display: inline-block;
  max-width: 0;
  overflow: hidden;
  opacity: 0;
  transition: max-width var(--d-slow) var(--ease-out-expo),
              opacity var(--d-base) var(--ease-out-expo),
              padding-right var(--d-slow) var(--ease-out-expo);
  padding-right: 0;
}
.fab-whatsapp:hover {
  transform: translateY(-3px);
  box-shadow:
    0 22px 50px rgba(37, 211, 102, .55),
    0 8px 18px rgba(37, 211, 102, .35),
    0 2px 4px rgba(0, 0, 0, .14);
  background: var(--whatsapp-deep);
}
.fab-whatsapp:hover .fab-whatsapp__label {
  max-width: 240px;
  opacity: 1;
  padding-right: 22px;
}
.fab-whatsapp:hover .fab-whatsapp__icon::before { animation: none; }
@media (max-width: 768px) {
  .fab-whatsapp__label { display: none; }
}

/* ================================================================
   REVEAL ON SCROLL
   ================================================================ */
[data-reveal] {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity var(--d-slower) var(--ease-out-expo), transform var(--d-slower) var(--ease-out-expo);
}
[data-reveal].is-revealed { opacity: 1; transform: none; }
[data-reveal-delay="1"].is-revealed { transition-delay: 100ms; }
[data-reveal-delay="2"].is-revealed { transition-delay: 200ms; }
[data-reveal-delay="3"].is-revealed { transition-delay: 300ms; }
[data-reveal-delay="4"].is-revealed { transition-delay: 400ms; }
[data-reveal-delay="5"].is-revealed { transition-delay: 500ms; }
[data-reveal-delay="6"].is-revealed { transition-delay: 600ms; }

[data-reveal="scale"] { transform: scale(0.92); }
[data-reveal="scale"].is-revealed { transform: scale(1); }
[data-reveal="left"]  { transform: translateX(-60px); }
[data-reveal="left"].is-revealed { transform: none; }
[data-reveal="right"] { transform: translateX(60px); }
[data-reveal="right"].is-revealed { transform: none; }

/* ================================================================
   PARALLAX
   ================================================================ */
[data-parallax] { will-change: transform; }

/* ================================================================
   ╔═══════════════════════════════════════════════════════════╗
   ║  GLORIFICADOR — Premium retail product display            ║
   ║  Producto flotando gigante con halo, spotlight, specs     ║
   ╚═══════════════════════════════════════════════════════════╝
   ================================================================ */
.glorifier {
  position: relative;
  background:
    radial-gradient(ellipse 70% 90% at 35% 50%, rgba(184, 152, 90, .18) 0%, transparent 55%),
    radial-gradient(ellipse 60% 80% at 65% 60%, rgba(122, 31, 46, .12) 0%, transparent 60%),
    linear-gradient(180deg, var(--cb-ink) 0%, #0d0a08 100%);
  color: var(--cb-cream);
  padding-block: clamp(80px, 12vw, 180px);
  overflow: hidden;
  isolation: isolate;
}
/* Light rays from top */
.glorifier::before {
  content: '';
  position: absolute;
  top: -20%;
  left: 50%;
  transform: translateX(-50%);
  width: 90%;
  height: 140%;
  background:
    conic-gradient(from 200deg at 50% 0%,
      transparent 0deg,
      rgba(184, 152, 90, .04) 8deg,
      rgba(184, 152, 90, .14) 14deg,
      rgba(184, 152, 90, .04) 20deg,
      transparent 26deg,
      transparent 30deg,
      rgba(184, 152, 90, .12) 38deg,
      transparent 50deg);
  pointer-events: none;
  filter: blur(2px);
}
/* Brand watermark gigante atrás */
.glorifier::after {
  content: 'CB';
  position: absolute;
  bottom: -6vw;
  left: 50%;
  transform: translateX(-50%);
  font: 400 38vw/0.85 var(--f-script);
  color: var(--cb-gold);
  opacity: 0.06;
  pointer-events: none;
  user-select: none;
  z-index: 0;
  letter-spacing: -0.05em;
}
.glorifier__inner {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: clamp(40px, 6vw, 100px);
  align-items: center;
  max-width: 1280px;
  margin-inline: auto;
  padding-inline: var(--container-pad);
}

/* PRODUCTO — flotando con halo */
.glorifier__stage {
  position: relative;
  aspect-ratio: 5/4;
  display: grid;
  place-items: center;
  perspective: 1200px;
}
.glorifier__halo {
  position: absolute;
  inset: 12% 8%;
  background: radial-gradient(circle at 50% 55%,
    rgba(184, 152, 90, .55) 0%,
    rgba(184, 152, 90, .30) 25%,
    rgba(184, 152, 90, .10) 50%,
    transparent 70%);
  filter: blur(40px);
  z-index: 1;
  animation: glor-pulse 5s ease-in-out infinite;
}
.glorifier__halo--datil {
  background: radial-gradient(circle at 50% 55%,
    rgba(232, 154, 158, .55) 0%,
    rgba(232, 154, 158, .30) 25%,
    rgba(232, 154, 158, .10) 50%,
    transparent 70%);
}
@keyframes glor-pulse {
  0%, 100% { transform: scale(1); opacity: 0.85; }
  50%      { transform: scale(1.08); opacity: 1; }
}
/* Pedestal — círculo decorativo bajo el producto */
.glorifier__pedestal {
  position: absolute;
  bottom: 8%;
  left: 50%;
  transform: translateX(-50%);
  width: 70%;
  aspect-ratio: 4/1;
  background: radial-gradient(ellipse, rgba(0,0,0,.65) 0%, transparent 70%);
  filter: blur(20px);
  z-index: 1;
}
.glorifier__product {
  position: relative;
  z-index: 3;
  width: 100%;
  max-width: 720px;
  filter:
    drop-shadow(0 30px 50px rgba(0, 0, 0, .65))
    drop-shadow(0 0 60px rgba(184, 152, 90, .35));
  animation: glor-float 7s ease-in-out infinite;
  transform-origin: center;
}
@keyframes glor-float {
  0%, 100% { transform: translateY(0) rotate(-1deg); }
  50%      { transform: translateY(-22px) rotate(1deg); }
}
/* Sparkle particles */
.glorifier__sparkles {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background-image:
    radial-gradient(circle at 18% 32%, var(--cb-gold-light) 1.5px, transparent 2px),
    radial-gradient(circle at 78% 22%, var(--cb-gold-light) 1px, transparent 1.5px),
    radial-gradient(circle at 25% 75%, var(--cb-gold-light) 2px, transparent 2.5px),
    radial-gradient(circle at 85% 68%, var(--cb-gold-light) 1px, transparent 1.5px),
    radial-gradient(circle at 50% 12%, var(--cb-gold-light) 1.5px, transparent 2px);
  animation: glor-twinkle 3.5s ease-in-out infinite alternate;
}
@keyframes glor-twinkle {
  0%   { opacity: 0.4; }
  100% { opacity: 1.0; }
}

/* INFO derecha */
.glorifier__info {
  position: relative;
  z-index: 2;
}
.glorifier__eyebrow {
  font: 700 11px/1 var(--f-spaced);
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--cb-gold-light);
  display: inline-flex;
  align-items: center;
  gap: 12px;
}
.glorifier__eyebrow::before {
  content: '';
  width: 32px;
  height: 1.5px;
  background: currentColor;
}
.glorifier__title {
  font: 700 clamp(48px, 6vw, 88px)/0.95 var(--f-display);
  color: var(--cb-cream);
  margin-block: var(--sp-3);
  letter-spacing: -0.035em;
  text-wrap: balance;
}
.glorifier__title em {
  font-style: italic;
  color: var(--cb-gold-light);
}
.glorifier__subtitle {
  font: 400 var(--fs-md)/1.2 var(--f-script);
  color: var(--cb-gold);
  font-weight: 400;
  display: block;
  font-size: clamp(28px, 3vw, 44px);
  margin-bottom: var(--sp-3);
}
.glorifier__desc {
  font: 400 var(--fs-md)/1.6 var(--f-sans);
  color: var(--cb-cream-deep);
  max-width: 50ch;
  margin-bottom: var(--sp-5);
}
.glorifier__specs {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--sp-5);
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0;
  border-top: 1px solid rgba(184, 152, 90, .25);
}
.glorifier__specs li {
  padding: var(--sp-3) var(--sp-3) var(--sp-3) 0;
  border-bottom: 1px solid rgba(184, 152, 90, .25);
  font: 400 13px/1.3 var(--f-sans);
  color: var(--cb-cream-deep);
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.glorifier__specs li:nth-child(odd) { padding-right: var(--sp-4); border-right: 1px solid rgba(184, 152, 90, .25); }
.glorifier__specs li:nth-child(even) { padding-left: var(--sp-4); }
.glorifier__specs strong {
  font: 700 13px/1 var(--f-spaced);
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--cb-gold-light);
}
.glorifier__ctas {
  display: flex;
  gap: var(--sp-3);
  flex-wrap: wrap;
}

@media (max-width: 880px) {
  .glorifier__inner { grid-template-columns: 1fr; gap: var(--sp-5); }
  .glorifier__stage { aspect-ratio: 4/3; max-width: 540px; margin-inline: auto; }
  .glorifier__specs { grid-template-columns: 1fr; }
  .glorifier__specs li,
  .glorifier__specs li:nth-child(odd) { padding: var(--sp-2) 0 !important; border-right: 0 !important; }
}

/* ================================================================
   ╔═══════════════════════════════════════════════════════════╗
   ║  PRODUCT COVERFLOW — 8 sabores en slider 3D estilo Apple  ║
   ╚═══════════════════════════════════════════════════════════╝
   ================================================================ */
.coverflow {
  background: linear-gradient(180deg, var(--cb-paper) 0%, var(--cb-cream) 100%);
  padding-block: var(--sp-8) var(--sp-7);
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.coverflow::before {
  content: 'SABORES';
  position: absolute;
  top: 8%;
  left: 50%;
  transform: translateX(-50%);
  font: 800 18vw/0.85 var(--f-display);
  color: var(--cb-brown-dark);
  opacity: 0.04;
  pointer-events: none;
  white-space: nowrap;
  letter-spacing: -0.05em;
}
.coverflow__head {
  position: relative;
  z-index: 2;
  text-align: center;
  margin-bottom: var(--sp-7);
  padding-inline: var(--container-pad);
}
.coverflow__swiper {
  position: relative;
  z-index: 2;
  width: 100%;
  padding-block: 30px 60px;
  overflow: visible !important;
}
.coverflow__swiper .swiper-slide {
  width: clamp(260px, 32vw, 460px);
  display: flex;
  align-items: center;
  justify-content: center;
}
.coverflow__card {
  background: var(--cb-white);
  border-radius: var(--r-lg);
  padding: var(--sp-5) var(--sp-4) var(--sp-4);
  box-shadow: var(--shadow-md);
  text-align: center;
  width: 100%;
  position: relative;
  isolation: isolate;
}
.coverflow__card::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: var(--r-lg);
  background: linear-gradient(135deg, var(--cb-paper), var(--cb-cream-deep));
  z-index: -1;
  opacity: 0.5;
}
.coverflow__media {
  aspect-ratio: 4/2.4;
  display: grid;
  place-items: center;
  position: relative;
  margin-bottom: var(--sp-3);
}
.coverflow__media::before {
  content: '';
  position: absolute;
  bottom: 8%;
  left: 50%;
  transform: translateX(-50%);
  width: 80%;
  aspect-ratio: 6/1;
  background: radial-gradient(ellipse, rgba(61, 40, 23, .35) 0%, transparent 65%);
  filter: blur(12px);
  z-index: 0;
}
.coverflow__media img {
  position: relative;
  z-index: 1;
  max-width: 100%;
  max-height: 100%;
  filter: drop-shadow(0 12px 20px rgba(61, 40, 23, .25));
}
.coverflow__name {
  font: 700 clamp(20px, 1.6vw, 26px)/1.1 var(--f-display);
  color: var(--cb-brown-dark);
  letter-spacing: -0.01em;
  margin-bottom: 4px;
}
.coverflow__group {
  font: 600 10px/1 var(--f-spaced);
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--cb-gold);
  margin-bottom: var(--sp-3);
}
.coverflow__desc {
  font: 400 var(--fs-sm)/1.4 var(--f-sans);
  color: var(--cb-brown);
  margin-bottom: var(--sp-3);
  min-height: 50px;
}
.coverflow__cta {
  display: inline-flex;
  width: 100%;
  justify-content: center;
}
/* Swiper navigation custom */
.coverflow__nav {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--sp-3);
  margin-top: var(--sp-3);
}
.coverflow__nav-btn {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  border: 1.5px solid var(--cb-brown-dark);
  background: transparent;
  color: var(--cb-brown-dark);
  display: grid;
  place-items: center;
  cursor: pointer;
  transition: all var(--d-base) var(--ease-out-expo);
}
.coverflow__nav-btn:hover {
  background: var(--cb-brown-dark);
  color: var(--cb-cream);
  transform: scale(1.05);
}
.coverflow__nav-btn:disabled {
  opacity: .3;
  cursor: not-allowed;
}
.coverflow__pagination {
  display: inline-flex;
  gap: 6px;
  align-items: center;
}
.coverflow__pagination .swiper-pagination-bullet {
  width: 6px;
  height: 6px;
  background: var(--cb-brown);
  opacity: .25;
  margin: 0 !important;
  transition: all var(--d-base);
}
.coverflow__pagination .swiper-pagination-bullet-active {
  width: 32px;
  border-radius: 3px;
  background: var(--cb-gold);
  opacity: 1;
}

/* ================================================================
   NUMBERS LEGENDARIOS — count-up stats section
   ================================================================ */
.stats {
  background:
    radial-gradient(ellipse at 20% 30%, rgba(184, 152, 90, .12) 0%, transparent 60%),
    radial-gradient(ellipse at 80% 70%, rgba(184, 152, 90, .08) 0%, transparent 60%),
    linear-gradient(135deg, var(--cb-ink) 0%, var(--cb-brown-dark) 100%);
  color: var(--cb-cream);
  padding-block: var(--sp-8);
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.stats::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(circle at 12% 18%, rgba(184, 152, 90, .35) 1.5px, transparent 2px),
    radial-gradient(circle at 28% 80%, rgba(184, 152, 90, .25) 1px, transparent 1.5px),
    radial-gradient(circle at 60% 45%, rgba(184, 152, 90, .35) 2px, transparent 2.5px),
    radial-gradient(circle at 85% 25%, rgba(184, 152, 90, .25) 1px, transparent 1.5px),
    radial-gradient(circle at 92% 75%, rgba(184, 152, 90, .35) 1.5px, transparent 2px),
    radial-gradient(circle at 45% 92%, rgba(184, 152, 90, .25) 1px, transparent 1.5px);
  pointer-events: none;
  animation: stats-twinkle 6s ease-in-out infinite alternate;
}
@keyframes stats-twinkle {
  0%   { opacity: 0.7; }
  100% { opacity: 1.0; }
}
.stats__inner {
  position: relative;
  z-index: 2;
  text-align: center;
}
.stats__heading {
  margin-bottom: var(--sp-7);
}
.stats__heading .eyebrow { color: var(--cb-gold-light); }
.stats__heading h2 { color: var(--cb-cream); }
.stats__heading h2 em { color: var(--cb-gold-light); }

.stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  position: relative;
  max-width: 1100px;
  margin-inline: auto;
}
.stats-grid::before,
.stats-grid::after,
.stats-grid > .stat:not(:last-child)::after {
  content: '';
  position: absolute;
  top: 12%; bottom: 12%;
  width: 1px;
  background: linear-gradient(to bottom, transparent, rgba(184, 152, 90, .3), transparent);
  pointer-events: none;
}
.stat:nth-child(1)::after { right: -0.5px; left: auto; top: 12%; bottom: 12%; }
.stats-grid::before { display: none; }
.stats-grid::after { display: none; }
@media (max-width: 720px) {
  .stats-grid { grid-template-columns: repeat(2, 1fr); }
  .stat::after { display: none; }
}

.stat {
  text-align: center;
  position: relative;
  padding: var(--sp-4) var(--sp-3);
}
.stat:not(:last-child)::after {
  content: '';
  position: absolute;
  top: 18%; bottom: 18%;
  right: 0;
  width: 1px;
  background: linear-gradient(to bottom, transparent, rgba(184, 152, 90, .25), transparent);
}
.stat__value {
  display: inline-flex;
  align-items: baseline;
  justify-content: center;
  gap: 2px;
  white-space: nowrap;
  background: linear-gradient(135deg, var(--cb-gold-light) 0%, var(--cb-gold) 50%, var(--cb-gold-light) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  margin-bottom: var(--sp-2);
}
.stat__prefix,
.stat__suffix {
  font: 700 clamp(22px, 2.4vw, 36px)/1 var(--f-display);
  letter-spacing: -0.02em;
}
.stat__num {
  font: 700 clamp(40px, 5.4vw, 80px)/1 var(--f-display);
  letter-spacing: -0.035em;
  font-variant-numeric: tabular-nums;
}
.stat__label {
  font: 600 11px/1.3 var(--f-spaced);
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--cb-cream);
  margin-top: var(--sp-2);
}
.stat__sub {
  font: 400 12px/1.4 var(--f-sans);
  color: rgba(245, 235, 220, .55);
  margin-top: 6px;
  letter-spacing: .02em;
  max-width: 22ch;
  margin-inline: auto;
}

/* ================================================================
   CURSOR FOLLOWER (dark sections only — desktop)
   ================================================================ */
.cursor-trail {
  position: fixed;
  top: 0; left: 0;
  width: 24px; height: 24px;
  border-radius: 50%;
  background: radial-gradient(circle, var(--cb-gold) 0%, transparent 70%);
  pointer-events: none;
  z-index: 9998;
  opacity: 0;
  transform: translate(-50%, -50%);
  mix-blend-mode: screen;
  transition: opacity 300ms ease;
  filter: blur(2px);
}
.cursor-trail.is-active { opacity: 0.9; }
@media (hover: none), (max-width: 1024px) {
  .cursor-trail { display: none; }
}

/* ================================================================
   GIANT DECORATIVE NUMBERS (between sections)
   ================================================================ */
.giant-num {
  font: 800 clamp(120px, 28vw, 360px)/0.85 var(--f-display);
  letter-spacing: -0.05em;
  color: transparent;
  -webkit-text-stroke: 2px var(--cb-gold);
  text-stroke: 2px var(--cb-gold);
  opacity: 0.3;
  text-align: center;
  user-select: none;
  pointer-events: none;
  margin-block: var(--sp-6);
  background: linear-gradient(180deg, transparent 50%, rgba(184, 152, 90, .08) 100%);
  -webkit-background-clip: text;
  background-clip: text;
}

/* ================================================================
   REDUCED MOTION
   ================================================================ */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
  .fab-whatsapp { animation: none; }
  .hero-slide__bg { transform: scale(1) !important; }
}

/* ================================================================
   PRINT
   ================================================================ */
@media print {
  .site-header, .site-footer, .fab-whatsapp, .hero-pagination, .hero-counter, .hero-scroll-hint { display: none; }
  .hero { min-height: auto; padding: var(--sp-5); }
  body { background: white; color: black; }
}
