:root{
  --ice-black:#020617;
  --polar-night:#020c1b;
  --emerald:#10b981;
  --mint:#6ee7b7;
  --ice-white:#f8fafc;
  --steel:#94a3b8;
  --gradient:linear-gradient(135deg,#020617,#020c1b,#10b981);
  --max:1380px;
  --section:110px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',sans-serif;
  background:var(--ice-black);
  color:var(--ice-white);
  line-height:1.65;
  overflow-x:hidden;
  animation:fadeIn .6s ease;
}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:color .25s}
a:hover{color:var(--mint)}

h1,h2,h3,h4{font-family:'Playfair Display',serif;font-weight:600;letter-spacing:-.5px;line-height:1.2}
h1{font-size:clamp(2.4rem,5vw,4.2rem)}
h2{font-size:clamp(1.8rem,3.4vw,2.8rem);margin-bottom:18px}
h3{font-size:1.3rem;margin-bottom:12px}
p{color:var(--steel);margin-bottom:14px}
.muted{color:var(--steel);font-size:.9rem;opacity:.85}

.container{max-width:var(--max);margin:0 auto;padding:0 32px}
.section{padding:var(--section) 0}
@media(max-width:1024px){.section{padding:80px 0}:root{--section:80px}}
@media(max-width:600px){.section{padding:50px 0}:root{--section:50px}}

.eyebrow{
  display:inline-block;
  color:var(--emerald);
  text-transform:uppercase;
  letter-spacing:3px;
  font-size:.78rem;
  font-weight:600;
  margin-bottom:14px;
}

/* Buttons */
.btn{
  display:inline-block;
  padding:14px 30px;
  font-weight:600;
  letter-spacing:.5px;
  cursor:pointer;
  border:none;
  font-size:.95rem;
  position:relative;
  overflow:hidden;
  transition:all .3s;
  text-transform:uppercase;
}
.btn-primary{
  background:linear-gradient(135deg,var(--emerald),var(--mint));
  color:var(--ice-black);
  box-shadow:0 0 0 rgba(16,185,129,.4);
}
.btn-primary:hover{box-shadow:0 0 30px rgba(16,185,129,.6);transform:translateY(-2px);color:var(--ice-black)}
.btn-ghost{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.15);color:var(--ice-white)}
.btn-ghost:hover{border-color:var(--emerald);color:var(--mint)}
.btn-outline{background:transparent;border:1px solid var(--emerald);color:var(--emerald)}
.btn-outline:hover{background:var(--emerald);color:var(--ice-black)}
.btn-block{display:block;width:100%;margin-top:18px}
.btn::after{
  content:'';position:absolute;top:50%;left:50%;width:0;height:0;
  background:rgba(255,255,255,.4);border-radius:50%;
  transform:translate(-50%,-50%);transition:width .5s,height .5s;
}
.btn:active::after{width:300px;height:300px}

/* Age Notice Strip */
.age-notice{
  background:var(--polar-night);
  border-bottom:1px solid rgba(16,185,129,.25);
  color:var(--mint);
  text-align:center;
  font-size:.78rem;
  padding:8px 16px;
  letter-spacing:.5px;
}

/* Header — now flows with the page (not fixed) */
#siteHeader{
  position:absolute;
  top:32px;left:0;right:0;
  z-index:99;
  padding:18px 0;
  transition:background .35s, border-color .35s, box-shadow .35s;
  background:transparent;
  border-bottom:1px solid transparent;
}
/* keep the .scrolled class harmless if any leftover JS toggles it */
#siteHeader.scrolled{
  background:transparent;
  backdrop-filter:none;
  border-bottom:1px solid transparent;
  box-shadow:none;
}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;gap:24px}
.logo{
  font-family:'Playfair Display',serif;
  font-weight:700;
  font-size:1.4rem;
  letter-spacing:2px;
  color:var(--ice-white);
}
.logo span{color:var(--emerald);font-size:.8rem;margin-left:4px}
#navMenu{display:flex;gap:28px}
#navMenu a{font-size:.9rem;font-weight:500;letter-spacing:.5px;color:var(--ice-white);position:relative;padding:6px 0}
#navMenu a.active,#navMenu a:hover{color:var(--mint)}
#navMenu a.active::after,#navMenu a:hover::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:var(--emerald);
  box-shadow:0 0 8px var(--emerald);
}
.menu-toggle{display:none;background:transparent;border:none;cursor:pointer;width:30px;height:30px;flex-direction:column;justify-content:center;gap:5px}
.menu-toggle span{display:block;width:100%;height:2px;background:var(--ice-white);transition:.3s}
@media(max-width:1024px){
  #navMenu{
    position:absolute;top:100%;right:-100%;width:80%;max-width:320px;
    background:var(--polar-night);flex-direction:column;justify-content:flex-start;
    padding:30px 32px;transition:right .4s;border-left:1px solid rgba(16,185,129,.3);
    border-bottom:1px solid rgba(16,185,129,.3);
  }
  #navMenu.open{right:0}
  .menu-toggle{display:flex}
  .nav-wrap .btn-primary{display:none}
}

