/* ============================================================
   OMNIS — Premium Gin · Mallorca
   Hero (vídeo) + Nav + Menú fullscreen
   Paleta tomada del hero: negro azulado · oro · teal · crema
   ============================================================ */

:root{
  --bg:#0a0d11;
  --bg-2:#0c1014;
  --gold:#c6a36a;
  --gold-2:#e7d2a6;
  --teal:#205b57;
  --teal-deep:#0c2c2a;
  --cream:#efe7d6;
  --line:rgba(198,163,106,.28);
  --ease:cubic-bezier(.7,0,.2,1);
  --ease-soft:cubic-bezier(.22,1,.36,1);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}

/* accesible para lectores de pantalla y SEO, oculto visualmente */
.visually-hidden{
  position:absolute !important;
  width:1px;height:1px;
  padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);
  white-space:nowrap;border:0;
}
body{
  background:var(--bg);
  color:var(--cream);
  font-family:'Jost',sans-serif;
  font-weight:300;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
body.is-locked{overflow:hidden}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
::selection{background:var(--gold);color:var(--bg)}

/* textura/grano de película (estático) por encima de toda la web -> da "tacto" y cohesión.
   Blend NORMAL a baja opacidad: el grano gris se nota por igual sobre fondos oscuros
   y claros (aclara los oscuros, oscurece los claros). NO usar 'screen'/'overlay': solo
   se verían en las zonas casi negras (era el bug: "solo dos partes arriba"). */
.grain{
  position:fixed;inset:0;z-index:60;pointer-events:none;
  opacity:.07;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='ng'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.82' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23ng)'/%3E%3C/svg%3E");
}

/* marco de lujo fijo */
.frame{
  position:fixed;inset:14px;z-index:60;pointer-events:none;
  border:1px solid rgba(239,231,214,.14);
  mix-blend-mode:overlay;
}
@media(max-width:640px){.frame{inset:8px}}

/* ===================== NAV ===================== */
.nav{
  position:fixed;top:0;left:0;width:100%;z-index:50;
  padding:26px clamp(20px,4vw,52px);
  background:rgba(255,255,255,.05);                 /* glass ~5% blanco */
  backdrop-filter:blur(12px) saturate(120%);
  -webkit-backdrop-filter:blur(12px) saturate(120%);
  border-bottom:0;
  transition:padding .5s var(--ease),background .5s var(--ease),backdrop-filter .5s var(--ease);
}
/* línea dorada sutil de división bajo el nav (se desvanece a los lados) */
.nav::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:1px;pointer-events:none;
  background:linear-gradient(90deg, transparent, rgba(198,163,106,.4) 22%, rgba(231,210,166,.55) 50%, rgba(198,163,106,.4) 78%, transparent);
}
.nav__inner{
  display:flex;align-items:center;justify-content:space-between;gap:20px;
}
.nav--scrolled{
  padding-top:16px;padding-bottom:16px;
  background:rgba(255,255,255,.09);                 /* un poco más sólido al hacer scroll */
  backdrop-filter:blur(18px) saturate(130%);
  -webkit-backdrop-filter:blur(18px) saturate(130%);
  border-bottom:0;
}

/* trigger / hamburguesa */
.nav__trigger{
  display:flex;align-items:center;gap:12px;
  background:none;border:0;cursor:pointer;color:var(--cream);
  font-family:'Jost';font-weight:400;font-size:13px;letter-spacing:.22em;text-transform:uppercase;
}
.burger{display:inline-flex;flex-direction:column;gap:5px;width:26px}
.burger i{height:1.5px;width:100%;background:var(--cream);transition:.4s var(--ease);transform-origin:center}
.burger i:last-child{width:64%}
.nav__trigger:hover .burger i{background:var(--gold-2)}
.nav__trigger:hover .burger i:last-child{width:100%}
.nav__trigger-label{opacity:.9;transition:.4s}
@media(max-width:640px){.nav__trigger-label{display:none}}

