/* ═══════════════════════════════════════════════════
   VILLA ST. BENEDICT — Multi-Page Luxury System v2
   Dark Navy Glassmorphic Premium Design
   ═══════════════════════════════════════════════════ */

/* ─── Design Tokens ─── */
:root {
  --navy-abyss: #040b15;
  --navy-deepest: #060e1a;
  --navy-deep: #0a1628;
  --navy-base: #0f1d35;
  --navy-mid: #162544;
  --navy-light: #1e3055;
  --steel: #3a6b8a;
  --steel-light: #5a92b5;
  --gold: #c9a96e;
  --gold-light: #dfc496;
  --gold-dim: rgba(201,169,110,0.12);
  --silver: #b8c5d0;
  --silver-muted: #8a99a8;
  --white: #f0f4f8;
  --white-pure: #fff;
  --glass-bg: rgba(12,24,45,0.55);
  --glass-bg-strong: rgba(12,24,45,0.75);
  --glass-border: rgba(186,200,215,0.10);
  --glass-border-hover: rgba(201,169,110,0.22);
  --glass-highlight: rgba(255,255,255,0.03);
  --glass-blur: 22px;
  --shadow-soft: 0 4px 30px rgba(0,0,0,0.25);
  --shadow-deep: 0 8px 60px rgba(0,0,0,0.4);
  --shadow-gold: 0 4px 30px rgba(201,169,110,0.12);
  --r-sm: 8px; --r-md: 16px; --r-lg: 24px;
  --ease: 0.5s cubic-bezier(0.25,0.46,0.45,0.94);
  --ease-bounce: 0.6s cubic-bezier(0.34,1.56,0.64,1);
  --font-display: 'Cormorant Garamond','Georgia',serif;
  --font-body: 'Raleway','Helvetica Neue',sans-serif;
  --font-accent: 'Cormorant',serif;
}

/* ─── Reset ─── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{font-family:var(--font-body);background:var(--navy-abyss);color:var(--silver);line-height:1.7;overflow-x:hidden;animation:pageIn .8s ease}
img{max-width:100%;height:auto;display:block}
a{color:var(--gold);text-decoration:none;transition:color var(--ease)}
a:hover{color:var(--gold-light)}
::selection{background:var(--gold);color:var(--navy-abyss)}
@keyframes pageIn{from{opacity:0}to{opacity:1}}

/* ─── Typography ─── */
h1,h2,h3,h4{font-family:var(--font-display);color:var(--white);font-weight:400;line-height:1.15}

.section-label{
  font-family:var(--font-body);font-size:.68rem;font-weight:600;
  letter-spacing:4px;text-transform:uppercase;color:var(--gold);
  margin-bottom:1rem;display:flex;align-items:center;gap:14px;
}
.section-label::before{content:'';width:40px;height:1px;background:var(--gold)}
.section-label-center{justify-content:center}
.section-label-center::before{display:none}

.section-title{font-size:clamp(2rem,5vw,3.5rem);margin-bottom:1.5rem;font-weight:300}
.section-subtitle{font-size:1.05rem;color:var(--silver-muted);max-width:560px;line-height:1.8;font-weight:300}
.text-center{text-align:center}
.mx-auto{margin-left:auto;margin-right:auto}

/* ─── Layout ─── */
.container{max-width:1280px;margin:0 auto;padding:0 2rem}
section{padding:120px 0;position:relative}

/* ─── Glass ─── */
.glass{
  background:var(--glass-bg);
  backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));
  border:1px solid var(--glass-border);border-radius:var(--r-md);box-shadow:var(--shadow-soft);
  transition:border-color var(--ease),box-shadow var(--ease);
}
.glass:hover{border-color:var(--glass-border-hover)}
.glass-strong{background:var(--glass-bg-strong);backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);border:1px solid rgba(186,200,215,0.14)}

