@import "tailwindcss";
@import "tw-animate-css";

@custom-variant dark (&:is(.dark *));

:root {
  /* VIP Play Brand Colors */
  --verde-bosque: oklch(0.42 0.12 155);
  --verde-neon: oklch(0.65 0.18 155);
  --naranja-vip: oklch(0.68 0.18 35);
  --crema: oklch(0.93 0.03 75);
  --gris-oscuro: oklch(0.35 0 0);

  /* Semantic Design Tokens */
  --background: oklch(1 0 0);
  --foreground: var(--gris-oscuro);
  --card: oklch(1 0 0);
  --card-foreground: var(--gris-oscuro);
  --popover: oklch(1 0 0);
  --popover-foreground: var(--gris-oscuro);
  --primary: var(--verde-bosque);
  --primary-foreground: oklch(1 0 0);
  --secondary: var(--verde-neon);
  --secondary-foreground: oklch(1 0 0);
  --muted: oklch(0.96 0 0);
  --muted-foreground: oklch(0.556 0 0);
  --accent: var(--naranja-vip);
  --accent-foreground: oklch(1 0 0);
  --cta: var(--verde-neon);
  --cta-foreground: oklch(1 0 0);
  --destructive: oklch(0.577 0.245 27.325);
  --destructive-foreground: oklch(1 0 0);
  --border: oklch(0.922 0 0);
  --input: oklch(0.922 0 0);
  --ring: var(--verde-neon);
  --chart-1: oklch(0.646 0.222 41.116);
  --chart-2: oklch(0.6 0.118 184.704);
  --chart-3: oklch(0.398 0.07 227.392);
  --chart-4: oklch(0.828 0.189 84.429);
  --chart-5: oklch(0.769 0.188 70.08);
  --radius: 0.5rem;
  --sidebar: oklch(0.985 0 0);
  --sidebar-foreground: oklch(0.145 0 0);
  --sidebar-primary: oklch(0.205 0 0);
  --sidebar-primary-foreground: oklch(0.985 0 0);
  --sidebar-accent: oklch(0.97 0 0);
  --sidebar-accent-foreground: oklch(0.205 0 0);
  --sidebar-border: oklch(0.922 0 0);
  --sidebar-ring: oklch(0.708 0 0);
}

.dark {
  --background: oklch(0.145 0 0);
  --foreground: var(--crema);
  --card: oklch(0.18 0 0);
  --card-foreground: var(--crema);
  --popover: oklch(0.18 0 0);
  --popover-foreground: var(--crema);
  --primary: var(--verde-neon);
  --primary-foreground: oklch(0.145 0 0);
  --secondary: var(--verde-bosque);
  --secondary-foreground: oklch(1 0 0);
  --muted: oklch(0.269 0 0);
  --muted-foreground: oklch(0.708 0 0);
  --accent: var(--naranja-vip);
  --accent-foreground: oklch(1 0 0);
  --cta: var(--verde-neon);
  --cta-foreground: oklch(0.145 0 0);
  --destructive: oklch(0.396 0.141 25.723);
  --destructive-foreground: oklch(0.637 0.237 25.331);
  --border: oklch(0.269 0 0);
  --input: oklch(0.269 0 0);
  --ring: var(--verde-neon);
  --chart-1: oklch(0.488 0.243 264.376);
  --chart-2: oklch(0.696 0.17 162.48);
  --chart-3: oklch(0.769 0.188 70.08);
  --chart-4: oklch(0.627 0.265 303.9);
  --chart-5: oklch(0.645 0.246 16.439);
  --sidebar: oklch(0.205 0 0);
  --sidebar-foreground: oklch(0.985 0 0);
  --sidebar-primary: oklch(0.488 0.243 264.376);
  --sidebar-primary-foreground: oklch(0.985 0 0);
  --sidebar-accent: oklch(0.269 0 0);
  --sidebar-accent-foreground: oklch(0.985 0 0);
  --sidebar-border: oklch(0.269 0 0);
  --sidebar-ring: oklch(0.439 0 0);
}

/* ============================================
   TEMA: VIP CLASSIC
   Neuromarketing: Negro (exclusividad) + Dorado (lujo) + Burdeos (apetito refinado)
   Ideal para: Experiencia VIP premium, mayor permanencia y gasto
   ============================================ */
