/*
Theme Name: 414 Galería
Theme URI: https://414galeria.com
Author: JEOWebs
Description: Tema oficial 414 Galería – Boliche & Bar, Córdoba, Argentina. v2.4
Version: 2.4.0
License: GNU General Public License v2
Text Domain: 414-galeria
*/

/* ── VARIABLES ───────────────────────────────────────── */
:root {
  --bg-base:      #050407;
  --bg-card:      #0c0a14;
  --bg-surface:   #100d1a;
  --bg-glass:     rgba(16,12,26,.8);
  --brand-purple: #3d1b6e;
  --brand-magenta:#c8338a;
  --brand-orange: #b85420;
  --brand-red:    #d62d2d;
  --brand-star:   #e8c842;
  --accent:       var(--brand-magenta);
  --text-primary: #f0eeff;
  --text-secondary:#a89ec8;
  --text-muted:   #5c5478;
  --border:       rgba(200,51,138,.12);
  --border-active:rgba(200,51,138,.45);
  --glow-magenta: 0 0 28px rgba(200,51,138,.45);
  --glow-purple:  0 0 24px rgba(61,27,110,.5);
  --glow-red:     0 0 24px rgba(214,45,45,.4);
  --shadow-card:  0 8px 40px rgba(0,0,0,.6);
  --shadow-float: 0 16px 60px rgba(0,0,0,.8);
  --font-display: 'Haettenschweiler','Arial Narrow','Oswald',sans-serif;
  --font-alt:     'Oswald','Arial Narrow',sans-serif;
  --font-body:    'Inter','Segoe UI',system-ui,sans-serif;
  --navbar-h:     60px;
  --r-sm: 8px; --r-md: 14px; --r-lg: 20px; --r-xl: 28px; --r-pill: 999px;
  --t:      all .3s cubic-bezier(.4,0,.2,1);
  --t-fast: all .18s ease;
  --wa-green: #25D366;
}

/* ── RESET ───────────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0 }
html { scroll-behavior:smooth; font-size:16px; -webkit-text-size-adjust:100% }
body { background:var(--bg-base); color:var(--text-primary); font-family:var(--font-body); line-height:1.6; overflow-x:hidden; -webkit-font-smoothing:antialiased }
img { max-width:100%; height:auto; display:block }
a { color:inherit; text-decoration:none }
button { cursor:pointer; border:none; background:none; font-family:inherit; color:inherit }
ul,ol { list-style:none }
input,textarea,select { font-family:inherit }

/* Noise overlay */
body::after { content:''; position:fixed; inset:0; background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E"); opacity:.025; pointer-events:none; z-index:9999; mix-blend-mode:overlay }
::-webkit-scrollbar { width:3px } ::-webkit-scrollbar-track { background:var(--bg-base) } ::-webkit-scrollbar-thumb { background:var(--brand-magenta); border-radius:2px }

/* ── TIPOGRAFÍA ──────────────────────────────────────── */
h1,h2,h3,h4,h5 { font-family:var(--font-alt); font-weight:700; letter-spacing:.04em; line-height:1; text-transform:uppercase }
.display-title  { font-family:var(--font-display); font-weight:900; letter-spacing:.06em; text-transform:uppercase }
.eyebrow        { display:inline-block; font-family:var(--font-alt); font-size:.68rem; letter-spacing:.28em; text-transform:uppercase; color:var(--brand-magenta) }

/* ── NAVBAR ──────────────────────────────────────────── */
#navbar { position:fixed; top:0; left:0; right:0; z-index:1000; height:var(--navbar-h); display:flex; align-items:center; justify-content:space-between; padding:0 20px; transition:var(--t) }
#navbar.scrolled { background:rgba(5,4,7,.94); backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px); border-bottom:1px solid var(--border); box-shadow:0 4px 30px rgba(0,0,0,.4) }
.nav-logo { display:flex; flex-direction:column; align-items:flex-start; gap:1px; line-height:1 }
.nav-logo-img    { height:38px; width:auto; object-fit:contain; filter:brightness(0) invert(1) }
.nav-logo-cuatro { font-size:.55rem; letter-spacing:.35em; color:var(--text-secondary); text-transform:uppercase; font-family:var(--font-alt) }
.nav-logo-main   { font-family:var(--font-display); font-size:1.45rem; font-weight:900; color:var(--text-primary); text-transform:uppercase; line-height:1 }
.nav-logo-galeria{ font-size:.45rem; letter-spacing:.5em; color:var(--brand-magenta); text-transform:uppercase; font-family:var(--font-alt) }
.nav-links { display:none; gap:20px; align-items:center }
.nav-links a { font-family:var(--font-alt); font-size:.75rem; letter-spacing:.12em; text-transform:uppercase; color:var(--text-secondary); transition:var(--t-fast) }
.nav-links a:hover { color:var(--text-primary) }
.nav-cta-btn { background:var(--brand-magenta) !important; color:white !important; padding:8px 16px; border-radius:var(--r-pill); font-size:.72rem !important; transition:var(--t) !important }
.nav-cta-btn:hover { background:#a82070 !important; box-shadow:var(--glow-magenta) !important }
.hamburger { display:flex; flex-direction:column; gap:5px; padding:8px; z-index:1001; position:relative }
.hamburger span { display:block; width:22px; height:2px; background:var(--text-primary); border-radius:2px; transition:var(--t); transform-origin:center }
.hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg) }
.hamburger.open span:nth-child(2) { opacity:0; transform:scaleX(0) }
.hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg) }
.mobile-menu { position:fixed; inset:0; background:rgba(5,4,7,.98); backdrop-filter:blur(20px); z-index:999; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:24px; transform:translateY(-100%); transition:transform .45s cubic-bezier(.4,0,.2,1) }
.mobile-menu.open { transform:translateY(0) }
.mobile-menu a { font-family:var(--font-display); font-size:2rem; letter-spacing:.08em; text-transform:uppercase; color:var(--text-primary); transition:var(--t-fast); position:relative }
.mobile-menu a:hover { color:var(--brand-magenta) }

/* ── APERTURA / HERO ─────────────────────────────────── */
#apertura { position:relative; height:100svh; min-height:600px; display:flex; flex-direction:column; align-items:center; justify-content:center; overflow:hidden; text-align:center }
.apertura-bg { position:absolute; inset:0; z-index:0 }
.apertura-bg .bg-media { width:100%; height:100%; object-fit:cover; opacity:.38 }
.apertura-bg-gradient { position:absolute; inset:0; background:radial-gradient(ellipse 80% 60% at 50% 20%,rgba(61,27,110,.5) 0%,transparent 70%),radial-gradient(ellipse 60% 50% at 80% 80%,rgba(200,51,138,.2) 0%,transparent 60%); animation:bgPulse 12s ease-in-out infinite alternate }
@keyframes bgPulse { 0%{opacity:.7;transform:scale(1)} 100%{opacity:1;transform:scale(1.04)} }
.apertura-scanlines { position:absolute; inset:0; background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.05) 2px,rgba(0,0,0,.05) 4px); pointer-events:none; z-index:1 }
.apertura-overlay   { position:absolute; inset:0; background:linear-gradient(to bottom,rgba(5,4,7,.2) 0%,rgba(5,4,7,.1) 40%,rgba(5,4,7,.85) 100%); z-index:2 }