/* ─── Animated Background ─── */
.bg-ambient{position:fixed;inset:0;z-index:-1;overflow:hidden;pointer-events:none}
.bg-ambient::before,.bg-ambient::after{
  content:'';position:absolute;border-radius:50%;filter:blur(140px);opacity:.06;
  animation:float 20s infinite ease-in-out;
}
.bg-ambient::before{width:600px;height:600px;background:var(--gold);top:-10%;left:-10%;animation-delay:0s}
.bg-ambient::after{width:500px;height:500px;background:var(--steel);bottom:-10%;right:-10%;animation-delay:-10s}
@keyframes float{
  0%,100%{transform:translate(0,0) scale(1)}
  25%{transform:translate(80px,60px) scale(1.1)}
  50%{transform:translate(-40px,120px) scale(.95)}
  75%{transform:translate(60px,-40px) scale(1.05)}
}

/* Grain overlay */
.bg-grain{
  position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.025;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ─── Reveal Animations ─── */
.reveal{opacity:0;transform:translateY(36px);transition:opacity .8s ease,transform .8s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-d1{transition-delay:.12s}.reveal-d2{transition-delay:.24s}
.reveal-d3{transition-delay:.36s}.reveal-d4{transition-delay:.48s}

/* ═══════════════════════════════════
   NAVIGATION
   ═══════════════════════════════════ */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:1.2rem 2rem;transition:all var(--ease);
}
.navbar.scrolled{
  background:rgba(4,11,21,0.92);backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);
  border-bottom:1px solid var(--glass-border);padding:.7rem 2rem;
}
.navbar-inner{max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}

.logo{display:flex;flex-direction:column}
.logo-name{font-family:var(--font-display);font-size:1.5rem;font-weight:400;color:var(--white);letter-spacing:3px;line-height:1}
.logo-tagline{font-family:var(--font-body);font-size:.52rem;letter-spacing:5px;text-transform:uppercase;color:var(--gold);font-weight:500}

.nav-links{display:flex;align-items:center;gap:2.2rem;list-style:none}
.nav-links a{
  font-family:var(--font-body);font-size:.72rem;letter-spacing:2px;text-transform:uppercase;
  color:var(--silver);font-weight:500;position:relative;padding:4px 0;transition:color var(--ease);
}
.nav-links a::after{
  content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;
  background:var(--gold);transition:width var(--ease);
}
.nav-links a:hover,.nav-links a.active{color:var(--white)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-links a.active{color:var(--gold)}

.lang-toggle{display:flex;border:1px solid var(--glass-border);border-radius:30px;overflow:hidden}
.lang-toggle a{padding:5px 13px;font-size:.68rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--silver-muted);font-weight:600;transition:all .3s}
.lang-toggle a.active{background:var(--gold);color:var(--navy-abyss)}
.lang-toggle a:hover:not(.active){color:var(--white)}

.menu-toggle{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;z-index:1001}
.menu-toggle span{width:28px;height:2px;background:var(--white);transition:all .3s}
.menu-toggle.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.menu-toggle.active span:nth-child(2){opacity:0}
.menu-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ═══════════════════════════════════
   HERO — HOME
   ═══════════════════════════════════ */
