/* ===== Reset & Base ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{
  font-family:'Inter',sans-serif;
  background:#05060f;
  color:#e8eaf2;
  overflow-x:hidden;
  line-height:1.6;
}

:root{
  --bg:#05060f;
  --bg-2:#0a0c1c;
  --text:#e8eaf2;
  --muted:#9aa0b4;
  --glass:rgba(255,255,255,0.06);
  --glass-border:rgba(255,255,255,0.12);
  --purple:#a855f7;
  --cyan:#22d3ee;
  --gold:#f5c945;
  --pink:#ec4899;
  --green:#4ade80;
  --accent:var(--purple);
}

body[data-theme="purple"]{--accent:#a855f7}
body[data-theme="cyan"]{--accent:#22d3ee}
body[data-theme="gold"]{--accent:#f5c945}
body[data-theme="pink"]{--accent:#ec4899}
body[data-theme="green"]{--accent:#4ade80}

img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}

.container{max-width:1300px;margin:0 auto;padding:0 28px}

/* ===== Typography ===== */
h1,h2,h3,h4,h5{font-family:'Cormorant Garamond',serif;font-weight:500;letter-spacing:-0.01em;line-height:1.15}
.gradient-text{
  background:linear-gradient(135deg,#a855f7 0%,#22d3ee 50%,#f5c945 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  background-size:200% 200%;
  animation:gradientShift 8s ease infinite;
}
@keyframes gradientShift{
  0%,100%{background-position:0% 50%}
  50%{background-position:100% 50%}
}

/* ===== Loader ===== */
.loader{
  position:fixed;inset:0;background:#05060f;z-index:10000;
  display:flex;align-items:center;justify-content:center;
  transition:opacity .8s ease,visibility .8s ease;
}
.loader.hidden{opacity:0;visibility:hidden}
.loader-inner{text-align:center}
.loader-ring{
  width:80px;height:80px;margin:0 auto 24px;
  border:2px solid rgba(255,255,255,0.1);
  border-top-color:#a855f7;border-right-color:#22d3ee;
  border-radius:50%;
  animation:spin 1.1s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}
.loader-text{font-family:'Cormorant Garamond',serif;font-size:22px;letter-spacing:8px;color:#e8eaf2}

/* ===== Cursor Glow ===== */
.cursor-glow{
  position:fixed;width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle,rgba(168,85,247,0.18) 0%,transparent 60%);
  pointer-events:none;z-index:1;transform:translate(-50%,-50%);
  transition:opacity .3s ease;mix-blend-mode:screen;
  left:-500px;top:-500px;
}
@media(max-width:768px){.cursor-glow{display:none}}

/* ===== Navbar ===== */
.navbar{
  position:fixed;top:20px;left:50%;transform:translateX(-50%);
  width:calc(100% - 40px);max-width:1300px;z-index:1000;
  transition:all .4s cubic-bezier(.2,.8,.2,1);
}
.nav-container{
  background:rgba(10,12,28,0.55);
  backdrop-filter:blur(24px) saturate(1.4);
  -webkit-backdrop-filter:blur(24px) saturate(1.4);
  border:1px solid rgba(255,255,255,0.1);
  border-radius:100px;
  padding:14px 28px;
  display:flex;align-items:center;justify-content:space-between;
  box-shadow:0 20px 60px -20px rgba(0,0,0,0.5), inset 0 1px 0 rgba(255,255,255,0.08);
  position:relative;overflow:hidden;
}
.nav-container::before{
  content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,0.04),transparent);
  animation:navShine 8s ease-in-out infinite;
}
@keyframes navShine{0%,100%{left:-100%}50%{left:100%}}
.navbar.scrolled{top:10px}
.navbar.scrolled .nav-container{padding:10px 24px;background:rgba(10,12,28,0.85)}

.logo{display:flex;align-items:center;gap:10px;font-family:'Cormorant Garamond',serif}
.logo-mark{color:var(--accent);font-size:22px;text-shadow:0 0 20px currentColor}
.logo-text{font-size:22px;letter-spacing:.5px;font-weight:500}

