/* ================================================================
   VINARTES HOME v3.0 — CSS
   !important en todo para ganarle a Elementor
   Espaciado garantizado: 40px mínimo entre secciones
   20px mínimo entre párrafos
   30px mínimo de padding en formularios
   ================================================================ */

#vhApp,#vhApp *{box-sizing:border-box !important}
#vhApp h1,#vhApp h2,#vhApp h3,#vhApp h4,#vhApp p,#vhApp ul,#vhApp li,
#vhApp input,#vhApp textarea,#vhApp button,#vhApp a{
  margin:0 !important;padding:0 !important;font-family:inherit !important;
  line-height:inherit !important;border-radius:0 !important;border:none !important;
  outline:none !important;box-shadow:none !important;background:none !important}

#vhApp{
  --or:#AD5207;--navy:#021F67;--gray:#54595F;--cream:#F7F3EE;
  --gold:#C9A84C;--w:#ffffff;--blk:#0D0D0D;
  --fd:Georgia,'Times New Roman',serif;
  --fb:'Helvetica Neue',Arial,sans-serif;
  --ease:cubic-bezier(.4,0,.2,1);
  font-family:var(--fb) !important;font-size:18px !important;
  line-height:1.65 !important;color:var(--gray) !important;
  background:var(--w) !important;overflow-x:clip !important;
  -webkit-font-smoothing:antialiased;width:100% !important;max-width:100% !important;position:relative !important}

/* ── Wrapper central ── */
#vhApp .vh-wrap{
  width:100% !important;max-width:1200px !important;
  margin:0 auto !important;padding:0 64px !important}
@media(max-width:1024px){#vhApp .vh-wrap{padding:0 40px !important}}
@media(max-width:768px) {#vhApp .vh-wrap{padding:0 24px !important}}

/* ── Labels ── */
#vhApp .vh-section-label{
  display:block !important;font-family:var(--fb) !important;
  font-size:11px !important;font-weight:700 !important;
  letter-spacing:.22em !important;text-transform:uppercase !important;
  color:var(--or) !important;margin-bottom:18px !important;line-height:1 !important}
#vhApp .vh-label-light{color:rgba(255,255,255,.5) !important}

/* ── Títulos de sección ── */
#vhApp .vh-section-title{
  font-family:var(--fd) !important;font-size:clamp(1.9rem,3.5vw,2.9rem) !important;
  font-weight:700 !important;line-height:1.12 !important;letter-spacing:-.02em !important;
  color:var(--navy) !important;margin-bottom:56px !important}
#vhApp .vh-section-title span{color:var(--or) !important;font-style:italic !important}

/* ════════════════════════════════════════════
   HERO
   ════════════════════════════════════════════ */
#vhApp .vh-hero{
  position:relative !important;width:100% !important;overflow:hidden !important;background:var(--blk) !important}

/* ── Slider — altura controlada por breakpoint ── */
#vhApp .vh-slider{
  position:relative !important;width:100% !important;
  height:88vh !important;min-height:520px !important;max-height:860px !important;
  overflow:hidden !important}
/* Tablet */
@media(max-width:1024px){#vhApp .vh-slider{height:70vh !important;min-height:480px !important;max-height:640px !important}}
/* Mobile */
@media(max-width:600px){#vhApp .vh-slider{height:auto !important;min-height:0 !important;max-height:none !important;padding-bottom:0 !important}}

#vhApp .vh-slide{
  position:absolute !important;inset:0 !important;opacity:0 !important;
  transition:opacity 1s var(--ease) !important;pointer-events:none !important}
#vhApp .vh-slide.is-active{opacity:1 !important;pointer-events:auto !important}
/* Mobile: position static para que el slide tenga altura real */
@media(max-width:600px){
  #vhApp .vh-slide{position:relative !important;inset:auto !important;display:none !important}
  #vhApp .vh-slide.is-active{display:block !important}}

#vhApp .vh-slide-bg{
  position:absolute !important;inset:0 !important;
  background-size:cover !important;background-position:center !important;
  transform:scale(1.06) !important;transition:transform 9s var(--ease) !important}
#vhApp .vh-slide.is-active .vh-slide-bg{transform:scale(1) !important}
/* Mobile: bg se convierte en imagen de fondo de altura fija */
@media(max-width:600px){
  #vhApp .vh-slide-bg{position:relative !important;width:100% !important;height:280px !important;}}

#vhApp .vh-slide-ink{
  position:absolute !important;inset:0 !important;
  background:
    linear-gradient(to right,rgba(2,31,103,.82) 0%,rgba(2,31,103,.38) 55%,rgba(0,0,0,.12) 100%),
    linear-gradient(to top,rgba(0,0,0,.62) 0%,transparent 55%) !important}

/* ── Cuerpo del slide ── */
#vhApp .vh-slide-body{
  position:absolute !important;inset:0 !important;
  display:flex !important;flex-direction:column !important;justify-content:center !important;
  padding:60px 7% !important;z-index:2 !important;max-width:800px !important}
@media(max-width:1024px){#vhApp .vh-slide-body{padding:48px 6% !important}}
@media(max-width:600px){
  #vhApp .vh-slide-body{
    position:relative !important;inset:auto !important;
    padding:32px 24px 40px !important;max-width:100% !important;
    background:var(--navy) !important}}

#vhApp .vh-eyebrow{
  display:inline-block !important;font-family:var(--fb) !important;
  font-size:10px !important;font-weight:700 !important;letter-spacing:.22em !important;
  text-transform:uppercase !important;color:rgba(255,255,255,.7) !important;
  margin-bottom:20px !important;line-height:1 !important;
  opacity:0 !important;transform:translateY(18px) !important;
  transition:opacity .7s .3s,transform .7s .3s !important}