.hero{position:relative;height:100vh;min-height:700px;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:0}
.hero-video,.hero-fallback{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero-overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(4,11,21,.45) 0%,rgba(4,11,21,.25) 40%,rgba(4,11,21,.55) 75%,rgba(4,11,21,.95) 100%);
}
.hero-content{position:relative;z-index:2;text-align:center;padding:0 2rem}
.hero-eyebrow{font-family:var(--font-body);font-size:.68rem;font-weight:600;letter-spacing:6px;text-transform:uppercase;color:var(--gold);margin-bottom:1.5rem;opacity:0;animation:fadeUp 1s .5s forwards}
.hero-title{font-family:var(--font-display);font-size:clamp(2.8rem,8vw,5.5rem);font-weight:300;color:var(--white-pure);line-height:1.05;margin-bottom:1.5rem;opacity:0;animation:fadeUp 1s .8s forwards}
.hero-title em{font-style:italic;color:var(--gold)}
.hero-subtitle{font-family:var(--font-body);font-size:1.05rem;color:rgba(240,244,248,.7);max-width:520px;margin:0 auto 2.5rem;font-weight:300;line-height:1.8;opacity:0;animation:fadeUp 1s 1.1s forwards}
.hero-cta{display:flex;gap:1.2rem;justify-content:center;flex-wrap:wrap;opacity:0;animation:fadeUp 1s 1.4s forwards}
.hero-scroll{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--silver-muted);font-size:.62rem;letter-spacing:3px;text-transform:uppercase;opacity:0;animation:fadeUp 1s 1.8s forwards}
.hero-scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,var(--gold),transparent);animation:scrollPulse 2s infinite}
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
@keyframes scrollPulse{0%,100%{opacity:.3;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}

/* ═══════════════════════════════════
   PAGE HERO — Interior Pages
   ═══════════════════════════════════ */
.page-hero{
  position:relative;padding:180px 0 100px;overflow:hidden;
  background:linear-gradient(180deg,var(--navy-abyss),var(--navy-deep));
}
.page-hero-bg{
  position:absolute;inset:0;z-index:0;
  background-size:cover;background-position:center;
  opacity:.15;filter:blur(2px);
}
.page-hero .container{position:relative;z-index:1}
.page-hero .section-title{font-size:clamp(2.5rem,6vw,4rem)}

/* ═══════════════════════════════════
   BUTTONS
   ═══════════════════════════════════ */
.btn{
  display:inline-flex;align-items:center;gap:8px;padding:14px 36px;
  font-family:var(--font-body);font-size:.72rem;font-weight:600;letter-spacing:2.5px;
  text-transform:uppercase;border-radius:50px;cursor:pointer;
  transition:all var(--ease);border:none;text-decoration:none;position:relative;overflow:hidden;
}
.btn-primary{background:var(--gold);color:var(--navy-abyss)}
.btn-primary:hover{background:var(--gold-light);color:var(--navy-abyss);transform:translateY(-2px);box-shadow:var(--shadow-gold)}
.btn-outline{background:transparent;color:var(--white);border:1px solid rgba(240,244,248,.2)}
.btn-outline:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-2px)}

/* Shine sweep on hover */
.btn::after{
  content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.12),transparent);
  transition:left .6s ease;
}
.btn:hover::after{left:150%}

/* ═══════════════════════════════════
   FEATURE CARDS — Home Highlights
   ═══════════════════════════════════ */
.highlights-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.highlight-card{
  border-radius:var(--r-lg);overflow:hidden;position:relative;
  height:420px;transition:transform var(--ease);
}
.highlight-card:hover{transform:translateY(-8px)}
.highlight-card img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.highlight-card:hover img{transform:scale(1.06)}
.highlight-card-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(4,11,21,.85) 0%,rgba(4,11,21,.2) 50%,transparent 100%);
  display:flex;flex-direction:column;justify-content:flex-end;padding:2.5rem;
  transition:background var(--ease);
}
.highlight-card:hover .highlight-card-overlay{
  background:linear-gradient(to top,rgba(4,11,21,.9) 0%,rgba(4,11,21,.3) 60%,transparent 100%);
}
.highlight-card h3{font-family:var(--font-display);font-size:1.6rem;color:var(--white);margin-bottom:.5rem;font-weight:400}
.highlight-card p{font-size:.88rem;color:var(--silver);font-weight:300;line-height:1.6}
.highlight-card .btn{margin-top:1rem;padding:10px 24px;font-size:.65rem}

/* ═══════════════════════════════════
   ROOM CARDS
   ═══════════════════════════════════ */
