
*,
*::before,
*::after{box-sizing:border-box;}

body{
  margin:0;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  background:#050505;
  color:#f5f5f5;
  line-height:1.6;
}

img{max-width:100%;display:block;}

a{text-decoration:none;color:inherit;}

header{
  position:sticky;
  top:0;
  z-index:100;
  background:rgba(0,0,0,.9);
  border-bottom:1px solid rgba(255,215,0,.4);
  backdrop-filter:blur(10px);
}

.nav-bar{
  max-width:1200px;
  margin:0 auto;
  padding:10px 16px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}

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

.nav-left img{
  width:42px;
  height:42px;
  border-radius:50%;
  border:2px solid rgba(255,215,0,.7);
  object-fit:cover;
}

.nav-title{
  font-size:14px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:#f7e7b5;
}

.nav-links{
  display:flex;
  gap:14px;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.16em;
}

.nav-links a{
  position:relative;
  padding-bottom:2px;
}

.nav-links a::after{
  content:"";
  position:absolute;
  left:0;
  bottom:0;
  width:0;
  height:2px;
  background:linear-gradient(90deg,#f6d365,#fda085);
  transition:width .2s ease-out;
}

.nav-links a:hover::after{width:100%;}

.visit-pill{
  font-size:11px;
  border-radius:999px;
  border:1px solid rgba(255,215,0,.7);
  padding:3px 10px;
  color:#ffe7b7;
  white-space:nowrap;
}

.visit-pill span{font-weight:600;}

.burger{
  display:none;
  flex-direction:column;
  gap:4px;
  cursor:pointer;
}

.burger span{
  width:20px;
  height:2px;
  border-radius:999px;
  background:#f7e7b5;
}

/* HERO */

.hero{
  position:relative;
  min-height:80vh;
  display:flex;
  align-items:center;
  color:#fff7dd;
  overflow:hidden;
}

.hero::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(120deg,rgba(5,5,5,.9),rgba(0,0,0,.4)),
    url("img/portada.jpg");
  background-size:cover;
  background-position:center;
  transform:scale(1.03);
  filter:blur(1px);
  z-index:-2;
}

.hero::after{
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(circle at top,rgba(255,215,0,.18),transparent 55%);
  mix-blend-mode:screen;
  z-index:-1;
}

.hero-inner{
  max-width:1200px;
  margin:0 auto;
  padding:60px 16px 40px;
  display:grid;
  grid-template-columns:minmax(0,3fr) minmax(0,2fr);
  gap:28px;
  align-items:center;
}

.hero h1{
  font-size:clamp(32px,4vw,40px);
  letter-spacing:.14em;
  text-transform:uppercase;
  margin:0 0 8px;
}

.hero h1 span{
  display:block;
  font-size:11px;
  letter-spacing:.3em;
  color:#f0d890;
  margin-bottom:4px;
}

.hero-sub{
  font-size:16px;
  margin-bottom:10px;
}

.hero-tag{
  font-size:13px;
  font-style:italic;
  color:#f4e4b9;
  margin-bottom:14px;
}

.hero-meta{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  font-size:12px;
  margin-bottom:16px;
}

.meta-pill{
  padding:4px 10px;
  border-radius:999px;
  border:1px solid rgba(255,215,0,.7);
  background:rgba(0,0,0,.55);
}

.hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.btn-primary,.btn-ghost{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:8px 18px;
  border-radius:999px;
  border:1px solid transparent;
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  cursor:pointer;
}

