/* ============================================================
   KAYA CLUB · Guadarrama — Sistema visual v2 (motor Fable 5)
   Tipos: Neue Montreal · ITC Garamond (kickers) · Organetto (display) · DSEG7 (LED)
   Color: ROJO #FF0000 · AMARILLO #FFEA00 · crema · estética verano del sur de Italia
   Novedades 2026: view transitions entre páginas, scroll-driven animations CSS,
   bento grid, tipografía cinética, lightbox <dialog>, micro-interacciones.
   Todo con degradación elegante (@supports / prefers-reduced-motion / sin JS).
   ============================================================ */

/* ----------------------------- FUENTES ----------------------------- */
@font-face{font-family:"Neue Montreal";src:url("../fonts/NeueMontreal-Regular.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Neue Montreal";src:url("../fonts/NeueMontreal-Italic.woff2") format("woff2");font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:"Neue Montreal";src:url("../fonts/NeueMontreal-Medium.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Neue Montreal";src:url("../fonts/NeueMontreal-Bold.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"ITC Garamond";src:url("../fonts/ITCGaramond-Light.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"ITC Garamond";src:url("../fonts/ITCGaramond-LightItalic.woff2") format("woff2");font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:"ITC Garamond";src:url("../fonts/ITCGaramond-BookItalic.woff2") format("woff2");font-weight:600;font-style:italic;font-display:swap}
@font-face{font-family:"Organetto";src:url("../fonts/Organetto-Bold.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"Organetto";src:url("../fonts/Organetto-Ultrabold.woff2") format("woff2");font-weight:800;font-style:normal;font-display:swap}
@font-face{font-family:"DSEG7";src:url("../fonts/DSEG7Classic-Bold.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap}

/* ----------------------------- TOKENS ----------------------------- */
:root{
  --rojo:#ff0000;
  --rojo-700:#cc0000;
  --marca:#c10b0b;          /* superficie de marca (rojo profundo) */
  --marca-700:#9c0808;
  --marca-900:#5e0606;      /* footer */
  --crema:#f6ecd6;
  --crema-2:#fbf5e8;
  --naranja:#f4791f;
  --amarillo:#ffea00;
  --tinta:#231712;
  --negro:#0c0b0a;

  --sunset:linear-gradient(120deg,#ffea00 0%,#f4791f 48%,#ff0000 100%);

  --f-body:"Neue Montreal",system-ui,-apple-system,"Segoe UI",sans-serif;
  --f-display:"Organetto","Neue Montreal",system-ui,sans-serif;
  --f-serif:"ITC Garamond",Garamond,"Times New Roman",serif;
  --f-led:"DSEG7","Courier New",monospace;

  --wrap:1240px;
  --r:20px;
  --r-pill:999px;
  --nav-h:74px;
  --shadow:0 18px 50px -22px rgba(20,10,5,.55);
  --shadow-card:0 26px 60px -30px rgba(20,10,5,.6);
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
}

/* ----------------------------- RESET ----------------------------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-padding-top:calc(var(--nav-h) + 12px)}
@media(prefers-reduced-motion:no-preference){html{scroll-behavior:smooth}}
body{font-family:var(--f-body);color:var(--tinta);background:var(--crema);line-height:1.6;overflow-x:clip;-webkit-font-smoothing:antialiased}
body.menu-open{overflow:hidden}
img,video{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
svg{display:block}
::selection{background:var(--rojo);color:#fff}

/* Accesibilidad */
.sr-only{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.skip{position:fixed;top:10px;left:10px;z-index:300;background:var(--tinta);color:#fff;font-weight:700;padding:.8rem 1.2rem;border-radius:12px;transform:translateY(-200%);transition:transform .25s var(--ease)}
.skip:focus-visible{transform:none}
:focus-visible{outline:3px solid var(--rojo);outline-offset:3px;border-radius:4px}
.section--marca :focus-visible,.section--noche :focus-visible,.foot :focus-visible,.nav :focus-visible,.hero-cover :focus-visible{outline-color:var(--amarillo)}

/* ----------------------------- VIEW TRANSITIONS (MPA) ----------------------------- */
@view-transition{navigation:auto}
.nav{view-transition-name:site-nav}
.grain{view-transition-name:site-grain}
@media(prefers-reduced-motion:no-preference){
  ::view-transition-old(root){animation:vt-out .26s var(--ease) both}
  ::view-transition-new(root){animation:vt-in .38s var(--ease-out) both}
}
@keyframes vt-out{to{opacity:0;transform:translateY(-14px)}}
@keyframes vt-in{from{opacity:0;transform:translateY(18px)}}

/* ----------------------------- BARRA DE PROGRESO DE SCROLL ----------------------------- */
.progress{position:fixed;top:0;left:0;right:0;height:4px;z-index:260;pointer-events:none;background:transparent}
.progress::before{content:"";display:block;height:100%;width:100%;background:var(--sunset);transform-origin:0 50%;transform:scaleX(0)}
@media(prefers-reduced-motion:no-preference){
  @supports(animation-timeline:scroll()){
    .progress::before{animation:growX linear both;animation-timeline:scroll(root)}
  }
}
@keyframes growX{from{transform:scaleX(0)}to{transform:scaleX(1)}}

/* ----------------------------- GRANO ----------------------------- */
.grain{position:fixed;inset:0;z-index:220;pointer-events:none;opacity:.05;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* ----------------------------- TIPOGRAFÍA ----------------------------- */
h1,h2,h3,h4{font-weight:700;line-height:1.03;letter-spacing:-.02em}
.kicker{font-family:var(--f-serif);font-style:italic;font-weight:400;font-size:clamp(1.15rem,2.3vw,1.6rem);color:var(--rojo);line-height:1.1;display:inline-block}
.title{font-family:var(--f-display);font-weight:800;font-size:clamp(2.1rem,5.6vw,4.2rem);text-transform:uppercase;letter-spacing:-.015em;line-height:.96;margin-left:-.06em}
/* -.06em compensa el bearing izquierdo de Organetto para alinear con kickers y párrafos */
.title--sm{font-size:clamp(1.7rem,4vw,2.9rem)}
.center .title,.section-head.center .title,.section--sunset .title{margin-left:0}
.lead{font-size:clamp(1.02rem,1.55vw,1.2rem);max-width:62ch;color:#48382e}
.section-head{margin-bottom:clamp(1.9rem,4vw,3.2rem);max-width:70ch}
.section-head .kicker{display:block;margin:0 0 .15rem 0}
.section-head .lead{margin-top:clamp(.7rem,1.4vw,1.05rem)}
.section-head.center{margin-inline:auto;text-align:center}
.text-rojo{color:var(--rojo)}
.text-amarillo{color:var(--amarillo)}
.text-crema{color:var(--crema)}
.center{text-align:center}

/* ----------------------------- LAYOUT ----------------------------- */
.wrap{width:min(100% - 2.6rem,var(--wrap));margin-inline:auto}
.section{padding:clamp(3.6rem,8vw,7rem) 0;position:relative}
.section--marca{background:var(--marca);color:var(--crema)}
.section--marca .lead{color:#ffe7e0}
.section--marca .kicker{color:var(--amarillo)}
.section--noche{background:var(--negro);color:var(--crema)}
.section--noche .lead{color:#e8c7c3}
.section--sunset{background:var(--sunset);color:#fff;text-align:center}
.section--sunset .kicker{color:#fff}
.section--sunset .lead{color:#fff5e6;margin-inline:auto}

/* ----------------------------- NAVBAR ----------------------------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:240;height:var(--nav-h);display:flex;align-items:center;
  background:rgba(150,9,9,.96);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);
  box-shadow:0 10px 30px -18px rgba(0,0,0,.6);transition:background .35s var(--ease),box-shadow .35s var(--ease)}
.nav--hero{background:transparent;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}
.nav--hero.scrolled{background:rgba(150,9,9,.96);box-shadow:0 10px 30px -18px rgba(0,0,0,.6);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}
.nav__in{width:min(100% - 2.6rem,1340px);margin-inline:auto;display:flex;align-items:center;justify-content:space-between;gap:1rem}
.nav__logo{position:relative;z-index:2}
.nav__logo img{height:34px;width:auto}
.nav__links{display:flex;align-items:center;gap:.25rem}
.nav__links a{position:relative;color:var(--crema);font-weight:500;font-size:.95rem;padding:.55rem .95rem;border-radius:var(--r-pill);transition:color .2s,background .2s}
.nav__links a:hover{background:rgba(255,255,255,.14)}
.nav__links a.active{color:var(--amarillo)}
.nav__links a.active::after{content:"";position:absolute;left:50%;bottom:.18rem;width:4px;height:4px;border-radius:50%;background:var(--amarillo);transform:translateX(-50%)}
.nav__cta{display:inline-flex;align-items:center;gap:.45rem;background:var(--amarillo);color:var(--tinta)!important;font-weight:700;padding:.55rem 1.15rem!important;border-radius:var(--r-pill)}
.nav__cta::after{display:none!important}
.nav__cta:hover{background:#fff200!important}
.nav__burger{display:none;width:46px;height:46px;border-radius:14px;position:relative;background:rgba(255,255,255,.14);z-index:2}
.nav__burger span{position:absolute;left:12px;right:12px;height:2.5px;background:var(--crema);border-radius:2px;transition:.32s var(--ease)}
.nav__burger span:nth-child(1){top:16px}.nav__burger span:nth-child(2){top:22px}.nav__burger span:nth-child(3){top:28px}
.nav.open .nav__burger span:nth-child(1){top:22px;transform:rotate(45deg)}
.nav.open .nav__burger span:nth-child(2){opacity:0}
.nav.open .nav__burger span:nth-child(3){top:22px;transform:rotate(-45deg)}

/* Menú móvil: panel a pantalla completa con enlaces XXL escalonados */
@media(max-width:880px){
  .nav__burger{display:block}
  .nav__links{position:fixed;inset:0;z-index:1;flex-direction:column;align-items:flex-start;justify-content:center;gap:.4rem;
    padding:calc(var(--nav-h) + 1rem) 1.6rem 2rem;background:linear-gradient(160deg,var(--marca) 0%,var(--marca-900) 100%);
    opacity:0;visibility:hidden;transition:opacity .35s var(--ease),visibility 0s .35s}
  .nav.open .nav__links{opacity:1;visibility:visible;transition:opacity .35s var(--ease)}
  .nav__links a{font-family:var(--f-display);font-weight:800;text-transform:uppercase;font-size:clamp(1.9rem,9vw,3rem);
    padding:.35rem .2rem;border-radius:10px;opacity:0;transform:translateY(22px);transition:opacity .4s var(--ease),transform .4s var(--ease)}
  .nav.open .nav__links a{opacity:1;transform:none}
  .nav.open .nav__links a:nth-child(1){transition-delay:.05s}
  .nav.open .nav__links a:nth-child(2){transition-delay:.1s}
  .nav.open .nav__links a:nth-child(3){transition-delay:.15s}
  .nav.open .nav__links a:nth-child(4){transition-delay:.2s}
  .nav.open .nav__links a:nth-child(5){transition-delay:.25s}
  .nav__links a.active::after{display:none}
  .nav__cta{font-size:1.05rem!important;font-family:var(--f-body);text-transform:none;margin-top:1.2rem;padding:.85rem 1.6rem!important}
}

/* ----------------------------- BOTONES ----------------------------- */
.btn{position:relative;display:inline-flex;align-items:center;gap:.55rem;font-weight:600;font-size:.95rem;text-transform:uppercase;letter-spacing:.04em;
  padding:.95rem 1.75rem;border-radius:var(--r-pill);background:var(--rojo);color:#fff;box-shadow:0 16px 30px -16px var(--rojo);
  transition:transform .25s var(--ease),box-shadow .25s,background .25s;will-change:transform}
.btn:hover{box-shadow:0 22px 38px -16px var(--rojo);background:var(--rojo-700)}
.btn--amarillo{background:var(--amarillo);color:var(--tinta);box-shadow:0 16px 30px -16px rgba(244,121,31,.8)}
.btn--amarillo:hover{background:#fff200}
.btn--ghost{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.85);box-shadow:none}
.btn--ghost:hover{background:#fff;color:var(--rojo);border-color:#fff}
.btn--tinta{background:var(--tinta);color:var(--crema);box-shadow:0 16px 30px -16px rgba(12,11,10,.8)}
.btn--lg{padding:1.08rem 2.2rem;font-size:1.01rem}
.btn .arrow{transition:transform .25s var(--ease)}
.btn:hover .arrow{transform:translateX(4px)}
@media(hover:hover) and (pointer:fine){
  .btn{transform:translate(var(--tx,0),var(--ty,0))}
}

/* ----------------------------- HERO COVER (inicio) ----------------------------- */
/* Vídeo de intro a pantalla completa + velo suave para legibilidad (sin sombras en el texto) */
.hero-cover{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden;color:#fff;
  background:linear-gradient(172deg,#e31212 0%,#c10b0b 52%,#7c0707 100%)}
.hero-cover__bg{position:absolute;inset:0;z-index:0}
.hero-cover__bg video{width:100%;height:100%;object-fit:cover}
.hero-cover__scrim{position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(24,4,4,.4),rgba(24,4,4,.04) 30%,rgba(24,4,4,.12) 55%,rgba(20,3,3,.86)),
             linear-gradient(95deg,rgba(24,4,4,.46),rgba(24,4,4,.06) 56%,transparent 80%)}
.hero-cover__in{position:relative;z-index:2;display:grid;grid-template-columns:1.25fr .75fr;gap:clamp(1.6rem,4vw,3.5rem);align-items:end;
  padding-block:clamp(7.5rem,16vw,10rem) clamp(4.6rem,8vw,5.6rem)}
.hero-kicker{display:inline-flex;align-items:center;gap:.55rem;font-family:var(--f-serif);font-style:italic;font-size:clamp(1.05rem,2vw,1.35rem);color:#ffe9b8}
.hero-kicker .dot{width:9px;height:9px;border-radius:50%;background:var(--amarillo);box-shadow:0 0 0 5px rgba(255,234,0,.22);animation:pulse 2.4s ease-in-out infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 4px rgba(255,234,0,.22)}50%{box-shadow:0 0 0 9px rgba(255,234,0,.07)}}
.hero-title{font-family:var(--f-display);font-weight:800;text-transform:uppercase;line-height:.92;letter-spacing:-.015em;
  font-size:clamp(2.85rem,9.2vw,7.4rem);margin:.5rem 0 0 -.066em}
/* -.066em = bearing izquierdo medido de Organetto: alinea ópticamente el titular con los subtextos */
.hero-line{display:block;overflow:hidden;padding-bottom:.06em;margin-bottom:-.06em}
.hero-line>span{display:inline-block}
.hero-line--serif>span{font-family:var(--f-serif);font-style:italic;font-weight:600;text-transform:none;letter-spacing:0;color:var(--amarillo);font-size:1.04em}
.hero-sub{font-size:clamp(1.05rem,1.8vw,1.3rem);max-width:46ch;color:#fdeede;margin-top:1.1rem}
.hero-sub b{color:var(--amarillo)}
.hero-cta{display:flex;flex-wrap:wrap;gap:.85rem;margin-top:1.7rem}
.hero-chips{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.5rem}
.hero-chips li{font-size:.8rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:#fff;
  border:1px solid rgba(255,255,255,.4);background:rgba(255,255,255,.12);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  padding:.42rem .85rem;border-radius:var(--r-pill)}
/* Tarjetas flotantes (solo escritorio): vídeo delante, póster detrás */
.hero-media{position:relative;isolation:isolate;justify-self:end;width:min(300px,100%)}
.hero-card{position:relative;width:100%;border-radius:22px;overflow:hidden;aspect-ratio:9/14;
  box-shadow:0 40px 90px -30px rgba(0,0,0,.75);border:1px solid rgba(255,255,255,.25);background:#000;
  transform:rotate(2.6deg);transition:transform .5s var(--ease)}
.hero-card:hover{transform:rotate(0deg) scale(1.02)}
.hero-card video,.hero-card>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(0,0,0,.72));pointer-events:none}
.hero-card span{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:.95rem 1.1rem;font-weight:700;text-transform:uppercase;font-size:.92rem}
.hero-card--back{position:absolute;inset:0;z-index:-1;transform:rotate(-7deg) translate(-30px,16px) scale(.95);opacity:.95}
.hero-card--back:hover{transform:rotate(-7deg) translate(-30px,16px) scale(.95)}
.hero-scroll{position:absolute;left:50%;bottom:1.1rem;transform:translateX(-50%);z-index:3;display:grid;place-items:center;gap:.3rem;
  color:#fff;font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;opacity:.85}
.hero-scroll::after{content:"";width:1.5px;height:34px;background:linear-gradient(180deg,#fff,transparent);animation:drip 1.8s var(--ease) infinite}
@keyframes drip{0%{transform:scaleY(0);transform-origin:top}55%{transform:scaleY(1);transform-origin:top}56%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* Cinética: líneas del titular entran al cargar */
@media(prefers-reduced-motion:no-preference){
  html.js .hero-line>span{transform:translateY(112%);animation:lineUp .9s var(--ease-out) forwards}
  html.js .hero-line:nth-child(1)>span{animation-delay:.12s}
  html.js .hero-line:nth-child(2)>span{animation-delay:.24s}
  html.js .hero-line:nth-child(3)>span{animation-delay:.36s}
  html.js .hero-kicker,html.js .hero-sub,html.js .hero-cta,html.js .hero-chips{opacity:0;animation:fadeUp .8s var(--ease-out) forwards}
  html.js .hero-kicker{animation-delay:.05s}
  html.js .hero-sub{animation-delay:.5s}
  html.js .hero-cta{animation-delay:.62s}
  html.js .hero-chips{animation-delay:.74s}
  html.js .hero-card{opacity:0;animation:cardIn 1s var(--ease-out) .55s forwards}
  html.js .hero-card--back{animation:cardInBack 1s var(--ease-out) .42s forwards}
}
@keyframes lineUp{to{transform:translateY(0)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
@keyframes cardIn{from{opacity:0;transform:rotate(6deg) translateY(40px)}to{opacity:1;transform:rotate(2.6deg)}}
@keyframes cardInBack{from{opacity:0;transform:rotate(-12deg) translate(-30px,58px) scale(.95)}to{opacity:.95;transform:rotate(-7deg) translate(-30px,16px) scale(.95)}}

@media(max-width:1023px){
  .hero-cover__in{grid-template-columns:1fr;align-items:end}
  .hero-media{display:none}
}

/* ----------------------------- HERO SPLIT (interiores) ----------------------------- */
.hero-split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(1.6rem,4vw,3.6rem);align-items:center;
  padding:calc(var(--nav-h) + clamp(1.6rem,5vw,3.2rem)) max(1.3rem,calc((100% - var(--wrap))/2)) clamp(2.6rem,6vw,4.2rem);
  background:radial-gradient(115% 90% at 88% 6%,rgba(255,234,0,.32),transparent 55%),
             radial-gradient(90% 80% at 0% 100%,rgba(255,0,0,.1),transparent 55%),
             linear-gradient(180deg,var(--crema-2),var(--crema))}
.hero-split__badge{display:inline-flex;align-items:center;gap:.5rem;background:#fff;border:1px solid rgba(0,0,0,.08);padding:.45rem 1rem;border-radius:var(--r-pill);
  font-size:.78rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--marca);box-shadow:0 10px 24px -16px rgba(0,0,0,.4)}
.hero-split__badge .dot{width:8px;height:8px;border-radius:50%;background:var(--rojo);box-shadow:0 0 0 4px rgba(255,0,0,.18)}
.hero-split .kicker{display:block;margin:.95rem 0 .1rem 0}
.hero-split h1{font-family:var(--f-display);font-weight:800;font-size:clamp(2.7rem,8vw,5.6rem);text-transform:uppercase;line-height:.94;letter-spacing:-.02em;margin-left:-.06em}
.hero-split__sub{font-size:clamp(1.05rem,1.8vw,1.3rem);max-width:46ch;color:#4a3a30;margin-top:.8rem}
.hero-split__sub b{color:var(--rojo)}
.hero-split .hero-cta{margin-top:1.6rem}
.hero-split__frame{position:relative;border-radius:26px;overflow:hidden;aspect-ratio:4/5;max-height:74svh;background:#1a0606;box-shadow:var(--shadow-card);border:1px solid rgba(0,0,0,.06)}
.hero-split__frame img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-split__frame::after{content:"";position:absolute;inset:0;background:linear-gradient(200deg,rgba(255,234,0,.12),transparent 40%)}
@media(max-width:880px){
  .hero-split{grid-template-columns:1fr;gap:1.8rem}
  .hero-split__frame{max-height:56svh;order:2}
}
@media(prefers-reduced-motion:no-preference){
  html.js .hero-split h1,html.js .hero-split .kicker,html.js .hero-split__badge,html.js .hero-split__sub,html.js .hero-split .hero-cta{opacity:0;animation:fadeUp .75s var(--ease-out) forwards}
  html.js .hero-split .kicker{animation-delay:.08s}
  html.js .hero-split h1{animation-delay:.16s}
  html.js .hero-split__sub{animation-delay:.28s}
  html.js .hero-split .hero-cta{animation-delay:.4s}
  html.js .hero-split__frame{opacity:0;animation:fadeUp .9s var(--ease-out) .3s forwards}
}

/* ----------------------------- MARQUEE ----------------------------- */
.marquee{background:var(--rojo);color:#fff;overflow:hidden;border-block:3px solid var(--tinta);position:relative;z-index:3}
.marquee--amarillo{background:var(--amarillo);color:var(--tinta)}
.marquee__track{display:flex;white-space:nowrap;padding:.72rem 0;width:max-content}
.marquee span{font-weight:700;text-transform:uppercase;letter-spacing:.02em;font-size:1.04rem;display:inline-flex;align-items:center}
.marquee span::after{content:"●";color:var(--amarillo);margin:0 1.6rem;font-size:.6rem;transform:translateY(-1px)}
.marquee--amarillo span::after{color:var(--rojo)}
@media(prefers-reduced-motion:no-preference){
  .marquee__track{animation:marquee 28s linear infinite}
  .marquee:hover .marquee__track{animation-play-state:paused}
}
@media(prefers-reduced-motion:reduce){
  .marquee__track{width:auto;white-space:normal;flex-wrap:wrap;justify-content:center;gap:.3rem 0}
}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ----------------------------- BENTO ----------------------------- */
.bento{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:150px;gap:1rem}
.cell{position:relative;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-card);isolation:isolate}
.cell--spot::after{content:"";position:absolute;inset:0;z-index:3;opacity:0;transition:opacity .35s var(--ease);pointer-events:none;
  background:radial-gradient(260px circle at var(--mx,50%) var(--my,50%),rgba(255,255,255,.16),transparent 65%)}
@media(hover:hover) and (pointer:fine){.cell--spot:hover::after{opacity:1}}
.cell--img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.cell--img:hover img{transform:scale(1.05)}
.cell--img::before{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(12,11,10,0) 30%,rgba(12,11,10,.85) 100%)}
.cell__body{position:absolute;inset:auto 0 0 0;z-index:2;padding:1.3rem 1.4rem;color:var(--crema)}
.cell__tag{display:inline-block;background:var(--amarillo);color:var(--tinta);font-weight:700;font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;padding:.3rem .7rem;border-radius:var(--r-pill);margin-bottom:.55rem}
.cell__body h3{font-family:var(--f-display);font-weight:800;font-size:clamp(1.3rem,2.6vw,1.9rem);text-transform:uppercase}
.cell__body p{color:#eadfca;font-size:.95rem;margin-top:.15rem}
.cell--sala{grid-column:span 2;grid-row:span 3}
.cell--sala img{object-position:center 42%}
.cell--terraza{grid-column:span 1;grid-row:span 2}
.cell--terraza img{object-position:center 46%}
.cell--stat{display:flex;flex-direction:column;justify-content:center;align-items:flex-start;gap:.2rem;padding:1.2rem 1.3rem;background:var(--crema-2);border:1px solid rgba(36,23,18,.08)}
.cell--stat b{font-family:var(--f-led);font-weight:700;font-size:clamp(1.45rem,2.6vw,2.05rem);color:var(--rojo);line-height:1.22}
.cell--stat b.word{font-family:var(--f-display);font-weight:800;text-transform:uppercase;font-size:clamp(1.6rem,3.2vw,2.3rem)}
.cell--stat span{font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:#6a584c;font-weight:600}
.cell--stat small{font-size:.82rem;color:#8a7568}
.cell--ig{background:var(--sunset);color:#fff;display:flex;flex-direction:column;justify-content:space-between;padding:1.2rem 1.3rem;transition:transform .3s var(--ease)}
.cell--ig:hover{transform:translateY(-4px)}
.cell--ig svg{width:30px;height:30px;fill:#fff}
.cell--ig b{font-weight:700;font-size:1.02rem;line-height:1.25}
.cell--quote{background:var(--tinta);color:var(--crema);display:flex;align-items:center;justify-content:center;text-align:center;padding:1.3rem 1.6rem;grid-column:span 4}
.cell--quote p{font-family:var(--f-serif);font-style:italic;font-size:clamp(1.15rem,2.6vw,1.7rem);line-height:1.3;color:#ffe9b8}
@media(max-width:980px){
  .bento{grid-template-columns:repeat(2,1fr);grid-auto-rows:140px}
  .cell--sala{grid-column:span 2}
  .cell--quote{grid-column:span 2}
}
@media(max-width:560px){
  .bento{grid-template-columns:1fr 1fr;grid-auto-rows:130px}
  .cell--terraza{grid-column:span 2;grid-row:span 2}
  .cell--quote{grid-column:span 2}
}

/* ----------------------------- BOTELLINÓMETRO ----------------------------- */
.bm{position:relative;max-width:900px;margin-inline:auto;border-radius:26px;overflow:hidden;text-align:center;color:#fff;
  padding:clamp(2rem,5vw,3.6rem);border:1px solid rgba(255,0,0,.4);
  background:radial-gradient(circle at 1px 1px,rgba(255,255,255,.06) 1px,transparent 1.4px) 0 0/14px 14px,
             radial-gradient(120% 120% at 50% -10%,#2a0e0e 0%,#0a0606 70%);
  box-shadow:inset 0 0 90px rgba(255,0,0,.16),0 40px 80px -40px rgba(0,0,0,.8)}
.bm::before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.16;z-index:1;
  background:repeating-linear-gradient(180deg,transparent 0 2px,rgba(0,0,0,.55) 2px 4px)}/* scanlines CRT */
.bm>*{position:relative;z-index:2}
.bm__pill{display:inline-flex;align-items:center;gap:.5rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;font-size:.72rem;color:#ffb4ae;
  border:1px solid rgba(255,0,0,.5);padding:.34rem .95rem;border-radius:var(--r-pill);background:rgba(255,0,0,.12)}
.bm__pill .live{width:8px;height:8px;border-radius:50%;background:#ff2a1e;animation:pulse 1.6s ease-in-out infinite}
.bm__label{font-family:var(--f-display);font-weight:800;text-transform:uppercase;letter-spacing:.04em;color:#ff5247;
  font-size:clamp(1.2rem,2.8vw,1.9rem);margin:1rem 0 .1rem;text-shadow:0 0 22px rgba(255,0,0,.6)}
.bm__countwrap{position:relative;display:inline-block;margin:.35rem 0 .1rem}
.bm__count{position:relative;font-family:var(--f-led);font-weight:700;font-size:clamp(3.2rem,14vw,8.6rem);line-height:1;letter-spacing:.06em}
.bm__count .num{color:#ff2a1e;text-shadow:0 0 8px rgba(255,42,30,.9),0 0 34px rgba(255,0,0,.85),0 0 70px rgba(255,0,0,.5)}
.bm__count .ghost{color:rgba(255,42,30,.10);position:absolute;left:0;right:0;top:0}
.bm.lit .bm__count .num{animation:ledBurst .9s var(--ease) 1}
@keyframes ledBurst{0%{text-shadow:0 0 8px rgba(255,42,30,.9),0 0 34px rgba(255,0,0,.85)}45%{text-shadow:0 0 18px rgba(255,90,60,1),0 0 80px rgba(255,40,0,1),0 0 140px rgba(255,0,0,.9)}100%{text-shadow:0 0 8px rgba(255,42,30,.9),0 0 34px rgba(255,0,0,.85),0 0 70px rgba(255,0,0,.5)}}
.bm__sub{color:#f0c9c6;font-size:1rem;margin-top:.3rem}
.bm__sub b{color:var(--amarillo)}
.bm__bar{margin:1.7rem auto 0;max-width:620px;height:20px;border-radius:var(--r-pill);background:rgba(255,255,255,.08);border:1px solid rgba(255,0,0,.4);overflow:hidden;padding:3px}
.bm__fill{height:100%;width:0;border-radius:var(--r-pill);background:repeating-linear-gradient(90deg,#ff2a1e 0,#ff2a1e 10px,#ff6a4d 10px,#ff6a4d 20px);box-shadow:0 0 20px rgba(255,42,30,.8);transition:width 1.8s var(--ease)}
.bm__meta{display:flex;justify-content:space-between;gap:.6rem;max-width:620px;margin:.6rem auto 0;font-size:.78rem;color:#e9b6b2;letter-spacing:.05em;text-transform:uppercase}
.bm__meta b{color:var(--amarillo);font-family:var(--f-led)}
.bm__note{margin-top:1.4rem;color:#cc9a94;font-size:.85rem}
.bm-clip{max-width:300px;margin:1.8rem auto 0;border-radius:18px;overflow:hidden;aspect-ratio:9/16;position:relative;box-shadow:var(--shadow-card);background:#000}
.bm-clip video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.bm-clip::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(0,0,0,.7) 100%)}
.bm-clip .reel__label{position:absolute;left:0;bottom:0;z-index:2;padding:.8rem 1rem;color:#fff;font-weight:700;text-transform:uppercase;font-size:.98rem}
/* Callout compacto (carta) */
.bm-strip{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:clamp(1.2rem,3vw,2.4rem);max-width:1040px;margin-inline:auto;text-align:left;border-radius:26px;overflow:hidden;
  padding:clamp(1.4rem,3.4vw,2.2rem);border:1px solid rgba(255,0,0,.4);
  background:radial-gradient(120% 120% at 50% -10%,#2a0e0e 0%,#0a0606 70%);box-shadow:inset 0 0 90px rgba(255,0,0,.14),0 40px 80px -40px rgba(0,0,0,.8);color:#fff}
.bm-strip img{width:clamp(150px,22vw,240px);border-radius:14px;border:1px solid rgba(255,0,0,.35)}
.bm-strip h2{font-family:var(--f-display);font-weight:800;text-transform:uppercase;font-size:clamp(1.3rem,3vw,2rem);color:#ff5247;text-shadow:0 0 22px rgba(255,0,0,.5)}
.bm-strip p{color:#f0c9c6;max-width:48ch;margin-top:.4rem}
.bm-strip p b{color:var(--amarillo)}
@media(max-width:880px){.bm-strip{grid-template-columns:1fr;text-align:center}.bm-strip img{margin-inline:auto}.bm-strip .btn{justify-self:center}}

/* ----------------------------- RAIL DE REELS (scroll-snap horizontal) ----------------------------- */
.rail-zone{timeline-scope:--rail}
.rail{display:flex;gap:1rem;overflow-x:auto;scroll-snap-type:x mandatory;padding:.4rem .2rem 1.2rem;
  scrollbar-width:none;-webkit-overflow-scrolling:touch;scroll-timeline:--rail x;cursor:grab}
.rail::-webkit-scrollbar{display:none}
.rail.dragging{cursor:grabbing;scroll-snap-type:none}
.reel{position:relative;flex:0 0 min(74vw,300px);border-radius:var(--r);overflow:hidden;aspect-ratio:9/15;box-shadow:var(--shadow-card);background:#000;scroll-snap-align:center}
.reel video,.reel img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.reel::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 52%,rgba(0,0,0,.72) 100%);pointer-events:none}
.reel__label{position:absolute;left:0;bottom:0;z-index:2;padding:1rem;color:#fff;font-weight:700;text-transform:uppercase;font-size:1rem}
.rail-bar{height:4px;max-width:280px;margin:.2rem auto 0;border-radius:99px;background:rgba(35,23,18,.15);overflow:hidden}
.section--marca .rail-bar,.section--noche .rail-bar{background:rgba(255,255,255,.18)}
.rail-bar::before{content:"";display:block;height:100%;width:100%;border-radius:99px;background:var(--rojo);transform-origin:0 50%;transform:scaleX(.12)}
.section--marca .rail-bar::before{background:var(--amarillo)}
@media(prefers-reduced-motion:no-preference){
  @supports(animation-timeline:scroll()){
    .rail-bar::before{animation:growX linear both;animation-timeline:--rail}
  }
}

/* ----------------------------- TARJETAS GENÉRICAS ----------------------------- */
.cards{display:grid;gap:1.3rem}
.cards--2{grid-template-columns:repeat(2,1fr)}
.cards--3{grid-template-columns:repeat(3,1fr)}
.feat{background:var(--crema-2);border-radius:var(--r);padding:1.8rem 1.6rem;border:1px solid rgba(36,23,18,.08);box-shadow:0 16px 40px -30px rgba(20,10,5,.5);transition:transform .3s var(--ease),box-shadow .3s;height:100%}
.feat:hover{transform:translateY(-5px);box-shadow:var(--shadow-card)}
.feat.center{display:flex;flex-direction:column;align-items:center;text-align:center}
.feat__ico{color:#fff;width:58px;height:58px;display:grid;place-items:center;border-radius:18px;background:var(--sunset);margin-bottom:1rem;box-shadow:0 12px 24px -14px var(--naranja)}
.feat__ico svg{width:27px;height:27px}
.feat h3{font-size:1.2rem;margin-bottom:.35rem;text-transform:uppercase}
.feat p{color:#5a4a40;font-size:.97rem;line-height:1.35}
.section--marca .feat{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.14);color:var(--crema)}
.section--marca .feat h3{color:var(--crema)}
.section--marca .feat p{color:#ffe2dc}
.section--noche .feat{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.12)}
.section--noche .feat h3{color:var(--crema)}
.section--noche .feat p{color:#e8c7c3}
.price-tag{display:grid;place-items:center;width:100px;height:100px;border-radius:50%;background:var(--sunset);color:#fff;font-weight:700;box-shadow:var(--shadow-card);text-align:center;margin-bottom:1.2rem}
.price-tag b{font-size:2.2rem;line-height:1;letter-spacing:-.02em}

/* ----------------------------- GÉNEROS ----------------------------- */
.genre{position:relative;border-radius:var(--r);overflow:hidden;padding:1.6rem;min-height:196px;display:flex;flex-direction:column;justify-content:flex-end;color:#fff;box-shadow:var(--shadow-card);transition:transform .35s var(--ease)}
.genre::before{content:"";position:absolute;inset:0;opacity:.12;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.genre:hover{transform:translateY(-5px)}
.genre:nth-child(6n+1){background:linear-gradient(140deg,#ff1a1a,#cc0000)}
.genre:nth-child(6n+2){background:linear-gradient(140deg,#f4791f,#ff0000)}
.genre:nth-child(6n+3){background:linear-gradient(140deg,#5aa7d6,#2f6f9e)}
.genre:nth-child(6n+4){background:linear-gradient(140deg,#c10b0b,#6e0606)}
.genre:nth-child(6n+5){background:linear-gradient(140deg,#ffea00,#f4791f);color:var(--tinta)}
.genre:nth-child(6n+6){background:linear-gradient(140deg,#3a0c0c,#0c0b0a)}
.genre__ico{margin-bottom:auto;transition:transform .35s var(--ease)}
.genre:hover .genre__ico{transform:scale(1.12) rotate(-4deg)}
.genre__ico svg{width:36px;height:36px}
.genre h3{font-family:var(--f-display);font-weight:800;font-size:1.3rem;text-transform:uppercase;margin-top:.9rem;line-height:1.05}
.genre p{font-size:.92rem;opacity:.92;margin-top:.2rem}

/* ----------------------------- CALENDARIO ----------------------------- */
.cal{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.cal__card{background:var(--crema-2);border-radius:var(--r);padding:1.5rem 1.4rem;border:1px solid rgba(36,23,18,.08);text-align:center;box-shadow:0 16px 40px -32px rgba(20,10,5,.5)}
.cal__mes{font-family:var(--f-display);font-weight:800;text-transform:uppercase;font-size:1.3rem;color:var(--rojo)}
.cal__dias{display:flex;justify-content:center;gap:.4rem;margin-top:.95rem;flex-wrap:wrap}
.cal__d{width:42px;height:42px;display:grid;place-items:center;border-radius:50%;font-weight:600;font-size:.82rem;background:#eaddc4;color:#a8967f}
.cal__d.on{background:var(--rojo);color:#fff;box-shadow:0 8px 18px -8px var(--rojo)}
.cal__nota{font-size:.84rem;color:#6a584c;margin-top:.95rem}
.cal__row{display:flex;align-items:center;justify-content:space-between;gap:1rem;text-align:left}
.cal__card--dark{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.16);color:var(--crema)}
.cal__card--dark .cal__mes{color:var(--amarillo)}
.cal__card--dark .cal__nota{color:#ffe2dc}
.cal-open{display:flex;align-items:center;gap:1.2rem;background:var(--tinta);color:var(--crema);border-radius:var(--r);padding:1.4rem 1.6rem;box-shadow:var(--shadow-card);flex-wrap:wrap}
.cal-open__date{font-family:var(--f-led);font-weight:700;font-size:clamp(1.6rem,4vw,2.4rem);color:var(--amarillo);text-shadow:0 0 18px rgba(255,234,0,.45)}
.cal-open p{color:#eadfca;flex:1 1 240px}
@media(max-width:980px){.cal{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.cal{grid-template-columns:1fr}}

/* ----------------------------- STATS ----------------------------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;text-align:center}
.stat b{font-family:var(--f-led);font-weight:700;font-size:clamp(1.6rem,3.6vw,2.5rem);color:var(--rojo);display:block;line-height:1.22}
.section--marca .stat b,.section--noche .stat b{color:var(--amarillo);text-shadow:0 0 22px rgba(255,234,0,.35)}
.stat span{font-size:.8rem;text-transform:uppercase;letter-spacing:.08em;opacity:.85;font-weight:600}
@media(max-width:680px){.stats{grid-template-columns:repeat(2,1fr);gap:1.4rem}}

/* ----------------------------- CARTA ----------------------------- */
.split2{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.8rem,4vw,3rem);align-items:center}
@media(max-width:840px){.split2{grid-template-columns:1fr}}
.menu{display:grid;gap:1.1rem}
.menu__item{display:flex;align-items:baseline;gap:1rem;flex-wrap:wrap;padding:1.15rem 1.35rem;background:var(--crema-2);border-radius:16px;border:1px solid rgba(36,23,18,.08);color:var(--tinta);transition:transform .3s var(--ease),box-shadow .3s}
.menu__item:hover{transform:translateX(6px);box-shadow:0 18px 40px -26px rgba(20,10,5,.6)}
.menu__item h3{font-size:1.16rem;text-transform:uppercase;white-space:nowrap}
.menu__dots{flex:1;border-bottom:2px dotted rgba(36,23,18,.28);transform:translateY(-4px);min-width:24px}
.menu__price{font-family:var(--f-led);font-size:1.35rem;color:var(--rojo);white-space:nowrap}
.menu__desc{flex-basis:100%;color:#6a584c;font-size:.93rem;margin-top:-.25rem}
.menu__tag{display:inline-block;background:var(--amarillo);color:var(--tinta);font-weight:700;font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;padding:.32rem .75rem;border-radius:var(--r-pill)}

/* Botellín flotante + sticker */
.bottle-show{position:relative;width:min(320px,82vw);margin-inline:auto;display:grid;place-items:center;padding-block:1rem}
.bottle-show__img{width:min(210px,56vw);filter:drop-shadow(0 26px 30px rgba(20,10,5,.35))}
.bottle-show::after{content:"";position:absolute;left:50%;bottom:0;transform:translateX(-50%);width:130px;height:30px;border-radius:50%;background:radial-gradient(ellipse at center,rgba(20,10,5,.34),transparent 70%);filter:blur(6px)}
.bottle-show__badge{position:absolute;top:2%;right:2%;z-index:2;background:var(--amarillo);color:var(--tinta);font-weight:700;font-size:1.5rem;width:74px;height:74px;border-radius:50%;display:grid;place-items:center;box-shadow:var(--shadow-card);rotate:8deg}
@media(prefers-reduced-motion:no-preference){
  .bottle-show__img{animation:floaty 3.8s ease-in-out infinite}
  .bottle-show__badge{animation:wobble 3.8s ease-in-out infinite}
  @supports(animation-timeline:view()){
    .bottle-show{view-timeline:--bottle}
    .bottle-show__img{animation:floaty 3.8s ease-in-out infinite,bottleSpin linear both;animation-timeline:auto,--bottle;animation-range:normal,entry 0% cover 60%}
  }
}
@keyframes floaty{0%,100%{translate:0 -2.2%}50%{translate:0 2.2%}}
@keyframes wobble{0%,100%{rotate:8deg}50%{rotate:-2deg}}
@keyframes bottleSpin{from{rotate:-10deg}to{rotate:6deg}}

/* Smash: foto enmarcada con sticker */
.burger-frame{position:relative;max-width:440px;margin-inline:auto;border-radius:24px;overflow:hidden;
  box-shadow:0 36px 70px -28px rgba(0,0,0,.65);border:1px solid rgba(0,0,0,.3);background:#0c0b0a}
.burger-frame img{width:100%;height:auto;display:block;transition:transform .8s var(--ease)}
.burger-frame:hover img{transform:scale(1.04)}
.burger-frame__badge{position:absolute;top:14px;right:14px;z-index:2;background:var(--amarillo);color:var(--tinta);font-weight:700;font-size:.92rem;line-height:1.15;text-align:center;text-transform:uppercase;width:96px;height:96px;border-radius:50%;display:grid;place-items:center;box-shadow:var(--shadow-card);rotate:10deg;padding:.4rem}

/* ----------------------------- GALERÍA + LIGHTBOX ----------------------------- */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.gphoto{position:relative;aspect-ratio:4/5;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-card);padding:0;display:block;width:100%}
.gphoto img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.gphoto:hover img,.gphoto:focus-visible img{transform:scale(1.06)}
.gphoto::after{content:"+";position:absolute;right:.9rem;bottom:.8rem;z-index:2;width:40px;height:40px;display:grid;place-items:center;border-radius:50%;
  background:rgba(12,11,10,.55);color:#fff;font-size:1.4rem;font-weight:500;opacity:0;transition:opacity .3s var(--ease);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}
.gphoto:hover::after,.gphoto:focus-visible::after{opacity:1}
@media(max-width:880px){.gallery{grid-template-columns:repeat(2,1fr)}}
.lb{border:none;border-radius:22px;padding:0;background:#140505;color:#fff;max-width:min(92vw,560px);box-shadow:0 60px 120px -40px rgba(0,0,0,.9)}
.lb::backdrop{background:rgba(10,4,4,.82);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}
.lb__img{width:100%;max-height:74svh;object-fit:contain;border-radius:22px 22px 0 0;background:#000}
.lb__bar{display:flex;align-items:center;justify-content:space-between;gap:.8rem;padding:.85rem 1.1rem}
.lb__cap{font-size:.92rem;color:#f0d9c6}
.lb__nav{display:flex;gap:.5rem}
.lb button{width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.12);display:grid;place-items:center;font-size:1.25rem;transition:background .25s}
.lb button:hover{background:var(--rojo)}
.lb__close{position:absolute;top:.7rem;right:.7rem;background:rgba(12,11,10,.6)!important}
.lb__close:hover{background:var(--rojo)!important}

/* ----------------------------- INFO / UBICACIÓN ----------------------------- */
.info-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:1.4rem;align-items:stretch}
.info-list{display:grid;gap:1rem;align-content:start}
.info-row{display:flex;gap:1rem;align-items:flex-start;padding:1.15rem 1.25rem;background:var(--crema-2);border-radius:16px;border:1px solid rgba(36,23,18,.08);transition:transform .3s var(--ease)}
.info-row:hover{transform:translateX(6px)}
.info-row .ico{color:#fff;width:46px;height:46px;display:grid;place-items:center;border-radius:13px;background:var(--sunset);flex:none}
.info-row .ico svg{width:24px;height:24px}
.info-row h4{font-weight:700;text-transform:uppercase;font-size:1rem}
.info-row p{color:#5a4a40;font-size:.95rem}
.map{position:relative;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-card);min-height:480px;border:1px solid rgba(36,23,18,.1);background:#e9e2cf}
.map__img{position:absolute;inset:0;display:block}
.map__img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.map__img:hover img{transform:scale(1.04)}
.map__links{position:absolute;left:14px;right:14px;bottom:14px;z-index:2;display:flex;gap:.6rem;flex-wrap:wrap}
.map__link{display:inline-flex;align-items:center;gap:.45rem;background:var(--rojo);color:#fff;font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:.03em;padding:.6rem 1.05rem;border-radius:var(--r-pill);box-shadow:0 12px 24px -12px rgba(0,0,0,.6);transition:background .25s,transform .25s}
.map__link:hover{background:var(--rojo-700);transform:translateY(-2px)}
.map__link--alt{background:var(--tinta)}
.map__link--alt:hover{background:#000}
@media(max-width:980px){.info-grid{grid-template-columns:1fr}.map{min-height:380px}}

/* FAQ */
.faq{max-width:860px;margin-inline:auto;display:grid;gap:.9rem}
.faq details{background:var(--crema-2);border:1px solid rgba(36,23,18,.1);border-radius:16px;overflow:hidden;transition:box-shadow .3s}
.faq details[open]{box-shadow:var(--shadow)}
.faq summary{list-style:none;display:flex;align-items:center;justify-content:space-between;gap:1rem;cursor:pointer;padding:1.15rem 1.35rem;font-weight:700;font-size:1.04rem;text-transform:uppercase;letter-spacing:.01em}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.5rem;font-weight:500;color:var(--rojo);transition:rotate .3s var(--ease);flex:none}
.faq details[open] summary::after{rotate:45deg}
.faq .faq__a{padding:0 1.35rem 1.25rem;color:#5a4a40;max-width:70ch}

/* ----------------------------- FOOTER ----------------------------- */
.foot{background:var(--marca-900);color:#f3d7d2;padding:3.6rem 0 1.6rem;overflow:hidden}
.foot__top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2rem;align-items:start}
.foot__logo img{height:42px;width:auto;margin-bottom:1rem}
.foot p{font-size:.93rem;color:#e3b9b3;max-width:36ch}
.foot h4{font-weight:700;text-transform:uppercase;color:var(--crema);font-size:1rem;margin-bottom:.8rem;letter-spacing:.03em}
.foot a{display:block;color:#edc3bd;font-size:.94rem;padding:.24rem 0;transition:color .2s}
.foot a:hover{color:var(--amarillo)}
.foot__social{display:flex;gap:.6rem;margin-top:.5rem}
.foot__social a{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.10);transition:background .25s,transform .25s}
.foot__social a:hover{background:var(--amarillo);transform:translateY(-3px)}
.foot__social a:hover svg{fill:var(--tinta)}
.foot__social svg{width:20px;height:20px;fill:var(--crema)}
/* Marca de agua: el logotipo Kaya Club (solo texto) en amarillo difuminado */
.foot__word{display:block;width:min(94%,1080px);height:auto;margin:3rem auto 0;opacity:.32;user-select:none;pointer-events:none;transition:opacity .6s var(--ease)}
.foot:hover .foot__word{opacity:.55}
@supports(animation-timeline:view()){
  @media(prefers-reduced-motion:no-preference){
    .foot__word{animation:wordIn linear both;animation-timeline:view();animation-range:entry 0% entry 100%}
  }
}
@keyframes wordIn{from{transform:translateY(30%)}to{transform:none}}
.foot__bar{margin-top:1.8rem;padding-top:1.4rem;border-top:1px solid rgba(255,255,255,.12);display:flex;justify-content:space-between;flex-wrap:wrap;gap:.6rem;font-size:.82rem;color:#d9a59f}
@media(max-width:980px){.foot__top{grid-template-columns:1fr 1fr}}
@media(max-width:680px){.foot__top{grid-template-columns:1fr;gap:1.6rem}}

/* ----------------------------- 404 ----------------------------- */
.page404{min-height:100svh;display:grid;place-items:center;text-align:center;background:var(--sunset);color:#fff;padding:2rem}
.page404 b{font-family:var(--f-led);font-weight:700;font-size:clamp(5rem,22vw,13rem);line-height:1;display:block;text-shadow:0 0 40px rgba(255,0,0,.55)}
.page404 h1{font-family:var(--f-display);text-transform:uppercase;font-size:clamp(1.6rem,5vw,2.6rem);margin-top:.6rem}
.page404 p{color:#fff5e6;margin:.8rem auto 1.6rem;max-width:46ch}

/* ----------------------------- REVEAL (IO + fallback CSS scroll-driven) ----------------------------- */
html.js .reveal{opacity:0;transform:translateY(30px);transition:opacity .75s var(--ease),transform .75s var(--ease)}
html.js .reveal.in{opacity:1;transform:none}
html.js .reveal.d1{transition-delay:.08s}
html.js .reveal.d2{transition-delay:.16s}
html.js .reveal.d3{transition-delay:.24s}
html.js .reveal.d4{transition-delay:.32s}
@media(prefers-reduced-motion:reduce){
  html.js .reveal{opacity:1;transform:none;transition:none}
  *,*::before,*::after{animation-duration:.001s!important;animation-iteration-count:1!important;transition-duration:.001s!important}
}

/* ----------------------------- RESEÑAS ----------------------------- */
.review{display:flex;flex-direction:column;gap:.75rem;background:var(--crema-2);border:1px solid rgba(36,23,18,.08);border-radius:var(--r);padding:1.7rem 1.6rem;box-shadow:0 16px 40px -30px rgba(20,10,5,.5);height:100%;transition:transform .3s var(--ease),box-shadow .3s}
.review:hover{transform:translateY(-5px);box-shadow:var(--shadow-card)}
.review__stars{display:flex;gap:.18rem;color:#f5b400}
.review__stars svg{width:21px;height:21px;fill:currentColor}
.review blockquote{margin:0;color:#4a3a30;font-size:.99rem;line-height:1.5;flex:1}
.review__foot{display:flex;align-items:center;justify-content:space-between;gap:.6rem;margin-top:.3rem}
.review__who b{display:block;font-size:.95rem}
.review__who span{font-size:.8rem;color:#8a7568}
.review__g{display:inline-flex;align-items:center;gap:.45rem;font-size:.78rem;font-weight:600;color:#6a584c;white-space:nowrap}
.review__g svg{width:18px;height:18px;flex:none}

/* ----------------------------- UTILIDADES ----------------------------- */
.mt-1{margin-top:1rem}.mt-2{margin-top:1.8rem}.mt-3{margin-top:2.6rem}.mt-4{margin-top:3.2rem}
.center-flex{display:flex;justify-content:center;flex-wrap:wrap;gap:.85rem}