.theme-vip-classic {
  --verde-bosque: oklch(0.12 0 0);          /* Negro profundo */
  --verde-neon: oklch(0.75 0.13 85);        /* Dorado brillante #D4AF37 */
  --naranja-vip: oklch(0.45 0.15 25);       /* Burdeos/Vino #722F37 */
  --crema: oklch(0.95 0.02 85);             /* Crema dorado */
  --gris-oscuro: oklch(0.15 0 0);           /* Negro suave */

  --background: oklch(0.10 0 0);            /* Fondo negro elegante */
  --foreground: oklch(0.95 0.02 85);        /* Texto crema */
  --card: oklch(0.16 0.01 25);              /* Cards con tinte burdeos */
  --card-foreground: oklch(0.95 0.02 85);
  --popover: oklch(0.16 0.01 25);
  --popover-foreground: oklch(0.95 0.02 85);
  --primary: oklch(0.75 0.13 85);           /* Dorado - CTAs principales */
  --primary-foreground: oklch(0.10 0 0);
  --secondary: oklch(0.45 0.15 25);         /* Burdeos - acentos */
  --secondary-foreground: oklch(0.95 0.02 85);
  --accent: oklch(0.75 0.13 85);            /* Dorado */
  --accent-foreground: oklch(0.10 0 0);
  --cta: oklch(0.75 0.13 85);               /* Dorado para CTAs */
  --cta-foreground: oklch(0.10 0 0);
  --muted: oklch(0.22 0.02 25);
  --muted-foreground: oklch(0.70 0.02 85);
  --ring: oklch(0.75 0.13 85);
  --border: oklch(0.30 0.03 25);
  --input: oklch(0.18 0.01 25);
}

/* ============================================
   TEMA: PREMIUM AMBER
   Neuromarketing: Negro (poder) + Ámbar/Whisky (calidez premium) + Crema (sofisticación)
   Ideal para: Ambiente de bar premium, bebidas de alta gama
   ============================================ */
.theme-premium-amber {
  --verde-bosque: oklch(0.12 0 0);          /* Negro profundo */
  --verde-neon: oklch(0.68 0.14 70);        /* Ámbar/Whisky #D4A84B */
  --naranja-vip: oklch(0.72 0.12 65);       /* Ámbar claro */
  --crema: oklch(0.94 0.03 80);             /* Crema cálido #F5E6D3 */
  --gris-oscuro: oklch(0.18 0 0);           /* Negro carbón */

  --background: oklch(0.08 0 0);            /* Fondo negro intenso */
  --foreground: oklch(0.94 0.03 80);        /* Texto crema */
  --card: oklch(0.14 0.02 70);              /* Cards con tinte ámbar */
  --card-foreground: oklch(0.94 0.03 80);
  --popover: oklch(0.14 0.02 70);
  --popover-foreground: oklch(0.94 0.03 80);
  --primary: oklch(0.68 0.14 70);           /* Ámbar - CTAs principales */
  --primary-foreground: oklch(0.08 0 0);
  --secondary: oklch(0.25 0.04 70);         /* Bronce oscuro */
  --secondary-foreground: oklch(0.94 0.03 80);
  --accent: oklch(0.68 0.14 70);            /* Ámbar */
  --accent-foreground: oklch(0.08 0 0);
  --cta: oklch(0.68 0.14 70);               /* Ámbar para CTAs */
  --cta-foreground: oklch(0.08 0 0);
  --muted: oklch(0.20 0.02 70);
  --muted-foreground: oklch(0.65 0.03 80);
  --ring: oklch(0.68 0.14 70);
  --border: oklch(0.28 0.04 70);
  --input: oklch(0.16 0.02 70);
}

/* ============================================
   TEMA: ROYAL SPORT
   Neuromarketing: Negro (autoridad) + Rojo vibrante (energía/apetito) + Dorado (victoria)
   Ideal para: Sports Bar con ambiente premium, eventos deportivos
   ============================================ */