.rooms-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.room-card{border-radius:var(--r-lg);overflow:hidden;transition:transform var(--ease);position:relative}
.room-card:hover{transform:translateY(-8px)}
.room-card::before{
  content:'';position:absolute;top:0;left:-100%;width:50%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.02),transparent);
  transition:left .8s ease;z-index:1;pointer-events:none;
}
.room-card:hover::before{left:150%}
.room-card-image{position:relative;height:300px;overflow:hidden}
.room-card-image img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.room-card:hover .room-card-image img{transform:scale(1.06)}
.room-card-body{padding:2rem}
.room-card-name{font-family:var(--font-display);font-size:1.5rem;color:var(--white);margin-bottom:.75rem;font-weight:400}
.room-card-desc{font-size:.9rem;color:var(--silver-muted);margin-bottom:1.25rem;line-height:1.7;font-weight:300}
.room-features{display:flex;flex-wrap:wrap;gap:.5rem}
.room-tag{padding:5px 14px;font-size:.62rem;letter-spacing:1px;text-transform:uppercase;border:1px solid var(--glass-border);border-radius:30px;color:var(--gold);font-weight:500;transition:all .3s}
.room-tag:hover{border-color:var(--gold);background:var(--gold-dim)}

/* ═══════════════════════════════════
   AMENITY CARDS
   ═══════════════════════════════════ */
.amenities-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.amenity-card{
  padding:2.5rem 1.5rem;text-align:center;border-radius:var(--r-md);
  transition:all var(--ease);cursor:default;
}
.amenity-card:hover{background:rgba(201,169,110,.05);border-color:var(--glass-border-hover);transform:translateY(-4px)}
.amenity-icon{width:48px;height:48px;margin:0 auto 1.25rem;display:flex;align-items:center;justify-content:center;color:var(--gold)}
.amenity-icon svg{width:30px;height:30px;stroke:var(--gold);stroke-width:1.5;fill:none}
.amenity-name{font-family:var(--font-display);font-size:1.1rem;color:var(--white);margin-bottom:.5rem;font-weight:400}
.amenity-desc{font-size:.85rem;color:var(--silver-muted);font-weight:300;line-height:1.6}

/* ═══════════════════════════════════
   GALLERY
   ═══════════════════════════════════ */
.gallery-mosaic{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:220px;gap:1rem}
.gallery-item{border-radius:var(--r-md);overflow:hidden;position:relative;cursor:pointer}
.gallery-item:nth-child(1){grid-column:span 2;grid-row:span 2}
.gallery-item:nth-child(5){grid-column:span 2}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.gallery-item:hover img{transform:scale(1.06)}
.gallery-item::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(4,11,21,.35),transparent);opacity:0;transition:opacity .4s;border-radius:var(--r-md)}
.gallery-item:hover::after{opacity:1}

.gallery-page-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;padding:0 0 100px}
.gallery-page-item{border-radius:var(--r-md);overflow:hidden;aspect-ratio:4/3;cursor:pointer;position:relative}
.gallery-page-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.gallery-page-item:hover img{transform:scale(1.05)}
.gallery-page-item:nth-child(1){grid-column:span 2;aspect-ratio:16/9}

/* ═══════════════════════════════════
   LOCATION — SVG Icons (no emoji)
   ═══════════════════════════════════ */
