.elementor-kit-14{--e-global-color-primary:#6EC1E4;--e-global-color-secondary:#54595F;--e-global-color-text:#7A7A7A;--e-global-color-accent:#61CE70;--e-global-typography-primary-font-family:"Roboto";--e-global-typography-primary-font-weight:600;--e-global-typography-secondary-font-family:"Roboto Slab";--e-global-typography-secondary-font-weight:400;--e-global-typography-text-font-family:"Roboto";--e-global-typography-text-font-weight:400;--e-global-typography-accent-font-family:"Roboto";--e-global-typography-accent-font-weight:500;--e-global-typography-d66554b-font-family:"Fraunces";--e-global-typography-9520d14-font-family:"Pacifico";--e-global-typography-a7b5a51-font-family:"DM Sans";}.elementor-kit-14 e-page-transition{background-color:#FFBC7D;}.elementor-section.elementor-section-boxed > .elementor-container{max-width:1140px;}.e-con{--container-max-width:1140px;}.elementor-widget:not(:last-child){--kit-widget-spacing:20px;}.elementor-element{--widgets-spacing:20px 20px;--widgets-spacing-row:20px;--widgets-spacing-column:20px;}{}h1.entry-title{display:var(--page-title-display);}.site-header .site-branding{flex-direction:column;align-items:stretch;}.site-header{padding-inline-end:0px;padding-inline-start:0px;}.site-footer .site-branding{flex-direction:column;align-items:stretch;}@media(max-width:1024px){.elementor-section.elementor-section-boxed > .elementor-container{max-width:1024px;}.e-con{--container-max-width:1024px;}}@media(max-width:767px){.elementor-section.elementor-section-boxed > .elementor-container{max-width:767px;}.e-con{--container-max-width:767px;}}
/* Start custom CSS *//* ═══════════════════════════════════════════════════════════════════
   ░░ OLITAZ KÉFIR · v2 · ESTÉTICA OLIPOP × POPPI ░░
   ═══════════════════════════════════════════════════════════════════ */
:root {
  /* Neutros — paleta Olipop cream cálido */
  --kf-cream:        #F5EFE3;   /* cream principal, ligeramente más amarillo */
  --kf-cream-soft:   #FAF6EC;
  --kf-cream-deep:   #EDE2CC;
  --kf-peach:        #F4DAB8;   /* peachy warm cream */
  --kf-sand:         #D9C8A8;
  --kf-white:        #FFFFFF;
  --kf-ink:          #2A1A0E;   /* casi negro cálido */
  --kf-ink-soft:     #5C4A3E;
  --kf-line:         rgba(42, 26, 14, 0.14);

  /* Cobre */
  --kf-copper:       #B87333;
  --kf-copper-deep:  #8E5524;
  --kf-copper-soft:  #D4A574;

  /* Colores por SKU (más saturados para bloques tipo Poppi) */
  --kf-wake:         #3D6B3A;
  --kf-wake-deep:    #2A4D27;
  --kf-wake-tint:    #C8D9C6;
  --kf-move:         #D26331;
  --kf-move-deep:    #A04A1F;
  --kf-move-tint:    #F5C9A8;
  --kf-social:       #A02334;
  --kf-social-deep:  #7A1623;
  --kf-social-tint:  #E3B5BA;
  --kf-rest:         #C4A0A8;
  --kf-rest-deep:    #8C6C73;
  --kf-rest-tint:    #EBDADD;

  /* Tipografía */
  --kf-font-display: 'Fraunces', 'Recoleta', Georgia, serif;
  --kf-font-script:  'Pacifico', cursive;
  --kf-font-body:    'DM Sans', 'Inter', -apple-system, sans-serif;

  /* Layout */
  --kf-container:    1240px;
  --kf-gutter:       clamp(1.25rem, 4vw, 2.5rem);

  /* Radios */
  --kf-radius-sm:    8px;
  --kf-radius:       16px;
  --kf-radius-lg:    28px;
}

/* ═══════════════════════════════════════════════════════════════════
   RESET
   ═══════════════════════════════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  background: var(--kf-cream);
  color: var(--kf-ink);
  font-family: var(--kf-font-body);
  font-weight: 400;
  font-size: 16px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}
img { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; border: none; background: none; color: inherit; }
ul { list-style: none; }
h1, h2, h3, h4, h5 { line-height: 1.05; }

/* ═══════════════════════════════════════════════════════════════════
   UTILIDADES + TIPOGRAFÍA
   ═══════════════════════════════════════════════════════════════════ */
.kf-container {
  max-width: var(--kf-container);
  margin-inline: auto;
  padding-inline: var(--kf-gutter);
}

.kf-display {
  font-family: var(--kf-font-display);
  font-weight: 600;
  font-variation-settings: "opsz" 144, "SOFT" 50;
  letter-spacing: -0.025em;
  line-height: 0.95;
}
.kf-script {
  font-family: var(--kf-font-script);
  font-weight: 400;
  line-height: 1;
}
.kf-italic {
  font-style: italic;
  font-variation-settings: "opsz" 144, "SOFT" 50;
}
.kf-eyebrow {
  display: inline-block;
  font-family: var(--kf-font-body);
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.22em;
  color: var(--kf-copper);
}

.kf-h1 {
  font-family: var(--kf-font-display);
  font-weight: 600;
  font-variation-settings: "opsz" 144, "SOFT" 50;
  font-size: clamp(2.75rem, 7.5vw, 6rem);
  letter-spacing: -0.035em;
  line-height: 0.95;
}
.kf-h2 {
  font-family: var(--kf-font-display);
  font-weight: 600;
  font-variation-settings: "opsz" 144, "SOFT" 50;
  font-size: clamp(2.25rem, 5vw, 4rem);
  letter-spacing: -0.03em;
  line-height: 1;
}
.kf-h3 {
  font-family: var(--kf-font-display);
  font-weight: 600;
  font-variation-settings: "opsz" 96, "SOFT" 50;
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  letter-spacing: -0.02em;
  line-height: 1.1;
}
.kf-lead {
  font-size: clamp(1.05rem, 1.5vw, 1.2rem);
  line-height: 1.6;
  color: var(--kf-ink-soft);
  max-width: 56ch;
}

/* Botones — pill estilo Poppi/Olipop */
.kf-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 1rem 1.75rem;
  font-family: var(--kf-font-body);
  font-weight: 600;
  font-size: 0.93rem;
  letter-spacing: 0.01em;
  border-radius: 999px;
  border: 2px solid transparent;
  transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease, color 0.18s ease;
  white-space: nowrap;
}
.kf-btn--ink { background: var(--kf-ink); color: var(--kf-cream); }
.kf-btn--ink:hover { transform: translateY(-2px); box-shadow: 0 10px 24px rgba(42,26,14,0.25); }
.kf-btn--copper { background: var(--kf-copper); color: var(--kf-white); }
.kf-btn--copper:hover { background: var(--kf-copper-deep); transform: translateY(-2px); }
.kf-btn--cream { background: var(--kf-cream); color: var(--kf-ink); }
.kf-btn--cream:hover { transform: translateY(-2px); box-shadow: 0 10px 24px rgba(0,0,0,0.18); }
.kf-btn--outline-ink {
  background: transparent; color: var(--kf-ink); border-color: var(--kf-ink);
}
.kf-btn--outline-ink:hover { background: var(--kf-ink); color: var(--kf-cream); }
.kf-btn--outline-cream {
  background: transparent; color: var(--kf-cream); border-color: var(--kf-cream);
}
.kf-btn--outline-cream:hover { background: var(--kf-cream); color: var(--kf-ink); }

/* Pill genérica para badges/feature pills */
.kf-pill {
  display: inline-flex; align-items: center; gap: 0.4rem;
  padding: 0.5rem 0.95rem;
  background: var(--kf-cream);
  border: 1.5px solid var(--kf-ink);
  border-radius: 999px;
  font-family: var(--kf-font-body);
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--kf-ink);
  letter-spacing: 0.01em;
}
.kf-pill__dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--kf-copper);
}

