/* ═══════════════════════════════════════════════════════════════════════════
   index.css — BigLow Web · Landing Page (2026-04-12)
   ══════════════════════════════════════════════════════════════════════════ */

/* ── Shared section utilities ───────────────────────────────────────────── */
.lp-tag{
  display:inline-block;padding:4px 14px;border-radius:20px;
  background:rgba(214,40,40,.09);color:#C41E1E;
  font-size:.68rem;font-weight:700;letter-spacing:.08em;margin-bottom:.65rem;
}
.lp-section__title{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(1.9rem,3.5vw,2.8rem);
  color:#1A1A1A;letter-spacing:.03em;line-height:1.1;margin-bottom:.5rem;
}
.lp-section__sub{font-size:.9rem;color:#888;line-height:1.6;max-width:520px}
.lp-section__head{margin-bottom:3rem}
.lp-section__head--center{text-align:center}
.lp-section__head--center .lp-section__sub{margin:0 auto}
.lp-section{padding:5rem 0}
.lp-section--alt{background:#F9F9FA}

.lp-btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:.85rem 1.9rem;border-radius:14px;
  font-size:.85rem;font-weight:700;letter-spacing:.04em;
  border:none;cursor:pointer;text-decoration:none;
  transition:transform .25s cubic-bezier(.22,1,.36,1),box-shadow .25s,background .2s,border-color .2s,color .2s;
}
.lp-btn--primary{background:#D62828;color:#fff;box-shadow:0 4px 20px rgba(214,40,40,.28)}
.lp-btn--primary:hover{background:#B91C1C;transform:translateY(-2px);box-shadow:0 8px 30px rgba(214,40,40,.38)}
.lp-btn--primary:active{transform:scale(.96)}
.lp-btn--outline{background:transparent;color:#666;border:1.5px solid #ddd}
.lp-btn--outline:hover{border-color:#D62828;color:#D62828;transform:translateY(-1px)}
/* Closed state — store unavailable */
.lp-btn--closed{
  background:#9CA3AF!important;
  color:#fff!important;
  box-shadow:none!important;
  cursor:not-allowed!important;
  pointer-events:none;
  transform:none!important;
}
/* Phone call buttons (shown when store is closed) */
.hero-tel-group{
  display:flex;gap:.7rem;flex-wrap:wrap;
}
.lp-btn--tel{
  background:#fff;
  color:#1A1A1A;
  border:2px solid #1A1A1A;
  box-shadow:0 2px 12px rgba(0,0,0,.08);
}
.lp-btn--tel:hover{
  background:#1A1A1A;
  color:#fff;
  transform:translateY(-2px);
  box-shadow:0 6px 20px rgba(0,0,0,.18);
}
.lp-btn--tel-movil{
  border-color:#D62828;
  color:#D62828;
}
.lp-btn--tel-movil:hover{
  background:#D62828;
  color:#fff;
  box-shadow:0 6px 20px rgba(214,40,40,.28);
}
.lp-hero__badge--closed{
  background:rgba(156,163,175,.12);
  color:#6B7280;
}
.lp-hero__dot--closed{
  background:#9CA3AF;
  box-shadow:none;
  animation:none;
}

/* ══ Hero ════════════════════════════════════════════════════════════════ */
.lp-hero{
  min-height:calc(100dvh - 66px);
  display:flex;align-items:center;
  padding:3.5rem 0;
  background:linear-gradient(140deg,#FFF9F7 0%,#FFFFFF 45%,#FEF2F2 100%);
  position:relative;overflow:hidden;
}
.lp-hero::before{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(rgba(214,40,40,.035) 1px,transparent 1px);
  background-size:26px 26px;pointer-events:none;
}
.lp-hero__inner{
  display:grid;grid-template-columns:1fr 1fr;
  gap:3rem;align-items:center;position:relative;z-index:1;
}
.lp-hero__badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 14px;border-radius:30px;
  background:rgba(22,163,74,.1);color:#15803D;
  font-size:.68rem;font-weight:700;letter-spacing:.07em;margin-bottom:1.4rem;
}
.lp-hero__dot{
  width:8px;height:8px;border-radius:50%;background:#16A34A;flex-shrink:0;
  box-shadow:0 0 0 3px rgba(22,163,74,.25);
  animation:lpDotPulse 2.2s ease-in-out infinite;
}
@keyframes lpDotPulse{
  0%,100%{box-shadow:0 0 0 0 rgba(22,163,74,.5)}
  50%{box-shadow:0 0 0 7px rgba(22,163,74,0)}
}
/* ── Hero entrance animations ──────────────────────────────────────────── */
@keyframes slideUpFade{
  from{opacity:0;transform:translateY(30px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes dotColorPop{
  0%,75%{color:inherit}
  100%{color:#D62828}
}
.animate-line{
  display:inline-block;
  opacity:0;
  animation:slideUpFade .8s cubic-bezier(0.16,1,0.3,1) forwards;
}
.delay-1{animation-delay:0s}
.delay-2{animation-delay:.15s}
.animate-dot{
  display:inline-block;
  animation:dotColorPop 1.2s ease forwards;
  animation-delay:.9s;
}
.lp-hero__title{
  font-family:'Montserrat',sans-serif;
  font-weight:900;
  font-size:clamp(3.4rem,6.5vw,5.8rem);
  line-height:0.95;letter-spacing:-2px;
  text-transform:uppercase;
  color:#1A1A1A;margin-bottom:1.5rem;
}
.lp-hero__accent{color:#D62828}
.lp-hero__sub{
  font-family:'Inter',sans-serif;font-style:normal;
  font-size:1.1rem;color:#4B5563;line-height:1.6;
  font-weight:400;
  max-width:440px;margin-bottom:2rem;
}
.lp-hero__ctas{display:flex;gap:.85rem;flex-wrap:wrap;margin-bottom:2.5rem}
.lp-hero__stats{
  display:inline-flex;align-items:stretch;
  background:#fff;border-radius:16px;
  box-shadow:0 3px 20px rgba(0,0,0,.08);overflow:hidden;
}
.lp-stat{padding:.85rem 1.35rem;text-align:center}
.lp-stat strong{
  display:block;font-family:'Bebas Neue',sans-serif;
  font-size:1.4rem;color:#1A1A1A;line-height:1;
}
.lp-stat span{font-size:.6rem;font-weight:700;color:#bbb;letter-spacing:.06em;text-transform:uppercase}
.lp-stat-sep{width:1px;background:#f0f0f0}
/* Visual */
.lp-hero__visual{position:relative;display:flex;align-items:center;justify-content:center}
.lp-hero__glow{
  position:absolute;width:540px;height:540px;border-radius:50%;
  background:radial-gradient(circle,rgba(214,40,40,.13) 0%,transparent 65%);
  pointer-events:none;
}
.lp-hero__pizza{
  width:100%;max-width:540px;position:relative;z-index:1;
  will-change:transform;
  animation:lpSpin 22s linear infinite;
  filter:drop-shadow(0 24px 60px rgba(214,40,40,.18));
}
@keyframes lpSpin{to{transform:rotate(360deg)}}

/* ══ Top Ventas ══════════════════════════════════════════════════════════ */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.feat-card{
  background:#fff;border-radius:20px;
  border:1.5px solid rgba(0,0,0,.06);
  box-shadow:0 3px 16px rgba(0,0,0,.06);
  overflow:hidden;display:flex;flex-direction:column;
  transition:transform .3s cubic-bezier(.22,1,.36,1),box-shadow .3s;
}
.feat-card:hover{transform:translateY(-6px);box-shadow:0 16px 40px rgba(0,0,0,.1)}
/* visual section removed — badge now inline */
.feat-card__badge{
  display:inline-flex;align-items:center;
  background:#D62828;color:#fff;
  font-size:.55rem;font-weight:800;letter-spacing:.07em;
  padding:2px 8px;border-radius:20px;vertical-align:middle;
}
.feat-card__badge--inline{margin-left:.4rem}
.feat-card__body{padding:1.5rem 1.35rem 1.35rem;display:flex;flex-direction:column;flex:1}
.feat-card__cat{font-size:.62rem;font-weight:700;letter-spacing:.07em;color:#D62828;margin-bottom:.55rem;display:flex;align-items:center;flex-wrap:wrap;gap:.25rem}
.feat-card__name{
  font-family:'Bebas Neue',sans-serif;
  font-size:1.3rem;color:#1A1A1A;letter-spacing:.04em;line-height:1.15;margin-bottom:.5rem;
}
.feat-card__desc{font-size:.78rem;color:#999;line-height:1.55;flex:1;margin-bottom:1rem}
.feat-card__footer{
  display:flex;align-items:center;justify-content:space-between;
  border-top:1px solid rgba(0,0,0,.06);padding-top:.85rem;
}
.feat-card__price{font-family:'Bebas Neue',sans-serif;font-size:1.25rem;color:#D62828;letter-spacing:.04em}
.feat-card__btn{
  display:inline-flex;align-items:center;gap:5px;
  padding:.5rem 1.1rem;border-radius:10px;
  background:#D62828;color:#fff;
  font-size:.75rem;font-weight:700;letter-spacing:.03em;text-decoration:none;
  transition:background .18s,transform .2s;
}
.feat-card__btn:hover{background:#B91C1C;transform:scale(1.05)}

/* ══ La Esencia BigLow ═══════════════════════════════════════════════════ */
.esencia-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.esencia-card{
  padding:2rem 1.75rem;border-radius:20px;text-align:center;
  background:#fff;border:1.5px solid rgba(0,0,0,.06);
  box-shadow:0 2px 12px rgba(0,0,0,.05);
  transition:transform .3s cubic-bezier(.22,1,.36,1),box-shadow .3s;
}
.esencia-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,.09)}
.esencia-card__icon{font-size:2.8rem;display:block;margin-bottom:1.1rem;line-height:1}
.esencia-card__title{
  font-family:'Bebas Neue',sans-serif;
  font-size:1.2rem;color:#1A1A1A;letter-spacing:.05em;margin-bottom:.65rem;
}
.esencia-card__desc{font-size:.83rem;color:#999;line-height:1.6}

/* ══ Reparto zones ═══════════════════════════════════════════════════════ */
.reparto-inner{display:grid;grid-template-columns:1fr 1.3fr;gap:4rem;align-items:start}
.reparto-inner .lp-section__sub{margin-bottom:1.75rem}
.reparto-zones{display:flex;flex-direction:column;gap:.75rem}
.zone-card{
  display:flex;align-items:center;gap:1rem;
  padding:1rem 1.25rem;border-radius:14px;
  background:#fff;border:1.5px solid rgba(0,0,0,.07);
  box-shadow:0 2px 10px rgba(0,0,0,.04);
  transition:border-color .2s,box-shadow .2s;
}
.zone-card:hover{border-color:rgba(214,40,40,.2);box-shadow:0 4px 16px rgba(214,40,40,.08)}
.zone-card--featured{border-color:rgba(214,40,40,.3);background:rgba(214,40,40,.025)}
.zone-card__pin{font-size:1.25rem;color:#D62828;flex-shrink:0}
.zone-card__body{flex:1}
.zone-card__town{display:block;font-size:.9rem;font-weight:700;color:#1A1A1A;margin-bottom:.3rem}
.zone-card__details{display:flex;gap:1.25rem;flex-wrap:wrap}
.zone-card__details span{display:inline-flex;align-items:center;gap:.3rem;font-size:.72rem;color:#888}
.zone-card__details i{font-size:.75rem;color:#bbb}
.zone-card__details span:first-child b{color:#D62828}
.zone-card--featured .zone-card__details span:last-child{color:#15803D;font-weight:700}

/* ══ Reviews ═════════════════════════════════════════════════════════════ */
.reviews-meta{
  display:flex;align-items:center;gap:.75rem;margin-top:.75rem;justify-content:center;
}
.reviews-stars-big{color:#F59E0B;font-size:1.15rem;letter-spacing:.05em}
.reviews-score{font-family:'Bebas Neue',sans-serif;font-size:1.5rem;color:#1A1A1A}
.reviews-platform{font-size:.73rem;color:#aaa;font-weight:600}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.review-card{
  background:#fff;border-radius:18px;
  border:1.5px solid rgba(0,0,0,.06);
  padding:1.5rem 1.4rem;
  box-shadow:0 2px 12px rgba(0,0,0,.05);
  position:relative;display:flex;flex-direction:column;gap:.85rem;
}
.review-card::before{
  content:'\201C';
  position:absolute;top:.5rem;right:1rem;
  font-size:4.5rem;color:rgba(214,40,40,.07);
  font-family:Georgia,serif;line-height:1;pointer-events:none;
}
.review-card__stars{color:#F59E0B;font-size:.88rem;letter-spacing:.05em}
.review-card__text{font-size:.84rem;color:#444;line-height:1.65;flex:1;font-style:italic}
.review-card__author{
  display:flex;align-items:center;gap:.65rem;
  border-top:1px solid rgba(0,0,0,.05);padding-top:.75rem;
}
.review-card__avatar{
  width:36px;height:36px;border-radius:50%;flex-shrink:0;
  background:#D62828;color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:.65rem;font-weight:800;letter-spacing:.03em;
}
.review-card__name{font-size:.82rem;font-weight:700;color:#1A1A1A}

/* ══ CTA Banner ══════════════════════════════════════════════════════════ */
.cta-banner{
  background:linear-gradient(135deg,#1A1A1A 0%,#2A0808 100%);
  padding:4.5rem 0;position:relative;overflow:hidden;
}
.cta-banner::before{
  content:'';position:absolute;right:-80px;top:-80px;
  width:380px;height:380px;border-radius:50%;
  background:radial-gradient(circle,rgba(214,40,40,.22) 0%,transparent 70%);
  pointer-events:none;
}
.cta-banner::after{
  content:'🫕';position:absolute;right:8%;bottom:-10px;
  font-size:10rem;opacity:.07;line-height:1;pointer-events:none;
  transform:rotate(-15deg);
}
.cta-banner__inner{
  display:grid;grid-template-columns:1fr auto;
  gap:3rem;align-items:center;position:relative;z-index:1;
}
.cta-banner__tag{font-size:.68rem;font-weight:700;letter-spacing:.08em;color:rgba(255,255,255,.4);margin-bottom:.5rem}
.cta-banner__title{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(1.8rem,3.5vw,2.8rem);
  color:#fff;letter-spacing:.03em;line-height:1.1;margin-bottom:.65rem;
}
.cta-banner__title span{color:#D62828}
.cta-banner__sub{font-size:.88rem;color:rgba(255,255,255,.55);line-height:1.65;max-width:480px}
.cta-banner__btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:.9rem 2rem;border-radius:14px;
  background:#D62828;color:#fff;
  font-size:.85rem;font-weight:700;letter-spacing:.04em;
  text-decoration:none;white-space:nowrap;flex-shrink:0;
  box-shadow:0 4px 20px rgba(214,40,40,.35);
  transition:background .2s,transform .25s,box-shadow .25s;
}
.cta-banner__btn:hover{background:#B91C1C;transform:translateY(-2px);box-shadow:0 8px 30px rgba(214,40,40,.5)}

/* ══ Scroll-Reveal Animations ════════════════════════════════════════════ */

/* Elements start visible by default.
   JS adds .js to <html>, then .reveal hides them for scroll-reveal. */
html.js .reveal{
  opacity:0;
  transform:translateY(28px);
  transition:opacity .65s cubic-bezier(.22,1,.36,1),
             transform .65s cubic-bezier(.22,1,.36,1);
}
html.js .reveal.is-revealed{opacity:1;transform:none}

/* Directional variants */
html.js .reveal--left{transform:translateX(-32px)}
html.js .reveal--left.is-revealed{transform:none}
html.js .reveal--right{transform:translateX(32px)}
html.js .reveal--right.is-revealed{transform:none}
html.js .reveal--scale{transform:scale(.92);opacity:0}
html.js .reveal--scale.is-revealed{transform:none;opacity:1}

/* Stagger children (used on grids) */
html.js .reveal-stagger > .reveal:nth-child(1){transition-delay:0ms}
html.js .reveal-stagger > .reveal:nth-child(2){transition-delay:80ms}
html.js .reveal-stagger > .reveal:nth-child(3){transition-delay:160ms}
html.js .reveal-stagger > .reveal:nth-child(4){transition-delay:240ms}

/* Hero entrance (no JS needed, just CSS on load) */
.lp-hero__copy{
  animation:heroFadeIn .7s cubic-bezier(.22,1,.36,1) .1s both;
}
.lp-hero__visual{
  animation:heroFadeIn .7s cubic-bezier(.22,1,.36,1) .3s both;
}
@keyframes heroFadeIn{
  from{opacity:0;transform:translateY(20px)}
  to{opacity:1;transform:none}
}

/* Stats counter reveal */
.lp-hero__stats{
  animation:heroFadeIn .6s cubic-bezier(.22,1,.36,1) .55s both;
}

/* Interactive tilt on feat-cards */
.feat-card{transform-style:preserve-3d;perspective:600px}

/* Zone card slide-in */
.zone-card.reveal{transform:translateX(20px)}
.zone-card.reveal.is-revealed{transform:none}

/* Review card hover lift */
.review-card{
  transition:transform .3s cubic-bezier(.22,1,.36,1),box-shadow .3s;
}
.review-card:hover{
  transform:translateY(-5px);
  box-shadow:0 14px 36px rgba(0,0,0,.1);
}

/* CTA banner pulse effect */
.cta-banner__btn{position:relative;overflow:hidden}
.cta-banner__btn::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(105deg,transparent 40%,rgba(255,255,255,.15) 50%,transparent 60%);
  background-size:250% 100%;
  animation:ctaShimmer 3.5s linear infinite;
}
@keyframes ctaShimmer{
  0%{background-position:200% center}
  100%{background-position:-200% center}
}

/* ══ Responsive ══════════════════════════════════════════════════════════ */
@media(max-width:1120px){
  .feat-grid{grid-template-columns:repeat(2,1fr)}
  .reviews-grid{grid-template-columns:repeat(2,1fr)}
  .esencia-grid{grid-template-columns:repeat(2,1fr)}
}

@media(max-width:768px){
  .lp-hero{min-height:auto;padding:3rem 0 2.5rem}
  .lp-hero__inner{grid-template-columns:1fr;text-align:left;gap:2rem}
  .lp-hero__visual{order:1}
  .lp-hero__pizza{max-width:300px;margin:0 auto;display:block}
  .lp-hero__glow{width:320px;height:320px}
  .lp-hero__badge{margin:0 0 1.25rem}
  .lp-hero__sub{margin:0 0 2rem}
  .lp-hero__ctas{justify-content:flex-start}
  .lp-hero__stats{width:100%;justify-content:space-around;border-radius:14px}
  .lp-section{padding:3.5rem 0}
  .feat-grid{grid-template-columns:1fr}
  .esencia-grid{grid-template-columns:1fr}
  .reparto-inner{grid-template-columns:1fr;gap:2.5rem}
  .reviews-grid{grid-template-columns:1fr}
  .cta-banner__inner{grid-template-columns:1fr;text-align:center;gap:2rem}
  .cta-banner__sub{margin:0 auto}
  .cta-banner::after{display:none}
}

@media(max-width:480px){
  .lp-hero__title{font-size:2.8rem;letter-spacing:-1px}
  /* Stats: fila horizontal compacta */
  .lp-hero__stats{
    flex-direction:row;width:auto;border-radius:12px;
    display:inline-flex;
  }
  .lp-stat-sep{width:1px;height:auto}
  .lp-stat{padding:.45rem .8rem;text-align:center}
  .lp-stat strong{font-size:1rem}
  .lp-stat span{font-size:.52rem}
  .zone-card__details{flex-direction:column;gap:.35rem}
}

@media(prefers-reduced-motion:reduce){
  .lp-hero__pizza{animation:none}
  .lp-hero__dot{animation:none}
  .lp-hero__copy,.lp-hero__visual,.lp-hero__stats{animation:none}
  .feat-card,.esencia-card,.zone-card,.review-card{transition:none}
  html.js .reveal{opacity:1!important;transform:none!important;transition:none!important}
  .cta-banner__btn::after{animation:none}
}