.poi-list{list-style:none;display:flex;flex-direction:column;gap:1.25rem;margin-top:2rem}
.poi-item{
  display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;
  border-radius:var(--r-md);background:var(--glass-highlight);border:1px solid var(--glass-border);
  transition:all .3s;
}
.poi-item:hover{border-color:var(--glass-border-hover);background:rgba(201,169,110,.03)}
.poi-icon{
  width:42px;height:42px;border-radius:50%;background:var(--gold-dim);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.poi-icon svg{width:18px;height:18px;stroke:var(--gold);stroke-width:1.5;fill:none}
.poi-name{font-family:var(--font-display);font-size:1.05rem;color:var(--white);font-weight:400}
.poi-distance{font-size:.8rem;color:var(--silver-muted);font-weight:300}

.location-map{border-radius:var(--r-lg);overflow:hidden;height:450px;border:1px solid var(--glass-border)}
.location-map iframe{width:100%;height:100%;border:0;filter:brightness(.7) contrast(1.1) saturate(.3) hue-rotate(190deg);transition:filter .5s}
.location-map:hover iframe{filter:brightness(.8) contrast(1.05) saturate(.5) hue-rotate(190deg)}

/* ═══════════════════════════════════
   TESTIMONIALS
   ═══════════════════════════════════ */
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.testimonial-card{padding:2.5rem;border-radius:var(--r-lg);position:relative}
.testimonial-card::before{content:'\201C';position:absolute;top:1.2rem;right:2rem;font-family:var(--font-display);font-size:5rem;line-height:1;color:var(--gold);opacity:.07;pointer-events:none}
.testimonial-stars{display:flex;gap:4px;margin-bottom:1.25rem;color:var(--gold);font-size:.85rem}
.testimonial-text{font-family:var(--font-accent);font-size:1.1rem;font-style:italic;color:var(--silver);line-height:1.8;margin-bottom:1.5rem}
.testimonial-author{display:flex;align-items:center;gap:1rem}
.testimonial-avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--gold-dim),var(--steel));display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:1rem;color:var(--gold)}
.testimonial-name{font-size:.88rem;color:var(--white);font-weight:500}
.testimonial-origin{font-size:.75rem;color:var(--silver-muted);font-weight:300}

/* ═══════════════════════════════════
   CONTACT FORM
   ═══════════════════════════════════ */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}
