/* NEW BOWL — Premium Carta Section */

#full-menu { position: relative !important; }

#full-menu::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background-image:
    radial-gradient(ellipse 60% 40% at 15% 20%, rgba(255,180,60,0.05) 0%, transparent 70%),
    radial-gradient(ellipse 50% 50% at 85% 75%, rgba(255,107,53,0.06) 0%, transparent 65%);
}

#full-menu .max-w-7xl {
  position: relative !important;
  z-index: 1 !important;
}

/* Bowl 3D flotante */
#nb-bowl-3d {
  position: absolute; right: 3.5%; top: 60px;
  width: clamp(130px, 12vw, 200px); height: clamp(130px, 12vw, 200px);
  z-index: 10; pointer-events: none;
  animation: nbBowlFloat 6s ease-in-out infinite;
  filter: drop-shadow(0 30px 50px rgba(255,107,53,0.35)) drop-shadow(0 10px 20px rgba(0,0,0,0.8));
}
#nb-bowl-shadow {
  position: absolute; right: 3.5%; top: clamp(190px, 18vw, 265px);
  width: clamp(130px, 12vw, 200px); height: 24px;
  z-index: 9; pointer-events: none;
  background: radial-gradient(ellipse, rgba(255,107,53,0.28) 0%, transparent 70%);
  border-radius: 50%; animation: nbBowlShadow 6s ease-in-out infinite;
}
@keyframes nbBowlFloat {
  0%,100% { transform: translateY(0px) rotate(0deg); }
  20%      { transform: translateY(-20px) rotate(-1.5deg); }
  50%      { transform: translateY(-32px) rotate(1deg); }
  80%      { transform: translateY(-14px) rotate(-0.5deg); }
}
@keyframes nbBowlShadow {
  0%,100% { transform: scaleX(1); opacity: 0.45; }
  50%      { transform: scaleX(0.65); opacity: 0.15; }
}
@media (max-width: 1024px) { #nb-bowl-3d { right:2%; top:50px; } #nb-bowl-shadow { right:2%; } }
@media (max-width: 640px)  { #nb-bowl-3d { right:2%; top:30px; width:80px; height:80px; } #nb-bowl-shadow { right:2%; top:108px; width:80px; height:14px; } }

/* Bingo Night nav pulse */
@keyframes bingoPulse {
  0%,100% { box-shadow: 0 0 15px rgba(212,160,23,0.5), 0 0 30px rgba(192,21,42,0.3); }
  50%      { box-shadow: 0 0 25px rgba(212,160,23,0.8), 0 0 50px rgba(192,21,42,0.5); }
}

/* =====================================================
   MOBILE BUTTON SWITCHER — CSS only, zero JS change
   The Bingo button has class "flex sm:hidden"
   sm:hidden doesn't exist in compiled CSS so it shows always.
   We manually hide it on tablet/desktop and show it on mobile.
   ===================================================== */

/* Hide Bingo Night hero button on tablet and desktop */
a[href="/bingo-night.html"].flex {
  display: none !important;
}

/* Show it ONLY on mobile */
@media (max-width: 639px) {
  a[href="/bingo-night.html"].flex {
    display: flex !important;
  }
  /* Also hide the WhatsApp button on mobile
     (it has class "hidden sm:flex" — sm:flex exists in CSS so it shows on sm+,
      but on mobile "hidden" wins... except we need to be sure) */
  a[href*="wa.me"].hidden {
    display: none !important;
  }
}

/* ── Hide sticky bottom Bingo Night bar on ALL screens ── */
.fixed.bottom-0.left-0.right-0.z-40 {
  display: none !important;
}

/* ── HERO IMAGE — Trilogía Pisco Sour ── */
#hero .bg-cover {
  background-image: url(/hero-pisco-sour.png) !important;
  background-position: center 25% !important;
  background-size: cover !important;
  animation: heroZoom 14s ease-in-out infinite alternate;
  will-change: transform;
  transform-origin: center center;
}

/* Zoom slow — ALL screens (mobile, tablet, PC) */
@keyframes heroZoom {
  0%   { transform: scale(1.0) translateY(0); }
  100% { transform: scale(1.08) translateY(-2%); }
}

/* Refined overlay for the new image */
#hero .bg-gradient-to-b {
  background: linear-gradient(
    to bottom,
    rgba(0,0,0,0.45) 0%,
    rgba(0,0,0,0.25) 35%,
    rgba(0,0,0,0.60) 100%
  ) !important;
}