#vhApp .vh-slide.is-active .vh-eyebrow{opacity:1 !important;transform:translateY(0) !important}
@media(max-width:600px){#vhApp .vh-eyebrow{margin-bottom:14px !important;opacity:1 !important;transform:none !important}}

/* ── HEADLINE — tamaños escalonados por breakpoint ── */
#vhApp .vh-headline{
  font-family:var(--fd) !important;
  font-size:5.5rem !important;  /* Desktop base */
  font-weight:700 !important;line-height:.97 !important;letter-spacing:-.03em !important;
  color:var(--w) !important;margin-bottom:20px !important;
  opacity:0 !important;transform:translateY(28px) !important;
  transition:opacity .8s .5s,transform .8s .5s !important}
/* Laptop / tablet grande */
@media(max-width:1200px){#vhApp .vh-headline{font-size:4.2rem !important}}
/* Tablet */
@media(max-width:1024px){#vhApp .vh-headline{font-size:3.2rem !important;line-height:1.05 !important}}
/* Tablet chico */
@media(max-width:768px) {#vhApp .vh-headline{font-size:2.6rem !important;line-height:1.08 !important;margin-bottom:14px !important}}
/* Mobile */
@media(max-width:600px) {#vhApp .vh-headline{font-size:2.1rem !important;line-height:1.1 !important;margin-bottom:12px !important;opacity:1 !important;transform:none !important}}
@media(max-width:400px) {#vhApp .vh-headline{font-size:1.8rem !important}}

#vhApp .vh-slide.is-active .vh-headline{opacity:1 !important;transform:translateY(0) !important}
#vhApp .vh-headline em{font-style:italic !important;color:var(--gold) !important;display:block !important}

#vhApp .vh-tagline{
  font-family:var(--fb) !important;font-size:1rem !important;
  color:rgba(255,255,255,.8) !important;font-weight:300 !important;
  letter-spacing:.03em !important;margin-bottom:32px !important;line-height:1.55 !important;
  opacity:0 !important;transform:translateY(18px) !important;
  transition:opacity .7s .7s,transform .7s .7s !important}
@media(max-width:768px){#vhApp .vh-tagline{font-size:.9rem !important;margin-bottom:24px !important}}
@media(max-width:600px){#vhApp .vh-tagline{opacity:1 !important;transform:none !important;margin-bottom:20px !important}}
#vhApp .vh-slide.is-active .vh-tagline{opacity:1 !important;transform:translateY(0) !important}

#vhApp .vh-hero-actions{
  opacity:0 !important;transform:translateY(18px) !important;
  transition:opacity .7s .9s,transform .7s .9s !important}
#vhApp .vh-slide.is-active .vh-hero-actions{opacity:1 !important;transform:translateY(0) !important}
@media(max-width:600px){#vhApp .vh-hero-actions{opacity:1 !important;transform:none !important}}

#vhApp .vh-cta-primary{
  display:inline-flex !important;align-items:center !important;gap:10px !important;
  background:var(--or) !important;color:var(--w) !important;font-family:var(--fb) !important;
  font-size:13px !important;font-weight:700 !important;letter-spacing:.08em !important;
  text-transform:uppercase !important;text-decoration:none !important;
  padding:15px 28px !important;border-radius:4px !important;
  box-shadow:0 6px 24px rgba(173,82,7,.4) !important;
  transition:background .3s,transform .3s !important;line-height:1 !important;
  white-space:nowrap !important}
#vhApp .vh-cta-primary:hover{background:#bf5c09 !important;transform:translateY(-2px) !important}
@media(max-width:600px){#vhApp .vh-cta-primary{font-size:12px !important;padding:13px 22px !important}}

/* Flechas — ocultar en mobile para no tapar texto */
#vhApp .vh-arrow{
  position:absolute !important;top:50% !important;transform:translateY(-50%) !important;
  width:44px !important;height:44px !important;background:rgba(255,255,255,.1) !important;
  border:1.5px solid rgba(255,255,255,.25) !important;border-radius:50% !important;
  color:var(--w) !important;display:flex !important;align-items:center !important;
  justify-content:center !important;cursor:pointer !important;z-index:10 !important;
  backdrop-filter:blur(6px) !important;transition:background .3s,transform .3s !important}
#vhApp .vh-arrow:hover{
  background:var(--or) !important;border-color:var(--or) !important;
  transform:translateY(-50%) scale(1.1) !important}
#vhApp .vh-arrow-l{left:16px !important}
#vhApp .vh-arrow-r{right:16px !important}
#vhApp .vh-arrow svg{display:block !important;width:18px !important;height:18px !important}
@media(max-width:600px){#vhApp .vh-arrow-l{left:8px !important}#vhApp .vh-arrow-r{right:8px !important}}

#vhApp .vh-dots{
  position:absolute !important;bottom:32px !important;left:50% !important;
  transform:translateX(-50%) !important;display:flex !important;gap:10px !important;z-index:10 !important}
#vhApp .vh-dot{
  width:8px !important;height:8px !important;border-radius:50% !important;
  background:rgba(255,255,255,.4) !important;border:none !important;
  cursor:pointer !important;padding:0 !important;
  transition:background .3s,width .3s,border-radius .3s !important}
#vhApp .vh-dot.is-on{background:var(--or) !important;width:28px !important;border-radius:4px !important}

#vhApp .vh-hero-badge{
  position:absolute !important;top:28px !important;right:36px !important;z-index:20 !important;
  background:rgba(255,255,255,.1) !important;backdrop-filter:blur(8px) !important;
  border:1px solid rgba(255,255,255,.2) !important;border-radius:12px !important;
  padding:10px 14px !important}
#vhApp .vh-hero-badge img{display:block !important}
@media(max-width:600px){#vhApp .vh-hero-badge{display:none !important}}

/* ════════════════════════════════════════════
   PILARES
   ════════════════════════════════════════════ */
#vhApp .vh-pillars{padding-top:100px !important;padding-bottom:100px !important;background:var(--w) !important}

#vhApp .vh-pillars-grid{
  display:grid !important;grid-template-columns:repeat(3,1fr) !important;
  gap:0 !important;border:1px solid #E0DBD4 !important;border-radius:20px !important;overflow:hidden !important}
@media(max-width:900px){#vhApp .vh-pillars-grid{grid-template-columns:1fr !important}}

#vhApp .vh-pillar{
  padding:56px 48px !important;background:var(--w) !important;
  border-right:1px solid #E0DBD4 !important;transition:background .4s !important;position:relative !important}
#vhApp .vh-pillar:last-child{border-right:none !important}
#vhApp .vh-pillar:hover{background:var(--cream) !important}
@media(max-width:900px){
  #vhApp .vh-pillar{border-right:none !important;border-bottom:1px solid #E0DBD4 !important}
  #vhApp .vh-pillar:last-child{border-bottom:none !important}}

#vhApp .vh-pillar--mid{background:var(--navy) !important;border-right:1px solid rgba(255,255,255,.08) !important}
#vhApp .vh-pillar--mid:hover{background:#042d8a !important}

#vhApp .vh-pillar-num{
  font-family:var(--fd) !important;font-size:3rem !important;font-weight:700 !important;
  color:#E0DBD4 !important;line-height:1 !important;margin-bottom:24px !important;
  letter-spacing:-.04em !important;display:block !important}
#vhApp .vh-pillar--mid .vh-pillar-num{color:rgba(255,255,255,.12) !important}

#vhApp .vh-pillar-ico{
  width:68px !important;height:68px !important;border:1.5px solid #E0DBD4 !important;
  border-radius:50% !important;display:flex !important;align-items:center !important;
  justify-content:center !important;color:var(--or) !important;margin-bottom:28px !important}
#vhApp .vh-pillar--mid .vh-pillar-ico{border-color:rgba(255,255,255,.2) !important;color:var(--gold) !important}
#vhApp .vh-pillar-ico svg{display:block !important}

#vhApp .vh-pillar h3{
  font-family:var(--fd) !important;font-size:1.4rem !important;font-weight:700 !important;
  color:var(--navy) !important;line-height:1.25 !important;margin-bottom:20px !important}
#vhApp .vh-pillar--mid h3{color:var(--w) !important}

#vhApp .vh-pillar p{
  font-family:var(--fb) !important;font-size:15px !important;
  line-height:1.82 !important;color:var(--gray) !important}
#vhApp .vh-pillar--mid p{color:rgba(255,255,255,.7) !important}

#vhApp .vh-pillar-line{
  width:36px !important;height:2px !important;background:var(--or) !important;
  margin-top:28px !important;display:block !important}