.theme-royal-sport {
  --verde-bosque: oklch(0.12 0 0);          /* Negro profundo */
  --verde-neon: oklch(0.55 0.22 25);        /* Rojo vibrante #C41E3A */
  --naranja-vip: oklch(0.75 0.13 85);       /* Dorado victoria */
  --crema: oklch(0.96 0.01 0);              /* Blanco puro */
  --gris-oscuro: oklch(0.15 0 0);           /* Negro suave */

  --background: oklch(0.10 0 0);            /* Fondo negro */
  --foreground: oklch(0.96 0.01 0);         /* Texto blanco */
  --card: oklch(0.16 0.03 25);              /* Cards con tinte rojo */
  --card-foreground: oklch(0.96 0.01 0);
  --popover: oklch(0.16 0.03 25);
  --popover-foreground: oklch(0.96 0.01 0);
  --primary: oklch(0.55 0.22 25);           /* Rojo - energía, acción */
  --primary-foreground: oklch(0.98 0 0);
  --secondary: oklch(0.75 0.13 85);         /* Dorado - premium */
  --secondary-foreground: oklch(0.10 0 0);
  --accent: oklch(0.75 0.13 85);            /* Dorado */
  --accent-foreground: oklch(0.10 0 0);
  --cta: oklch(0.55 0.22 25);               /* Rojo para CTAs - urgencia */
  --cta-foreground: oklch(0.98 0 0);
  --muted: oklch(0.22 0.02 25);
  --muted-foreground: oklch(0.70 0.01 0);
  --ring: oklch(0.55 0.22 25);
  --border: oklch(0.30 0.04 25);
  --input: oklch(0.18 0.02 25);
}

/* ============================================
   TEMA: ELEGANT NIGHT
   Neuromarketing: Azul marino (confianza/relajación) + Dorado (lujo) + Crema (sofisticación)
   Ideal para: Experiencia nocturna elegante, mayor permanencia
   ============================================ */
.theme-elegant-night {
  --verde-bosque: oklch(0.20 0.08 250);     /* Azul marino profundo #0A1628 */
  --verde-neon: oklch(0.75 0.13 85);        /* Dorado clásico #D4AF37 */
  --naranja-vip: oklch(0.78 0.10 85);       /* Oro suave */
  --crema: oklch(0.94 0.02 75);             /* Crema marfil #F8F4E9 */
  --gris-oscuro: oklch(0.25 0.06 250);      /* Azul noche */

  --background: oklch(0.15 0.06 250);       /* Fondo azul noche */
  --foreground: oklch(0.94 0.02 75);        /* Texto crema */
  --card: oklch(0.22 0.07 250);             /* Cards azul oscuro */
  --card-foreground: oklch(0.94 0.02 75);
  --popover: oklch(0.22 0.07 250);
  --popover-foreground: oklch(0.94 0.02 75);
  --primary: oklch(0.75 0.13 85);           /* Dorado - lujo atemporal */
  --primary-foreground: oklch(0.15 0.06 250);
  --secondary: oklch(0.30 0.08 250);        /* Azul medio */
  --secondary-foreground: oklch(0.94 0.02 75);
  --accent: oklch(0.75 0.13 85);            /* Dorado */
  --accent-foreground: oklch(0.15 0.06 250);
  --cta: oklch(0.75 0.13 85);               /* Dorado para CTAs */
  --cta-foreground: oklch(0.15 0.06 250);
  --muted: oklch(0.28 0.05 250);
  --muted-foreground: oklch(0.70 0.02 75);
  --ring: oklch(0.75 0.13 85);
  --border: oklch(0.32 0.06 250);
  --input: oklch(0.22 0.05 250);
}

/* ============================================
   TEMA 6: WARM BISTRO
   Carbón cálido + Cobre/Bronce + Crema
   Neuromarketing: Marrón/cobre (apetito, sofisticación) + Crema (calidez) - Sin verde
   Ideal para: Ambiente bistró sofisticado, menos deportivo, más gastronómico
   ============================================ */
