:root{
  --negro:#242424;
  --dorado:#c39d54;
  --dorado-claro:#d4b06a;
  --blanco:#ffffff;
  --gris:#f7f5f0;
  --gris-text:#666;
  --shadow:0 10px 40px rgba(36,36,36,.12);
  --transition:all .4s cubic-bezier(.25,.8,.25,1);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Open Sans',sans-serif;color:var(--negro);line-height:1.6;background:var(--blanco);overflow-x:hidden}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}

.container{max-width:1200px;margin:0 auto;padding:0 24px}

h1,h2,h3,h4{font-family:'Open Sans',sans-serif;font-weight:700;line-height:1.2;letter-spacing:-.01em}
h2{font-size:2.4rem;margin-bottom:1rem}
h3{font-size:1.4rem}

.section-pretitle, .hero-pretitle{
  display:inline-block;color:var(--dorado);
  font-size:.85rem;letter-spacing:.3em;text-transform:uppercase;
  font-weight:500;margin-bottom:1rem
}

.section-header{text-align:center;max-width:700px;margin:0 auto 4rem}
.section-header p{color:var(--gris-text);font-size:1.05rem}

.btn{
  display:inline-block;padding:14px 36px;font-weight:500;letter-spacing:.1em;
  text-transform:uppercase;font-size:.85rem;cursor:pointer;border:2px solid transparent;
  transition:var(--transition);border-radius:2px
}
.btn-primary{background:var(--dorado);color:var(--blanco);border-color:var(--dorado)}
.btn-primary:hover{background:transparent;color:var(--dorado);transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--blanco);border-color:var(--blanco)}
.btn-outline:hover{background:var(--blanco);color:var(--negro)}
.btn-block{width:100%}

/* INTRO SCREEN */
#intro-screen{
  position:relative;height:100vh;min-height:600px;width:100%;
  background:radial-gradient(ellipse at center,#3a3a3a 0%,#242424 70%,#1a1a1a 100%);
  display:flex;align-items:center;justify-content:center;overflow:hidden
}
.intro-stars{position:absolute;inset:0;background-image:
  radial-gradient(2px 2px at 20% 30%,rgba(195,157,84,.6),transparent),
  radial-gradient(1px 1px at 60% 70%,rgba(255,255,255,.4),transparent),
  radial-gradient(1.5px 1.5px at 80% 20%,rgba(195,157,84,.5),transparent),
  radial-gradient(1px 1px at 30% 80%,rgba(255,255,255,.3),transparent),
  radial-gradient(2px 2px at 90% 50%,rgba(195,157,84,.4),transparent),
  radial-gradient(1px 1px at 10% 60%,rgba(255,255,255,.4),transparent);
  animation:starsTwinkle 4s ease-in-out infinite alternate}
