:root{
  --bg-main:#F8F5EF;
  --bg-sec:#ECE5DA;
  --dark:#1F2328;
  --card:rgba(255,255,255,0.82);
  --glass-border:rgba(255,255,255,0.25);
  --gold:#C79B63;
  --gold-soft:#E2C4A2;
  --arctic:#7E97A8;
  --forest:#708D81;
  --heading:#25211D;
  --body:#655C52;
  --white:#FFFFFF;
  --glow:rgba(199,155,99,0.35);
  --shadow-soft:0 10px 35px rgba(0,0,0,0.08);
  --shadow-deep:0 20px 60px rgba(0,0,0,0.15);
  --serif:'Cormorant Garamond', 'Playfair Display', serif;
  --sans:'Inter', 'Manrope', system-ui, sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  background:var(--bg-main);
  color:var(--body);
  line-height:1.7;
  font-weight:300;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

h1,h2,h3,h4,h5{
  font-family:var(--serif);
  color:var(--heading);
  font-weight:500;
  letter-spacing:-0.01em;
  line-height:1.15;
}

a{color:inherit;text-decoration:none;transition:.3s}
img{max-width:100%;display:block}

/* SIDEBAR */
.sidebar{
  position:fixed;top:24px;left:24px;bottom:24px;width:230px;
  background:rgba(255,255,255,0.65);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border:1px solid var(--glass-border);
  border-radius:24px;
  box-shadow:var(--shadow-soft);
  padding:32px 22px;
  display:flex;flex-direction:column;
  z-index:100;
  transition:transform .4s ease;
}
.sidebar-brand h2{
  font-family:var(--serif);
  font-size:1.7rem;
  color:var(--heading);
  font-weight:600;
}
.sidebar-brand span{
  font-size:.7rem;
  letter-spacing:.25em;
  text-transform:uppercase;
  color:var(--gold);
  display:block;
  margin-top:4px;
}
.sidebar-nav{margin-top:40px;flex:1;display:flex;flex-direction:column;gap:4px}
.sidebar-nav a{
  display:flex;align-items:center;gap:12px;
  padding:12px 14px;border-radius:14px;
  font-size:.92rem;color:var(--body);
  position:relative;
}
.sidebar-nav .nav-icon{
  width:22px;height:22px;
  display:flex;align-items:center;justify-content:center;
  border-radius:50%;background:rgba(199,155,99,0.12);
  color:var(--gold);font-size:.7rem;
}
.sidebar-nav a:hover{
  background:rgba(199,155,99,0.1);
  color:var(--heading);
  transform:translateX(4px);
  box-shadow:0 0 0 1px rgba(199,155,99,0.15), 0 8px 24px var(--glow);
}
.sidebar-nav a.active{
  background:linear-gradient(135deg,rgba(199,155,99,0.2),rgba(226,196,162,0.1));
  color:var(--heading);
  font-weight:500;
}
.sidebar-footer{margin-top:auto;padding-top:20px;font-size:.75rem;color:var(--body);opacity:.7}

.mobile-toggle{
  display:none;
  position:fixed;top:20px;right:20px;
  width:46px;height:46px;
  background:var(--white);
  border:none;border-radius:14px;
  box-shadow:var(--shadow-soft);
  z-index:200;
  flex-direction:column;justify-content:center;align-items:center;
  gap:5px;cursor:pointer;
}
.mobile-toggle span{
  width:20px;height:1.5px;background:var(--heading);transition:.3s;
}
.mobile-toggle.active span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.mobile-toggle.active span:nth-child(2){opacity:0}
.mobile-toggle.active span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* MAIN */
.main-content{margin-left:280px;min-height:100vh}
.container{max-width:1280px;margin:0 auto;padding:0 40px}
.section{padding:120px 0}

/* TYPE */
.eyebrow{
  display:inline-block;
  font-size:.72rem;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--gold);
  font-weight:500;
  margin-bottom:18px;
}
.eyebrow.gold{color:var(--gold-soft)}
.display{font-size:clamp(2rem,4vw,3.4rem);margin-bottom:24px;font-weight:500}
.display.light{color:var(--white)}
.lead{font-size:1.15rem;color:var(--heading);margin-bottom:18px;font-weight:400}
.muted{color:var(--body);font-size:.97rem}
.muted-light{color:rgba(255,255,255,0.55);font-size:.85rem}
.light{color:var(--white)}
.light-muted{color:rgba(255,255,255,0.7);font-size:1.02rem;margin-bottom:30px}