/* logo central */
.nav__logo{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  display:flex;align-items:center;gap:10px;
}
.nav__star{width:13px;height:13px;fill:var(--gold);opacity:.95}
/* logo real (SVG blanco) en el nav -> ligeramente más grande + brillo dorado que lo recorre */
.nav__logo-img{height:clamp(34px,4.4vw,48px);width:auto;display:block}
.nav__logo-shine{
  position:absolute;inset:0;pointer-events:none;
  -webkit-mask:url("assets/logo-white.svg") center/contain no-repeat;
          mask:url("assets/logo-white.svg") center/contain no-repeat;
  background:linear-gradient(105deg,transparent 40%,rgba(231,210,166,.92) 50%,transparent 60%);
  background-repeat:no-repeat;background-size:250% 100%;background-position:175% 0;
  animation:navLogoShine 7.5s ease-in-out infinite;
}
@keyframes navLogoShine{
  0%{background-position:175% 0}
  15%{background-position:-75% 0}
  100%{background-position:-75% 0}
}
.nav__word{
  font-family:'Cinzel',serif;font-weight:500;
  font-size:clamp(20px,2.3vw,26px);letter-spacing:.42em;
  padding-left:.42em;color:var(--cream);
}
/* logo siempre centrado; en móvil ocultamos el CTA para que no lo tape (el menú lo cubre) */
@media(max-width:600px){.nav__cta{display:none}}

/* derecha */
.nav__right{display:flex;align-items:center;gap:clamp(16px,2vw,30px)}
.nav__lang{
  display:flex;gap:7px;font-size:12px;letter-spacing:.18em;text-transform:uppercase;opacity:.85;
}
.nav__lang b{color:var(--gold-2);font-weight:500}
.nav__lang span{opacity:.4}
@media(max-width:640px){.nav__lang{display:none}}
.nav__cta{
  position:relative;font-size:12px;letter-spacing:.2em;text-transform:uppercase;
  padding:11px 22px;border:1px solid var(--line);border-radius:40px;overflow:hidden;
  color:var(--gold-2);transition:color .5s var(--ease),border-color .5s var(--ease);
}
.nav__cta span{position:relative;z-index:1}
.nav__cta::before{
  content:"";position:absolute;inset:0;background:var(--gold);
  transform:translateY(101%);transition:transform .5s var(--ease);z-index:0;
}
.nav__cta:hover{color:var(--bg);border-color:var(--gold)}
.nav__cta:hover::before{transform:translateY(0)}
@media(max-width:480px){.nav__cta{padding:9px 16px;font-size:11px}}

/* icono de compra/reserva (-> formulario de pedido) */
.nav__cart{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;color:var(--gold-2);transition:color .4s var(--ease),transform .3s var(--ease)}
.nav__cart svg{width:21px;height:21px;fill:none;stroke:currentColor;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.nav__cart:hover{color:var(--cream);transform:translateY(-1px)}

/* ===================== HERO ===================== */
.hero{position:relative;height:100svh;width:100%;overflow:hidden;background:var(--bg)}
.hero__video{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;
}
.hero__scrim{position:absolute;left:0;width:100%;pointer-events:none;z-index:2}
.hero__scrim--top{top:0;height:30%;background:linear-gradient(to bottom,rgba(6,8,11,.78),transparent)}
.hero__scrim--bottom{bottom:0;height:26%;background:linear-gradient(to top,rgba(6,8,11,.7),transparent)}

.hero__footer{
  position:absolute;left:0;bottom:0;z-index:3;width:100%;
  padding:0 clamp(22px,4vw,56px) clamp(22px,3.4vw,40px);
  display:flex;align-items:flex-end;justify-content:space-between;gap:20px;
}
.hero__tag{
  font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--gold-2);opacity:.82;
  padding-bottom:6px;
}
@media(max-width:640px){.hero__tag{display:none}}
.hero__scroll{
  display:flex;flex-direction:column;align-items:center;gap:12px;margin:0 auto;
  font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--cream);opacity:.9;
}
.hero__scroll-line{width:1px;height:28px;background:linear-gradient(to bottom,var(--gold),transparent);position:relative;overflow:hidden}
.hero__scroll-line::after{
  content:"";position:absolute;top:-50%;left:0;width:100%;height:50%;background:var(--gold-2);
  animation:scrollPulse 2.2s var(--ease) infinite;
}
@keyframes scrollPulse{0%{top:-50%}60%,100%{top:100%}}
.hero__scroll-txt{
  font-family:'Jost',sans-serif;font-size:10px;font-weight:400;
  letter-spacing:.36em;text-transform:uppercase;color:var(--gold-2);
  animation:scrollLabel 2.6s ease-in-out infinite;
}
@keyframes scrollLabel{0%,100%{opacity:.45}50%{opacity:.95}}

