

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--gold:#c9a84c;--gold2:#e8d5a3;--dark:#0a0a0a;--dark2:#111;--dark3:#1a1a1a;--dark4:#222;--text:#e8e4df;--muted:#888;--border:#2a2a2a}
body{font-family:'Georgia',serif;background:var(--dark);color:var(--text);overflow-x:hidden}
a{text-decoration:none;color:inherit}
@media (max-width: 768px){

  .gallery-grid{
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
  }

  .gitem:nth-child(1){
    grid-column: span 2;
    height: 300px;
  }

  .gitem:nth-child(2),
  .gitem:nth-child(3),
  .gitem:nth-child(4),
  .gitem:nth-child(5),
  .gitem:nth-child(6){
    height: 180px;
  }
}


@media (max-width: 768px){

  .gallery-grid{
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
  }

  .gitem{
    height: auto !important;
    aspect-ratio: 4 / 3;
  }

  .gitem img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }

  .gitem:nth-child(1),
  .gitem:nth-child(6){
    grid-column: span 2;
  }
}
/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:200;padding:0 60px;height:72px;display:flex;align-items:center;justify-content:space-between;transition:background .4s,border .4s}
nav.scrolled{background:rgba(10,10,10,.96);border-bottom:1px solid var(--border)}
.nav-logo{font-size:22px;letter-spacing:.35em;color:var(--gold);cursor:pointer;font-weight:400}
.nav-logo span{font-size:10px;display:block;letter-spacing:.25em;color:var(--muted);margin-top:-2px}
.nav-links{display:flex;gap:32px;list-style:none}
.nav-links a{font-family:'Helvetica Neue',sans-serif;font-size:11px;color:var(--muted);letter-spacing:.14em;cursor:pointer;transition:color .2s;text-transform:uppercase}
.nav-links a:hover,.nav-links a.active{color:var(--gold)}
.nav-cta{background:var(--gold);color:var(--dark);font-family:'Helvetica Neue',sans-serif;font-size:10px;letter-spacing:.18em;padding:11px 24px;border:none;cursor:pointer;transition:background .2s;text-transform:uppercase}
.nav-cta:hover{background:var(--gold2)}

/* PÁGINAS */
.page{display:none}.page.active{display:block}