/* ═══════════════════════════════════════════════════════════════════
   DECORACIONES RETRO (squiggles, asteriscos, sunbursts)
   ═══════════════════════════════════════════════════════════════════ */
.kf-deco {
  position: absolute;
  pointer-events: none;
  opacity: 0.9;
}

@keyframes kf-spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
@keyframes kf-spin-slow { from { transform: rotate(0deg); } to { transform: rotate(-360deg); } }
@keyframes kf-float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-14px); }
}
@keyframes kf-marquee {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}
@media (prefers-reduced-motion: reduce) {
  .kf-spin, .kf-spin-slow, .kf-float, .kf-marquee__track { animation: none !important; }
}

/* ═══════════════════════════════════════════════════════════════════
   HEADER STICKY
   ═══════════════════════════════════════════════════════════════════ */
.kf-header {
  position: sticky; top: 0; z-index: 100;
  background: rgba(245, 239, 227, 0.85);
  backdrop-filter: blur(14px) saturate(1.1);
  -webkit-backdrop-filter: blur(14px) saturate(1.1);
  border-bottom: 1px solid transparent;
  transition: border-color 0.25s, background 0.25s;
}
.kf-header.is-scrolled {
  background: rgba(245, 239, 227, 0.96);
  border-bottom-color: var(--kf-line);
}
.kf-header__inner {
  display: flex; align-items: center; justify-content: space-between;
  padding-block: 0.95rem;
  gap: 1rem;
}
.kf-header__logo {
  font-family: var(--kf-font-script);
  font-size: 1.9rem;
  color: var(--kf-ink);
  line-height: 1;
  transform: translateY(-2px);
}
.kf-header__nav { display: flex; gap: 1.75rem; }
.kf-header__nav a {
  font-size: 0.88rem; font-weight: 500;
  color: var(--kf-ink-soft);
  transition: color 0.2s;
}
.kf-header__nav a:hover { color: var(--kf-copper); }
.kf-header__cta {
  display: inline-flex; align-items: center; gap: 0.4rem;
  padding: 0.5rem 1rem;
  background: var(--kf-ink); color: var(--kf-cream);
  border-radius: 999px;
  font-size: 0.82rem; font-weight: 600;
}
.kf-header__cta:hover { background: var(--kf-copper-deep); }
@media (max-width: 800px) {
  .kf-header__nav { display: none; }
}

/* ═══════════════════════════════════════════════════════════════════
   1 · HERO
   ═══════════════════════════════════════════════════════════════════ */
.kf-hero {
  background: var(--kf-cream);
  padding-block: clamp(2.5rem, 6vw, 4rem) clamp(3rem, 7vw, 5rem);
  position: relative;
  overflow: hidden;
  text-align: center;
}
.kf-hero__pill {
  display: inline-flex; align-items: center; gap: 0.5rem;
  padding: 0.5rem 1rem;
  background: var(--kf-peach);
  border: 1.5px solid var(--kf-ink);
  border-radius: 999px;
  font-size: 0.78rem; font-weight: 600;
  color: var(--kf-ink);
  margin-bottom: 1.5rem;
  letter-spacing: 0.04em;
}
.kf-hero__pill svg { color: var(--kf-copper); }
.kf-hero__title {
  font-family: var(--kf-font-display);
  font-weight: 600;
  font-variation-settings: "opsz" 144, "SOFT" 100;
  font-size: clamp(3rem, 9vw, 7rem);
  letter-spacing: -0.04em;
  line-height: 0.92;
  margin-bottom: 1.25rem;
  color: var(--kf-ink);
  max-width: 18ch;
  margin-inline: auto;
}
.kf-hero__title em {
  font-style: italic;
  color: var(--kf-copper);
  font-variation-settings: "opsz" 144, "SOFT" 100;
}
.kf-hero__sub {
  font-size: clamp(1.05rem, 1.6vw, 1.25rem);
  color: var(--kf-ink-soft);
  max-width: 48ch;
  margin: 0 auto 2.5rem;
  line-height: 1.55;
}
.kf-hero__cta-row {
  display: flex; gap: 0.85rem; justify-content: center; flex-wrap: wrap;
  margin-bottom: 4rem;
}
.kf-hero__bottles {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(0.5rem, 2vw, 1.5rem);
  align-items: end;
  max-width: 1100px;
  margin-inline: auto;
  position: relative;
}
.kf-hero__bottle {
  position: relative;
  text-align: center;
}
.kf-hero__bottle img {
  width: 100%;
  max-width: 240px;
  margin-inline: auto;
  filter: drop-shadow(0 24px 32px color-mix(in srgb, var(--sku) 30%, transparent));
  animation: kf-float 6s ease-in-out infinite;
  position: relative;
  z-index: 2;
}
.kf-hero__bottle:nth-child(1) img { transform: rotate(-3deg); animation-delay: 0s; }
.kf-hero__bottle:nth-child(2) img { transform: rotate(2deg); animation-delay: 0.7s; }
.kf-hero__bottle:nth-child(3) img { transform: rotate(-2deg); animation-delay: 1.4s; }
.kf-hero__bottle:nth-child(4) img { transform: rotate(3deg); animation-delay: 2.1s; }

.kf-hero__bottle-bg {
  position: absolute;
  inset: 10% 5% 5% 5%;
  background: var(--sku);
  border-radius: 50%;
  filter: blur(40px);
  opacity: 0.45;
  z-index: 1;
}
.kf-hero__bottle-label {
  display: block;
  margin-top: 1.25rem;
  font-family: var(--kf-font-display);
  font-weight: 700;
  font-size: clamp(1rem, 1.6vw, 1.35rem);
  letter-spacing: 0.06em;
  color: var(--sku);
  text-transform: uppercase;
  position: relative;
  z-index: 3;
}
.kf-hero__bottle-moment {
  display: block;
  margin-top: 0.15rem;
  font-size: 0.72rem;
  color: var(--kf-ink-soft);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 500;
}

/* Decoración retro del hero */
.kf-hero__star-1 { top: 8%; left: 4%; width: 60px; animation: kf-spin 20s linear infinite; }
.kf-hero__star-2 { top: 14%; right: 6%; width: 48px; animation: kf-spin-slow 24s linear infinite; }
.kf-hero__sun-1 { bottom: 18%; left: 2%; width: 80px; animation: kf-spin-slow 40s linear infinite; }
.kf-hero__squiggle-1 { top: 35%; right: 2%; width: 120px; opacity: 0.5; }
.kf-hero__squiggle-2 { bottom: 8%; right: 4%; width: 100px; opacity: 0.5; }
.kf-hero__dot-1 { top: 22%; left: 9%; width: 14px; height: 14px; background: var(--kf-copper); border-radius: 50%; }
.kf-hero__dot-2 { bottom: 28%; right: 9%; width: 10px; height: 10px; background: var(--kf-wake); border-radius: 50%; }

@media (max-width: 720px) {
  .kf-hero__bottles { grid-template-columns: repeat(2, 1fr); gap: 1.5rem; }
  .kf-hero__bottle img { max-width: 160px; }
  .kf-hero__star-1, .kf-hero__star-2, .kf-hero__sun-1 { display: none; }
}

/* ═══════════════════════════════════════════════════════════════════
   2 · MARQUEE
   ═══════════════════════════════════════════════════════════════════ */
.kf-marquee {
  background: var(--kf-ink);
  color: var(--kf-cream);
  padding-block: 1.1rem;
  overflow: hidden;
  border-top: 2px solid var(--kf-copper);
  border-bottom: 2px solid var(--kf-copper);
}
.kf-marquee__track {
  display: flex;
  gap: 2.5rem;
  white-space: nowrap;
  animation: kf-marquee 30s linear infinite;
  width: max-content;
}
.kf-marquee__item {
  font-family: var(--kf-font-display);
  font-variation-settings: "opsz" 96, "SOFT" 30;
  font-weight: 600;
  font-style: italic;
  font-size: clamp(1.1rem, 1.6vw, 1.35rem);
  letter-spacing: 0.02em;
  display: flex; align-items: center; gap: 2.5rem;
}
.kf-marquee__sep {
  color: var(--kf-copper);
  font-style: normal;
  font-size: 1.4rem;
}