@keyframes starsTwinkle{0%{opacity:.4}100%{opacity:1}}
.intro-content{position:relative;z-index:2;text-align:center;padding:0 24px;animation:introFadeIn 1.4s ease}
@keyframes introFadeIn{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
.intro-logo-wrap{position:relative;display:inline-block}
.intro-logo{
  max-width:min(560px,80vw);width:100%;height:auto;
  filter:drop-shadow(0 0 30px rgba(195,157,84,.4)) drop-shadow(0 10px 40px rgba(0,0,0,.5));
  animation:logoFloat 4s ease-in-out infinite
}
@keyframes logoFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

.lights-string{
  position:absolute;left:5%;right:5%;bottom:-2px;height:30px;
  display:flex;justify-content:space-between;align-items:center
}
.lights-string span{
  display:block;width:9px;height:9px;border-radius:50%;
  background:var(--dorado);
  box-shadow:0 0 8px var(--dorado),0 0 18px var(--dorado),0 0 30px rgba(195,157,84,.6);
  animation:lightTwinkle 1.6s ease-in-out infinite
}
.lights-string span:nth-child(odd){background:#fff7e0;box-shadow:0 0 8px #fff7e0,0 0 18px var(--dorado),0 0 30px rgba(195,157,84,.7)}
.lights-string span:nth-child(2){animation-delay:.1s}
.lights-string span:nth-child(3){animation-delay:.2s}
.lights-string span:nth-child(4){animation-delay:.3s}
.lights-string span:nth-child(5){animation-delay:.4s}
.lights-string span:nth-child(6){animation-delay:.5s}
.lights-string span:nth-child(7){animation-delay:.6s}
.lights-string span:nth-child(8){animation-delay:.7s}
.lights-string span:nth-child(9){animation-delay:.8s}
.lights-string span:nth-child(10){animation-delay:.9s}
.lights-string span:nth-child(11){animation-delay:1s}
.lights-string span:nth-child(12){animation-delay:.15s}
.lights-string span:nth-child(13){animation-delay:.25s}
.lights-string span:nth-child(14){animation-delay:.35s}
.lights-string span:nth-child(15){animation-delay:.45s}
.lights-string span:nth-child(16){animation-delay:.55s}
.lights-string span:nth-child(17){animation-delay:.65s}
.lights-string span:nth-child(18){animation-delay:.75s}
.lights-string span:nth-child(19){animation-delay:.85s}
.lights-string span:nth-child(20){animation-delay:.95s}
@keyframes lightTwinkle{
  0%,100%{opacity:.35;transform:scale(.8)}
  50%{opacity:1;transform:scale(1.25)}
}

.intro-tagline{
  color:rgba(255,255,255,.8);margin-top:3rem;
  font-size:.95rem;letter-spacing:.3em;text-transform:uppercase;font-weight:300
}
.intro-scroll{
  position:absolute;bottom:40px;left:50%;transform:translateX(-50%);
  color:rgba(255,255,255,.7);text-align:center;animation:bounce 2.2s infinite
}
.intro-scroll span{display:block;font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;margin-bottom:8px}
.intro-scroll i{font-size:1.2rem;color:var(--dorado)}

/* Hide navbar logo while in intro screen */
#header:not(.scrolled) .logo{opacity:0;pointer-events:none;transition:opacity .4s ease}
#header.scrolled .logo{opacity:1}

@media (max-width:768px){
  .intro-logo{max-width:85vw}
  .intro-tagline{font-size:.75rem;letter-spacing:.2em}
  .lights-string span{width:7px;height:7px}
}

/* HEADER */
#header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:20px 0;transition:var(--transition);
  background:transparent
}
#header.scrolled{background:rgba(36,36,36,.97);padding:12px 0;box-shadow:var(--shadow)}
.nav-container{max-width:1300px;margin:0 auto;padding:0 30px;display:flex;justify-content:space-between;align-items:center}
.logo img{height:60px;transition:var(--transition)}
#header.scrolled .logo img{height:48px}
.nav-menu{display:flex;gap:36px;align-items:center}
.nav-menu a{color:var(--blanco);font-size:.9rem;font-weight:500;letter-spacing:.05em;position:relative;transition:var(--transition)}
.nav-menu a:not(.btn-nav)::after{
  content:'';position:absolute;bottom:-6px;left:0;width:0;height:2px;
  background:var(--dorado);transition:var(--transition)
}
.nav-menu a:hover::after{width:100%}
.nav-menu a:hover{color:var(--dorado)}
.btn-nav{
  background:var(--dorado);padding:10px 24px;border-radius:2px;
  color:var(--blanco)!important
}
.btn-nav:hover{background:var(--dorado-claro)}
.menu-toggle{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px}
.menu-toggle span{display:block;width:26px;height:2px;background:var(--blanco);transition:var(--transition)}

/* HERO */
.hero{
  position:relative;height:100vh;min-height:650px;overflow:hidden;
  display:flex;align-items:center;justify-content:center;color:var(--blanco);text-align:center
}
.hero-slides{position:absolute;inset:0}
.hero-slide{
  position:absolute;inset:0;background-size:cover;background-position:center;
  opacity:0;transition:opacity 1.5s ease;transform:scale(1.05)
}
.hero-slide.active{opacity:1;animation:zoomBg 8s ease forwards}
@keyframes zoomBg{from{transform:scale(1.05)}to{transform:scale(1.15)}}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(36,36,36,.55),rgba(36,36,36,.75))}
.hero-content{position:relative;z-index:2;padding:0 24px;animation:fadeUp 1.2s ease}
@keyframes fadeUp{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}
.hero h1{font-size:5rem;margin:.5rem 0 1.5rem;letter-spacing:-.02em;font-weight:800}
.hero h1::after{
  content:'';display:block;width:80px;height:2px;background:var(--dorado);
  margin:1.5rem auto
}
.hero-subtitle{font-size:1.25rem;font-weight:300;max-width:600px;margin:0 auto 2.5rem;letter-spacing:.05em}
.hero-buttons{display:flex;gap:18px;justify-content:center;flex-wrap:wrap}
.scroll-down{
  position:absolute;bottom:40px;left:50%;transform:translateX(-50%);
  color:var(--blanco);font-size:1.5rem;animation:bounce 2s infinite;z-index:2
}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(10px)}}

