:root{
  --bg-main:#F7F4EE;
  --bg-secondary:#ECE4D8;
  --card-bg:rgba(255,255,255,0.82);
  --gold:#D4A373;
  --nordic-blue:#5F7C8A;
  --forest:#7B8F7A;
  --text:#27231F;
  --text-muted:#6A625A;
  --highlight:#E8C9A7;
  --border:rgba(212,163,115,0.25);
  --shadow:0 20px 60px rgba(39,35,31,0.08);
  --shadow-lg:0 30px 80px rgba(39,35,31,0.15);
  --radius:24px;
  --radius-sm:14px;
  --transition:0.4s cubic-bezier(0.22,0.61,0.36,1);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Inter','Lato',sans-serif;
  background:var(--bg-main);
  color:var(--text);
  line-height:1.7;
  overflow-x:hidden;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none;transition:var(--transition)}

h1,h2,h3,h4,h5{
  font-family:'Playfair Display',serif;
  font-weight:500;
  letter-spacing:-0.01em;
  line-height:1.2;
  color:var(--text);
}
h1{font-size:clamp(2.4rem,5vw,4.5rem)}
h2{font-size:clamp(2rem,3.5vw,3rem);margin-bottom:20px}
h3{font-size:clamp(1.4rem,2.2vw,1.9rem);margin-bottom:15px}
h4{font-size:1.2rem;margin-bottom:10px}
h5{font-size:1rem;margin-bottom:15px;font-family:'Inter',sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:0.1em}
p{color:var(--text-muted);margin-bottom:15px}

.eyebrow{
  display:inline-block;
  font-family:'Inter',sans-serif;
  font-size:0.75rem;
  font-weight:500;
  text-transform:uppercase;
  letter-spacing:0.25em;
  color:var(--gold);
  margin-bottom:15px;
}

/* Sidebar */
.sidebar{
  position:fixed;
  left:0;top:0;
  height:100vh;
  width:80px;
  background:rgba(247,244,238,0.85);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-right:1px solid var(--border);
  z-index:100;
  display:flex;
  flex-direction:column;
  align-items:center;
  padding:30px 0;
  transition:var(--transition);
}
.sidebar-logo{
  display:flex;
  flex-direction:column;
  align-items:center;
  margin-bottom:50px;
}
.logo-mark{
  width:46px;height:46px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--gold),var(--highlight));
  display:flex;align-items:center;justify-content:center;
  font-family:'Playfair Display',serif;
  font-size:1.4rem;color:#fff;font-weight:600;
  box-shadow:0 6px 20px rgba(212,163,115,0.4);
}
.logo-text{
  display:none;
  font-family:'Playfair Display',serif;
  font-size:0.85rem;
  margin-top:10px;
}
.sidebar-nav{
  display:flex;
  flex-direction:column;
  gap:8px;
  width:100%;
  align-items:center;
}
.nav-item{
  display:flex;
  align-items:center;
  justify-content:center;
  width:50px;height:50px;
  border-radius:50%;
  position:relative;
  color:var(--text-muted);
  transition:var(--transition);
}
.nav-item:hover,.nav-item.active{
  background:linear-gradient(135deg,var(--gold),var(--highlight));
  color:#fff;
  box-shadow:0 6px 20px rgba(212,163,115,0.4);
}
.nav-icon{font-size:1.2rem;line-height:1}
.nav-label{display:none}
.nav-item::after{
  content:attr(data-tooltip);
  position:absolute;
  left:65px;
  background:var(--text);
  color:#fff;
  padding:6px 12px;
  border-radius:6px;
  font-size:0.75rem;
  white-space:nowrap;
  opacity:0;
  pointer-events:none;
  transition:var(--transition);
  font-family:'Inter',sans-serif;
}
.nav-item:hover::after{opacity:1;left:75px}

.mobile-toggle{
  display:none;
  position:fixed;
  top:20px;right:20px;
  width:48px;height:48px;
  border-radius:50%;
  background:var(--card-bg);
  backdrop-filter:blur(20px);
  border:1px solid var(--border);
  z-index:101;
  cursor:pointer;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:5px;
}
.mobile-toggle span{
  width:22px;height:2px;
  background:var(--text);
  transition:var(--transition);
}

.main-content{
  margin-left:80px;
  min-height:100vh;
}

/* Hero */
.hero{
  position:relative;
  height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}