/* ═══════════════════════════════════════════════════════════════════
   3-6 · SECCIONES SKU (bloques de color tipo Poppi)
   ═══════════════════════════════════════════════════════════════════ */
.kf-sku-block {
  background: var(--sku);
  color: var(--kf-cream);
  padding-block: clamp(4rem, 9vw, 7rem);
  position: relative;
  overflow: hidden;
}
.kf-sku-block--wake   { --sku: var(--kf-wake);   --sku-deep: var(--kf-wake-deep);   --sku-tint: var(--kf-wake-tint); }
.kf-sku-block--move   { --sku: var(--kf-move);   --sku-deep: var(--kf-move-deep);   --sku-tint: var(--kf-move-tint); }
.kf-sku-block--social { --sku: var(--kf-social); --sku-deep: var(--kf-social-deep); --sku-tint: var(--kf-social-tint); }
.kf-sku-block--rest   { --sku: var(--kf-rest);   --sku-deep: var(--kf-rest-deep);   --sku-tint: var(--kf-rest-tint); color: var(--kf-ink); }

.kf-sku-block__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
  position: relative;
  z-index: 2;
}
.kf-sku-block--alt .kf-sku-block__inner { grid-template-columns: 1fr 1fr; }
.kf-sku-block--alt .kf-sku-block__media { order: 2; }
.kf-sku-block--alt .kf-sku-block__text { order: 1; }

/* Tipografía dentro de bloque SKU */
.kf-sku-block__num {
  font-family: var(--kf-font-display);
  font-variation-settings: "opsz" 144, "SOFT" 100;
  font-size: clamp(2.5rem, 5vw, 4rem);
  font-weight: 700;
  color: var(--sku-tint);
  opacity: 0.5;
  line-height: 1;
  display: inline-block;
  margin-bottom: 0.5rem;
}
.kf-sku-block__moment {
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--sku-tint);
  margin-bottom: 1rem;
}
.kf-sku-block__name {
  font-family: var(--kf-font-display);
  font-variation-settings: "opsz" 144, "SOFT" 100;
  font-weight: 700;
  font-size: clamp(4rem, 12vw, 9rem);
  letter-spacing: -0.04em;
  line-height: 0.85;
  margin-bottom: 0.75rem;
}
.kf-sku-block--rest .kf-sku-block__num,
.kf-sku-block--rest .kf-sku-block__moment { color: var(--kf-rest-deep); opacity: 0.7; }
.kf-sku-block__tagline {
  font-family: var(--kf-font-script);
  font-size: clamp(1.5rem, 2.5vw, 2.1rem);
  margin-bottom: 1.5rem;
  color: inherit;
}
.kf-sku-block__desc {
  font-size: 1.05rem;
  line-height: 1.65;
  max-width: 42ch;
  margin-bottom: 1.75rem;
  opacity: 0.92;
}
.kf-sku-block__ingredients {
  display: flex; flex-wrap: wrap; gap: 0.5rem;
  margin-bottom: 2rem;
}
.kf-sku-block__ingredient {
  padding: 0.55rem 1rem;
  border: 1.5px solid currentColor;
  border-radius: 999px;
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.02em;
}
.kf-sku-block__for {
  font-style: italic;
  font-family: var(--kf-font-display);
  font-variation-settings: "opsz" 96, "SOFT" 50;
  font-size: 0.95rem;
  opacity: 0.85;
  margin-bottom: 2rem;
  display: block;
}
.kf-sku-block__cta {
  display: inline-flex; align-items: center; gap: 0.5rem;
  padding: 1rem 1.85rem;
  background: var(--kf-cream); color: var(--sku-deep);
  border-radius: 999px;
  font-weight: 700; font-size: 0.95rem;
  transition: transform 0.2s, box-shadow 0.2s;
}
.kf-sku-block__cta:hover { transform: translateY(-2px); box-shadow: 0 14px 28px rgba(0,0,0,0.18); }
.kf-sku-block--rest .kf-sku-block__cta { background: var(--kf-ink); color: var(--kf-cream); }
.kf-sku-block--rest .kf-sku-block__cta:hover { background: var(--kf-rest-deep); }

.kf-sku-block__media {
  position: relative;
  text-align: center;
}
.kf-sku-block__bottle {
  max-width: 380px;
  margin-inline: auto;
  filter: drop-shadow(0 32px 48px rgba(0,0,0,0.3));
  animation: kf-float 6s ease-in-out infinite;
  position: relative;
  z-index: 2;
}
.kf-sku-block__halo {
  position: absolute;
  inset: 10% 15% 10% 15%;
  background: var(--sku-tint);
  border-radius: 50%;
  filter: blur(60px);
  opacity: 0.4;
  z-index: 1;
}

/* Decoración retro dentro de bloques SKU */
.kf-sku-block__deco-1 {
  position: absolute; top: 5%; right: 6%;
  width: 70px; height: 70px; opacity: 0.4;
  color: var(--sku-tint);
  animation: kf-spin 30s linear infinite;
}
.kf-sku-block__deco-2 {
  position: absolute; bottom: 8%; left: 4%;
  width: 50px; opacity: 0.45;
  color: var(--sku-tint);
}
.kf-sku-block__deco-3 {
  position: absolute; top: 30%; left: 50%;
  width: 30px; opacity: 0.35;
  color: var(--sku-tint);
}
.kf-sku-block--rest .kf-sku-block__deco-1,
.kf-sku-block--rest .kf-sku-block__deco-2,
.kf-sku-block--rest .kf-sku-block__deco-3 { color: var(--kf-rest-deep); opacity: 0.4; }

/* Etiqueta nutricional flotante (estilo Olipop) */
.kf-sku-block__stats {
  position: absolute;
  background: var(--kf-cream);
  color: var(--kf-ink);
  padding: 1.25rem 1.5rem;
  border-radius: var(--kf-radius);
  border: 2px solid var(--kf-ink);
  box-shadow: 6px 6px 0 var(--sku-deep);
  font-family: var(--kf-font-body);
  z-index: 4;
  transform: rotate(-3deg);
}
.kf-sku-block--alt .kf-sku-block__stats { transform: rotate(3deg); }
.kf-sku-block__stats--tr { top: 8%; right: 4%; }
.kf-sku-block__stats--bl { bottom: 12%; left: 4%; }
.kf-sku-block__stats strong {
  display: block;
  font-family: var(--kf-font-display);
  font-variation-settings: "opsz" 96, "SOFT" 50;
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--sku-deep);
  line-height: 1;
}
.kf-sku-block__stats span {
  font-size: 0.72rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--kf-ink-soft);
  font-weight: 600;
}

@media (max-width: 880px) {
  .kf-sku-block__inner,
  .kf-sku-block--alt .kf-sku-block__inner { grid-template-columns: 1fr; text-align: center; }
  .kf-sku-block--alt .kf-sku-block__media { order: 1; }
  .kf-sku-block--alt .kf-sku-block__text { order: 2; }
  .kf-sku-block__bottle { max-width: 240px; }
  .kf-sku-block__desc { margin-inline: auto; }
  .kf-sku-block__ingredients { justify-content: center; }
  .kf-sku-block__stats { display: none; }
}

/* ═══════════════════════════════════════════════════════════════════
   7 · CONCEPTO (intro entre bloques)
   ═══════════════════════════════════════════════════════════════════ */
