﻿.hero{min-height:78vh;background:linear-gradient(160deg,var(--cream2) 0%,var(--pearl) 40%,var(--cream3) 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:72px 40px 52px;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:-30%;right:-15%;width:700px;height:700px;background:radial-gradient(circle,rgba(201,169,110,.12) 0%,transparent 65%);pointer-events:none}
.hero::after{content:'';position:absolute;bottom:-20%;left:-10%;width:500px;height:500px;background:radial-gradient(circle,rgba(196,132,126,.09) 0%,transparent 65%);pointer-events:none}
.hero-eyebrow{font-size:11px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--gold2);margin-bottom:16px;display:flex;align-items:center;gap:12px}
.hero-eyebrow::before,.hero-eyebrow::after{content:'';width:40px;height:1px;background:var(--gold3)}
.hero h1{font-family:var(--serif);font-size:clamp(50px,9vw,100px);font-weight:300;line-height:1;color:var(--ink);margin-bottom:28px}
.hero h1 em{font-style:italic;color:var(--rose2)}.hero h1 .thin{font-weight:300;color:var(--mink)}
.hero-sub{font-size:16px;color:var(--mink);margin-bottom:32px;line-height:1.7;max-width:480px;font-weight:400}
.hero-sub strong{color:var(--ink2);font-weight:600}
.hero-ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:20px;margin-bottom:0}
.btn-gold{background:var(--ink);color:var(--gold3);border:none;padding:15px 36px;border-radius:4px;font-size:13px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;font-family:var(--sans);transition:all var(--transition);-webkit-tap-highlight-color:transparent}
.btn-gold:hover{background:var(--ink2);transform:translateY(-2px);box-shadow:0 8px 24px rgba(44,31,26,.2)}
.btn-outline{background:transparent;color:var(--ink);border:1.5px solid var(--cream4);padding:14px 36px;border-radius:4px;font-size:13px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;font-family:var(--sans);transition:all var(--transition)}
.btn-outline:hover{border-color:var(--gold);color:var(--gold2);transform:translateY(-2px)}
.hero-stats{display:flex;gap:48px;justify-content:center;flex-wrap:wrap;align-items:center;margin-top:32px}
.stat-item{text-align:center}
.stat-item[style*="width:1px"]{flex-shrink:0;align-self:stretch;min-width:1px!important;width:1px!important}
.stat-num{font-family:var(--serif);font-size:40px;font-weight:300;color:var(--ink);display:block;line-height:1;margin-bottom:4px;font-style:italic}
.stat-label{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--mink);font-weight:500}
.hero-ornament{position:absolute;opacity:.07;font-size:400px;color:var(--gold2);bottom:-80px;right:-60px;line-height:1;pointer-events:none;font-family:var(--serif);font-style:italic;font-weight:300}
.scroll-hint{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;opacity:.5;transition:opacity .3s}
.scroll-hint:hover{opacity:.9}
.scroll-hint-line{width:1px;height:32px;background:linear-gradient(to bottom,transparent,var(--gold))}
.scroll-hint-dot{width:5px;height:5px;background:var(--gold);border-radius:50%;animation:scrollPulse 1.6s ease-in-out infinite}
@keyframes scrollPulse{0%,100%{transform:translateY(0);opacity:.5}50%{transform:translateY(6px);opacity:1}}

.countdown-bar{background:var(--rose2);color:#fff;padding:16px 40px;display:flex;align-items:center;justify-content:center;gap:24px;flex-wrap:wrap}
@keyframes rgbShift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
.countdown-label{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:#fff;font-weight:700;text-shadow:0 1px 4px rgba(0,0,0,.3)}
.countdown-units{display:flex;gap:16px;align-items:center}
.cd-unit{text-align:center}
.cd-num{font-family:var(--serif);font-size:28px;font-weight:300;color:var(--gold3);display:block;line-height:1;min-width:40px;font-style:italic}
.cd-label{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.85);font-weight:500}
.cd-sep{font-family:var(--serif);font-size:24px;color:var(--gold);opacity:.5;font-style:italic;align-self:flex-start;margin-top:2px}

/* â”€â”€ Widget entrance animations â”€â”€ */
@keyframes widgetIn{from{opacity:0;transform:translateY(20px) scale(.96)}to{opacity:1;transform:none}}

/* â”€â”€ Widget row â€” desktop â”€â”€ */
.hero-widgets-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  grid-template-rows:auto;
  gap:10px;
  margin:28px auto 0;
  padding:0 16px;
  max-width:880px;
  align-items:stretch;
}
.hero-widgets-row .hwidget:nth-child(1){animation:widgetIn .55s cubic-bezier(.34,1.2,.64,1) .3s both}
.hero-widgets-row .hwidget:nth-child(2){animation:widgetIn .55s cubic-bezier(.34,1.2,.64,1) .45s both}
.hero-widgets-row .hwidget-packdia{animation:widgetIn .6s cubic-bezier(.34,1.2,.64,1) .6s both}

/* â”€â”€ Widget base â”€â”€ */
.hwidget{
  display:flex;align-items:center;gap:12px;
  padding:16px 16px;border-radius:20px;
  min-width:0;
  background:rgba(255,255,255,.82);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border:1.5px solid rgba(255,255,255,.9);
  box-shadow:0 4px 24px rgba(92,74,61,.07),0 1px 0 rgba(255,255,255,.95) inset;
  cursor:pointer;position:relative;overflow:hidden;
  transition:transform .28s cubic-bezier(.34,1.5,.64,1),box-shadow .28s;
}
.hwidget:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 14px 36px rgba(92,74,61,.13)}
.hwidget:active{transform:scale(.96)}

.hwidget-icon{
  font-size:32px;line-height:1;flex-shrink:0;
  filter:drop-shadow(0 3px 8px rgba(0,0,0,.1));
}
.hwidget-body{display:flex;flex-direction:column;gap:3px;min-width:0;flex:1}
.hwidget-title{
  font-size:9px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--mink);font-weight:700;opacity:.7;
}
.hwidget-val{
  font-family:var(--serif);font-size:21px;font-weight:300;
  color:var(--ink);line-height:1.1;font-style:italic;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.hwidget-sub{
  font-size:10px;color:var(--mink);line-height:1.35;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;opacity:.8;
}
.hwidget-pulse{
  position:absolute;top:12px;right:12px;
  width:8px;height:8px;border-radius:50%;
  background:var(--rose2);animation:hwRing 2.2s ease-out infinite;
}
@keyframes hwRing{
  0%{box-shadow:0 0 0 0 rgba(196,132,126,.55)}
  70%{box-shadow:0 0 0 9px rgba(196,132,126,0)}
  100%{box-shadow:0 0 0 0 rgba(196,132,126,0)}
}

/* Widget temas */
.hwidget-festivo{
  background:linear-gradient(150deg,rgba(255,237,228,.92),rgba(255,248,244,.95));
  border-color:rgba(220,155,130,.28);
}
.hwidget-clima{
  background:linear-gradient(150deg,rgba(224,240,255,.92),rgba(240,250,255,.95));
  border-color:rgba(110,175,230,.25);
}

/* â”€â”€ Chips de sugerencia en widgets â”€â”€ */
.wf-chips{
  display:flex;flex-wrap:wrap;gap:4px;margin-top:6px;
}
.wf-chip{
  display:inline-block;
  background:rgba(196,132,126,.12);
  border:1px solid rgba(196,132,126,.22);
  border-radius:30px;
  padding:3px 9px;
  font-size:9px;font-weight:700;
  color:var(--rose2);
  cursor:pointer;
  transition:background .2s,transform .15s;
  white-space:nowrap;
}
.wf-chip:hover{background:rgba(196,132,126,.22);transform:scale(1.04)}
.wf-chip-season{
  background:rgba(59,130,246,.08);
  border-color:rgba(59,130,246,.18);
  color:var(--ink2);
}

/* â”€â”€ Pack del dÃ­a â”€â”€ */
.hwidget-packdia{
  border-radius:20px;overflow:hidden;cursor:pointer;
  box-shadow:0 8px 32px rgba(92,74,61,.1);
  transition:transform .3s cubic-bezier(.34,1.3,.64,1),box-shadow .3s;
}
.hwidget-packdia:hover{transform:translateY(-4px);box-shadow:0 18px 44px rgba(92,74,61,.16)}
.hwidget-packdia:active{transform:scale(.98)}
.hpd-bg{
  background:linear-gradient(145deg,var(--pearl) 0%,var(--cream2) 55%,var(--rose3) 100%);
  border:1.5px solid rgba(196,132,126,.2);
  padding:16px 18px;display:flex;flex-direction:column;gap:9px;
  height:100%;position:relative;overflow:hidden;
}
.hpd-orb1{position:absolute;top:-50px;right:-30px;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(196,132,126,.12),transparent 70%);pointer-events:none}
.hpd-orb2{position:absolute;bottom:-60px;left:-10px;width:160px;height:160px;border-radius:50%;background:radial-gradient(circle,rgba(201,169,110,.09),transparent 70%);pointer-events:none}
.hpd-shine{position:absolute;top:0;left:-100%;width:55%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);transform:skewX(-18deg);animation:pdShine 6s ease-in-out infinite;pointer-events:none}
@keyframes pdShine{0%,100%{left:-100%}40%,60%{left:140%}}
.hpd-top{display:flex;justify-content:space-between;align-items:center}
.hpd-nombre{display:flex;align-items:center;gap:7px}
.hpd-emoji{font-size:16px;line-height:1}
.hpd-title{font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--rose2)}
.hpd-live{display:flex;align-items:center;gap:5px;font-size:9px;color:var(--mink);font-weight:700;letter-spacing:.09em;opacity:.65}
.hpd-dot{width:7px;height:7px;border-radius:50%;background:#66bb6a;flex-shrink:0;animation:hwRing 2.2s ease-out infinite}
.hpd-chips{display:flex;gap:5px;flex-wrap:wrap}
.hpd-chip-item{background:rgba(196,132,126,.1);border:1px solid rgba(196,132,126,.2);border-radius:40px;padding:3px 10px;font-size:10px;color:var(--mink);font-weight:600;white-space:nowrap}
.hpd-delivery{display:inline-flex;align-items:center;gap:6px;border-radius:40px;padding:4px 12px;font-size:10px;font-weight:700;letter-spacing:.04em;border:1px solid;transition:all .4s;width:fit-content}
.hpd-stock-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}
.hpd-stock-lbl{font-size:10px;font-weight:700;color:var(--mink)}
.hpd-stock-num{font-size:10px;font-weight:800;color:var(--rose2)}
.hpd-bar{height:5px;background:rgba(196,132,126,.15);border-radius:3px;overflow:hidden}
.hpd-bar-inner{height:100%;width:0%;border-radius:3px;transition:width 1.5s cubic-bezier(.34,1.1,.64,1)}
.hpd-foot{display:flex;justify-content:space-between;align-items:center;margin-top:2px}
.hpd-price-lbl{font-size:9px;color:var(--mink);opacity:.55;text-transform:uppercase;letter-spacing:.07em}
.hpd-price{font-family:var(--serif);font-size:24px;font-style:italic;font-weight:300;color:var(--ink);line-height:1.1}
.hpd-btn{
  background:var(--ink);color:var(--gold3);
  padding:10px 20px;border-radius:14px;
  font-size:11px;font-weight:800;letter-spacing:.07em;text-transform:uppercase;
  box-shadow:0 4px 16px rgba(44,31,26,.2);
  border:none;cursor:pointer;flex-shrink:0;
  transition:transform .22s,box-shadow .22s;
}
.hpd-btn:hover{transform:scale(1.04);box-shadow:0 6px 20px rgba(44,31,26,.3)}