.hero-bg{
  position:absolute;inset:0;
  background-size:cover;
  background-position:center;
  transform:scale(1.05);
  animation:slowZoom 20s ease-in-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(39,35,31,0.55),rgba(95,124,138,0.35) 60%,rgba(232,201,167,0.3));
}
.particles{position:absolute;inset:0;pointer-events:none}
.particles span{
  position:absolute;
  width:6px;height:6px;
  background:var(--highlight);
  border-radius:50%;
  opacity:0.5;
  animation:floatUp 12s linear infinite;
  box-shadow:0 0 12px var(--gold);
}
.particles span:nth-child(1){left:10%;animation-delay:0s}
.particles span:nth-child(2){left:25%;animation-delay:2s}
.particles span:nth-child(3){left:50%;animation-delay:4s}
.particles span:nth-child(4){left:70%;animation-delay:6s}
.particles span:nth-child(5){left:85%;animation-delay:1s}
.particles span:nth-child(6){left:40%;animation-delay:8s}
@keyframes floatUp{
  0%{bottom:-10px;opacity:0}
  20%{opacity:0.6}
  100%{bottom:110%;opacity:0}
}
.hero-content{
  position:relative;
  z-index:2;
  max-width:900px;
  text-align:center;
  padding:0 30px;
  color:#fff;
}
.hero-content h1{color:#fff;font-weight:500;margin-bottom:25px;text-shadow:0 4px 30px rgba(0,0,0,0.3)}
.hero-content p{color:rgba(255,255,255,0.92);font-size:1.15rem;max-width:680px;margin:0 auto 35px}
.hero-content .eyebrow{color:var(--highlight)}
.hero-buttons{display:flex;gap:15px;justify-content:center;flex-wrap:wrap}
.scroll-indicator{
  position:absolute;
  bottom:30px;left:50%;
  transform:translateX(-50%);
  width:24px;height:40px;
  border:2px solid rgba(255,255,255,0.5);
  border-radius:12px;
  z-index:2;
}
.scroll-indicator span{
  position:absolute;
  top:8px;left:50%;
  transform:translateX(-50%);
  width:4px;height:8px;
  background:#fff;
  border-radius:2px;
  animation:scrollDot 2s infinite;
}
@keyframes scrollDot{0%,100%{top:8px;opacity:1}50%{top:20px;opacity:0.3}}

/* Buttons */
.btn{
  display:inline-block;
  padding:14px 32px;
  font-family:'Inter',sans-serif;
  font-size:0.78rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:0.2em;
  border-radius:50px;
  cursor:pointer;
  transition:var(--transition);
  border:none;
  text-align:center;
}
.btn-primary{
  background:linear-gradient(135deg,var(--gold),var(--highlight));
  color:#fff;
  box-shadow:0 8px 25px rgba(212,163,115,0.4);
}
.btn-primary:hover{
  transform:translateY(-3px);
  box-shadow:0 15px 35px rgba(212,163,115,0.55);
}
.btn-secondary{
  background:rgba(255,255,255,0.15);
  color:#fff;
  backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,0.3);
}
.btn-secondary:hover{background:rgba(255,255,255,0.25);transform:translateY(-3px)}
.btn-outline{
  background:transparent;
  color:var(--text);
  border:1.5px solid var(--gold);
}
.btn-outline:hover{
  background:var(--gold);
  color:#fff;
  box-shadow:0 8px 20px rgba(212,163,115,0.35);
}

/* Sections */
.section{
  padding:100px 60px;
}
.section-alt{background:var(--bg-secondary)}
.section-header{
  text-align:center;
  max-width:700px;
  margin:0 auto 60px;
}
.section-sub{font-size:1.05rem}

/* Hotel Cards */
.hotels-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(320px,1fr));
  gap:35px;
  max-width:1400px;
  margin:0 auto;
}
.hotel-card{
  background:var(--card-bg);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow);
  transition:var(--transition);
}
.hotel-card:hover{
  transform:translateY(-8px);
  box-shadow:var(--shadow-lg);
  border-color:var(--gold);
}
.hotel-image{
  height:280px;
  overflow:hidden;
  position:relative;
}
.hotel-image img{
  width:100%;height:100%;
  object-fit:cover;
  transition:transform 0.7s ease;
}
.hotel-card:hover .hotel-image img{transform:scale(1.08)}
.hotel-body{padding:30px}
.hotel-location{
  font-family:'Inter',sans-serif;
  font-size:0.7rem;
  text-transform:uppercase;
  letter-spacing:0.2em;
  color:var(--gold);
  font-weight:500;
}
.hotel-body h3{margin:8px 0 12px}
.hotel-features{
  list-style:none;
  display:flex;flex-wrap:wrap;
  gap:8px;
  margin:18px 0 25px;
}
.hotel-features li{
  font-size:0.7rem;
  background:rgba(212,163,115,0.12);
  color:var(--gold);
  padding:6px 12px;
  border-radius:50px;
  font-weight:500;
  letter-spacing:0.05em;
  text-transform:uppercase;
}