.kf-concepto {
  background: var(--kf-cream);
  padding-block: clamp(4rem, 9vw, 7rem);
  position: relative;
  overflow: hidden;
}
.kf-concepto__head {
  text-align: center;
  max-width: 720px;
  margin: 0 auto 3.5rem;
  position: relative;
  z-index: 2;
}
.kf-concepto__title {
  font-family: var(--kf-font-display);
  font-variation-settings: "opsz" 144, "SOFT" 100;
  font-size: clamp(2.5rem, 6vw, 4.5rem);
  font-weight: 600;
  line-height: 0.95;
  letter-spacing: -0.03em;
  margin-bottom: 1.25rem;
}
.kf-concepto__title em {
  font-style: italic;
  color: var(--kf-copper);
}
.kf-concepto__lead {
  font-size: 1.15rem;
  line-height: 1.65;
  color: var(--kf-ink-soft);
  max-width: 56ch;
  margin-inline: auto;
}
.kf-concepto__features {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  max-width: 960px;
  margin: 0 auto;
}
.kf-feature {
  background: var(--kf-cream-soft);
  border: 2px solid var(--kf-ink);
  border-radius: var(--kf-radius);
  padding: 2rem 1.75rem;
  text-align: center;
  position: relative;
  transition: transform 0.25s, box-shadow 0.25s;
}
.kf-feature:hover {
  transform: translateY(-4px);
  box-shadow: 6px 6px 0 var(--kf-copper);
}
.kf-feature__icon {
  width: 48px; height: 48px;
  border-radius: 50%;
  background: var(--kf-peach);
  border: 1.5px solid var(--kf-ink);
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 1rem;
  color: var(--kf-copper-deep);
}
.kf-feature__big {
  font-family: var(--kf-font-display);
  font-variation-settings: "opsz" 144, "SOFT" 100;
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--kf-ink);
  line-height: 1;
  margin-bottom: 0.25rem;
}
.kf-feature__big-sub {
  font-size: 0.78rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--kf-copper);
  font-weight: 600;
  margin-bottom: 1rem;
}
.kf-feature__title {
  font-family: var(--kf-font-display);
  font-variation-settings: "opsz" 96, "SOFT" 50;
  font-size: 1.15rem;
  font-weight: 600;
  margin-bottom: 0.5rem;
}
.kf-feature__txt {
  font-size: 0.9rem;
  color: var(--kf-ink-soft);
  line-height: 1.6;
}
@media (max-width: 880px) {
  .kf-concepto__features { grid-template-columns: 1fr; }
}

.kf-concepto__deco-1 { top: 5%; left: 4%; width: 80px; opacity: 0.4; color: var(--kf-copper); animation: kf-spin 30s linear infinite; }
.kf-concepto__deco-2 { bottom: 8%; right: 5%; width: 60px; opacity: 0.4; color: var(--kf-copper); animation: kf-spin-slow 40s linear infinite; }

/* ═══════════════════════════════════════════════════════════════════
   8 · POR QUÉ OLITAZ (4 pilares)
   ═══════════════════════════════════════════════════════════════════ */
.kf-porque {
  background: var(--kf-peach);
  padding-block: clamp(4rem, 9vw, 7rem);
  position: relative;
  overflow: hidden;
}
.kf-porque__head {
  text-align: center;
  max-width: 700px;
  margin: 0 auto 4rem;
  position: relative;
  z-index: 2;
}
.kf-porque__title {
  font-family: var(--kf-font-display);
  font-variation-settings: "opsz" 144, "SOFT" 100;
  font-size: clamp(2.25rem, 5vw, 3.75rem);
  font-weight: 600;
  letter-spacing: -0.03em;
  line-height: 1;
}
.kf-porque__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
}
.kf-pilar {
  background: var(--kf-cream-soft);
  border: 2px solid var(--kf-ink);
  border-radius: var(--kf-radius);
  padding: 1.75rem;
  position: relative;
  transition: transform 0.25s, box-shadow 0.25s;
}
.kf-pilar:hover {
  transform: translateY(-4px);
  box-shadow: 6px 6px 0 var(--kf-ink);
}
.kf-pilar__icon {
  width: 52px; height: 52px;
  background: var(--kf-copper);
  color: var(--kf-cream);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 1.25rem;
  border: 2px solid var(--kf-ink);
}
.kf-pilar__num {
  position: absolute;
  top: 1rem; right: 1.25rem;
  font-family: var(--kf-font-display);
  font-weight: 700;
  font-size: 1.4rem;
  color: var(--kf-copper);
  opacity: 0.5;
}
.kf-pilar__title {
  font-family: var(--kf-font-display);
  font-variation-settings: "opsz" 96, "SOFT" 50;
  font-size: 1.15rem;
  font-weight: 600;
  letter-spacing: -0.01em;
  margin-bottom: 0.5rem;
}
.kf-pilar__txt {
  font-size: 0.88rem;
  color: var(--kf-ink-soft);
  line-height: 1.55;
}
@media (max-width: 900px) { .kf-porque__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .kf-porque__grid { grid-template-columns: 1fr; } }

/* ═══════════════════════════════════════════════════════════════════
   9 · CIENCIA
   ═══════════════════════════════════════════════════════════════════ */
