@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400&family=Nunito+Sans:wght@300;400;600&display=swap');
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --cream:#F5F0EB;--charcoal:#1A1A1A;--warm-gray:#8A8278;--gold:#B8956A;
  --gold-light:#D4B896;--dark-green:#2C3E2D;--soft-white:#FDFCFA;
  --serif:'Cormorant Garamond',Georgia,serif;--sans:'Nunito Sans',sans-serif;
}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--charcoal);background:var(--cream);font-weight:300;line-height:1.7;overflow-x:hidden;-webkit-font-smoothing:antialiased}

/* PRELOADER */
.preloader{position:fixed;inset:0;z-index:9999;background:var(--charcoal);display:flex;align-items:center;justify-content:center;transition:opacity .8s,visibility .8s}
.preloader.hidden{opacity:0;visibility:hidden;pointer-events:none}
.preloader-text{font-family:var(--serif);font-size:clamp(2rem,5vw,3.5rem);color:var(--gold);letter-spacing:.3em;animation:pulse 1.5s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.4}50%{opacity:1}}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:1.4rem 3rem;display:flex;justify-content:space-between;align-items:center;transition:all .5s;background:rgba(26,26,26,.85);backdrop-filter:blur(20px)}
nav.scrolled{padding:1rem 3rem;box-shadow:0 1px 30px rgba(0,0,0,.15)}
nav.transparent-nav{background:transparent;backdrop-filter:none}
nav.transparent-nav.scrolled{background:rgba(26,26,26,.92);backdrop-filter:blur(20px)}
.nav-logo{font-family:var(--serif);font-size:1.4rem;font-weight:400;letter-spacing:.25em;color:#fff;text-decoration:none;text-transform:uppercase}
.nav-right{display:flex;align-items:center;gap:2rem}
.nav-links{display:flex;gap:2rem;list-style:none}
.nav-links a{color:rgba(255,255,255,.75);text-decoration:none;font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;font-weight:400;transition:color .3s;position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;background:var(--gold);transition:width .3s}
.nav-links a:hover{color:#fff}
.nav-links a:hover::after{width:100%}
.nav-links a.active{color:var(--gold-light)}
.nav-links a.active::after{width:100%}
.lang-toggle{display:flex;border:1px solid rgba(255,255,255,.25);border-radius:2px;overflow:hidden}
.lang-btn{background:none;border:none;color:rgba(255,255,255,.5);padding:.3rem .6rem;font-size:.68rem;letter-spacing:.1em;cursor:pointer;transition:all .3s;font-family:var(--sans)}
.lang-btn.active{background:var(--gold);color:var(--charcoal)}
.hamburger{display:none;background:none;border:none;cursor:pointer;width:28px;height:20px;position:relative;z-index:101}
.hamburger span{display:block;width:100%;height:1.5px;background:#fff;position:absolute;left:0;transition:all .3s}
.hamburger span:nth-child(1){top:0}.hamburger span:nth-child(2){top:50%;transform:translateY(-50%)}.hamburger span:nth-child(3){bottom:0}
.hamburger.open span:nth-child(1){top:50%;transform:translateY(-50%) rotate(45deg)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){bottom:50%;transform:translateY(50%) rotate(-45deg)}
.mobile-menu{position:fixed;inset:0;z-index:99;background:rgba(26,26,26,.97);backdrop-filter:blur(30px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.8rem;opacity:0;visibility:hidden;transition:all .5s}
.mobile-menu.open{opacity:1;visibility:visible}
.mobile-menu a{font-family:var(--serif);font-size:1.8rem;color:#fff;text-decoration:none;letter-spacing:.08em;opacity:0;transform:translateY(20px);transition:all .4s}
.mobile-menu.open a{opacity:1;transform:translateY(0)}
.mobile-menu.open a:nth-child(1){transition-delay:.05s}.mobile-menu.open a:nth-child(2){transition-delay:.1s}.mobile-menu.open a:nth-child(3){transition-delay:.15s}.mobile-menu.open a:nth-child(4){transition-delay:.2s}.mobile-menu.open a:nth-child(5){transition-delay:.25s}.mobile-menu.open a:nth-child(6){transition-delay:.3s}

/* PAGE HERO (inner pages) */
.page-hero{height:45vh;min-height:320px;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;background:var(--charcoal)}
.page-hero-bg{position:absolute;inset:0;object-fit:cover;width:100%;height:100%;opacity:.4;transform:scale(1.05)}
.page-hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(26,26,26,.5),rgba(26,26,26,.7))}
.page-hero-content{position:relative;z-index:2;text-align:center}
.page-hero-content h1{font-family:var(--serif);font-size:clamp(2.5rem,6vw,4.5rem);font-weight:300;color:#fff;letter-spacing:.08em}
.page-hero-content p{color:rgba(255,255,255,.6);font-size:.9rem;margin-top:.8rem;letter-spacing:.05em}

/* SECTIONS */
section{padding:6rem 2rem}
.section-label{font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:1rem}
.section-title{font-family:var(--serif);font-size:clamp(2rem,4vw,3.2rem);font-weight:300;line-height:1.2;margin-bottom:1.5rem}
.section-text{color:var(--warm-gray);max-width:620px;font-size:.95rem;line-height:1.9}
.container{max-width:1200px;margin:0 auto}

/* CAROUSEL */
.carousel{position:relative;overflow:hidden;border-radius:4px}
.carousel-track{display:flex;transition:transform .5s cubic-bezier(.25,.46,.45,.94);cursor:grab}
.carousel-track.dragging{transition:none;cursor:grabbing}
.carousel-slide{min-width:100%;position:relative}
.carousel-slide img{width:100%;aspect-ratio:16/10;object-fit:cover;display:block}
.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);background:rgba(26,26,26,.55);backdrop-filter:blur(10px);border:none;color:#fff;width:46px;height:46px;cursor:pointer;font-size:1.1rem;transition:all .3s;z-index:2;display:flex;align-items:center;justify-content:center}
.carousel-btn:hover{background:var(--gold);color:var(--charcoal)}
.carousel-btn.prev{left:.8rem}.carousel-btn.next{right:.8rem}
.carousel-dots{display:flex;justify-content:center;gap:.5rem;margin-top:1rem}
.carousel-dot{width:8px;height:8px;border-radius:50%;background:rgba(138,130,120,.25);border:none;cursor:pointer;transition:all .3s;padding:0}
.carousel-dot.active{background:var(--gold);transform:scale(1.3)}
.dark-section .carousel-dot{background:rgba(255,255,255,.25)}

/* ROOM BLOCKS */
.room-block{margin-bottom:4rem}
.room-block-title{font-family:var(--serif);font-size:1.5rem;font-weight:300;margin-bottom:1.2rem;display:flex;align-items:center;gap:1rem}
.room-block-title span{font-size:.68rem;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);background:rgba(184,149,106,.12);padding:.3rem .8rem;border-radius:2px}

/* PRICING */
.pricing-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-top:3rem}
.price-card{background:var(--soft-white);border:1px solid rgba(138,130,120,.1);padding:2.5rem;text-align:center;transition:all .4s}
.price-card:hover{border-color:var(--gold);transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,0,0,.06)}
.price-card h4{font-family:var(--serif);font-size:1.3rem;font-weight:400;margin-bottom:.5rem}
.price-card .price{font-family:var(--serif);font-size:2.8rem;font-weight:400;color:var(--gold)}
.price-card .price-note{font-size:.75rem;color:var(--warm-gray);margin-top:.3rem}
.pricing-note{text-align:center;color:var(--warm-gray);font-size:.85rem;font-style:italic;margin-top:2rem}