/* HERO */
.hero{
  position:relative;height:100vh;min-height:680px;
  display:flex;align-items:center;
  border-radius:0 0 40px 40px;
  overflow:hidden;
}
.hero-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  transform:scale(1.05);
  animation:slowZoom 20s ease-out infinite alternate;
}
@keyframes slowZoom{from{transform:scale(1.05)}to{transform:scale(1.15)}}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(31,35,40,0.65) 0%,rgba(31,35,40,0.35) 50%,rgba(199,155,99,0.25) 100%);
}
.hero-content{position:relative;z-index:2;padding:0 60px;max-width:900px;color:var(--white)}
.hero-content .eyebrow{color:var(--gold-soft)}
.hero-content h1{
  font-size:clamp(2.4rem,5.5vw,5rem);
  color:var(--white);
  margin-bottom:24px;
  font-weight:500;
  line-height:1.05;
}
.hero-sub{font-size:1.15rem;color:rgba(255,255,255,0.85);max-width:620px;margin-bottom:36px;font-weight:300}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap}
.hero-scroll{
  position:absolute;bottom:40px;left:60px;
  font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;
  color:rgba(255,255,255,0.7);
  display:flex;align-items:center;gap:12px;
}
.hero-scroll span{
  width:30px;height:1px;background:rgba(255,255,255,0.5);
  display:inline-block;animation:scrollPulse 2s infinite;
}
@keyframes scrollPulse{0%,100%{width:30px;opacity:.5}50%{width:50px;opacity:1}}

.page-hero{
  position:relative;height:60vh;min-height:440px;
  display:flex;align-items:center;
  border-radius:0 0 40px 40px;overflow:hidden;
}
.page-hero.short{height:40vh;min-height:300px}
.page-hero-content{position:relative;z-index:2;padding:0 60px;color:var(--white);max-width:800px}
.page-hero-content h1{
  font-family:var(--serif);
  font-size:clamp(2.2rem,4.5vw,4rem);
  color:var(--white);margin-bottom:18px;font-weight:500;
}
.page-hero-content p{color:rgba(255,255,255,0.8);font-size:1.1rem}

/* BUTTONS */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:14px 32px;
  border-radius:14px;
  font-family:var(--sans);
  font-size:.85rem;
  letter-spacing:.15em;
  text-transform:uppercase;
  font-weight:500;
  cursor:pointer;border:none;
  transition:all .35s cubic-bezier(.2,.7,.3,1);
}
.btn-gold{
  background:linear-gradient(135deg,var(--gold) 0%,var(--gold-soft) 100%);
  color:var(--white);
  box-shadow:0 6px 20px var(--glow);
}
.btn-gold:hover{
  transform:translateY(-3px);
  box-shadow:0 14px 36px var(--glow), 0 0 0 1px rgba(199,155,99,0.3);
}
.btn-ghost{
  background:rgba(255,255,255,0.1);
  color:var(--white);
  border:1px solid rgba(255,255,255,0.3);
  backdrop-filter:blur(10px);
}
.btn-ghost:hover{
  background:rgba(255,255,255,0.2);
  transform:translateY(-3px);
}

.link-arrow{
  color:var(--gold);font-weight:500;font-size:.88rem;
  letter-spacing:.08em;display:inline-block;margin-top:8px;
}
.link-arrow:hover{color:var(--heading);transform:translateX(4px)}

/* SECTIONS */
.two-col{
  display:grid;grid-template-columns:1fr 1.4fr;gap:80px;align-items:start;
}
.section-head{margin-bottom:60px;max-width:680px}