#vhApp .vh-pillar--mid .vh-pillar-line{background:var(--gold) !important}

/* ════════════════════════════════════════════
   MANIFESTO
   ════════════════════════════════════════════ */
#vhApp .vh-manifesto{
  padding-top:100px !important;padding-bottom:100px !important;
  background:var(--navy) !important;position:relative !important;overflow:hidden !important;width:100% !important}
#vhApp .vh-manifesto::before{
  content:'VINARTES' !important;position:absolute !important;
  font-family:var(--fd) !important;font-size:18vw !important;font-weight:700 !important;
  color:rgba(255,255,255,.03) !important;letter-spacing:-.05em !important;
  top:50% !important;left:50% !important;transform:translate(-50%,-50%) !important;
  white-space:nowrap !important;pointer-events:none !important}

#vhApp .vh-manifesto-inner{
  max-width:820px !important;margin:0 auto !important;
  padding:0 60px !important;text-align:center !important}
@media(max-width:768px){#vhApp .vh-manifesto-inner{padding:0 32px !important}}

#vhApp .vh-manifesto-quote{
  font-family:var(--fd) !important;font-size:7rem !important;line-height:.5 !important;
  color:var(--or) !important;margin-bottom:36px !important;display:block !important}

#vhApp .vh-manifesto-text{
  font-family:var(--fd) !important;font-size:clamp(1.1rem,2.2vw,1.5rem) !important;
  line-height:1.72 !important;color:rgba(255,255,255,.85) !important;font-style:italic !important;letter-spacing:.01em !important}
#vhApp .vh-manifesto-text strong{color:var(--w) !important;font-style:normal !important}

#vhApp .vh-manifesto-firma{
  display:flex !important;align-items:center !important;justify-content:center !important;
  gap:16px !important;margin-top:48px !important;
  border-top:1px solid rgba(255,255,255,.1) !important;padding-top:32px !important}
#vhApp .vh-manifesto-firma span{
  font-family:var(--fb) !important;font-size:11px !important;
  letter-spacing:.14em !important;text-transform:uppercase !important;color:rgba(255,255,255,.45) !important}
#vhApp .vh-manifesto-firma img{display:block !important;border-radius:8px !important;opacity:.85 !important}

/* ════════════════════════════════════════════
   SOBRE EL EVENTO
   ════════════════════════════════════════════ */
#vhApp .vh-about{padding-top:120px !important;padding-bottom:120px !important;background:var(--cream) !important}

#vhApp .vh-about-grid{
  display:grid !important;grid-template-columns:1fr 1fr !important;
  gap:80px !important;align-items:center !important;width:100% !important}
#vhApp .vh-about-grid > *{min-width:0 !important;max-width:100% !important}
@media(max-width:960px){#vhApp .vh-about-grid{grid-template-columns:1fr !important;gap:60px !important}}

#vhApp .vh-img-stack{position:relative !important;padding-bottom:56px !important;padding-right:56px !important}
#vhApp .vh-img-main{
  width:100% !important;border-radius:20px !important;display:block !important;
  box-shadow:0 24px 72px rgba(2,31,103,.16) !important;aspect-ratio:4/5 !important;
  object-fit:cover !important;object-position:center !important}

#vhApp .vh-img-float{
  position:absolute !important;bottom:0 !important;right:0 !important;width:195px !important;
  border-radius:14px !important;overflow:hidden !important;
  box-shadow:0 16px 48px rgba(173,82,7,.28) !important;border:5px solid var(--w) !important}