/* ABOUT */
.about{padding:120px 0;background:var(--blanco)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-text .lead{font-size:1.15rem;color:var(--negro);margin-bottom:1.2rem;font-weight:400}
.about-text p{color:var(--gris-text);margin-bottom:1rem}
.about-features{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:2.5rem}
.feature{display:flex;align-items:center;gap:14px;padding:16px;background:var(--gris);border-left:3px solid var(--dorado);transition:var(--transition)}
.feature:hover{transform:translateX(6px);box-shadow:var(--shadow)}
.feature i{color:var(--dorado);font-size:1.4rem}
.feature span{font-size:.9rem;font-weight:500}
.about-image{position:relative}
.about-image img{border-radius:4px;box-shadow:var(--shadow);height:520px;width:100%;object-fit:cover}
.about-badge{
  position:absolute;bottom:-30px;left:-30px;
  background:var(--dorado);color:var(--blanco);padding:24px 32px;border-radius:4px;
  display:flex;flex-direction:column;align-items:center;box-shadow:var(--shadow)
}
.badge-num{font-family:'Open Sans',sans-serif;font-size:2.4rem;font-weight:800;line-height:1}
.badge-text{font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;margin-top:6px}

/* SPACES */
.spaces{padding:120px 0;background:var(--gris)}
.spaces-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.space-card{
  background:var(--blanco);border-radius:4px;overflow:hidden;
  transition:var(--transition);box-shadow:0 4px 20px rgba(0,0,0,.06)
}
.space-card:hover{transform:translateY(-10px);box-shadow:var(--shadow)}
.space-img{
  height:240px;background-size:cover;background-position:center;
  position:relative;overflow:hidden;transition:var(--transition)
}
.space-img::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 50%,rgba(36,36,36,.3));
  transition:var(--transition)
}
.space-card:hover .space-img{transform:scale(1.05)}
.space-content{padding:24px}
.space-content h3{color:var(--negro);margin-bottom:.5rem}
.space-content h3::after{content:'';display:block;width:30px;height:2px;background:var(--dorado);margin:.6rem 0}
.space-content p{color:var(--gris-text);font-size:.92rem}

/* PARALLAX */
.parallax{
  background-size:cover;background-position:center;
  padding:140px 0;position:relative;color:var(--blanco);text-align:center
}
.parallax-overlay{position:absolute;inset:0;background:rgba(36,36,36,.7)}
.parallax-content{position:relative;z-index:2}
.parallax h2{font-size:2.6rem;max-width:800px;margin:0 auto 1rem;color:var(--blanco)}
.parallax p{font-size:1.15rem;margin-bottom:2rem;font-weight:300}

/* GALLERY */
.gallery{padding:120px 0;background:var(--blanco)}
.gallery-grid{
  display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:240px;gap:14px
}
.gallery-item{overflow:hidden;border-radius:4px;cursor:pointer;position:relative}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.gallery-item::after{
  content:'\f00e';font-family:'Font Awesome 6 Free';font-weight:900;
  position:absolute;inset:0;background:rgba(195,157,84,.85);color:var(--blanco);
  display:flex;align-items:center;justify-content:center;font-size:2rem;
  opacity:0;transition:var(--transition)
}
.gallery-item:hover::after{opacity:1}
.gallery-item:hover img{transform:scale(1.1)}
.gallery-item.tall{grid-row:span 2}
.gallery-item.wide{grid-column:span 2}

/* EVENTS */
.events{padding:120px 0;background:var(--negro);color:var(--blanco)}
.events .section-pretitle{color:var(--dorado)}
.events .section-header h2{color:var(--blanco)}
.events .section-header p{color:rgba(255,255,255,.7)}
.events-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.event-card{
  padding:50px 30px;text-align:center;border:1px solid rgba(195,157,84,.25);
  transition:var(--transition);background:rgba(255,255,255,.02)
}
.event-card:hover{
  background:var(--dorado);border-color:var(--dorado);transform:translateY(-8px)
}
.event-card i{font-size:3rem;color:var(--dorado);margin-bottom:1.2rem;transition:var(--transition)}
.event-card:hover i{color:var(--blanco)}
.event-card h3{color:var(--blanco);margin-bottom:.8rem}
.event-card p{color:rgba(255,255,255,.7);font-size:.92rem}
.event-card:hover p{color:var(--blanco)}

/* CONTACT */
.contact{padding:120px 0;background:var(--gris)}
.contact-grid{max-width:720px;margin:0 auto;text-align:center}
.contact-grid .social{justify-content:center}
.contact-list li{justify-content:flex-start;text-align:left}
.contact-info h2{margin-bottom:1rem}
.contact-info > p{color:var(--gris-text);margin-bottom:2.5rem}
.contact-list{margin-bottom:2rem}
.contact-list li{
  display:flex;gap:18px;align-items:center;padding:18px 0;
  border-bottom:1px solid rgba(0,0,0,.08)
}
.contact-list i{
  color:var(--dorado);font-size:1.3rem;width:48px;height:48px;
  background:var(--blanco);border-radius:50%;display:flex;align-items:center;justify-content:center;
  flex-shrink:0;box-shadow:0 4px 14px rgba(195,157,84,.2)
}
.contact-list strong{display:block;font-size:.8rem;letter-spacing:.15em;text-transform:uppercase;color:var(--negro);margin-bottom:2px}
.contact-list span{color:var(--gris-text);font-size:.95rem}
.social{display:flex;gap:14px}
.social a{
  width:44px;height:44px;border-radius:50%;background:var(--negro);color:var(--blanco);
  display:flex;align-items:center;justify-content:center;transition:var(--transition)
}
.social a:hover{background:var(--dorado);transform:translateY(-4px)}

