/* ============================================================
   GRAND CASINO ESCAZÚ — style.css
   Paleta: negro profundo · dorado #c9a84c · crema #ede8dc
   Tipografía: Cormorant Garamond (display) · DM Sans (body)
   ============================================================ */

/* ── VARIABLES ── */
:root {
  --gold:        #c9a84c;
  --gold2:       #e8c96a;
  --jackpot-cyan:#60efff;
  --gold-dim:    #c9a84c14;
  --gold-line:   #c9a84c28;
  --ruby:        #7b1f3b;
  --violet:      #3b295f;
  --emerald:     #1f5a4d;
  --amber-glow:  #f0c95a;
  --dark:        #070706;
  --dark2:       #0c0c0a;
  --dark3:       #111110;
  --dark4:       #161614;
  --cream:       #ede8dc;
  --cream2:      #f5f0e8;
  --cream-dim:   #ede8dcb8;
  --cream-muted: #c4bfb2;
  --serif:       'Cormorant Garamond', serif;
  --casino:      'Cinzel', serif;
  --sans:        'DM Sans', sans-serif;
}

/* ── RESET ── */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  background:
    radial-gradient(1200px 520px at 8% -10%, #c9a84c22 0%, transparent 60%),
    radial-gradient(900px 420px at 92% 8%, #7b1f3b44 0%, transparent 60%),
    linear-gradient(180deg, #070706 0%, #0b0a09 55%, #070706 100%);
  color: var(--cream);
  font-family: var(--sans);
  overflow-x: hidden;
}
img { display: block; max-width: 100%; }
a { text-decoration: none; }

/* ── UTILIDADES ── */
.section { width: 100%; }

/* ── FONDOS POR SECCIÓN (alternancia estilo Graton) ── */
#gaming {
  background:
    radial-gradient(800px 300px at 90% 0%, rgba(59, 41, 95, 0.28) 0%, transparent 65%),
    linear-gradient(180deg, #0c0b14 0%, #0e0c16 100%);
  border-top: 0.5px solid var(--gold-line);
}
#eventos {
  background: linear-gradient(180deg, #06060a 0%, #09080e 100%);
  border-top: 0.5px solid var(--gold-line);
}
#promociones {
  background: var(--cream2);
  border-top: 0.5px solid #e0d8c8;
  border-bottom: 0.5px solid #e0d8c8;
}
#promociones .sh-eye      { color: #6b2fa0; }
#promociones .sh-title    { color: #1a1810; }
#promociones .sh-title em { color: #6b2fa0; }
#promociones .promos-body { color: #5a5040; }
#promociones .pc          { background: #fff; box-shadow: 0 2px 18px rgba(0,0,0,0.07); }
#promociones .pc:hover    { background: #fdf9f4; }
#promociones .pc-num      { color: rgba(201,168,76,0.55); }
#promociones .pc-title    { color: #1a1810; }
#promociones .pc-dates    { color: #b08a30; }
#promociones .pc-desc     { color: #5a5040; }
#promociones .carousel-track-wrap { background: transparent; }
#promociones .carousel-btn {
  border-color: rgba(201,168,76,0.45);
  color: #1a1810;
  background: transparent;
}
#promociones .carousel-btn:hover:not(:disabled) {
  border-color: var(--gold);
  background: rgba(201,168,76,0.1);
}
#promociones .carousel-dot    { background: rgba(26,24,16,0.18); }
#promociones .carousel-dot.active { background: var(--gold); }
#gastronomia {
  background: linear-gradient(180deg, #080c10 0%, #090e13 100%);
  border-top: 0.5px solid var(--gold-line);
}
#conozcanos {
  background: var(--cream2);
  border-top: 1px solid #e0d8c8;
}

.sh { padding: 56px 52px 32px; }
.sh-eye {
  font-size: 15px;
  font-weight: 600;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 10px;
}
.sh-title {
  font-family: var(--serif);
  font-size: 52px;
  font-weight: 600;
  line-height: 1.0;
  color: var(--cream2);
}
.sh-title em { font-style: italic; color: var(--gold); }

.link-gold {
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--gold);
}
.link-gold::after { content: ' →'; }

/* ── BOTONES ── */
.btn-gold {
  font-size: 13px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--dark);
  background: var(--gold);
  padding: 16px 36px;
  border: none;
  cursor: pointer;
  font-family: var(--sans);
  font-weight: 500;
  transition: background 0.2s, box-shadow 0.25s, transform 0.25s;
}
.btn-gold:hover {
  background: var(--gold2);
  box-shadow: 0 10px 28px #c9a84c42;
  transform: translateY(-2px);
}

.btn-outline {
  font-size: 13px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--gold);
  background: transparent;
  padding: 16px 36px;
  border: 0.5px solid var(--gold-line);
  cursor: pointer;
  font-family: var(--sans);
  transition: border-color 0.2s, background 0.25s, color 0.25s, transform 0.25s;
}
.btn-outline:hover {
  border-color: var(--gold);
  background: var(--gold-dim);
  color: var(--gold2);
  transform: translateY(-2px);
}

.btn-login {
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--dark);
  background: var(--gold);
  padding: 9px 22px;
  border: none;
  cursor: pointer;
  font-family: var(--sans);
  font-weight: 500;
}

.btn-ticket {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--dark);
  background: var(--gold);
  padding: 12px 22px;
  border: none;
  cursor: pointer;
  font-family: var(--sans);
  font-weight: 500;
  transition: transform 0.25s, box-shadow 0.25s;
}
.btn-ticket:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 22px #c9a84c3a;
}

/* ── PROMO BAND ── */
.promo-band {
  position: relative;
  border-top: 1px solid var(--gold);
  border-bottom: 1px solid var(--gold);
  overflow: hidden;
  height: 360px;
}
.promo-band-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  filter: brightness(0.45) saturate(0.7);
}
.promo-band-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to right, rgba(7,5,3,0.94) 0%, rgba(7,5,3,0.70) 50%, rgba(7,5,3,0.30) 100%);
}
.promo-band-content {
  position: relative;
  z-index: 2;
  height: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 52px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
}
.pb-left {
  display: flex;
  flex-direction: column;
  gap: 8px;
  flex: 1 1 auto;
  min-width: 0;
}
.pb-eyebrow {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 2px;
}
.pb-diamond {
  font-size: 8px;
  color: var(--gold);
  opacity: 0.8;
}
.pb-amount {
  font-family: var(--serif);
  font-size: 110px;
  font-weight: 600;
  color: var(--gold2);
  line-height: 0.95;
  letter-spacing: -2px;
}
.pb-desc {
  font-family: var(--serif);
  font-size: 24px;
  font-weight: 400;
  color: var(--cream2);
  opacity: 0.85;
  line-height: 1.3;
  margin-top: 4px;
}
.pb-divider {
  width: 1px;
  height: 180px;
  background: linear-gradient(to bottom, transparent, var(--gold-line), transparent);
  flex-shrink: 0;
}
.pb-right {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  align-self: center;
  gap: 14px;
  flex: 0 0 320px;
  width: 320px;
  border: 1px solid rgba(212,175,80,0.4);
  border-radius: 4px;
  padding: 24px 24px 22px;
  background:
    radial-gradient(300px 200px at 10% 20%, rgba(59,41,95,0.5) 0%, transparent 70%),
    linear-gradient(180deg, #140f1e 0%, #100c18 100%);
}
.pb-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: var(--gold);
  border: 1px solid rgba(212,175,80,0.5);
  border-radius: 2px;
  padding: 4px 10px;
}
.pb-right-top {
  display: flex;
  flex-direction: column;
  gap: 10px;
  width: 100%;
}
.pb-logo-placeholder {
  height: 38px;
  width: 140px;
  border: 1px dashed rgba(212,175,80,0.35);
  border-radius: 3px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: rgba(212,175,80,0.4);
}
.pb-logo-img {
  height: 38px;
  width: auto;
  object-fit: contain;
}
.pb-logo-hidden { display: none; }
.pb-cta-heading {
  font-family: var(--serif);
  font-size: 26px;
  font-weight: 600;
  color: var(--cream2);
  line-height: 1.2;
  white-space: nowrap;
}
.pb-cta-sub {
  font-size: 14px;
  color: var(--cream-muted);
  line-height: 1.6;
  margin-bottom: 4px;
}
.pb-cta-sub2 {
  font-size: 14px;
  color: var(--cream-muted);
  line-height: 1.4;
}
.pb-highlight {
  font-family: var(--casino);
  font-size: 20px;
  font-weight: 700;
  color: var(--gold);
  letter-spacing: 0.5px;
}
.pb-cta-btn {
  white-space: nowrap;
}
@media (max-width: 1024px) {
  .promo-band          { height: 300px; }
  .promo-band-content  { padding: 0 32px; gap: 24px; }
  .pb-amount           { font-size: 80px; }
  .pb-desc             { font-size: 20px; }
  .pb-cta-heading      { font-size: 26px; }
  .pb-right            { flex: 0 0 230px; width: 230px; padding: 20px; }
}
@media (max-width: 768px) {
  .promo-band          { height: auto; }
  .promo-band-content  { flex-direction: column; align-items: flex-start; padding: 40px 20px; gap: 28px; }
  .pb-divider          { display: none; }
  .pb-right            { max-width: 100%; }
  .pb-left             { flex-direction: column; gap: 4px; }
  .pb-amount           { font-size: 48px; }
  .pb-desc             { font-size: 20px; }
}