.apertura-content { position:relative; z-index:3; padding:0 24px; max-width:680px; width:100%; display:flex; flex-direction:column; align-items:center; gap:22px }

.apertura-badge { display:inline-flex; align-items:center; gap:8px; border:1px solid rgba(200,51,138,.4); border-radius:var(--r-pill); padding:6px 18px; font-family:var(--font-alt); font-size:.68rem; letter-spacing:.25em; color:var(--brand-magenta); text-transform:uppercase; animation:fadeInDown .7s ease both }
.badge-dot { width:6px; height:6px; border-radius:50%; background:var(--brand-magenta); animation:dotBlink 1.5s ease infinite }
@keyframes dotBlink { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.3;transform:scale(.8)} }

/* LOGO HERO — GRANDE ★ */
.apertura-logo { display:flex; flex-direction:column; align-items:center; gap:0; animation:fadeInUp .8s ease .15s both; width:100% }
/* Imagen: escala por ancho para que 1350x1080 se vea grande */
.hero-logo-img  {
  width: min(580px, 88vw);
  height: auto;
  max-height: none;
  object-fit: contain;
  filter: brightness(0) invert(1);
  filter: drop-shadow(0 4px 30px rgba(200,51,138,.4)) brightness(0) invert(1);
}
.logo-small-text  { font-family:var(--font-alt); font-size:clamp(1rem,4.5vw,1.6rem); letter-spacing:.55em; color:var(--text-secondary); text-transform:uppercase; width:100%; text-align:center }
.logo-main-text   { font-family:var(--font-display); font-size:clamp(6.5rem,30vw,12rem); font-weight:900; color:var(--text-primary); letter-spacing:.04em; line-height:.88; text-shadow:0 0 80px rgba(200,51,138,.35), 0 4px 40px rgba(0,0,0,.7); width:100%; text-align:center }
.logo-galeria-text{ font-family:var(--font-alt); font-size:clamp(.9rem,3.5vw,1.3rem); letter-spacing:.65em; color:var(--brand-magenta); text-transform:uppercase; margin-top:10px; width:100%; text-align:center }