.theme-warm-bistro {
  --verde-bosque: oklch(0.22 0.02 50);        /* Carbón cálido #2C2825 */
  --verde-neon: oklch(0.58 0.12 55);          /* Cobre/Bronce #B87333 */
  --naranja-vip: oklch(0.65 0.14 50);         /* Terracota cálido */
  --crema: oklch(0.92 0.03 75);               /* Crema cálida #F5E6D3 */
  --gris-oscuro: oklch(0.28 0.02 50);         /* Carbón medio */

  --background: oklch(0.18 0.02 50);          /* Fondo carbón oscuro */
  --foreground: oklch(0.92 0.03 75);          /* Texto crema */
  --card: oklch(0.25 0.02 50);                /* Cards carbón */
  --card-foreground: oklch(0.92 0.03 75);
  --popover: oklch(0.25 0.02 50);
  --popover-foreground: oklch(0.92 0.03 75);
  --primary: oklch(0.58 0.12 55);             /* Cobre - calidez premium */
  --primary-foreground: oklch(0.18 0.02 50);
  --secondary: oklch(0.32 0.03 50);           /* Carbón claro */
  --secondary-foreground: oklch(0.92 0.03 75);
  --accent: oklch(0.65 0.14 50);              /* Terracota */
  --accent-foreground: oklch(0.18 0.02 50);
  --cta: oklch(0.58 0.12 55);                 /* Cobre para CTAs */
  --cta-foreground: oklch(0.98 0.01 75);
  --muted: oklch(0.30 0.02 50);
  --muted-foreground: oklch(0.70 0.02 75);
  --ring: oklch(0.58 0.12 55);
  --border: oklch(0.35 0.03 50);
  --input: oklch(0.25 0.02 50);
}

/* ============================================
   TEMA: HOTEL VIP LA GUAIRA
   Fondo claro (blanco/crema) con acentos dorados
   Para el menú de Room Service del Hotel VIP La Guaira
   ============================================ */
.theme-hotel {
  --hotel-gold: oklch(0.75 0.13 85);          /* Dorado principal #D4AF37 */
  --hotel-gold-dark: oklch(0.65 0.12 85);     /* Dorado oscuro para hover */
  --hotel-cream: oklch(0.97 0.02 85);         /* Crema suave #F8F4E9 */
  --hotel-white: oklch(1 0 0);                /* Blanco puro */
  --hotel-text: oklch(0.15 0 0);              /* Texto casi negro */
  --hotel-muted: oklch(0.45 0 0);             /* Texto secundario */

  --verde-bosque: var(--hotel-gold);          /* Mapeo para compatibilidad */
  --verde-neon: var(--hotel-gold);
  --naranja-vip: var(--hotel-gold-dark);
  --crema: var(--hotel-cream);
  --gris-oscuro: var(--hotel-text);

  --background: var(--hotel-white);           /* Fondo blanco */
  --foreground: var(--hotel-text);            /* Texto oscuro */
  --card: var(--hotel-white);                 /* Cards blancas */
  --card-foreground: var(--hotel-text);
  --popover: var(--hotel-white);
  --popover-foreground: var(--hotel-text);
  --primary: var(--hotel-gold);               /* Dorado - CTAs principales */
  --primary-foreground: var(--hotel-white);
  --secondary: var(--hotel-cream);            /* Crema para secundarios */
  --secondary-foreground: var(--hotel-text);
  --accent: var(--hotel-gold);                /* Dorado para acentos */
  --accent-foreground: var(--hotel-white);
  --cta: var(--hotel-gold);                   /* Dorado para CTAs */
  --cta-foreground: var(--hotel-white);
  --muted: oklch(0.96 0.01 85);               /* Fondo muted crema suave */
  --muted-foreground: var(--hotel-muted);
  --ring: var(--hotel-gold);
  --border: oklch(0.90 0.02 85);              /* Bordes dorados suaves */
  --input: oklch(0.96 0.01 85);               /* Input crema */
  --destructive: oklch(0.577 0.245 27.325);
  --destructive-foreground: oklch(1 0 0);
}