/* ── SITE HEADER (sticky wrapper) ── */
.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
}

/* ── NAV ── */
.nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 52px;
  background: linear-gradient(90deg, #070706 0%, #0b0a09 55%, #120d12 100%);
  border-bottom: 0.5px solid var(--gold-line);
}
.logo { display: flex; align-items: center; gap: 12px; }
.logo-ring {
  width: 38px;
  height: 38px;
  border: 1px solid var(--gold);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--serif);
  font-size: 20px;
  color: var(--gold);
  font-weight: 300;
}
.logo-name {
  font-size: 11px;
  letter-spacing: 3px;
  color: var(--gold);
  text-transform: uppercase;
  line-height: 1.5;
}
.nav-links { display: flex; gap: 28px; }
.nav-links a {
  font-size: 12px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--cream);
  opacity: 0.94;
  position: relative;
  transition: color 0.2s, opacity 0.2s;
}
.nav-links a:hover { color: var(--gold); opacity: 1; }
.nav-links a.active {
  color: var(--gold2);
  opacity: 1;
}
.nav-links a.active::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: -7px;
  height: 1px;
  background: linear-gradient(90deg, transparent 0%, var(--gold2) 25%, var(--gold2) 75%, transparent 100%);
}
.nav-right { display: flex; align-items: center; gap: 12px; }
.lang {
  font-size: 11px;
  letter-spacing: 2px;
  color: var(--cream);
  padding: 6px 10px;
  border: 0.5px solid var(--gold-line);
  cursor: pointer;
}

/* ── TICKER ── */
.ticker {
  background: linear-gradient(90deg, #1e0f30 0%, #24143a 50%, #301743 100%);
  border-bottom: 0.5px solid var(--gold-line);
  padding: 9px 52px;
  display: flex;
  align-items: center;
  gap: 14px;
  overflow: hidden;
}
.t-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--gold);
  flex-shrink: 0;
  animation: blink 1.4s infinite;
}
@keyframes blink {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.2; }
}
.t-label {
  font-size: 11px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--gold);
  white-space: nowrap;
  flex-shrink: 0;
}
.t-divider {
  width: 0.5px;
  height: 14px;
  background: var(--gold-line);
  flex-shrink: 0;
}
.t-track { overflow: hidden; flex: 1; }
.t-scroll {
  display: flex;
  gap: 34px;
  animation: slide 28s linear infinite;
  white-space: nowrap;
}
@keyframes slide {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
.t-item {
  display: inline-flex;
  align-items: baseline;
  gap: 8px;
  font-size: 11px;
  color: var(--cream-dim);
  flex-shrink: 0;
  text-transform: uppercase;
  letter-spacing: 0.8px;
}
.t-item::after {
  content: '············';
  margin-left: 10px;
  color: #cfba7b96;
  letter-spacing: 2px;
}
.t-amount {
  color: var(--gold2);
  font-family: var(--casino);
  font-size: 22px;
  line-height: 1;
  font-weight: 700;
  letter-spacing: 1px;
}
.t-copy {
  color: #e8dec9;
  font-size: 12px;
  letter-spacing: 1.3px;
  opacity: 0.9;
}
.t-game {
  color: var(--jackpot-cyan);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 1.2px;
}
.t-datetime {
  color: #d7cfbf;
  opacity: 0.78;
  font-size: 12px;
  text-transform: none;
  font-style: italic;
}

/* ── HERO ── */
.hero {
  display: flex;
  align-items: stretch;
  width: 100%;
  position: relative;
}
.hero-left {
  flex: 1 1 0;
  min-width: 600px;
  background:
    radial-gradient(560px 240px at 8% 8%, #7b1f3b30 0%, transparent 75%),
    linear-gradient(165deg, #080706 0%, #100f0e 55%, #0c0b0a 100%);
  padding: 36px 52px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
  overflow: hidden;
}
.hero-bg-char {
  position: absolute;
  right: -40px;
  bottom: -60px;
  font-family: var(--serif);
  font-size: 300px;
  font-weight: 300;
  color: var(--gold);
  opacity: 0.07;
  line-height: 1;
  pointer-events: none;
  user-select: none;
}
.hero-eyebrow {
  font-size: 12px;
  letter-spacing: 4px;
  color: var(--gold);
  text-transform: uppercase;
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  gap: 14px;
}
.hero-eyebrow-line {
  width: 28px;
  height: 0.5px;
  background: var(--gold);
}
.hero-h1 {
  font-family: var(--serif);
  font-size: 68px;
  font-weight: 400;
  line-height: 1.0;
  color: var(--cream2);
  margin-bottom: 18px;
  text-shadow: 0 6px 30px rgba(0, 0, 0, 0.45);
}
.hero-h1 em { font-style: italic; color: var(--gold); }
.hero-body {
  font-size: 15px;
  line-height: 1.95;
  color: var(--cream-muted);
  max-width: 360px;
  margin-bottom: 28px;
}
.hero-actions { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.hero-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  margin-top: 32px;
  background: var(--gold-line);
}
.h-stat {
  background: var(--dark);
  padding: 26px 28px;
  border-top: 2px solid var(--gold-line);
  transition: border-color 0.25s, background 0.25s;
}
.h-stat:hover {
  border-top-color: var(--gold);
  background: var(--dark4);
}
.h-stat-n {
  font-family: var(--serif);
  font-size: 68px;
  font-weight: 400;
  color: var(--gold);
  line-height: 1;
  letter-spacing: -1px;
}
.h-stat-l {
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: var(--cream2);
  opacity: 0.7;
  margin-top: 8px;
}
.hero-right {
  flex: 0 0 auto;
  position: relative;
  overflow: hidden;
}

/* ── HERO MEDIA (video full-width) ── */
.hero-media {
  position: absolute;
  inset: 0;
  overflow: hidden;
  z-index: 0;
}
.hero-bg-img,
.hero-bg-video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(0.90) saturate(1.0) contrast(1.02);
  display: block;
  animation: kenBurns 24s ease-in-out infinite alternate;
  transform-origin: center center;
  will-change: transform;
}

@keyframes kenBurns {
  0%   { transform: scale(1)    translate(0,    0);    }
  33%  { transform: scale(1.06) translate(-1.5%, -1%); }
  66%  { transform: scale(1.04) translate(1%,   -2%);  }
  100% { transform: scale(1.1)  translate(-2%,  1%);   }
}

/* Shimmer diagonal que cruza la imagen cada 8 s */
.hero-shimmer {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    108deg,
    transparent 38%,
    rgba(201, 168, 76, 0.07) 50%,
    transparent 62%
  );
  animation: heroShimmer 9s ease-in-out infinite;
  pointer-events: none;
}

@keyframes heroShimmer {
  0%, 100% { transform: translateX(-120%); }
  50%       { transform: translateX(200%);  }
}

/* ── PARTÍCULAS (canvas) ── */
.hero-particles {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 2;
}

/* ── OVERLAY ── */
.hero-overlay {
  position: absolute;
  inset: 0;
  z-index: 2;
  background:
    linear-gradient(to right, rgb(8, 7, 6) 0%, rgba(8, 7, 6, 0.70) 6%, transparent 18%),
    linear-gradient(to top,   rgba(7, 7, 6, 0.30) 0%, transparent 30%);
}

/* ── BADGES ── */
.hero-float-top {
  position: absolute;
  top: 32px;
  left: 32px;
  z-index: 3;
  background: rgba(7, 7, 6, 0.85);
  border: 0.5px solid var(--gold-line);
  padding: 14px 18px;
  backdrop-filter: blur(4px);
}
.hero-badge {
  position: absolute;
  bottom: 32px;
  right: 32px;
  z-index: 3;
  background: linear-gradient(135deg, var(--gold2) 0%, var(--gold) 100%);
  padding: 14px 18px;
  text-align: center;
  box-shadow: 0 10px 26px rgba(201, 168, 76, 0.34);
}

/* ── ANIMACIONES DE ENTRADA DEL TEXTO ── */
@keyframes fadeSlideUp {
  from { opacity: 0; transform: translateY(28px); }
  to   { opacity: 1; transform: translateY(0);    }
}

.hero-eyebrow { animation: fadeSlideUp 0.85s cubic-bezier(0.22, 1, 0.36, 1) 0.2s both; }
.hero-h1      { animation: fadeSlideUp 0.95s cubic-bezier(0.22, 1, 0.36, 1) 0.45s both; }
.hero-body    { animation: fadeSlideUp 0.85s cubic-bezier(0.22, 1, 0.36, 1) 0.75s both; }
.hero-actions { animation: fadeSlideUp 0.85s cubic-bezier(0.22, 1, 0.36, 1) 1.0s both; }
.hero-stats   { animation: fadeSlideUp 0.85s cubic-bezier(0.22, 1, 0.36, 1) 1.25s both; }

/* Respeta preferencia del SO por menos movimiento */
@media (prefers-reduced-motion: reduce) {
  .hero-bg-img,
  .hero-bg-video  { animation: none; }
  .hero-shimmer   { animation: none; }
  .hero-eyebrow,
  .hero-h1,
  .hero-body,
  .hero-actions,
  .hero-stats     { animation: none; }
}
.hb-num {
  font-family: var(--serif);
  font-size: 30px;
  color: var(--dark);
  font-weight: 300;
  line-height: 1;
}
.hb-lbl {
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--dark);
  opacity: 0.65;
  margin-top: 2px;
}