.contact-form{padding:3rem;border-radius:var(--r-lg)}
.form-group{margin-bottom:1.5rem}
.form-group label{display:block;font-size:.68rem;letter-spacing:2px;text-transform:uppercase;color:var(--silver-muted);margin-bottom:.5rem;font-weight:500}
.form-group input,.form-group textarea,.form-group select{
  width:100%;padding:14px 18px;background:rgba(255,255,255,.03);border:1px solid var(--glass-border);
  border-radius:var(--r-sm);color:var(--white);font-family:var(--font-body);font-size:.95rem;
  transition:all .3s;outline:none;
}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--gold);background:rgba(201,169,110,.03)}
.form-group textarea{resize:vertical;min-height:120px}
.form-group select option{background:var(--navy-deep);color:var(--white)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.contact-detail{display:flex;align-items:center;gap:1rem;margin-bottom:1.25rem;color:var(--silver)}
.contact-icon{width:44px;height:44px;border-radius:50%;background:var(--gold-dim);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.contact-icon svg{width:18px;height:18px;stroke:var(--gold);stroke-width:1.5;fill:none}

/* ═══════════════════════════════════
   STATS
   ═══════════════════════════════════ */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.stat{text-align:center;padding:2rem 1.5rem;border-radius:var(--r-md);background:var(--glass-highlight);border:1px solid var(--glass-border)}
.stat-number{font-family:var(--font-display);font-size:2.8rem;font-weight:400;line-height:1;margin-bottom:.3rem;background:linear-gradient(135deg,var(--gold),var(--gold-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.stat-label{font-size:.68rem;letter-spacing:2px;text-transform:uppercase;color:var(--silver-muted);font-weight:500}

/* ═══════════════════════════════════
   TWO-COL LAYOUTS
   ═══════════════════════════════════ */
.split{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.split-images{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.split-img{border-radius:var(--r-md);overflow:hidden}
.split-img:first-child{grid-row:1/3}
.split-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s}
.split-img:hover img{transform:scale(1.04)}

/* ═══════════════════════════════════
   FOOTER
   ═══════════════════════════════════ */
.footer{background:var(--navy-abyss);border-top:1px solid var(--glass-border);padding:3rem 0 2rem}
.footer-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1.5rem}
.footer-brand .logo-name{font-size:1.25rem}
.footer-copy{font-size:.78rem;color:var(--silver-muted);font-weight:300}
.footer-links{display:flex;gap:2rem;list-style:none}
.footer-links a{font-size:.72rem;letter-spacing:1px;text-transform:uppercase;color:var(--silver-muted);font-weight:500}
.footer-links a:hover{color:var(--gold)}

/* ═══════════════════════════════════
   LIGHTBOX
   ═══════════════════════════════════ */
.lightbox{position:fixed;inset:0;z-index:9999;background:rgba(4,11,21,.95);backdrop-filter:blur(20px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .4s}
.lightbox.active{opacity:1;pointer-events:all}
.lightbox img{max-width:90vw;max-height:85vh;border-radius:var(--r-md);box-shadow:var(--shadow-deep)}
.lightbox-close{position:absolute;top:2rem;right:2rem;width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.08);border:1px solid var(--glass-border);color:var(--white);font-size:1.4rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s}
.lightbox-close:hover{background:var(--gold);color:var(--navy-abyss)}
.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.06);border:1px solid var(--glass-border);color:var(--white);font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s}
.lightbox-nav:hover{background:var(--gold);color:var(--navy-abyss)}
.lightbox-prev{left:2rem}.lightbox-next{right:2rem}

/* ═══════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════ */
@media(max-width:1024px){
  .amenities-grid{grid-template-columns:repeat(2,1fr)}
  .rooms-grid,.highlights-grid{grid-template-columns:repeat(2,1fr)}
  .testimonials-grid{grid-template-columns:1fr 1fr}
  .stats-row{grid-template-columns:repeat(2,1fr)}
  .gallery-mosaic{grid-template-columns:repeat(2,1fr);grid-auto-rows:200px}
  .gallery-mosaic .gallery-item:nth-child(1){grid-column:span 2;grid-row:span 1}
  .gallery-mosaic .gallery-item:nth-child(5){grid-column:span 1}
}

@media(max-width:768px){
  section{padding:80px 0}.container{padding:0 1.25rem}
  .nav-links{position:fixed;top:0;right:-100%;width:100%;height:100vh;background:rgba(4,11,21,.97);backdrop-filter:blur(30px);flex-direction:column;justify-content:center;gap:2rem;transition:right .5s}
  .nav-links.open{right:0}
  .nav-links a{font-size:1rem;letter-spacing:3px}
  .menu-toggle{display:flex}
  .split,.contact-grid{grid-template-columns:1fr;gap:2.5rem}
  .rooms-grid,.highlights-grid{grid-template-columns:1fr}
  .amenities-grid{grid-template-columns:1fr 1fr}
  .testimonials-grid{grid-template-columns:1fr}
  .stats-row{grid-template-columns:repeat(2,1fr);gap:.75rem}
  .gallery-mosaic{grid-template-columns:1fr 1fr;grid-auto-rows:160px}
  .gallery-page-grid{grid-template-columns:1fr 1fr}
  .gallery-page-item:nth-child(1){grid-column:span 2}
  .form-row{grid-template-columns:1fr}
  .footer-inner{flex-direction:column;text-align:center}
  .footer-links{flex-wrap:wrap;justify-content:center}
  .page-hero{padding:140px 0 70px}
}

@media(max-width:480px){
  .amenities-grid,.stats-row{grid-template-columns:1fr}
  .gallery-mosaic,.gallery-page-grid{grid-template-columns:1fr;grid-auto-rows:200px}
  .gallery-mosaic .gallery-item:nth-child(1),.gallery-page-item:nth-child(1){grid-column:span 1}
  .hero-cta{flex-direction:column;align-items:center}
  .highlights-grid{grid-template-columns:1fr}
}

/* ═══════════════════════════════════
   AI CONCIERGE
   ═══════════════════════════════════ */
.concierge-btn{
  position:fixed;bottom:2rem;right:2rem;z-index:900;
  width:56px;height:56px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold),var(--gold-light));
  color:var(--navy-abyss);display:flex;align-items:center;justify-content:center;
  cursor:pointer;box-shadow:0 4px 24px rgba(201,169,110,.35);
  transition:all .4s cubic-bezier(.25,.46,.45,.94);
}
.concierge-btn:hover{transform:scale(1.08);box-shadow:0 6px 32px rgba(201,169,110,.45)}
.concierge-btn.hidden{transform:scale(0);opacity:0;pointer-events:none}

.concierge-panel{
  position:fixed;bottom:2rem;right:2rem;z-index:901;
  width:380px;max-width:calc(100vw - 2rem);height:520px;max-height:calc(100vh - 4rem);
  background:rgba(8,18,35,.92);backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);
  border:1px solid rgba(186,200,215,.12);border-radius:20px;
  display:flex;flex-direction:column;overflow:hidden;
  box-shadow:0 12px 60px rgba(0,0,0,.5);
  transform:translateY(20px) scale(.95);opacity:0;pointer-events:none;
  transition:all .4s cubic-bezier(.25,.46,.45,.94);
}
.concierge-panel.open{transform:translateY(0) scale(1);opacity:1;pointer-events:all}