/* HERO */
.hero{height:100vh;position:relative;display:flex;align-items:flex-end;overflow:hidden}
.hero-bg{position:absolute;inset:0}
.hero-bg img{width:100%;height:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.85) 0%,rgba(0,0,0,.3) 50%,rgba(0,0,0,.2) 100%)}
.hero-txt{position:relative;z-index:1;padding:0 60px 80px}
.hero-tag{font-family:'Helvetica Neue',sans-serif;font-size:10px;letter-spacing:.3em;color:var(--gold);text-transform:uppercase;margin-bottom:18px;display:flex;align-items:center;gap:12px}
.hero-tag::before{content:'';width:40px;height:1px;background:var(--gold)}
.hero-title{font-size:72px;font-weight:400;line-height:1.05;margin-bottom:20px;max-width:700px}
.hero-title em{font-style:italic;color:var(--gold)}
.hero-sub{font-family:'Helvetica Neue',sans-serif;font-size:14px;color:rgba(255,255,255,.6);line-height:1.8;max-width:420px;margin-bottom:36px}
.hero-btns{display:flex;gap:14px;align-items:center}
.btn-gold{background:var(--gold);color:var(--dark);font-family:'Helvetica Neue',sans-serif;font-size:11px;letter-spacing:.18em;padding:15px 36px;border:none;cursor:pointer;transition:all .2s;text-transform:uppercase}
.btn-gold:hover{background:var(--gold2)}
.btn-outline-gold{background:transparent;color:var(--gold);font-family:'Helvetica Neue',sans-serif;font-size:11px;letter-spacing:.18em;padding:14px 36px;border:1px solid var(--gold);cursor:pointer;transition:all .2s;text-transform:uppercase}
.btn-outline-gold:hover{background:var(--gold);color:var(--dark)}
.hero-scroll{position:absolute;bottom:32px;right:60px;z-index:1;display:flex;flex-direction:column;align-items:center;gap:8px}
.hero-scroll span{font-family:'Helvetica Neue',sans-serif;font-size:9px;letter-spacing:.2em;color:var(--muted);text-transform:uppercase;writing-mode:vertical-rl}
.scroll-line{width:1px;height:60px;background:linear-gradient(to bottom,var(--gold),transparent);animation:scrollDown 2s infinite}
@keyframes scrollDown{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* STRIP */
.strip{background:var(--dark3);border-top:1px solid var(--border);border-bottom:1px solid var(--border);display:grid;grid-template-columns:repeat(4,1fr)}
.strip-item{padding:28px 36px;display:flex;align-items:center;gap:16px;border-right:1px solid var(--border)}
.strip-item:last-child{border-right:none}
.strip-item svg{width:22px;height:22px;stroke:var(--gold);fill:none;stroke-width:1.5;flex-shrink:0}
.strip-item h4{font-size:13px;font-weight:400;color:var(--text);margin-bottom:3px}
.strip-item p{font-family:'Helvetica Neue',sans-serif;font-size:11px;color:var(--muted)}

/* SECCIÓN */
.sec{padding:100px 60px}
.sec-dark{background:var(--dark)}
.sec-dark2{background:var(--dark2)}
.sec-dark3{background:var(--dark3)}
.sec-head{text-align:center;margin-bottom:64px}
.sec-tag{font-family:'Helvetica Neue',sans-serif;font-size:10px;letter-spacing:.3em;color:var(--gold);text-transform:uppercase;margin-bottom:14px;display:flex;align-items:center;justify-content:center;gap:12px}
.sec-tag::before,.sec-tag::after{content:'';width:30px;height:1px;background:var(--gold)}
.sec-title{font-size:42px;font-weight:400;line-height:1.2;margin-bottom:16px}
.sec-desc{font-family:'Helvetica Neue',sans-serif;font-size:14px;color:var(--muted);line-height:1.85;max-width:520px;margin:0 auto}

/* EXPERIENCIAS */
.exp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.exp-card{position:relative;height:480px;overflow:hidden;cursor:pointer}
.exp-card img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.exp-card:hover img{transform:scale(1.06)}
.exp-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.8),rgba(0,0,0,.1))}
.exp-txt{position:absolute;bottom:0;left:0;right:0;padding:32px;z-index:1;transform:translateY(20px);transition:transform .3s}
.exp-card:hover .exp-txt{transform:translateY(0)}
.exp-txt .etag{font-family:'Helvetica Neue',sans-serif;font-size:9px;letter-spacing:.25em;color:var(--gold);text-transform:uppercase;margin-bottom:10px}
.exp-txt h3{font-size:22px;font-weight:400;margin-bottom:8px}
.exp-txt p{font-family:'Helvetica Neue',sans-serif;font-size:12px;color:rgba(255,255,255,.6);line-height:1.7;opacity:0;transition:opacity .3s .1s}
.exp-card:hover .exp-txt p{opacity:1}