/* ── COUNTDOWN ── */
.countdown {
  background: #f0ede8;
  border-top: 1px solid #d8d0c4;
  border-bottom: 1px solid #d8d0c4;
  padding: 20px 52px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  position: relative;
  overflow: hidden;
}
.countdown::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
  opacity: 0.5;
}
.cd-left { display: flex; align-items: center; gap: 14px; }
.cd-pulse {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #6b2fa0;
  animation: blink 1.4s infinite;
  box-shadow: 0 0 8px rgba(107,47,160,0.55);
  flex-shrink: 0;
}
.cd-lbl {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 2px;
  text-transform: uppercase;
  white-space: nowrap;
  padding: 5px 12px;
  border: 1.5px solid #6b2fa0;
  color: #6b2fa0;
  animation: cdLblContrast 2.8s ease-in-out infinite;
}
@keyframes cdLblContrast {
  0%, 100% { color: #6b2fa0; background: transparent; }
  40%, 60% { color: #fff;    background: #6b2fa0;     }
}
.cd-name {
  font-family: var(--serif);
  font-size: 26px;
  color: #1a1810;
  margin-left: 4px;
  white-space: nowrap;
}
.cd-units { display: flex; align-items: center; gap: 3px; }
.cd-unit {
  background: rgba(255,255,255,0.7);
  border: 1px solid #d8d0c4;
  padding: 10px 16px;
  text-align: center;
  min-width: 64px;
}
.cd-n {
  font-family: var(--serif);
  font-size: 32px;
  color: #6b2fa0;
  line-height: 1;
  display: block;
}
.cd-s {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #7a6e5e;
  display: block;
  margin-top: 3px;
}
.cd-sep {
  font-family: var(--serif);
  font-size: 22px;
  color: #6b2fa0;
  opacity: 0.5;
  padding: 0 2px;
}
.cd-cta {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #fff;
  background: #6b2fa0;
  padding: 12px 22px;
  white-space: nowrap;
  border: none;
  cursor: pointer;
  transition: background 0.2s;
}
.cd-cta:hover { background: #7e38bd; }
.cd-cta::after { content: ''; }

/* ── AGENDA SEMANAL TICKER ── */
.week-ticker {
  background: linear-gradient(90deg, #0d0a07 0%, #110e0a 50%, #0d0a07 100%);
  border-bottom: 0.5px solid var(--gold-line);
  padding: 11px 52px;
  display: flex;
  align-items: center;
  gap: 16px;
  overflow: hidden;
}
.wt-label {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 9px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--cream2);
  white-space: nowrap;
  flex-shrink: 0;
}
.wt-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--gold);
  flex-shrink: 0;
}
.wt-divider {
  width: 0.5px;
  height: 14px;
  background: var(--gold-line);
  flex-shrink: 0;
}
.wt-track { overflow: hidden; flex: 1; }
.wt-scroll {
  display: flex;
  align-items: center;
  gap: 16px;
  white-space: nowrap;
  animation: slide 35s linear infinite;
}
.wt-scroll:hover { animation-play-state: paused; }
.wt-item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  text-decoration: none;
  flex-shrink: 0;
  transition: opacity 0.2s;
}
.wt-item:hover { opacity: 0.8; }
.wt-day {
  font-size: 8px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--gold);
  opacity: 0.7;
}
.wt-name {
  font-size: 11px;
  color: var(--cream-muted);
}
.wt-hour {
  font-size: 9px;
  color: var(--cream-muted);
  opacity: 0.45;
}
/* Eventos destacados (viernes/sábado) */
.wt-item--hot .wt-day { opacity: 1; }
.wt-item--hot .wt-name { color: var(--cream2); font-weight: 500; }
.wt-sep {
  color: var(--gold-line);
  font-size: 14px;
  flex-shrink: 0;
  user-select: none;
}
.wt-cta {
  font-size: 9px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--gold);
  white-space: nowrap;
  flex-shrink: 0;
  transition: opacity 0.2s;
}
.wt-cta:hover { opacity: 0.7; }
.wt-cta::after { content: ' →'; }

/* ── GAMING ── */
.gaming-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.5px;
  background: var(--gold-line);
  margin: 0 52px;
}
.gc {
  background: linear-gradient(160deg, #0e0d0b 0%, #151311 100%);
  padding: 0 0 28px;
  cursor: pointer;
  transition: background 0.25s;
  overflow: hidden;
}
.gc:hover {
  background: linear-gradient(160deg, #171513 0%, #1f1a18 100%);
  box-shadow: inset 0 0 0 1px rgba(201, 168, 76, 0.2);
}
.gc:nth-child(1) { border-top: 2px solid #c9a84c66; }
.gc:nth-child(2) { border-top: 2px solid #7b1f3b88; }
.gc:nth-child(3) { border-top: 2px solid #1f5a4d88; }
.gc:nth-child(4) { border-top: 2px solid #3b295f88; }
.gc-photo {
  height: 200px;
  overflow: hidden;
  position: relative;
  margin-bottom: 24px;
}
.gc-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(0.5) saturate(0.6);
}
.gc-photo-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to top, rgba(12, 12, 10, 0.95) 0%, transparent 62%),
    linear-gradient(to right, rgba(123, 31, 59, 0.22) 0%, transparent 48%);
}
.gc-icon {
  font-size: 22px;
  color: var(--gold);
  margin: 0 26px 8px;
}
.gc-badge {
  display: inline-block;
  font-size: 8px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--gold);
  border: 0.5px solid var(--gold-line);
  padding: 3px 8px;
  margin: 0 26px 8px;
}
.gc-name {
  font-family: var(--serif);
  font-size: 30px;
  font-weight: 300;
  color: var(--cream2);
  margin: 0 26px 8px;
}
.gc-desc {
  font-size: 11px;
  color: var(--cream-muted);
  line-height: 1.85;
  margin: 0 26px 16px;
}
.gc-link {
  font-size: 9px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--gold);
  margin: 0 26px;
}
.gc-link::after { content: ' →'; }
.gc-link { display: none; }

/* ── PHOTO BREAK ── */
.photo-break {
  background: linear-gradient(180deg, #0c0b14 0%, #0e0c16 100%);
  border-top: 0.5px solid var(--gold-line);
  border-bottom: 0.5px solid var(--gold-line);
}
.pb-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 480px;
}
.pb-left {
  padding: 64px 52px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.pb-body {
  font-size: 13px;
  color: var(--cream-muted);
  line-height: 2.1;
  max-width: 320px;
  margin: 14px 0 26px;
}
.pb-right {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 0.5px;
  background: var(--gold-line);
}
.pb-cell {
  overflow: hidden;
  position: relative;
}
.pb-span2 { grid-column: span 2; }
.pb-cell img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(0.55) saturate(0.65);
  transition: filter 0.4s;
}
.pb-cell:hover img { filter: brightness(0.7) saturate(0.75); }
.pb-cell-label {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  background: rgba(7, 7, 6, 0.7);
  border-top: 0.5px solid var(--gold-line);
  padding: 10px 14px;
  font-size: 8px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--gold);
}