.concierge-header{
  display:flex;justify-content:space-between;align-items:center;
  padding:1.25rem 1.5rem;border-bottom:1px solid rgba(186,200,215,.08);
  background:rgba(201,169,110,.04);flex-shrink:0;
}
.concierge-title{font-family:var(--font-display);font-size:1.15rem;color:var(--white);font-weight:400}
.concierge-status{font-size:.65rem;color:var(--gold);letter-spacing:1px;text-transform:uppercase;font-weight:500;margin-top:2px}
.concierge-close{background:none;border:none;color:var(--silver-muted);font-size:1.5rem;cursor:pointer;padding:4px;transition:color .3s}
.concierge-close:hover{color:var(--white)}

.concierge-messages{
  flex:1;overflow-y:auto;padding:1.25rem;display:flex;flex-direction:column;gap:.75rem;
  scrollbar-width:thin;scrollbar-color:rgba(186,200,215,.15) transparent;
}
.concierge-messages::-webkit-scrollbar{width:4px}
.concierge-messages::-webkit-scrollbar-thumb{background:rgba(186,200,215,.15);border-radius:4px}

.concierge-msg{
  max-width:85%;padding:.85rem 1.1rem;border-radius:16px;font-size:.88rem;line-height:1.6;
  animation:msgIn .3s ease;font-weight:300;
}
@keyframes msgIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.concierge-msg-bot{
  background:rgba(186,200,215,.08);color:var(--silver);border:1px solid rgba(186,200,215,.06);
  align-self:flex-start;border-bottom-left-radius:4px;
}
.concierge-msg-user{
  background:linear-gradient(135deg,rgba(201,169,110,.15),rgba(201,169,110,.08));
  color:var(--white);border:1px solid rgba(201,169,110,.12);
  align-self:flex-end;border-bottom-right-radius:4px;
}

.concierge-quick{
  display:flex;gap:.5rem;padding:.75rem 1.25rem;flex-wrap:wrap;flex-shrink:0;
  border-top:1px solid rgba(186,200,215,.06);
}
.concierge-quick button{
  padding:6px 14px;font-size:.68rem;font-family:var(--font-body);font-weight:500;
  letter-spacing:.5px;text-transform:uppercase;border-radius:20px;cursor:pointer;
  background:rgba(201,169,110,.08);border:1px solid rgba(201,169,110,.15);color:var(--gold);
  transition:all .3s;
}
.concierge-quick button:hover{background:rgba(201,169,110,.18);border-color:var(--gold)}