#vhApp .vh-img-float img{width:100% !important;display:block !important}

#vhApp .vh-img-badge{
  position:absolute !important;top:36px !important;right:-16px !important;
  background:var(--or) !important;color:var(--w) !important;border-radius:14px !important;
  padding:16px 20px !important;text-align:center !important;
  box-shadow:0 8px 24px rgba(173,82,7,.4) !important}
#vhApp .vh-img-badge-num{
  display:block !important;font-family:var(--fd) !important;font-size:2rem !important;
  font-weight:700 !important;line-height:1 !important;color:var(--w) !important}
#vhApp .vh-img-badge-txt{
  display:block !important;font-family:var(--fb) !important;font-size:10px !important;
  letter-spacing:.1em !important;text-transform:uppercase !important;opacity:.85 !important;
  margin-top:5px !important;line-height:1.5 !important;color:var(--w) !important}

#vhApp .vh-about-title{
  font-family:var(--fd) !important;font-size:clamp(1.85rem,3.5vw,2.9rem) !important;
  font-weight:700 !important;line-height:1.12 !important;letter-spacing:-.025em !important;
  color:var(--navy) !important;margin-bottom:32px !important}
#vhApp .vh-about-title span{color:var(--or) !important;font-style:italic !important}

#vhApp .vh-about-text p{
  font-family:var(--fb) !important;font-size:16px !important;line-height:1.85 !important;
  margin-bottom:20px !important;color:var(--gray) !important}
#vhApp .vh-about-text p strong{color:var(--navy) !important}

#vhApp .vh-about-stats{
  display:flex !important;align-items:center !important;gap:28px !important;
  padding:32px 0 !important;border-top:1px solid #D8D2C8 !important;
  border-bottom:1px solid #D8D2C8 !important;margin:36px 0 !important}
#vhApp .vh-stat{text-align:center !important}
#vhApp .vh-stat-n{
  display:block !important;font-family:var(--fd) !important;font-size:2.2rem !important;
  font-weight:700 !important;color:var(--or) !important;line-height:1 !important}
#vhApp .vh-stat-l{
  display:block !important;font-family:var(--fb) !important;font-size:11px !important;
  color:var(--gray) !important;letter-spacing:.06em !important;text-transform:uppercase !important;
  margin-top:6px !important;line-height:1.5 !important}
#vhApp .vh-stat-div{width:1px !important;height:44px !important;background:#D8D2C8 !important;flex-shrink:0 !important}

#vhApp .vh-ig-link{
  display:inline-flex !important;align-items:center !important;gap:10px !important;
  color:var(--navy) !important;font-family:var(--fb) !important;font-size:13px !important;
  font-weight:700 !important;letter-spacing:.08em !important;text-transform:uppercase !important;
  text-decoration:none !important;border-bottom:2px solid var(--or) !important;
  padding-bottom:4px !important;transition:color .3s !important}
#vhApp .vh-ig-link:hover{color:var(--or) !important}

/* ════════════════════════════════════════════
   VIDEO
   ════════════════════════════════════════════ */
#vhApp .vh-video-sec{padding-top:100px !important;padding-bottom:100px !important;background:var(--w) !important}

#vhApp .vh-video-frame{
  position:relative !important;border-radius:20px !important;overflow:hidden !important;
  aspect-ratio:16/7 !important;cursor:pointer !important;
  box-shadow:0 24px 80px rgba(2,31,103,.14) !important}
@media(max-width:768px){
  #vhApp .vh-video-frame{aspect-ratio:16/9 !important;border-radius:12px !important}}
#vhApp .vh-video-frame img{
  width:100% !important;height:100% !important;object-fit:cover !important;
  display:block !important;transition:transform .5s var(--ease) !important}
#vhApp .vh-video-frame:hover img{transform:scale(1.03) !important}
#vhApp .vh-video-gradient{
  position:absolute !important;inset:0 !important;
  background:linear-gradient(to right,rgba(2,31,103,.65) 0%,rgba(0,0,0,.25) 60%,rgba(0,0,0,.5) 100%) !important}
#vhApp .vh-play{
  position:absolute !important;inset:0 !important;
  display:flex !important;align-items:center !important;justify-content:center !important}
#vhApp .vh-play svg{
  width:88px !important;height:88px !important;background:var(--or) !important;
  border-radius:50% !important;padding:20px !important;color:var(--w) !important;fill:var(--w) !important;
  box-shadow:0 8px 40px rgba(173,82,7,.5) !important;transition:transform .3s,box-shadow .3s !important}
#vhApp .vh-video-frame:hover .vh-play svg{
  transform:scale(1.12) !important;box-shadow:0 14px 56px rgba(173,82,7,.65) !important}
#vhApp .vh-video-caption{
  position:absolute !important;bottom:28px !important;left:36px !important;
  font-family:var(--fb) !important;font-size:11px !important;font-weight:700 !important;
  letter-spacing:.18em !important;text-transform:uppercase !important;color:rgba(255,255,255,.7) !important}
/* ── Video embed wrapper — técnica padding-bottom para mobile ── */
#vhApp #vhVideoEmbed{display:none !important;width:100% !important}
#vhApp #vhVideoEmbed.active{display:block !important}

/* El wrapper creado por JS usa esta clase */
#vhApp .vh-iframe-wrap{
  position:relative !important;
  width:100% !important;
  /* 16:7 ratio = 43.75% */
  padding-bottom:43.75% !important;
  height:0 !important;
  overflow:hidden !important;
  border-radius:20px !important;
  display:block !important}
@media(max-width:768px){
  #vhApp .vh-iframe-wrap{
    /* 16:9 ratio = 56.25% */
    padding-bottom:56.25% !important;
    border-radius:12px !important}}

/* El iframe se estira al 100% del wrapper */
#vhApp .vh-iframe-wrap iframe{
  position:absolute !important;
  top:0 !important;left:0 !important;
  width:100% !important;height:100% !important;
  border:none !important;margin:0 !important;padding:0 !important;
  display:block !important}