/* ── Pack featured: foto de fondo ── */
.hpd-featured{padding:0!important;overflow:hidden}
.hpd-img-wrap{position:absolute;inset:0;z-index:0}
.hpd-img{width:100%;height:100%;object-fit:cover;object-position:center;transition:transform .5s ease}
.hpd-featured:hover .hpd-img{transform:scale(1.04)}
.hpd-img-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(20,10,5,.82) 0%,rgba(20,10,5,.35) 55%,rgba(20,10,5,.1) 100%)}
.hpd-featured .hpd-orb1,.hpd-featured .hpd-orb2,.hpd-featured .hpd-shine{z-index:1}
.hpd-featured .hpd-top,.hpd-featured .hpd-chips,.hpd-featured .hpd-delivery,
.hpd-featured .hpd-stock-head,.hpd-featured .hpd-bar,.hpd-featured .hpd-foot{position:relative;z-index:2}
.hpd-featured{display:flex;flex-direction:column;gap:9px;padding:16px 18px!important}
.hpd-featured .hpd-title{color:#fff!important;text-shadow:0 1px 4px rgba(0,0,0,.4)}
.hpd-featured .hpd-price{color:#fff!important}
.hpd-featured .hpd-price-lbl{color:rgba(255,255,255,.6)!important;opacity:1!important}
.hpd-featured .hpd-stock-lbl{color:rgba(255,255,255,.7)!important}
.hpd-featured .hpd-stock-num{color:var(--gold3)!important}
.hpd-featured .hpd-bar{background:rgba(255,255,255,.15)!important}
.hpd-featured .hpd-bar-inner{background:linear-gradient(90deg,var(--gold2),var(--gold3))!important}
.hpd-featured .hpd-delivery{color:rgba(255,255,255,.85)!important;border-color:rgba(255,255,255,.2)!important;background:rgba(255,255,255,.08)!important}
.hpd-featured .hpd-chip{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);border-radius:40px;padding:3px 10px;font-size:10px;color:rgba(255,255,255,.85);font-weight:600;white-space:nowrap}
/* Badge "El más solicitado" */
.hpd-hot{
  background:linear-gradient(135deg,var(--gold2),var(--gold));
  color:#fff!important;opacity:1!important;
  padding:4px 10px;border-radius:20px;
  font-size:9px!important;font-weight:800!important;letter-spacing:.06em;
  box-shadow:0 2px 8px rgba(201,169,110,.4);
  white-space:nowrap;
}

/* â”€â”€ MÃ“VIL: bento 2+1 compacto â”€â”€ */
/* -- MOVIL: columna vertical, cada widget full-width -- */
@media(max-width:600px){
  .hero-widgets-row{
    display:flex;
    flex-direction:column;
    gap:8px;
    padding:0 12px;
    margin-top:16px;
    max-width:100%;
  }

  /* Widgets pequenos: fila horizontal compacta */
  .hwidget{
    flex-direction:row;
    align-items:center;
    gap:12px;
    padding:14px 16px;
    border-radius:16px;
    min-height:unset;
  }
  .hwidget-icon{
    font-size:28px;
    margin-bottom:0;
    flex-shrink:0;
  }
  .hwidget-body{flex:1;min-width:0}
  .hwidget-title{font-size:9px;letter-spacing:.12em;margin-bottom:1px}
  .hwidget-val{
    font-size:18px;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
    line-height:1.2;
  }
  .hwidget-sub{
    font-size:10px;
    margin-top:2px;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
    line-height:1.3;
  }
  .hwidget-pulse{top:10px;right:10px}
  .wf-chips{display:none}

  /* Pack del dia: full width */
  .hwidget-packdia{
    border-radius:16px;
    box-shadow:0 6px 24px rgba(92,74,61,.12);
  }
  .hpd-bg{
    padding:14px 16px;
    gap:8px;
    flex-direction:column;
  }
  .hpd-top{width:100%}
  .hpd-chips{display:flex;flex-wrap:wrap;gap:4px}
  .hpd-delivery{font-size:10px;padding:4px 12px}
  .hpd-stock-head{display:flex}
  .hpd-bar{display:block}
  .hpd-foot{
    display:flex;align-items:center;
    justify-content:space-between;
    gap:10px;
    margin-top:0;
    border-top:1px solid rgba(196,132,126,.15);
    padding-top:10px;
  }
  .hpd-price{font-size:22px}
  .hpd-price-lbl{font-size:9px}
  .hpd-btn{
    padding:10px 20px;font-size:11px;
    border-radius:13px;
    flex-shrink:0;
  }
}

#live-sales-container{position:fixed;bottom:80px;left:16px;z-index:9000;display:flex;flex-direction:column-reverse;gap:8px;pointer-events:none}
.live-sale-notif{display:flex;align-items:center;gap:10px;background:rgba(253,250,247,.97);backdrop-filter:blur(6px);border:1px solid rgba(196,132,126,.25);border-radius:14px;padding:10px 14px;box-shadow:0 8px 28px rgba(92,74,61,.18);pointer-events:all;cursor:pointer;max-width:280px;animation:lsIn .5s cubic-bezier(.34,1.3,.64,1) both}
.ls-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--rose2),var(--gold));display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;color:#fff;font-weight:700}
.ls-body{display:flex;flex-direction:column;gap:1px;min-width:0}
.ls-name{font-size:11px;font-weight:700;color:var(--ink);letter-spacing:.02em}
.ls-product{font-size:10px;color:var(--mink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ls-time{font-size:9px;color:var(--gold2);font-weight:600;margin-top:1px}

#chat-bubble-wrap{position:fixed;bottom:76px;right:16px;z-index:9100;animation:chatIn .6s cubic-bezier(.34,1.3,.64,1) both}
#chat-bubble{display:flex;align-items:flex-start;gap:10px;background:rgba(253,250,247,.97);backdrop-filter:blur(8px);border:1px solid rgba(196,132,126,.22);border-radius:18px 18px 4px 18px;padding:12px 14px;box-shadow:0 10px 40px rgba(92,74,61,.22);cursor:pointer;max-width:240px;position:relative;transition:transform .2s}
#chat-bubble-avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--rose2),#e8a87c);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:18px;font-style:italic;color:#fff;font-weight:700;flex-shrink:0}

.why-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:2px}
@media(max-width:768px){.why-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.why-grid{grid-template-columns:repeat(1,1fr)}}
.why-card{
  padding:40px 28px;background:var(--cream2);text-align:center;
  transition:all var(--transition);position:relative;overflow:hidden;
}
.why-card::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(201,169,110,.08),transparent 60%);
  opacity:0;transition:opacity .3s;pointer-events:none;
}
.why-card:hover{background:var(--ink)}
.why-card:hover::before{opacity:1}
.why-stat{
  font-family:var(--serif);font-size:36px;font-weight:300;font-style:italic;
  color:var(--rose2);display:block;line-height:1;margin-bottom:6px;
  transition:color var(--transition);
}
.why-card:hover .why-stat{color:var(--gold3)}
.why-icon{font-size:32px;margin-bottom:16px;display:block;transition:transform .3s cubic-bezier(.34,1.4,.64,1)}
.why-card:hover .why-icon{transform:scale(1.18) rotate(-5deg)}
.why-card h4{font-family:var(--serif);font-size:17px;font-style:italic;font-weight:400;color:var(--ink);margin-bottom:8px;transition:color var(--transition)}
.why-card p{font-size:13px;color:var(--mink);line-height:1.6;transition:color var(--transition)}
.why-card:hover h4{color:var(--gold3)}
.why-card:hover p{color:rgba(255,255,255,.6)}

/* â”€â”€ Testimonios â”€â”€ */
.testimonios-section {
  padding: 80px 0 60px;
  background: var(--cream3);
  position: relative;
  overflow: hidden;
}
.testimonios-header {
  text-align: center;
  margin-bottom: 40px;
}
.rain-stage {
  height: 500px;
  position: relative;
  max-width: 1200px;
  margin: 0 auto;
}