/* ── WINNERS ── */
.winners {
  background: var(--cream2);
  border-top: 0.5px solid #e0d8c8;
  border-bottom: 0.5px solid #e0d8c8;
  padding: 56px 52px;
}
.winners .sh-eye    { color: #6b2fa0; }
.winners .sh-title  { color: #1a1810; }
.winners .sh-title em { color: #6b2fa0; }
.winners .cd-cta    { color: var(--gold); border-color: var(--gold); }
.winners .w-grid    { background: #e0d8c8; }
.winners .wc        { background: #fff; }
.winners .wc:hover  { background: #fdf9f4; box-shadow: inset 0 0 0 1px rgba(201,168,76,0.25); }
.winners .wc-init   { color: var(--gold); border-color: rgba(201,168,76,0.45); background: transparent; }
.winners .wc-amount { color: #1a1810; }
.winners .wc-game   { color: #6b5e4a; opacity: 1; }
.winners .wc-time   { color: #9b8f7a; opacity: 1; }
.winners .wc-photo  { background: #e8e0d4; }
.winners .wc-photo img { filter: brightness(0.85) saturate(0.85); }
.w-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: 28px;
}
.w-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.5px;
  background: var(--gold-line);
}
.wc {
  background: linear-gradient(160deg, #0f0e0c 0%, #141311 100%);
  padding: 0 0 22px;
  transition: background 0.2s;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.wc:hover {
  background: linear-gradient(160deg, #1a1715 0%, #1f1b19 100%);
  box-shadow: inset 0 0 0 1px rgba(201, 168, 76, 0.18);
}
.wc-photo {
  width: 100%;
  height: 130px;
  position: relative;
  overflow: hidden;
  flex-shrink: 0;
  margin-bottom: 18px;
  background: #0a0908;
}
.wc-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(0.55) saturate(0.75);
  transition: filter 0.3s, transform 0.35s;
}
.wc:hover .wc-photo img {
  filter: brightness(0.68) saturate(0.9);
  transform: scale(1.04);
}
.wc-photo-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, transparent 35%, rgba(15,14,12,0.92) 100%);
}
.wc-info {
  padding: 0 22px;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.wc-init {
  width: 36px;
  height: 36px;
  border: 0.5px solid var(--gold-line);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--serif);
  font-size: 13px;
  color: var(--gold);
  margin-bottom: 12px;
}
.wc-amount {
  font-family: var(--serif);
  font-size: 38px;
  font-weight: 700;
  color: var(--gold);
  line-height: 1;
  margin-bottom: 6px;
}
.wc-game {
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--cream-muted);
  margin-top: 0;
}
.wc-time {
  font-size: 10px;
  color: var(--cream-muted);
  opacity: 0.4;
  margin-top: 5px;
}

/* ── EVENTOS ── */
.ev-grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: 0.5px;
  background: var(--gold-line);
  margin: 0 52px;
}
.ev-feat {
  position: relative;
  overflow: hidden;
  min-height: 420px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}
.ev-feat img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(0.4) saturate(0.6);
}
.ev-feat-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to top, rgba(7,7,6,0.95) 35%, rgba(7,7,6,0.6) 62%, transparent 100%),
    linear-gradient(to right, rgba(123, 31, 59, 0.22) 0%, transparent 55%);
}
.ev-feat-content {
  position: relative;
  z-index: 2;
  padding: 36px;
}
.ev-tag {
  font-size: 9px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 8px;
}
.ev-title {
  font-family: var(--serif);
  font-size: 34px;
  font-weight: 300;
  color: var(--cream2);
  margin-bottom: 8px;
  line-height: 1.15;
}
.ev-meta {
  font-size: 11px;
  color: var(--cream-muted);
  margin-bottom: 18px;
  line-height: 1.8;
}
.ev-stack {
  display: flex;
  flex-direction: column;
  gap: 0.5px;
}
.ev-sm {
  background: linear-gradient(165deg, #0f0e0c 0%, #141210 100%);
  padding: 26px 30px;
  flex: 1;
  cursor: pointer;
  transition: background 0.2s;
  border-left: 2px solid transparent;
}
.ev-sm:hover {
  background: linear-gradient(165deg, #171412 0%, #1d1817 100%);
  border-left-color: var(--gold);
}
.ev-sm-title {
  font-family: var(--serif);
  font-size: 19px;
  font-weight: 300;
  color: var(--cream2);
  margin-bottom: 5px;
}
.ev-sm-meta {
  font-size: 10px;
  color: var(--cream-muted);
  margin-bottom: 10px;
}

/* ── UNIQUE CLUB ── */
.unique-wrap {
  background:
    radial-gradient(900px 340px at 12% 8%, rgba(59, 41, 95, 0.38) 0%, transparent 65%),
    radial-gradient(600px 220px at 88% 80%, rgba(123, 31, 59, 0.22) 0%, transparent 60%),
    linear-gradient(180deg, #140f1e 0%, #100c18 100%);
  border-top: 0.5px solid var(--gold-line);
  padding: 60px 52px;
}
.unique-gold-bar {
  background: linear-gradient(90deg, var(--gold2) 0%, var(--gold) 45%, #c49f45 100%);
  padding: 0 52px;
  margin: 0 -52px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.ugb-text {
  font-size: 9px;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--dark);
  font-weight: 500;
  padding: 10px 0;
}
.unique-intro {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: end;
  margin: 36px 0;
}
.u-body {
  font-size: 13px;
  color: var(--cream-muted);
  line-height: 2.1;
  max-width: 400px;
}
.tiers {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0.5px;
  background: var(--gold-line);
}
.tier {
  background: linear-gradient(170deg, #0f0e0c 0%, #141311 100%);
  text-align: center;
  cursor: pointer;
  transition: all 0.25s;
  border-top: 2px solid transparent;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.tier:hover,
.tier.active {
  background: linear-gradient(170deg, #191614 0%, #211d1b 100%);
  border-top-color: var(--gold);
  box-shadow: inset 0 0 0 1px rgba(201, 168, 76, 0.14);
}

/* ── Imagen vertical de la tier card ── */
.tier-img-wrap {
  position: relative;
  width: 100%;
  aspect-ratio: 3 / 4;
  overflow: hidden;
  flex-shrink: 0;
}
.tier-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  filter: brightness(0.42) saturate(0.6);
  transition: filter 0.4s, transform 0.5s;
}
.tier:hover .tier-img,
.tier.active .tier-img {
  filter: brightness(0.58) saturate(0.75);
  transform: scale(1.04);
}
.tier-img-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to top, rgba(10,9,8,0.92) 0%, rgba(10,9,8,0.25) 55%, transparent 100%),
    linear-gradient(to bottom, rgba(10,9,8,0.55) 0%, transparent 40%);
  pointer-events: none;
}

/* ── Contenido textual ── */
.tier-body {
  padding: 20px 14px 24px;
  display: flex;
  flex-direction: column;
  align-items: center;
  flex: 1;
}
.tier-n {
  font-size: 8px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--cream-muted);
  opacity: 0.4;
  margin-bottom: 8px;
}
.tier-name {
  font-family: var(--serif);
  font-size: 30px;
  font-weight: 300;
  color: var(--cream2);
  margin-bottom: 8px;
}
.tier-bar {
  width: 14px;
  height: 1px;
  background: var(--gold);
  margin: 0 auto 12px;
}
.tier-desc {
  font-size: 10px;
  color: var(--cream-muted);
  line-height: 1.8;
}
.tier-link {
  display: block;
  margin-top: 14px;
  font-size: 8px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--gold);
}

/* ── PROMOCIONES ── */
.promos-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.5px;
  background: var(--gold-line);
  margin: 0 52px;
}
.pc {
  background: linear-gradient(165deg, #0f0e0c 0%, #141311 100%);
  overflow: hidden;
  cursor: pointer;
  transition: background 0.2s;
}
.pc:hover {
  background: linear-gradient(165deg, #181513 0%, #1d1917 100%);
}
.pc-photo {
  height: 180px;
  overflow: hidden;
  position: relative;
}
.pc-photo::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(7, 7, 6, 0.72) 0%, transparent 56%),
              linear-gradient(to right, rgba(123, 31, 59, 0.26) 0%, transparent 60%);
  transition: opacity 0.3s;
}
.pc:hover .pc-photo::after { opacity: 0.72; }
.pc-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(0.45) saturate(0.6);
  transition: filter 0.3s;
}
.pc:hover .pc-photo img { filter: brightness(0.55) saturate(0.7); }
.pc-photo-tag {
  position: absolute;
  top: 16px;
  left: 16px;
  background: var(--gold);
  padding: 5px 12px;
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #fff;
  font-weight: 700;
}
.pc-body { padding: 28px; }
.pc-num {
  font-family: var(--serif);
  font-size: 9px;
  letter-spacing: 3px;
  color: var(--gold-line);
  margin-bottom: 10px;
}
.pc-title {
  font-family: var(--serif);
  font-size: 30px;
  font-weight: 300;
  color: var(--cream2);
  margin-bottom: 6px;
}
.pc-dates {
  font-size: 9px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 10px;
}
.pc-desc {
  font-size: 11px;
  color: var(--cream-muted);
  line-height: 1.9;
  margin-bottom: 18px;
}

/* ── GASTRONOMÍA ── */
.gastro {
  padding: 60px 52px;
  border-top: 0.5px solid var(--gold-line);
}
.gastro-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.5px;
  background: var(--gold-line);
  margin-top: 36px;
}
.gi {
  background: linear-gradient(165deg, #0f0e0c 0%, #141311 100%);
  overflow: hidden;
}
.gi-photo {
  height: 200px;
  overflow: hidden;
  position: relative;
}
.gi-photo::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(7, 7, 6, 0.78) 0%, transparent 58%),
              linear-gradient(to right, rgba(31, 90, 77, 0.2) 0%, transparent 62%);
}
.gi-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(0.5) saturate(0.65);
  transition: filter 0.35s;
}
.gi:hover .gi-photo img { filter: brightness(0.65) saturate(0.75); }
.gi-photo-label {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  background: var(--gold);
  padding: 8px 16px;
  font-size: 8px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--dark);
  font-weight: 500;
}
.gi-body { padding: 28px; }
.gi-name {
  font-family: var(--serif);
  font-size: 24px;
  font-weight: 300;
  color: var(--cream2);
  margin-bottom: 4px;
}
.gi-sub {
  font-size: 9px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--gold);
  opacity: 0.7;
  margin-bottom: 12px;
}
.gi-desc {
  font-size: 11px;
  color: var(--cream-muted);
  line-height: 1.9;
  margin-bottom: 18px;
}

