/* ============================================================
   LA VENTERA — Landing one-page
   Paleta y tokens editables abajo (variables CSS)
   ============================================================ */
:root{
  /* ---- PALETA DE MARCA (editable) ---- */
  --rojo:    #C8102E;   /* principal  */
  --rojo-osc:#9E0C24;
  --verde:   #1B7A3E;   /* secundario */
  --verde-osc:#0F5026;
  --dorado:  #E0A100;   /* acento / CTA */
  --dorado-cl:#F4C23B;
  --crema:   #F7F3E9;   /* fondo cálido almacén */
  --crema-osc:#EDE5D2;
  --carbon:  #1A1A1A;   /* texto */
  --blanco:  #FFFFFF;   /* tarjetas */

  /* ---- Tipografía ---- */
  --display: 'Anton', 'Archivo Black', sans-serif;
  --body: 'Work Sans', system-ui, sans-serif;
  --serif: 'Playfair Display', Georgia, serif;
  --script: 'Yellowtail', cursive;

  --maxw: 1180px;
  --r: 18px;
  --header-h: 68px;
  --shadow: 0 18px 50px -18px rgba(26,26,26,.32);
  --shadow-sm: 0 8px 24px -12px rgba(26,26,26,.30);
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--body);
  color:var(--carbon);
  background:var(--crema);
  line-height:1.6;
  overflow-x:hidden;
  font-size:18px;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }

/* Textura kraft sutil sobre el fondo crema */
body::before{
  content:""; position:fixed; inset:0; z-index:0; pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.45'/%3E%3C/svg%3E");
  opacity:.04; mix-blend-mode:multiply;
}

.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 22px; position:relative; z-index:1; }

/* ============ TIPOGRAFÍA UTIL ============ */
.kicker{
  font-family:var(--serif); font-style:italic; font-weight:500;
  color:var(--rojo); font-size:clamp(20px,2.6vw,28px); line-height:1.15;
}
.h-display{
  font-family:var(--display); font-weight:400; line-height:.98;
  text-transform:uppercase; letter-spacing:.01em;
}
.eyebrow{
  font-family:var(--body); font-weight:700; letter-spacing:.18em;
  text-transform:uppercase; font-size:13px; color:var(--verde);
}

