
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Jost',sans-serif;background:#f8f5f0;color:#1c1914;overflow-x:hidden}
:root{--gold:#b09050;--cream:#f8f5f0;--dark:#1a1610;--muted:#7a7060;--border:#e5ddd0;--white:#ffffff}
section{
  padding:80px 20px;
}
/* NAV */
nav{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 4rem;position:fixed;top:0;width:100%;z-index:100;transition:.4s}
nav.scrolled{background:rgba(248,245,240,.97);border-bottom:1px solid var(--border);backdrop-filter:blur(8px)}
.nav-logo{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:300;letter-spacing:.3em;color:#f8f5f0;text-transform:uppercase;transition:.4s}
nav.scrolled .nav-logo{color:var(--dark)}
.nav-links{display:flex;gap:2.5rem}
.nav-links a{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;text-decoration:none;color:rgba(248,245,240,.75);transition:.3s}
nav.scrolled .nav-links a{color:var(--muted)}
.nav-links a:hover{color:var(--gold)}
.nav-reserve{font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;cursor:pointer;border:1px solid rgba(248,245,240,.5);color:#f8f5f0;padding:.55rem 1.5rem;background:transparent;transition:.3s}
nav.scrolled .nav-reserve{border-color:var(--dark);color:var(--dark)}
.nav-reserve:hover{background:var(--gold);border-color:var(--gold);color:#fff}

/* HERO */
.hero{position:relative;height:100vh;overflow:hidden;display:flex;align-items:center;justify-content:center;text-align:center}
.hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(26,22,16,.3) 0%,rgba(26,22,16,.5) 100%)}
.hero-content{position:relative;z-index:2;padding:0 2rem}
.hero-tag{font-size:.62rem;letter-spacing:.4em;text-transform:uppercase;color:var(--gold);margin-bottom:1.5rem;display:block}
.hero-title{font-family:'Cormorant Garamond',serif;font-size:5.5rem;font-weight:300;line-height:1.05;color:#f8f5f0;margin-bottom:1.5rem}
.hero-title em{font-style:italic}
.hero-sub{font-size:.82rem;color:rgba(248,245,240,.7);line-height:1.9;margin-bottom:3rem;font-weight:300;max-width:520px;margin-left:auto;margin-right:auto}
.hero-btns{display:flex;gap:1rem;justify-content:center}
.btn-gold{background:var(--gold);color:#fff;padding:1rem 2.8rem;font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;cursor:pointer;border:none;transition:.3s;font-family:'Jost',sans-serif}
.btn-gold:hover{background:#8a6e38}
.btn-outline-light{background:transparent;color:#f8f5f0;padding:1rem 2.8rem;font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;cursor:pointer;border:1px solid rgba(248,245,240,.45);transition:.3s;font-family:'Jost',sans-serif}
.btn-outline-light:hover{border-color:#f8f5f0}

/* BOOKING BAR */
.booking-bar{background:var(--dark);display:flex;align-items:center;justify-content:center;gap:0;padding:0}
.booking-field{display:flex;flex-direction:column;padding:1.4rem 2.5rem;border-right:1px solid rgba(255,255,255,.1);flex:1;max-width:220px}
.booking-field label{font-size:.55rem;letter-spacing:.25em;text-transform:uppercase;color:var(--gold);margin-bottom:.4rem}
.booking-field input,.booking-field select{background:transparent;border:none;color:#f8f5f0;font-family:'Jost',sans-serif;font-size:.82rem;font-weight:300;outline:none;cursor:pointer;width:100%}
.booking-field select option{background:var(--dark);color:#f8f5f0}
.booking-bar-btn{background:var(--gold);color:#fff;border:none;padding:0 3rem;height:100%;font-family:'Jost',sans-serif;font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;cursor:pointer;transition:.3s;min-height:80px}
.booking-bar-btn:hover{background:#8a6e38}

/* SECTION */
.section-head{text-align:center;padding:5.5rem 2rem 3.5rem}
.section-tag{font-size:.6rem;letter-spacing:.35em;text-transform:uppercase;color:var(--gold);margin-bottom:1rem;display:block}
.section-title{font-family:'Cormorant Garamond',serif;font-size:3rem;font-weight:300;color:var(--dark);line-height:1.2}

/* EXPERIENCIAS */
.experiences{padding:0 4rem 6rem}
.exp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.exp-card{position:relative;overflow:hidden;cursor:pointer}
.exp-card:first-child{grid-row:span 2}
.exp-img{width:100%;height:100%;min-height:280px;overflow:hidden}
.exp-card:first-child .exp-img{min-height:580px}
.exp-img img{width:100%;height:100%;object-fit:cover;transition:.7s ease}
.exp-card:hover .exp-img img{transform:scale(1.07)}
.exp-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(26,22,16,.78) 0%,transparent 55%)}
.exp-info{position:absolute;bottom:0;left:0;right:0;padding:2rem 1.8rem}
.exp-name{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:300;color:#f8f5f0;margin-bottom:.4rem}
.exp-desc{font-size:.72rem;color:rgba(248,245,240,.6);line-height:1.7;font-weight:300}

/* HABITACIONES */
.rooms{padding:0 4rem 6rem;background:var(--cream)}
.rooms-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem}
.room-card{background:var(--white);overflow:hidden;cursor:pointer;transition:.3s}
.room-card:hover{box-shadow:0 12px 40px rgba(26,22,16,.1)}
.room-img{
  width:100%;
  height:260px;
  overflow:hidden;
  position:relative;
}

.room-img img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:transform .7s ease;
}

.room-card:hover .room-img img{
  transform:scale(1.05);
}
.room-badge{position:absolute;top:1rem;left:1rem;background:var(--gold);color:#fff;font-size:.58rem;letter-spacing:.15em;text-transform:uppercase;padding:.3rem .9rem}
.room-body{padding:2rem}
.room-cat{font-size:.58rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:.5rem}
.room-name{font-family:'Cormorant Garamond',serif;font-size:1.8rem;font-weight:400;color:var(--dark);margin-bottom:.6rem}
.room-desc{font-size:.78rem;color:var(--muted);line-height:1.8;font-weight:300;margin-bottom:1.5rem}
.room-amenities{display:flex;gap:1.5rem;margin-bottom:1.8rem;flex-wrap:wrap}
.amenity{font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:.4rem}
.amenity::before{content:'';width:4px;height:4px;background:var(--gold);border-radius:50%;flex-shrink:0}
.room-footer{display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--border);padding-top:1.5rem}
.room-price{display:flex;flex-direction:column}
.room-price span{font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.room-price strong{font-family:'Cormorant Garamond',serif;font-size:2rem;font-weight:300;color:var(--dark)}
.room-price small{font-size:.65rem;color:var(--muted);font-weight:300}
.btn-reserve{background:var(--dark);color:var(--cream);border:none;padding:.8rem 2rem;font-family:'Jost',sans-serif;font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;cursor:pointer;transition:.3s}
.btn-reserve:hover{background:var(--gold)}

/* ABOUT */
.about{display:grid;grid-template-columns:1fr 1fr;min-height:700px}
.about-imgs{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:.8rem;padding:3rem 2rem 3rem 4rem}
.about-imgs img{width:100%;height:100%;object-fit:cover}
.about-imgs img:first-child{grid-column:span 2;height:320px}
.about-text{background:var(--dark);display:flex;align-items:center;padding:6rem 5rem}
.about-inner{max-width:420px}
.about-inner .section-tag{text-align:left;display:block;margin-bottom:1rem}
.about-inner h2{font-family:'Cormorant Garamond',serif;font-size:2.8rem;font-weight:300;color:#f8f5f0;line-height:1.2;margin-bottom:1.8rem}
.about-inner p{font-size:.8rem;color:rgba(248,245,240,.55);line-height:1.9;font-weight:300;margin-bottom:1.2rem}
.about-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin:2.5rem 0}
.stat-n{font-family:'Cormorant Garamond',serif;font-size:2.4rem;font-weight:300;color:#f8f5f0;line-height:1}
.stat-l{font-size:.58rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(248,245,240,.35);margin-top:.3rem}

/* GALLERY */
.gallery{padding:0 4rem 6rem}
.gallery-grid{display:grid;grid-template-columns:repeat(12,1fr);grid-template-rows:280px 280px;gap:1rem}
.g1{grid-column:span 5;grid-row:span 2}
.g2{grid-column:span 4}
.g3{grid-column:span 3}
.g4{grid-column:span 3}
.g5{grid-column:span 4}
.gallery-grid div{overflow:hidden}
.gallery-grid div img{width:100%;height:100%;object-fit:cover;transition:.6s}
.gallery-grid div:hover img{transform:scale(1.05)}

/* TESTIMONIALS */
.testimonials{background:#f0ebe2;padding:6rem 4rem}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:1rem}
.testi-card{background:var(--white);padding:2.8rem 2.2rem}
.testi-line{width:28px;height:1px;background:var(--gold);margin-bottom:1.8rem}
.testi-text{font-family:'Cormorant Garamond',serif;font-size:1.1rem;font-style:italic;font-weight:300;line-height:1.8;color:var(--dark);margin-bottom:2rem}
.testi-author{font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.testi-stay{font-size:.62rem;color:var(--gold);margin-top:.3rem;letter-spacing:.08em}

/* CTA */
.cta-section{position:relative;height:520px;overflow:hidden;display:flex;align-items:center;justify-content:center;text-align:center}
.cta-section img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.cta-overlay{position:absolute;inset:0;background:rgba(26,22,16,.65)}
.cta-content{position:relative;z-index:2}
.cta-content h2{font-family:'Cormorant Garamond',serif;font-size:3.8rem;font-weight:300;color:#f8f5f0;margin-bottom:1rem;line-height:1.15}
.cta-content p{font-size:.8rem;color:rgba(248,245,240,.6);margin-bottom:2.5rem;font-weight:300}

/* FOOTER */
footer{background:#100e0b;color:#f8f5f0;padding:5rem 4rem 2rem}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:4rem;margin-bottom:4rem}
.footer-logo{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:300;letter-spacing:.3em;text-transform:uppercase;display:block;margin-bottom:1rem}
.footer-brand p{font-size:.74rem;color:rgba(248,245,240,.35);line-height:1.9;font-weight:300;max-width:240px}
.newsletter{margin-top:1.5rem;display:flex}
.newsletter input{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);color:#f8f5f0;padding:.7rem 1rem;font-family:'Jost',sans-serif;font-size:.72rem;flex:1;outline:none}
.newsletter input::placeholder{color:rgba(255,255,255,.25)}
.newsletter button{background:var(--gold);color:#fff;border:none;padding:.7rem 1.2rem;font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;cursor:pointer}
.footer-col h4{font-size:.6rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin-bottom:1.3rem}
.footer-col a{display:block;font-size:.74rem;color:rgba(248,245,240,.35);text-decoration:none;margin-bottom:.6rem;font-weight:300;transition:.2s}
.footer-col a:hover{color:#f8f5f0}
.footer-bottom{border-top:1px solid rgba(255,255,255,.07);padding-top:2rem;display:flex;justify-content:space-between}
.footer-bottom p{font-size:.6rem;letter-spacing:.08em;color:rgba(255,255,255,.2)}

/* MODAL */
#modal-overlay{display:none;position:fixed;inset:0;background:rgba(26,22,16,.88);z-index:500;align-items:center;justify-content:center}
#modal-overlay.open{display:flex}
.modal-box{background:var(--white);width:90%;max-width:560px;max-height:90vh;overflow-y:auto;position:relative}
.modal-img{width:100%;height:180px;object-fit:cover}
.modal-body{padding:2.5rem}
.modal-close{position:absolute;top:1rem;right:1.2rem;background:none;border:none;font-size:1.3rem;cursor:pointer;color:var(--muted);z-index:10}
.modal-tag{font-size:.58rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:.5rem}
.modal-title{font-family:'Cormorant Garamond',serif;font-size:2rem;font-weight:300;color:var(--dark);margin-bottom:2rem}
.modal-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}
.modal-field{display:flex;flex-direction:column;gap:.4rem}
.modal-field label{font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.modal-field input,.modal-field select{border:1px solid var(--border);padding:.75rem 1rem;font-family:'Jost',sans-serif;font-size:.82rem;color:var(--dark);outline:none;background:#fff;width:100%}
.modal-field.full{grid-column:span 2}
.modal-submit{width:100%;background:var(--dark);color:#fff;border:none;padding:1rem;font-family:'Jost',sans-serif;font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;cursor:pointer;margin-top:1.2rem;transition:.3s}
.modal-submit:hover{background:var(--gold)}
.modal-success{display:none;text-align:center;padding:1.5rem;background:#f0ebe2;font-size:.82rem;color:var(--dark);line-height:1.8}
@media (max-width: 900px){

  /* RESET GENERAL GRID */
  .exp-grid,
  .rooms-grid,
  .testi-grid{
    grid-template-columns:1fr !important;
  }

  /* GALLERY: rompe layout editorial */
  .gallery-grid{
    display:block;
  }

  .gallery-grid div{
    height:220px;
    margin-bottom:1rem;
  }

  /* ABOUT */
  .about{
    grid-template-columns:1fr;
  }

  .about-imgs{
    padding:2rem;
    grid-template-columns:1fr;
    grid-template-rows:auto;
  }

  .about-imgs img:first-child{
    grid-column:auto;
    height:240px;
  }

  /* HERO TEXT */
  .hero-title{
    font-size:2.8rem;
  }

  /* EXPERIENCES BIG IMAGE FIX */
  .exp-card:first-child .exp-img{
    min-height:260px;
  }

}

.gallery-grid div,
.room-img,
.exp-img,
.about-imgs img{
  width:100%;
  aspect-ratio: 4 / 3;
  overflow:hidden;
  position:relative;
}

.gallery-grid div img,
.room-img img,
.exp-img img,
.about-imgs img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
</style>