.kf-ciencia {
  background: var(--kf-cream-deep);
  padding-block: clamp(4rem, 9vw, 7rem);
  position: relative;
  overflow: hidden;
}
.kf-ciencia__head {
  text-align: center;
  max-width: 720px;
  margin: 0 auto 3rem;
}
.kf-ciencia__title {
  font-family: var(--kf-font-display);
  font-variation-settings: "opsz" 144, "SOFT" 100;
  font-size: clamp(2.5rem, 5.5vw, 4rem);
  font-weight: 600;
  letter-spacing: -0.03em;
  line-height: 0.98;
  margin-bottom: 1.25rem;
}
.kf-ciencia__title em { font-style: italic; color: var(--kf-copper); }
.kf-ciencia__claims {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  margin-top: 3rem;
}
.kf-claim {
  background: var(--kf-cream);
  border: 2px solid var(--kf-ink);
  border-radius: var(--kf-radius);
  padding: 1.75rem;
  position: relative;
}
.kf-claim__nutrient {
  font-family: var(--kf-font-display);
  font-variation-settings: "opsz" 96, "SOFT" 50;
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--kf-copper-deep);
  margin-bottom: 0.85rem;
}
.kf-claim__text {
  font-family: var(--kf-font-body);
  font-size: 0.95rem;
  color: var(--kf-ink);
  line-height: 1.55;
  margin-bottom: 1rem;
}
.kf-claim__source {
  font-size: 0.7rem;
  color: var(--kf-ink-soft);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 600;
}
.kf-ciencia__note {
  font-size: 0.85rem;
  color: var(--kf-ink-soft);
  text-align: center;
  margin-top: 2.5rem;
  max-width: 600px;
  margin-inline: auto;
  font-style: italic;
}
@media (max-width: 800px) {
  .kf-ciencia__claims { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════════════════════
   10 · DÓNDE ENCONTRARNOS / CTA
   ═══════════════════════════════════════════════════════════════════ */
.kf-cta-section {
  background: var(--kf-copper);
  color: var(--kf-cream);
  padding-block: clamp(4rem, 9vw, 7rem);
  text-align: center;
  position: relative;
  overflow: hidden;
}
.kf-cta-section__title {
  font-family: var(--kf-font-display);
  font-variation-settings: "opsz" 144, "SOFT" 100;
  font-size: clamp(2.5rem, 7vw, 5rem);
  font-weight: 600;
  letter-spacing: -0.03em;
  line-height: 0.95;
  margin-bottom: 1.25rem;
  position: relative;
  z-index: 2;
}
.kf-cta-section__title em { font-style: italic; color: var(--kf-cream); opacity: 0.85; }
.kf-cta-section__sub {
  font-size: 1.15rem;
  margin-bottom: 2.5rem;
  max-width: 50ch;
  margin-inline: auto;
  opacity: 0.9;
  position: relative;
  z-index: 2;
}
.kf-cta-section__row {
  display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap;
  position: relative; z-index: 2;
}
.kf-cta-section__cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  max-width: 900px;
  margin: 3rem auto 0;
  position: relative; z-index: 2;
}
.kf-where-card {
  background: var(--kf-cream);
  color: var(--kf-ink);
  border-radius: var(--kf-radius);
  padding: 2rem;
  text-align: left;
  border: 2px solid var(--kf-ink);
}
.kf-where-card__type {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--kf-copper-deep);
  margin-bottom: 0.5rem;
}
.kf-where-card__title {
  font-family: var(--kf-font-display);
  font-variation-settings: "opsz" 96, "SOFT" 50;
  font-size: 1.4rem;
  font-weight: 600;
  margin-bottom: 0.75rem;
  letter-spacing: -0.01em;
}
.kf-where-card__txt {
  font-size: 0.92rem;
  color: var(--kf-ink-soft);
  margin-bottom: 1.25rem;
  line-height: 1.55;
}
.kf-where-card__highlight {
  display: inline-block;
  padding: 0.35rem 0.8rem;
  background: var(--kf-peach);
  border: 1px solid var(--kf-copper-deep);
  border-radius: 999px;
  font-size: 0.76rem;
  font-weight: 700;
  color: var(--kf-copper-deep);
}
.kf-cta-section__deco-1 { top: 8%; left: 4%; width: 80px; opacity: 0.3; color: var(--kf-cream); animation: kf-spin 30s linear infinite; }
.kf-cta-section__deco-2 { bottom: 8%; right: 4%; width: 70px; opacity: 0.3; color: var(--kf-cream); animation: kf-spin-slow 40s linear infinite; }
@media (max-width: 800px) {
  .kf-cta-section__cards { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════════════════════
   11 · FOOTER
   ═══════════════════════════════════════════════════════════════════ */
.kf-footer {
  background: var(--kf-ink);
  color: var(--kf-cream);
  padding-block: 4rem 2rem;
}
.kf-footer__top {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 3rem;
  padding-bottom: 3rem;
  border-bottom: 1px solid rgba(245,239,227,0.15);
}
.kf-footer__brand .kf-footer__logo {
  font-family: var(--kf-font-script);
  font-size: 2.75rem;
  color: var(--kf-cream);
  line-height: 1;
  margin-bottom: 0.75rem;
}
.kf-footer__brand p {
  color: var(--kf-copper-soft);
  font-style: italic;
  font-family: var(--kf-font-display);
  font-variation-settings: "opsz" 96, "SOFT" 50;
  font-size: 1.1rem;
  margin-bottom: 1rem;
}
.kf-footer__brand .kf-footer__note {
  font-size: 0.82rem;
  color: rgba(245,239,227,0.55);
  font-style: normal;
  font-family: var(--kf-font-body);
  line-height: 1.55;
}
.kf-footer__col h4 {
  font-family: var(--kf-font-body);
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--kf-copper-soft);
  margin-bottom: 1.25rem;
}
.kf-footer__col ul li { margin-bottom: 0.65rem; }
.kf-footer__col a {
  font-size: 0.9rem;
  color: rgba(245,239,227,0.85);
  transition: color 0.2s;
}
.kf-footer__col a:hover { color: var(--kf-copper-soft); }
.kf-footer__social { display: flex; gap: 0.75rem; }
.kf-footer__social a {
  width: 38px; height: 38px;
  border-radius: 50%;
  border: 1px solid rgba(245,239,227,0.25);
  display: flex; align-items: center; justify-content: center;
  transition: all 0.2s;
}
.kf-footer__social a:hover { border-color: var(--kf-copper); background: var(--kf-copper); color: var(--kf-cream); }
.kf-footer__bottom {
  padding-top: 1.75rem;
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: 1rem;
  font-size: 0.78rem;
  color: rgba(245,239,227,0.5);
}
@media (max-width: 800px) {
  .kf-footer__top { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 500px) {
  .kf-footer__top { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════════════════════
   FADE-IN SCROLL
   ═══════════════════════════════════════════════════════════════════ */
/* Default: todo visible (sin JS, sin animación pero contenido legible) */
.kf-fade-in { opacity: 1; transform: none; }
/* Solo si el JS está cargado y ha añadido .kf-js al <html>, ocultamos
   y activamos el fade-in al scrollear */
.kf-js .kf-fade-in {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}
.kf-js .kf-fade-in.is-visible { opacity: 1; transform: translateY(0); }
@media (prefers-reduced-motion: reduce) {
  .kf-js .kf-fade-in { opacity: 1; transform: none; transition: none; }
}

/* ═══════════════════════════════════════════════════════════════════
   ░░ PÁGINA DE PRODUCTO INDIVIDUAL (kp-* · kéfir producto) ░░
   Themed por SKU vía --sku (variable que se hereda del bloque o se
   define inline: style="--sku:var(--kf-wake)")
   ═══════════════════════════════════════════════════════════════════ */

/* Hero producto */
.kp-hero {
  background: var(--kf-cream);
  padding-block: clamp(3rem, 7vw, 6rem);
  position: relative;
  overflow: hidden;
}
.kp-hero__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
}
.kp-hero__media { position: relative; text-align: center; }
.kp-hero__bottle {
  max-width: 400px;
  margin-inline: auto;
  filter: drop-shadow(0 32px 48px color-mix(in srgb, var(--sku) 40%, transparent));
  animation: kf-float 6s ease-in-out infinite;
  position: relative; z-index: 2;
}
.kp-hero__halo {
  position: absolute;
  inset: 5% 10%;
  background: var(--sku);
  border-radius: 50%;
  filter: blur(60px);
  opacity: 0.28;
  z-index: 0;
}
.kp-hero__deco {
  position: absolute; pointer-events: none;
  color: var(--sku); opacity: 0.45;
}
.kp-hero__deco--1 { top: 8%; right: 6%; width: 70px; animation: kf-spin 28s linear infinite; }
.kp-hero__deco--2 { bottom: 10%; left: 8%; width: 50px; }
.kp-hero__moment {
  display: inline-block;
  padding: 0.5rem 1rem;
  background: var(--kf-peach);
  border: 1.5px solid var(--kf-ink);
  border-radius: 999px;
  font-size: 0.74rem; font-weight: 700;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--kf-ink);
  margin-bottom: 1.25rem;
}
.kp-hero__name {
  font-family: var(--kf-font-display);
  font-variation-settings: "opsz" 144, "SOFT" 100;
  font-size: clamp(4rem, 11vw, 8rem);
  font-weight: 700;
  letter-spacing: -0.045em;
  line-height: 0.85;
  color: var(--sku);
  margin-bottom: 0.65rem;
}
.kp-hero__tagline {
  font-family: var(--kf-font-script);
  font-size: clamp(1.5rem, 2.8vw, 2.25rem);
  margin-bottom: 1.25rem;
  color: var(--kf-ink);
  line-height: 1.1;
}
.kp-hero__desc {
  font-size: 1.05rem;
  line-height: 1.65;
  color: var(--kf-ink-soft);
  margin-bottom: 1.75rem;
  max-width: 46ch;
}
.kp-hero__badges {
  display: flex; flex-wrap: wrap; gap: 0.5rem;
  margin-bottom: 1.75rem;
}
.kp-hero__badge {
  padding: 0.5rem 1rem;
  border: 1.5px solid var(--kf-ink);
  border-radius: 999px;
  font-size: 0.78rem; font-weight: 600;
  color: var(--kf-ink);
  background: var(--kf-cream-soft);
}
.kp-hero__price-row {
  display: flex; align-items: baseline; gap: 1rem;
  margin-bottom: 1.5rem;
}
.kp-hero__price {
  font-family: var(--kf-font-display);
  font-variation-settings: "opsz" 144, "SOFT" 100;
  font-size: 2.5rem; font-weight: 700;
  color: var(--kf-ink); line-height: 1;
}
.kp-hero__price-unit {
  font-size: 0.85rem; color: var(--kf-ink-soft);
}
.kp-hero__price-pack {
  font-size: 0.85rem; color: var(--kf-copper-deep); font-weight: 600;
}
.kp-hero__cta-row { display: flex; gap: 0.75rem; flex-wrap: wrap; }
.kp-hero__atc {
  display: inline-flex; align-items: center; gap: 0.5rem;
  padding: 1rem 1.85rem;
  background: var(--sku); color: var(--kf-cream);
  border-radius: 999px;
  font-weight: 700; font-size: 0.95rem;
  transition: transform 0.2s, box-shadow 0.2s, filter 0.2s;
}
.kp-hero__atc:hover { transform: translateY(-2px); filter: brightness(0.92); box-shadow: 0 14px 28px color-mix(in srgb, var(--sku) 35%, transparent); }
.kp-hero__sub-link {
  display: inline-flex; align-items: center; gap: 0.5rem;
  padding: 1rem 1.5rem;
  border: 2px solid var(--kf-ink);
  border-radius: 999px;
  font-weight: 600; font-size: 0.9rem;
  color: var(--kf-ink);
}
.kp-hero__sub-link:hover { background: var(--kf-ink); color: var(--kf-cream); }
@media (max-width: 880px) {
  .kp-hero__inner { grid-template-columns: 1fr; text-align: center; }
  .kp-hero__bottle { max-width: 260px; }
  .kp-hero__desc { margin-inline: auto; }
  .kp-hero__badges, .kp-hero__cta-row, .kp-hero__price-row { justify-content: center; }
}

/* Por qué este momento — storytelling */
.kp-why {
  background: var(--kf-cream-soft);
  padding-block: clamp(4rem, 9vw, 7rem);
  position: relative; overflow: hidden;
}
.kp-why__inner {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
}
.kp-why__visual {
  position: relative;
  aspect-ratio: 1;
  background: var(--sku);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  max-width: 380px;
  margin-inline: auto;
  border: 3px solid var(--kf-ink);
  box-shadow: 12px 12px 0 var(--kf-ink);
}
.kp-why__visual svg { width: 55%; height: 55%; color: var(--kf-cream); }
.kp-why__eyebrow {
  font-size: 0.72rem; font-weight: 700;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--kf-copper); margin-bottom: 1rem;
  display: inline-block;
}
.kp-why__title {
  font-family: var(--kf-font-display);
  font-variation-settings: "opsz" 144, "SOFT" 100;
  font-size: clamp(2.25rem, 5vw, 3.75rem);
  font-weight: 600;
  letter-spacing: -0.03em; line-height: 1;
  margin-bottom: 1.5rem;
}
.kp-why__title em { font-style: italic; color: var(--sku); }
.kp-why__body p {
  font-size: 1.05rem; color: var(--kf-ink-soft);
  margin-bottom: 1rem; line-height: 1.65;
}
.kp-why__body strong { color: var(--kf-ink); font-weight: 600; }
.kp-why__stats {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 1rem; margin-top: 2rem;
}
.kp-stat {
  text-align: center;
  padding: 1.25rem 0.75rem;
  background: var(--kf-cream);
  border: 2px solid var(--kf-ink);
  border-radius: var(--kf-radius);
}
.kp-stat__num {
  font-family: var(--kf-font-display);
  font-variation-settings: "opsz" 96, "SOFT" 100;
  font-size: 1.9rem; font-weight: 700;
  color: var(--sku); line-height: 1;
  margin-bottom: 0.35rem;
}
.kp-stat__txt {
  font-size: 0.72rem;
  letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--kf-ink-soft); font-weight: 600;
  line-height: 1.3;
}
@media (max-width: 880px) {
  .kp-why__inner { grid-template-columns: 1fr; text-align: center; }
  .kp-why__visual { max-width: 240px; box-shadow: 8px 8px 0 var(--kf-ink); }
}