/* â”€â”€ Videos Unboxing â”€â”€ */
.videos-section {
  padding: 80px 40px;
  background: var(--white);
}
.videos-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  max-width: 1320px;
  margin: 40px auto 0;
}
.video-card {
  position: relative;
  aspect-ratio: 9/16;
  background: var(--pearl);
  border-radius: var(--radius-lg);
  overflow: hidden;
  cursor: pointer;
  box-shadow: 0 10px 30px var(--shadow);
}
.video-card video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.video-play-btn {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,.2);
  transition: opacity .3s;
}
.video-card.playing .video-play-btn { opacity: 0; }
.video-play-icon {
  width: 60px;
  height: 60px;
  background: var(--white);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  color: var(--ink);
  box-shadow: 0 8px 24px rgba(0,0,0,.2);
}

/* â”€â”€ GalerÃ­a de Momentos â”€â”€ */
.moments-section {
  padding: 80px 20px;
  background: var(--cream2);
  overflow: hidden;
}
.moments-container {
  max-width: 1320px;
  margin: 0 auto;
}
.moments-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  padding: 20px 0;
}
.moment-card {
  background: var(--white);
  padding: 12px 12px 40px;
  border-radius: 4px;
  box-shadow: 0 10px 30px var(--shadow);
  transition: all .4s cubic-bezier(.4,0,.2,1);
  cursor: pointer;
  position: relative;
  overflow: hidden;
}
.moment-card:nth-child(even) { transform: rotate(2deg) translateY(10px); }
.moment-card:nth-child(odd) { transform: rotate(-2deg) translateY(-10px); }

.moment-card:hover {
  transform: scale(1.05) rotate(0) translateY(-10px);
  box-shadow: 0 20px 50px var(--shadow);
  z-index: 10;
}
.moment-img {
  width: 100%;
  aspect-ratio: 1;
  border-radius: 2px;
  overflow: hidden;
  background: var(--pearl);
}
.moment-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .6s;
}
.moment-card:hover .moment-img img { transform: scale(1.1); }

.moment-caption {
  position: absolute;
  bottom: 12px;
  left: 0;
  right: 0;
  text-align: center;
  font-family: var(--serif);
  font-style: italic;
  font-size: 14px;
  color: var(--mink);
}

@media (max-width: 900px) {
  .moments-grid { grid-template-columns: repeat(2, 1fr); gap: 16px; }
}
@media (max-width: 500px) {
  .moments-grid { grid-template-columns: 1fr; gap: 30px; }
}

/* â”€â”€ Autoscroll (Deprecado, pero mantenemos por si acaso) â”€â”€ */
.autoscroll-wrap {
  overflow: hidden;
  padding: 20px 0;
  position: relative;
}
.autoscroll-track {
  display: flex;
  gap: 20px;
  width: max-content;
  animation: scroll 40s linear infinite;
}
.autoscroll-track.reverse {
  animation-direction: reverse;
}
@keyframes scroll {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
.gallery-card {
  width: 220px;
  background: var(--white);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: 0 4px 12px var(--shadow2);
  flex-shrink: 0;
}
.gallery-card-img {
  height: 240px;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}
.gallery-card-body {
  padding: 15px;
}
.gallery-card-name {
  font-size: 14px;
  font-weight: 600;
  color: var(--ink);
  margin-bottom: 4px;
}
.gallery-card-price {
  font-size: 13px;
  color: var(--rose2);
  font-weight: 700;
}

/* â”€â”€ Videos mobile â”€â”€ */
@media(max-width:768px){
  .videos-section{padding:60px 16px}
  .videos-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .video-play-icon{width:44px;height:44px;font-size:16px}
}
@media(max-width:480px){
  .videos-section{padding:48px 12px}
  .videos-grid{grid-template-columns:repeat(2,1fr);gap:8px}
  .video-play-icon{width:36px;height:36px;font-size:14px}
  .video-label{font-size:10px}
}
.why-card:hover h4{color:var(--gold3)}
.why-card:hover p{color:rgba(255,255,255,.6)}

/* â”€â”€ Live Sales â”€â”€ */
@keyframes lsIn{from{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:none}}

/* â”€â”€ Chat Bubble Body â”€â”€ */
#chat-bubble-body{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}

/* â”€â”€ Festivo Sticker â”€â”€ */
.festivo-sticker{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.9);backdrop-filter:blur(6px);border:1.5px solid rgba(201,169,110,.3);border-radius:30px;padding:10px 20px;font-size:13px;font-weight:700;color:var(--ink);box-shadow:0 4px 20px var(--shadow);cursor:pointer;transition:all .3s}
.festivo-sticker:hover{transform:translateY(-2px);box-shadow:0 8px 28px var(--shadow)}
.festivo-sticker-emoji{font-size:20px}
.festivo-sticker-days{font-family:var(--serif);font-size:22px;font-style:italic;color:var(--rose2);margin:0 4px}

/* â”€â”€ Autoscroll extras â”€â”€ */
.autoscroll-wrap:hover .autoscroll-track{animation-play-state:paused}
.gallery-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.gallery-card:hover .gallery-card-img img{transform:scale(1.05)}

/* â”€â”€ Countdown bar mobile â”€â”€ */
@media(max-width:600px){
  .countdown-bar{padding:12px 16px;gap:12px}
  .cd-num{font-size:22px}
  .countdown-label{font-size:10px}
}

/* â”€â”€ Hero mobile â”€â”€ */
@media(max-width:768px){
  .hero{padding:70px 20px 48px;min-height:auto}
  .hero-stats{gap:16px;flex-wrap:wrap;justify-content:center}
  .stat-num{font-size:32px}
  .stat-item{min-width:80px}
  .stat-item[style*="width:1px"]{display:none}
}
@media(max-width:600px){
  .hero{padding:60px 16px 40px;min-height:auto}
  .hero-stats{gap:12px}
  .stat-num{font-size:26px}
  .hero-ctas{flex-direction:column;align-items:center}
  .btn-gold,.btn-outline{width:100%;max-width:280px}
  .hero h1{font-size:clamp(38px,11vw,60px)}
  .hero-sub{font-size:14px;margin-bottom:32px}
}

/* â”€â”€ Videos mobile â”€â”€ */
@media(max-width:480px){
  .videos-section{padding:60px 16px}
  .videos-grid{grid-template-columns:repeat(2,1fr);gap:10px}
}

/* â”€â”€ Why grid mobile â”€â”€ */
@media(max-width:768px){.why-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:400px){.why-grid{grid-template-columns:repeat(1,1fr)}.why-card{padding:28px 20px}}

/* â”€â”€ Testimonios mobile â”€â”€ */
@media(max-width:768px){
  .testimonios-section{padding:60px 0}
  .rain-stage{height:400px}
}
@media(max-width:480px){
  .rain-stage{height:320px}
  .rain-card{max-width:200px;min-width:160px;padding:12px 14px}
  .rain-text{font-size:12px}
}

/* â”€â”€ Moments mobile â”€â”€ */
@media(max-width:600px){
  .moments-section{padding:48px 12px}
  .moments-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .moment-card:nth-child(even),.moment-card:nth-child(odd){transform:none}
}

/* â”€â”€ Countdown bar mobile â”€â”€ */
@media(max-width:600px){
  .countdown-bar{padding:12px 16px;gap:12px}
  .cd-num{font-size:22px}
  .countdown-label{font-size:10px}
}

/* â”€â”€ Autoscroll mobile â”€â”€ */
@media(max-width:600px){
  .gallery-card{width:160px}
  .gallery-card-img{height:180px}
}

/* â”€â”€ Autoscroll Gallery â”€â”€ */
.autoscroll-section{overflow:hidden;padding:40px 0;background:var(--cream2);contain:layout}
.autoscroll-wrap{display:flex;flex-direction:column;gap:16px}
.autoscroll-row{display:flex;gap:12px;width:max-content;animation:scrollLeft 30s linear infinite;will-change:transform}