.nav-menu{display:flex;gap:36px}
.nav-menu a{
  font-size:14px;letter-spacing:.5px;color:rgba(232,234,242,0.8);
  transition:all .3s ease;position:relative;
}
.nav-menu a::after{
  content:'';position:absolute;bottom:-6px;left:50%;width:0;height:1px;
  background:var(--accent);transition:all .3s ease;transform:translateX(-50%);
  box-shadow:0 0 8px currentColor;
}
.nav-menu a:hover{color:#fff;text-shadow:0 0 16px rgba(168,85,247,0.6)}
.nav-menu a:hover::after{width:24px}

.nav-toggle{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:8px}
.nav-toggle span{width:24px;height:2px;background:#fff;transition:all .3s ease;border-radius:2px}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media(max-width:900px){
  .nav-toggle{display:flex}
  .nav-menu{
    position:fixed;top:90px;left:20px;right:20px;
    flex-direction:column;gap:24px;padding:32px;
    background:rgba(10,12,28,0.95);backdrop-filter:blur(24px);
    border:1px solid rgba(255,255,255,0.1);border-radius:24px;
    transform:translateY(-20px);opacity:0;pointer-events:none;
    transition:all .4s cubic-bezier(.2,.8,.2,1);
  }
  .nav-menu.open{transform:translateY(0);opacity:1;pointer-events:auto}
}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 28px;border-radius:100px;font-size:14px;font-weight:500;
  letter-spacing:.5px;cursor:pointer;border:none;
  transition:all .35s cubic-bezier(.2,.8,.2,1);
  position:relative;overflow:hidden;text-align:center;
}
.btn-primary{
  background:linear-gradient(135deg,var(--accent),#7c3aed);
  color:#fff;
  box-shadow:0 10px 30px -10px var(--accent),inset 0 1px 0 rgba(255,255,255,0.3);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 20px 40px -10px var(--accent)}
.btn-outline{background:rgba(255,255,255,0.05);color:#fff;border:1px solid rgba(255,255,255,0.15)}
.btn-outline:hover{background:rgba(255,255,255,0.1);border-color:var(--accent);box-shadow:0 0 24px -4px var(--accent)}
.btn-ghost{background:transparent;color:#fff;border:1px solid rgba(255,255,255,0.2)}
.btn-ghost:hover{background:rgba(255,255,255,0.06);border-color:#fff}
.btn-lg{padding:18px 36px;font-size:15px}
.btn-block{width:100%}

/* ===== Hero ===== */
.hero{
  position:relative;min-height:100vh;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;text-align:center;padding:120px 20px 80px;
}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg-image{
  width:100%;height:100%;object-fit:cover;
  animation:slowZoom 20s ease-in-out infinite alternate;
}
@keyframes slowZoom{from{transform:scale(1)}to{transform:scale(1.15)}}
.hero-overlay{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse at top,transparent 0%,rgba(5,6,15,0.6) 50%,rgba(5,6,15,0.95) 100%),
    linear-gradient(180deg,rgba(5,6,15,0.3) 0%,rgba(5,6,15,0.85) 100%);
}
.hero-shine{
  position:absolute;inset:0;
  background:linear-gradient(115deg,transparent 40%,rgba(255,255,255,0.08) 50%,transparent 60%);
  animation:shine 6s ease-in-out infinite;
}
@keyframes shine{
  0%{transform:translateX(-100%)}
  100%{transform:translateX(100%)}
}
.hero-particles{position:absolute;inset:0;overflow:hidden}
.particle{
  position:absolute;width:4px;height:4px;border-radius:50%;
  background:rgba(255,255,255,0.6);
  box-shadow:0 0 10px rgba(168,85,247,0.8);
  animation:float linear infinite;
}
@keyframes float{
  0%{transform:translateY(100vh) translateX(0);opacity:0}
  10%{opacity:1}
  90%{opacity:1}
  100%{transform:translateY(-100px) translateX(30px);opacity:0}
}

.hero-content{position:relative;z-index:2;max-width:900px}
.hero-badge{
  display:inline-block;padding:10px 20px;margin-bottom:32px;
  background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.15);
  border-radius:100px;backdrop-filter:blur(12px);
  font-size:12px;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,0.85);
}
.hero-title{font-size:clamp(42px,7vw,96px);margin-bottom:24px;font-weight:400}
.hero-subtitle{font-size:clamp(16px,2vw,20px);color:rgba(232,234,242,0.75);margin-bottom:48px;font-weight:300}
.hero-cta{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

.scroll-indicator{
  position:absolute;bottom:40px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:12px;
  font-size:10px;letter-spacing:3px;color:rgba(255,255,255,0.5);z-index:2;
}
.scroll-line{
  width:1px;height:40px;background:linear-gradient(to bottom,var(--accent),transparent);
  animation:scrollDown 2s ease-in-out infinite;
}
@keyframes scrollDown{0%,100%{transform:scaleY(0.3);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}}

/* ===== Sections ===== */
section{position:relative;padding:120px 0}
.section-header{text-align:center;max-width:700px;margin:0 auto 80px}
.section-tag{
  display:inline-block;margin-bottom:20px;padding:8px 18px;
  background:rgba(168,85,247,0.12);border:1px solid rgba(168,85,247,0.25);
  border-radius:100px;font-size:11px;letter-spacing:3px;text-transform:uppercase;
  color:var(--accent);
}
.section-title{font-size:clamp(36px,5vw,64px);margin-bottom:20px;font-weight:400}
.section-subtitle{font-size:17px;color:var(--muted);font-weight:300}

/* ===== Hotels Grid ===== */
.hotels-section{background:linear-gradient(180deg,#05060f 0%,#0a0c1c 100%)}
.hotels-grid{
  display:grid;gap:32px;
  grid-template-columns:repeat(3,1fr);
}
@media(max-width:1024px){.hotels-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.hotels-grid{grid-template-columns:1fr}}

.hotel-card{
  position:relative;border-radius:24px;overflow:hidden;
  background:linear-gradient(145deg,rgba(255,255,255,0.06),rgba(255,255,255,0.02));
  backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,0.1);
  transition:all .5s cubic-bezier(.2,.8,.2,1);
  display:flex;flex-direction:column;
}
.hotel-card::before{
  content:'';position:absolute;inset:-1px;border-radius:24px;padding:1px;
  background:linear-gradient(135deg,transparent,var(--card-glow,#a855f7),transparent);
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:0;transition:opacity .5s ease;pointer-events:none;
}
.hotel-card[data-glow="purple"]{--card-glow:#a855f7}
.hotel-card[data-glow="gold"]{--card-glow:#f5c945}
.hotel-card[data-glow="cyan"]{--card-glow:#22d3ee}
.hotel-card[data-glow="pink"]{--card-glow:#ec4899}
.hotel-card[data-glow="green"]{--card-glow:#4ade80}

.hotel-card:hover{
  transform:translateY(-8px) scale(1.01);
  box-shadow:0 40px 80px -20px rgba(0,0,0,0.6),0 0 60px -10px var(--card-glow,#a855f7);
}
.hotel-card:hover::before{opacity:1}

.card-image{position:relative;aspect-ratio:4/3;overflow:hidden}
.card-image img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1s cubic-bezier(.2,.8,.2,1);
}
.hotel-card:hover .card-image img{transform:scale(1.12)}
.card-shine{
  position:absolute;inset:0;
  background:linear-gradient(115deg,transparent 40%,rgba(255,255,255,0.3) 50%,transparent 60%);
  transform:translateX(-100%);transition:transform .8s ease;
  pointer-events:none;
}
.hotel-card:hover .card-shine{transform:translateX(100%)}

.card-rating{
  position:absolute;top:16px;right:16px;
  background:rgba(0,0,0,0.6);backdrop-filter:blur(12px);
  color:var(--gold);padding:6px 14px;border-radius:100px;
  font-size:13px;font-weight:600;border:1px solid rgba(245,201,69,0.3);
}

.card-body{padding:28px;flex:1;display:flex;flex-direction:column}
.card-location{font-size:12px;color:var(--muted);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:10px}
.card-title{font-size:28px;margin-bottom:12px;font-weight:500}
.card-desc{color:var(--muted);font-size:14px;margin-bottom:24px;flex:1}
.card-footer{margin-bottom:20px;padding-top:20px;border-top:1px solid rgba(255,255,255,0.08)}
.card-price{display:flex;align-items:baseline;gap:8px}
.card-price span{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:1px}
.card-price strong{font-family:'Cormorant Garamond',serif;font-size:32px;color:#fff;font-weight:500}
.card-actions{display:flex;gap:10px}
.card-actions .btn{flex:1;padding:12px 16px;font-size:13px}

.feature-card{
  background:linear-gradient(145deg,rgba(168,85,247,0.15),rgba(34,211,238,0.08));
  border:1px solid rgba(168,85,247,0.3);
  display:flex;align-items:center;justify-content:center;text-align:center;padding:48px 32px;
}
.feature-content h3{font-size:38px;margin-bottom:16px}
.feature-content p{color:var(--muted);margin-bottom:24px;font-size:15px}

/* ===== Why Section ===== */
.why-section{background:#05060f}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
@media(max-width:900px){.why-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:500px){.why-grid{grid-template-columns:1fr}}
.why-card{
  padding:36px 28px;text-align:center;border-radius:20px;
  background:rgba(255,255,255,0.04);backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,0.08);
  transition:all .4s ease;
}
.why-card:hover{
  transform:translateY(-6px);
  background:rgba(255,255,255,0.07);
  border-color:rgba(168,85,247,0.4);
  box-shadow:0 20px 50px -15px rgba(168,85,247,0.3);
}
.why-icon{
  font-size:40px;color:var(--accent);margin-bottom:20px;
  filter:drop-shadow(0 0 16px currentColor);
}
.why-card h4{font-size:22px;margin-bottom:12px}
.why-card p{color:var(--muted);font-size:14px}

/* ===== Gallery ===== */
.gallery-section{background:linear-gradient(180deg,#0a0c1c,#05060f)}
.masonry{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  grid-auto-rows:200px;gap:16px;
}
.masonry-item{
  position:relative;overflow:hidden;border-radius:16px;
  border:1px solid rgba(255,255,255,0.06);
  transition:all .5s ease;cursor:pointer;
}
.masonry-item img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.masonry-item::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(168,85,247,0.3),transparent);
  opacity:0;transition:opacity .4s ease;
}
.masonry-item:hover::after{opacity:1}
.masonry-item:hover img{transform:scale(1.1)}
.masonry-item:hover{box-shadow:0 20px 50px -15px rgba(168,85,247,0.4)}
.masonry-item.tall{grid-row:span 2}
.masonry-item.wide{grid-column:span 2}
@media(max-width:900px){.masonry{grid-template-columns:repeat(2,1fr)}}

/* ===== Testimonials ===== */
.testimonials-section{background:#05060f}
.testimonial-slider{position:relative;overflow:hidden;max-width:800px;margin:0 auto}
.testimonial-track{display:flex;transition:transform .7s cubic-bezier(.2,.8,.2,1)}
.testimonial-card{
  min-width:100%;padding:48px;text-align:center;
  background:linear-gradient(145deg,rgba(255,255,255,0.06),rgba(255,255,255,0.02));
  backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,0.1);
  border-radius:24px;box-shadow:0 0 40px -10px rgba(168,85,247,0.3);
}
.testimonial-card .stars{color:var(--gold);font-size:20px;margin-bottom:20px;letter-spacing:4px}
.testimonial-card p{
  font-family:'Cormorant Garamond',serif;font-size:24px;font-style:italic;
  margin-bottom:24px;color:#fff;line-height:1.5;
}
.author strong{display:block;font-size:14px;letter-spacing:1px}
.author span{font-size:12px;color:var(--muted)}
.slider-dots{display:flex;justify-content:center;gap:10px;margin-top:32px}
.slider-dots button{
  width:10px;height:10px;border-radius:50%;border:none;
  background:rgba(255,255,255,0.2);cursor:pointer;transition:all .3s ease;
}
.slider-dots button.active{background:var(--accent);width:30px;border-radius:100px;box-shadow:0 0 12px currentColor}

/* ===== About ===== */
.about-section{background:linear-gradient(180deg,#05060f,#0a0c1c)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
@media(max-width:900px){.about-grid{grid-template-columns:1fr;gap:48px}}
.about-image{position:relative;border-radius:24px;overflow:hidden;aspect-ratio:4/5}
.about-image img{width:100%;height:100%;object-fit:cover}
.about-image-glow{
  position:absolute;inset:-40px;z-index:-1;
  background:radial-gradient(circle,rgba(168,85,247,0.3),transparent 70%);
  filter:blur(40px);
}
.about-content .section-tag{margin-bottom:20px}
.about-content p{color:var(--muted);font-size:16px;margin-bottom:20px}
.about-stats{display:flex;gap:40px;margin-top:40px;flex-wrap:wrap}
.about-stats strong{display:block;font-family:'Cormorant Garamond',serif;font-size:44px;color:#fff;font-weight:500}
.about-stats span{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:1px}

/* ===== Contact ===== */
.contact-section,.contact-page{background:#05060f}
.contact-page{padding-top:180px}
.contact-form{
  max-width:700px;margin:0 auto;padding:48px;
  background:linear-gradient(145deg,rgba(255,255,255,0.06),rgba(255,255,255,0.02));
  backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,0.1);
  border-radius:24px;
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:600px){.form-row{grid-template-columns:1fr}.contact-form{padding:32px 24px}}
.form-group{margin-bottom:24px}
.form-group label{display:block;font-size:12px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin-bottom:10px}
.form-group input,.form-group select,.form-group textarea{
  width:100%;padding:14px 18px;
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.1);
  border-radius:12px;color:#fff;font-family:inherit;font-size:15px;
  transition:all .3s ease;
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{
  outline:none;border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(168,85,247,0.15),0 0 24px -6px var(--accent);
  background:rgba(255,255,255,0.06);
}
.form-group select{cursor:pointer}
.form-group select option{background:#0a0c1c}
.form-group textarea{resize:vertical;font-family:inherit}

/* ===== Hotel Page ===== */
.hotel-hero{
  position:relative;min-height:75vh;display:flex;align-items:flex-end;
  padding:160px 20px 80px;overflow:hidden;
}
.hotel-hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;animation:slowZoom 20s ease-in-out infinite alternate}
.hotel-hero-overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(5,6,15,0.4) 0%,rgba(5,6,15,0.9) 100%);
}
.hotel-hero-content{position:relative;z-index:2;max-width:1300px;margin:0 auto;width:100%;padding:0 8px}
.hotel-hero-title{font-size:clamp(48px,8vw,100px);margin:20px 0 16px;font-weight:400}
.hotel-hero-sub{font-size:20px;color:rgba(255,255,255,0.8);max-width:600px;font-weight:300}

.hotel-gallery{background:#05060f;padding:80px 0}
.carousel{position:relative;border-radius:24px;overflow:hidden;aspect-ratio:16/9;border:1px solid rgba(255,255,255,0.1)}
.carousel-track{display:flex;width:100%;height:100%;transition:transform .7s cubic-bezier(.2,.8,.2,1)}
.carousel-track img{min-width:100%;height:100%;object-fit:cover}
.carousel-btn{
  position:absolute;top:50%;transform:translateY(-50%);
  width:52px;height:52px;border-radius:50%;
  background:rgba(0,0,0,0.6);backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,0.2);
  color:#fff;font-size:24px;cursor:pointer;z-index:2;
  transition:all .3s ease;
}
.carousel-btn:hover{background:var(--accent);border-color:var(--accent);box-shadow:0 0 24px currentColor}
.carousel-btn.prev{left:20px}
.carousel-btn.next{right:20px}

.hotel-info{background:linear-gradient(180deg,#05060f,#0a0c1c);padding:80px 0 120px}
.info-grid{display:grid;grid-template-columns:2fr 1fr;gap:60px;align-items:flex-start}
@media(max-width:900px){.info-grid{grid-template-columns:1fr}}
.info-main .section-title{text-align:left;margin-bottom:24px}
.info-main p{color:var(--muted);margin-bottom:20px;font-size:16px}
.sub-title{font-size:28px;margin:48px 0 20px}
.amenities{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:32px}
.amenity{
  padding:14px 18px;background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.08);border-radius:12px;
  font-size:14px;color:#e8eaf2;transition:all .3s ease;
}
.amenity:hover{border-color:var(--accent);background:rgba(255,255,255,0.08)}
.reviews{display:grid;gap:16px}
.review-card{
  padding:24px;background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.08);border-radius:16px;
}
.review-card .stars{color:var(--gold);margin-bottom:12px;letter-spacing:3px}
.review-card p{font-family:'Cormorant Garamond',serif;font-size:18px;font-style:italic;color:#fff;margin-bottom:12px}
.review-card strong{font-size:13px;color:var(--muted)}

.info-side{position:sticky;top:110px;display:flex;flex-direction:column;gap:24px}
.booking-card,.map-card{
  padding:32px;border-radius:20px;
  background:linear-gradient(145deg,rgba(255,255,255,0.06),rgba(255,255,255,0.02));
  backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,0.1);
  box-shadow:0 20px 50px -20px rgba(0,0,0,0.4);
}
.price-tag{text-align:center;margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid rgba(255,255,255,0.08)}
.price-tag span{display:block;font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:1px}
.price-tag strong{font-family:'Cormorant Garamond',serif;font-size:56px;color:#fff;font-weight:500;display:block;line-height:1;margin:8px 0}
.price-tag em{font-style:normal;font-size:13px;color:var(--muted)}
.booking-features{margin-bottom:24px}
.booking-features li{padding:8px 0;color:var(--muted);font-size:14px;border-bottom:1px solid rgba(255,255,255,0.04)}
.booking-features li:last-child{border:none}
.booking-card .btn{margin-bottom:12px}
.map-card h4{font-size:22px;margin-bottom:16px}
.map-placeholder{
  position:relative;aspect-ratio:4/3;border-radius:12px;overflow:hidden;
  margin-bottom:16px;border:1px solid rgba(255,255,255,0.08);
}
.map-placeholder img{width:100%;height:100%;object-fit:cover;filter:saturate(0.6) brightness(0.7)}
.map-pin{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  font-size:32px;filter:drop-shadow(0 4px 12px rgba(0,0,0,0.6));
  animation:pinBounce 2s ease-in-out infinite;
}
@keyframes pinBounce{0%,100%{transform:translate(-50%,-50%)}50%{transform:translate(-50%,-60%)}}
.map-card p{color:var(--muted);font-size:14px}

/* ===== Legal Pages (Privacy / Terms) ===== */
.legal-page{background:#05060f;padding-top:180px;padding-bottom:120px}
.legal-content{
  max-width:820px;margin:0 auto;padding:56px;
  background:linear-gradient(145deg,rgba(255,255,255,0.05),rgba(255,255,255,0.02));
  backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,0.1);
  border-radius:24px;
  box-shadow:0 20px 50px -20px rgba(0,0,0,0.4);
}
.legal-content h3{
  font-size:28px;margin:40px 0 16px;color:#fff;
  padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,0.08);
}
.legal-content h3:first-child{margin-top:0}
.legal-content p{color:var(--muted);font-size:15.5px;margin-bottom:16px;line-height:1.75}
.legal-content a{color:var(--accent);transition:all .3s ease;border-bottom:1px solid transparent}
.legal-content a:hover{border-bottom-color:var(--accent);text-shadow:0 0 12px currentColor}
.legal-list{list-style:none;margin:0 0 20px;padding:0}
.legal-list li{
  position:relative;padding:8px 0 8px 26px;
  color:var(--muted);font-size:15px;line-height:1.65;
}
.legal-list li::before{
  content:'✦';position:absolute;left:0;top:8px;
  color:var(--accent);font-size:13px;
}
.legal-contact{
  margin-top:16px;padding:20px 24px;
  background:rgba(168,85,247,0.06);
  border:1px solid rgba(168,85,247,0.18);
  border-radius:14px;color:var(--text);
}
@media(max-width:640px){
  .legal-content{padding:32px 24px}
  .legal-content h3{font-size:22px}
}

/* ===== Footer ===== */
.footer{background:#03040a;border-top:1px solid rgba(255,255,255,0.06);padding:80px 0 30px;position:relative}
.footer::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(168,85,247,0.5),transparent);
}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:60px}
@media(max-width:900px){.footer-grid{grid-template-columns:1fr 1fr;gap:40px 24px}}
@media(max-width:500px){.footer-grid{grid-template-columns:1fr}}
.footer-col p{color:var(--muted);font-size:14px;margin:16px 0 20px;max-width:300px}
.footer-col h5{font-size:14px;letter-spacing:2px;text-transform:uppercase;margin-bottom:20px;color:#fff}
.footer-col ul li{padding:6px 0;color:var(--muted);font-size:14px}
.footer-col ul li a{transition:color .3s ease}
.footer-col ul li a:hover{color:var(--accent)}
.social{display:flex;gap:12px}
.social a{
  width:40px;height:40px;display:flex;align-items:center;justify-content:center;
  border-radius:50%;border:1px solid rgba(255,255,255,0.1);
  background:rgba(255,255,255,0.03);transition:all .3s ease;font-size:14px;
}
.social a:hover{border-color:var(--accent);color:var(--accent);box-shadow:0 0 16px -2px var(--accent);transform:translateY(-2px)}
.footer-bottom{
  padding-top:30px;border-top:1px solid rgba(255,255,255,0.06);
  display:flex;justify-content:space-between;align-items:center;
  font-size:13px;color:var(--muted);flex-wrap:wrap;gap:12px;
}
.footer-bottom a{margin:0 6px}
.footer-bottom a:hover{color:var(--accent)}

/* ===== Reveal animations ===== */
.reveal{opacity:0;transform:translateY(40px);transition:all .9s cubic-bezier(.2,.8,.2,1)}
.reveal.visible{opacity:1;transform:translateY(0)}