/* HABITACIONES */
.rooms-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.room-card{background:var(--dark3);border:1px solid var(--border);cursor:pointer;transition:border-color .3s}
.room-card:hover{border-color:var(--gold)}
.room-img{height:260px;overflow:hidden;position:relative}
.room-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.room-card:hover .room-img img{transform:scale(1.05)}
.room-badge{position:absolute;top:16px;left:16px;background:var(--gold);color:var(--dark);font-family:'Helvetica Neue',sans-serif;font-size:9px;letter-spacing:.14em;padding:5px 10px;text-transform:uppercase}
.room-info{padding:28px}
.room-tag{font-family:'Helvetica Neue',sans-serif;font-size:9px;letter-spacing:.2em;color:var(--gold);text-transform:uppercase;margin-bottom:10px}
.room-name{font-size:20px;font-weight:400;margin-bottom:8px}
.room-desc{font-family:'Helvetica Neue',sans-serif;font-size:12px;color:var(--muted);line-height:1.75;margin-bottom:20px}
.room-feats{display:flex;gap:16px;margin-bottom:22px;flex-wrap:wrap}
.room-feat{font-family:'Helvetica Neue',sans-serif;font-size:10px;color:var(--muted);letter-spacing:.06em;display:flex;align-items:center;gap:5px}
.room-feat::before{content:'·';color:var(--gold)}
.room-foot{display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--border);padding-top:18px}
.room-price{font-size:11px;color:var(--muted);font-family:'Helvetica Neue',sans-serif}
.room-price strong{font-size:24px;color:var(--gold);font-family:'Georgia',serif;font-weight:400;display:block}
.btn-room{background:transparent;color:var(--gold);font-family:'Helvetica Neue',sans-serif;font-size:10px;letter-spacing:.15em;padding:10px 20px;border:1px solid var(--gold);cursor:pointer;transition:all .2s;text-transform:uppercase}
.btn-room:hover{background:var(--gold);color:var(--dark)}

/* RESTAURANTE */
.resto-layout{display:grid;grid-template-columns:1fr 1fr;min-height:560px}
.resto-img{position:relative;overflow:hidden}
.resto-img img{width:100%;height:100%;object-fit:cover}
.resto-img-overlay{position:absolute;inset:0;background:rgba(0,0,0,.3)}
.resto-info{padding:80px 64px;display:flex;flex-direction:column;justify-content:center;background:var(--dark3)}
.resto-info .rtag{font-family:'Helvetica Neue',sans-serif;font-size:9px;letter-spacing:.3em;color:var(--gold);text-transform:uppercase;margin-bottom:16px}
.resto-info h2{font-size:38px;font-weight:400;line-height:1.2;margin-bottom:16px}
.resto-info h2 em{font-style:italic;color:var(--gold)}
.resto-info p{font-family:'Helvetica Neue',sans-serif;font-size:13px;color:var(--muted);line-height:1.9;margin-bottom:28px}
.menu-items{margin-bottom:32px}
.menu-item{display:flex;justify-content:space-between;align-items:baseline;padding:12px 0;border-bottom:1px solid var(--border)}
.menu-item:last-child{border-bottom:none}
.mi-name{font-size:14px}
.mi-desc{font-family:'Helvetica Neue',sans-serif;font-size:11px;color:var(--muted);display:block;margin-top:2px}
.mi-price{font-family:'Helvetica Neue',sans-serif;font-size:14px;color:var(--gold);flex-shrink:0;margin-left:20px}

/* SPA */
.spa-layout{display:grid;grid-template-columns:1fr 1fr;min-height:560px}
.spa-info{padding:80px 64px;display:flex;flex-direction:column;justify-content:center;background:var(--dark2)}
.spa-info .stag{font-family:'Helvetica Neue',sans-serif;font-size:9px;letter-spacing:.3em;color:var(--gold);text-transform:uppercase;margin-bottom:16px}
.spa-info h2{font-size:38px;font-weight:400;line-height:1.2;margin-bottom:16px}
.spa-info h2 em{font-style:italic;color:var(--gold)}
.spa-info p{font-family:'Helvetica Neue',sans-serif;font-size:13px;color:var(--muted);line-height:1.9;margin-bottom:28px}
.spa-services{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:32px}
.spa-svc{background:var(--dark3);border:1px solid var(--border);padding:20px}
.spa-svc h4{font-size:14px;font-weight:400;margin-bottom:6px}
.spa-svc p{font-family:'Helvetica Neue',sans-serif;font-size:11px;color:var(--muted);margin-bottom:8px}
.spa-svc span{font-family:'Helvetica Neue',sans-serif;font-size:12px;color:var(--gold)}
.spa-img{position:relative;overflow:hidden}
.spa-img img{width:100%;height:100%;object-fit:cover}