/* Mobile: focus more on the glasses */
@media (max-width: 640px) {
  #hero .bg-cover {
    background-position: center 35% !important;
  }
}

/* Tablet */
@media (min-width: 641px) and (max-width: 1024px) {
  #hero .bg-cover {
    background-position: center 20% !important;
  }
}

/* PC — same zoom effect, wider view */
@media (min-width: 1025px) {
  #hero .bg-cover {
    background-position: center 15% !important;
    animation: heroZoomPC 14s ease-in-out infinite alternate;
  }
}

@keyframes heroZoomPC {
  0%   { transform: scale(1.0) translateY(0) translateX(0); }
  50%  { transform: scale(1.05) translateY(-1%) translateX(0.5%); }
  100% { transform: scale(1.08) translateY(-2%) translateX(-0.5%); }
}

/* ═══════════════════════════════════════════
   LOGO — transparent background, all screens
   ═══════════════════════════════════════════ */
nav img[alt="NEW BOWL"],
img[src="/logo-nb.png"],
img[src="/favicon.png"] {
  background: transparent !important;
  mix-blend-mode: normal;
  filter: drop-shadow(0 2px 8px rgba(212,160,23,0.4));
}

/* ═══════════════════════════════════════════
   TRILOGÍA PISCO SOUR BANNER
   Same section style as drinks — elegant, neon
   ═══════════════════════════════════════════ */
.nb-trilogia-banner {
  margin: 0 auto 2.5rem;
  max-width: 860px;
  padding: 0 1rem;
}

.nb-trilogia-inner {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  background: linear-gradient(135deg,
    rgba(168,85,247,0.08) 0%,
    rgba(236,72,153,0.12) 40%,
    rgba(168,85,247,0.06) 100%
  );
  border: 1px solid rgba(236,72,153,0.35);
  border-radius: 1.25rem;
  padding: 1rem 1.5rem;
  position: relative;
  overflow: hidden;
  box-shadow:
    0 0 30px rgba(236,72,153,0.15),
    0 0 60px rgba(168,85,247,0.08),
    inset 0 0 30px rgba(168,85,247,0.04);
  animation: trilogiaPulse 3s ease-in-out infinite;
}

/* Shimmer line across top */
.nb-trilogia-inner::before {
  content: '';
  position: absolute;
  top: 0; left: -100%;
  width: 60%; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(236,72,153,0.8), transparent);
  animation: trilogiaShimmer 3s ease-in-out infinite;
}

@keyframes trilogiaShimmer {
  0%   { left: -60%; }
  100% { left: 120%; }
}

@keyframes trilogiaPulse {
  0%,100% { box-shadow: 0 0 30px rgba(236,72,153,0.15), 0 0 60px rgba(168,85,247,0.08), inset 0 0 30px rgba(168,85,247,0.04); }
  50%      { box-shadow: 0 0 45px rgba(236,72,153,0.25), 0 0 80px rgba(168,85,247,0.15), inset 0 0 40px rgba(168,85,247,0.07); }
}

/* Floating image */
.nb-trilogia-img-wrap {
  flex-shrink: 0;
  width: 72px;
  height: 72px;
  border-radius: 50%;
  overflow: hidden;
  border: 2px solid rgba(236,72,153,0.5);
  box-shadow: 0 0 20px rgba(236,72,153,0.4), 0 0 40px rgba(168,85,247,0.2);
  animation: trilogiaFloat 4s ease-in-out infinite;
  cursor: pointer;
  transition: transform 0.3s, box-shadow 0.3s;
}

.nb-trilogia-img-wrap:hover {
  transform: scale(1.12) rotate(-3deg);
  box-shadow: 0 0 30px rgba(236,72,153,0.7), 0 0 60px rgba(168,85,247,0.4);
}