/* ════════════════════════════════════════════
   LISTA DE ESPERA
   ════════════════════════════════════════════ */
#vhApp .vh-espera{
  padding-top:120px !important;padding-bottom:120px !important;background:var(--navy) !important;
  position:relative !important;overflow:hidden !important;width:100% !important}
#vhApp .vh-espera-deco{
  position:absolute !important;width:600px !important;height:600px !important;
  border-radius:50% !important;background:radial-gradient(circle,rgba(173,82,7,.14) 0%,transparent 70%) !important;
  top:-100px !important;right:-100px !important;pointer-events:none !important}

#vhApp .vh-espera-grid{
  display:grid !important;grid-template-columns:1fr 1fr !important;
  gap:80px !important;align-items:start !important;
  max-width:1200px !important;margin:0 auto !important;padding:0 64px !important;width:100% !important}
#vhApp .vh-espera-grid > *{min-width:0 !important;max-width:100% !important}
@media(max-width:960px){#vhApp .vh-espera-grid{grid-template-columns:1fr !important;gap:56px !important;padding:0 40px !important}}
@media(max-width:600px){#vhApp .vh-espera-grid{padding:0 24px !important}}

#vhApp .vh-espera-title{
  font-family:var(--fd) !important;font-size:clamp(2.1rem,4.5vw,3.8rem) !important;
  font-weight:700 !important;line-height:1 !important;letter-spacing:-.03em !important;
  color:var(--w) !important;margin-bottom:28px !important}
#vhApp .vh-espera-title em{font-style:italic !important;color:var(--gold) !important}

#vhApp .vh-espera-sub{
  font-family:var(--fb) !important;font-size:16px !important;line-height:1.8 !important;
  color:rgba(255,255,255,.7) !important;margin-bottom:36px !important}

#vhApp .vh-espera-perks{list-style:none !important;margin-bottom:48px !important}
#vhApp .vh-espera-perks li{
  display:flex !important;align-items:center !important;gap:14px !important;
  font-family:var(--fb) !important;font-size:15px !important;
  color:rgba(255,255,255,.8) !important;margin-bottom:16px !important;line-height:1.5 !important}
#vhApp .vh-espera-perks li svg{color:var(--gold) !important;flex-shrink:0 !important;display:block !important}

#vhApp .vh-counter{
  display:flex !important;align-items:center !important;gap:24px !important;
  padding:32px 0 !important;border-top:1px solid rgba(255,255,255,.1) !important}
#vhApp .vh-counter-num{
  font-family:var(--fd) !important;font-size:3.8rem !important;font-weight:700 !important;
  line-height:1 !important;color:var(--gold) !important;letter-spacing:-.04em !important}
#vhApp .vh-counter-txt{
  font-family:var(--fb) !important;font-size:15px !important;
  line-height:1.6 !important;color:rgba(255,255,255,.65) !important}

/* Tarjeta formulario */
#vhApp .vh-form-card{
  background:rgba(255,255,255,.07) !important;border:1px solid rgba(255,255,255,.13) !important;
  border-radius:20px !important;padding:48px 44px !important;backdrop-filter:blur(12px) !important;
  width:100% !important;overflow:hidden !important;box-sizing:border-box !important}
@media(max-width:600px){#vhApp .vh-form-card{padding:32px 28px !important}}

#vhApp .vh-form-card h3{
  font-family:var(--fd) !important;font-size:1.5rem !important;font-weight:700 !important;
  color:var(--w) !important;margin-bottom:10px !important;line-height:1.2 !important}
#vhApp .vh-form-card>p{
  font-family:var(--fb) !important;font-size:14px !important;color:rgba(255,255,255,.55) !important;
  margin-bottom:32px !important;line-height:1.65 !important}

/* Campos */
#vhApp .vh-field{margin-bottom:22px !important}
#vhApp .vh-field label{
  display:block !important;font-family:var(--fb) !important;font-size:11px !important;
  font-weight:700 !important;letter-spacing:.1em !important;text-transform:uppercase !important;
  color:rgba(255,255,255,.6) !important;margin-bottom:10px !important;line-height:1 !important}
#vhApp .vh-field input,
#vhApp .vh-field textarea{
  display:block !important;width:100% !important;max-width:100% !important;
  min-width:0 !important;box-sizing:border-box !important;
  font-family:var(--fb) !important;
  font-size:15px !important;line-height:1.5 !important;padding:14px 18px !important;
  background:rgba(255,255,255,.09) !important;border:1.5px solid rgba(255,255,255,.16) !important;
  border-radius:10px !important;color:var(--w) !important;outline:none !important;
  transition:border-color .3s,background .3s !important;-webkit-appearance:none !important}
#vhApp .vh-field input::placeholder,
#vhApp .vh-field textarea::placeholder{color:rgba(255,255,255,.3) !important}
#vhApp .vh-field input:focus,
#vhApp .vh-field textarea:focus{
  border-color:var(--gold) !important;background:rgba(255,255,255,.13) !important;outline:none !important}
#vhApp .vh-field textarea{resize:vertical !important;min-height:96px !important}

/* Botón submit */
#vhApp .vh-submit{
  display:flex !important;align-items:center !important;justify-content:center !important;
  gap:10px !important;width:100% !important;padding:17px 28px !important;
  background:var(--or) !important;color:var(--w) !important;font-family:var(--fb) !important;
  font-size:13px !important;font-weight:700 !important;letter-spacing:.1em !important;
  text-transform:uppercase !important;border:none !important;border-radius:10px !important;
  cursor:pointer !important;box-shadow:0 6px 28px rgba(173,82,7,.4) !important;
  transition:background .3s,transform .3s !important;margin-top:12px !important;line-height:1 !important}