.contact-form{
  background:var(--blanco);padding:40px;border-radius:4px;box-shadow:var(--shadow)
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form-group{margin-bottom:18px}
.form-group label{
  display:block;font-size:.78rem;letter-spacing:.15em;text-transform:uppercase;
  color:var(--negro);margin-bottom:8px;font-weight:500
}
.form-group input,.form-group select,.form-group textarea{
  width:100%;padding:12px 16px;border:1px solid #e0e0e0;border-radius:2px;
  font-family:inherit;font-size:.95rem;transition:var(--transition);background:var(--blanco)
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{
  outline:none;border-color:var(--dorado);box-shadow:0 0 0 3px rgba(195,157,84,.15)
}
.form-group textarea{resize:vertical}

/* FOOTER */
footer{background:var(--negro);color:var(--blanco);padding:80px 0 0}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:60px;margin-bottom:60px}
.footer-brand img{height:80px;margin-bottom:1.2rem}
.footer-brand p{color:rgba(255,255,255,.65);max-width:350px}
.footer-col h4{
  font-family:'Open Sans',sans-serif;font-size:.85rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--dorado);margin-bottom:1.5rem;font-weight:600
}
.footer-col ul li{margin-bottom:12px;color:rgba(255,255,255,.7);font-size:.92rem}
.footer-col ul li a{transition:var(--transition)}
.footer-col ul li a:hover{color:var(--dorado);padding-left:6px}
.footer-col i{color:var(--dorado);margin-right:8px;width:18px}
.footer-bottom{
  text-align:center;padding:24px 0;border-top:1px solid rgba(255,255,255,.08);
  font-size:.85rem;color:rgba(255,255,255,.5)
}

/* WHATSAPP FLOAT */
.whatsapp-float{
  position:fixed;bottom:30px;right:30px;width:60px;height:60px;border-radius:50%;
  background:#25d366;color:var(--blanco);display:flex;align-items:center;justify-content:center;
  font-size:1.8rem;box-shadow:0 6px 20px rgba(37,211,102,.4);z-index:999;
  transition:var(--transition);animation:pulse 2s infinite
}
.whatsapp-float:hover{transform:scale(1.1)}
@keyframes pulse{0%,100%{box-shadow:0 6px 20px rgba(37,211,102,.4)}50%{box-shadow:0 6px 30px rgba(37,211,102,.7)}}

/* Animations on scroll */
.fade-in{opacity:0;transform:translateY(30px);transition:opacity .8s ease,transform .8s ease}
.fade-in.visible{opacity:1;transform:translateY(0)}

/* RESPONSIVE */
@media (max-width:1024px){
  .spaces-grid{grid-template-columns:repeat(2,1fr)}
  .events-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-grid{grid-template-columns:repeat(3,1fr)}
  .hero h1{font-size:3.8rem}
}
@media (max-width:768px){
  h2{font-size:1.9rem}
  .hero h1{font-size:2.8rem}
  .hero-subtitle{font-size:1rem}
  .nav-menu{
    position:fixed;top:0;right:-100%;width:80%;height:100vh;background:var(--negro);
    flex-direction:column;justify-content:center;gap:30px;transition:right .4s ease
  }
  .nav-menu.active{right:0}
  .menu-toggle{display:flex}
  .menu-toggle.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
  .menu-toggle.active span:nth-child(2){opacity:0}
  .menu-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(7px,-7px)}
  .about-grid,.contact-grid,.footer-grid{grid-template-columns:1fr;gap:40px}
  .about-image img{height:380px}
  .about-badge{left:20px;bottom:-20px}
  .about-features{grid-template-columns:1fr}
  .spaces-grid,.events-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:180px}
  .gallery-item.wide,.gallery-item.tall{grid-column:auto;grid-row:auto}
  .form-row{grid-template-columns:1fr}
  .parallax{background-attachment:scroll;padding:80px 0}
  .parallax h2{font-size:2rem}
  .about,.spaces,.gallery,.events,.contact{padding:80px 0}
  .contact-form{padding:24px}
  .footer-brand img{height:60px}
}