/* GALERÍA */
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:auto;gap:3px}
.gitem{overflow:hidden;cursor:pointer;position:relative}
.gitem img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.gitem:hover img{transform:scale(1.06)}
.gitem:nth-child(1){grid-column:span 2;grid-row:span 2;height:520px}
.gitem:nth-child(2){height:258px}
.gitem:nth-child(3){height:258px}
.gitem:nth-child(4){height:258px}
.gitem:nth-child(5){height:258px}
.gitem:nth-child(6){grid-column:span 2;height:258px}

/* LIGHTBOX */
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.95);z-index:500;display:none;align-items:center;justify-content:center}
.lightbox.open{display:flex}
.lightbox img{max-width:90vw;max-height:90vh;object-fit:contain}
.lb-close{position:absolute;top:24px;right:32px;background:none;border:none;color:#fff;font-size:32px;cursor:pointer;line-height:1}
.lb-prev,.lb-next{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.1);border:none;color:#fff;font-size:22px;cursor:pointer;padding:16px 20px;transition:background .2s}
.lb-prev{left:24px}.lb-next{right:24px}
.lb-prev:hover,.lb-next:hover{background:rgba(201,168,76,.3)}

/* RESERVAS */
.booking-layout{display:grid;grid-template-columns:1fr 1fr;min-height:700px}
.booking-img{position:relative;overflow:hidden}
.booking-img img{width:100%;height:100%;object-fit:cover}
.booking-img-overlay{position:absolute;inset:0;background:rgba(0,0,0,.5)}
.booking-img-txt{position:absolute;bottom:48px;left:48px;z-index:1}
.booking-img-txt h3{font-size:32px;font-weight:400;margin-bottom:8px}
.booking-img-txt p{font-family:'Helvetica Neue',sans-serif;font-size:13px;color:rgba(255,255,255,.6)}
.booking-form{background:var(--dark3);padding:72px 56px;display:flex;flex-direction:column;justify-content:center}
.booking-form h2{font-size:32px;font-weight:400;margin-bottom:8px}
.booking-form .bsub{font-family:'Helvetica Neue',sans-serif;font-size:13px;color:var(--muted);margin-bottom:40px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.form-group{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}
.form-group label{font-family:'Helvetica Neue',sans-serif;font-size:10px;letter-spacing:.16em;color:var(--gold);text-transform:uppercase}
.form-group input,.form-group select{background:var(--dark);border:1px solid var(--border);color:var(--text);padding:14px 16px;font-family:'Helvetica Neue',sans-serif;font-size:13px;outline:none;transition:border .2s;-webkit-appearance:none;border-radius:0}
.form-group input:focus,.form-group select:focus{border-color:var(--gold)}
.form-group select option{background:var(--dark)}
.btn-book{width:100%;background:var(--gold);color:var(--dark);font-family:'Helvetica Neue',sans-serif;font-size:11px;letter-spacing:.2em;padding:18px;border:none;cursor:pointer;margin-top:8px;transition:background .2s;text-transform:uppercase}
.btn-book:hover{background:var(--gold2)}
.book-note{font-family:'Helvetica Neue',sans-serif;font-size:11px;color:var(--muted);text-align:center;margin-top:14px}

/* TESTIMONIO */
.test-sec{background:var(--dark2);padding:100px 60px;text-align:center}
.quote-mark{font-size:80px;color:var(--gold);line-height:.8;margin-bottom:16px;opacity:.4;font-family:Georgia}
.test-text{font-size:22px;font-weight:400;line-height:1.7;max-width:720px;margin:0 auto 28px;font-style:italic;color:rgba(255,255,255,.85)}
.test-author{font-family:'Helvetica Neue',sans-serif;font-size:11px;letter-spacing:.18em;color:var(--gold);text-transform:uppercase}
.test-dots{display:flex;justify-content:center;gap:8px;margin-top:36px}
.tdot{width:6px;height:6px;border-radius:50%;background:var(--border);cursor:pointer;transition:background .2s}
.tdot.active{background:var(--gold)}

/* CTA BANNER */
.cta-banner{position:relative;height:420px;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden}
.cta-banner img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.cta-overlay{position:absolute;inset:0;background:rgba(0,0,0,.65)}
.cta-txt{position:relative;z-index:1}
.cta-txt h2{font-size:48px;font-weight:400;margin-bottom:12px}
.cta-txt h2 em{font-style:italic;color:var(--gold)}
.cta-txt p{font-family:'Helvetica Neue',sans-serif;font-size:14px;color:rgba(255,255,255,.6);margin-bottom:32px}

/* FOOTER */
footer{background:var(--dark2);border-top:1px solid var(--border);padding:72px 60px 40px}
.foot-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:56px}
.fbrand .flogo{font-size:20px;letter-spacing:.3em;color:var(--gold);margin-bottom:8px}
.fbrand .fslogan{font-family:'Helvetica Neue',sans-serif;font-size:11px;color:var(--muted);letter-spacing:.1em;margin-bottom:16px}
.fbrand p{font-family:'Helvetica Neue',sans-serif;font-size:12px;color:var(--muted);line-height:1.85;max-width:220px}
.fcol h4{font-family:'Helvetica Neue',sans-serif;font-size:9px;letter-spacing:.22em;color:var(--gold);text-transform:uppercase;margin-bottom:20px}
.fcol ul{list-style:none;display:flex;flex-direction:column;gap:12px}
.fcol ul a{font-family:'Helvetica Neue',sans-serif;font-size:12px;color:var(--muted);cursor:pointer;transition:color .2s}
.fcol ul a:hover{color:var(--gold)}
.foot-bottom{border-top:1px solid var(--border);padding-top:28px;display:flex;justify-content:space-between;align-items:center}
.foot-bottom p{font-family:'Helvetica Neue',sans-serif;font-size:11px;color:var(--muted)}
.social-links{display:flex;gap:20px}
.social-links a{font-family:'Helvetica Neue',sans-serif;font-size:10px;letter-spacing:.12em;color:var(--muted);cursor:pointer;transition:color .2s;text-transform:uppercase}
.social-links a:hover{color:var(--gold)}

/* MODAL HABITACIÓN */

.modal-overlay{
  position:fixed;inset:0;
  background:rgba(0,0,0,.85);
  z-index:300;
  display:flex;align-items:center;justify-content:center;padding:40px;
  /* en vez de display:none, usamos opacity + visibility */
  opacity:0;
  visibility:hidden;
  transition:opacity .25s ease;
}
.modal-overlay.open{
  opacity:1;
  visibility:visible;
}

.modal{
  background:var(--dark3);border:1px solid var(--border);
  max-width:880px;width:100%;max-height:90vh;overflow-y:auto;
  display:grid;grid-template-columns:1fr 1fr;
  /* pequeña animación de escala, solo transform (no dispara layout) */
  transform:scale(.96);
  transition:transform .25s ease;
}
.modal-overlay.open .modal{
  transform:scale(1);
}

.modal-img{height:100%;min-height:400px;overflow:hidden}
.modal-img img{width:100%;height:100%;object-fit:cover}
.modal-info{padding:48px}
.modal-close{background:none;border:none;color:var(--muted);font-size:24px;cursor:pointer;float:right;margin-top:-8px}
.modal-info .mtag{font-family:'Helvetica Neue',sans-serif;font-size:9px;letter-spacing:.25em;color:var(--gold);text-transform:uppercase;margin-bottom:12px}
.modal-info h2{font-size:28px;font-weight:400;margin-bottom:12px}
.modal-info .mprice{font-size:26px;color:var(--gold);margin-bottom:6px;font-family:'Helvetica Neue',sans-serif}
.modal-info .mprice span{font-size:13px;color:var(--muted)}
.modal-info p{font-family:'Helvetica Neue',sans-serif;font-size:13px;color:var(--muted);line-height:1.85;margin:16px 0}
.modal-amenities{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:16px 0 24px}
.ma{font-family:'Helvetica Neue',sans-serif;font-size:11px;color:var(--muted);display:flex;align-items:center;gap:6px}
.ma::before{content:'✓';color:var(--gold);font-size:12px}