#vhApp .vh-submit:hover:not(:disabled){background:#bf5c09 !important;transform:translateY(-2px) !important}
#vhApp .vh-submit:disabled{opacity:.6 !important;cursor:not-allowed !important}
#vhApp .vh-submit--alt{background:var(--gold) !important;color:var(--navy) !important}
#vhApp .vh-submit--alt:hover:not(:disabled){background:#b89430 !important}

#vhApp .vh-submit-spin{
  display:none !important;width:18px !important;height:18px !important;
  border:2.5px solid rgba(255,255,255,.35) !important;border-top-color:var(--w) !important;
  border-radius:50% !important;animation:vhSpin .7s linear infinite !important}
#vhApp .vh-submit.loading .vh-submit-txt{display:none !important}
#vhApp .vh-submit.loading .vh-submit-spin{display:block !important}
@keyframes vhSpin{to{transform:rotate(360deg)}}

#vhApp .vh-fmsg{
  margin-top:16px !important;padding:14px 18px !important;border-radius:10px !important;
  font-family:var(--fb) !important;font-size:14px !important;font-weight:600 !important;
  text-align:center !important;display:none !important;line-height:1.5 !important}
#vhApp .vh-fmsg.ok{
  background:rgba(37,211,102,.14) !important;color:#7dffc8 !important;
  border:1px solid rgba(37,211,102,.24) !important;display:block !important}
#vhApp .vh-fmsg.err{
  background:rgba(255,70,70,.12) !important;color:#ffb3b3 !important;
  border:1px solid rgba(255,70,70,.2) !important;display:block !important}

/* Ticker */
#vhApp .vh-ticker-wrap{
  display:flex !important;align-items:center !important;gap:14px !important;
  overflow:hidden !important;border-top:1px solid rgba(255,255,255,.1) !important;
  padding-top:20px !important;margin-top:24px !important;min-height:40px !important}
#vhApp .vh-ticker-label{
  font-family:var(--fb) !important;font-size:11px !important;font-weight:700 !important;
  letter-spacing:.12em !important;text-transform:uppercase !important;
  color:rgba(255,255,255,.4) !important;white-space:nowrap !important;flex-shrink:0 !important}
#vhApp .vh-ticker{flex:1 !important;position:relative !important;height:26px !important;overflow:hidden !important}
#vhApp .vh-tname{
  font-family:var(--fb) !important;font-size:15px !important;font-weight:700 !important;
  color:var(--gold) !important;white-space:nowrap !important;position:absolute !important;
  top:0 !important;left:0 !important;opacity:0 !important;transform:translateY(100%) !important;
  transition:opacity .45s,transform .45s !important;line-height:1.7 !important}
#vhApp .vh-tname.show{opacity:1 !important;transform:translateY(0) !important}
#vhApp .vh-tname.hide{opacity:0 !important;transform:translateY(-100%) !important}

/* ════════════════════════════════════════════
   BODEGAS
   ════════════════════════════════════════════ */
#vhApp .vh-bodegas{padding-top:120px !important;padding-bottom:120px !important;background:var(--cream) !important}

#vhApp .vh-bodegas-grid{
  display:grid !important;grid-template-columns:1fr 1fr !important;
  gap:80px !important;align-items:start !important;width:100% !important;overflow:hidden !important}
#vhApp .vh-bodegas-grid > *{min-width:0 !important;max-width:100% !important;overflow:hidden !important}
@media(max-width:960px){#vhApp .vh-bodegas-grid{grid-template-columns:1fr !important;gap:56px !important}}

#vhApp .vh-bodegas-title{
  font-family:var(--fd) !important;font-size:clamp(1.9rem,3.8vw,3.1rem) !important;
  font-weight:700 !important;line-height:1.08 !important;color:var(--navy) !important;
  letter-spacing:-.025em !important;margin-bottom:28px !important}
#vhApp .vh-bodegas-title span{color:var(--or) !important;font-style:italic !important}

#vhApp .vh-bodegas-text p{
  font-family:var(--fb) !important;font-size:16px !important;line-height:1.85 !important;
  margin-bottom:20px !important;color:var(--gray) !important}
#vhApp .vh-bodegas-text p strong{color:var(--navy) !important}

#vhApp .vh-bodegas-reasons{list-style:none !important;margin-top:32px !important;border-top:1px solid #D8D2C8 !important;padding-top:24px !important}
#vhApp .vh-bodegas-reasons li{
  font-family:var(--fb) !important;font-size:15px !important;font-weight:600 !important;
  color:var(--navy) !important;padding:14px 0 14px 22px !important;
  border-bottom:1px solid #D8D2C8 !important;position:relative !important;line-height:1.5 !important}
#vhApp .vh-bodegas-reasons li::before{content:'—' !important;position:absolute !important;left:0 !important;color:var(--or) !important}

#vhApp .vh-form-card--dark{background:var(--navy) !important;border:1px solid rgba(255,255,255,.1) !important}

/* ════════════════════════════════════════════
   INSTAGRAM
   ════════════════════════════════════════════ */
#vhApp .vh-ig-section{
  padding-top:100px !important;padding-bottom:100px !important;
  background:var(--w) !important;border-top:1px solid #E0DBD4 !important}
#vhApp .vh-ig-inner{
  display:flex !important;align-items:center !important;
  justify-content:space-between !important;gap:60px !important}
@media(max-width:768px){#vhApp .vh-ig-inner{flex-direction:column !important;text-align:center !important;gap:40px !important}}

#vhApp .vh-ig-text h2{
  font-family:var(--fd) !important;font-size:clamp(1.75rem,3.5vw,2.75rem) !important;
  font-weight:700 !important;color:var(--navy) !important;line-height:1.12 !important;margin-bottom:18px !important}
#vhApp .vh-ig-text h2 span{color:var(--or) !important;font-style:italic !important}
#vhApp .vh-ig-text p{
  font-family:var(--fb) !important;font-size:16px !important;color:var(--gray) !important;
  line-height:1.8 !important;margin-bottom:32px !important}