/* Spa Cards */
.spa-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:30px;
  max-width:1300px;
  margin:0 auto;
}
.spa-card{
  background:var(--card-bg);
  backdrop-filter:blur(20px);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:40px 32px;
  text-align:center;
  transition:var(--transition);
  box-shadow:var(--shadow);
}
.spa-card:hover{
  transform:translateY(-8px);
  box-shadow:var(--shadow-lg);
  border-color:var(--gold);
}
.spa-icon{
  width:70px;height:70px;
  margin:0 auto 20px;
  background:linear-gradient(135deg,var(--gold),var(--highlight));
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:1.8rem;color:#fff;
  box-shadow:0 8px 20px rgba(212,163,115,0.3);
}

/* VIP Grid */
.vip-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:24px;
  max-width:1300px;
  margin:0 auto;
}
.vip-card{
  background:var(--card-bg);
  backdrop-filter:blur(20px);
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  padding:32px 26px;
  transition:var(--transition);
  position:relative;
  overflow:hidden;
}
.vip-card:hover{
  transform:translateY(-5px);
  border-color:var(--gold);
  box-shadow:var(--shadow);
}
.vip-num{
  font-family:'Playfair Display',serif;
  font-size:2.5rem;
  color:var(--highlight);
  display:block;
  margin-bottom:10px;
  font-style:italic;
}
.vip-card h4{font-size:1.1rem;margin-bottom:8px}
.vip-card p{font-size:0.9rem;margin:0}

/* Dining */
.dining-section{
  position:relative;
  background:url('images/photo-1414235077428-338989a2e8c0.png') center/cover fixed;
  padding:120px 60px;
  text-align:center;
  overflow:hidden;
}
.dining-overlay{
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(39,35,31,0.7),rgba(95,124,138,0.5));
}
.dining-content{
  position:relative;z-index:2;
  max-width:700px;
  margin:0 auto;
  color:#fff;
}
.dining-content h2{color:#fff}
.dining-content p{color:rgba(255,255,255,0.9);font-size:1.05rem;margin-bottom:30px}
.dining-content .eyebrow{color:var(--highlight)}

/* About */
.about-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:60px;
  align-items:center;
  max-width:1300px;
  margin:0 auto;
}
.about-image img{
  border-radius:var(--radius);
  box-shadow:var(--shadow-lg);
}

/* Page Hero */
.page-hero{
  position:relative;
  height:55vh;
  min-height:380px;
  display:flex;
  align-items:center;
  justify-content:center;
  background-size:cover;
  background-position:center;
  text-align:center;
}
.page-hero.short{height:38vh;min-height:260px}
.page-hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(39,35,31,0.55),rgba(95,124,138,0.35));
}
.page-hero-content{
  position:relative;z-index:2;
  color:#fff;padding:0 30px;max-width:900px;
}
.page-hero-content h1{color:#fff}
.page-hero-content p{color:rgba(255,255,255,0.9);margin-top:15px}
.page-hero-content .eyebrow{color:var(--highlight)}

/* Detail */
.detail-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:60px;
  align-items:center;
  max-width:1300px;
  margin:0 auto 60px;
}
.detail-image img{
  border-radius:var(--radius);
  box-shadow:var(--shadow-lg);
}
.features-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:20px;
  max-width:1300px;
  margin:60px auto;
}
.feature-block{
  background:var(--card-bg);
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  padding:24px;
  backdrop-filter:blur(15px);
  transition:var(--transition);
}
.feature-block:hover{border-color:var(--gold);transform:translateY(-3px)}
.feature-block h4{font-family:'Inter',sans-serif;font-size:0.8rem;text-transform:uppercase;letter-spacing:0.2em;color:var(--gold);margin-bottom:8px}
.feature-block p{margin:0;font-size:0.95rem}

.cta-block{
  text-align:center;
  background:var(--card-bg);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:60px 30px;
  max-width:700px;
  margin:60px auto 0;
  backdrop-filter:blur(20px);
}
.cta-block h3{margin-bottom:25px}