.btn-primary{
  background:linear-gradient(120deg,#f6d365,#fda085);
  color:#1b1306;
  box-shadow:0 12px 26px rgba(0,0,0,.7);
}

.btn-primary:hover{filter:brightness(1.05);transform:translateY(-1px);}

.btn-ghost{
  background:rgba(0,0,0,.7);
  border-color:rgba(255,215,0,.8);
  color:#ffe7b7;
}

.hero-card{
  background:linear-gradient(145deg,rgba(0,0,0,.95),rgba(25,16,4,.95));
  border-radius:14px;
  border:1px solid rgba(255,215,0,.4);
  padding:14px;
  box-shadow:0 18px 42px rgba(0,0,0,.85);
  display:grid;
  gap:10px;
}

.hero-logo{
  display:flex;
  justify-content:center;
}

.hero-logo img{max-width:190px;height:auto;}

.hero-drink{
  border-radius:10px;
  overflow:hidden;
}

.hero-drink img{
  width:100%;
  height:auto;
  transform-origin:center;
  transition:transform .25s ease-out;
}

.hero-drink:hover img{transform:scale(1.04);}

.hero-small{
  font-size:12px;
  color:#f3e5c0;
}

/* SECTIONS */

.section{
  padding:40px 16px;
}

.section-alt{
  background:radial-gradient(circle at top,rgba(255,215,0,.08),transparent 55%);
}

.section-inner{
  max-width:1200px;
  margin:0 auto;
}

.section-header{
  margin-bottom:22px;
  display:flex;
  flex-wrap:wrap;
  align-items:flex-end;
  gap:18px;
  justify-content:space-between;
}

.section-kicker{
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.26em;
  color:#c7b57f;
}

.section-title{
  font-size:20px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:#f7e7b5;
  margin-top:4px;
}

.section-desc{
  max-width:460px;
  font-size:13px;
  color:#e9ddc1;
}

/* GRIDS */

.grid-gallery,
.grid-promos,
.grid-events{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:8px;
}

.card-img{
  position:relative;
  border-radius:10px;
  overflow:hidden;
  background:#111;
  cursor:pointer;
}

.card-img img{
  width:100%;
  height:100%;
  object-fit:cover;
  transform-origin:center;
  transition:transform .25s ease-out,opacity .25s ease-out;
}

.card-img:hover img{
  transform:scale(1.06);
  opacity:.94;
}

.card-img::after{
  content:"Ver más";
  position:absolute;
  inset:auto 0 7px 0;
  margin-inline:auto;
  width:fit-content;
  padding:2px 9px;
  font-size:11px;
  border-radius:999px;
  background:rgba(0,0,0,.7);
  border:1px solid rgba(255,215,0,.8);
  letter-spacing:.18em;
  text-transform:uppercase;
  opacity:0;
  transform:translateY(6px);
  transition:opacity .2s ease,transform .2s ease;
}

.card-img:hover::after{
  opacity:1;
  transform:translateY(0);
}

/* VIDEO & REVIEWS */

.ratio{
  position:relative;
  width:100%;
  padding-top:56.25%;
  border-radius:14px;
  overflow:hidden;
  background:#000;
  border:1px solid rgba(255,215,0,.35);
  box-shadow:0 16px 40px rgba(0,0,0,.85);
}

.ratio iframe{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
}

.reviews-box{
  border-radius:14px;
  overflow:hidden;
  border:1px solid rgba(255,215,0,.35);
  background:#000;
  box-shadow:0 16px 40px rgba(0,0,0,.85);
  min-height:420px;
}

.reviews-box iframe{
  width:100%;
  height:100%;
}

/* CONTACTO */

.contact-grid{
  display:grid;
  grid-template-columns:minmax(0,3fr) minmax(0,2fr);
  gap:28px;
}

form{
  display:grid;
  gap:10px;
}

label{
  font-size:12px;
  color:#f0e0b0;
}

input,textarea{
  width:100%;
  padding:8px 10px;
  border-radius:8px;
  border:1px solid rgba(255,215,0,.6);
  background:rgba(0,0,0,.85);
  color:#f5f5f5;
  font-size:13px;
}

input:focus,textarea:focus{
  outline:none;
  border-color:#f6d365;
  box-shadow:0 0 0 1px rgba(246,211,101,.45);
}

textarea{min-height:120px;resize:vertical;}

.contact-info{
  font-size:13px;
  color:#f1e4c4;
  display:grid;
  gap:8px;
}

/* LIGHTBOX */

.lightbox{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.9);
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:0;
  pointer-events:none;
  transition:.2s ease-out;
  z-index:2000;
}

.lightbox.visible{
  opacity:1;
  pointer-events:auto;
}

.lightbox img{
  max-width:92vw;
  max-height:88vh;
  border-radius:14px;
  box-shadow:0 22px 60px rgba(0,0,0,.9);
}

.lightbox-close{
  position:fixed;
  top:10px;
  right:16px;
  font-size:30px;
  cursor:pointer;
  color:#f7e7b5;
}

/* WHATSAPP */

.whatsapp-float{
  position:fixed;
  right:16px;
  bottom:16px;
  width:54px;
  height:54px;
  border-radius:50%;
  background:#25d366;
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:26px;
  box-shadow:0 10px 26px rgba(0,0,0,.6);
  text-decoration:none;
  z-index:1500;
}

/* FOOTER */

footer{
  border-top:1px solid rgba(255,215,0,.35);
  padding:16px;
  background:#050505;
  font-size:12px;
  color:#e0d4af;
}

.footer-inner{
  max-width:1200px;
  margin:0 auto;
}

/* RESPONSIVE */

@media(max-width:900px){
  .hero-inner{grid-template-columns:minmax(0,1fr);}
  .contact-grid{grid-template-columns:minmax(0,1fr);}
  .nav-links{
    position:absolute;
    inset:54px 0 auto 0;
    background:rgba(0,0,0,.97);
    padding:10px 16px 14px;
    flex-direction:column;
    align-items:flex-start;
    transform-origin:top;
    transform:scaleY(0);
    opacity:0;
    pointer-events:none;
    transition:transform .18s ease-out,opacity .18s ease-out;
  }
  .nav-links.open{
    transform:scaleY(1);
    opacity:1;
    pointer-events:auto;
  }
  .burger{display:flex;}
}

@media(max-width:600px){
  .visit-pill{display:none;}
}