#vhApp .vh-ig-text p strong{color:var(--navy) !important}

#vhApp .vh-ig-btn{
  display:inline-flex !important;align-items:center !important;gap:12px !important;
  background:linear-gradient(135deg,#F09433,#E6683C,#DC2743,#CC2366,#BC1888) !important;
  color:var(--w) !important;text-decoration:none !important;padding:16px 32px !important;
  border-radius:50px !important;font-family:var(--fb) !important;font-size:15px !important;
  font-weight:700 !important;letter-spacing:.05em !important;
  box-shadow:0 8px 28px rgba(220,39,67,.3) !important;transition:transform .3s,box-shadow .3s !important;line-height:1 !important}
#vhApp .vh-ig-btn:hover{transform:translateY(-3px) !important;box-shadow:0 14px 40px rgba(220,39,67,.4) !important}
#vhApp .vh-ig-btn svg{display:block !important}

#vhApp .vh-ig-logo img{
  width:180px !important;height:180px !important;border-radius:50% !important;
  object-fit:cover !important;box-shadow:0 16px 48px rgba(2,31,103,.18) !important;
  border:6px solid var(--cream) !important;display:block !important}

/* ════════════════════════════════════════════
   WHATSAPP FAB
   ════════════════════════════════════════════ */
#vhApp .vh-wa-fab{
  position:fixed !important;bottom:32px !important;right:32px !important;
  width:64px !important;height:64px !important;background:#25D366 !important;
  border-radius:50% !important;display:flex !important;align-items:center !important;
  justify-content:center !important;color:var(--w) !important;
  box-shadow:0 8px 32px rgba(37,211,102,.45) !important;z-index:9999 !important;
  text-decoration:none !important;transition:transform .3s,box-shadow .3s !important}
#vhApp .vh-wa-fab:hover{transform:scale(1.12) !important;box-shadow:0 14px 48px rgba(37,211,102,.6) !important}
#vhApp .vh-wa-fab svg{display:block !important}
#vhApp .vh-wa-tip{
  position:absolute !important;right:76px !important;background:var(--blk) !important;
  color:var(--w) !important;font-family:var(--fb) !important;font-size:13px !important;
  font-weight:700 !important;padding:8px 14px !important;border-radius:6px !important;
  white-space:nowrap !important;opacity:0 !important;pointer-events:none !important;
  transform:translateX(6px) !important;transition:opacity .25s,transform .25s !important}
#vhApp .vh-wa-fab:hover .vh-wa-tip{opacity:1 !important;transform:translateX(0) !important}

/* ════════════════════════════════════════════
   SCROLL REVEAL
   ════════════════════════════════════════════ */
#vhApp .vh-reveal{
  opacity:0 !important;transform:translateY(32px) !important;
  transition:opacity .8s var(--ease),transform .8s var(--ease) !important}
#vhApp .vh-reveal.in{opacity:1 !important;transform:translateY(0) !important}
#vhApp .vh-reveal-d1{transition-delay:.1s !important}
#vhApp .vh-reveal-d2{transition-delay:.2s !important}
#vhApp .vh-reveal-d3{transition-delay:.3s !important}


/* ════════════════════════════════════════════
   RESPONSIVE COMPLETO — TABLET Y MOBILE
   Breakpoints: 1024 / 768 / 480 / 360
   ════════════════════════════════════════════ */

/* ── TABLET GRANDE (≤1024px) ── */
@media(max-width:1024px){
  #vhApp .vh-wrap{padding:0 40px !important}
  #vhApp .vh-espera-grid{padding:0 40px !important}

  #vhApp .vh-about-grid,
  #vhApp .vh-bodegas-grid{gap:48px !important}

  #vhApp .vh-pillars{padding-top:72px !important;padding-bottom:72px !important}
  #vhApp .vh-about{padding-top:80px !important;padding-bottom:80px !important}
  #vhApp .vh-video-sec{padding-top:72px !important;padding-bottom:72px !important}
  #vhApp .vh-espera{padding-top:80px !important;padding-bottom:80px !important}
  #vhApp .vh-bodegas{padding-top:80px !important;padding-bottom:80px !important}
  #vhApp .vh-ig-section{padding-top:72px !important;padding-bottom:72px !important}
  #vhApp .vh-manifesto{padding-top:72px !important;padding-bottom:72px !important}
}