@theme inline {
  --font-sans: "Inter", "Inter Fallback", system-ui, -apple-system, sans-serif;
  --font-heading: "Bebas Neue", "Bebas Neue Fallback", "Impact", sans-serif;
  --font-accent: "Montserrat", "Montserrat Fallback", sans-serif;
  --font-luxury: "Playfair Display", "Playfair Display Fallback", Georgia, serif;
  --font-elegant: "Cormorant Garamond", "Cormorant Garamond Fallback", Georgia, serif;

  --color-verde-bosque: var(--verde-bosque);
  --color-verde-neon: var(--verde-neon);
  --color-naranja-vip: var(--naranja-vip);
  --color-crema: var(--crema);
  --color-gris-oscuro: var(--gris-oscuro);

  --color-background: var(--background);
  --color-foreground: var(--foreground);
  --color-card: var(--card);
  --color-card-foreground: var(--card-foreground);
  --color-popover: var(--popover);
  --color-popover-foreground: var(--popover-foreground);
  --color-primary: var(--primary);
  --color-primary-foreground: var(--primary-foreground);
  --color-secondary: var(--secondary);
  --color-secondary-foreground: var(--secondary-foreground);
  --color-muted: var(--muted);
  --color-muted-foreground: var(--muted-foreground);
  --color-accent: var(--accent);
  --color-accent-foreground: var(--accent-foreground);
  --color-cta: var(--cta);
  --color-cta-foreground: var(--cta-foreground);
  --color-destructive: var(--destructive);
  --color-destructive-foreground: var(--destructive-foreground);
  --color-border: var(--border);
  --color-input: var(--input);
  --color-ring: var(--ring);
  --color-chart-1: var(--chart-1);
  --color-chart-2: var(--chart-2);
  --color-chart-3: var(--chart-3);
  --color-chart-4: var(--chart-4);
  --color-chart-5: var(--chart-5);
  --radius-sm: calc(var(--radius) - 4px);
  --radius-md: calc(var(--radius) - 2px);
  --radius-lg: var(--radius);
  --radius-xl: calc(var(--radius) + 4px);
  --color-sidebar: var(--sidebar);
  --color-sidebar-foreground: var(--sidebar-foreground);
  --color-sidebar-primary: var(--sidebar-primary);
  --color-sidebar-primary-foreground: var(--sidebar-primary-foreground);
  --color-sidebar-accent: var(--sidebar-accent);
  --color-sidebar-accent-foreground: var(--sidebar-accent-foreground);
  --color-sidebar-border: var(--sidebar-border);
  --color-sidebar-ring: var(--sidebar-ring);
}

@layer base {
  * {
    @apply border-border outline-ring/50;
  }
  body {
    @apply bg-background text-foreground;
  }

  .font-heading {
    font-family: var(--font-heading);
  }

  .font-accent {
    font-family: var(--font-accent);
  }

  .font-luxury {
    font-family: var(--font-luxury);
  }

  .font-elegant {
    font-family: var(--font-elegant);
  }
}

/* Custom animations */
@keyframes pulse-slow {
  0%,
  100% {
    opacity: 1;
  }
  50% {
    opacity: 0.7;
  }
}

.animate-pulse-slow {
  animation: pulse-slow 3s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}

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

@keyframes float {
  0%, 100% {
    transform: translateY(0px);
  }
  50% {
    transform: translateY(-10px);
  }
}

.animate-float {
  animation: float 3s ease-in-out infinite;
}

@keyframes glow {
  0%, 100% {
    box-shadow: 0 0 20px rgba(0, 165, 80, 0.2);
  }
  50% {
    box-shadow: 0 0 40px rgba(0, 165, 80, 0.4);
  }
}

.animate-glow {
  animation: glow 2s ease-in-out infinite;
}

/* Hide scrollbar for horizontal carousel */
.scrollbar-hide {
  -ms-overflow-style: none;  /* IE and Edge */
  scrollbar-width: none;  /* Firefox */
}

.scrollbar-hide::-webkit-scrollbar {
  display: none;  /* Chrome, Safari and Opera */
}

/* Tablet-specific styles for landing page cards */
@media (min-width: 768px) and (max-width: 1024px) and (min-height: 900px) {
  .landing-cards-grid {
    flex: none !important;
  }
}

/* ============================================
   iOS Safe Area Support
   Prevents content from being hidden under
   Safari's bottom navigation bar
   ============================================ */

/* Safe area padding for bottom elements */
.pb-safe {
  padding-bottom: env(safe-area-inset-bottom, 16px);
}

.mb-safe {
  margin-bottom: env(safe-area-inset-bottom, 16px);
}

/* Minimum touch target size (WCAG 2.1 - 44x44px) */
.touch-target {
  min-height: 44px;
  min-width: 44px;
}

/* iOS-specific fixes for bottom positioned elements */
@supports (padding-bottom: env(safe-area-inset-bottom)) {
  .fixed-bottom-safe {
    padding-bottom: calc(env(safe-area-inset-bottom) + 1rem);
  }
}