/* HOTEL CARDS */
.hotel-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.hotel-grid.wide{grid-template-columns:1fr;gap:48px}
.hotel-grid.single{grid-template-columns:1fr;gap:48px}
.hotel-grid.stacked{grid-template-columns:1fr;gap:48px}
.hotel-card{
  background:var(--card);
  backdrop-filter:blur(14px);
  border:1px solid var(--glass-border);
  border-radius:24px;overflow:hidden;
  box-shadow:var(--shadow-soft);
  transition:.5s;
  display:flex;flex-direction:column;
}
.hotel-card.large{
  display:grid;grid-template-columns:1.2fr 1fr;
  gap:0;align-items:stretch;
}
.hotel-grid.single .hotel-card.large,
.hotel-grid.stacked .hotel-card.large{grid-template-columns:1.2fr 1fr}
.hotel-card.large.reverse{grid-template-columns:1fr 1.2fr}
.hotel-card.large.reverse .hotel-img{order:2}
.hotel-card:hover{
  transform:translateY(-8px);
  box-shadow:var(--shadow-deep);
}
.hotel-img{overflow:hidden;height:280px}
.hotel-card.large .hotel-img{height:auto;min-height:420px}
.hotel-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.hotel-card:hover .hotel-img img{transform:scale(1.08)}
.hotel-body{padding:32px}
.hotel-card.large .hotel-body{padding:50px;display:flex;flex-direction:column;justify-content:center}
.tag{
  display:inline-block;font-size:.7rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--gold);margin-bottom:14px;
}
.hotel-body h3{font-size:1.8rem;margin-bottom:14px}
.hotel-card.large h3{font-size:2.4rem}
.hotel-body p{margin-bottom:14px}
.feature-list{list-style:none;margin:18px 0 24px}
.feature-list li{
  padding:8px 0 8px 22px;position:relative;
  font-size:.95rem;border-bottom:1px solid rgba(101,92,82,0.1);
}
.feature-list li:before{
  content:'◇';position:absolute;left:0;color:var(--gold);
}

/* DARK SECTION */
.dark-section{
  background:var(--dark);
  border-radius:40px;
  margin:40px;padding:120px 0;
  position:relative;overflow:hidden;
}
.dark-section .container{padding:0 60px}
.vip-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:20px;
}
.vip-tile{
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.1);
  backdrop-filter:blur(12px);
  border-radius:18px;padding:28px;
  transition:.4s;
}
.vip-tile:hover{
  background:rgba(199,155,99,0.12);
  border-color:rgba(199,155,99,0.3);
  transform:translateY(-4px);
}
.vip-tile h4{color:var(--white);margin-bottom:8px;font-size:1.3rem}
.vip-tile p{color:rgba(255,255,255,0.7);font-size:.92rem}

.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.feature-card{
  background:rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.1);
  border-radius:20px;padding:34px;
  transition:.4s;
}
.feature-card:hover{
  background:rgba(199,155,99,0.1);
  transform:translateY(-6px);
  box-shadow:0 12px 40px rgba(199,155,99,0.15);
}
.feature-card h4{color:var(--white);font-size:1.4rem;margin-bottom:10px}
.feature-card p{color:rgba(255,255,255,0.7);font-size:.95rem}

/* WELLNESS */
.wellness-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.wellness-card{
  border-radius:22px;overflow:hidden;
  position:relative;height:340px;
  box-shadow:var(--shadow-soft);transition:.5s;
}
.wellness-card img{width:100%;height:100%;object-fit:cover;transition:transform .8s}
.wellness-card:hover img{transform:scale(1.1)}
.wellness-card h4{
  position:absolute;bottom:24px;left:24px;
  color:var(--white);font-size:1.4rem;
  text-shadow:0 2px 12px rgba(0,0,0,0.5);
}
.wellness-card:after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to top,rgba(31,35,40,0.7),transparent 50%);
}

.wellness-large-grid{display:flex;flex-direction:column;gap:36px}
.wellness-large{
  display:grid;grid-template-columns:1fr 1fr;gap:0;
  background:var(--card);border-radius:24px;overflow:hidden;
  box-shadow:var(--shadow-soft);
}
.wellness-large.reverse img{order:2}
.wellness-large img{width:100%;height:100%;object-fit:cover;min-height:340px}
.wellness-large > div{padding:50px;display:flex;flex-direction:column;justify-content:center}
.wellness-large h3{font-size:2rem;margin-bottom:14px}

/* DINING */
.dining-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:28px;
}
.dining-card{
  background:var(--card);border-radius:22px;overflow:hidden;
  box-shadow:var(--shadow-soft);transition:.5s;
}
.dining-card.wide{grid-column:span 3;display:grid;grid-template-columns:1.2fr 1fr;align-items:stretch}
.dining-card.wide img{height:100%;min-height:340px}
.dining-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-deep)}
.dining-card img{width:100%;height:240px;object-fit:cover;transition:transform .8s}
.dining-card:hover img{transform:scale(1.06)}
.dining-card > div{padding:30px}
.dining-card.wide > div{padding:50px;display:flex;flex-direction:column;justify-content:center}
.dining-card h3{font-size:1.6rem;margin-bottom:10px}