/* ── VIP HOSTS ── */
.vip {
  background: var(--dark3);
  border-top: 0.5px solid var(--gold-line);
  padding: 60px 52px;
}
.vip-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.5px;
  background: var(--gold-line);
  margin-top: 36px;
}
.vc {
  background: linear-gradient(165deg, #0f0e0c 0%, #141311 100%);
  padding: 30px 26px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.vc-avatar {
  width: 50px;
  height: 50px;
  border: 0.5px solid var(--gold-line);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--serif);
  font-size: 17px;
  color: var(--gold);
}
.vc-name {
  font-family: var(--serif);
  font-size: 19px;
  font-weight: 300;
  color: var(--cream2);
}
.vc-role {
  font-size: 9px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--gold);
  opacity: 0.65;
}
.vc-contacts {
  display: flex;
  flex-direction: column;
  gap: 7px;
  margin-top: 4px;
}
.vc-contact {
  font-size: 11px;
  color: var(--cream-muted);
  display: flex;
  align-items: center;
  gap: 9px;
  transition: color 0.2s;
}
.vc-contact:hover { color: var(--gold); }
.vc-icon {
  width: 20px;
  height: 20px;
  border: 0.5px solid var(--gold-line);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 9px;
  color: var(--gold);
  flex-shrink: 0;
}

/* ── APP BANNER ── */
.app-banner {
  background:
    radial-gradient(700px 240px at 86% 18%, rgba(59, 41, 95, 0.22) 0%, transparent 62%),
    linear-gradient(170deg, #0f0e0c 0%, #141210 100%);
  border-top: 0.5px solid var(--gold-line);
  border-bottom: 0.5px solid var(--gold-line);
  padding: 56px 52px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 48px;
  align-items: center;
}
.app-eye {
  font-size: 9px;
  letter-spacing: 5px;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 10px;
}
.app-title {
  font-family: var(--serif);
  font-size: 40px;
  font-weight: 300;
  color: var(--cream2);
  margin-bottom: 12px;
  line-height: 1.1;
}
.app-body {
  font-size: 13px;
  color: var(--cream-muted);
  line-height: 2.1;
  max-width: 420px;
  margin-bottom: 26px;
}
.app-stores { display: flex; gap: 10px; }
.store {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 11px 18px;
  border: 0.5px solid var(--gold-line);
  cursor: pointer;
  transition: border-color 0.2s;
}
.store:hover { border-color: var(--gold); }
.store-sub {
  font-size: 8px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--cream-muted);
  display: block;
}
.store-name {
  font-size: 12px;
  color: var(--cream2);
  font-weight: 500;
  display: block;
}
.app-mockup {
  background: var(--dark3);
  border: 0.5px solid var(--gold-line);
  border-radius: 14px;
  padding: 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  width: 120px;
  flex-shrink: 0;
  text-align: center;
}
.am-title {
  font-size: 8px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--gold);
}
.am-pts {
  font-family: var(--serif);
  font-size: 32px;
  color: var(--gold);
}
.am-sub {
  font-size: 9px;
  color: var(--cream-muted);
}
.am-track {
  width: 100%;
  height: 3px;
  background: var(--dark2);
  border-radius: 2px;
}
.am-fill {
  width: 62%;
  height: 3px;
  background: var(--gold);
  border-radius: 2px;
}
.am-tier {
  font-size: 8px;
  letter-spacing: 1px;
  color: var(--cream-muted);
}
.am-promo {
  width: 100%;
  background: var(--gold);
  padding: 6px 8px;
  font-size: 8px;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--dark);
  font-weight: 500;
}

/* ── GOLD STRIP ── */
.gold-strip {
  background: linear-gradient(100deg, var(--gold2) 0%, var(--gold) 50%, #bf8f41 100%);
  padding: 22px 52px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.gs-text {
  font-family: var(--serif);
  font-size: 22px;
  font-weight: 300;
  color: var(--dark);
}
.gs-text em { font-style: italic; }
.gs-cta {
  font-size: 10px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--cream2);
  background: rgba(0, 0, 0, 0.28);
  border: 1px solid rgba(0,0,0,0.3);
  padding: 10px 24px;
  cursor: pointer;
  font-family: var(--sans);
  font-weight: 500;
  transition: background 0.25s, transform 0.25s;
}
.gs-cta:hover {
  background: rgba(0, 0, 0, 0.42);
  transform: translateY(-2px);
}

/* ── FOOTER ── */
.footer {
  background: linear-gradient(180deg, #0b0a09 0%, #070706 100%);
  border-top: 1px solid var(--gold);
}

/* Barra Síguenos */
.footer-follow {
  display: flex;
  align-items: center;
  gap: 20px;
  padding: 18px 52px;
  border-bottom: 0.5px solid var(--gold-line);
  justify-content: flex-end;
}
.footer-follow-lbl {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--gold);
}
.f-social { display: flex; gap: 10px; }
.f-soc {
  width: 34px;
  height: 34px;
  border: 1px solid var(--gold-line);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 600;
  color: var(--cream-muted);
  cursor: pointer;
  transition: border-color 0.2s, color 0.2s, background 0.2s;
}
.f-soc:hover {
  border-color: var(--gold);
  color: var(--gold);
  background: rgba(201,168,76,0.08);
}

/* Columnas principales */
.footer-top {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr 1fr 1fr;
  gap: 40px;
  padding: 52px 52px 44px;
  border-bottom: 0.5px solid var(--gold-line);
}
.footer-brand-col {}
.footer-logo-wrap {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 14px;
}
.f-ring {
  width: 42px;
  height: 42px;
  border: 1px solid var(--gold);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--serif);
  font-size: 20px;
  color: var(--gold);
  font-weight: 300;
  flex-shrink: 0;
}
.f-brand {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: var(--gold);
  line-height: 1.5;
}
.f-tagline {
  font-size: 12px;
  color: var(--cream-muted);
  line-height: 1.9;
  margin-bottom: 20px;
}
.f-contact-block {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.f-phone {
  font-family: var(--serif);
  font-size: 20px;
  color: var(--gold);
  letter-spacing: 0.5px;
}
.f-address {
  font-size: 12px;
  color: var(--cream-muted);
  line-height: 1.8;
  margin-bottom: 6px;
}
.f-dir-link {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 1px;
  color: var(--gold);
  text-transform: uppercase;
  transition: color 0.2s;
}
.f-dir-link:hover { color: var(--gold2); }

/* Columnas de links */
.f-col-title {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--cream2);
  margin-bottom: 18px;
}
.f-links {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 11px;
}
.f-links a {
  font-size: 13px;
  color: var(--cream-muted);
  transition: color 0.2s;
}
.f-links a:hover { color: var(--gold); }

/* Bloques informativos */
.footer-blocks {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.5px;
  background: var(--gold-line);
  border-bottom: 0.5px solid var(--gold-line);
}
.f-block {
  background: #0d0c0a;
  padding: 32px 40px;
}
.f-block-title {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--cream2);
  margin-bottom: 12px;
}
.f-block-body {
  font-size: 12px;
  color: var(--cream-muted);
  line-height: 1.95;
  margin-bottom: 14px;
}
.f-block-link {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--gold);
  transition: color 0.2s;
}
.f-block-link:hover { color: var(--gold2); }

/* Barra copyright */
.footer-bot {
  padding: 20px 52px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
}
.f-copy {
  font-size: 11px;
  color: var(--cream-muted);
  opacity: 0.45;
}
.f-legal { display: flex; gap: 20px; }
.f-legal a {
  font-size: 11px;
  color: var(--cream-muted);
  opacity: 0.45;
  transition: opacity 0.2s;
}
.f-legal a:hover { opacity: 0.8; }