.autoscroll-row-reverse{animation-direction:reverse}
.autoscroll-row:hover{animation-play-state:paused}
@keyframes scrollLeft{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.autoscroll-item{flex-shrink:0;width:140px;cursor:pointer;border-radius:12px;overflow:hidden;background:var(--white);box-shadow:0 2px 12px rgba(44,31,26,.08);transition:transform .2s,box-shadow .2s;contain:layout style}
.autoscroll-item:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(44,31,26,.15)}
.autoscroll-item img{width:100%;height:140px;object-fit:cover;display:block}
.autoscroll-item-name{font-size:11px;font-weight:600;color:var(--ink);padding:6px 8px 2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.autoscroll-price{font-size:11px;color:var(--mink);padding:0 8px 8px}
@media(max-width:600px){
  .autoscroll-item{width:110px}
  .autoscroll-item img{height:110px}
}

/* â”€â”€ Lluvia de Fotos (Photo Rain) â”€â”€ */
.photo-rain-wrap {
  position: relative;
  height: 480px;
  overflow: hidden;
  margin-top: 40px;
  border-radius: 20px;
  background: linear-gradient(160deg, var(--pearl) 0%, var(--cream2) 100%);
}
.photo-rain-overlay-top {
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 100px;
  background: linear-gradient(to bottom, var(--cream3) 20%, transparent);
  z-index: 3; pointer-events: none;
}
.photo-rain-overlay-bottom {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 120px;
  background: linear-gradient(to top, var(--cream3) 20%, transparent);
  z-index: 3; pointer-events: none;
}
.photo-rain-counter {
  position: absolute;
  bottom: 28px; left: 50%; transform: translateX(-50%);
  z-index: 5;
  background: rgba(253,250,247,.95);
  backdrop-filter: blur(16px);
  border: 1px solid var(--cream4);
  border-radius: 40px;
  padding: 10px 28px;
  display: flex; align-items: center; gap: 10px;
  box-shadow: 0 8px 32px rgba(92,74,61,.15);
  white-space: nowrap;
}
.prc-num {
  font-family: var(--serif);
  font-size: 28px;
  font-style: italic;
  color: var(--rose2);
  font-weight: 300;
  line-height: 1;
}
.prc-label {
  font-size: 13px;
  font-weight: 600;
  color: var(--ink2);
}
.rain-card {
  background: var(--white);
  border-radius: 3px;
  padding: 5px 5px 18px;
  box-shadow: 0 3px 12px rgba(44,31,26,.14);
  transform: rotate(var(--rot, 0deg));
  cursor: pointer;
  position: relative;
  transition: transform .25s cubic-bezier(.34,1.3,.64,1), box-shadow .25s;
  flex-shrink: 0;
  overflow: hidden;
}
.rain-card:hover {
  transform: rotate(0deg) scale(1.08) !important;
  box-shadow: 0 10px 30px rgba(44,31,26,.22);
  z-index: 10;
}
.rain-card img {
  width: 100%;
  height: calc(100% - 16px);
  object-fit: cover;
  border-radius: 2px;
  display: block;
}
.rain-card-emoji {
  position: absolute;
  bottom: 3px; left: 0; right: 0;
  text-align: center;
  font-size: 11px;
  line-height: 1;
}
@media(max-width:768px) {
  .photo-rain-wrap { height: 360px; border-radius: 14px; }
  .photo-rain-overlay-top { height: 70px; }
  .photo-rain-overlay-bottom { height: 90px; }
  .prc-num { font-size: 22px; }
  .prc-label { font-size: 11px; }
  .photo-rain-counter { padding: 8px 18px; gap: 8px; bottom: 20px; }
}
@media(max-width:480px) {
  .photo-rain-wrap { height: 300px; }
}
body.dark-mode .photo-rain-wrap { background: linear-gradient(160deg, var(--cream4) 0%, var(--cream2) 100%); }
body.dark-mode .photo-rain-overlay-top { background: linear-gradient(to bottom, var(--cream3) 20%, transparent); }
body.dark-mode .photo-rain-overlay-bottom { background: linear-gradient(to top, var(--cream3) 20%, transparent); }
body.dark-mode .photo-rain-counter { background: rgba(30,21,16,.95); border-color: var(--cream4); }
body.dark-mode .prc-label { color: var(--ink); }
body.dark-mode .rain-card { background: var(--cream2); box-shadow: 0 3px 12px rgba(0,0,0,.3); }

.clientas-cta {
  text-align: center;
  margin-top: 48px;
  padding: 0 20px;
}
.btn-clientas-cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: #25d366;
  color: #fff;
  border: none;
  padding: 14px 32px;
  border-radius: 40px;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: .04em;
  cursor: pointer;
  font-family: var(--sans);
  text-decoration: none;
  box-shadow: 0 4px 20px rgba(37,211,102,.35);
  transition: all .25s;
}
.btn-clientas-cta:hover { transform: translateY(-2px); box-shadow: 0 8px 28px rgba(37,211,102,.45); }

@media(max-width:600px) {
  .clienta-item { width: 130px; height: 160px; }
}

/* â”€â”€ Reviews Carrusel â”€â”€ */
.reviews-carousel-wrap {
  overflow: hidden;
  padding: 8px 0 24px;
  position: relative;
}

.reviews-carousel-track {
  display: flex;
  gap: 16px;
  width: max-content;
  animation: reviewsScroll 45s linear infinite;
  will-change: transform;
}
.reviews-carousel-wrap:hover .reviews-carousel-track { animation-play-state: paused; }



@keyframes reviewsScroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
.rc-card {
  width: 280px;
  flex-shrink: 0;
  background: var(--white);
  border-radius: 18px;
  border: 1px solid var(--cream4);
  overflow: hidden;
  box-shadow: 0 4px 18px rgba(44,31,26,.07);
  transition: transform .25s, box-shadow .25s;
}
.rc-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 14px 36px rgba(44,31,26,.13);
}
.rc-img-wrap {
  width: 100%;
  height: 200px;
  overflow: hidden;
  background: var(--pearl);
}
.rc-img {
  width: 100%;
  height: 200px;
  object-fit: cover;
  display: block;
  transition: transform .4s;
}
.rc-card:hover .rc-img { transform: scale(1.04); }
.rc-body { padding: 14px 16px 16px; }
.rc-top {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
}
.rc-avatar {
  width: 34px; height: 34px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--rose2), var(--gold));
  color: #fff;
  font-size: 13px; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.rc-name { font-size: 13px; font-weight: 700; color: var(--ink); }
.rc-loc  { font-size: 11px; color: var(--mink); margin-top: 1px; }
.rc-stars { color: #ffc107; font-size: 12px; margin-left: auto; letter-spacing: 1px; }
.rc-text {
  font-size: 12px; color: var(--ink2); line-height: 1.65;
  font-style: italic; margin-bottom: 10px;
}
.rc-verified {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 10px; font-weight: 700; color: #22c55e;
  background: #f0fdf4; border: 1px solid #bbf7d0;
  border-radius: 20px; padding: 2px 8px;
}
.reviews-carousel-wrap::before,
.reviews-carousel-wrap::after {
  content: '';
  position: absolute;
  top: 0; bottom: 0;
  width: 80px;
  z-index: 2;
  pointer-events: none;
}
.reviews-carousel-wrap::before { left: 0;  background: linear-gradient(to right, var(--pearl), transparent); }
.reviews-carousel-wrap::after  { right: 0; background: linear-gradient(to left,  var(--pearl), transparent); }
@media(max-width:600px) {
  .rc-card { width: 220px; }
  .rc-img-wrap { height: 160px; }
  .rc-img  { height: 160px; }
}
body.dark-mode .rc-card { background: var(--cream2); border-color: var(--cream4); }
body.dark-mode .reviews-carousel-wrap::before { background: linear-gradient(to right, var(--cream3), transparent); }
body.dark-mode .reviews-carousel-wrap::after  { background: linear-gradient(to left,  var(--cream3), transparent); }
body.dark-mode .rc-verified { background: rgba(34,197,94,.1); border-color: rgba(34,197,94,.2); }

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   HERO â€” Contador de pedidos
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.hero-orders-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.85);backdrop-filter:blur(12px);
  border:1.5px solid rgba(196,132,126,.25);border-radius:30px;
  padding:8px 18px;font-size:13px;color:var(--ink2);
  margin-bottom:28px;box-shadow:0 4px 16px rgba(92,74,61,.08);
  animation:widgetIn .5s cubic-bezier(.34,1.2,.64,1) .2s both;
}
.hero-orders-dot{
  width:8px;height:8px;border-radius:50%;background:#22c55e;flex-shrink:0;
  animation:hwRing 2s ease-out infinite;
}
.hero-orders-badge strong{color:var(--rose2)}
body.dark-mode .hero-orders-badge{background:rgba(42,31,26,.85);border-color:rgba(196,132,126,.2)}


/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   LO NUEVO â€” Bento Grid
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.nuevos-section {
  padding: 80px 40px 60px;
  background: var(--white);
}
.nuevos-bento {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: 220px;
  gap: 14px;
  max-width: 1200px;
  margin: 0 auto;
}
/* Layout: 8 cuadros iguales, 4 por fila */
.nb-card {
  position: relative;
  border-radius: 18px;
  overflow: hidden;
  cursor: pointer;
  background: var(--pearl);
  box-shadow: 0 4px 20px rgba(44,31,26,.08);
  transition: transform .35s cubic-bezier(.34,1.2,.64,1), box-shadow .35s;
  -webkit-tap-highlight-color: transparent;
  min-height: 0;
  min-width: 0;
}
.nb-card:hover {
  transform: translateY(-5px) scale(1.01);
  box-shadow: 0 16px 44px rgba(44,31,26,.15);
}
.nb-card:active { transform: scale(.97); }

/* TamaÃ±os bento â€” desktop 4 cols x 4 rows */
.nb-card.nb-big   { grid-column: span 2; grid-row: span 2; }
.nb-card.nb-tall  { grid-column: span 1; grid-row: span 2; }
.nb-card.nb-wide  { grid-column: span 2; grid-row: span 1; }
.nb-card.nb-small { grid-column: span 1; grid-row: span 1; }

/* Imagen de fondo (tarjeta simple) */
.nb-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  transition: transform .55s cubic-bezier(.4,0,.2,1);
  will-change: transform;
  display: block;
}
.nb-card:hover .nb-img { transform: scale(1.06); }

/* â”€â”€ Collage grid â”€â”€ */
.nb-collage-card .nb-overlay { z-index: 2; }
.nb-collage-card .nb-content { z-index: 3; }
.nb-collage-card .nb-badge   { z-index: 4; }

.nb-collage-grid {
  position: absolute;
  inset: 0;
  display: grid;
  gap: 2px;
}
/* 4 fotos: 2x2 */
.nb-collage-4 {
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: repeat(2, 1fr);
}
/* 8 fotos: 4x2 */
.nb-collage-8 {
  grid-template-columns: repeat(4, 1fr);
  grid-template-rows: repeat(2, 1fr);
}
.nb-collage-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 20%;
  display: block;
  transition: transform .5s cubic-bezier(.4,0,.2,1);
}
.nb-card:hover .nb-collage-img { transform: scale(1.07); }

/* Overlay gradiente */
.nb-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(20,12,8,.75) 0%, rgba(20,12,8,.15) 50%, transparent 100%);
  transition: background .35s;
  z-index: 1;
}
.nb-card:hover .nb-overlay {
  background: linear-gradient(to top, rgba(20,12,8,.85) 0%, rgba(20,12,8,.3) 60%, transparent 100%);
}

/* Badge */
.nb-badge {
  position: absolute;
  top: 12px;
  left: 12px;
  background: var(--rose2);
  color: #fff;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .07em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 20px;
  z-index: 3;
  box-shadow: 0 2px 8px rgba(0,0,0,.2);
}
.nb-badge.gold {
  background: linear-gradient(135deg, var(--gold2), var(--gold));
  color: var(--ink);
}

