:root{
  --bg:#070707;
  --panel:#0d0d0d;
  --text:#f2f2f2;
  --muted:rgba(255,255,255,.72);
  --muted2:rgba(255,255,255,.55);
  --gold:#c9a24a;           /* dorado Dino */
  --gold2:#f3d37a;          /* brillo */
  --stroke:rgba(255,255,255,.10);
  --shadow: 0 18px 60px rgba(0,0,0,.55);
  --radius:18px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

/* HEADER */
.topbar{
  position:sticky;
  top:0;
  z-index:50;
  backdrop-filter: blur(8px);
  background:rgba(0,0,0,.55);
  border-bottom:1px solid rgba(255,255,255,.06);
}

.topbar__inner{
  height:74px;
  max-width:1200px;
  margin:0 auto;
  padding:0 18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
}

.btn-outline{
  color:var(--text);
  text-decoration:none;
  border:1px solid rgba(255,255,255,.35);
  padding:10px 14px;
  font-weight:700;
  letter-spacing:.06em;
  font-size:12px;
  border-radius:12px;
  transition:.2s ease;
}
.btn-outline:hover{
  border-color:var(--gold);
  color:var(--gold2);
  transform:translateY(-1px);
}

.brand{
  display:flex;
  align-items:center;
  gap:12px;
  min-width:240px;
  justify-content:center;
}
.brand__logo{
  width:44px;
  height:44px;
  object-fit:cover;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.10);
  box-shadow: 0 10px 30px rgba(0,0,0,.35);
}
.brand__text{line-height:1}
.brand__name{
  font-weight:800;
  letter-spacing:.12em;
  font-size:12px;
  color:var(--gold2);
}
.brand__sub{
  margin-top:6px;
  font-size:11px;
  letter-spacing:.08em;
  color:rgba(255,255,255,.62);
}

.topbar__right{
  display:flex;
  align-items:center;
  gap:10px;
}

.lang{
  background:transparent;
  border:none;
  color:rgba(255,255,255,.85);
  font-weight:700;
  letter-spacing:.08em;
  cursor:pointer;
  padding:8px 6px;
}
.lang:hover{color:var(--gold2)}
.lang-sep{color:rgba(255,255,255,.35)}

.icon-btn{
  width:40px;
  height:40px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(0,0,0,.25);
  display:grid;
  place-items:center;
  cursor:pointer;
  transition:.2s ease;
  color:#fff;
  text-decoration:none;
}
.icon-btn:hover{
  border-color:rgba(201,162,74,.6);
  transform:translateY(-1px);
}
.icon-btn svg{
  width:18px;
  height:18px;
  fill:rgba(255,255,255,.9);
}
.icon-btn svg path[stroke-width]{
  stroke:rgba(255,255,255,.9);
  fill:none;
}

.mobile-menu{
  display:none;
  max-width:1200px;
  margin:0 auto;
  padding:0 18px 14px;
}
.mobile-menu a{
  display:block;
  text-decoration:none;
  color:rgba(255,255,255,.85);
  padding:10px 12px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(0,0,0,.28);
  border-radius:12px;
  margin-top:10px;
}
.mobile-menu a:hover{border-color:rgba(201,162,74,.5); color:var(--gold2)}

/* HERO */
.hero{
  position:relative;
  min-height:460px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  overflow:hidden;
  border-bottom:1px solid rgba(255,255,255,.06);

  /* Cambia esta imagen por la tuya (hero) */
  background:
    radial-gradient(70% 120% at 50% 0%, rgba(201,162,74,.15), transparent 55%),
    linear-gradient(180deg, rgba(0,0,0,.35), rgba(0,0,0,.92)),
    url("./assets/hero.jpg") center/cover no-repeat;
}

.hero__overlay{
  position:absolute; inset:0;
  background:
    radial-gradient(1200px 500px at 50% 0%, rgba(0,0,0,.20), rgba(0,0,0,.88) 70%),
    linear-gradient(180deg, rgba(0,0,0,.15), rgba(0,0,0,.92));
}

.hero__content{
  position:relative;
  padding:90px 18px 80px;
  max-width:1100px;
}