/* Ingrediente protagonista */
.kp-ingredient {
  background: var(--sku);
  color: var(--kf-cream);
  padding-block: clamp(4rem, 9vw, 7rem);
  position: relative; overflow: hidden;
}
.kp-ingredient--light { background: var(--kf-peach); color: var(--kf-ink); }
.kp-ingredient__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
  position: relative; z-index: 2;
}
.kp-ingredient__illust { text-align: center; position: relative; }
.kp-ingredient__illust svg { max-width: 360px; margin-inline: auto; width: 100%; height: auto; }
.kp-ingredient__eyebrow {
  font-size: 0.72rem; font-weight: 700;
  letter-spacing: 0.22em; text-transform: uppercase;
  opacity: 0.85; margin-bottom: 1rem;
  display: inline-block;
}
.kp-ingredient__name {
  font-family: var(--kf-font-display);
  font-variation-settings: "opsz" 144, "SOFT" 100;
  font-size: clamp(2.5rem, 5.5vw, 4rem);
  font-weight: 600;
  letter-spacing: -0.025em; line-height: 1;
  margin-bottom: 1.25rem;
}
.kp-ingredient__name em { font-style: italic; }
.kp-ingredient__lead {
  font-size: 1.1rem; line-height: 1.65;
  margin-bottom: 2rem; opacity: 0.92;
  max-width: 50ch;
}
.kp-ingredient__steps { list-style: none; padding: 0; margin: 0; }
.kp-ingredient__step {
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: 1rem;
  padding: 1.1rem 0;
  border-top: 1px solid color-mix(in srgb, currentColor 30%, transparent);
}
.kp-ingredient__step:last-child {
  border-bottom: 1px solid color-mix(in srgb, currentColor 30%, transparent);
}
.kp-ingredient__step-num {
  font-family: var(--kf-font-display);
  font-variation-settings: "opsz" 96, "SOFT" 100;
  font-size: 1.5rem; font-weight: 700;
  font-style: italic; line-height: 1;
}
.kp-ingredient__step h4 {
  font-family: var(--kf-font-display);
  font-variation-settings: "opsz" 96, "SOFT" 50;
  font-weight: 600; font-size: 1.05rem;
  margin-bottom: 0.35rem;
  letter-spacing: -0.01em;
}
.kp-ingredient__step p {
  font-size: 0.9rem; line-height: 1.55; opacity: 0.92;
}
@media (max-width: 880px) {
  .kp-ingredient__inner { grid-template-columns: 1fr; }
  .kp-ingredient__illust svg { max-width: 220px; }
}

/* Activos funcionales */
.kp-active {
  background: var(--kf-cream-deep);
  padding-block: clamp(4rem, 9vw, 7rem);
  position: relative; overflow: hidden;
}
.kp-active__head { text-align: center; max-width: 680px; margin: 0 auto 3rem; }
.kp-active__title {
  font-family: var(--kf-font-display);
  font-variation-settings: "opsz" 144, "SOFT" 100;
  font-size: clamp(2rem, 4.5vw, 3.25rem);
  font-weight: 600;
  letter-spacing: -0.03em; line-height: 1;
  margin-bottom: 1rem;
}
.kp-active__title em { font-style: italic; color: var(--sku); }
.kp-active__lead {
  font-size: 1.05rem; color: var(--kf-ink-soft);
  margin-top: 1rem; max-width: 56ch; margin-inline: auto;
}
.kp-active__grid {
  display: grid; grid-template-columns: repeat(2, 1fr);
  gap: 1.5rem;
}
.kp-active-card {
  background: var(--kf-cream);
  border: 2px solid var(--kf-ink);
  border-radius: var(--kf-radius);
  padding: 1.85rem;
  position: relative;
  transition: transform 0.2s, box-shadow 0.2s;
}
.kp-active-card:hover {
  transform: translateY(-3px);
  box-shadow: 6px 6px 0 var(--sku);
}
.kp-active-card__icon {
  width: 50px; height: 50px;
  background: var(--sku);
  color: var(--kf-cream);
  border-radius: 50%;
  border: 2px solid var(--kf-ink);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 1.25rem;
}
.kp-active-card__name {
  font-family: var(--kf-font-display);
  font-variation-settings: "opsz" 96, "SOFT" 50;
  font-size: 1.35rem; font-weight: 600;
  margin-bottom: 0.35rem;
  color: var(--kf-ink);
  letter-spacing: -0.01em;
}
.kp-active-card__dose {
  font-size: 0.76rem; font-weight: 700;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--sku); margin-bottom: 1rem;
}
.kp-active-card p {
  font-size: 0.92rem;
  color: var(--kf-ink-soft);
  line-height: 1.6;
}
.kp-active-card__claim {
  font-size: 0.78rem;
  color: var(--kf-ink-soft);
  font-style: italic;
  margin-top: 1rem;
  padding-top: 0.85rem;
  border-top: 1px dashed var(--kf-line);
}
@media (max-width: 720px) {
  .kp-active__grid { grid-template-columns: 1fr; }
}