/* Contenido inferior */
.nb-content {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: 18px 18px 20px;
  z-index: 2;
}
.nb-cat {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(255,255,255,.6);
  margin-bottom: 4px;
}
.nb-name {
  font-family: var(--serif);
  font-size: 18px;
  font-weight: 400;
  font-style: italic;
  color: #fff;
  line-height: 1.2;
  margin-bottom: 5px;
}
.nb-card.nb-big .nb-name { font-size: 26px; }
.nb-price {
  font-size: 13px;
  font-weight: 700;
  color: var(--gold3);
}

/* Hover reveal */
.nb-reveal {
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transition: max-height .35s ease, opacity .28s .05s;
}
.nb-card:hover .nb-reveal { max-height: 80px; opacity: 1; }
.nb-desc {
  font-size: 11px;
  color: rgba(255,255,255,.72);
  line-height: 1.5;
  margin-top: 7px;
  margin-bottom: 9px;
}
.nb-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: rgba(255,255,255,.14);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.28);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .05em;
  padding: 6px 14px;
  border-radius: 20px;
  cursor: pointer;
  font-family: var(--sans);
  transition: background .2s;
}
.nb-btn:hover { background: rgba(255,255,255,.26); }

/* Emoji placeholder */
.nb-emoji-bg {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 72px;
  opacity: .15;
  pointer-events: none;
}
.nb-card.nb-big .nb-emoji-bg { font-size: 110px; }