/* Responsive footer */
@media (max-width: 1024px) {
  .footer-follow { padding: 16px 28px; }
  .footer-top    { grid-template-columns: 1fr 1fr 1fr; gap: 32px; padding: 40px 28px 36px; }
  .footer-blocks { grid-template-columns: 1fr; }
  .footer-bot    { padding: 18px 28px; flex-direction: column; align-items: flex-start; }
}
@media (max-width: 768px) {
  .footer-follow { padding: 14px 20px; }
  .footer-top    { grid-template-columns: 1fr 1fr; gap: 28px; padding: 32px 20px; }
  .footer-bot    { padding: 16px 20px; }
  .f-block       { padding: 24px 20px; }
}

/* ============================================================
   NAV SOCIAL ICONS
   ============================================================ */
.nav-social { display: flex; gap: 6px; align-items: center; }
.nav-soc {
  width: 26px;
  height: 26px;
  border: 0.5px solid var(--gold-line);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  color: var(--cream-muted);
  transition: border-color 0.2s, color 0.2s, background 0.2s;
}
.nav-soc:hover { border-color: var(--gold); color: var(--gold); }
.nav-soc:hover { background: var(--gold-dim); }

/* ============================================================
   CAROUSEL DE PROMOCIONES
   ============================================================ */
.promos-carousel { margin: 0 52px; }
.carousel-track-wrap { overflow: hidden; }
.carousel-track {
  display: flex;
  transition: transform 0.45s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  background: var(--gold-line);
  gap: 0.5px;
}
.promos-carousel .pc {
  flex: 0 0 calc(33.333% - 0.34px);
  min-width: 0;
}

.carousel-controls {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 18px;
  padding: 22px 0 4px;
}
.carousel-btn {
  width: 36px;
  height: 36px;
  border: 0.5px solid var(--gold-line);
  background: transparent;
  color: var(--gold);
  font-size: 16px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: border-color 0.2s, background 0.2s;
  font-family: var(--serif);
  line-height: 1;
}
.carousel-btn:hover:not(:disabled) {
  border-color: var(--gold);
  background: var(--gold-dim);
}
.carousel-btn:disabled { opacity: 0.2; cursor: not-allowed; }

.carousel-dots { display: flex; gap: 8px; align-items: center; }
.carousel-dot {
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--gold-line);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background 0.25s, width 0.25s, border-radius 0.25s;
}
.carousel-dot.active {
  background: var(--gold);
  width: 18px;
  border-radius: 2px;
}

/* ============================================================
   ALIADOS / PARTNERS
   ============================================================ */
.partners {
  border-top: 0.5px solid var(--gold-line);
  border-bottom: 0.5px solid var(--gold-line);
  padding: 22px 52px;
  background: var(--dark2);
  display: flex;
  align-items: center;
  gap: 36px;
}
.partners-label {
  font-size: 8px;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--gold);
  opacity: 0.45;
  white-space: nowrap;
  flex-shrink: 0;
}
.partners-logos {
  display: flex;
  align-items: center;
  gap: 28px;
  flex-wrap: wrap;
}
.partner-item { display: flex; flex-direction: column; gap: 2px; }
.partner-name {
  font-family: var(--serif);
  font-size: 15px;
  font-weight: 300;
  color: var(--cream-muted);
  letter-spacing: 2px;
}
.partner-sub {
  font-size: 8px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--cream-muted);
  opacity: 0.4;
}
.partner-divider {
  width: 0.5px;
  height: 28px;
  background: var(--gold-line);
  flex-shrink: 0;
}

/* ============================================================
   NAV BURGER
   ============================================================ */
.nav-burger {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px;
  width: 32px;
  height: 32px;
  flex-shrink: 0;
}
.burger-line {
  display: block;
  width: 22px;
  height: 1px;
  background: var(--gold);
  transition: transform 0.25s, opacity 0.25s;
}
.nav.menu-open .burger-line:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.nav.menu-open .burger-line:nth-child(2) { opacity: 0; transform: scaleX(0); }
.nav.menu-open .burger-line:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

/* ============================================================
   DESKTOP READABILITY PASS (≥ 1200px)
   ============================================================ */