/* ============ BOTONES ============ */
.btn{
  display:inline-flex; align-items:center; gap:.55em;
  font-family:var(--body); font-weight:700; font-size:17px;
  padding:16px 26px; border-radius:999px; cursor:pointer; border:2px solid transparent;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease;
  will-change:transform;
}
.btn .arrow{ transition:transform .25s ease; }
.btn:hover .arrow{ transform:translateX(5px); }
.btn-gold{
  background:var(--dorado); color:#3a2a00;
  box-shadow:0 12px 26px -10px rgba(224,161,0,.8);
}
.btn-gold:hover{ background:var(--dorado-cl); transform:translateY(-3px); box-shadow:0 18px 34px -10px rgba(224,161,0,.9); }
.btn-wa{ background:#25D366; color:#06351b; box-shadow:0 12px 26px -12px rgba(37,211,102,.8); }
.btn-wa:hover{ transform:translateY(-3px); filter:brightness(1.05); }
.btn-ghost{ background:transparent; color:var(--blanco); border-color:rgba(255,255,255,.7); }
.btn-ghost:hover{ background:rgba(255,255,255,.14); transform:translateY(-3px); }
.btn-red{ background:var(--rojo); color:#fff; box-shadow:0 12px 28px -12px rgba(200,16,46,.75); }
.btn-red:hover{ background:var(--rojo-osc); transform:translateY(-3px); }
.btn-lg{ font-size:19px; padding:19px 34px; }

/* ============ LOGO SVG (sello recurrente) ============ */
.logo{ display:inline-block; line-height:0; }
.logo svg{ width:100%; height:auto; display:block; }
.logo .lv-script{ font-family:var(--script); }

/* ============ SECCIONES ============ */
section{ position:relative; z-index:1; }
.section-pad{ padding:clamp(70px,9vw,128px) 0; }

/* divisor kraft entre secciones */
.kraft-edge{ position:relative; }
.kraft-edge::before{
  content:""; position:absolute; top:0; left:0; right:0; height:6px;
  background:repeating-linear-gradient(90deg, var(--dorado) 0 18px, var(--rojo) 18px 36px, var(--verde) 36px 54px);
  opacity:.85;
}

/* ====================================================
   HEADER FIJO (sticky)
   ==================================================== */
.site-header{
  position:sticky; top:0; z-index:70; height:var(--header-h);
  display:flex; align-items:center;
  background:rgba(247,243,233,.45);
  backdrop-filter:blur(16px) saturate(1.4);
  -webkit-backdrop-filter:blur(16px) saturate(1.4);
  border-bottom:1px solid rgba(255,255,255,.18);
  box-shadow:0 6px 24px -16px rgba(0,0,0,.4);
}
.site-header .wrap{ display:flex; align-items:center; gap:22px; }
.site-header__logo{ width:116px; display:block; flex:0 0 auto; line-height:0; }
.site-header__logo .logo{ display:block; width:100%; line-height:0; }
.site-header__logo .logo svg{ width:100%; height:auto; display:block; }
.site-nav{ display:flex; gap:24px; margin-left:6px; }
.site-nav a{ font-family:var(--body); font-weight:600; font-size:15px; color:var(--carbon); position:relative; padding:4px 0; }
.site-nav a::after{ content:""; position:absolute; left:0; bottom:-2px; width:0; height:2px; background:var(--rojo); border-radius:2px; transition:width .2s ease; }
.site-nav a:hover{ color:var(--rojo); }
.site-nav a:hover::after{ width:100%; }
.site-header__cta{ margin-left:auto; padding:11px 22px; font-size:15px; }

/* ====================================================
   1. HERO
   ==================================================== */
.hero{
  position:relative; min-height:calc(100svh - var(--header-h)); display:flex; align-items:center;
  overflow:hidden; color:#fff;
}
.hero__bg{ position:absolute; inset:-8% 0 -8% 0; z-index:0; }
.hero__bg img{
  width:100%; height:100%; object-fit:cover; object-position:72% center;
  will-change:transform;
}
.hero__scrim{
  position:absolute; inset:0; z-index:1;
  background:
    linear-gradient(90deg, rgba(20,10,2,.92) 0%, rgba(30,15,3,.72) 34%, rgba(30,15,3,.18) 60%, rgba(30,15,3,0) 80%),
    linear-gradient(0deg, rgba(20,10,2,.55) 0%, rgba(0,0,0,0) 40%);
}
.hero__inner{ position:relative; z-index:2; width:100%; }
/* Cartel flotante, centrado arriba del hero */
.hero__cartel{
  position:absolute; top:clamp(18px,4vh,46px); left:50%; z-index:6;
  width:clamp(240px,34vw,460px); display:block; line-height:0;
  transform:translateX(-50%);
  transition:transform .4s cubic-bezier(.22,.61,.36,1), filter .4s ease;
  filter:drop-shadow(0 18px 34px rgba(0,0,0,.5));
}
.hero__cartel img{ width:100%; height:auto; display:block; }
/* Hover: leve acercamiento + elevación + sombra más marcada */
.hero__cartel:hover{
  transform:translateX(-50%) scale(1.045) translateY(-6px);
  filter:drop-shadow(0 28px 50px rgba(0,0,0,.66));
}
/* Desktop/tablet: cartel al lateral superior derecho (sobre el cielo),
   despejando el título que está alineado a la izquierda */
@media (min-width:760px){
  .hero__cartel{
    left:auto; right:clamp(18px,3vw,52px); transform:none;
    top:clamp(18px,4vh,48px);
    width:clamp(220px,23vw,380px);
  }
  .hero__cartel:hover{ transform:scale(1.045) translateY(-6px); }
  /* Título más arriba (solo visual): se separa del subtítulo y se acerca
     al cartel, sin mover el resto del bloque. En pantallas bajas se reduce
     para que el título nunca quede debajo del header fijo. */
  .hero__content h1.reveal{ transform:translateY(-0.6cm); }
}
@media (min-width:760px) and (min-height:880px){
  .hero__content h1.reveal{ transform:translateY(-1.5cm); }
}
.hero__topbar{
  position:absolute; top:26px; left:0; right:0; z-index:5;
  display:flex; align-items:center; justify-content:space-between; gap:16px;
}
.hero__logo{ width:clamp(118px,15vw,168px); filter:drop-shadow(0 8px 20px rgba(0,0,0,.45)); }
.hero__content{ max-width:680px; padding:36px 0 56px; }
.hero h1{
  font-family:var(--display); font-weight:400; text-transform:uppercase;
  font-size:clamp(40px,7vw,82px); line-height:.96; letter-spacing:.005em;
  text-shadow:0 6px 30px rgba(0,0,0,.5);
}
.hero h1 .accent{
  font-family:var(--serif); font-style:italic; font-weight:600;
  text-transform:none; color:var(--dorado-cl);
  font-size:1.55em; line-height:.7; letter-spacing:0;
  position:relative; top:.06em;
  text-shadow:0 1px 2px rgba(0,0,0,.7), 0 3px 14px rgba(0,0,0,.55);
}
.hero__sub{
  margin-top:24px; font-size:clamp(17px,2.1vw,21px); max-width:560px;
  color:rgba(255,255,255,.94); text-shadow:0 2px 12px rgba(0,0,0,.55);
}
.hero__sub b{ color:var(--dorado-cl); font-weight:700; }
.hero__sub-lead{ margin:0; font-size:clamp(18px,2.2vw,22px); }
.hero__sub-note{
  margin:3px 0 0; font-size:clamp(13px,1.6vw,15px); font-weight:500;
  letter-spacing:.04em; color:rgba(255,255,255,.75);
}
.hero__facts{
  list-style:none; margin:12px 0 0; padding:0;
  display:flex; flex-direction:column; gap:9px;
}
.hero__facts li{
  display:flex; align-items:center; gap:10px;
  font-size:clamp(15px,1.9vw,18px); font-weight:500;
  color:rgba(255,255,255,.92);
}
.hero__facts svg{ width:21px; height:21px; flex:0 0 auto; color:var(--dorado-cl); }
.hero__cta{ margin-top:36px; display:flex; flex-wrap:wrap; gap:14px; }
.hero__scroll{
  position:absolute; bottom:22px; left:50%; transform:translateX(-50%); z-index:4;
  display:flex; flex-direction:column; align-items:center; gap:6px;
  font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:rgba(255,255,255,.8);
}
.hero__scroll .mouse{
  width:22px; height:36px; border:2px solid rgba(255,255,255,.7); border-radius:12px; position:relative;
}
.hero__scroll .mouse::after{
  content:""; position:absolute; top:6px; left:50%; transform:translateX(-50%);
  width:3px; height:7px; border-radius:2px; background:#fff; animation:wheel 1.6s ease-in-out infinite;
}
@keyframes wheel{ 0%{opacity:0;transform:translate(-50%,0)} 30%{opacity:1} 70%{opacity:1;transform:translate(-50%,9px)} 100%{opacity:0;transform:translate(-50%,12px)} }

/* ====================================================
   2. SU HISTORIA
   ==================================================== */
.historia{ background:var(--crema); }
.historia__grid{
  display:grid; grid-template-columns:1fr; gap:clamp(32px,5vw,64px); align-items:center;
}
.historia__media{ position:relative; }
.historia__media img{
  width:100%; border-radius:var(--r); box-shadow:var(--shadow);
  aspect-ratio:4/5; object-fit:cover; object-position:center;
}
.historia__media .seal{
  position:absolute; right:-14px; bottom:-22px; width:clamp(120px,18vw,168px);
  transform:rotate(-7deg); filter:drop-shadow(0 12px 26px rgba(0,0,0,.28));
}
.historia__media .since{
  position:absolute; left:-10px; top:-14px; background:var(--dorado); color:#3a2a00;
  font-family:var(--display); font-size:clamp(18px,2.4vw,24px); padding:12px 18px;
  border-radius:14px; line-height:1; box-shadow:var(--shadow-sm); transform:rotate(-4deg);
}
.historia__copy .kicker{ margin-bottom:8px; }
.historia__copy h2{ font-family:var(--display); text-transform:uppercase; font-weight:400;
  font-size:clamp(30px,4.6vw,52px); line-height:1; margin-bottom:22px; }
.historia__copy p{ margin-bottom:18px; color:#332f28; font-size:clamp(17px,1.7vw,19px); max-width:46ch; }
.historia__copy p .hl{ color:var(--rojo); font-weight:700; }
.signature{ font-family:var(--serif); font-style:italic; font-size:clamp(20px,2.4vw,26px); color:var(--verde); margin-top:8px; }
.signature small{ display:block; font-family:var(--body); font-style:normal; font-size:13px; letter-spacing:.1em; text-transform:uppercase; color:#8a8170; margin-top:4px; }

/* ====================================================
   3. EL ACEITE PROTAGONISTA
   ==================================================== */
.aceite{
  background:
    radial-gradient(120% 80% at 80% -10%, rgba(224,161,0,.18), transparent 60%),
    linear-gradient(180deg, #221709 0%, #2c1d0b 100%);
  color:#fff; overflow:hidden;
}
.aceite__head{ display:grid; grid-template-columns:1fr; gap:36px; align-items:center; }
.aceite__hero-img{ position:relative; animation:floatY 5.5s ease-in-out infinite; }
@keyframes floatY{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-16px); } }
.aceite__hero-img img{
  width:100%; max-width:520px; margin:0 auto;
  filter:drop-shadow(0 40px 60px rgba(0,0,0,.6));
  transition:transform .5s cubic-bezier(.2,.7,.2,1); will-change:transform;
}
.aceite__glow{
  position:absolute; inset:auto 0 -10% 0; height:60%; z-index:-1; filter:blur(40px);
  background:radial-gradient(60% 100% at 50% 100%, rgba(224,161,0,.55), transparent 70%);
  transition:opacity .4s ease, transform .4s ease;
}
.aceite__hero-img:hover .aceite__glow{ transform:scale(1.12); opacity:.95; }
.aceite__intro .eyebrow{ color:var(--dorado-cl); }
.aceite__intro h2{ font-family:var(--display); text-transform:uppercase; font-weight:400;
  font-size:clamp(32px,5vw,60px); line-height:.98; margin:10px 0 18px; }
.aceite__intro h2 em{ font-family:var(--serif); font-style:italic; text-transform:none; color:var(--dorado-cl); font-weight:500; }
.aceite__intro p{ color:rgba(255,255,255,.82); max-width:50ch; font-size:clamp(17px,1.7vw,19px); }

.lines{ display:grid; grid-template-columns:1fr; gap:22px; margin-top:clamp(48px,6vw,76px); }
.line-card{
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.1);
  border-radius:var(--r); overflow:hidden; backdrop-filter:blur(4px);
  transition:transform .3s ease, box-shadow .3s ease, border-color .3s ease;
  display:flex; flex-direction:column;
}
.line-card:hover{ transform:translateY(-8px); border-color:rgba(255,255,255,.28); box-shadow:0 30px 50px -20px rgba(0,0,0,.7); }
.line-card__top{ position:relative; padding:22px 22px 0; }
.line-card__cap{
  display:inline-flex; align-items:center; gap:9px; font-weight:700; font-size:13px;
  letter-spacing:.14em; text-transform:uppercase; padding:7px 14px; border-radius:999px;
}
.cap-dot{ width:14px; height:14px; border-radius:50%; box-shadow:0 0 0 3px rgba(255,255,255,.25) inset; }
.cap-roja{ background:rgba(200,16,46,.18); color:#ff9aa9; } .cap-roja .cap-dot{ background:var(--rojo); }
.cap-amar{ background:rgba(224,161,0,.18); color:var(--dorado-cl); } .cap-amar .cap-dot{ background:#F2C200; }
.cap-verd{ background:rgba(27,122,62,.22); color:#7fd49c; } .cap-verd .cap-dot{ background:#2D9D55; }
.cap-blanca{ background:rgba(255,255,255,.16); color:#f3f3f3; } .cap-blanca .cap-dot{ background:#fff; box-shadow:0 0 0 1px rgba(0,0,0,.3) inset; }
.line-card__img{ position:relative; height:230px; margin-top:6px; display:flex; align-items:center; justify-content:center; padding:12px 0; }
/* glow blanco detrás de la botella (aparece en hover) */
.line-card__img::before{
  content:""; position:absolute; left:50%; top:50%; width:68%; aspect-ratio:1/1;
  transform:translate(-50%,-50%) scale(.6);
  background:radial-gradient(circle, rgba(255,255,255,.42) 0%, rgba(255,255,255,.12) 45%, transparent 70%);
  filter:blur(22px); opacity:0; transition:opacity .35s ease, transform .35s ease; z-index:0; pointer-events:none;
}
.line-card:hover .line-card__img::before,
.line-card.is-hover .line-card__img::before{ opacity:.55; transform:translate(-50%,-50%) scale(1); }
.line-card__img img{
  position:relative; z-index:1; width:auto; height:auto; max-height:206px; max-width:62%;
  object-fit:contain; filter:drop-shadow(0 16px 24px rgba(0,0,0,.55));
  transition:transform .4s cubic-bezier(.2,.7,.2,1); will-change:transform;
}
.line-card:hover .line-card__img img{ transform:scale(1.12); }
.line-card__body{ padding:24px; flex:1; display:flex; flex-direction:column; }
.line-card h3{ font-family:var(--display); text-transform:uppercase; font-weight:400; font-size:24px; line-height:1; margin-bottom:6px; }
.line-card .use{ color:rgba(255,255,255,.72); font-size:16px; margin-bottom:18px; flex:1; }
.line-card .metric{ display:flex; align-items:baseline; gap:10px; margin-top:auto; }
.metric .num{ font-family:var(--display); font-size:clamp(48px,8vw,68px); line-height:.8; color:var(--dorado-cl); }
.metric .unit{ font-family:var(--display); font-size:26px; color:#fff; }
.metric .label{ font-size:13px; letter-spacing:.08em; text-transform:uppercase; color:rgba(255,255,255,.6); align-self:flex-end; padding-bottom:6px; }
.metric.cold .num{ font-size:clamp(30px,5vw,40px); color:#7fd49c; }
.aceite__reinforce{
  margin-top:clamp(40px,5vw,60px); text-align:center;
  display:flex; flex-wrap:wrap; justify-content:center; gap:10px 0;
}
.aceite__reinforce span{
  font-family:var(--body); font-weight:600; font-size:15px; letter-spacing:.04em;
  color:rgba(255,255,255,.9); padding:0 22px; position:relative;
}
.aceite__reinforce span+span::before{ content:"·"; position:absolute; left:-3px; color:var(--dorado); }

/* ====================================================
   4. POR QUÉ LA VENTERA
   ==================================================== */
.porque{ background:var(--blanco); }
.porque__head{ text-align:center; max-width:640px; margin:0 auto clamp(44px,5vw,64px); }
.porque__head h2{ font-family:var(--display); text-transform:uppercase; font-weight:400;
  font-size:clamp(30px,4.6vw,52px); line-height:1; margin-top:8px; }
.trust-grid{ display:grid; grid-template-columns:1fr; gap:18px; }
.trust-card{
  background:var(--crema); border:1px solid var(--crema-osc); border-radius:var(--r);
  padding:30px 26px; transition:transform .3s ease, box-shadow .3s ease;
  display:flex; gap:18px; align-items:flex-start;
}
.trust-card:hover{ transform:translateY(-6px) scale(1.015); box-shadow:var(--shadow); }
.trust-card .ic{ flex:0 0 auto; width:52px; height:52px; border-radius:14px; display:grid; place-items:center; color:#fff; }
.trust-card .ic svg{ width:28px; height:28px; }
.trust-card h3{ font-family:var(--display); text-transform:uppercase; font-weight:400; font-size:clamp(26px,3vw,32px); line-height:.95; color:var(--rojo); }
.trust-card p{ font-size:16px; color:#4a463d; margin-top:4px; }
.trust-card.span-all{ grid-column:1/-1; background:var(--carbon); color:#fff; align-items:center; justify-content:center; gap:26px; text-align:center; }
.trust-card.span-all .ic{ background:var(--dorado); color:#3a2a00; flex:0 0 auto; }
.trust-card.span-all .regs{ display:flex; flex-wrap:wrap; justify-content:center; align-items:stretch; gap:0; }
.trust-card.span-all .regs span{
  display:flex; flex-direction:column; align-items:center; gap:5px;
  padding:2px 30px; position:relative;
}
.trust-card.span-all .regs span + span::before{
  content:""; position:absolute; left:0; top:50%; transform:translateY(-50%);
  width:1px; height:34px; background:rgba(255,255,255,.16);
}
.trust-card.span-all .regs i{
  font-style:normal; text-transform:uppercase; letter-spacing:.22em;
  font-size:10.5px; font-weight:700; color:rgba(255,255,255,.5);
}
.trust-card.span-all .regs b{
  font-weight:700; font-size:16px; letter-spacing:.05em; color:var(--dorado-cl);
  font-variant-numeric:tabular-nums;
}

/* ====================================================
   5. CÓMO PEDIR
   ==================================================== */
.pedir{ background:var(--crema); overflow:hidden; }
.pedir__grid{ display:grid; grid-template-columns:1fr; gap:clamp(36px,5vw,60px); align-items:center; }
.pedir__media{ position:relative; }
.pedir__media img{ width:100%; border-radius:var(--r); box-shadow:var(--shadow); aspect-ratio:4/3; object-fit:cover; }
.pedir__media .wa-tag{
  position:absolute; right:-12px; bottom:-16px; background:#25D366; color:#06351b;
  font-weight:700; padding:12px 18px; border-radius:14px; box-shadow:var(--shadow-sm);
  display:flex; align-items:center; gap:8px; font-size:15px;
}
.pedir__copy h2{ font-family:var(--display); text-transform:uppercase; font-weight:400;
  font-size:clamp(30px,4.6vw,52px); line-height:1; margin:8px 0 28px; }
.steps{ display:flex; flex-direction:column; gap:8px; counter-reset:step; }
.step{
  display:flex; gap:18px; align-items:flex-start; padding:18px 0; position:relative;
  border-bottom:1px dashed var(--crema-osc);
}
.step:last-of-type{ border-bottom:none; }
.step__num{
  flex:0 0 auto; counter-increment:step; width:48px; height:48px; border-radius:50%;
  background:var(--rojo); color:#fff; font-family:var(--display); font-size:24px;
  display:grid; place-items:center; box-shadow:0 8px 18px -8px rgba(200,16,46,.7);
}
.step__num::before{ content:counter(step); }
.step h3{ font-weight:700; font-size:19px; }
.step p{ font-size:16px; color:#4a463d; }
.step p b{ color:var(--verde); }
.pedir__cta{ margin-top:30px; }

/* ====================================================
   6. ZONAS DE REPARTO
   ==================================================== */
.zonas{
  background:linear-gradient(180deg, var(--verde-osc), var(--verde)); color:#fff; overflow:hidden;
}
.zonas__grid{ display:grid; grid-template-columns:1fr; gap:clamp(36px,5vw,56px); align-items:center; }
.zonas__copy .eyebrow{ color:var(--dorado-cl); }
.zonas__copy h2{ font-family:var(--display); text-transform:uppercase; font-weight:400;
  font-size:clamp(30px,4.6vw,52px); line-height:1; margin:8px 0 14px; }
.zonas__copy p{ color:rgba(255,255,255,.86); max-width:46ch; margin-bottom:28px; }
.zona-cards{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.zona-card{
  background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.16); border-radius:var(--r);
  padding:26px 22px; transition:transform .3s ease, background .3s ease;
}
.zona-card:hover{ transform:translateY(-6px); background:rgba(255,255,255,.16); }
.zona-card .pin{ width:34px; height:34px; margin-bottom:12px; color:var(--dorado-cl); }
.zona-card h3{ font-family:var(--display); text-transform:uppercase; font-weight:400; font-size:clamp(28px,4vw,40px); line-height:.95; }
.zona-card p{ color:rgba(255,255,255,.82); font-size:15px; margin-top:4px; }
.zonas__media{ position:relative; }
.zonas__media img{ width:100%; border-radius:var(--r); box-shadow:var(--shadow); aspect-ratio:4/3; object-fit:cover; }

/* ====================================================
   7. FOOTER
   ==================================================== */
.footer{ background:var(--carbon); color:#cfc9bd; padding:clamp(56px,7vw,84px) 0 40px; }
.footer__grid{ display:grid; grid-template-columns:1fr; gap:40px; }
.footer__brand .logo{ width:180px; margin-bottom:18px; }
.footer__brand p{ font-size:15px; max-width:34ch; color:#a8a194; }
.footer h4{ font-family:var(--body); font-weight:700; letter-spacing:.14em; text-transform:uppercase;
  font-size:13px; color:var(--dorado-cl); margin-bottom:16px; }
.footer__col a, .footer__col p{ font-size:15px; color:#cfc9bd; margin-bottom:10px; display:flex; gap:10px; align-items:flex-start; }
.footer__col a:hover{ color:#fff; }
.footer__col svg{ width:18px; height:18px; flex:0 0 auto; margin-top:2px; color:var(--dorado-cl); }
.footer__regs{ font-size:13px; color:#8a8377; line-height:1.7; }
.footer__bottom{
  border-top:1px solid #2e2e2e; margin-top:44px; padding-top:24px;
  display:flex; flex-wrap:wrap; gap:10px; justify-content:space-between; font-size:13px; color:#8a8377;
}
.footer__bottom .ind{ display:flex; align-items:center; gap:8px; }
.footer__bottom .ind .flag{ width:22px; height:15px; border-radius:2px; overflow:hidden; box-shadow:0 0 0 1px rgba(255,255,255,.15); }

/* ============ WHATSAPP FLOTANTE ============ */
.wa-float{
  position:fixed; right:18px; bottom:18px; z-index:60;
  width:58px; height:58px; border-radius:50%; background:#25D366; color:#fff;
  display:grid; place-items:center; box-shadow:0 14px 30px -8px rgba(37,211,102,.7);
  transition:transform .2s ease; opacity:0; transform:translateY(20px) scale(.6); pointer-events:none;
}
.wa-float.show{ opacity:1; transform:none; pointer-events:auto; }
.wa-float:hover{ transform:scale(1.08); }
.wa-float svg{ width:30px; height:30px; }
.wa-float::after{
  content:""; position:absolute; inset:0; border-radius:50%; border:2px solid #25D366;
  animation:pulse 2.4s ease-out infinite;
}
@keyframes pulse{ 0%{transform:scale(1);opacity:.7} 100%{transform:scale(1.8);opacity:0} }

/* ============ REVEAL ON SCROLL ============ */
.reveal{ opacity:0; transform:translateY(34px); transition:opacity .7s cubic-bezier(.16,.8,.3,1), transform .7s cubic-bezier(.16,.8,.3,1); }
.reveal.in{ opacity:1; transform:none; }
.reveal[data-delay="1"]{ transition-delay:.09s; }
.reveal[data-delay="2"]{ transition-delay:.18s; }
.reveal[data-delay="3"]{ transition-delay:.27s; }
.reveal[data-delay="4"]{ transition-delay:.36s; }

/* ============ RESPONSIVE ============ */
@media (min-width:760px){
  .historia__grid{ grid-template-columns:.9fr 1.1fr; }
  .historia__grid.flip .historia__media{ order:2; }
  .aceite__head{ grid-template-columns:1fr 1fr; }
  .lines{ grid-template-columns:repeat(3,1fr); }
  .trust-grid{ grid-template-columns:repeat(3,1fr); }
  .trust-card.span-all{ grid-template-columns:none; }
  .pedir__grid{ grid-template-columns:1fr 1fr; }
  .zonas__grid{ grid-template-columns:1.05fr .95fr; }
  .footer__grid{ grid-template-columns:1.4fr 1fr 1fr; }
}
@media (max-width:880px){
  .site-nav{ display:none; }
}
@media (max-width:759px){
  /* Hero a altura completa: título arriba (bajo el cartel), resto al fondo */
  .hero{ align-items:stretch; }
  .hero__inner{ display:flex; flex-direction:column; }
  .hero__inner > .wrap{ display:flex; flex-direction:column; flex:1; }
  .hero__content{ display:flex; flex-direction:column; flex:1; padding:0 0 96px; }
  /* Título un poco más arriba (más cerca del cartel) y separado del subtítulo */
  .hero h1{ margin-top:198px; margin-bottom:42px; }
  /* Empuja subtítulo + botones al fondo, dejando la cara despejada */
  .hero__sub{ margin-top:auto; }
  /* Refuerzo del degradado inferior para legibilidad del texto */
  .hero__scrim{
    background:
      linear-gradient(90deg, rgba(20,10,2,.78) 0%, rgba(30,15,3,.5) 40%, rgba(30,15,3,.12) 72%, rgba(30,15,3,0) 100%),
      linear-gradient(0deg, rgba(16,8,1,.82) 0%, rgba(16,8,1,.4) 32%, rgba(0,0,0,0) 58%);
  }
  .historia__copy{ text-align:left; }
  .aceite__intro{ text-align:center; }
  .aceite__intro p{ margin:0 auto; }
}
@media (max-width:600px){
  .btn-lg{ font-size:16px; padding:13px 22px; }
  /* Botones compactos, centrados y un poco más abajo */
  .hero__cta{
    flex-direction:column; align-items:center; gap:12px; margin-top:30px;
  }
  .hero__cta .btn{
    width:auto; min-width:236px; min-height:48px; justify-content:center;
  }
}
@media (max-width:430px){
  .site-header__logo{ width:100px; }
  .site-header__cta{ padding:10px 16px; font-size:14px; }
  .btn-lg{ font-size:15px; padding:13px 18px; }
}
@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition:none !important; }
  .reveal{ opacity:1; transform:none; }
}

/* ====================================================
   PRELOADER — cartel mientras cargan las imágenes
   ==================================================== */
body.preloading{ overflow:hidden; }
.preloader{
  position:fixed; inset:0; z-index:2000; display:flex; align-items:center; justify-content:center;
  background:rgba(10,6,3,.82); backdrop-filter:blur(4px); -webkit-backdrop-filter:blur(4px);
  transition:opacity .6s ease, visibility .6s ease;
}
.preloader.is-done{ opacity:0; visibility:hidden; }
.preloader__inner{ display:flex; flex-direction:column; align-items:center; gap:28px; padding:24px; }
.preloader__logo{
  width:clamp(220px,42vw,380px); height:auto; display:block;
  filter:drop-shadow(0 18px 36px rgba(0,0,0,.28));
  animation:preloaderPulse 1.8s ease-in-out infinite;
}
@keyframes preloaderPulse{
  0%,100%{ transform:scale(1); }
  50%{ transform:scale(1.05); }
}
.preloader__bar{
  width:min(220px,58vw); height:4px; border-radius:99px; overflow:hidden;
  background:rgba(200,16,46,.16);
}
.preloader__bar span{
  display:block; height:100%; width:38%; border-radius:99px; background:var(--rojo);
  animation:preloaderBar 1.15s ease-in-out infinite;
}
@keyframes preloaderBar{
  0%{ transform:translateX(-130%); }
  100%{ transform:translateX(360%); }
}

/* ====================================================
   LIGHTBOX — visor ampliado de botellas
   ==================================================== */
.line-card__img img, .aceite__hero-img img{ cursor:zoom-in; }
.lightbox{
  position:fixed; inset:0; z-index:1000; display:flex; align-items:center; justify-content:center;
  padding:28px; background:rgba(10,6,2,.84); backdrop-filter:blur(3px);
  opacity:0; visibility:hidden; transition:opacity .3s ease, visibility .3s ease;
}
.lightbox.show{ opacity:1; visibility:visible; }
.lightbox__fig{
  margin:0; display:flex; flex-direction:column; align-items:center; gap:20px;
  max-width:min(92vw,540px);
}
.lightbox__img{
  max-width:100%; max-height:72vh; width:auto; height:auto; object-fit:contain;
  filter:drop-shadow(0 34px 64px rgba(0,0,0,.6));
  transform:scale(.85); opacity:0;
  transition:transform .38s cubic-bezier(.2,.7,.2,1), opacity .38s ease;
}
.lightbox.show .lightbox__img{ transform:scale(1); opacity:1; }
.lightbox__title{
  color:#fff; font-family:var(--display); text-transform:uppercase; letter-spacing:.02em;
  font-size:clamp(19px,3.2vw,28px); line-height:1.05; text-align:center;
  text-shadow:0 2px 16px rgba(0,0,0,.55);
}
.lightbox__close{
  position:absolute; top:18px; right:20px; width:46px; height:46px; border-radius:50%;
  background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.28); color:#fff;
  display:flex; align-items:center; justify-content:center; cursor:pointer;
  transition:background .2s ease, transform .2s ease;
}
.lightbox__close:hover{ background:rgba(255,255,255,.22); transform:scale(1.06); }
.lightbox__close svg{ width:22px; height:22px; }