/* Cómo se hace · fermentación */
.kp-ferment {
  background: var(--kf-cream);
  padding-block: clamp(4rem, 9vw, 7rem);
}
.kp-ferment__head { text-align: center; max-width: 700px; margin: 0 auto 4rem; }
.kp-ferment__title {
  font-family: var(--kf-font-display);
  font-variation-settings: "opsz" 144, "SOFT" 100;
  font-size: clamp(2rem, 4.5vw, 3.25rem);
  font-weight: 600;
  letter-spacing: -0.03em; line-height: 1;
  margin-bottom: 1.25rem;
}
.kp-ferment__title em { font-style: italic; color: var(--sku); }
.kp-ferment__steps {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 1.25rem;
}
.kp-ferment-step { text-align: center; position: relative; }
.kp-ferment-step__num {
  width: 64px; height: 64px;
  background: var(--sku); color: var(--kf-cream);
  border: 2px solid var(--kf-ink);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 1.25rem;
  font-family: var(--kf-font-display);
  font-variation-settings: "opsz" 96, "SOFT" 100;
  font-weight: 700; font-size: 1.5rem;
}
.kp-ferment-step h4 {
  font-family: var(--kf-font-display);
  font-variation-settings: "opsz" 96, "SOFT" 50;
  font-weight: 600; font-size: 1.1rem;
  margin-bottom: 0.5rem;
  letter-spacing: -0.01em;
}
.kp-ferment-step p {
  font-size: 0.9rem; color: var(--kf-ink-soft);
  line-height: 1.6;
}
@media (max-width: 800px) { .kp-ferment__steps { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 460px) { .kp-ferment__steps { grid-template-columns: 1fr; } }

/* Tu rutina */
.kp-routine {
  background: var(--kf-peach);
  padding-block: clamp(4rem, 9vw, 7rem);
}
.kp-routine__head { text-align: center; max-width: 680px; margin: 0 auto 3rem; }
.kp-routine__title {
  font-family: var(--kf-font-display);
  font-variation-settings: "opsz" 144, "SOFT" 100;
  font-size: clamp(2rem, 4.5vw, 3.25rem);
  font-weight: 600;
  letter-spacing: -0.03em; line-height: 1;
  margin-bottom: 1rem;
}
.kp-routine__title em { font-style: italic; color: var(--sku); }
.kp-routine__grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}
.kp-routine-card {
  background: var(--kf-cream);
  border: 2px solid var(--kf-ink);
  border-radius: var(--kf-radius);
  padding: 1.85rem;
  transition: transform 0.2s, box-shadow 0.2s;
}
.kp-routine-card:hover {
  transform: translateY(-3px);
  box-shadow: 6px 6px 0 var(--sku);
}
.kp-routine-card__time {
  font-family: var(--kf-font-display);
  font-variation-settings: "opsz" 96, "SOFT" 100;
  font-weight: 700; font-size: 1.85rem;
  color: var(--sku); line-height: 1;
}
.kp-routine-card__moment {
  font-size: 0.72rem;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--kf-ink-soft); font-weight: 700;
  margin-top: 0.35rem; margin-bottom: 0.85rem;
}
.kp-routine-card h4 {
  font-family: var(--kf-font-display);
  font-variation-settings: "opsz" 96, "SOFT" 50;
  font-weight: 600; font-size: 1.15rem;
  line-height: 1.2; margin-bottom: 0.5rem;
  letter-spacing: -0.01em;
}
.kp-routine-card p {
  font-size: 0.9rem; color: var(--kf-ink-soft); line-height: 1.55;
}
@media (max-width: 880px) { .kp-routine__grid { grid-template-columns: 1fr; } }

/* Nutricional */
.kp-nutri { background: var(--kf-cream); padding-block: clamp(4rem, 9vw, 7rem); }
.kp-nutri__inner {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: clamp(2rem, 5vw, 4rem);
  align-items: start;
}
.kp-nutri__title {
  font-family: var(--kf-font-display);
  font-variation-settings: "opsz" 144, "SOFT" 100;
  font-size: clamp(2rem, 4.5vw, 3.25rem);
  font-weight: 600;
  letter-spacing: -0.03em; line-height: 1;
  margin-bottom: 1.25rem;
}
.kp-nutri__title em { font-style: italic; color: var(--sku); }
.kp-nutri__lead {
  font-size: 1.02rem;
  color: var(--kf-ink-soft);
  margin-bottom: 1.5rem;
  line-height: 1.65;
}
.kp-nutri__list {
  margin-top: 1.5rem;
  font-size: 0.92rem;
  color: var(--kf-ink-soft);
  line-height: 1.7;
}
.kp-nutri__list dt {
  font-weight: 600; color: var(--kf-ink);
  margin-top: 0.65rem;
}
.kp-nutri__allergens {
  display: flex; flex-wrap: wrap; gap: 0.5rem;
  margin-top: 1.5rem;
}
.kp-nutri__allergen {
  padding: 0.5rem 0.9rem;
  background: var(--kf-cream-soft);
  border: 1.5px solid var(--kf-ink);
  border-radius: 999px;
  font-size: 0.78rem; font-weight: 600;
  color: var(--kf-ink);
}
.kp-nutri__table-wrap {
  background: var(--kf-cream-soft);
  border: 2px solid var(--kf-ink);
  border-radius: var(--kf-radius);
  overflow: hidden;
  box-shadow: 6px 6px 0 var(--sku);
}
.kp-nutri__table-header {
  background: var(--sku);
  color: var(--kf-cream);
  padding: 1.25rem 1.5rem;
}
.kp-nutri__table-header h4 {
  font-family: var(--kf-font-display);
  font-variation-settings: "opsz" 96, "SOFT" 50;
  font-weight: 600; font-size: 1.15rem;
  margin-bottom: 0.15rem;
}
.kp-nutri__table-header p {
  font-size: 0.85rem; opacity: 0.85;
}
.kp-nutri__table { width: 100%; border-collapse: collapse; }
.kp-nutri__table th,
.kp-nutri__table td {
  padding: 0.85rem 1.25rem;
  text-align: left;
  font-size: 0.9rem;
}
.kp-nutri__table tbody tr { border-top: 1px solid var(--kf-line); }
.kp-nutri__table tbody tr:first-child { border-top: none; }
.kp-nutri__table tbody th { font-weight: 500; color: var(--kf-ink); }
.kp-nutri__table tbody td { font-weight: 700; text-align: right; color: var(--kf-ink); }
.kp-nutri__table tbody tr.kp-nutri__row--main {
  background: color-mix(in srgb, var(--sku) 6%, transparent);
}
.kp-nutri__table-note {
  padding: 1rem 1.5rem;
  font-size: 0.78rem;
  color: var(--kf-ink-soft);
  font-style: italic;
}
@media (max-width: 880px) {
  .kp-nutri__inner { grid-template-columns: 1fr; }
  .kp-nutri__table-wrap { box-shadow: 4px 4px 0 var(--sku); }
}