/* VIP CARDS */
.vip-cards{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px;
}
.vip-card{
  background:var(--card);border-radius:20px;overflow:hidden;
  box-shadow:var(--shadow-soft);transition:.5s;
  border:1px solid var(--glass-border);
}
.vip-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-deep)}
.vip-card img{width:100%;height:200px;object-fit:cover;transition:.6s}
.vip-card:hover img{transform:scale(1.05)}
.vip-card h4{padding:24px 24px 6px;font-size:1.3rem}
.vip-card p{padding:0 24px 26px;font-size:.93rem}

/* IMAGE STRIP */
.image-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.image-strip img{
  width:100%;height:340px;object-fit:cover;
  border-radius:20px;box-shadow:var(--shadow-soft);
  transition:transform .6s;
}
.image-strip img:hover{transform:scale(1.02)}
.rounded-img{border-radius:24px;box-shadow:var(--shadow-soft)}

/* CTA SECTION */
.cta-section{padding:80px 0}
.glass-cta{
  background:linear-gradient(135deg,rgba(255,255,255,0.85),rgba(236,229,218,0.7));
  backdrop-filter:blur(20px);
  border:1px solid var(--glass-border);
  border-radius:32px;
  padding:70px 80px;
  display:flex;justify-content:space-between;align-items:center;gap:40px;
  box-shadow:var(--shadow-soft);
}
.glass-cta h2{margin-bottom:8px}
.glass-cta p{color:var(--body)}

/* MASONRY */
.masonry{
  columns:3;column-gap:20px;
}
.masonry-item{
  break-inside:avoid;margin-bottom:20px;
  border-radius:18px;overflow:hidden;
  box-shadow:var(--shadow-soft);cursor:pointer;
  transition:.4s;
}
.masonry-item:hover{transform:translateY(-4px);box-shadow:var(--shadow-deep)}
.masonry-item img{width:100%;height:auto;display:block;transition:transform .8s}
.masonry-item:hover img{transform:scale(1.06)}

/* LIGHTBOX */
.lightbox{
  position:fixed;inset:0;
  background:rgba(31,35,40,0.95);
  display:none;align-items:center;justify-content:center;
  z-index:9999;padding:40px;
}
.lightbox.active{display:flex}
.lightbox img{max-width:90%;max-height:90vh;border-radius:18px}
.lightbox-close{
  position:absolute;top:30px;right:40px;
  font-size:2.4rem;color:var(--white);cursor:pointer;
}

/* CONTACT */
.contact-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:60px}
.contact-form-wrap h2{margin-bottom:10px}
.contact-form{margin-top:30px;display:flex;flex-direction:column;gap:18px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.contact-form label{
  display:flex;flex-direction:column;
  font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--body);font-weight:500;gap:8px;
}
.contact-form input,
.contact-form select,
.contact-form textarea{
  padding:14px 18px;
  border:1px solid rgba(101,92,82,0.18);
  border-radius:14px;
  background:var(--white);
  font-family:var(--sans);font-size:.95rem;
  color:var(--heading);
  transition:.3s;
  text-transform:none;letter-spacing:normal;font-weight:300;
}
.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus{
  outline:none;border-color:var(--gold);
  box-shadow:0 0 0 3px var(--glow);
}
.form-status{font-size:.9rem;color:var(--gold);min-height:20px}
.contact-info{display:flex;flex-direction:column;gap:24px}
.info-card{
  background:var(--card);
  border:1px solid var(--glass-border);
  border-radius:20px;padding:30px;
  box-shadow:var(--shadow-soft);
}
.info-card h4{font-size:1.3rem;margin-bottom:8px}
.map-wrap{border-radius:20px;overflow:hidden;box-shadow:var(--shadow-soft)}