/* ===================== INTRO ===================== */
.intro{
  min-height:96vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;
  padding:14vh clamp(22px,6vw,40px);
  background:
    radial-gradient(120% 80% at 50% 0%,rgba(32,91,87,.16),transparent 60%),
    linear-gradient(to bottom,var(--bg),var(--bg-2));
  position:relative;
}
.intro__orn{width:130px;height:13px;color:var(--gold);opacity:.7;margin-bottom:34px}
.intro__eyebrow{
  font-size:13px;letter-spacing:.34em;text-transform:uppercase;color:var(--gold-2);margin-bottom:26px;
}
.intro__title{
  font-family:'Cormorant Garamond',serif;font-weight:500;
  font-size:clamp(34px,6.4vw,80px);line-height:1.04;letter-spacing:.01em;color:var(--cream);
}
.intro__title em{font-style:italic;color:var(--gold-2)}
.intro__body{
  max-width:560px;margin:30px auto 0;
  font-family:'Cormorant Garamond',serif;font-size:clamp(17px,2vw,22px);line-height:1.6;
  color:rgba(239,231,214,.74);
}
.intro__link{
  display:inline-flex;align-items:center;gap:14px;margin-top:46px;
  font-size:12px;letter-spacing:.26em;text-transform:uppercase;color:var(--cream);
}
.intro__link i{width:42px;height:1px;background:var(--gold);transition:width .5s var(--ease)}
.intro__link:hover i{width:74px}
.intro__link:hover{color:var(--gold-2)}

/* reveal */
.reveal{opacity:0;transform:translateY(38px);transition:opacity 1.1s var(--ease-soft),transform 1.1s var(--ease-soft)}
.reveal.in{opacity:1;transform:none}

/* ===================== FOOT ===================== */
.foot{
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  padding:30px clamp(22px,4vw,56px);border-top:1px solid rgba(239,231,214,.08);
  font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:rgba(239,231,214,.5);
}