@keyframes trilogiaFloat {
  0%,100% { transform: translateY(0) rotate(0deg); }
  33%      { transform: translateY(-6px) rotate(2deg); }
  66%      { transform: translateY(-3px) rotate(-1deg); }
}

.nb-trilogia-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 30%;
}

/* Text */
.nb-trilogia-text {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}

.nb-trilogia-new {
  font-size: 0.65rem;
  font-weight: 800;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  background: linear-gradient(90deg, #f472b6, #c084fc, #f472b6);
  background-size: 200% auto;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: trilogiaTextShine 2.5s linear infinite;
}

@keyframes trilogiaTextShine {
  0%   { background-position: 0% center; }
  100% { background-position: 200% center; }
}

.nb-trilogia-title {
  font-size: clamp(1.1rem, 2.5vw, 1.5rem);
  font-weight: 900;
  line-height: 1.1;
  background: linear-gradient(135deg, #f9a8d4 0%, #e879f9 40%, #a78bfa 80%, #f9a8d4 100%);
  background-size: 200% auto;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: trilogiaTextShine 3s linear infinite;
  text-shadow: none;
}

.nb-trilogia-sub {
  font-size: clamp(0.72rem, 1.4vw, 0.85rem);
  color: rgba(249,168,212,0.65);
  letter-spacing: 0.05em;
  margin: 0;
}

/* Mobile */
@media (max-width: 640px) {
  .nb-trilogia-inner {
    gap: 1rem;
    padding: 0.85rem 1rem;
  }
  .nb-trilogia-img-wrap {
    width: 58px;
    height: 58px;
  }
}

/* Float animation for Trilogia icon — keyframes must be in CSS */
@keyframes trilogiaFloat {
  0%,100% { transform: translateY(0) rotate(0deg); }
  33%      { transform: translateY(-7px) rotate(2deg); }
  66%      { transform: translateY(-3px) rotate(-1deg); }
}

/* ═══════════════════════════════════════════
   VIERNES KARAOKE MARQUEE
   Works on PC, tablet and mobile — no Tailwind
   ═══════════════════════════════════════════ */
#nb-karaoke-marquee {
  position: relative;
  width: 100%;
  overflow: hidden;
}

/* Fade edges */
#nb-karaoke-marquee::before,
#nb-karaoke-marquee::after {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  width: 80px;
  z-index: 2;
  pointer-events: none;
}
#nb-karaoke-marquee::before {
  left: 0;
  background: linear-gradient(to right, #0d0008, transparent);
}
#nb-karaoke-marquee::after {
  right: 0;
  background: linear-gradient(to left, #0d0008, transparent);
}

.nb-marquee-track {
  display: flex;
  width: 100%;
  overflow: hidden;
}

.nb-marquee-inner {
  display: flex;
  align-items: center;
  white-space: nowrap;
  gap: 0;
  font-family: 'Inter', sans-serif;
  font-size: clamp(0.75rem, 1.4vw, 0.9rem);
  font-weight: 700;
  letter-spacing: 0.08em;
  color: #ff69b4;
  text-shadow:
    0 0 10px rgba(255,105,180,0.9),
    0 0 20px rgba(255,105,180,0.6),
    0 0 40px rgba(255,20,147,0.4);
  animation: nbMarqueeScroll 28s linear infinite;
  padding-right: 4rem;
}

.nb-marquee-inner:hover {
  animation-play-state: paused;
}

.nb-marquee-sep {
  color: #ff1493;
  text-shadow:
    0 0 8px rgba(255,20,147,1),
    0 0 20px rgba(255,20,147,0.7);
  margin: 0 0.6rem;
  font-size: 0.7em;
}

@keyframes nbMarqueeScroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* Neon underline pulse */
#nb-karaoke-marquee::after {
  right: 0;
  background: linear-gradient(to left, #0d0008, transparent);
}

/* Mobile — slightly faster */
@media (max-width: 640px) {
  #nb-karaoke-marquee { height: 44px !important; }
  .nb-marquee-inner {
    font-size: 0.72rem;
    animation-duration: 20s;
  }
}

/* Karaoke marquee keyframe */
@keyframes nbKaraokeScroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-75%); }
}