/* LEGAL */
.legal-content{max-width:820px}
.legal-content h3{font-size:1.4rem;margin:32px 0 12px;color:var(--heading)}
.legal-content h4{font-size:1.1rem;margin:22px 0 10px;color:var(--heading)}
.legal-content p{margin-bottom:14px}
.legal-content ul{margin:10px 0 18px 22px}
.legal-content ul li{margin-bottom:8px;font-size:.97rem}
.legal-content table{
  width:100%;border-collapse:collapse;margin:18px 0 24px;
  background:var(--card);border-radius:14px;overflow:hidden;
  box-shadow:var(--shadow-soft);
}
.legal-content th,
.legal-content td{
  padding:14px 18px;text-align:left;
  border-bottom:1px solid rgba(101,92,82,0.12);
  font-size:.92rem;
}
.legal-content th{
  background:rgba(199,155,99,0.12);
  color:var(--heading);font-weight:600;
  font-family:var(--sans);
  letter-spacing:.06em;text-transform:uppercase;font-size:.78rem;
}
.legal-content tr:last-child td{border-bottom:none}

/* FOOTER */
.footer{
  background:var(--dark);
  color:rgba(255,255,255,0.75);
  padding:80px 0 30px;
  margin-top:60px;
  border-radius:40px 40px 0 0;
}
.footer-grid{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr 1.2fr;gap:50px;
}
.footer-brand{
  font-family:var(--serif);font-size:1.8rem;
  color:var(--white);margin-bottom:14px;
}
.footer h5{
  color:var(--gold-soft);font-family:var(--sans);
  font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;
  font-weight:500;margin-bottom:18px;
}
.footer a{
  display:block;color:rgba(255,255,255,0.65);
  font-size:.92rem;padding:6px 0;
}
.footer a:hover{color:var(--gold)}
.footer p{font-size:.92rem;color:rgba(255,255,255,0.65);line-height:1.7}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,0.08);
  margin-top:60px;padding:30px 40px 0;
  max-width:1280px;margin-left:auto;margin-right:auto;
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;
}
.footer-bottom p{color:rgba(255,255,255,0.55);font-size:.82rem}

/* REVEAL */
.reveal{opacity:0;transform:translateY(40px);transition:opacity 1s, transform 1s}
.reveal.visible{opacity:1;transform:translateY(0)}

/* RESPONSIVE */
@media (max-width:1100px){
  .sidebar{width:200px}
  .main-content{margin-left:240px}
  .hotel-grid{grid-template-columns:repeat(2,1fr)}
  .hotel-grid.stacked{grid-template-columns:1fr}
  .feature-grid{grid-template-columns:repeat(2,1fr)}
  .wellness-grid{grid-template-columns:repeat(2,1fr)}
  .dining-grid{grid-template-columns:repeat(2,1fr)}
  .dining-card.wide{grid-column:span 2}
  .footer-grid{grid-template-columns:repeat(2,1fr)}
  .masonry{columns:2}
}

@media (max-width:860px){
  .sidebar{
    transform:translateX(-110%);
    width:280px;top:0;left:0;bottom:0;border-radius:0 24px 24px 0;
  }
  .sidebar.active{transform:translateX(0)}
  .main-content{margin-left:0}
  .mobile-toggle{display:flex}
  .container{padding:0 24px}
  .section{padding:80px 0}
  .hero-content{padding:0 30px}
  .page-hero-content{padding:0 30px}
  .hero-scroll{left:30px}
  .two-col{grid-template-columns:1fr;gap:30px}
  .hotel-grid{grid-template-columns:1fr;gap:24px}
  .hotel-card.large{grid-template-columns:1fr}
  .hotel-card.large.reverse{grid-template-columns:1fr}
  .hotel-card.large.reverse .hotel-img{order:0}
  .hotel-card.large .hotel-img{min-height:240px}
  .hotel-card.large .hotel-body{padding:30px}
  .feature-grid{grid-template-columns:1fr}
  .vip-grid{grid-template-columns:1fr}
  .wellness-grid{grid-template-columns:1fr}
  .wellness-large{grid-template-columns:1fr}
  .wellness-large.reverse img{order:0}
  .wellness-large > div{padding:30px}
  .dining-grid{grid-template-columns:1fr}
  .dining-card.wide{grid-column:span 1;grid-template-columns:1fr}
  .image-strip{grid-template-columns:1fr}
  .image-strip img{height:240px}
  .glass-cta{flex-direction:column;text-align:center;padding:50px 30px}
  .contact-grid{grid-template-columns:1fr;gap:30px}
  .form-row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:30px}
  .footer-bottom{flex-direction:column;text-align:center}
  .dark-section{margin:20px;padding:80px 0}
  .dark-section .container{padding:0 30px}
  .masonry{columns:1}
  .legal-content table{font-size:.85rem}
  .legal-content th,
  .legal-content td{padding:10px 12px}
}