/* ===================== MENÚ FULLSCREEN ===================== */
.menu{
  position:fixed;inset:0;z-index:55;visibility:hidden;opacity:0;
  transition:opacity .45s var(--ease), visibility 0s linear .55s, backdrop-filter .5s var(--ease), background .5s var(--ease);
}
.menu.open{visibility:visible;opacity:1;transition:opacity .4s var(--ease), backdrop-filter .5s var(--ease), background .5s var(--ease)}
/* PANEL (cajón). Móvil: pantalla completa, entra desde arriba. */
.menu__panel{
  position:absolute;left:0;top:0;bottom:0;width:100%;overflow:hidden;
  transform:translateY(-100%);transition:transform .8s var(--ease);
}
.menu.open .menu__panel{transform:none}
.menu__bg{
  position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(120% 100% at 80% 10%,rgba(32,91,87,.4),transparent 55%),
    linear-gradient(150deg,#0c2c2a 0%,#0a0d11 55%,#070a0d 100%);
}
/* monograma OMNIS como filigrana dentro del panel -> sutil */
.menu__watermark{
  position:absolute;right:-8%;top:50%;transform:translateY(-50%);
  width:min(78%,380px);height:auto;z-index:0;
  fill:rgba(198,163,106,.05);pointer-events:none;
}
@media(max-width:900px){.menu__watermark{right:auto;left:50%;transform:translate(-50%,-50%);width:min(64vw,320px);top:40%}}
.menu__inner{
  position:relative;z-index:2;height:100%;
  display:flex;flex-direction:column;
  padding:104px clamp(28px,8vw,64px) 56px;
  overflow-y:auto;-webkit-overflow-scrolling:touch;
}

/* lista */
.menu__list{flex:1 1 auto;display:flex;flex-direction:column;justify-content:center;width:100%}
.menu__item{
  position:relative;display:flex;align-items:baseline;gap:20px;
  padding:clamp(10px,1.4vw,18px) 0;border-bottom:1px solid rgba(239,231,214,.08);
  opacity:0;transform:translateY(26px);
  transition:opacity .7s var(--ease-soft),transform .7s var(--ease-soft),padding-left .5s var(--ease);
}
.menu.open .menu__item{opacity:1;transform:none}
.menu.open .menu__item:nth-child(1){transition-delay:.18s}
.menu.open .menu__item:nth-child(2){transition-delay:.25s}
.menu.open .menu__item:nth-child(3){transition-delay:.32s}
.menu.open .menu__item:nth-child(4){transition-delay:.39s}
.menu.open .menu__item:nth-child(5){transition-delay:.46s}
.menu.open .menu__item:nth-child(6){transition-delay:.53s}
.menu.open .menu__item:nth-child(7){transition-delay:.60s}
.menu__num{
  font-family:'Jost';font-size:13px;letter-spacing:.1em;color:var(--gold);opacity:.7;
  width:30px;flex:none;transition:.5s var(--ease)
}
.menu__text{
  font-family:'Cinzel',serif;font-weight:400;
  font-size:clamp(28px,5vw,52px);line-height:1.04;color:var(--cream);
  transition:color .5s var(--ease),letter-spacing .6s var(--ease);
}
.menu__sub{
  margin-left:auto;font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(239,231,214,.4);opacity:0;transform:translateX(-12px);
  transition:.5s var(--ease)
}
@media(max-width:560px){.menu__sub{display:none}}
.menu__item:hover{padding-left:22px}
.menu__item:hover .menu__text{color:var(--gold-2);letter-spacing:.02em}
.menu__item:hover .menu__num{opacity:1;color:var(--gold-2)}
.menu__item:hover .menu__sub{opacity:1;transform:none;color:var(--gold)}

/* pie del panel: lema + Instagram (sustituye a las imágenes de la derecha) */
.menu__foot{flex:none;width:100%;padding-top:26px;margin-top:20px;
  border-top:1px solid rgba(239,231,214,.1);
  opacity:0;transition:opacity .6s var(--ease) .45s}
.menu.open .menu__foot{opacity:1}
.menu__foot-tag{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:clamp(18px,2vw,22px);line-height:1.35;color:var(--gold-2);margin:0 0 16px}
.menu__foot-meta{display:flex;flex-direction:column;gap:6px;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:rgba(239,231,214,.45)}
.menu__foot-meta a{color:var(--gold-2);transition:color .35s var(--ease)}
.menu__foot-meta a:hover{color:var(--cream)}

/* close (siempre a la izquierda) */
.menu__close{
  position:absolute;top:24px;left:clamp(20px,4vw,44px);z-index:5;
  width:46px;height:46px;border:1px solid var(--line);border-radius:50%;
  background:none;cursor:pointer;
  opacity:0;transition:opacity .5s var(--ease) .3s,transform .5s var(--ease),border-color .4s
}
.menu.open .menu__close{opacity:1}
.menu__close span{position:absolute;top:50%;left:50%;width:16px;height:1.5px;background:var(--cream);transition:.4s}
.menu__close span:first-child{transform:translate(-50%,-50%) rotate(45deg)}
.menu__close span:last-child{transform:translate(-50%,-50%) rotate(-45deg)}
.menu__close:hover{transform:rotate(90deg);border-color:var(--gold)}
.menu__close:hover span{background:var(--gold-2)}

/* DESKTOP: cajón a la izquierda + página desenfocada detrás (no pantalla completa) */
@media(min-width:901px){
  .menu.open{background:rgba(6,8,11,.34);-webkit-backdrop-filter:blur(16px) saturate(115%);backdrop-filter:blur(16px) saturate(115%)}
  .menu__panel{width:min(560px,90vw);transform:translateX(-100%);box-shadow:60px 0 160px rgba(0,0,0,.55),1px 0 0 rgba(231,210,166,.12)}
  .menu.open .menu__panel{transform:none}
  .menu__inner{padding:108px 60px 56px}
  .menu__text{font-size:clamp(28px,2.2vw,40px);line-height:1;white-space:nowrap}
  .menu__item{padding:clamp(9px,1vw,15px) 0}
  .menu__sub{display:none}
}

/* ===================== MÓVIL — hero + menú top ===================== */
@media(max-width:760px){
  .hero{background:#05080a}
  .hero__scrim{display:none}
  /* vídeo centrado en el hero a pantalla completa, encima de la aura, con bordes
     arriba/abajo muy difuminados (máscara) para que se fundan con el fondo */
  .hero__video{
    object-fit:cover;z-index:1;
    top:50%;bottom:auto;transform:translateY(-50%);
    height:76vw;
    -webkit-mask-image:linear-gradient(to bottom, transparent 0%, transparent 6%, #000 32%, #000 80%, transparent 100%);
            mask-image:linear-gradient(to bottom, transparent 0%, transparent 6%, #000 32%, #000 80%, transparent 100%);
  }
  .nav{padding:18px clamp(16px,4vw,52px);background:rgba(255,255,255,.03)}
  /* desliza un poco más grande */
  .hero__scroll{gap:14px}
  .hero__scroll-txt{font-size:12px;letter-spacing:.42em}
  .hero__scroll-line{height:36px}
}

/* ===== destellos de luz del hero (solo móvil): estrellitas tenues que se encienden ===== */
.hero__sparks{display:block;position:absolute;inset:0;z-index:3;pointer-events:none;overflow:hidden}
@keyframes heroTwinkle{0%,100%{opacity:0;transform:scale(.45)}50%{opacity:var(--o,.8);transform:scale(1)}}
  .hero__sparks i{
    position:absolute;width:2px;height:2px;border-radius:50%;background:#f4e9cf;opacity:0;
    box-shadow:0 0 5px 1px rgba(243,231,200,.5);
    animation:heroTwinkle var(--d,4.6s) ease-in-out infinite;
  }
  .hero__sparks i:nth-child(1){left:13%;top:9%;--d:4.2s;animation-delay:.1s}
  .hero__sparks i:nth-child(2){left:80%;top:6%;--d:5.5s;animation-delay:1.8s;width:1.5px;height:1.5px;--o:.5}
  .hero__sparks i:nth-child(3){left:42%;top:14%;--d:4.8s;animation-delay:3.2s}
  .hero__sparks i:nth-child(4){left:90%;top:20%;--d:5.2s;animation-delay:.9s;width:1.5px;height:1.5px;--o:.5}
  .hero__sparks i:nth-child(5){left:7%;top:26%;--d:4.6s;animation-delay:2.5s}
  .hero__sparks i:nth-child(6){left:61%;top:30%;--d:6s;animation-delay:4.3s;width:3px;height:3px;--o:.9}
  .hero__sparks i:nth-child(7){left:28%;top:36%;--d:4.4s;animation-delay:1.2s}
  .hero__sparks i:nth-child(8){left:86%;top:42%;--d:5.3s;animation-delay:3.7s;--o:.5}
  .hero__sparks i:nth-child(9){left:17%;top:48%;--d:4.9s;animation-delay:.5s;width:1.5px;height:1.5px;--o:.5}
  .hero__sparks i:nth-child(10){left:73%;top:52%;--d:5.6s;animation-delay:2.9s}
  .hero__sparks i:nth-child(11){left:45%;top:59%;--d:4.3s;animation-delay:4.7s;width:3px;height:3px;--o:.9}
  .hero__sparks i:nth-child(12){left:91%;top:63%;--d:5.1s;animation-delay:1.5s;--o:.5}
  .hero__sparks i:nth-child(13){left:23%;top:69%;--d:4.7s;animation-delay:3.4s;width:1.5px;height:1.5px;--o:.5}
  .hero__sparks i:nth-child(14){left:66%;top:74%;--d:5.8s;animation-delay:.7s}
  .hero__sparks i:nth-child(15){left:11%;top:82%;--d:4.5s;animation-delay:2.2s;--o:.5}
  .hero__sparks i:nth-child(16){left:82%;top:86%;--d:5.4s;animation-delay:4.1s;width:1.5px;height:1.5px;--o:.45}
  .hero__sparks i:nth-child(17){left:37%;top:90%;--d:4.6s;animation-delay:1s;--o:.5}
  .hero__sparks i:nth-child(18){left:54%;top:44%;--d:6.2s;animation-delay:5.1s;width:3px;height:3px;--o:.85}
/* desktop: menos cantidad (pocos) */
@media(min-width:761px){
  .hero__sparks i:nth-child(3),.hero__sparks i:nth-child(4),.hero__sparks i:nth-child(5),
  .hero__sparks i:nth-child(7),.hero__sparks i:nth-child(10),.hero__sparks i:nth-child(12),
  .hero__sparks i:nth-child(14),.hero__sparks i:nth-child(15),.hero__sparks i:nth-child(18){display:none}
}
@media(prefers-reduced-motion:reduce){.hero__sparks{display:none}}

/* menú: arreglos para móvil (centrado + scroll si hace falta) */
@media(max-width:900px){
  .menu__inner{align-content:center;overflow-y:auto;-webkit-overflow-scrolling:touch;
    padding-top:100px;padding-bottom:64px}
  .menu__list{justify-content:center}
  /* botón de cerrar a la IZQUIERDA en móvil */
  .menu__close{left:clamp(20px,4vw,52px);right:auto}
}
@media(max-width:560px){
  .menu__text{font-size:clamp(30px,8vw,46px)}
  .menu__item{padding:14px 0}
  .menu__close{top:18px;width:42px;height:42px}
}

@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition-duration:.001s!important}
  html{scroll-behavior:auto}
}