/* AMENITIES */
.amenities-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-top:3rem}
.amenity{background:var(--soft-white);border:1px solid rgba(138,130,120,.08);padding:2rem 1.5rem;text-align:center;transition:all .4s}
.amenity:hover{border-color:var(--gold-light);transform:translateY(-3px);box-shadow:0 8px 30px rgba(0,0,0,.05)}
.amenity-icon{font-size:2rem;margin-bottom:1rem}
.amenity h4{font-family:var(--serif);font-size:1.05rem;font-weight:400;margin-bottom:.5rem}
.amenity p{font-size:.8rem;color:var(--warm-gray);line-height:1.7}

/* IMAGE GRIDS */
.image-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.image-grid-4 img{width:100%;aspect-ratio:3/4;object-fit:cover;border-radius:3px;transition:transform .6s}
.image-grid-4 img:hover{transform:scale(1.04)}

/* FEATURES */
.features{display:flex;flex-direction:column;gap:2rem;margin-top:2rem}
.feature{display:flex;gap:1rem;align-items:flex-start}
.feature-icon{width:42px;height:42px;flex-shrink:0;border:1px solid var(--gold-light);display:flex;align-items:center;justify-content:center;color:var(--gold);font-size:1.1rem}
.feature-text h4{font-family:var(--serif);font-size:1.05rem;font-weight:400;margin-bottom:.3rem}
.feature-text p{font-size:.85rem;color:var(--warm-gray);line-height:1.7}