/* Contact */
.contact-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:50px;
  max-width:1300px;
  margin:0 auto;
}
.contact-map{
  border-radius:var(--radius);
  overflow:hidden;
  min-height:500px;
  box-shadow:var(--shadow);
  border:1px solid var(--border);
}
.contact-form{
  background:var(--card-bg);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:40px;
  backdrop-filter:blur(20px);
  box-shadow:var(--shadow);
}
.contact-form h3{margin-bottom:25px}
.form-group{margin-bottom:18px}
.form-group label{
  display:block;
  font-size:0.75rem;
  text-transform:uppercase;
  letter-spacing:0.15em;
  color:var(--text-muted);
  margin-bottom:8px;
  font-weight:500;
}
.form-group input,
.form-group select,
.form-group textarea{
  width:100%;
  padding:14px 16px;
  background:rgba(255,255,255,0.6);
  border:1px solid var(--border);
  border-radius:12px;
  font-family:'Inter',sans-serif;
  font-size:0.95rem;
  color:var(--text);
  transition:var(--transition);
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{
  outline:none;
  border-color:var(--gold);
  background:#fff;
  box-shadow:0 0 0 3px rgba(212,163,115,0.15);
}
.form-status{margin-top:15px;font-size:0.9rem;color:var(--forest)}

/* Legal */
.legal-section{padding:80px 60px}
.legal-content{max-width:850px;margin:0 auto}
.legal-content h2{font-size:1.4rem;margin-top:35px;margin-bottom:12px;color:var(--gold)}
.legal-content h2:first-child{margin-top:0}
.legal-content p{font-size:1rem;color:var(--text)}
.legal-content a{color:var(--gold);border-bottom:1px solid var(--gold)}

/* Footer */
.footer{
  background:linear-gradient(135deg,#27231F,#3a3530);
  color:rgba(255,255,255,0.8);
  padding:70px 60px 30px;
  margin-left:0;
  position:relative;
}
.footer::before{
  content:'';
  position:absolute;
  inset:0;
  background:rgba(212,163,115,0.04);
  pointer-events:none;
}
.footer-grid{
  position:relative;
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:40px;
  max-width:1300px;
  margin:0 auto 40px;
}
.footer-col h4{
  font-family:'Playfair Display',serif;
  font-size:1.4rem;
  color:#fff;
  margin-bottom:12px;
}
.footer-col h5{color:var(--highlight);font-size:0.8rem}
.footer-col p{color:rgba(255,255,255,0.6);font-size:0.9rem}
.footer-col a{
  display:block;
  font-size:0.9rem;
  color:rgba(255,255,255,0.7);
  margin-bottom:8px;
}
.footer-col a:hover{color:var(--highlight);padding-left:5px}
.footer-bottom{
  position:relative;
  border-top:1px solid rgba(255,255,255,0.1);
  padding-top:25px;
  text-align:center;
  font-size:0.85rem;
  color:rgba(255,255,255,0.5);
}

/* Reveal */
.reveal{
  opacity:0;
  transform:translateY(30px);
  transition:opacity 0.9s ease,transform 0.9s ease;
}
.reveal.visible{opacity:1;transform:translateY(0)}

/* Responsive */
@media (max-width:1024px){
  .about-grid,.detail-grid,.contact-grid{grid-template-columns:1fr;gap:40px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:30px}
}
@media (max-width:768px){
  .sidebar{
    transform:translateX(-100%);
    width:240px;
  }
  .sidebar.open{transform:translateX(0)}
  .sidebar-logo{margin-bottom:30px}
  .logo-text{display:block}
  .sidebar-nav{align-items:flex-start;padding:0 25px}
  .nav-item{
    width:100%;
    height:auto;
    padding:14px 18px;
    border-radius:12px;
    justify-content:flex-start;
    gap:14px;
  }
  .nav-icon{font-size:1.1rem}
  .nav-label{display:inline-block;font-size:0.95rem}
  .nav-item::after{display:none}
  .mobile-toggle{display:flex}
  .mobile-toggle.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
  .mobile-toggle.active span:nth-child(2){opacity:0}
  .mobile-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}
  .main-content{margin-left:0}
  .section,.dining-section,.legal-section,.footer{padding-left:25px;padding-right:25px}
  .section{padding-top:70px;padding-bottom:70px}
  .hero-content h1{font-size:2.2rem}
  .hero-buttons{flex-direction:column;width:100%;max-width:280px;margin:0 auto}
  .footer-grid{grid-template-columns:1fr;text-align:center}
  .contact-map{min-height:300px}
}