@media (min-width: 1200px) {
  .nav-links a { font-size: 12px; letter-spacing: 2.4px; }
  .btn-login { font-size: 10px; padding: 10px 24px; }

  .ticker { padding: 11px 52px; }
  .t-label { font-size: 10px; }
  .t-item { font-size: 12px; color: #e7decd; }
  .t-amount { font-size: 26px; }
  .t-game { font-size: 13px; }

  .hero-eyebrow { font-size: 10px; }
  .hero-h1 { font-size: 92px; line-height: 0.98; }
  .hero-body {
    font-size: 17px;
    line-height: 1.9;
    max-width: 470px;
    color: #d4cab9;
  }

  .btn-gold,
  .btn-outline { font-size: 11px; padding: 16px 34px; }

  .sh-eye,
  .cd-lbl,
  .cd-cta,
  .link-gold,
  .gc-link,
  .tier-link { font-size: 10px; }

  .cd-name { font-size: 28px; }
  .cd-n { font-size: 28px; }
  .cd-s { font-size: 9px; }

  .pb-body,
  .u-body,
  .ev-meta,
  .gc-desc,
  .pc-desc,
  .gi-desc,
  .app-body { font-size: 13px; line-height: 1.95; }

  .ev-sm-meta,
  .wc-time,
  .vc-contact,
  .f-links a,
  .f-info p { font-size: 12px; }

  .wc-time { opacity: 0.7; }
}

/* ============================================================
   RESPONSIVE — TABLET (≤ 1024px)
   ============================================================ */
@media (max-width: 1024px) {
  .nav              { padding: 16px 28px; }
  .nav-links        { gap: 16px; }
  .ticker           { padding: 9px 28px; }

  .sh               { padding: 48px 28px 28px; }

  .hero-left        { padding: 48px 28px; }
  .hero-h1          { font-size: 58px; }

  .countdown        { padding: 16px 28px; flex-wrap: wrap; gap: 14px; }
  .cd-unit          { min-width: 58px; }
  .cd-n             { font-size: 28px; }

  .gaming-grid      { grid-template-columns: repeat(2, 1fr); margin: 0 28px; }

  .pb-inner         { grid-template-columns: 1fr; min-height: auto; }
  .pb-left          { padding: 48px 28px; }
  .pb-right         { min-height: 360px; }

  .winners          { padding: 48px 28px; }
  .w-grid           { grid-template-columns: repeat(2, 1fr); }

  .ev-grid          { margin: 0 28px; }

  .unique-wrap      { padding: 48px 28px; }
  .unique-gold-bar  { padding: 0 28px; margin: 0 -28px; }
  .unique-intro     { grid-template-columns: 1fr; gap: 24px; }
  .tiers            { grid-template-columns: repeat(3, 1fr); }

  .promos-carousel  { margin: 0 28px; }
  .promos-carousel .pc { flex: 0 0 calc(50% - 0.25px); }

  .gastro           { padding: 48px 28px; }
  .gastro-grid      { grid-template-columns: repeat(2, 1fr); }

  .vip              { padding: 48px 28px; }
  .vip-grid         { grid-template-columns: repeat(2, 1fr); }

  .app-banner       { padding: 48px 28px; }

  .gold-strip       { padding: 20px 28px; }

  .footer           { padding: 48px 28px 20px; }
  .footer-top       { grid-template-columns: 1fr 1fr; gap: 32px; }
}

/* ============================================================
   RESPONSIVE — HERO OVERLAY (≤ 1100px)
   Cuando la pantalla no tiene suficiente ancho para texto + video
   lado a lado, el video pasa a ser fondo y el texto se monta encima.
   ============================================================ */
@media (max-width: 1100px) {
  /* Cambia a block para que hero-left fluya al 100% del ancho */
  .hero {
    display: block !important;
    position: relative;
  }

  /* Video pasa a fondo absoluto detrás del texto */
  .hero-right {
    position: absolute !important;
    inset: 0 !important;
    width: 100% !important;
    height: 100% !important;
    z-index: 0;
  }

  /* Texto ocupa todo el ancho y se monta sobre el video */
  .hero-left {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    position: relative !important;
    z-index: 1;
    overflow: visible !important;   /* el texto nunca se trunca */
    padding-bottom: 52px;
    background:
      radial-gradient(560px 240px at 8% 8%, #7b1f3b55 0%, transparent 75%),
      linear-gradient(to right, rgba(7,7,6,0.96) 0%, rgba(7,7,6,0.90) 45%, rgba(7,7,6,0.65) 75%, transparent 100%);
  }

  /* h1 fluido: nunca más grande que la pantalla permite */
  .hero-h1 {
    font-size: clamp(36px, 6vw, 68px) !important;
    white-space: normal;
    overflow-wrap: break-word;
  }
}

/* ============================================================
   RESPONSIVE — MOBILE (≤ 768px)
   ============================================================ */
@media (max-width: 768px) {
  /* ── Nav ── */
  .nav              { padding: 14px 20px; }
  .nav-links        { display: none; }
  .nav-right        { display: none; }
  .nav-burger       { display: flex; }

  /* Mobile menu open — full-screen overlay */
  .nav.menu-open .nav-links {
    display: flex;
    flex-direction: column;
    position: fixed;
    top: 99px;
    left: 0;
    right: 0;
    bottom: 0;
    background: var(--dark);
    border-top: 0.5px solid var(--gold-line);
    padding: 32px 20px;
    gap: 0;
    z-index: 99;
    overflow-y: auto;
  }
  .nav.menu-open .nav-links a {
    font-size: 13px;
    letter-spacing: 3px;
    padding: 18px 0;
    border-bottom: 0.5px solid var(--gold-line);
    color: var(--cream-muted);
  }
  .nav.menu-open .nav-links a:last-child { border-bottom: none; }

  /* ── Ticker ── */
  .ticker           { padding: 9px 20px; }
  .t-label,
  .t-divider        { display: none; }
  .t-scroll         { gap: 24px; }
  .t-item           { gap: 6px; }
  .t-item::after    { letter-spacing: 1px; margin-left: 6px; }
  .t-amount         { font-size: 20px; }
  .t-game           { font-size: 11px; }
  .t-datetime       { display: none; }

  /* ── Hero ── */
  .hero-left        { padding: 48px 20px 40px; }
  .hero-h1          { font-size: 46px; }
  .hero-float-top   { top: 14px; left: 14px; }
  .hero-badge       { bottom: 14px; right: 14px; }

  /* ── Countdown ── */
  .countdown        { padding: 16px 20px; flex-direction: column; align-items: flex-start; gap: 14px; }
  .cd-name          { display: none; }

  /* ── Sections ── */
  .sh               { padding: 40px 20px 22px; }
  .sh-title         { font-size: 34px; }

  /* ── Gaming ── */
  .gaming-grid      { grid-template-columns: 1fr; margin: 0 20px; }

  /* ── Photo break ── */
  .pb-left          { padding: 40px 20px; }
  .pb-right         { grid-template-columns: 1fr; grid-template-rows: auto; height: 400px; }
  .pb-span2         { grid-column: span 1; }

  /* ── Winners ── */
  .winners          { padding: 40px 20px; }
  .w-head           { flex-direction: column; align-items: flex-start; gap: 14px; }
  .w-grid           { grid-template-columns: repeat(2, 1fr); }

  /* ── Eventos ── */
  .ev-grid          { margin: 0 20px; grid-template-columns: 1fr; }
  .ev-stack         { flex-direction: column; }

  /* ── Unique Club ── */
  .unique-wrap      { padding: 40px 20px; }
  .unique-gold-bar  { padding: 10px 20px; margin: 0 -20px; flex-direction: column; align-items: flex-start; gap: 4px; }
  .tiers            { grid-template-columns: repeat(2, 1fr); }

  /* ── Nav social ── */
  .nav-social       { display: none; }

  /* ── Week ticker ── */
  .week-ticker      { padding: 11px 20px; }
  .wt-label         { display: none; }
  .wt-divider       { display: none; }
  .wt-cta           { display: none; }

  /* ── Promociones carousel ── */
  .promos-carousel  { margin: 0 20px; }
  .promos-carousel .pc { flex: 0 0 100%; }

  /* ── Partners ── */
  .partners         { padding: 20px; flex-direction: column; align-items: flex-start; gap: 14px; }
  .partner-divider  { display: none; }

  /* ── Gastronomía ── */
  .gastro           { padding: 40px 20px; }
  .gastro-grid      { grid-template-columns: 1fr; }

  /* ── VIP ── */
  .vip              { padding: 40px 20px; }
  .vip-grid         { grid-template-columns: 1fr; }

  /* ── App Banner ── */
  .app-banner       { padding: 40px 20px; grid-template-columns: 1fr; gap: 28px; }
  .app-mockup       { width: 100%; max-width: 180px; margin: 0 auto; }

  /* ── Gold Strip ── */
  .gold-strip       { padding: 22px 20px; flex-direction: column; gap: 16px; text-align: center; }
  .gs-text          { font-size: 19px; }

  /* ── Footer ── */
  .footer           { padding: 40px 20px 20px; }
  .footer-top       { grid-template-columns: 1fr; gap: 28px; }
  .footer-bot       { flex-direction: column; gap: 10px; text-align: center; }
}

/* ============================================================
   RESPONSIVE — SMALL MOBILE (≤ 480px)
   ============================================================ */
@media (max-width: 480px) {
  .t-copy           { display: none; }
  .t-amount         { font-size: 18px; }

  .hero-h1          { font-size: 38px; }
  .hero-stats       { grid-template-columns: 1fr 1fr; }

  .cd-unit          { min-width: 44px; padding: 7px 9px; }
  .cd-n             { font-size: 20px; }
  .cd-sep           { font-size: 14px; }

  .w-grid           { grid-template-columns: 1fr; }

  .tiers            { grid-template-columns: 1fr; }

  .app-stores       { flex-direction: column; }
}

/* ============================================================
   SECTION HEADING VARIANTS
   ============================================================ */
.sh--eventos {
  padding-bottom: 16px;
}
.sh-title--lg {
  font-size: 64px !important;
  letter-spacing: -1px;
}

/* ============================================================
   UNIQUE CLUB — TITLE OVERRIDE
   ============================================================ */
.unique-title {
  font-size: 72px !important;
  line-height: 0.95;
  margin-bottom: 4px;
}
.unique-logo-placeholder {
  height: 72px;
  width: 240px;
  border: 1px dashed rgba(212,175,80,0.35);
  border-radius: 3px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: rgba(212,175,80,0.4);
  margin-bottom: 8px;
}
.unique-logo-img {
  height: 72px;
  width: auto;
  object-fit: contain;
  margin-bottom: 8px;
}
.unique-logo-hidden { display: none; }
.unique-sub-title {
  font-size: 18px;
  letter-spacing: 6px;
  text-transform: uppercase;
  font-style: normal;
  color: var(--cream-muted);
  font-family: var(--sans);
  font-weight: 300;
}

/* ============================================================
   SECTION SEPARATOR
   ============================================================ */
.section-sep {
  display: flex;
  align-items: center;
  padding: 0 52px;
  height: 44px;
  background: var(--dark2);
  border-top: 0.5px solid var(--gold-line);
  border-bottom: 0.5px solid var(--gold-line);
  gap: 0;
}
.section-sep::before,
.section-sep::after {
  content: '';
  flex: 1;
  height: 0.5px;
  background: var(--gold-line);
}
.section-sep-text {
  font-size: 8px;
  letter-spacing: 8px;
  text-transform: uppercase;
  color: var(--cream-muted);
  opacity: 0.35;
  padding: 0 28px;
  white-space: nowrap;
}

/* ============================================================
   EVENTS 2×2 GRID
   ============================================================ */
.ev-grid2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 280px 280px;
  gap: 0.5px;
  background: var(--gold-line);
  margin: 0 52px;
}
.ev-card2 {
  position: relative;
  overflow: hidden;
  cursor: pointer;
  background: var(--dark3);
}
.ev-card2 img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(0.35) saturate(0.55);
  transition: filter 0.45s, transform 0.5s;
}
.ev-card2:hover img {
  filter: brightness(0.48) saturate(0.7);
  transform: scale(1.03);
}
.ev-card2-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(5,5,4,0.96) 0%, rgba(5,5,4,0.35) 55%, transparent 100%);
  pointer-events: none;
}
.ev-card2--main .ev-card2-overlay {
  background:
    linear-gradient(to top, rgba(5,5,4,0.97) 0%, rgba(5,20,55,0.45) 50%, transparent 100%);
}
.ev-card2-content {
  position: relative;
  z-index: 2;
  padding: 28px 32px;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}
.ev-tag2 {
  font-size: 8px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 10px;
  opacity: 0.85;
}
.ev-title2 {
  font-family: var(--serif);
  font-size: 30px;
  font-weight: 300;
  color: var(--cream2);
  margin-bottom: 10px;
  line-height: 1.15;
}
.ev-desc2 {
  font-size: 12px;
  color: var(--cream-muted);
  line-height: 1.85;
  margin-bottom: 18px;
  max-width: 340px;
}
.btn-ev {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: rgba(59, 41, 95, 0.82);
  border: 2.5px solid var(--gold);
  cursor: pointer;
  transition: background 0.22s, border-color 0.22s, transform 0.22s;
  flex-shrink: 0;
  position: relative;
}
.btn-ev::after {
  content: '';
  display: block;
  width: 13px;
  height: 13px;
  border-right: 2.5px solid var(--gold);
  border-top: 2.5px solid var(--gold);
  transform: rotate(45deg) translate(-2px, 2px);
  transition: border-color 0.22s;
}
.btn-ev:hover {
  background: rgba(59, 41, 95, 1);
  border-color: var(--gold2);
  transform: scale(1.1);
}
.btn-ev:hover::after {
  border-color: var(--gold2);
}