.hero__title{
  margin:0;
  font-family:"Bebas Neue", Inter, sans-serif;
  font-weight:400;
  letter-spacing:.04em;
  font-size:92px;
  line-height:.92;
  text-transform:uppercase;
  text-shadow: 0 20px 80px rgba(0,0,0,.75);
}
.hero__divider{
  width:120px;
  height:3px;
  background:linear-gradient(90deg, transparent, var(--gold2), transparent);
  margin:22px auto 18px;
  border-radius:999px;
}
.hero__subtitle{
  margin:0;
  font-family:"Bebas Neue", Inter, sans-serif;
  font-size:44px;
  letter-spacing:.06em;
  color:rgba(255,255,255,.92);
  text-transform:uppercase;
  text-shadow: 0 16px 70px rgba(0,0,0,.8);
}

/* LAYOUT */
.wrap{
  max-width:1200px;
  margin:0 auto;
  padding:34px 18px 60px;
}

.section{padding:24px 0}
.section__head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
  margin-bottom:18px;
}
.section__title{
  margin:0;
  font-size:22px;
  letter-spacing:.02em;
}
.section__desc{
  margin:0;
  color:var(--muted2);
  max-width:560px;
}

/* GRID CARDS */
.grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap:18px;
}

.card{
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.015));
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow: var(--shadow);
}

.card__media{
  position:relative;
  aspect-ratio: 4 / 3;
  overflow:hidden;
}
.card__media img{
  width:100%;
  height:100%;
  object-fit:cover;
  transform:scale(1.03);
  filter: contrast(1.03) saturate(1.08);
}
.badge{
  position:absolute;
  top:12px;
  left:12px;
  padding:7px 10px;
  border-radius:999px;
  font-size:12px;
  letter-spacing:.12em;
  font-weight:800;
  color:#111;
  background:linear-gradient(90deg, var(--gold), var(--gold2));
  box-shadow: 0 16px 35px rgba(0,0,0,.55);
}

.card__body{padding:14px 14px 16px}
.card__title{
  margin:0;
  font-size:18px;
  letter-spacing:.01em;
}
.card__meta{
  margin-top:8px;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  color:rgba(255,255,255,.68);
  font-size:13px;
}
.card__text{
  margin:10px 0 0;
  color:rgba(255,255,255,.80);
  font-size:14px;
  line-height:1.5;
}

.card__actions{
  margin-top:14px;
  display:flex;
  gap:10px;
}

/* BUTTONS */
.btn-gold{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:10px 14px;
  border-radius:12px;
  text-decoration:none;
  color:#161616;
  font-weight:900;
  letter-spacing:.06em;
  background:linear-gradient(90deg, var(--gold), var(--gold2));
  border:1px solid rgba(0,0,0,.25);
  transition:.2s ease;
}
.btn-gold:hover{transform:translateY(-1px); filter:saturate(1.06)}
.btn-ghost{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 14px;
  border-radius:12px;
  text-decoration:none;
  color:rgba(255,255,255,.88);
  font-weight:800;
  letter-spacing:.06em;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.12);
  transition:.2s ease;
}
.btn-ghost:hover{border-color:rgba(201,162,74,.55); color:var(--gold2)}
.btn-full{width:100%}

/* RESERVE */
.reserve{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:18px;
  border:1px solid rgba(255,255,255,.08);
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
  border-radius:var(--radius);
  padding:18px;
  box-shadow: var(--shadow);
}
.reserve__title{
  margin:0;
  font-size:24px;
}
.reserve__desc{
  margin:10px 0 0;
  color:var(--muted2);
  line-height:1.6;
}
.list{
  margin:14px 0 0;
  padding:0;
  list-style:none;
  color:rgba(255,255,255,.82);
}
.list li{margin:8px 0}

.reserve__form{
  background:rgba(0,0,0,.25);
  border:1px solid rgba(255,255,255,.07);
  border-radius:16px;
  padding:14px;
}
.reserve__form label{
  display:block;
  margin-bottom:12px;
}
.reserve__form span{
  display:block;
  font-size:12px;
  letter-spacing:.08em;
  color:rgba(255,255,255,.72);
  margin-bottom:6px;
}
.reserve__form input,
.reserve__form select{
  width:100%;
  padding:11px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.35);
  color:rgba(255,255,255,.92);
  outline:none;
}
.reserve__form input:focus,
.reserve__form select:focus{
  border-color:rgba(201,162,74,.65);
  box-shadow: 0 0 0 4px rgba(201,162,74,.12);
}
.fineprint{
  margin:10px 0 0;
  font-size:12px;
  color:rgba(255,255,255,.55);
  line-height:1.45;
}

