*{
margin:0;
padding:0;
box-sizing:border-box;
}

html{
scroll-behavior:smooth;
}

body{
font-family:'Inter',sans-serif;
background:#000;
color:white;
overflow-x:hidden;
}

/* FONDO PREMIUM */

.overlay{
position:fixed;
inset:0;
background:
linear-gradient(rgba(0,0,0,0.6),rgba(0,0,0,0.92)),
url('assets/hero-bg.jpg');
background-size:cover;
background-position:center;
z-index:-1;
}

/* HOME */

.hero{
min-height:100vh;
padding:40px 5%;
display:flex;
flex-direction:column;
justify-content:space-between;
}

.topbar{
display:flex;
justify-content:space-between;
align-items:center;
color:#d4af37;
letter-spacing:2px;
font-size:14px;
padding-bottom:10px;
border-bottom:1px solid rgba(212,175,55,0.15);
}

.center{
text-align:center;
margin-top:40px;
}

h1{
font-family:'Cormorant Garamond',serif;
font-size:110px;
line-height:0.9;
font-weight:700;
letter-spacing:6px;
background:linear-gradient(to bottom,#fff5d1,#f6d365,#d4af37,#7a5a18);
-webkit-background-clip:text;
-webkit-text-fill-color:transparent;
text-shadow:0 0 30px rgba(212,175,55,0.08);
}

.center p{
margin-top:25px;
color:#d8c48d;
letter-spacing:4px;
font-size:15px;
text-transform:uppercase;
}

/* BOTONES CIRCULARES */

.selector-grid{
display:grid;
grid-template-columns:repeat(4,1fr);
gap:35px;
margin-top:90px;
max-width:1400px;
margin-left:auto;
margin-right:auto;
}

.circle-item{
text-decoration:none;
display:flex;
flex-direction:column;
align-items:center;
gap:18px;
color:white;
transition:.4s ease;
position:relative;
}

.circle-item img{
width:220px;
height:220px;
border-radius:50%;
object-fit:cover;
border:1px solid rgba(212,175,55,0.7);
padding:8px;
background:#111;
box-shadow:
0 0 20px rgba(212,175,55,0.1),
0 0 50px rgba(0,0,0,0.5);
transition:.4s ease;
}

.circle-item:hover{
transform:translateY(-8px);
}

.circle-item:hover img{
transform:scale(1.03);
border-color:#f6d365;
box-shadow:
0 0 30px rgba(212,175,55,0.35),
0 0 80px rgba(212,175,55,0.15);
}

.circle-item span{
font-family:'Cormorant Garamond',serif;
font-size:34px;
letter-spacing:2px;
background:linear-gradient(to bottom,#fff5d1,#d4af37);
-webkit-background-clip:text;
-webkit-text-fill-color:transparent;
}

/* FOOTER */

.footer-info{
margin-top:90px;
padding-top:40px;
border-top:1px solid rgba(212,175,55,0.15);
display:grid;
grid-template-columns:repeat(3,1fr);
gap:30px;
}

.footer-info h4{
color:#d4af37;
margin-bottom:10px;
font-size:18px;
}

.footer-info p{
color:#d2d2d2;
font-size:14px;
}

/* PÁGINAS */

.page{
background:#050505;
min-height:100vh;
}

/* BANNERS */

.banner{
height:60vh;
position:relative;
display:flex;
justify-content:center;
align-items:center;
overflow:hidden;
border-bottom:1px solid rgba(212,175,55,0.15);
}

.banner img{
position:absolute;
width:100%;
height:100%;
object-fit:cover;
filter:brightness(0.38);
transform:scale(1.05);
}

.banner::after{
content:'';
position:absolute;
inset:0;
background:linear-gradient(to bottom,transparent,rgba(0,0,0,0.75));
}

.banner-content{
position:relative;
z-index:2;
text-align:center;
padding:20px;
}

.banner-content h2{
font-family:'Cormorant Garamond',serif;
font-size:90px;
font-weight:700;
letter-spacing:4px;
background:linear-gradient(to bottom,#fff5d1,#f6d365,#d4af37,#7a5a18);
-webkit-background-clip:text;
-webkit-text-fill-color:transparent;
}

.banner-content p{
margin-top:15px;
letter-spacing:4px;
font-size:14px;
text-transform:uppercase;
color:#d8c48d;
}

/* MENÚS */

.menu-content,
.vip-content{
padding:90px 10%;
}

.menu-grid,
.vip-grid{
display:grid;
grid-template-columns:1fr 1fr;
gap:70px;
align-items:center;
}

.menu-grid img,
.vip-grid img{
width:100%;
border-radius:22px;
box-shadow:
0 0 40px rgba(0,0,0,0.5),
0 0 20px rgba(212,175,55,0.08);
}

/* LISTAS */

.menu-list{
width:100%;
}

.menu-list li{
list-style:none;
padding:20px 0;
border-bottom:1px solid rgba(255,255,255,0.08);
display:flex;
justify-content:space-between;
align-items:center;
font-size:18px;
}

.menu-list li span:last-child{
color:#d4af37;
}

/* BOTÓN VOLVER */

.back{
display:inline-block;
margin-top:45px;
color:#d4af37;
text-decoration:none;
letter-spacing:1px;
transition:.3s;
}

.back:hover{
opacity:.7;
}

/* LOGIN VIP */

.vip-login{
min-height:100vh;
display:flex;
justify-content:center;
align-items:center;
padding:40px;
background:
radial-gradient(circle at top,rgba(212,175,55,0.08),transparent 30%),
#000;
transition:all .8s ease;
}

.door-container{
max-width:520px;
width:100%;
padding:70px 50px;
background:rgba(12,12,12,0.96);
border:1px solid rgba(212,175,55,0.2);
border-radius:24px;
text-align:center;
backdrop-filter:blur(10px);
box-shadow:
0 0 50px rgba(212,175,55,0.08),
0 0 120px rgba(0,0,0,0.8);
position:relative;
overflow:hidden;
}

.door-container::before{
content:'';
position:absolute;
top:0;
left:50%;
width:1px;
height:100%;
background:rgba(212,175,55,0.15);
}

.door-container h2{
font-family:'Cormorant Garamond',serif;
font-size:64px;
font-weight:700;
letter-spacing:3px;
background:linear-gradient(to bottom,#fff5d1,#f6d365,#d4af37,#7a5a18);
-webkit-background-clip:text;
-webkit-text-fill-color:transparent;
}

.door-container p{
margin-top:12px;
color:#d8c48d;
letter-spacing:3px;
font-size:13px;
text-transform:uppercase;
}

/* INPUT */

.door-container input{
width:100%;
padding:18px;
margin-top:30px;
background:#111;
border:1px solid rgba(212,175,55,0.25);
color:white;
border-radius:10px;
outline:none;
font-size:16px;
transition:.3s;
}

.door-container input:focus{
border-color:#d4af37;
box-shadow:0 0 15px rgba(212,175,55,0.15);
}

/* BOTÓN ENTRAR */

.door-container button{
margin-top:28px;
padding:17px 34px;
background:transparent;
border:1px solid #d4af37;
color:#d4af37;
cursor:pointer;
border-radius:10px;
font-size:14px;
letter-spacing:2px;
transition:.3s;
}

.door-container button:hover{
background:#d4af37;
color:#000;
}

/* CONTENIDO VIP */

.vip-hidden{
display:none;
animation:fadeIn 1s ease;
}

/* BOTÓN WHATSAPP */

.whatsapp-btn{
display:inline-block;
margin-top:35px;
padding:18px 34px;
background:#25D366;
color:white;
text-decoration:none;
border-radius:12px;
font-weight:600;
transition:.3s;
}

.whatsapp-btn:hover{
transform:translateY(-3px);
box-shadow:0 0 20px rgba(37,211,102,0.3);
}

/* ANIMACIÓN */

@keyframes fadeIn{

from{
opacity:0;
transform:scale(.98);
}

to{
opacity:1;
transform:scale(1);
}

}

/* MOBILE */

@media(max-width:950px){

h1{
font-size:68px;
}

.selector-grid,
.footer-info,
.menu-grid,
.vip-grid{
grid-template-columns:1fr;
}

.selector-grid{
gap:45px;
}

.circle-item img{
width:180px;
height:180px;
}

.banner{
height:50vh;
}

.banner-content h2{
font-size:58px;
}

.menu-content,
.vip-content{
padding:70px 7%;
}

.door-container{
padding:55px 30px;
}

.door-container h2{
font-size:48px;
}

}
/* =========================================================
   GRID PRODUCTOS PREMIUM
========================================================= */

.products-grid{
display:grid;
grid-template-columns:repeat(auto-fit,minmax(280px,320px));
justify-content:center;
gap:35px;
width:100%;
}

/* CARD */

.product-card{
position:relative;
border-radius:24px;
overflow:hidden;
background:#111;
border:1px solid rgba(212,175,55,0.15);
transition:.45s ease;
cursor:pointer;

box-shadow:
0 0 30px rgba(0,0,0,0.45),
0 0 10px rgba(212,175,55,0.05);
}

/* IMAGEN */

.product-card img{
width:100%;
height:100%;
display:block;
object-fit:cover;
transition:transform .6s ease;
}

/* HOVER */

.product-card:hover{
transform:translateY(-10px);

border-color:rgba(212,175,55,0.5);

box-shadow:
0 0 40px rgba(212,175,55,0.12),
0 0 80px rgba(0,0,0,0.6);
}

.product-card:hover img{
transform:scale(1.04);
}

/* VOLVER */

.back-wrapper{
display:flex;
justify-content:center;
margin-top:70px;
}

/* MOBILE */

@media(max-width:768px){

.products-grid{
grid-template-columns:1fr;
gap:28px;
}

.product-card{
border-radius:20px;
}

}
/* =========================================================
   PRIVATE CLUB
========================================================= */

.section-title{
text-align:center;
margin-bottom:50px;
}

.section-title h3{
font-family:'Cormorant Garamond',serif;
font-size:54px;
letter-spacing:3px;

background:linear-gradient(to bottom,#fff5d1,#d4af37);
-webkit-background-clip:text;
-webkit-text-fill-color:transparent;
}

/* EVENTOS */

.vip-section{
padding:0 10% 100px;
}

.events-grid{
display:grid;
grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
gap:35px;
}

.event-card{
border-radius:24px;
overflow:hidden;
border:1px solid rgba(212,175,55,0.15);
background:#111;
transition:.4s ease;
}

.event-card:hover{
transform:translateY(-8px);
}

.event-card img{
width:100%;
display:block;
object-fit:cover;
}

/* RESERVA */

.reservation-section{
padding:0 10% 100px;
}

.reservation-box{
max-width:700px;
margin:auto;
display:flex;
flex-direction:column;
gap:20px;
}

.reservation-box input,
.reservation-box textarea{
padding:18px;
background:#111;
border:1px solid rgba(212,175,55,0.2);
color:white;
border-radius:14px;
font-size:16px;
outline:none;
}

.reservation-box textarea{
height:140px;
resize:none;
}

.reserve-btn{
padding:18px;
background:linear-gradient(to right,#d4af37,#f6d365);
border:none;
border-radius:14px;
font-weight:700;
cursor:pointer;
color:#000;
transition:.3s;
}

.reserve-btn:hover{
transform:translateY(-3px);
}

/* BENEFICIOS */

.vip-benefits{
padding:0 10% 100px;
}

.benefits-grid{
display:flex;
justify-content:center;
}

.benefit-card{
max-width:1200px;
width:100%;
display:grid;
grid-template-columns:1fr 1fr;
gap:50px;
align-items:center;
background:#0d0d0d;
border-radius:28px;
overflow:hidden;
border:1px solid rgba(212,175,55,0.15);
}

.benefit-card img{
width:100%;
height:100%;
object-fit:cover;
}

.benefit-content{
padding:50px;
}

.benefit-content h4{
font-family:'Cormorant Garamond',serif;
font-size:54px;
margin-bottom:20px;

background:linear-gradient(to bottom,#fff5d1,#d4af37);
-webkit-background-clip:text;
-webkit-text-fill-color:transparent;
}

.benefit-content p{
line-height:1.8;
color:#d8d8d8;
margin-bottom:30px;
}

.charter-btn{
display:inline-block;
padding:16px 28px;
background:#d4af37;
color:#000;
text-decoration:none;
border-radius:12px;
font-weight:700;
}

/* MOBILE */

@media(max-width:900px){

.benefit-card{
grid-template-columns:1fr;
}

.benefit-content{
padding:35px;
}

.section-title h3{
font-size:40px;
}

}

img{max-width:100%;height:auto;}
.circle-item span,.banner-content p,.footer-info p,.topbar div{
word-break:break-word;
overflow-wrap:anywhere;
text-align:center;
}
.whatsapp-float{
position:fixed;
right:20px;
bottom:20px;
width:60px;
height:60px;
display:flex;
align-items:center;
justify-content:center;
background:#25D366;
color:#fff;
font-size:30px;
text-decoration:none;
border-radius:50%;
z-index:999;
box-shadow:0 10px 25px rgba(0,0,0,.35);
}

@media(max-width:950px){
.topbar{gap:10px;font-size:12px;flex-wrap:wrap;justify-content:center;text-align:center;}
.circle-item span{font-size:26px;line-height:1.2;padding:0 10px;}
.footer-info{margin-top:50px;text-align:center;}
.banner-content h2{font-size:44px;line-height:1;}
.banner-content p{font-size:12px;letter-spacing:2px;padding:0 10px;}
.menu-list li{flex-direction:column;gap:8px;text-align:center;}
.products-grid{grid-template-columns:1fr;}
.product-card{max-width:100%;}
}


/* MOBILE FIXES PRIVATE CLUB */

.benefit-content{
min-width:0;
overflow:hidden;
}

.benefit-content h4{
font-size:clamp(52px,8vw,92px);
line-height:0.95;
word-break:break-word;
overflow-wrap:anywhere;
max-width:100%;
}

.benefit-content p{
font-size:clamp(16px,3vw,22px);
line-height:1.6;
word-break:break-word;
overflow-wrap:anywhere;
}

.benefit-card{
overflow:hidden;
}

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

.field-label{
color:#d4af37;
font-size:14px;
letter-spacing:1px;
margin-bottom:-10px;
margin-top:8px;
font-weight:600;
}

.input-icon{
position:relative;
}

.input-icon svg{
position:absolute;
left:16px;
top:50%;
transform:translateY(-50%);
width:18px;
height:18px;
fill:#d4af37;
pointer-events:none;
}

.input-icon input{
padding-left:48px !important;
}

@media(max-width:768px){

.vip-benefits,
.reservation-section,
.vip-section{
padding-left:5%;
padding-right:5%;
}

.benefit-card{
grid-template-columns:1fr;
gap:0;
border-radius:22px;
}

.benefit-content{
padding:24px;
}

.benefit-content h4{
font-size:72px;
line-height:0.9;
}

.benefit-content p{
font-size:16px;
line-height:1.7;
}

.charter-btn{
width:100%;
text-align:center;
padding:18px;
font-size:16px;
}

.reservation-box{
gap:14px;
}

.reservation-box input,
.reservation-box textarea{
font-size:16px;
min-height:56px;
}

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