/* Compra */
.kp-buy {
  background: var(--sku);
  color: var(--kf-cream);
  padding-block: clamp(4rem, 9vw, 7rem);
  position: relative; overflow: hidden;
}
.kp-buy__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
}
.kp-buy__media { text-align: center; position: relative; }
.kp-buy__bottle {
  max-width: 360px; margin-inline: auto;
  filter: drop-shadow(0 32px 48px rgba(0,0,0,0.25));
  animation: kf-float 6s ease-in-out infinite;
}
.kp-buy__panel {
  background: var(--kf-cream);
  color: var(--kf-ink);
  border: 2px solid var(--kf-ink);
  border-radius: var(--kf-radius-lg);
  padding: 2rem;
  box-shadow: 8px 8px 0 var(--kf-ink);
}
.kp-buy__moment {
  font-size: 0.72rem; font-weight: 700;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--sku); margin-bottom: 0.5rem;
}
.kp-buy__name {
  font-family: var(--kf-font-display);
  font-variation-settings: "opsz" 144, "SOFT" 100;
  font-size: 3rem; font-weight: 700;
  letter-spacing: -0.03em; line-height: 1;
  margin-bottom: 1rem;
  color: var(--kf-ink);
}
.kp-buy__lead {
  font-size: 1rem;
  color: var(--kf-ink-soft);
  margin-bottom: 1.5rem;
  line-height: 1.55;
}
.kp-buy__plans { display: grid; gap: 0.75rem; margin-bottom: 1.5rem; }
.kp-buy-plan {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center; gap: 1rem;
  padding: 1rem 1.25rem;
  border: 2px solid var(--kf-ink);
  border-radius: var(--kf-radius);
  background: var(--kf-cream-soft);
  cursor: pointer;
  position: relative;
  transition: background 0.2s, border-color 0.2s;
}
.kp-buy-plan:hover { background: var(--kf-cream-deep); }
.kp-buy-plan.is-active {
  background: color-mix(in srgb, var(--sku) 12%, var(--kf-cream-soft));
  border-color: var(--sku);
}
.kp-buy-plan__type {
  font-family: var(--kf-font-display);
  font-variation-settings: "opsz" 96, "SOFT" 50;
  font-weight: 600; font-size: 1.05rem;
  margin-bottom: 0.15rem;
  letter-spacing: -0.01em;
}
.kp-buy-plan__txt { font-size: 0.8rem; color: var(--kf-ink-soft); }
.kp-buy-plan__price strong {
  display: block;
  font-family: var(--kf-font-display);
  font-variation-settings: "opsz" 96, "SOFT" 100;
  font-weight: 700; font-size: 1.4rem;
  color: var(--kf-ink); line-height: 1;
}
.kp-buy-plan__price span { font-size: 0.72rem; color: var(--kf-ink-soft); }
.kp-buy-plan__save {
  position: absolute;
  top: -0.6rem; right: 1rem;
  background: var(--sku); color: var(--kf-cream);
  padding: 0.2rem 0.7rem;
  border-radius: 999px;
  font-size: 0.7rem; font-weight: 700;
  letter-spacing: 0.05em;
  border: 1.5px solid var(--kf-ink);
}
.kp-buy__atc {
  width: 100%; justify-content: center;
  background: var(--kf-ink); color: var(--kf-cream);
  padding: 1.1rem 2rem;
  border-radius: 999px;
  font-family: var(--kf-font-body);
  font-weight: 700; font-size: 0.95rem;
  cursor: pointer; border: none;
  transition: background 0.2s, transform 0.2s;
  display: inline-flex; align-items: center; gap: 0.5rem;
}
.kp-buy__atc:hover { background: var(--sku); transform: translateY(-2px); }
.kp-buy__trust {
  margin-top: 1.25rem;
  display: flex; flex-wrap: wrap; gap: 1rem;
  font-size: 0.75rem;
  color: var(--kf-ink-soft);
  list-style: none; padding: 0;
}
.kp-buy__trust li { display: inline-flex; align-items: center; gap: 0.35rem; }
@media (max-width: 880px) {
  .kp-buy__inner { grid-template-columns: 1fr; }
  .kp-buy__bottle { max-width: 240px; }
}

/* Reseñas */
.kp-reviews { background: var(--kf-cream-soft); padding-block: clamp(4rem, 9vw, 7rem); }
.kp-reviews__head {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 2rem;
  margin-bottom: 3rem;
  align-items: end;
}
.kp-reviews__title {
  font-family: var(--kf-font-display);
  font-variation-settings: "opsz" 144, "SOFT" 100;
  font-size: clamp(2rem, 4.5vw, 3rem);
  font-weight: 600;
  letter-spacing: -0.03em; line-height: 1;
}
.kp-reviews__title em { font-style: italic; color: var(--sku); }
.kp-reviews__score {
  display: flex; flex-direction: column; align-items: flex-end; gap: 0.25rem;
}
.kp-reviews__score-num {
  font-family: var(--kf-font-display);
  font-variation-settings: "opsz" 144, "SOFT" 100;
  font-weight: 700; font-size: 3rem;
  color: var(--kf-ink); line-height: 1;
}
.kp-reviews__stars { color: var(--kf-copper); font-size: 1.1rem; letter-spacing: 0.1em; }
.kp-reviews__total { font-size: 0.85rem; color: var(--kf-ink-soft); }
.kp-reviews__grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
}
.kp-review {
  background: var(--kf-cream);
  border: 2px solid var(--kf-ink);
  border-radius: var(--kf-radius);
  padding: 1.65rem;
}
.kp-review__head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 0.85rem; }
.kp-review__stars { color: var(--kf-copper); font-size: 0.95rem; }
.kp-review__date { font-size: 0.75rem; color: var(--kf-ink-soft); }
.kp-review__title {
  font-family: var(--kf-font-display);
  font-variation-settings: "opsz" 96, "SOFT" 50;
  font-weight: 600; font-size: 1.05rem;
  margin-bottom: 0.5rem; line-height: 1.3;
  letter-spacing: -0.01em;
}
.kp-review__body {
  font-size: 0.9rem; line-height: 1.6;
  color: var(--kf-ink-soft);
  margin-bottom: 0.85rem;
}
.kp-review__foot {
  display: flex; justify-content: space-between;
  font-size: 0.78rem; color: var(--kf-ink-soft);
  padding-top: 0.85rem; border-top: 1px solid var(--kf-line);
}
.kp-review__verified { color: var(--kf-copper); font-weight: 600; }
@media (max-width: 880px) {
  .kp-reviews__grid { grid-template-columns: 1fr; }
  .kp-reviews__head { grid-template-columns: 1fr; }
  .kp-reviews__score { align-items: flex-start; }
}

/* Sigue probando (related) */
.kp-related { background: var(--kf-cream); padding-block: clamp(4rem, 9vw, 7rem); }
.kp-related__head { text-align: center; margin-bottom: 3rem; }
.kp-related__title {
  font-family: var(--kf-font-display);
  font-variation-settings: "opsz" 144, "SOFT" 100;
  font-size: clamp(2rem, 4.5vw, 3.25rem);
  font-weight: 600;
  letter-spacing: -0.03em; line-height: 1;
}
.kp-related__title em { font-style: italic; color: var(--kf-copper); }
.kp-related__grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}
.kp-related-card {
  background: var(--kf-cream-soft);
  border: 2px solid var(--kf-ink);
  border-top: 6px solid var(--rc);
  border-radius: var(--kf-radius);
  padding: 1.85rem;
  text-align: center;
  display: flex; flex-direction: column; align-items: center;
  transition: transform 0.25s, box-shadow 0.25s;
}
.kp-related-card:hover {
  transform: translateY(-4px);
  box-shadow: 8px 8px 0 var(--rc);
}
.kp-related-card__bottle {
  max-width: 140px; margin-bottom: 1.25rem;
  filter: drop-shadow(0 16px 24px color-mix(in srgb, var(--rc) 30%, transparent));
}
.kp-related-card__moment {
  font-size: 0.72rem;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--rc); font-weight: 700;
  margin-bottom: 0.5rem;
}
.kp-related-card__name {
  font-family: var(--kf-font-display);
  font-variation-settings: "opsz" 96, "SOFT" 100;
  font-weight: 700; font-size: 1.9rem;
  margin-bottom: 0.5rem;
  letter-spacing: -0.02em;
  line-height: 1;
}
.kp-related-card__tagline {
  font-family: var(--kf-font-script);
  font-size: 1.1rem;
  color: var(--rc);
  margin-bottom: 1.25rem;
}
.kp-related-card__cta {
  margin-top: auto;
  padding: 0.7rem 1.4rem;
  background: var(--rc); color: var(--kf-cream);
  border-radius: 999px;
  font-size: 0.85rem; font-weight: 700;
  transition: filter 0.2s, transform 0.2s;
}
.kp-related-card__cta:hover { transform: translateY(-2px); filter: brightness(0.92); }
@media (max-width: 880px) { .kp-related__grid { grid-template-columns: 1fr; } }/* End custom CSS */