/* FOOTER */
.footerbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:16px 0 0;
  border-top:1px solid rgba(255,255,255,.08);
}
.footerbar__brand{
  font-weight:900;
  letter-spacing:.14em;
  color:var(--gold2);
}
.footerbar__muted{color:rgba(255,255,255,.58); margin-top:6px}
.footerbar__links{
  display:flex; gap:12px; flex-wrap:wrap;
}
.footerbar__links a{
  color:rgba(255,255,255,.78);
  text-decoration:none;
  border:1px solid rgba(255,255,255,.10);
  padding:10px 12px;
  border-radius:12px;
}
.footerbar__links a:hover{border-color:rgba(201,162,74,.55); color:var(--gold2)}

/* RESPONSIVE */
@media (max-width: 980px){
  .grid{grid-template-columns: repeat(2, minmax(0,1fr));}
  .hero__title{font-size:76px}
  .hero__subtitle{font-size:36px}
  .brand{min-width:auto}
}
@media (max-width: 640px){
  .btn-outline{display:none}
  .hero{min-height:420px}
  .hero__content{padding:86px 18px 70px}
  .hero__title{font-size:62px}
  .hero__subtitle{font-size:30px}
  .grid{grid-template-columns: 1fr;}
  .reserve{grid-template-columns: 1fr;}
  .mobile-menu{display:none}
}

/* Clase helper para mostrar menú */
.mobile-menu.is-open{display:block}



/* ===== MODAL (Detalles) ===== */
.modal{position:fixed; inset:0; display:none; z-index:999999;}
.modal.show{display:block;}
.modal__overlay{position:absolute; inset:0; background:rgba(0,0,0,.78); backdrop-filter: blur(8px);}
.modal__box{
  position:relative; z-index:1;
  width:min(1100px, 92vw);
  max-height:88vh; overflow:auto;
  margin:6vh auto 0; padding:22px;
  background:#0d0d0d;
  border:1px solid rgba(255,255,255,.12);
  border-radius:22px;
  box-shadow:0 40px 120px rgba(0,0,0,.85);
}
.modal__close{
  position:absolute; top:14px; right:14px;
  width:40px; height:40px; border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.06);
  color:#fff; font-size:22px; cursor:pointer;
}
.modal__grid{display:grid; grid-template-columns: 0.95fr 1.05fr; gap:16px; align-items:start;}
.modal__flyer{border-radius:16px; overflow:hidden; border:1px solid rgba(255,255,255,.12); background:rgba(0,0,0,.25); box-shadow: 0 18px 60px rgba(0,0,0,.65);}
.modal__flyer img{width:100%; display:block; object-fit:cover; aspect-ratio: 9 / 16;}
.modal__content h2{margin: 6px 0 12px; font-size: 26px; font-weight: 900;}
.modal__section{margin-top:14px;}
.modal__section h4{margin:0 0 8px; color: var(--gold2);}
.modal__section ul{margin:0; padding-left:18px;}
.modal__section p{margin:0 0 10px; color: rgba(255,255,255,.85);}
@media (max-width: 820px){
  .modal__box{ margin: 2vh auto 0; max-height: 92vh; }
  .modal__grid{ grid-template-columns: 1fr; }
  .modal__flyer img{ aspect-ratio: 16 / 10; }
}

/* VIP BLACK DIAMOND */
.vip-highlight{margin-top:18px; padding:18px; border-radius:18px;
  background:linear-gradient(180deg, rgba(201,162,74,.12), rgba(0,0,0,.6)),
             radial-gradient(120% 120% at 50% 0%, rgba(201,162,74,.25), transparent 60%);
  border:1px solid rgba(201,162,74,.6);
  box-shadow:0 30px 90px rgba(0,0,0,.9);
  text-align:center;
}
.vip-badge{display:inline-block; padding:8px 14px; border-radius:999px; font-weight:900; letter-spacing:.12em;
  background:linear-gradient(90deg, #c9a24a, #f3d37a); color:#111; margin-bottom:12px;
}
.vip-features{list-style:none; padding:0; margin:14px 0; color:rgba(255,255,255,.92);}
.vip-features li{margin:8px 0; font-size:15px;}
.vip-price{font-size:32px; font-weight:900; color:var(--gold2); margin:14px 0;}
.vip-actions{display:grid; gap:10px;}

/* ===== SELECTOR BOLETOS ===== */
.ticket-box{
  margin-top:16px;
  padding:16px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.12);
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(0,0,0,.45));
  box-shadow: 0 18px 60px rgba(0,0,0,.55);
}