/* TWO COL */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.img-hover{overflow:hidden;border-radius:4px}
.img-hover img{width:100%;display:block;transition:transform .8s}
.img-hover:hover img{transform:scale(1.05)}

/* CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem}
.contact-detail{margin-bottom:2rem}
.contact-detail h4{font-family:var(--serif);font-size:1.05rem;font-weight:400;margin-bottom:.4rem}
.contact-detail a,.contact-detail p.sub{color:var(--warm-gray);text-decoration:none;font-size:.9rem;transition:color .3s}
.contact-detail a:hover{color:var(--gold)}
.contact-form{display:flex;flex-direction:column;gap:1.5rem}
.form-group input,.form-group textarea{width:100%;background:transparent;border:none;border-bottom:1px solid rgba(138,130,120,.2);padding:1rem 0;color:var(--charcoal);font-family:var(--sans);font-size:.9rem;font-weight:300;transition:border-color .3s;outline:none}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--warm-gray)}
.form-group input:focus,.form-group textarea:focus{border-color:var(--gold)}
.form-group textarea{resize:none;height:120px}
.submit-btn{align-self:flex-start;padding:1rem 3rem;background:var(--gold);color:var(--charcoal);border:none;cursor:pointer;font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;font-weight:600;font-family:var(--sans);transition:all .4s}
.submit-btn:hover{background:var(--charcoal);color:#fff;transform:translateY(-2px)}
.map-wrap{border-radius:4px;overflow:hidden;margin-top:4rem}
.map-wrap iframe{width:100%;height:320px;border:0;filter:grayscale(.4)}

/* FOOTER */
footer{background:var(--charcoal);color:rgba(255,255,255,.4);padding:3rem 2rem;text-align:center;font-size:.8rem}
footer .footer-logo{font-family:var(--serif);font-size:1.2rem;color:var(--gold-light);letter-spacing:.2em;margin-bottom:.8rem}
.social-link{display:inline-block;margin-top:.8rem;color:var(--gold);text-decoration:none;font-size:.78rem;letter-spacing:.1em;transition:color .3s}
.social-link:hover{color:#fff}

/* REVEAL */
.reveal{opacity:0;transform:translateY(35px);transition:all .8s cubic-bezier(.25,.46,.45,.94)}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ANIMATIONS */
@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
@keyframes heroZoom{0%{transform:scale(1.05)}100%{transform:scale(1.15)}}
@keyframes scrollDown{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}50.1%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* RESPONSIVE */
@media(max-width:1024px){
  .two-col,.contact-grid{grid-template-columns:1fr;gap:3rem}
  .amenities-grid{grid-template-columns:repeat(2,1fr)}
  .image-grid-4{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  nav{padding:1.1rem 1.5rem}nav.scrolled{padding:.8rem 1.5rem}
  .nav-links,.lang-toggle-desktop{display:none!important}
  .hamburger{display:block}
  section{padding:4rem 1.5rem}
  .pricing-grid{grid-template-columns:1fr}
  .amenities-grid{grid-template-columns:1fr 1fr}
  .image-grid-4{grid-template-columns:1fr 1fr}
  .page-hero{height:35vh;min-height:260px}
}

/* PARTNER BADGE */
.footer-partner{margin:1.5rem 0 .5rem;display:flex;justify-content:center}
.partner-badge{display:inline-flex;flex-direction:column;align-items:center;gap:5px;padding:14px 26px;background:rgba(255,255,255,.03);border:1px solid rgba(184,149,106,.15);border-radius:10px;text-decoration:none;transition:all .3s ease}
.partner-badge:hover{background:rgba(184,149,106,.08);border-color:rgba(184,149,106,.35);transform:translateY(-2px)}
.partner-badge__label{font-size:.6rem;text-transform:uppercase;letter-spacing:2px;color:rgba(255,255,255,.35)}
.partner-badge__logo{font-family:var(--sans);font-size:1.4rem;font-weight:700;color:#fff;letter-spacing:3px}
.partner-badge__accent{color:var(--gold)}
.partner-badge__desc{font-size:.65rem;color:rgba(255,255,255,.3);letter-spacing:.5px}