/* Temas de color */
.nb-card.nb-theme-rose   { background: linear-gradient(145deg, #f5e8e4, #edd5cf); }
.nb-card.nb-theme-gold   { background: linear-gradient(145deg, #f5edd8, #ede0c0); }
.nb-card.nb-theme-blue   { background: linear-gradient(145deg, #e4eef5, #d0e4f0); }
.nb-card.nb-theme-green  { background: linear-gradient(145deg, #e4f0e8, #d0e8d8); }
.nb-card.nb-theme-purple { background: linear-gradient(145deg, #ede4f5, #e0d0f0); }

/* â”€â”€ Tablet â”€â”€ */
@media(max-width:900px) {
  .nuevos-section { padding: 60px 20px 48px; }
  .nuevos-bento {
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: unset;
    grid-auto-rows: 220px;
    gap: 12px;
  }
  .nb-card.nb-big  { grid-column: span 2; grid-row: span 2; }
  .nb-card.nb-tall { grid-column: span 1; grid-row: span 2; }
  .nb-card.nb-wide { grid-column: span 2; grid-row: span 1; }
  .nb-card.nb-small{ grid-column: span 1; grid-row: span 1; }
  .nb-card.nb-big .nb-name { font-size: 22px; }
  /* Collage 8 fotos en tablet: 4 cols */
  .nb-collage-8 {
    grid-template-columns: repeat(4, 1fr);
    grid-template-rows: repeat(2, 1fr);
  }
}

/* â”€â”€ MÃ³vil â”€â”€ */
@media(max-width:560px) {
  .nuevos-section { padding: 48px 14px 40px; }
  .nuevos-bento {
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: unset;
    grid-auto-rows: 190px;
    gap: 10px;
  }
  .nb-card.nb-big  { grid-column: span 2; grid-row: span 2; }
  .nb-card.nb-tall { grid-column: span 1; grid-row: span 1; }
  .nb-card.nb-wide { grid-column: span 2; grid-row: span 1; }
  .nb-card.nb-small{ grid-column: span 1; grid-row: span 1; }
  .nb-name { font-size: 14px !important; }
  .nb-card.nb-big .nb-name { font-size: 16px !important; }
  .nb-price { font-size: 11px; }
  .nb-content { padding: 10px 12px 12px; }
  .nb-reveal { display: none; }
  .nb-badge { font-size: 9px; padding: 3px 8px; top: 8px; left: 8px; }
  .nb-cat { display: none; }
  /* Collage 8 fotos en móvil: 4 cols */
  .nb-collage-8 {
    grid-template-columns: repeat(4, 1fr);
    grid-template-rows: repeat(2, 1fr);
  }
}

/* Dark mode */
body.dark-mode .nb-card { box-shadow: 0 4px 20px rgba(0,0,0,.3); }
body.dark-mode .nb-card.nb-theme-rose   { background: linear-gradient(145deg, #3a2420, #2e1c18); }
body.dark-mode .nb-card.nb-theme-gold   { background: linear-gradient(145deg, #3a3020, #2e2418); }
body.dark-mode .nb-card.nb-theme-blue   { background: linear-gradient(145deg, #1c2a38, #162030); }
body.dark-mode .nb-card.nb-theme-green  { background: linear-gradient(145deg, #1c3028, #162420); }
body.dark-mode .nb-card.nb-theme-purple { background: linear-gradient(145deg, #2a1c38, #201630); }
body.dark-mode .nb-badge { background: rgba(255,255,255,.92); color: #1a0e08; }
body.dark-mode .nb-badge.gold { background: rgba(201,169,110,.95); color: #1a0e08; }

/* â”€â”€ CAJITA SECTION â”€â”€ */
.cajita-section {
  padding: 0;
  background: #fdf6f0;
  overflow: hidden;
  position: relative;
}
.cajita-section::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent 0%, #d4a030 30%, #e8b4c0 60%, #d4a030 80%, transparent 100%);
}
.cajita-section::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent 0%, #d4a030 30%, #e8b4c0 60%, #d4a030 80%, transparent 100%);
}
body.dark-mode .cajita-section { background: #0e0a07; }

/* media-only variant */
.cajita-section--media-only {
  padding: 60px 24px 80px;
  text-align: center;
}
.cajita-section--media-only .section-head {
  margin-bottom: 48px;
}

/* ── FICHA TECNICA cards ── */
.cajita-ficha {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  grid-template-rows: repeat(3, 1fr);
  gap: 14px;
  max-width: 1000px;
  height: 520px;
  margin: 0 auto;
}

/* card individual */
.cajita-card {
  position: relative;
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid rgba(184,134,11,.15);
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 4px 24px rgba(0,0,0,.08);
  transition: transform .2s, box-shadow .2s;
}
.cajita-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(0,0,0,.13);
}
body.dark-mode .cajita-card {
  background: #1a1208;
  border-color: rgba(212,160,48,.2);
}

/* badge top */
.cajita-card-badge {
  position: absolute;
  top: 12px; left: 12px;
  z-index: 2;
  background: rgba(212,160,48,.9);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  padding: 4px 10px;
  border-radius: 999px;
  letter-spacing: .04em;
  backdrop-filter: blur(4px);
}
.cajita-card-badge--brown { background: rgba(120,80,40,.85); }
.cajita-card-badge--video { background: rgba(30,30,30,.8); }

/* tamaños bento para cajita */
.cajita-card--video { grid-column: 1; grid-row: 1 / span 3; }
.cajita-card--small { grid-column: 2; grid-row: span 1; }
.cajita-card--small:nth-child(2) { grid-column: 2; }
.cajita-card--small:nth-child(3) { grid-column: 2; }
.cajita-card--small:nth-child(4) { grid-column: 2; }

/* imagen ocupa todo el card */
.cajita-card-img-wrap {
  position: relative;
  width: 100%;
  height: 100%;
  background: #f8f4ee;
  overflow: hidden;
  flex: 1;
}
body.dark-mode .cajita-card-img-wrap { background: #120e06; }

.cajita-card-img {
  width: 100%; height: 100%;
  object-fit: contain;
  display: block;
  mix-blend-mode: multiply;
  padding: 8px;
  box-sizing: border-box;
}
.cajita-card-video {
  object-fit: cover;
  padding: 0;
  mix-blend-mode: normal;
}
body.dark-mode .cajita-card-img { mix-blend-mode: normal; }

/* Variante cover — para fotos que deben llenar el contenedor */
.cajita-card-img--cover {
  object-fit: contain;
  object-position: center;
  padding: 20px;
  mix-blend-mode: normal;
  background: #f9ddd8;
}

/* etiquetas de medida — REEMPLAZADAS por flechas SVG */
.cajita-msr { display: none; } /* legacy — ya no se usa */

/* flechas de medida estilo diagrama tecnico */
.cajita-arrow {
  position: absolute;
  display: flex;
  align-items: center;
  z-index: 3;
  pointer-events: none;
}
/* horizontal (largo) — abajo */
.cajita-arrow--h {
  flex-direction: row;
  gap: 2px;
}
.cajita-arrow--bottom {
  bottom: 10px;
  left: 10%; right: 10%;
  justify-content: center;
}
.cajita-arrow-line-h {
  flex: 1;
  height: 1px;
  background: #5a3e10;
  opacity: .6;
}
/* vertical (alto) — derecha */
.cajita-arrow--v {
  flex-direction: column;
  gap: 2px;
  right: 10px;
  top: 10%; bottom: 10%;
  justify-content: center;
}
.cajita-arrow-line-v {
  flex: 1;
  width: 1px;
  background: #5a3e10;
  opacity: .6;
}
.cajita-arrow-tip {
  font-size: 7px;
  color: #5a3e10;
  line-height: 1;
}
.cajita-arrow-val {
  font-size: 11px;
  font-weight: 700;
  color: #3a2a10;
  background: rgba(255,248,220,.92);
  border: 1px solid rgba(184,134,11,.35);
  padding: 2px 7px;
  border-radius: 4px;
  white-space: nowrap;
  box-shadow: 0 1px 4px rgba(0,0,0,.1);
}
.cajita-arrow-val--v {
  writing-mode: vertical-rl;
  text-orientation: mixed;
  transform: rotate(180deg);
  padding: 7px 2px;
}
body.dark-mode .cajita-arrow-val {
  background: rgba(30,20,8,.92);
  border-color: rgba(212,160,48,.4);
  color: #f0e0c0;
}
body.dark-mode .cajita-arrow-tip,
body.dark-mode .cajita-arrow-line-h,
body.dark-mode .cajita-arrow-line-v { color: #c8a040; background: #c8a040; }

/* botón play/pausa del video */
.cajita-video-btn {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 52px; height: 52px;
  border-radius: 50%;
  background: rgba(0,0,0,.45);
  backdrop-filter: blur(6px);
  border: 2px solid rgba(255,255,255,.5);
  color: #fff;
  font-size: 20px;
  cursor: pointer;
  z-index: 4;
  display: flex; align-items: center; justify-content: center;
  transition: background .2s, transform .2s, opacity .3s;
  opacity: 0;
}
.cajita-card--video:hover .cajita-video-btn,
.cajita-card--video:focus-within .cajita-video-btn { opacity: 1; }
.cajita-video-btn:hover { background: rgba(212,160,48,.7); transform: translate(-50%,-50%) scale(1.1); }

/* nombre como etiqueta overlay sobre la imagen */
.cajita-card-overlay-name {
  position: absolute;
  bottom: 10px;
  left: 10px;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(184,134,11,.25);
  color: #3a2a10;
  font-size: 12px;
  font-weight: 700;
  padding: 5px 12px;
  border-radius: 999px;
  box-shadow: 0 2px 8px rgba(0,0,0,.1);
  z-index: 3;
}
body.dark-mode .cajita-card-overlay-name {
  background: rgba(20,14,4,.88);
  border-color: rgba(212,160,48,.3);
  color: #f0e0c0;
}

/* info section */
.cajita-card-info {
  padding: 14px 16px 16px;
  border-top: 1px solid rgba(184,134,11,.1);
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1;
}
.cajita-card-name {
  font-size: 15px;
  font-weight: 800;
  color: var(--ink);
}
body.dark-mode .cajita-card-name { color: #f5ede0; }

.cajita-card-desc {
  font-size: 13px;
  color: #9a8070;
  margin: 0;
  line-height: 1.5;
}
body.dark-mode .cajita-card-desc { color: #a09080; }

/* tabla */
.cajita-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.cajita-table th {
  background: rgba(212,160,48,.08);
  color: #8a6a20;
  font-weight: 700;
  padding: 6px 10px;
  text-align: left;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .05em;
}
.cajita-table td {
  padding: 6px 10px;
  color: var(--ink);
  border-top: 1px solid rgba(0,0,0,.04);
}
.cajita-table td strong { color: #5a3e10; font-weight: 700; }
body.dark-mode .cajita-table th { background: rgba(212,160,48,.08); color: #c8a040; }
body.dark-mode .cajita-table td { color: #e0d0c0; border-color: rgba(255,255,255,.05); }
body.dark-mode .cajita-table td strong { color: #f0d080; }

@media (max-width: 760px) {
  .cajita-ficha {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: unset;
    height: auto;
    gap: 10px;
  }
  .cajita-card--video { grid-column: 1 / span 2; grid-row: 1; min-height: 220px; }
  .cajita-card--small { grid-column: span 1 !important; grid-row: auto; min-height: 160px; }
}
@media (min-width: 761px) and (max-width: 1060px) {
  .cajita-ficha {
    max-width: 860px;
    height: 400px;
  }
}


/* specs chips */
.cajita-specs {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  max-width: min(520px, 92vw);
}
.cajita-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: rgba(255,255,255,.8);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(184,134,11,.22);
  color: #5a3e28;
  font-size: 12px;
  font-weight: 600;
  padding: 6px 14px;
  border-radius: 999px;
  white-space: nowrap;
  box-shadow: 0 1px 6px rgba(0,0,0,.06);
  transition: transform .15s, box-shadow .15s;
  cursor: default;
}
.cajita-chip:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 14px rgba(212,160,48,.22);
}
body.dark-mode .cajita-chip {
  background: rgba(255,255,255,.07);
  border-color: rgba(212,160,48,.25);
  color: #f0e0cc;
  box-shadow: none;
}
body.dark-mode .cajita-chip:hover {
  background: rgba(212,160,48,.15);
}
body.dark-mode .cslide-img {
  mix-blend-mode: normal;
}

.cajita-orb1 { width: 500px; height: 500px; background: #d4a030; top: -100px; left: -100px; }
.cajita-orb2 { width: 400px; height: 400px; background: #c06080; bottom: -80px; right: -80px; }
.cajita-section .cajita-orb1,
.cajita-section .cajita-orb2 {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
  filter: blur(80px);
  opacity: 0;
}
body.dark-mode .cajita-section .cajita-orb1,
body.dark-mode .cajita-section .cajita-orb2 { opacity: .18; }

.cajita-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  align-items: stretch;
  min-height: 560px;
}

/* â”€â”€ LADO TEXTO â”€â”€ */
.cajita-text {
  padding: 70px 60px 70px 40px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
  z-index: 1;
}
.cajita-text .section-eyebrow {
  color: #b8860b;
  letter-spacing: .12em;
  font-size: 11px;
  text-transform: uppercase;
  font-weight: 700;
}
body.dark-mode .cajita-text .section-eyebrow { color: #d4a030; }

.cajita-title {
  font-family: var(--serif);
  font-size: clamp(2.2rem, 4vw, 3.2rem);
  font-weight: 400;
  color: var(--ink);
  margin: 10px 0 18px;
  line-height: 1.15;
}
.cajita-title em { color: #b8860b; font-style: italic; }
body.dark-mode .cajita-title { color: #f5ede0; }
body.dark-mode .cajita-title em { color: #d4a030; }

.cajita-desc {
  color: var(--ink2);
  font-size: 15px;
  line-height: 1.75;
  margin-bottom: 28px;
  max-width: 400px;
}
body.dark-mode .cajita-desc { color: rgba(245,237,224,.65); }

.cajita-features {
  list-style: none;
  padding: 0;
  margin: 0 0 32px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.cajita-features li {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 14px;
  color: var(--ink2);
}
body.dark-mode .cajita-features li { color: rgba(245,237,224,.8); }

.cajita-feat-icon {
  width: 28px; height: 28px;
  background: rgba(184,134,11,.1);
  border: 1px solid rgba(184,134,11,.25);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 13px;
  flex-shrink: 0;
}
body.dark-mode .cajita-feat-icon {
  background: rgba(212,160,48,.15);
  border-color: rgba(212,160,48,.3);
}

/* stats row */
.cajita-stats {
  display: flex;
  gap: 28px;
  margin-bottom: 32px;
  padding-top: 24px;
  border-top: 1px solid rgba(0,0,0,.08);
}
body.dark-mode .cajita-stats { border-top-color: rgba(255,255,255,.08); }

.cajita-stat { text-align: center; }
.cajita-stat-num {
  font-family: var(--serif);
  font-size: 1.8rem;
  color: #b8860b;
  font-weight: 400;
  line-height: 1;
}
body.dark-mode .cajita-stat-num { color: #d4a030; }

.cajita-stat-lbl {
  font-size: 11px;
  color: var(--ink3, #a09080);
  margin-top: 4px;
  text-transform: uppercase;
  letter-spacing: .06em;
}
body.dark-mode .cajita-stat-lbl { color: rgba(245,237,224,.45); }

.cajita-text .btn-gold {
  align-self: flex-start;
  background: var(--gold);
  color: #1a0e08;
  font-weight: 700;
  padding: 14px 28px;
  border-radius: 40px;
  font-size: 14px;
  letter-spacing: .04em;
  border: none;
  cursor: pointer;
  transition: transform .2s, box-shadow .2s;
}
.cajita-text .btn-gold:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(212,160,48,.35);
}

/* â”€â”€ LADO MEDIA â”€â”€ */
.cajita-media {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 50px 40px 50px 20px;
  z-index: 1;
}
.cajita-slider {
  position: relative;
  background: transparent;
}
body.dark-mode .cajita-slider {
  box-shadow: none;
}

/* slides */
.cslide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity .5s ease;
  pointer-events: none;
}
.cslide.active {
  opacity: 1;
  pointer-events: auto;
}
.cslide-img {
  width: 100%; height: 100%;
  object-fit: contain;
  display: block;
  background: transparent;
  mix-blend-mode: multiply; /* funde el fondo blanco del PNG con el fondo de la sección */
}

/* video badge */
.cslide-play-badge {
  position: absolute;
  bottom: 14px; left: 14px;
  background: rgba(0,0,0,.5);
  backdrop-filter: blur(8px);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  padding: 5px 12px;
  border-radius: 20px;
  letter-spacing: .06em;
}

/* arrows */
.cslide-arrow {
  position: absolute;
  top: 50%; transform: translateY(-50%);
  background: rgba(255,255,255,.2);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.25);
  color: #fff;
  width: 48px; height: 48px;
  border-radius: 50%;
  font-size: 28px;
  line-height: 1;
  cursor: pointer;
  z-index: 10;
  display: flex; align-items: center; justify-content: center;
  transition: background .2s;
  text-shadow: 0 1px 4px rgba(0,0,0,.4);
}
.cslide-arrow:hover { background: rgba(212,160,48,.6); }
.cslide-prev { left: 16px; }
.cslide-next { right: 16px; }

/* dots */
.cslide-dots {
  position: absolute;
  bottom: 14px; left: 50%;
  transform: translateX(-50%);
  display: flex; gap: 6px;
  z-index: 10;
}
.cslide-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: rgba(255,255,255,.4);
  border: none; cursor: pointer; padding: 0;
  transition: background .3s, transform .3s;
}
.cslide-dot.active {
  background: #d4a030;
  transform: scale(1.3);
}

/* glow */
.cajita-glow {
  position: absolute;
  inset: -40px;
  background: radial-gradient(ellipse at 50% 60%, rgba(240,220,80,.25) 0%, transparent 65%);
  pointer-events: none;
  z-index: -1;
  animation: cajitaGlow 4s ease-in-out infinite alternate;
}
@keyframes cajitaGlow {
  from { opacity: .4; transform: scale(.9); }
  to   { opacity: 1;  transform: scale(1.1); }
}

/* floating tags */
.cajita-float-tag {
  position: absolute;
  background: #fff;
  border: 1px solid rgba(184,134,11,.2);
  color: var(--ink);
  font-size: 12px;
  font-weight: 600;
  padding: 7px 14px;
  border-radius: 20px;
  box-shadow: 0 4px 16px rgba(0,0,0,.1);
  white-space: nowrap;
  animation: cajitaFloat 3.5s ease-in-out infinite;
  z-index: 2;
}
body.dark-mode .cajita-float-tag {
  background: rgba(255,255,255,.06);
  backdrop-filter: blur(12px);
  border-color: rgba(255,255,255,.12);
  color: #f5ede0;
  box-shadow: none;
}
.cajita-tag1 { top: 10px; left: -30px; animation-delay: 0s; }
.cajita-tag2 { top: 38%; right: -36px; animation-delay: 1s; }
.cajita-tag3 { bottom: 20px; left: -20px; animation-delay: 2s; }
@keyframes cajitaFloat {
  0%,100% { transform: translateY(0px); }
  50%      { transform: translateY(-10px); }
}

/* JS tilt */
.cajita-3d-wrap.tilting .cajita-3d-card { transition: transform .08s linear; }

@media (max-width: 900px) {
  .cajita-inner { grid-template-columns: 1fr; min-height: auto; }
  .cajita-text { padding: 50px 24px 30px; }
  .cajita-media { padding: 10px 24px 50px; }
  .cajita-slider { width: 100%; max-width: 340px; height: 320px; margin: 0 auto; }
  .cajita-tag1 { left: -10px; }
  .cajita-tag2 { right: -10px; }
  .cajita-tag3 { left: 0; }
  .cajita-stats { gap: 20px; }
}



/* ════════════════════════════════════════════════
   HERO — Badges, Categorías rápidas
   ════════════════════════════════════════════════ */

/* Badge de pedidos en vivo */
.hero-orders-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(255,255,255,.85);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(201,169,110,.3);
  border-radius: 30px;
  padding: 8px 18px;
  font-size: 13px;
  font-weight: 600;
  color: var(--ink2);
  margin-bottom: 20px;
  box-shadow: 0 4px 16px rgba(92,74,61,.1);
  animation: badgePop .6s cubic-bezier(.34,1.4,.64,1) .2s both;
}
.hero-orders-dot {
  width: 8px; height: 8px;
  background: #ef4444;
  border-radius: 50%;
  animation: hwRing 2s ease-out infinite;
  flex-shrink: 0;
}
@keyframes badgePop {
  from { opacity: 0; transform: translateY(8px) scale(.9); }
  to   { opacity: 1; transform: none; }
}
body.dark-mode .hero-orders-badge {
  background: rgba(42,31,26,.88);
  border-color: rgba(201,169,110,.25);
  color: var(--ink);
}

/* Categorías rápidas */
.hero-cats-grid {
  display: flex;
  gap: 10px;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 28px;
}
.hero-cat-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  background: rgba(255,255,255,.82);
  backdrop-filter: blur(16px);
  border: 1.5px solid rgba(255,255,255,.9);
  border-radius: 16px;
  padding: 14px 20px;
  cursor: pointer;
  font-family: var(--sans);
  transition: transform .25s cubic-bezier(.34,1.4,.64,1), box-shadow .25s, border-color .2s;
  box-shadow: 0 4px 16px rgba(92,74,61,.07);
  min-width: 90px;
}
.hero-cat-btn:hover {
  transform: translateY(-4px) scale(1.04);
  box-shadow: 0 12px 28px rgba(92,74,61,.14);
  border-color: rgba(201,169,110,.5);
}
.hero-cat-btn:active { transform: scale(.96); }
.hero-cat-icon { font-size: 26px; line-height: 1; }
.hero-cat-name { font-size: 12px; font-weight: 700; color: var(--ink); letter-spacing: .02em; }
.hero-cat-price { font-size: 10px; color: var(--mink); font-weight: 500; }

body.dark-mode .hero-cat-btn {
  background: rgba(42,31,26,.88);
  border-color: rgba(61,46,38,.8);
}
body.dark-mode .hero-cat-name { color: var(--ink); }

@media (max-width: 600px) {
  .hero-cats-grid { gap: 8px; margin-top: 20px; }
  .hero-cat-btn { padding: 12px 14px; min-width: 76px; border-radius: 14px; }
  .hero-cat-icon { font-size: 22px; }
  .hero-cat-name { font-size: 11px; }
  .hero-cat-price { font-size: 9px; }
}

/* ════════════════════════════════════════════════
   CÓMO FUNCIONA
   ════════════════════════════════════════════════ */
.how-section {
  padding: 80px 40px;
  max-width: 1200px;
  margin: 0 auto;
}
.how-steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  align-items: stretch;
  gap: 14px;
  max-width: 760px;
  margin: 0 auto 40px;
}
.how-step {
  min-width: 0;
  text-align: center;
  padding: 24px 16px;
  background: var(--white);
  border: 1px solid var(--cream4);
  border-radius: 20px;
  position: relative;
  transition: transform .28s cubic-bezier(.34,1.2,.64,1), box-shadow .28s;
}
.how-step:hover {
  transform: translateY(-6px);
  box-shadow: 0 16px 40px rgba(92,74,61,.12);
}
.how-step-num {
  font-family: var(--serif);
  font-size: 32px;
  font-weight: 300;
  font-style: italic;
  color: var(--cream4);
  line-height: 1;
  margin-bottom: 6px;
}
.how-step-icon {
  font-size: 30px;
  margin-bottom: 8px;
  display: block;
  transition: transform .3s cubic-bezier(.34,1.4,.64,1);
}
.how-step:hover .how-step-icon { transform: scale(1.15) rotate(-5deg); }
.how-step-title {
  font-family: var(--serif);
  font-size: 16px;
  font-weight: 400;
  font-style: italic;
  color: var(--ink);
  margin-bottom: 6px;
}
.how-step-desc {
  font-size: 11.5px;
  color: var(--mink);
  line-height: 1.5;
}
.how-step-arrow { display: none; }
.how-cta {
  text-align: center;
  margin-top: 8px;
}

body.dark-mode .how-step {
  background: var(--cream2);
  border-color: var(--cream4);
}
body.dark-mode .how-step-title { color: var(--ink); }
body.dark-mode .how-step-desc { color: var(--mink); }

@media (max-width: 768px) {
  .how-section { padding: 60px 20px; }
  .how-steps { grid-template-columns: repeat(3, 1fr); gap: 10px; }
  .how-step { max-width: 100%; width: 100%; }
}
@media (max-width: 480px) {
  .how-steps { grid-template-columns: 1fr; gap: 10px; max-width: 320px; }
  .how-step { padding: 20px 16px; }
}

/* ════════════════════════════════════════════════
   LO NUEVO — Bento
   ════════════════════════════════════════════════ */
.nuevos-section {
  padding: 80px 40px;
  max-width: 1200px;
  margin: 0 auto;
}
.nuevos-bento {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.nuevos-bento-card {
  background: var(--white);
  border: 1px solid var(--cream4);
  border-radius: 20px;
  overflow: hidden;
  cursor: pointer;
  position: relative;
  transition: transform .28s cubic-bezier(.34,1.2,.64,1), box-shadow .28s, border-color .2s;
}
.nuevos-bento-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 16px 40px rgba(92,74,61,.14);
  border-color: rgba(201,169,110,.5);
}
.nuevos-bento-card:active { transform: scale(.98); }
.nuevos-bento-card--large {
  grid-column: span 2;
}
.nuevos-bento-img {
  width: 100%;
  aspect-ratio: 1/1;
  object-fit: cover;
  display: block;
  transition: transform .5s cubic-bezier(.4,0,.2,1);
}
.nuevos-bento-card--large .nuevos-bento-img {
  aspect-ratio: 2/1;
}
.nuevos-bento-card:hover .nuevos-bento-img { transform: scale(1.05); }
.nuevos-bento-body {
  padding: 14px 16px 16px;
}
.nuevos-bento-name {
  font-family: var(--serif);
  font-size: 15px;
  font-weight: 400;
  font-style: italic;
  color: var(--ink);
  margin-bottom: 4px;
}
.nuevos-bento-price {
  font-family: var(--serif);
  font-size: 18px;
  color: var(--rose2);
  font-style: italic;
}
.nuevos-bento-badge {
  position: absolute;
  top: 12px;
  left: 12px;
  background: var(--rose2);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 4px;
  z-index: 2;
}

body.dark-mode .nuevos-bento-card {
  background: var(--cream2);
  border-color: var(--cream4);
}
body.dark-mode .nuevos-bento-name { color: var(--ink); }
body.dark-mode .nuevos-bento-price { color: var(--rose2); }

@media (max-width: 768px) {
  .nuevos-section { padding: 60px 20px; }
  .nuevos-bento { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .nuevos-bento-card--large { grid-column: span 2; }
}
@media (max-width: 480px) {
  .nuevos-bento { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .nuevos-bento-card--large { grid-column: span 2; }
  .nuevos-bento-card--large .nuevos-bento-img { aspect-ratio: 16/9; }
}

/* ════════════════════════════════════════════════
   NUEVOS BENTO — nb-card grid
   ════════════════════════════════════════════════ */
.nuevos-bento {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: 240px;
  gap: 14px;
  max-width: 1200px;
  margin: 0 auto;
}

/* Tamaños */
.nb-big  { grid-column: span 2; grid-row: span 2; }
.nb-wide { grid-column: span 2; grid-row: span 1; }
.nb-small{ grid-column: span 1; grid-row: span 1; }

/* Card base */
.nb-card {
  position: relative;
  border-radius: 20px;
  overflow: hidden;
  cursor: pointer;
  transition: transform .28s cubic-bezier(.34,1.2,.64,1), box-shadow .28s;
  contain: layout style paint;
}
.nb-card:hover {
  transform: translateY(-5px) scale(1.01);
  box-shadow: 0 20px 48px rgba(92,74,61,.18);
}
.nb-card:active { transform: scale(.98); }

/* Imagen de fondo */
.nb-img {
  width: 100%; height: 100%;
  object-fit: cover;
  position: absolute; inset: 0;
  transition: transform .5s cubic-bezier(.4,0,.2,1);
}
.nb-card:hover .nb-img { transform: scale(1.06); }

/* Emoji fallback */
.nb-emoji-bg {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 72px;
  background: linear-gradient(145deg, var(--pearl), var(--cream2));
}

/* Overlay gradiente */
.nb-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(20,12,8,.75) 0%, rgba(20,12,8,.1) 55%, transparent 100%);
  z-index: 1;
  transition: opacity .3s;
}
.nb-card:hover .nb-overlay { opacity: .9; }

/* Badge */
.nb-badge {
  position: absolute; top: 14px; left: 14px;
  background: rgba(255,255,255,.92);
  color: var(--ink);
  font-size: 10px; font-weight: 700;
  letter-spacing: .06em; text-transform: uppercase;
  padding: 4px 10px; border-radius: 4px;
  z-index: 3; backdrop-filter: blur(8px);
}
.nb-badge.gold { background: rgba(201,169,110,.92); color: var(--ink); }

/* Contenido */
.nb-content {
  position: absolute; bottom: 0; left: 0; right: 0;
  padding: 20px 18px 18px;
  z-index: 2;
}
.nb-cat {
  font-size: 10px; font-weight: 700; letter-spacing: .1em;
  text-transform: uppercase; color: rgba(255,255,255,.65);
  margin-bottom: 4px;
}
.nb-name {
  font-family: var(--serif);
  font-size: 18px; font-weight: 400; font-style: italic;
  color: #fff; line-height: 1.2; margin-bottom: 4px;
}
.nb-big .nb-name { font-size: 22px; }
.nb-price {
  font-family: var(--serif);
  font-size: 15px; font-style: italic;
  color: var(--gold3); margin-bottom: 0;
}

/* Reveal al hover */
.nb-reveal {
  max-height: 0; overflow: hidden;
  transition: max-height .3s cubic-bezier(.4,0,.2,1), margin .3s;
}
.nb-card:hover .nb-reveal { max-height: 80px; margin-top: 8px; }
.nb-desc {
  font-size: 11px; color: rgba(255,255,255,.75);
  line-height: 1.5; margin-bottom: 8px;
}
.nb-btn {
  background: rgba(255,255,255,.15);
  border: 1px solid rgba(255,255,255,.3);
  color: #fff; font-size: 10px; font-weight: 700;
  letter-spacing: .07em; text-transform: uppercase;
  padding: 6px 14px; border-radius: 6px;
  cursor: pointer; font-family: var(--sans);
  backdrop-filter: blur(8px);
  transition: background .2s;
}
.nb-btn:hover { background: rgba(255,255,255,.25); }

/* Temas de color de fondo (cuando no hay imagen) */
.nb-theme-gold   { background: linear-gradient(145deg, #f4e8c8, #e8d5a0); }
.nb-theme-rose   { background: linear-gradient(145deg, #f4ddd8, #e8c4bc); }
.nb-theme-blue   { background: linear-gradient(145deg, #d8e8f4, #c0d8ec); }
.nb-theme-green  { background: linear-gradient(145deg, #d8f0e0, #b8e0c8); }
.nb-theme-purple { background: linear-gradient(145deg, #e8d8f4, #d4c0ec); }

/* Collage grid */
.nb-collage-card { overflow: hidden; }
.nb-collage-grid {
  position: absolute; inset: 0;
  display: grid; gap: 2px;
}
.nb-collage-4 { grid-template-columns: 1fr 1fr; grid-template-rows: 1fr 1fr; }
.nb-collage-6 { grid-template-columns: repeat(3, 1fr); grid-template-rows: 1fr 1fr; }
.nb-collage-8 { grid-template-columns: repeat(4, 1fr); grid-template-rows: 1fr 1fr; }
.nb-collage-img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .5s cubic-bezier(.4,0,.2,1);
}
.nb-collage-card:hover .nb-collage-img { transform: scale(1.08); }

/* Responsive */
@media (max-width: 900px) {
  .nuevos-bento {
    grid-template-columns: repeat(2, 1fr);
    grid-auto-rows: 200px;
    gap: 12px;
  }
  .nb-big  { grid-column: span 2; grid-row: span 2; }
  .nb-wide { grid-column: span 2; }
  .nb-small{ grid-column: span 1; }
}
@media (max-width: 600px) {
  .nuevos-section { padding: 48px 16px; }
  .nuevos-bento {
    grid-template-columns: repeat(2, 1fr);
    grid-auto-rows: 160px;
    gap: 10px;
  }
  .nb-name { font-size: 14px; }
  .nb-big .nb-name { font-size: 16px; }
  .nb-price { font-size: 13px; }
  .nb-content { padding: 14px 12px 12px; }
  .nb-badge { font-size: 9px; padding: 3px 8px; top: 10px; left: 10px; }
  .nb-reveal { display: none; }
}

/* ════════════════════════════════════════════════
   HERO — Duo de Packs Destacados
   ════════════════════════════════════════════════ */

/* Contenedor duo */
.hfp-duo {
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  gap: 14px;
  width: min(100%, 780px);
  margin: 0 auto 20px;
  animation: hfpIn .6s cubic-bezier(.34,1.2,.64,1) .25s both;
}
@keyframes hfpIn {
  from { opacity:0; transform:translateY(16px) scale(.97); }
  to   { opacity:1; transform:none; }
}

/* Tarjeta base */
.hfp-card {
  position: relative;
  border-radius: 22px;
  overflow: hidden;
  cursor: pointer;
  box-shadow: 0 16px 48px rgba(44,31,26,.22);
  transition: transform .32s cubic-bezier(.34,1.2,.64,1), box-shadow .32s;
  -webkit-tap-highlight-color: transparent;
}
.hfp-card:hover { transform: translateY(-6px) scale(1.015); box-shadow: 0 28px 64px rgba(44,31,26,.3); }
.hfp-card:active { transform: scale(.98); }
.hfp-card--main { height: 340px; }
.hfp-card--side { height: 340px; }

/* Imagen */
.hfp-card-img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover; object-position: center 80%;
  transition: transform .5s ease;
  z-index: 0;
}
.hfp-card:hover .hfp-card-img { transform: scale(1.07); }

/* Overlay */
.hfp-card-overlay {
  position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(to top, rgba(6,3,1,.92) 0%, rgba(6,3,1,.55) 45%, rgba(6,3,1,.08) 75%, transparent 100%);
}

/* Badge */
.hfp-card-badge {
  position: absolute; top: 14px; left: 14px; z-index: 3;
  background: linear-gradient(135deg, var(--gold2), var(--gold));
  color: #fff; font-size: 9px; font-weight: 800;
  letter-spacing: .12em; text-transform: uppercase;
  padding: 5px 13px; border-radius: 20px;
  box-shadow: 0 3px 14px rgba(201,169,110,.55);
  white-space: nowrap;
}
.hfp-card-badge--alt {
  background: linear-gradient(135deg, var(--rose2), #d4607a);
  box-shadow: 0 3px 14px rgba(196,132,126,.5);
}

/* Cuerpo */
.hfp-card-body {
  position: absolute; bottom: 0; left: 0; right: 0; z-index: 2;
  padding: 20px 18px 18px;
  display: flex; flex-direction: column; gap: 6px;
}
.hfp-card-name {
  font-family: var(--serif); font-size: 20px; font-weight: 400;
  font-style: italic; color: #fff; line-height: 1.2;
}
.hfp-card--side .hfp-card-name { font-size: 17px; }
.hfp-card-includes {
  font-size: 11px; color: rgba(255,255,255,.58); font-weight: 500; line-height: 1.4;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.hfp-card-footer {
  display: flex; align-items: center; justify-content: space-between;
  margin-top: 6px; gap: 10px;
}
.hfp-card-price {
  font-family: var(--serif); font-size: 26px; font-style: italic;
  font-weight: 300; color: #fff; white-space: nowrap; line-height: 1;
}
.hfp-card--side .hfp-card-price { font-size: 22px; }
.hfp-card-btn {
  background: rgba(255,255,255,.95); color: var(--ink);
  border: none; border-radius: 12px;
  padding: 9px 18px; font-size: 11px; font-weight: 800;
  letter-spacing: .05em; cursor: pointer; font-family: var(--sans);
  transition: background .15s, transform .15s, box-shadow .15s;
  white-space: nowrap; flex-shrink: 0;
}
.hfp-card-btn:hover { background: var(--gold3); transform: scale(1.06); box-shadow: 0 4px 14px rgba(201,169,110,.4); }

/* Ocultar widgets */
#w-festivo, #w-clima, .hero-widgets-row { display: none !important; }

/* hero-orders-badge spacing */
.hero-orders-badge { margin-bottom: 16px; margin-top: 4px; }

/* Dark mode */
body.dark-mode .hfp-card { box-shadow: 0 16px 48px rgba(0,0,0,.5); }
body.dark-mode .hfp-card-btn { background: var(--cream2); color: var(--ink); }

/* Mobile */
@media (max-width: 640px) {
  .hfp-duo { grid-template-columns: 1fr; gap: 10px; width: 100%; }
  .hfp-card--main { height: 260px; }
  .hfp-card--side { height: 200px; }
  .hfp-card { border-radius: 18px; }
  .hfp-card-name { font-size: 18px; }
  .hfp-card--side .hfp-card-name { font-size: 15px; }
  .hfp-card-price { font-size: 22px; }
  .hfp-card--side .hfp-card-price { font-size: 19px; }
  .hfp-card-btn { padding: 8px 14px; font-size: 10px; }
  .hfp-card-body { padding: 16px 14px 14px; }
  .hero-widgets-row { display: none !important; }
}
@media (max-width: 400px) {
  .hfp-card--main { height: 230px; }
  .hfp-card--side { height: 180px; }
}