.ticket-head{display:flex; align-items:flex-end; justify-content:space-between; gap:12px; flex-wrap:wrap;}
.ticket-title{font-weight:900; font-size:18px;}
.ticket-sub{color:rgba(255,255,255,.65); font-size:12px; letter-spacing:.06em;}

.ticket-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:12px;
  margin-top:12px;
}

.ticket-option{cursor:pointer;}
.ticket-option input{display:none;}

.ticket-card{
  border-radius:16px;
  padding:14px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.28);
  transition:.2s ease;
}
.ticket-card.vip{
  border-color: rgba(201,162,74,.55);
  background:linear-gradient(180deg, rgba(201,162,74,.10), rgba(0,0,0,.35));
}

.ticket-badge{
  display:inline-block;
  padding:6px 10px;
  border-radius:999px;
  font-weight:900;
  font-size:11px;
  letter-spacing:.12em;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.10);
}

.ticket-price{
  margin-top:10px;
  font-size:22px;
  font-weight:900;
  color:var(--gold2);
}
.ticket-desc{
  margin-top:6px;
  color:rgba(255,255,255,.75);
  font-size:13px;
  line-height:1.35;
}

.ticket-option input:checked + .ticket-card{
  transform: translateY(-1px);
  border-color: rgba(201,162,74,.70);
  box-shadow: 0 22px 70px rgba(0,0,0,.65);
}

.ticket-row{
  margin-top:12px;
  display:flex;
  gap:12px;
  align-items:flex-end;
  justify-content:space-between;
  flex-wrap:wrap;
}

.ticket-qty span{
  display:block;
  font-size:12px;
  letter-spacing:.08em;
  color:rgba(255,255,255,.72);
  margin-bottom:6px;
}
.ticket-qty input{
  width:140px;
  padding:11px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.35);
  color:rgba(255,255,255,.92);
  outline:none;
}
.ticket-qty input:focus{
  border-color:rgba(201,162,74,.65);
  box-shadow: 0 0 0 4px rgba(201,162,74,.12);
}

.ticket-total span{
  display:block;
  font-size:12px;
  letter-spacing:.08em;
  color:rgba(255,255,255,.72);
}
.ticket-total strong{
  display:block;
  font-size:22px;
  letter-spacing:.02em;
}

.ticket-actions{display:grid; gap:10px; margin-top:14px;}

@media (max-width: 820px){
  .ticket-grid{grid-template-columns:1fr;}
  .ticket-qty input{width:100%;}
}

/* ===== ADMIN (solo admin) ===== */
.admin-box{
  margin-top:14px;
  padding:14px;
  border-radius:18px;
  border:1px dashed rgba(243,211,122,.55);
  background:rgba(0,0,0,.35);
}
.admin-title{
  font-weight:900;
  letter-spacing:.04em;
  color:var(--gold2);
  margin-bottom:10px;
}
.admin-grid{
  display:grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap:10px;
  margin-bottom:12px;
}
.admin-grid label span{
  display:block;
  font-size:12px;
  letter-spacing:.08em;
  color:rgba(255,255,255,.72);
  margin-bottom:6px;
}
.admin-grid input{
  width:100%;
  padding:11px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.35);
  color:rgba(255,255,255,.92);
  outline:none;
}
.admin-grid input:focus{
  border-color:rgba(201,162,74,.65);
  box-shadow: 0 0 0 4px rgba(201,162,74,.12);
}
.admin-result{
  margin-top:10px;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.12);
  color:rgba(255,255,255,.86);
  background:rgba(255,255,255,.03);
  min-height:40px;
  line-height:1.45;
  font-size:13px;
}
@media (max-width: 820px){
  .admin-grid{grid-template-columns:1fr;}
}