.concierge-input-wrap{
  display:flex;gap:.5rem;padding:1rem 1.25rem;border-top:1px solid rgba(186,200,215,.08);
  background:rgba(0,0,0,.15);flex-shrink:0;
}
.concierge-input{
  flex:1;padding:10px 14px;background:rgba(255,255,255,.04);border:1px solid rgba(186,200,215,.1);
  border-radius:12px;color:var(--white);font-family:var(--font-body);font-size:.9rem;
  outline:none;transition:border-color .3s;
}
.concierge-input:focus{border-color:var(--gold)}
.concierge-input::placeholder{color:var(--silver-muted)}
.concierge-send{
  width:40px;height:40px;border-radius:12px;border:none;
  background:var(--gold);color:var(--navy-abyss);cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:all .3s;flex-shrink:0;
}
.concierge-send:hover{background:var(--gold-light);transform:scale(1.05)}

/* ═══════════════════════════════════
   FORM VALIDATION STATES
   ═══════════════════════════════════ */
.form-group input:valid:not(:placeholder-shown){border-color:rgba(130,200,130,.3)}
.form-group input:invalid:not(:placeholder-shown):not(:focus){border-color:rgba(200,130,130,.3)}
.form-group input:required+label::after{content:' *';color:var(--gold);font-size:.6rem}

/* ═══════════════════════════════════
   MOBILE OVERFLOW FIXES
   ═══════════════════════════════════ */
html,body{overflow-x:hidden;max-width:100%}
*{max-width:100%}
img,video,iframe{max-width:100%}
.hero-video,.hero-fallback{max-width:none}
.bg-ambient,.bg-ambient::before,.bg-ambient::after,.bg-grain{max-width:none}

@media(max-width:768px){
  .concierge-panel{width:calc(100vw - 1.5rem);right:.75rem;bottom:.75rem;height:calc(100vh - 6rem);border-radius:16px}
  .concierge-btn{bottom:1.25rem;right:1.25rem;width:50px;height:50px}
  .concierge-btn svg{width:20px;height:20px}
  .container{padding:0 1rem;overflow:hidden}
  .split-images{grid-template-columns:1fr}
  .split-img:first-child{grid-row:auto}
  .navbar-inner{padding:0}
  .hero-title{padding:0 .5rem}
  .hero-subtitle{padding:0 .5rem}
  .stats-row .stat{padding:1.25rem .75rem}
  .stat-number{font-size:2rem}
  .section-title{font-size:clamp(1.6rem,5vw,2.5rem)}
  .highlight-card{height:320px}
  .poi-item{padding:.75rem 1rem}
}

@media(max-width:380px){
  .concierge-panel{right:0;bottom:0;width:100%;height:100%;max-height:100%;border-radius:0}
  .hero-eyebrow{font-size:.58rem;letter-spacing:3px}
  .btn{padding:12px 24px;font-size:.65rem}
}

/* ═══════════════════════════════════
   SCROLLBAR STYLING
   ═══════════════════════════════════ */
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--navy-abyss)}
::-webkit-scrollbar-thumb{background:rgba(186,200,215,.15);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:rgba(186,200,215,.25)}
html{scrollbar-width:thin;scrollbar-color:rgba(186,200,215,.15) var(--navy-abyss)}

/* Form success/error states */
.form-success{
  padding:2rem;text-align:center;border-radius:var(--r-md);
  background:rgba(130,200,130,.06);border:1px solid rgba(130,200,130,.2);
  color:var(--white);display:none;
}
.form-success h3{font-family:var(--font-display);font-size:1.5rem;margin-bottom:.5rem;font-weight:400}
.form-success p{color:var(--silver-muted);font-weight:300}
.form-error{
  padding:.75rem 1rem;border-radius:var(--r-sm);margin-bottom:1rem;
  background:rgba(200,130,130,.06);border:1px solid rgba(200,130,130,.2);
  color:#e0a0a0;font-size:.85rem;display:none;
}

/* Focus visible for accessibility */
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{
  outline:2px solid var(--gold);outline-offset:2px;
}

/* Prefers reduced motion */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
  .bg-ambient::before,.bg-ambient::after{animation:none}
  .hero-scroll-line{animation:none}
}