/* ============================================================
   UNIQUE CLUB — CTA BUTTON BELOW TIERS
   ============================================================ */
.unique-cta-wrap {
  display: flex;
  justify-content: center;
  padding: 32px 0 4px;
}

/* ============================================================
   PROMOCIONES — 2-COLUMN LAYOUT
   ============================================================ */
/* (background definido en la sección de fondos por sección arriba) */
.promos-layout {
  display: grid;
  grid-template-columns: 300px 1fr;
  align-items: start;
  padding: 60px 52px;
  gap: 0;
}
.promos-text-col {
  padding-right: 52px;
  padding-top: 8px;
}
.promos-text-col .sh-eye { margin-bottom: 10px; }
.promos-text-col .sh-title { margin-bottom: 14px; }
.promos-body {
  font-size: 13px;
  color: var(--cream-muted);
  line-height: 2.0;
  max-width: 260px;
}
.promos-carousel-col { overflow: hidden; }
.promos-carousel-col .promos-carousel { margin: 0; }

/* ============================================================
   GASTRONOMÍA — CENTER-FEATURED 3-COLUMN
   ============================================================ */
.gastro-section {
  border-top: 0.5px solid var(--gold-line);
}
.gastro-layout {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 0.5px;
  background: var(--gold-line);
  margin: 0 52px;
}
.gi-outer {
  background: linear-gradient(165deg, #0f0e0c 0%, #141311 100%);
  display: flex;
  flex-direction: column;
}
.gi-card-top {
  flex: 1;
  display: flex;
  flex-direction: column;
}
.gi-photo2 {
  height: 220px;
  overflow: hidden;
  flex-shrink: 0;
}
.gi-photo2 img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(0.48) saturate(0.65);
  transition: filter 0.35s;
}
.gi-outer:hover .gi-photo2 img { filter: brightness(0.62) saturate(0.78); }
.gi-card-footer {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px 20px 20px;
}
.gi-card-label2 {
  font-family: var(--serif);
  font-size: 30px;
  font-weight: 300;
  color: var(--cream2);
  line-height: 1;
}
.gastro-center-col {
  background: linear-gradient(165deg, #0f0e0c 0%, #141311 100%);
  display: flex;
  flex-direction: column;
  padding: 40px 32px 0;
}
.gastro-center-header {
  margin-bottom: 28px;
}
.gastro-center-title {
  font-family: var(--serif);
  font-size: 52px;
  font-weight: 600;
  color: var(--cream2);
  margin-bottom: 8px;
  line-height: 1.1;
}
.gastro-center-sub {
  font-size: 16px;
  color: var(--cream-muted);
  line-height: 1.7;
}
.gi-buffet-card {
  margin: 0 -32px;
  flex: 1;
}
.gi-buffet-card .gi-photo2 { height: 160px; }

/* ============================================================
   DESCUBRE — 360° TOURS + PARTNERS
   ============================================================ */
.descubre {
  border-top: 0.5px solid var(--gold-line);
  padding: 60px 52px;
}
.descubre-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 36px;
}
.descubre-eyebrow {
  font-family: var(--serif);
  font-size: 58px;
  font-weight: 300;
  color: #1a1810;
  line-height: 1;
}
.descubre-name {
  font-size: 8px;
  letter-spacing: 8px;
  text-transform: uppercase;
  color: #6b2fa0;
  opacity: 0.85;
  margin-top: 6px;
}
.descubre-chip {
  width: 84px;
  height: 84px;
  border-radius: 50%;
  border: 3px solid var(--gold);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--serif);
  font-size: 22px;
  color: var(--gold);
  font-weight: 400;
  background: radial-gradient(circle, rgba(201,168,76,0.08) 0%, transparent 70%);
  box-shadow: 0 0 22px rgba(201,168,76,0.18);
  flex-shrink: 0;
}
.tour-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 0.5px;
  background: var(--gold-line);
  margin-bottom: 0.5px;
}
.tour-card {
  position: relative;
  overflow: hidden;
  min-height: 300px;
  cursor: pointer;
  background: var(--dark);
}
.tour-card img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(0.38) saturate(0.6);
  transition: filter 0.45s, transform 0.5s;
}
.tour-card:hover img {
  filter: brightness(0.5) saturate(0.72);
  transform: scale(1.03);
}
.tour-card-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(7,7,6,0.94) 0%, rgba(7,7,6,0.38) 58%, transparent 100%);
  pointer-events: none;
}
.tour-card-content {
  position: relative;
  z-index: 2;
  padding: 28px 36px;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}
.tour-card-label {
  font-family: var(--serif);
  font-size: 30px;
  font-weight: 300;
  color: var(--cream2);
  margin-bottom: 16px;
}
.btn-360 {
  display: inline-block;
  font-size: 8px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--cream2);
  background: transparent;
  border: 0.5px solid rgba(237,232,220,0.3);
  padding: 10px 18px;
  cursor: pointer;
  font-family: var(--sans);
  transition: border-color 0.2s, background 0.2s;
  width: fit-content;
}
.btn-360:hover { border-color: var(--gold); color: var(--gold); background: var(--gold-dim); }
.partners-section {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.5px;
  background: var(--gold-line);
  border-top: 1px solid var(--gold);
  border-bottom: 1px solid var(--gold);
}
.partner-card {
  padding: 32px 40px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  transition: opacity 0.2s;
}
.partner-card:hover { opacity: 0.88; }
.partner-card--506 {
  background: linear-gradient(135deg, #2a1a5a 0%, #1a0f38 100%);
}
.partner-card--sheraton {
  background: linear-gradient(135deg, #1e1a08 0%, #141206 100%);
  border-left: 0.5px solid var(--gold-line);
}
.partner-card-logo {
  font-family: var(--sans);
  font-size: 13px;
  letter-spacing: 4px;
  font-weight: 600;
  color: var(--cream-muted);
  text-transform: uppercase;
  line-height: 1.4;
}
.partner-card-num {
  font-family: var(--serif);
  font-size: 42px;
  color: var(--gold);
  font-weight: 400;
  letter-spacing: -1px;
  display: block;
  line-height: 1;
}
.partner-card-sub {
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--cream-muted);
  opacity: 0.55;
  margin-top: 4px;
}

/* ============================================================
   FOOTER — SIMPLIFIED
   ============================================================ */
.footer-main {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 48px;
  margin-bottom: 40px;
}
.footer-left {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.footer-logo-wrap {
  display: flex;
  align-items: center;
  gap: 12px;
}
.f-contact {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.f-contact-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-size: 12px;
  color: var(--cream-muted);
  line-height: 1.85;
}
.f-contact-icon {
  color: var(--gold);
  font-size: 12px;
  flex-shrink: 0;
  margin-top: 2px;
  opacity: 0.8;
}

/* ============================================================
   RESPONSIVE ADDITIONS — new sections
   ============================================================ */
@media (max-width: 1024px) {
  .ev-grid2         { margin: 0 28px; grid-template-rows: 240px 240px; }
  .promos-layout    { padding: 48px 28px; grid-template-columns: 260px 1fr; }
  .gastro-layout    { margin: 0 28px; grid-template-columns: 1fr 1fr 1fr; }
  .gastro-center-col { padding: 28px 20px 0; }
  .descubre         { padding: 48px 28px; }
  .partners-section { grid-template-columns: 1fr; }
  .partner-card--sheraton { border-left: none; border-top: 0.5px solid var(--gold-line); }
}

@media (max-width: 768px) {
  .section-sep      { padding: 0 20px; }
  .ev-grid2         { margin: 0 20px; grid-template-columns: 1fr; grid-template-rows: repeat(4, 220px); }
  .promos-layout    { padding: 40px 20px; grid-template-columns: 1fr; }
  .promos-text-col  { padding-right: 0; padding-bottom: 24px; }
  .promos-carousel-col .promos-carousel { margin: 0; }
  .gastro-layout    { margin: 0 20px; grid-template-columns: 1fr; }
  .descubre         { padding: 40px 20px; }
  .descubre-eyebrow { font-size: 42px; }
  .tour-grid        { grid-template-columns: 1fr; }
  .partners-section { grid-template-columns: 1fr; }
  .partner-card     { padding: 24px 20px; }
  .footer-main      { flex-direction: column; gap: 28px; }
}