/* ── TABLET (≤768px) ── */
@media(max-width:768px){
  /* Wrap */
  #vhApp .vh-wrap{padding:0 24px !important}
  #vhApp .vh-espera-grid{padding:0 24px !important}

  /* Texto: nunca se sale del contenedor */
  #vhApp p,#vhApp h1,#vhApp h2,#vhApp h3,#vhApp li,#vhApp span,#vhApp label{
    word-break:break-word !important;overflow-wrap:break-word !important;hyphens:auto !important}

  /* Grids: 1 columna */
  #vhApp .vh-about-grid,
  #vhApp .vh-bodegas-grid,
  #vhApp .vh-espera-grid{
    grid-template-columns:1fr !important;
    gap:40px !important}

  /* Inputs/textareas: contenidos siempre */
  #vhApp .vh-field{overflow:hidden !important}
  #vhApp .vh-field input,
  #vhApp .vh-field textarea{
    width:100% !important;max-width:100% !important;
    min-width:0 !important;box-sizing:border-box !important;
    font-size:16px !important} /* 16px evita zoom en iOS */

  /* Form cards */
  #vhApp .vh-form-card{
    padding:28px 22px !important;
    width:100% !important;overflow:hidden !important}

  /* Botón submit */
  #vhApp .vh-submit{font-size:13px !important;padding:16px 20px !important}

  /* Pilares */
  #vhApp .vh-pillars-grid{grid-template-columns:1fr !important}
  #vhApp .vh-pillar{padding:36px 28px !important;border-right:none !important;border-bottom:1px solid #E0DBD4 !important}
  #vhApp .vh-pillar:last-child{border-bottom:none !important}
  #vhApp .vh-pillar--mid{border-right:none !important}

  /* Stats */
  #vhApp .vh-about-stats{gap:16px !important}
  #vhApp .vh-stat-n{font-size:1.8rem !important}
  #vhApp .vh-stat-l{font-size:10px !important}

  /* Imagen sobre evento */
  #vhApp .vh-img-stack{padding-bottom:44px !important;padding-right:36px !important}
  #vhApp .vh-img-float{width:120px !important}
  #vhApp .vh-img-badge{right:-6px !important;top:16px !important;padding:12px 14px !important}

  /* Manifesto */
  #vhApp .vh-manifesto{padding-top:64px !important;padding-bottom:64px !important}
  #vhApp .vh-manifesto-inner{padding:0 24px !important}
  #vhApp .vh-manifesto-quote{font-size:5rem !important;margin-bottom:24px !important}
  #vhApp .vh-manifesto-text{font-size:1.05rem !important}
  #vhApp .vh-manifesto-firma{margin-top:32px !important;padding-top:24px !important}

  /* Instagram */
  #vhApp .vh-ig-inner{
    flex-direction:column !important;text-align:center !important;gap:32px !important}
  #vhApp .vh-ig-logo img{width:120px !important;height:120px !important}

  /* Secciones padding */
  #vhApp .vh-about{padding-top:64px !important;padding-bottom:64px !important}
  #vhApp .vh-bodegas{padding-top:64px !important;padding-bottom:64px !important}
  #vhApp .vh-espera{padding-top:64px !important;padding-bottom:64px !important}
  #vhApp .vh-video-sec{padding-top:64px !important;padding-bottom:64px !important}
  #vhApp .vh-ig-section{padding-top:64px !important;padding-bottom:64px !important}
  #vhApp .vh-pillars{padding-top:64px !important;padding-bottom:64px !important}

  /* Section titles */
  #vhApp .vh-section-title{margin-bottom:36px !important;font-size:1.8rem !important}

  /* Perks lista */
  #vhApp .vh-espera-perks li{font-size:14px !important;gap:10px !important}

  /* Counter */
  #vhApp .vh-counter-num{font-size:3rem !important}
  #vhApp .vh-counter-txt{font-size:14px !important}

  /* Video */
  #vhApp .vh-video-caption{font-size:10px !important;bottom:16px !important;left:16px !important}
  #vhApp .vh-play svg{width:64px !important;height:64px !important;padding:14px !important}

  /* WA FAB */
  #vhApp .vh-wa-fab{width:52px !important;height:52px !important;bottom:20px !important;right:20px !important}

  /* Bodegas reasons */
  #vhApp .vh-bodegas-reasons li{font-size:14px !important;padding:12px 0 12px 20px !important}

  /* About title */
  #vhApp .vh-about-title{font-size:1.75rem !important}
  #vhApp .vh-bodegas-title{font-size:1.75rem !important}
}

/* ── MOBILE (≤480px) ── */
@media(max-width:480px){
  #vhApp .vh-wrap{padding:0 16px !important}
  #vhApp .vh-espera-grid{padding:0 16px !important}

  #vhApp .vh-form-card{padding:24px 16px !important}

  /* Inputs más grandes para tacto */
  #vhApp .vh-field input,
  #vhApp .vh-field textarea{
    padding:14px 14px !important;font-size:16px !important}
  #vhApp .vh-field{margin-bottom:16px !important}
  #vhApp .vh-field label{font-size:10px !important;margin-bottom:8px !important}

  #vhApp .vh-pillar{padding:28px 20px !important}

  #vhApp .vh-img-stack{padding-bottom:40px !important;padding-right:32px !important}
  #vhApp .vh-img-float{width:100px !important}
  #vhApp .vh-img-badge{display:none !important}

  #vhApp .vh-about-stats{gap:12px !important;padding:24px 0 !important}
  #vhApp .vh-stat-n{font-size:1.5rem !important}
  #vhApp .vh-stat-div{height:36px !important}

  #vhApp .vh-espera-title{font-size:2rem !important}
  #vhApp .vh-counter-num{font-size:2.5rem !important}
  #vhApp .vh-counter{gap:16px !important;padding:24px 0 !important}

  #vhApp .vh-submit{padding:15px 16px !important;font-size:12px !important;letter-spacing:.06em !important}
  #vhApp .vh-bodegas-title{font-size:1.55rem !important}
  #vhApp .vh-about-title{font-size:1.55rem !important}

  #vhApp .vh-section-title{font-size:1.55rem !important;margin-bottom:28px !important}
  #vhApp .vh-manifesto-inner{padding:0 16px !important}
  #vhApp .vh-manifesto-quote{font-size:4rem !important}
  #vhApp .vh-manifesto-text{font-size:1rem !important;line-height:1.65 !important}

  #vhApp .vh-ig-btn{padding:13px 22px !important;font-size:13px !important}
  #vhApp .vh-ig-text p{font-size:15px !important}

  #vhApp .vh-bodegas-reasons li{font-size:13px !important}
}

/* ── MOBILE MUY PEQUEÑO (≤360px) ── */
@media(max-width:360px){
  #vhApp .vh-wrap{padding:0 12px !important}
  #vhApp .vh-espera-grid{padding:0 12px !important}
  #vhApp .vh-form-card{padding:20px 14px !important}
  #vhApp .vh-field input,
  #vhApp .vh-field textarea{padding:12px !important}
  #vhApp .vh-espera-title{font-size:1.8rem !important}
  #vhApp .vh-about-title,
  #vhApp .vh-bodegas-title{font-size:1.4rem !important}
}
/* ════════════════════════════════════════════
   OVERRIDES ELEMENTOR / TEMA
   ════════════════════════════════════════════ */
.elementor-section-boxed>.elementor-container{max-width:100% !important}
.e-con-inner{max-width:100% !important;padding:0 !important}
.elementor-widget-container{padding:0 !important;margin:0 !important}