/* Hero */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:center;
  overflow:hidden;
  padding-top:100px;
}
.hero-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  z-index:1;
  transform:scale(1.05);
  animation:slowZoom 18s 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(2,6,23,.92),rgba(2,12,27,.78),rgba(16,185,129,.18));
  z-index:2;
}
.hero-content{position:relative;z-index:3;max-width:780px}
.hero-content h1{margin-bottom:22px}
.hero-content p{font-size:1.15rem;color:var(--ice-white);opacity:.85;margin-bottom:34px;max-width:620px}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap}
.scroll-indicator{
  position:absolute;bottom:30px;left:50%;transform:translateX(-50%);
  width:1px;height:50px;background:rgba(255,255,255,.15);z-index:3;
}
.scroll-indicator span{
  position:absolute;top:0;left:0;right:0;height:30%;background:var(--emerald);
  animation:scrollLine 2s ease-in-out infinite;
}
@keyframes scrollLine{0%,100%{top:0}50%{top:70%}}

/* Page hero */
.page-hero{
  position:relative;
  min-height:55vh;
  display:flex;align-items:center;
  background-size:cover;background-position:center;background-attachment:fixed;
  padding-top:140px;padding-bottom:80px;
}
.page-hero.short{min-height:42vh}
.page-hero .hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(2,6,23,.92),rgba(2,12,27,.7))}
.page-hero .container{position:relative;z-index:2}
.page-hero h1{margin-bottom:14px}
.page-hero p{font-size:1.1rem;color:var(--ice-white);opacity:.85}
.legal-hero{background:var(--gradient);min-height:36vh}

/* Sections */
.section-head{text-align:center;margin-bottom:60px;max-width:760px;margin-left:auto;margin-right:auto}

/* Split */
.split-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;
}
.split-grid.reverse{direction:rtl}
.split-grid.reverse>*{direction:ltr}
.split-image{position:relative}
.split-image img{width:100%;height:540px;object-fit:cover;border:1px solid rgba(16,185,129,.2)}
.floating-card{
  position:absolute;bottom:-30px;left:-30px;
  background:var(--polar-night);
  border:1px solid rgba(16,185,129,.4);
  padding:22px 28px;
  box-shadow:0 0 40px rgba(16,185,129,.15);
}
.floating-card h4{font-size:1.5rem;color:var(--emerald);margin-bottom:4px}
.floating-card p{margin:0;font-size:.85rem}
@media(max-width:900px){
  .split-grid{grid-template-columns:1fr;gap:50px}
  .split-grid.reverse{direction:ltr}
  .split-image img{height:360px}
  .floating-card{left:0}
}

/* Grids */
.grid-5{display:grid;grid-template-columns:repeat(5,1fr);gap:24px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:30px}
@media(max-width:1024px){.grid-5{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.grid-5,.grid-3,.grid-2{grid-template-columns:1fr}}

/* Glass cards */
.glass-card{
  background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.02));
  border:1px solid rgba(16,185,129,.18);
  padding:32px 26px;
  backdrop-filter:blur(10px);
  transition:all .35s;
  position:relative;
}
.glass-card:hover{
  border-color:rgba(16,185,129,.6);
  transform:translateY(-4px);
  box-shadow:0 0 30px rgba(16,185,129,.18);
}
.glass-card img{width:100%;height:200px;object-fit:cover;margin-bottom:18px}
.icon-box{
  width:50px;height:50px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(16,185,129,.12);
  border:1px solid rgba(16,185,129,.4);
  font-size:1.5rem;margin-bottom:18px;
}

/* Parallax section */
.parallax-section{
  position:relative;background-size:cover;background-position:center;background-attachment:fixed;
  min-height:480px;display:flex;align-items:center;
}
.parallax-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(2,6,23,.92),rgba(16,185,129,.25))}
.parallax-content{position:relative;z-index:2;max-width:680px}
.parallax-content h2{margin-bottom:18px}

/* Testimonials */
.testimonial p{font-size:1.05rem;color:var(--ice-white);font-style:italic;margin-bottom:14px}
.testimonial strong{color:var(--emerald);font-style:normal}