.apertura-tagline { font-family:var(--font-body); font-style:italic; font-size:1rem; color:var(--text-secondary); animation:fadeInUp .8s ease .3s both }
.apertura-btns    { display:flex; flex-direction:column; gap:10px; width:100%; animation:fadeInUp .8s ease .45s both }
.btn-apertura-primary { display:flex; align-items:center; justify-content:center; gap:10px; background:var(--brand-magenta); color:white; font-family:var(--font-display); font-size:1.1rem; letter-spacing:.1em; text-transform:uppercase; padding:18px 28px; border-radius:var(--r-pill); border:none; cursor:pointer; transition:var(--t); width:100%; animation:pulseGlow 3s ease-in-out 1s infinite }
.btn-apertura-primary:hover { background:#a82070; transform:translateY(-2px) scale(1.02); box-shadow:var(--glow-magenta) }
@keyframes pulseGlow { 0%,100%{box-shadow:0 0 20px rgba(200,51,138,.3)} 50%{box-shadow:0 0 50px rgba(200,51,138,.6)} }
.btn-apertura-ghost { display:flex; align-items:center; justify-content:center; gap:8px; background:transparent; border:1px solid rgba(200,51,138,.3); color:var(--text-secondary); font-family:var(--font-alt); font-size:.8rem; letter-spacing:.14em; text-transform:uppercase; padding:13px 28px; border-radius:var(--r-pill); cursor:pointer; transition:var(--t); width:100% }
.btn-apertura-ghost:hover { border-color:var(--brand-magenta); color:var(--brand-magenta) }
.scroll-hint { position:absolute; bottom:24px; left:50%; transform:translateX(-50%); z-index:3; display:flex; flex-direction:column; align-items:center; gap:8px; color:var(--text-muted); font-family:var(--font-alt); font-size:.6rem; letter-spacing:.25em; text-transform:uppercase; animation:fadeIn 1.2s ease 1.5s both }
.scroll-mouse { width:20px; height:32px; border:1px solid var(--text-muted); border-radius:10px; position:relative }
.scroll-mouse::after { content:''; position:absolute; top:6px; left:50%; transform:translateX(-50%); width:3px; height:6px; background:var(--brand-magenta); border-radius:2px; animation:scrollWheel 2s ease infinite }
@keyframes scrollWheel { 0%{top:6px;opacity:1} 100%{top:18px;opacity:0} }

/* ── AMBIENTE ────────────────────────────────────────── */
#ambiente { padding:80px 0 60px; background:var(--bg-surface); position:relative; overflow:hidden }
.ambiente-bg { position:absolute; inset:0 }
.ambiente-bg .bg-media { width:100%; height:100%; object-fit:cover; opacity:.07 }
.ambiente-bg-grad { position:absolute; inset:0; background:radial-gradient(ellipse at 100% 0%,rgba(200,51,138,.08) 0%,transparent 50%) }
.ambiente-header { position:relative; z-index:1; text-align:center; padding:0 20px 20px }
.ambiente-title { font-size:clamp(2.4rem,10vw,4rem); color:var(--text-primary) }
.ambiente-title span { color:var(--brand-magenta) }
.marquee-bar { overflow:hidden; border-top:1px solid var(--border); border-bottom:1px solid var(--border); padding:10px 0; margin-bottom:28px; position:relative; z-index:1 }
.marquee-track { display:flex; gap:40px; white-space:nowrap; animation:marqueeScroll 25s linear infinite }
@keyframes marqueeScroll { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }
.marquee-item { font-family:var(--font-display); font-size:.72rem; letter-spacing:.25em; color:var(--text-muted); text-transform:uppercase; flex-shrink:0 }
.marquee-item.accent { color:var(--brand-magenta) }

/* Galería grid */
.galeria-editorial { position:relative; z-index:1; padding:0 12px; display:grid; grid-template-columns:1fr 1fr; grid-auto-rows:150px; gap:6px; max-width:860px; margin:0 auto }
.gal-item { overflow:hidden; border-radius:var(--r-md); background:var(--bg-card); border:1px solid rgba(255,255,255,.04); cursor:pointer; position:relative; transition:var(--t) }
.gal-item:nth-child(1) { grid-column:span 2; grid-row:span 2 }
.gal-item:nth-child(4) { grid-row:span 2 }
.gal-item:nth-child(6) { grid-column:span 2 }
.gal-item-inner { width:100%; height:100%; display:flex; align-items:center; justify-content:center; font-size:2.5rem; transition:transform .5s ease; overflow:hidden }
.gal-item:hover .gal-item-inner { transform:scale(1.05) }
.gal-item-inner img, .gal-item-inner video { width:100%; height:100%; object-fit:cover; display:block }
.gal-overlay { position:absolute; inset:0; background:rgba(0,0,0,0); transition:var(--t); display:flex; align-items:center; justify-content:center }
.gal-item:hover .gal-overlay { background:rgba(0,0,0,.35) }
.gal-zoom-icon { color:white; font-size:2rem; opacity:0; transform:scale(.7); transition:var(--t) }
.gal-item:hover .gal-zoom-icon { opacity:1; transform:scale(1) }
.galeria-cta { text-align:center; margin-top:24px; position:relative; z-index:1 }

/* ── LIGHTBOX ────────────────────────────────────────── */
#lightbox { position:fixed; inset:0; background:rgba(0,0,0,.95); z-index:5000; display:flex; align-items:center; justify-content:center; opacity:0; visibility:hidden; transition:var(--t) }
#lightbox.open { opacity:1; visibility:visible }
.lb-img-wrap { position:relative; max-width:92vw; max-height:88svh; display:flex; align-items:center; justify-content:center }
.lb-img-wrap img, .lb-img-wrap video { max-width:100%; max-height:88svh; object-fit:contain; border-radius:var(--r-md); display:block }
.lb-close { position:fixed; top:16px; right:20px; background:rgba(255,255,255,.12); color:white; border-radius:50%; width:40px; height:40px; display:flex; align-items:center; justify-content:center; font-size:1.3rem; cursor:pointer; transition:var(--t-fast); z-index:5001 }
.lb-close:hover { background:var(--brand-magenta) }
.lb-prev, .lb-next { position:fixed; top:50%; transform:translateY(-50%); background:rgba(255,255,255,.1); color:white; border-radius:50%; width:44px; height:44px; display:flex; align-items:center; justify-content:center; font-size:1.4rem; cursor:pointer; transition:var(--t-fast); z-index:5001 }
.lb-prev { left:10px }
.lb-next { right:10px }
.lb-prev:hover, .lb-next:hover { background:var(--brand-magenta) }
.lb-counter { position:fixed; bottom:16px; left:50%; transform:translateX(-50%); font-family:var(--font-alt); font-size:.72rem; letter-spacing:.2em; color:rgba(255,255,255,.6); z-index:5001 }

/* ── EL JUEGO ────────────────────────────────────────── */
#el-juego { position:relative; min-height:100svh; display:flex; flex-direction:column; overflow:hidden; background:var(--bg-surface) }
.juego-bg { position:absolute; inset:0; background:radial-gradient(ellipse 100% 80% at 100% 50%,rgba(184,84,32,.18) 0%,transparent 60%),radial-gradient(ellipse 60% 60% at 0% 0%,rgba(61,27,110,.25) 0%,transparent 50%); z-index:0 }
.juego-bg .bg-media { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:.15 }
.juego-content { position:relative; z-index:1; display:grid; grid-template-columns:1fr; min-height:100svh }
.juego-panel-text { padding:80px 24px 40px; display:flex; flex-direction:column; justify-content:center; gap:24px }
.juego-heading { font-size:clamp(3rem,14vw,5.5rem); color:var(--text-primary); line-height:.92 }
.juego-heading .line-red { color:var(--brand-red) }
.juego-sub { font-size:.9rem; color:var(--text-secondary); line-height:1.7; max-width:380px }
.juego-days { display:flex; gap:8px; flex-wrap:wrap }
.day-pill { background:rgba(200,51,138,.12); border:1px solid rgba(200,51,138,.3); color:var(--brand-magenta); font-family:var(--font-alt); font-size:.7rem; letter-spacing:.15em; text-transform:uppercase; padding:6px 14px; border-radius:var(--r-pill) }
.juego-cta-btn { display:inline-flex; align-items:center; gap:10px; background:var(--brand-red); color:white; font-family:var(--font-display); font-size:1.1rem; letter-spacing:.1em; text-transform:uppercase; padding:16px 28px; border-radius:var(--r-pill); border:none; cursor:pointer; transition:var(--t); align-self:flex-start }
.juego-cta-btn:hover { background:#b82020; transform:translateY(-2px); box-shadow:var(--glow-red) }
.juego-panel-dice { padding:40px 24px 60px; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:20px; position:relative }

/* ══════════════════════════════════════════════════════
   DADO 3D — FIX CRÍTICO:
   NO aplicar filter/box-shadow al .dice-cube directamente
   porque filter aplana los hijos 3D (preserve-3d).
   El glow va en .dice-scene únicamente.
══════════════════════════════════════════════════════ */
.dice-scene {
  perspective: 600px;
  perspective-origin: 50% 40%;
  width: 160px;
  height: 160px;
  margin: 0 auto;
  cursor: grab;
  touch-action: none;
  user-select: none;
  -webkit-user-select: none;
  /* Glow en el contenedor, NO en el cubo */
  transition: filter .3s ease;
}
.dice-scene.dragging { cursor: grabbing }
/* ⬇ CORRECTO: filter en scene, que NO tiene transform-style:preserve-3d */
.dice-scene:not(.dragging):hover { filter: drop-shadow(0 0 18px rgba(200,51,138,.55)) }

.dice-cube {
  width: 160px;
  height: 160px;
  position: relative;
  transform-style: preserve-3d;
  /* SIN filter aquí — causaría aplanamiento 3D */
  transform: rotateX(-25deg) rotateY(35deg);
  transition: transform 1.6s cubic-bezier(.4,0,.2,1);
  will-change: transform;
}
.dice-cube.rolling { animation: diceRollFull 1.6s cubic-bezier(.4,0,.2,1) forwards }
@keyframes diceRollFull {
  0%   { transform:rotateX(-25deg) rotateY(35deg) }
  20%  { transform:rotateX(200deg) rotateY(160deg) scale(1.05) }
  45%  { transform:rotateX(380deg) rotateY(320deg) scale(.98) }
  70%  { transform:rotateX(540deg) rotateY(460deg) scale(1.03) }
  88%  { transform:rotateX(680deg) rotateY(540deg) }
  100% { transform:rotateX(720deg) rotateY(630deg) }
}

.dice-face {
  position: absolute;
  width: 160px; height: 160px;
  border-radius: 18px;
  display: flex; align-items: center; justify-content: center;
  font-size: 3rem;
  /* Sin border exterior — el border causa separaciones visibles en las esquinas */
  backface-visibility: hidden; -webkit-backface-visibility: hidden;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.6),
    inset 0 -2px 6px rgba(0,0,0,.12);
}
/* translateZ = 81px (1px sobre el radio exacto) para eliminar huecos */
.face-front  { background:linear-gradient(135deg,#f5f0ff,#e8e0ff); transform:translateZ(81px) }
.face-back   { background:linear-gradient(135deg,#f0eaff,#ddd0ff); transform:rotateY(180deg)  translateZ(81px) }
.face-right  { background:linear-gradient(135deg,#ede8ff,#e0d8ff); transform:rotateY(90deg)   translateZ(81px) }
.face-left   { background:linear-gradient(135deg,#f2edff,#e4dcff); transform:rotateY(-90deg)  translateZ(81px) }
.face-top    { background:linear-gradient(135deg,#fff0f5,#ffe0ec); transform:rotateX(90deg)   translateZ(81px); font-family:var(--font-display); font-size:1.8rem; font-weight:900; color:var(--brand-red); letter-spacing:.06em; flex-direction:column; gap:2px }
.face-bottom { background:linear-gradient(135deg,#ece8ff,#ddd5ff); transform:rotateX(-90deg)  translateZ(81px) }
.face-414-label { font-size:2rem; line-height:1 }
.face-414-sub   { font-family:var(--font-alt); font-size:.5rem; letter-spacing:.25em; color:var(--brand-magenta); text-transform:uppercase }
.dice-dots { color:#1a1a3a }

.dice-drag-hint { display:flex; align-items:center; gap:6px; font-family:var(--font-alt); font-size:.65rem; letter-spacing:.15em; text-transform:uppercase; color:var(--text-muted); opacity:.8; transition:opacity .4s ease }
.dice-drag-hint.hidden { opacity:0; pointer-events:none }
.drag-hint-icon { font-size:1rem; animation:dragHint 2.2s ease-in-out infinite }
@keyframes dragHint { 0%,100%{transform:translateX(0)} 35%{transform:translateX(-7px)} 65%{transform:translateX(7px)} }

.dice-result-card { background:var(--bg-glass); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px); border:1px solid var(--border); border-radius:var(--r-xl); padding:20px; text-align:center; width:100%; max-width:280px }
.dice-result-number { font-family:var(--font-display); font-size:3rem; color:var(--text-primary); line-height:1 }
.dice-result-number.is-414 { color:var(--brand-red); animation:winnerFlash .5s ease 4 }
@keyframes winnerFlash { 0%,100%{color:var(--brand-red)} 50%{color:var(--brand-star)} }
.dice-result-label { font-family:var(--font-alt); font-size:.72rem; letter-spacing:.15em; color:var(--text-muted); text-transform:uppercase; margin-top:4px }
.dice-result-msg   { margin-top:10px; font-size:.82rem; color:var(--text-secondary); line-height:1.5 }
.dice-cooldown-wrap { display:none; flex-direction:column; align-items:center; gap:12px; text-align:center; padding:20px; width:100%; max-width:280px }
.dice-cooldown-wrap.visible { display:flex }
.cooldown-clock { font-family:var(--font-display); font-size:2.5rem; color:var(--brand-orange); letter-spacing:.06em; line-height:1 }

/* ── SHOWS & PROMOS ──────────────────────────────────── */
#shows-promos { padding:80px 20px; max-width:660px; margin:0 auto; position:relative }
.shows-bg { position:absolute; inset:0; z-index:0 }
.shows-bg .bg-media { width:100%; height:100%; object-fit:cover; opacity:.08 }
.shows-header { position:relative; z-index:1; text-align:center; margin-bottom:36px }
.shows-title { font-size:clamp(2.4rem,10vw,4rem); color:var(--text-primary) }
.shows-title span { color:var(--brand-orange) }
.promo-hero-card { position:relative; z-index:1; border-radius:var(--r-xl); overflow:hidden; margin-bottom:16px; border:1px solid rgba(214,45,45,.2) }
.promo-hero-top { background:linear-gradient(135deg,#6b0000 0%,#b52020 40%,#8b1a1a 100%); padding:28px 24px; text-align:center; position:relative; overflow:hidden }
.promo-hero-top::before { content:''; position:absolute; inset:0; background:repeating-linear-gradient(45deg,transparent,transparent 20px,rgba(255,255,255,.03) 20px,rgba(255,255,255,.03) 22px) }
/* Imagen de portada del show */
.promo-hero-media { position:absolute; inset:0; z-index:0 }
.promo-hero-media img, .promo-hero-media video { width:100%; height:100%; object-fit:cover; opacity:.28 }
.promo-hero-content { position:relative; z-index:1 }
.promo-dice-big { font-size:4rem; filter:drop-shadow(0 0 20px rgba(255,200,0,.4)); display:block; margin-bottom:14px }
.promo-main-title { font-family:var(--font-display); font-size:clamp(2rem,8vw,3rem); color:white; line-height:.9 }
.promo-main-title .red-line { color:var(--brand-star) }
.promo-italic { font-family:var(--font-body); font-style:italic; font-size:.85rem; color:rgba(255,255,255,.75); margin-top:10px }
.promo-hero-bottom { background:var(--bg-card); padding:20px 24px }
.promo-bottom-days { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:16px }
.promo-rule-list { display:flex; flex-direction:column; gap:12px }
.promo-rule { display:flex; gap:12px; align-items:flex-start; font-size:.84rem; color:var(--text-secondary); line-height:1.5 }
.rule-num { width:24px; height:24px; border-radius:50%; background:rgba(214,45,45,.15); border:1px solid rgba(214,45,45,.3); color:var(--brand-red); font-family:var(--font-alt); font-size:.7rem; font-weight:700; display:flex; align-items:center; justify-content:center; flex-shrink:0 }

/* Voucher cards */
.voucher-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin:16px 0; position:relative; z-index:1 }
.voucher-card { border-radius:var(--r-lg); overflow:hidden; border:1px solid rgba(255,255,255,.06) }
.voucher-top { padding:16px 14px; text-align:center; position:relative; overflow:hidden; min-height:80px; display:flex; flex-direction:column; align-items:center; justify-content:center }
.voucher-top-media { position:absolute; inset:0; z-index:0 }
.voucher-top-media img { width:100%; height:100%; object-fit:cover; opacity:.35 }
.voucher-top-content { position:relative; z-index:1 }
.voucher-top.bg-magenta { background:linear-gradient(135deg,#8b1a5e,#c8338a) }
.voucher-top.bg-red     { background:linear-gradient(135deg,#8b0000,#d42b2b) }
.voucher-top.bg-green   { background:linear-gradient(135deg,#1a5e1a,#2ea02e) }
.voucher-top.bg-purple  { background:linear-gradient(135deg,#2d1b4e,#5a28a0) }
.voucher-label { font-family:var(--font-alt); font-size:.58rem; letter-spacing:.2em; color:rgba(255,255,255,.75); text-transform:uppercase; margin-bottom:4px }
.voucher-value { font-family:var(--font-display); font-size:1.55rem; color:white; line-height:1 }
.voucher-bottom { background:var(--bg-card); padding:10px 12px; font-size:.7rem; color:var(--text-muted); line-height:1.4 }

/* Shots card */
.shots-card { position:relative; z-index:1; background:linear-gradient(135deg,#1a0a2e,#2d1b4e); border:1px solid rgba(61,27,110,.5); border-radius:var(--r-xl); padding:22px; display:flex; gap:16px; align-items:center; margin-top:16px; overflow:hidden }
.shots-card-media { position:absolute; inset:0; z-index:0 }
.shots-card-media img { width:100%; height:100%; object-fit:cover; opacity:.2 }
.shots-card-content { display:flex; gap:16px; align-items:center; position:relative; z-index:1; width:100% }
.shots-icon  { font-size:3rem; flex-shrink:0 }
.shots-info  { flex:1 }
.shots-title { font-family:var(--font-display); font-size:1.2rem; color:var(--text-primary); margin-bottom:4px }
.shots-desc  { font-size:.78rem; color:var(--text-secondary); line-height:1.5 }
.shots-price { font-family:var(--font-display); font-size:1.4rem; color:var(--brand-magenta); white-space:nowrap; flex-shrink:0 }

/* ── LA CARTA ────────────────────────────────────────── */
#carta { position:relative; background:var(--bg-base); min-height:100svh }
.carta-bg { position:absolute; inset:0 }
.carta-bg .bg-media { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:.07 }
.carta-grad { position:absolute; inset:0; background:radial-gradient(ellipse 50% 80% at 0% 50%,rgba(61,27,110,.12) 0%,transparent 60%) }
.carta-header { position:relative; z-index:1; padding:60px 20px 0; text-align:center }
.carta-title { font-size:clamp(2.8rem,12vw,5rem); color:var(--text-primary); margin:8px 0 }
.carta-title span { color:var(--brand-magenta) }
.carta-tabs-sticky { position:sticky; top:var(--navbar-h); z-index:100; background:rgba(5,4,7,.97); backdrop-filter:blur(16px); border-bottom:1px solid var(--border); padding:0 16px; margin-top:28px }
.carta-tabs-inner { display:flex; overflow-x:auto; scrollbar-width:none; gap:0; max-width:600px; margin:0 auto }
.carta-tabs-inner::-webkit-scrollbar { display:none }
.ctab { flex:1; padding:16px 10px; font-family:var(--font-alt); font-size:.75rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--text-muted); border-bottom:2px solid transparent; white-space:nowrap; cursor:pointer; transition:var(--t-fast); background:none; display:flex; align-items:center; justify-content:center; gap:5px }
.ctab.active { color:var(--brand-magenta); border-bottom-color:var(--brand-magenta) }
.cat-panel { display:none } .cat-panel.active { display:block }
.carta-body { position:relative; z-index:1; max-width:600px; margin:0 auto; padding:12px 16px 140px }
.carta-subsection { margin-top:20px }
.carta-subsection-title { font-family:var(--font-display); font-size:.7rem; letter-spacing:.3em; text-transform:uppercase; color:var(--text-muted); padding:12px 0 8px; border-bottom:1px solid rgba(255,255,255,.05); margin-bottom:4px }

/* Producto card — tipografía grande para legibilidad */
.prod-card { display:flex; align-items:center; gap:12px; padding:14px 12px; border-radius:var(--r-md); border:1px solid transparent; cursor:pointer; transition:var(--t-fast); position:relative; margin-bottom:2px }
.prod-card:hover, .prod-card.in-cart { background:var(--bg-card); border-color:var(--border) }
.prod-card.in-cart { border-color:rgba(200,51,138,.25) }
.prod-card.in-cart::before { content:''; position:absolute; left:0; top:20%; bottom:20%; width:2px; background:var(--brand-magenta); border-radius:2px }
.prod-emoji-box { width:52px; height:52px; border-radius:var(--r-sm); background:var(--bg-surface); display:flex; align-items:center; justify-content:center; font-size:1.6rem; flex-shrink:0; border:1px solid rgba(255,255,255,.05) }
.prod-info { flex:1; min-width:0 }
.prod-name  { font-family:var(--font-alt); font-size:1.05rem; font-weight:700; letter-spacing:.03em; text-transform:uppercase; color:var(--text-primary); display:flex; align-items:center; gap:5px; flex-wrap:wrap; line-height:1.2 }
.badge-top  { background:var(--brand-red); color:white; font-size:.52rem; letter-spacing:.08em; padding:2px 6px; border-radius:var(--r-pill) }
.badge-new  { background:var(--brand-purple); color:white; font-size:.52rem; letter-spacing:.08em; padding:2px 6px; border-radius:var(--r-pill) }
.badge-star { color:var(--brand-star); font-size:.75rem }
.prod-desc  { font-size:.82rem; color:var(--text-muted); margin-top:3px; line-height:1.4; white-space:nowrap; overflow:hidden; text-overflow:ellipsis }
.prod-right { display:flex; flex-direction:column; align-items:flex-end; gap:6px; flex-shrink:0 }
.prod-price { font-family:var(--font-alt); font-size:1.05rem; font-weight:700; color:var(--text-primary); white-space:nowrap }
.qty-row    { display:flex; align-items:center; gap:8px }
.qty-btn    { width:28px; height:28px; border-radius:50%; background:var(--bg-surface); border:1px solid var(--border); color:var(--text-primary); font-size:1.1rem; line-height:1; display:flex; align-items:center; justify-content:center; cursor:pointer; transition:var(--t-fast); flex-shrink:0; -webkit-tap-highlight-color:transparent }
.qty-btn:hover, .qty-btn:active { background:var(--brand-magenta); border-color:var(--brand-magenta) }
.qty-num    { font-family:var(--font-alt); font-size:.9rem; font-weight:700; min-width:16px; text-align:center }

/* Carrito flotante */
#cart-float { position:fixed; bottom:-88px; left:0; right:0; z-index:900; padding:10px 16px; transition:bottom .4s cubic-bezier(.4,0,.2,1); display:flex; justify-content:center; pointer-events:none }
#cart-float.visible { bottom:0; pointer-events:auto }
.cart-float-inner { display:flex; align-items:center; gap:10px; background:var(--bg-card); border:1px solid var(--border-active); border-radius:var(--r-pill); padding:10px 10px 10px 18px; max-width:500px; width:100%; box-shadow:0 -8px 40px rgba(0,0,0,.5),var(--glow-magenta) }
.cart-float-info  { flex:1 }
.cart-float-count { font-family:var(--font-alt); font-size:.68rem; letter-spacing:.12em; color:var(--text-secondary); text-transform:uppercase }
.cart-float-total { font-family:var(--font-display); font-size:1.2rem; font-weight:700; color:var(--text-primary); line-height:1.1 }
.btn-cart-go      { background:var(--brand-magenta); color:white; font-family:var(--font-alt); font-size:.8rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; padding:12px 18px; border-radius:var(--r-pill); border:none; cursor:pointer; transition:var(--t); white-space:nowrap }
.btn-cart-go:hover { background:#a82070 }

/* ── RESERVAS ────────────────────────────────────────── */
#reservas { padding:80px 20px; text-align:center; position:relative; background:var(--bg-surface) }
.reservas-bg { position:absolute; inset:0; z-index:0 }
.reservas-bg .bg-media { width:100%; height:100%; object-fit:cover; opacity:.12 }
.reservas-inner { position:relative; z-index:1; max-width:480px; margin:0 auto }
.reservas-ring  { width:90px; height:90px; border-radius:50%; border:2px solid var(--brand-magenta); display:flex; align-items:center; justify-content:center; font-size:2.5rem; margin:0 auto 24px; box-shadow:var(--glow-magenta); animation:ringPulse 3s ease infinite }
@keyframes ringPulse { 0%,100%{box-shadow:var(--glow-magenta)} 50%{box-shadow:0 0 40px rgba(200,51,138,.7)} }
.reservas-title  { font-size:clamp(2.2rem,9vw,3.5rem); color:var(--text-primary); margin-bottom:14px }
.reservas-title span { color:var(--brand-magenta) }
.reservas-desc   { font-size:.9rem; color:var(--text-secondary); line-height:1.7; margin-bottom:32px }
.reservas-btns   { display:flex; flex-direction:column; gap:12px; align-items:center }
.btn-wa-main     { display:flex; align-items:center; justify-content:center; gap:10px; background:var(--wa-green); color:white; font-family:var(--font-alt); font-size:.9rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; padding:16px 32px; border-radius:var(--r-pill); text-decoration:none; transition:var(--t); width:100%; max-width:320px }
.btn-wa-main:hover { background:#1da851; transform:translateY(-2px) }
.btn-meitre-main { display:flex; align-items:center; justify-content:center; gap:8px; background:transparent; border:1px solid var(--border-active); color:var(--brand-magenta); font-family:var(--font-alt); font-size:.82rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; padding:14px 28px; border-radius:var(--r-pill); text-decoration:none; transition:var(--t); width:100%; max-width:320px }
.btn-meitre-main:hover { background:rgba(200,51,138,.1); transform:translateY(-2px) }

/* ── UBICACIÓN ───────────────────────────────────────── */
#ubicacion { padding:80px 20px; background:var(--bg-base); position:relative }
.ubicacion-bg { position:absolute; inset:0; background:radial-gradient(ellipse at 50% 100%,rgba(61,27,110,.15) 0%,transparent 60%) }
.ubicacion-inner { position:relative; z-index:1; max-width:680px; margin:0 auto; text-align:center }
.ubicacion-title { font-size:clamp(2.2rem,9vw,3.5rem); color:var(--text-primary); margin-bottom:8px }
.ubicacion-title span { color:var(--brand-magenta) }
.ubicacion-sub   { font-size:.88rem; color:var(--text-secondary); margin-bottom:28px }
.mapa-wrap       { border-radius:var(--r-xl); overflow:hidden; height:360px; border:1px solid var(--border); margin-bottom:24px; position:relative }
.mapa-wrap iframe{ width:100%; height:100%; border:none; display:block }
.ubicacion-details { display:flex; flex-direction:column; align-items:center; gap:12px }
.ubicacion-addr  { font-size:.9rem; color:var(--text-secondary); line-height:1.6 }
.ubicacion-addr strong { color:var(--text-primary) }
.btn-open-maps   { display:inline-flex; align-items:center; gap:8px; background:var(--brand-magenta); color:white; font-family:var(--font-alt); font-size:.82rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; padding:14px 28px; border-radius:var(--r-pill); text-decoration:none; transition:var(--t) }
.btn-open-maps:hover { background:#a82070; transform:translateY(-2px); box-shadow:var(--glow-magenta) }

/* ── FOOTER ──────────────────────────────────────────── */
#footer { background:var(--bg-card); border-top:1px solid var(--border) }
.footer-main { padding:52px 20px 36px; max-width:960px; margin:0 auto; display:grid; grid-template-columns:1fr; gap:36px }
.footer-brand-col { display:flex; flex-direction:column; gap:14px }
.footer-brand-logo { display:flex; flex-direction:column; gap:2px }
.footer-logo-img   { max-height:60px; width:auto; object-fit:contain; filter:brightness(0) invert(1) }
.footer-logo-small { font-family:var(--font-alt); font-size:.5rem; letter-spacing:.45em; color:var(--text-muted); text-transform:uppercase }
.footer-logo-big   { font-family:var(--font-display); font-size:2rem; font-weight:900; color:var(--text-primary); letter-spacing:.06em; text-transform:uppercase; line-height:1 }
.footer-logo-galeria { font-family:var(--font-alt); font-size:.55rem; letter-spacing:.55em; color:var(--brand-magenta); text-transform:uppercase }
.footer-tagline { font-size:.82rem; color:var(--text-secondary); font-style:italic }
.footer-social  { display:flex; gap:8px }
.soc-btn { width:40px; height:40px; border-radius:50%; background:var(--bg-surface); border:1px solid var(--border); display:flex; align-items:center; justify-content:center; color:var(--text-secondary); transition:var(--t); text-decoration:none }
.soc-btn:hover { background:var(--brand-magenta); border-color:var(--brand-magenta); color:white; transform:translateY(-3px) }

/* Columnas del footer */
.footer-col-title { font-family:var(--font-alt); font-size:.62rem; letter-spacing:.22em; text-transform:uppercase; color:var(--brand-magenta); margin-bottom:14px; padding-bottom:8px; border-bottom:1px solid var(--border) }
.footer-links { display:flex; flex-direction:column; gap:9px }
.footer-links a { font-size:.8rem; color:var(--text-secondary); transition:var(--t-fast) }
.footer-links a:hover { color:var(--brand-magenta) }
.footer-info-row { display:flex; align-items:flex-start; gap:10px; font-size:.8rem; color:var(--text-secondary); line-height:1.5; margin-bottom:10px }
.footer-info-icon { font-size:.9rem; flex-shrink:0; margin-top:2px }
.footer-map-wrap { border-radius:var(--r-lg); overflow:hidden; border:1px solid var(--border); height:180px; margin-top:8px }
.footer-map-wrap iframe { width:100%; height:100%; border:none; display:block }

.footer-bottom { border-top:1px solid var(--border); padding:16px 20px; display:flex; flex-direction:column; align-items:center; gap:6px; text-align:center }
.footer-bottom-text { font-size:.7rem; color:var(--text-muted); line-height:1.7 }
.footer-bottom-text a { color:var(--brand-magenta); transition:var(--t-fast) }
.footer-bottom-text a:hover { color:var(--text-primary) }
.footer-dev { display:flex; align-items:center; gap:6px; font-size:.65rem; color:var(--text-muted) }
.footer-dev a { color:var(--brand-purple); font-weight:700; letter-spacing:.05em; transition:var(--t-fast) }
.footer-dev a:hover { color:var(--brand-magenta) }

/* ── MODALES ─────────────────────────────────────────── */
.modal-backdrop { position:fixed; inset:0; background:rgba(5,4,7,.88); backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px); z-index:2000; display:flex; align-items:flex-end; justify-content:center; opacity:0; visibility:hidden; transition:var(--t) }
.modal-backdrop.open { opacity:1; visibility:visible }
.modal-sheet { background:var(--bg-card); border-radius:var(--r-xl) var(--r-xl) 0 0; border:1px solid var(--border); border-bottom:none; width:100%; max-width:480px; padding:28px 22px 44px; transform:translateY(100%); transition:transform .4s cubic-bezier(.4,0,.2,1); position:relative; max-height:92svh; overflow-y:auto }
.modal-backdrop.open .modal-sheet { transform:translateY(0) }
.modal-handle { width:36px; height:4px; background:var(--text-muted); border-radius:2px; margin:0 auto 22px; opacity:.4 }
.modal-close-btn { position:absolute; top:14px; right:16px; width:30px; height:30px; border-radius:50%; background:var(--bg-surface); color:var(--text-muted); font-size:.9rem; display:flex; align-items:center; justify-content:center; cursor:pointer; transition:var(--t-fast) }
.modal-close-btn:hover { background:var(--brand-magenta); color:white }
.modal-eyebrow { display:inline-flex; align-items:center; gap:6px; background:rgba(200,51,138,.1); border:1px solid rgba(200,51,138,.3); border-radius:var(--r-pill); padding:4px 12px; font-family:var(--font-alt); font-size:.65rem; letter-spacing:.18em; color:var(--brand-magenta); text-transform:uppercase; margin-bottom:12px }
.modal-title { font-size:1.6rem; color:var(--text-primary); margin-bottom:8px }
.modal-title span { color:var(--brand-magenta) }
.modal-desc { font-size:.84rem; color:var(--text-secondary); margin-bottom:22px; line-height:1.6 }
.data-form  { display:flex; flex-direction:column; gap:12px }
.form-field { display:flex; flex-direction:column; gap:5px }
.form-label { font-family:var(--font-alt); font-size:.65rem; letter-spacing:.18em; text-transform:uppercase; color:var(--text-muted) }
.form-input { background:var(--bg-surface); border:1px solid var(--border); border-radius:var(--r-md); color:var(--text-primary); padding:13px 15px; font-size:1rem; outline:none; transition:var(--t-fast); -webkit-appearance:none; width:100%; -webkit-tap-highlight-color:transparent }
.form-input:focus { border-color:var(--brand-magenta); box-shadow:0 0 0 3px rgba(200,51,138,.15) }
.form-input::placeholder { color:var(--text-muted) }
.btn-modal-primary { display:flex; align-items:center; justify-content:center; gap:8px; background:var(--brand-magenta); color:white; font-family:var(--font-display); font-size:1rem; letter-spacing:.1em; text-transform:uppercase; padding:15px 24px; border-radius:var(--r-md); border:none; cursor:pointer; transition:var(--t); width:100%; margin-top:8px }
.btn-modal-primary:hover { background:#a82070; transform:translateY(-1px) }
.btn-modal-primary:disabled { opacity:.5; cursor:not-allowed; transform:none }
.btn-modal-wa { display:flex; align-items:center; justify-content:center; gap:10px; background:var(--wa-green); color:white; font-family:var(--font-display); font-size:.95rem; letter-spacing:.08em; text-transform:uppercase; padding:15px 24px; border-radius:var(--r-md); border:none; cursor:pointer; transition:var(--t); width:100%; margin-top:12px }
.btn-modal-wa:hover { background:#1da851; transform:translateY(-1px) }

/* Modal consentimiento centrado */
.modal-backdrop.consent-centered { align-items:center }
.consent-sheet { background:var(--bg-card); border-radius:var(--r-xl); border:1px solid var(--border-active); padding:28px 22px 22px; max-width:340px; width:calc(100% - 32px); transform:scale(.9); transition:transform .3s ease; box-shadow:var(--glow-magenta),var(--shadow-float) }
.modal-backdrop.open .consent-sheet { transform:scale(1) }
.consent-icon  { font-size:2rem; margin-bottom:12px; text-align:center; display:block }
.consent-title { font-size:1.2rem; color:var(--text-primary); text-align:center; margin-bottom:10px }
.consent-text  { font-size:.78rem; color:var(--text-secondary); line-height:1.6; margin-bottom:18px; text-align:center }
.consent-text strong { color:var(--brand-magenta) }
.consent-btns  { display:flex; gap:8px }
.consent-accept{ flex:1; background:var(--brand-magenta); color:white; font-family:var(--font-alt); font-size:.78rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; padding:12px; border-radius:var(--r-md); border:none; cursor:pointer; transition:var(--t-fast) }
.consent-accept:hover { background:#a82070 }
.consent-reject{ flex:1; background:var(--bg-surface); color:var(--text-muted); font-family:var(--font-alt); font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; padding:12px; border-radius:var(--r-md); border:1px solid var(--border); cursor:pointer; transition:var(--t-fast) }

/* Order modal */
.order-row { display:flex; justify-content:space-between; padding:8px 0; border-bottom:1px solid rgba(255,255,255,.04); font-size:.86rem }
.order-row .name  { color:var(--text-secondary) }
.order-row .price { font-family:var(--font-alt); font-weight:700 }
.order-total-row  { display:flex; justify-content:space-between; padding:12px 0 0; font-family:var(--font-alt); font-weight:700; font-size:1rem }

/* Botón PDF */
/* Botón flotante WhatsApp */
#wa-float-btn {
  position: fixed; right: 14px; bottom: 88px; z-index: 800;
  background: var(--wa-green);
  color: #fff;
  border-radius: 50%;
  width: 52px; height: 52px;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 18px rgba(37,211,102,.45), var(--shadow-card);
  transition: var(--t);
  border: 2px solid rgba(255,255,255,.18);
}
#wa-float-btn:hover { background: #1da851; transform: scale(1.08); box-shadow: 0 6px 24px rgba(37,211,102,.6) }

/* ── REVEAL / ANIMACIONES ────────────────────────────── */
.reveal      { opacity:0; transform:translateY(28px); transition:opacity .65s ease,transform .65s ease }
.reveal.visible { opacity:1; transform:translateY(0) }
.reveal-left { opacity:0; transform:translateX(-28px); transition:opacity .65s ease,transform .65s ease }
.reveal-left.visible { opacity:1; transform:translateX(0) }

/* ── UTILIDADES ──────────────────────────────────────── */
.glass { background:var(--bg-glass); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px); border:1px solid var(--border); border-radius:var(--r-lg) }
.btn-secondary { display:inline-flex; align-items:center; gap:8px; border:1px solid var(--border-active); color:var(--brand-magenta); font-family:var(--font-alt); font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; padding:11px 22px; border-radius:var(--r-pill); cursor:pointer; transition:var(--t); background:transparent }
.btn-secondary:hover { background:var(--brand-magenta); color:white; border-color:var(--brand-magenta) }
.sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0 }

/* ── KEYFRAMES ───────────────────────────────────────── */
@keyframes fadeIn    { from{opacity:0} to{opacity:1} }
@keyframes fadeInUp  { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:translateY(0)} }
@keyframes fadeInDown{ from{opacity:0;transform:translateY(-12px)} to{opacity:1;transform:translateY(0)} }

/* ── RESPONSIVE ──────────────────────────────────────── */
@media(min-width:600px) { .galeria-editorial { grid-auto-rows:180px } }
@media(min-width:768px) {
  .nav-links { display:flex } .hamburger { display:none }
  .juego-content { grid-template-columns:1fr 1fr; min-height:100svh }
  .juego-panel-text { padding:100px 48px 60px }
  .juego-panel-dice { padding:60px 48px }
  .footer-main { grid-template-columns:1.6fr 1fr 1fr 1.4fr; gap:32px }
  .mapa-wrap { height:420px }
}
@media(min-width:1024px) {
  .galeria-editorial { grid-template-columns:repeat(4,1fr); grid-auto-rows:160px; max-width:1060px }
}

/* ── COMIDAS & BEBIDAS BLOCK ──────────────────────────── */
.comida-block {
  padding: 40px 12px 20px;
  max-width: 1060px;
  margin: 0 auto;
  width: 100%;
}
.comida-header {
  text-align: center;
  margin-bottom: 24px;
}
.comida-title {
  font-family: var(--font-alt);
  font-size: clamp(1.6rem, 5vw, 2.4rem);
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--text-primary);
  margin-top: 6px;
}
.comida-title span { color: var(--brand-magenta) }

/*
  Grid editorial 14 slots — 3 columnas, sin huecos.
  Estructura:
  [ 1-tall ] [ 2 ]  [ 3 ]
  [ 1-cont ] [ 4 ]  [ 5 ]
  [ 6      ] [ 7-wide      ]
  [ 8 ] [ 9-tall ] [ 10   ]
  [ 11] [ 9-cont ] [ 12   ]
  [ 13-wide       ] [ 14  ]
*/
.comida-editorial {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-auto-rows: 200px;
  gap: 6px;
}
/* Slot 1: alto (2 filas) */
.comida-editorial .gal-item:nth-child(1)  { grid-row: span 2 }
/* Slot 7: ancho (2 columnas) */
.comida-editorial .gal-item:nth-child(7)  { grid-column: span 2 }
/* Slot 9: alto (2 filas) */
.comida-editorial .gal-item:nth-child(9)  { grid-row: span 2 }
/* Slot 13: ancho (2 columnas) */
.comida-editorial .gal-item:nth-child(13) { grid-column: span 2 }

.comida-item { /* hereda todo de .gal-item */ }

/* Placeholder para slots vacíos — ambiente Y comidas */
.slot-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%; height: 100%;
  color: var(--text-muted);
  border: 2px dashed rgba(200,51,138,.2);
  border-radius: var(--r-md);
  pointer-events: none;
}
.slot-placeholder-icon {
  font-size: 1.8rem;
  opacity: .4;
}
.slot-placeholder-label {
  font-family: var(--font-alt);
  font-size: .58rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--text-muted);
  opacity: .5;
}

/* Mobile: 2 columnas, sin spans especiales para simplificar */
@media(max-width: 600px) {
  .comida-editorial {
    grid-template-columns: repeat(2, 1fr);
    grid-auto-rows: 140px;
  }
  .comida-editorial .gal-item:nth-child(1),
  .comida-editorial .gal-item:nth-child(9)  { grid-row: span 1 }
  .comida-editorial .gal-item:nth-child(7),
  .comida-editorial .gal-item:nth-child(13) { grid-column: span 1 }
}

/* ── LIGHTBOX MEJORADO ────────────────────────────────── */
#lightbox {
  position: fixed; inset: 0; z-index: 9000;
  background: rgba(5,4,7,.96);
  display: none; align-items: center; justify-content: center;
  backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px);
}
#lightbox.open { display: flex }
.lb-img-wrap { max-width: 90vw; max-height: 86svh; display:flex; align-items:center; justify-content:center }
.lb-img-wrap img  { max-width:90vw; max-height:86svh; object-fit:contain; border-radius:var(--r-md) }
.lb-img-wrap video{ max-width:90vw; max-height:86svh; border-radius:var(--r-md) }
.lb-close { position:absolute; top:14px; right:16px; font-size:1.6rem; color:white; opacity:.8; z-index:1; width:44px; height:44px; display:flex; align-items:center; justify-content:center; border-radius:50%; background:rgba(255,255,255,.1) }
.lb-close:hover { opacity:1; background:rgba(255,255,255,.2) }
.lb-prev, .lb-next { position:absolute; top:50%; transform:translateY(-50%); font-size:2.4rem; color:white; opacity:.7; padding:12px; z-index:1; width:52px; height:52px; display:flex; align-items:center; justify-content:center; background:rgba(0,0,0,.3); border-radius:50% }
.lb-prev { left:12px }
.lb-next { right:12px }
.lb-prev:hover, .lb-next:hover { opacity:1; background:rgba(200,51,138,.5) }
.lb-counter { position:absolute; bottom:16px; left:50%; transform:translateX(-50%); font-size:.72rem; letter-spacing:.15em; text-transform:uppercase; color:rgba(255,255,255,.5); font-family:var(--font-alt) }