/* SEO Block */
.seo-block{background:var(--polar-night);border-top:1px solid rgba(16,185,129,.18);border-bottom:1px solid rgba(16,185,129,.18)}
.seo-block .container{max-width:880px;text-align:center}

/* Rooms */
.rooms-list{display:flex;flex-direction:column;gap:80px}
.room-card{display:grid;grid-template-columns:1.2fr 1fr;gap:50px;align-items:center}
.room-card.reverse{direction:rtl}
.room-card.reverse>*{direction:ltr}
.room-image img{width:100%;height:480px;object-fit:cover;border:1px solid rgba(16,185,129,.2)}
.room-info ul{list-style:none;margin:18px 0 28px}
.room-info ul li{padding:10px 0;border-bottom:1px solid rgba(255,255,255,.08);color:var(--steel)}
.room-info ul li::before{content:'◆ ';color:var(--emerald);margin-right:8px}
@media(max-width:900px){.room-card{grid-template-columns:1fr}.room-card.reverse{direction:ltr}.room-image img{height:340px}}

/* Check list */
.check-list{list-style:none;margin:18px 0 24px}
.check-list li{padding:8px 0;color:var(--steel);position:relative;padding-left:28px}
.check-list li::before{content:'✓';position:absolute;left:0;color:var(--emerald);font-weight:700}

/* Disclaimer */
.disclaimer-box{
  background:linear-gradient(135deg,rgba(16,185,129,.08),rgba(2,12,27,.4));
  border:1px solid rgba(16,185,129,.4);padding:50px;text-align:center;
}
.disclaimer-box h2{color:var(--emerald)}

/* Booking */
.booking-wrap{display:grid;grid-template-columns:2fr 1fr;gap:40px;align-items:start}
.booking-form{padding:40px}
.booking-form label{display:block;margin-bottom:18px;font-size:.85rem;color:var(--steel);text-transform:uppercase;letter-spacing:1px;font-weight:600}
.booking-form input,.booking-form select,.booking-form textarea{
  width:100%;margin-top:8px;padding:14px;
  background:rgba(2,6,23,.7);border:1px solid rgba(16,185,129,.25);
  color:var(--ice-white);font-family:inherit;font-size:1rem;text-transform:none;
}
.booking-form input:focus,.booking-form select:focus,.booking-form textarea:focus{
  outline:none;border-color:var(--emerald);box-shadow:0 0 0 3px rgba(16,185,129,.15);
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:600px){.form-row{grid-template-columns:1fr}.booking-wrap{grid-template-columns:1fr}}
.summary{padding:34px;position:sticky;top:120px}
.summary h3{color:var(--emerald);margin-bottom:18px}
.summary p{display:flex;justify-content:space-between;color:var(--ice-white);margin-bottom:8px}
.summary hr{border:none;border-top:1px solid rgba(255,255,255,.08);margin:14px 0}
.summary .total{font-size:1.4rem;font-weight:700;color:var(--mint)}

/* Modal */
.modal{
  position:fixed;inset:0;background:rgba(2,6,23,.85);
  display:none;align-items:center;justify-content:center;z-index:200;padding:20px;
  backdrop-filter:blur(6px);
}
.modal.show{display:flex;animation:fadeIn .35s ease}
.modal-inner{max-width:460px;text-align:center;padding:50px 36px}
.modal-inner h2{color:var(--emerald);margin-bottom:14px}

/* Legal pages */
.legal-content{max-width:820px}
.legal-content h2{margin-top:40px;color:var(--mint);font-size:1.5rem}
.legal-content h2:first-child{margin-top:0}

/* Footer */
footer{background:var(--polar-night);padding:80px 0 30px;border-top:1px solid rgba(16,185,129,.2);margin-top:80px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:50px}
.footer-grid h3{margin-bottom:18px}
.footer-grid h4{color:var(--emerald);text-transform:uppercase;letter-spacing:2px;font-size:.8rem;margin-bottom:18px;font-family:'Inter',sans-serif;font-weight:700}
.footer-grid a{display:block;color:var(--steel);font-size:.92rem;padding:6px 0}
.footer-grid p{font-size:.92rem;color:var(--steel)}
.foot-bottom{margin-top:50px;padding-top:24px;border-top:1px solid rgba(255,255,255,.06);text-align:center}
.foot-bottom p{font-size:.8rem;color:var(--steel);margin:0}
@media(max-width:900px){.footer-grid{grid-template-columns:1fr 1fr;gap:40px}}
@media(max-width:600px){.footer-grid{grid-template-columns:1fr}}

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