/* ===================================================
   ILAPURAM HOTEL — WHITE MODE
   =================================================== */
:root {
  --gold:       #B8912A;
  --gold-light: #D4A843;
  --gold-dark:  #8B6914;
  --white:      #FFFFFF;
  --off-white:  #FAF9F7;
  --light-bg:   #F4F1EC;
  --card-bg:    #FFFFFF;
  --text-dark:  #1A1A1A;
  --text-mid:   #4A4A4A;
  --text-light: #7A7A7A;
  --border:     #E8E0D0;
  --shadow-sm:  0 2px 12px rgba(0,0,0,0.08);
  --shadow-md:  0 8px 32px rgba(0,0,0,0.12);
  --shadow-lg:  0 20px 60px rgba(0,0,0,0.15);
  --transition: all 0.35s cubic-bezier(0.4,0,0.2,1);
  --radius:     8px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Poppins',sans-serif;background:var(--white);color:var(--text-dark);line-height:1.7;overflow-x:hidden}
img{display:block;width:100%;height:100%;object-fit:cover}
a{text-decoration:none;color:inherit}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}

/* Cursor */
#cursor{position:fixed;width:10px;height:10px;background:var(--gold);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:transform 0.1s}
#cursor-ring{position:fixed;width:36px;height:36px;border:1.5px solid var(--gold);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:all 0.18s ease;opacity:0.7}
#scroll-progress{position:fixed;top:0;left:0;height:3px;background:linear-gradient(90deg,var(--gold),var(--gold-light));z-index:9997;width:0%;transition:width 0.1s}

/* Loader */
#loader{position:fixed;inset:0;background:var(--white);display:flex;align-items:center;justify-content:center;flex-direction:column;z-index:10000;transition:opacity 0.6s ease,visibility 0.6s}
#loader .loader-logo{font-family:'Playfair Display',serif;font-size:2rem;color:var(--text-dark);letter-spacing:4px;margin-bottom:24px}
#loader .loader-logo span{color:var(--gold)}
.loader-bar{width:200px;height:2px;background:var(--border);border-radius:2px;overflow:hidden}
.loader-bar-fill{height:100%;background:linear-gradient(90deg,var(--gold),var(--gold-light));width:0%}
.loader-percent{margin-top:12px;font-size:0.75rem;color:var(--text-light);letter-spacing:3px}
#loader.hidden{opacity:0;visibility:hidden}
#back-top{position:fixed;bottom:32px;right:32px;width:48px;height:48px;background:var(--gold);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;z-index:500;opacity:0;transform:translateY(20px);transition:var(--transition);box-shadow:var(--shadow-md);font-size:1.2rem}
#back-top.visible{opacity:1;transform:translateY(0)}
#back-top:hover{background:var(--gold-dark)}

/* Navbar */
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:0 48px;height:140px;display:flex;align-items:center;justify-content:space-between;transition:var(--transition);background:transparent}
.navbar.scrolled{background:rgba(255,255,255,0.97);backdrop-filter:blur(16px);box-shadow:0 2px 20px rgba(0,0,0,0.08);height:80px}
.navbar.scrolled .brand-logo{height:60px}
.brand-logo{height:115px;width:auto;object-fit:contain;transition:var(--transition)}
.nav-logo{font-family:'Playfair Display',serif;font-size:1.5rem;color:#fff;letter-spacing:2px;transition:var(--transition)}
.nav-logo span{color:var(--gold-light)}
.navbar.scrolled .nav-logo{color:var(--text-dark)}
.navbar.scrolled .nav-logo span{color:var(--gold)}
.nav-links{display:flex;align-items:center;gap:8px}
.nav-links a{font-size:0.82rem;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,0.9);padding:8px 14px;border-radius:4px;transition:var(--transition);position:relative}
.nav-links a::after{content:'';position:absolute;bottom:4px;left:14px;right:14px;height:1px;background:var(--gold-light);transform:scaleX(0);transition:var(--transition)}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}
.navbar.scrolled .nav-links a{color:var(--text-mid)}
.navbar.scrolled .nav-links a:hover,.navbar.scrolled .nav-links a.active{color:var(--gold)}
.nav-cta{background:var(--gold);color:#fff!important;padding:10px 22px!important;border-radius:4px;font-weight:600!important}
.nav-cta::after{display:none!important}
.nav-cta:hover{background:var(--gold-dark)!important}
.navbar.scrolled .nav-cta{color:#fff!important}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px}
.hamburger span{display:block;width:24px;height:2px;background:#fff;border-radius:2px;transition:var(--transition)}
.navbar.scrolled .hamburger span{background:var(--text-dark)}
.mobile-nav{display:none;position:fixed;inset:0;background:var(--white);z-index:2000;flex-direction:column;align-items:center;justify-content:center;gap:24px}
.mobile-nav.open{display:flex}
.mobile-nav a{font-family:'Playfair Display',serif;font-size:1.6rem;color:var(--text-dark);transition:var(--transition)}
.mobile-nav a:hover{color:var(--gold)}
.mobile-close{position:absolute;top:24px;right:24px;font-size:2rem;color:var(--text-dark);cursor:pointer}

/* Hero */
.hero{position:relative;height:100vh;min-height:600px;overflow:hidden}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity 1.2s ease}
.hero-slide.active{opacity:1}
.hero-slide img{object-position:center;filter:brightness(0.55)}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,0,0,0.45) 0%,rgba(0,0,0,0.15) 100%)}
.hero-content{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:0 24px;color:#fff}
.hero-tag{font-size:0.75rem;letter-spacing:5px;text-transform:uppercase;color:var(--gold-light);margin-bottom:16px;font-weight:500}
.hero-title{font-family:'Playfair Display',serif;font-size:clamp(2.4rem,6vw,5rem);line-height:1.15;margin-bottom:20px}
.hero-title em{font-style:italic;color:var(--gold-light)}
.hero-sub{font-size:1rem;color:rgba(255,255,255,0.85);max-width:560px;margin-bottom:40px}
.hero-btns{display:flex;gap:16px;flex-wrap:wrap;justify-content:center}
.btn-gold{background:var(--gold);color:#fff;padding:14px 36px;border-radius:4px;font-weight:600;font-size:0.85rem;letter-spacing:1.5px;text-transform:uppercase;transition:var(--transition);display:inline-block}
.btn-gold:hover{background:var(--gold-dark);transform:translateY(-2px);box-shadow:0 8px 24px rgba(184,145,42,0.4)}
.btn-outline-white{border:1.5px solid rgba(255,255,255,0.7);color:#fff;padding:14px 36px;border-radius:4px;font-weight:500;font-size:0.85rem;letter-spacing:1.5px;text-transform:uppercase;transition:var(--transition);display:inline-block}
.btn-outline-white:hover{background:rgba(255,255,255,0.15);border-color:#fff}
.hero-dots{position:absolute;bottom:120px;left:50%;transform:translateX(-50%);display:flex;gap:10px}
.hero-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,0.4);border:1px solid rgba(255,255,255,0.6);cursor:pointer;transition:var(--transition)}
.hero-dot.active{background:var(--gold-light);border-color:var(--gold-light);transform:scale(1.3)}
.scroll-cue{position:absolute;bottom:36px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;color:rgba(255,255,255,0.7);font-size:0.7rem;letter-spacing:3px;text-transform:uppercase}
.scroll-cue-line{width:1px;height:40px;background:linear-gradient(to bottom,rgba(255,255,255,0.7),transparent);animation:scrollLine 2s ease infinite}
@keyframes scrollLine{0%,100%{transform:scaleY(1);opacity:1}50%{transform:scaleY(0.5);opacity:0.3}}

/* Booking Bar */
.booking-bar{background:var(--white);box-shadow:var(--shadow-lg);padding:28px 48px;margin:0 48px;border-radius:var(--radius);transform:translateY(-50%);display:flex;align-items:flex-end;gap:20px;flex-wrap:wrap;border-bottom:3px solid var(--gold);position:relative;z-index:10}
.booking-field{flex:1;min-width:160px}
.booking-field label{display:block;font-size:0.7rem;letter-spacing:2px;text-transform:uppercase;color:var(--text-light);margin-bottom:8px;font-weight:600}
.booking-field input,.booking-field select{width:100%;border:none;border-bottom:1.5px solid var(--border);padding:8px 0;font-size:0.95rem;color:var(--text-dark);background:transparent;font-family:'Poppins',sans-serif;outline:none;transition:border-color 0.3s}
.booking-field input:focus,.booking-field select:focus{border-color:var(--gold)}
.booking-bar .btn-gold{white-space:nowrap;align-self:flex-end;padding:12px 32px}

/* Sections */
section{padding:100px 0}
.container{max-width:1240px;margin:0 auto;padding:0 48px}
.section-tag{font-size:0.72rem;letter-spacing:5px;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:12px}
.section-title{font-family:'Playfair Display',serif;font-size:clamp(2rem,4vw,3rem);color:var(--text-dark);line-height:1.2}
.section-title em{color:var(--gold);font-style:italic}
.section-sub{color:var(--text-light);font-size:1rem;max-width:560px;margin-top:16px;line-height:1.8}
.section-divider{width:56px;height:2px;background:linear-gradient(90deg,var(--gold),var(--gold-light));margin:20px 0}
.text-center{text-align:center}
.text-center .section-divider{margin:20px auto}
.text-center .section-sub{margin:0 auto}

/* Intro */
.intro-section{background:var(--off-white)}
.intro-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.intro-images{position:relative;height:520px}
.intro-img-main{position:absolute;top:0;left:0;width:75%;height:85%;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-lg)}
.intro-img-accent{position:absolute;bottom:0;right:0;width:50%;height:55%;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-md);border:4px solid var(--white)}
.intro-badge{position:absolute;bottom:60px;left:-20px;background:var(--gold);color:#fff;padding:20px 24px;border-radius:var(--radius);text-align:center;box-shadow:var(--shadow-md)}
.intro-badge .num{font-family:'Playfair Display',serif;font-size:2.2rem;font-weight:700;display:block}
.intro-badge .lbl{font-size:0.7rem;letter-spacing:2px;text-transform:uppercase;opacity:0.9}
.counters{display:flex;gap:40px;margin-top:40px;flex-wrap:wrap}
.counter-item .num{font-family:'Playfair Display',serif;font-size:2.4rem;color:var(--gold);font-weight:700}
.counter-item .lbl{font-size:0.78rem;letter-spacing:2px;text-transform:uppercase;color:var(--text-light);margin-top:4px}

/* Rooms Grid */
.rooms-section{background:var(--white)}
.rooms-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-top:56px}
.room-card{background:var(--card-bg);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--border);transition:var(--transition)}
.room-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.room-card-img{height:240px;overflow:hidden;position:relative}
.room-card-img img{transition:transform 0.6s ease}
.room-card:hover .room-card-img img{transform:scale(1.06)}
.room-badge{position:absolute;top:16px;left:16px;background:var(--gold);color:#fff;font-size:0.68rem;letter-spacing:2px;text-transform:uppercase;padding:5px 12px;border-radius:20px;font-weight:600}
.room-card-body{padding:28px}
.room-card-body h3{font-family:'Playfair Display',serif;font-size:1.35rem;color:var(--text-dark);margin-bottom:8px}
.room-card-body p{font-size:0.88rem;color:var(--text-light);margin-bottom:20px;line-height:1.7}
.room-features{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.room-feature{font-size:0.72rem;letter-spacing:1px;text-transform:uppercase;color:var(--text-mid);background:var(--light-bg);padding:4px 10px;border-radius:20px;border:1px solid var(--border)}
.room-footer{display:flex;align-items:center;justify-content:space-between;padding-top:20px;border-top:1px solid var(--border)}
.room-price .from{font-size:0.7rem;letter-spacing:1px;text-transform:uppercase;color:var(--text-light)}
.room-price .amount{font-family:'Playfair Display',serif;font-size:1.5rem;color:var(--gold);font-weight:700}
.room-price .night{font-size:0.72rem;color:var(--text-light)}
.btn-outline-gold{border:1.5px solid var(--gold);color:var(--gold);padding:9px 20px;border-radius:4px;font-size:0.78rem;font-weight:600;letter-spacing:1px;text-transform:uppercase;transition:var(--transition);display:inline-block}
.btn-outline-gold:hover{background:var(--gold);color:#fff}

/* Dining */
.dining-section{background:var(--off-white)}
.dining-featured{display:grid;grid-template-columns:1.2fr 1fr;gap:0;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-lg);margin-top:56px;margin-bottom:40px;border:1px solid var(--border)}
.dining-featured-img{height:480px}
.dining-featured-body{padding:56px 48px;background:var(--white);display:flex;flex-direction:column;justify-content:center}
.dining-featured-body h3{font-family:'Playfair Display',serif;font-size:2rem;color:var(--text-dark);margin-bottom:16px}
.dining-featured-body p{color:var(--text-light);margin-bottom:24px;line-height:1.8}
.dining-hours{display:flex;gap:24px;margin-bottom:32px}
.dining-hour-item{font-size:0.8rem;color:var(--text-mid)}
.dining-hour-item strong{display:block;color:var(--gold);font-size:0.7rem;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:2px}
.dining-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.dining-card{background:var(--white);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--border);transition:var(--transition)}
.dining-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.dining-card-img{height:200px}
.dining-card-body{padding:24px}
.dining-card-body h4{font-family:'Playfair Display',serif;font-size:1.2rem;color:var(--text-dark);margin-bottom:8px}
.dining-card-body p{font-size:0.85rem;color:var(--text-light);line-height:1.7}

/* Amenities */
.amenities-section{background:var(--white)}
.amenities-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:56px}
.amenity-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:36px 28px;text-align:center;transition:var(--transition);position:relative;overflow:hidden}
.amenity-card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--gold) 0%,var(--gold-dark) 100%);opacity:0;transition:var(--transition)}
.amenity-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.amenity-card:hover::before{opacity:1}
.amenity-icon{font-size:2.4rem;margin-bottom:16px;position:relative;z-index:1}
.amenity-card h4{font-family:'Playfair Display',serif;font-size:1rem;color:var(--text-dark);margin-bottom:8px;position:relative;z-index:1;transition:var(--transition)}
.amenity-card p{font-size:0.82rem;color:var(--text-light);line-height:1.6;position:relative;z-index:1;transition:var(--transition)}
.amenity-card:hover h4,.amenity-card:hover p{color:#fff}

/* Testimonials */
.testimonials-section{background:var(--light-bg)}
.testimonials-wrap{max-width:800px;margin:56px auto 0;position:relative}
.testi-slide{display:none;text-align:center;animation:fadeIn 0.6s ease}
.testi-slide.active{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
.testi-quote{font-size:3rem;color:var(--gold);line-height:1;margin-bottom:20px}
.testi-text{font-family:'Playfair Display',serif;font-size:1.35rem;color:var(--text-dark);line-height:1.7;font-style:italic;margin-bottom:32px}
.testi-stars{color:var(--gold);font-size:1.1rem;letter-spacing:3px;margin-bottom:16px}
.testi-name{font-weight:600;font-size:0.9rem;letter-spacing:1px;text-transform:uppercase;color:var(--text-dark)}
.testi-role{font-size:0.78rem;color:var(--text-light);margin-top:4px}
.testi-nav{display:flex;justify-content:center;gap:10px;margin-top:40px}
.testi-dot{width:8px;height:8px;border-radius:50%;background:var(--border);cursor:pointer;transition:var(--transition);border:1.5px solid var(--gold)}
.testi-dot.active{background:var(--gold);transform:scale(1.3)}

/* CTA */
.cta-section{background:linear-gradient(135deg,var(--text-dark) 0%,#2A2A2A 100%);padding:100px 0;text-align:center;position:relative;overflow:hidden}
.cta-section h2{font-family:'Playfair Display',serif;font-size:clamp(2rem,4vw,3.2rem);color:#fff;margin-bottom:16px;position:relative}
.cta-section h2 em{color:var(--gold-light);font-style:italic}
.cta-section p{color:rgba(255,255,255,0.7);max-width:500px;margin:0 auto 40px;position:relative;font-size:1rem}
.cta-btns{display:flex;justify-content:center;gap:16px;flex-wrap:wrap;position:relative}
.btn-outline-light{border:1.5px solid rgba(255,255,255,0.5);color:#fff;padding:14px 36px;border-radius:4px;font-size:0.85rem;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;transition:var(--transition);display:inline-block}
.btn-outline-light:hover{border-color:#fff;background:rgba(255,255,255,0.1)}

/* Footer */
footer{background:var(--text-dark);color:rgba(255,255,255,0.75);padding:80px 0 0}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.3fr;gap:56px}
.footer-brand .logo{font-family:'Playfair Display',serif;font-size:1.6rem;color:#fff;letter-spacing:2px;margin-bottom:20px}
.footer-brand .logo span{color:var(--gold)}
.footer-brand p{font-size:0.88rem;line-height:1.8;margin-bottom:28px}
.social-links{display:flex;gap:12px}
.social-link{width:40px;height:40px;border:1px solid rgba(255,255,255,0.2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:0.9rem;transition:var(--transition);color:rgba(255,255,255,0.7)}
.social-link:hover{background:var(--gold);border-color:var(--gold);color:#fff}
.footer-col h5{font-size:0.72rem;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:24px;font-weight:600}
.footer-col ul li{margin-bottom:12px}
.footer-col ul li a{font-size:0.88rem;color:rgba(255,255,255,0.65);transition:var(--transition)}
.footer-col ul li a:hover{color:var(--gold);padding-left:6px}
.footer-contact-item{display:flex;gap:14px;margin-bottom:16px;align-items:flex-start}
.footer-contact-item .icon{color:var(--gold);font-size:1rem;margin-top:2px;flex-shrink:0}
.footer-contact-item span{font-size:0.88rem;color:rgba(255,255,255,0.65);line-height:1.6}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.1);margin-top:64px;padding:24px 0;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}
.footer-bottom p{font-size:0.8rem;color:rgba(255,255,255,0.4)}
.footer-legal{display:flex;gap:24px}
.footer-legal a{font-size:0.78rem;color:rgba(255,255,255,0.4);transition:var(--transition)}
.footer-legal a:hover{color:var(--gold)}

/* Page Hero */
.page-hero{position:relative;height:420px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.page-hero img{position:absolute;inset:0;filter:brightness(0.45)}
.page-hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,0.3),rgba(0,0,0,0.5))}
.page-hero-content{position:relative;text-align:center;color:#fff;z-index:2}
.page-hero-content .section-tag{color:var(--gold-light)}
.page-hero-content h1{font-family:'Playfair Display',serif;font-size:clamp(2.2rem,5vw,4rem);color:#fff;margin-top:8px}
.breadcrumb{display:flex;justify-content:center;gap:8px;margin-top:16px;font-size:0.8rem;color:rgba(255,255,255,0.65)}
.breadcrumb a{color:rgba(255,255,255,0.65)}
.breadcrumb a:hover{color:var(--gold-light)}
.breadcrumb span{color:var(--gold-light)}

/* Room Listings */
.room-listing{display:grid;grid-template-columns:1fr 1fr;gap:0;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-md);border:1px solid var(--border);margin-bottom:40px}
.room-listing.reverse{direction:rtl}
.room-listing.reverse>*{direction:ltr}
.room-listing-img{height:420px}
.room-listing-body{padding:52px 48px;background:var(--white);display:flex;flex-direction:column;justify-content:center}
.room-listing-body h2{font-family:'Playfair Display',serif;font-size:1.9rem;color:var(--text-dark);margin-bottom:12px}
.room-listing-body p{color:var(--text-light);margin-bottom:24px;line-height:1.8;font-size:0.95rem}
.room-listing-body .room-features{margin-bottom:28px}
.room-listing-price{font-family:'Playfair Display',serif;font-size:1.8rem;color:var(--gold);font-weight:700;margin-bottom:24px}
.room-listing-price small{font-size:0.85rem;font-family:'Poppins',sans-serif;color:var(--text-light);font-weight:400}

/* Gallery */
.gallery-filters{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin:40px 0 48px}
.filter-btn{padding:9px 22px;border-radius:4px;font-size:0.8rem;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;border:1.5px solid var(--border);color:var(--text-mid);transition:var(--transition);background:var(--white)}
.filter-btn:hover,.filter-btn.active{background:var(--gold);border-color:var(--gold);color:#fff}
.gallery-grid{columns:3;gap:20px}
.gallery-item{break-inside:avoid;margin-bottom:20px;border-radius:var(--radius);overflow:hidden;cursor:pointer;position:relative;box-shadow:var(--shadow-sm)}
.gallery-item img{display:block;width:100%;height:auto;transition:transform 0.5s ease}
.gallery-item:hover img{transform:scale(1.05)}
.gallery-overlay{position:absolute;inset:0;background:rgba(0,0,0,0.35);opacity:0;display:flex;align-items:center;justify-content:center;transition:var(--transition)}
.gallery-item:hover .gallery-overlay{opacity:1}
.gallery-overlay span{color:#fff;font-size:2rem}
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,0.95);z-index:9000;display:none;align-items:center;justify-content:center}
.lightbox.open{display:flex}
.lightbox img{max-width:90vw;max-height:85vh;object-fit:contain;border-radius:4px;width:auto;height:auto}
.lightbox-close{position:absolute;top:24px;right:32px;color:#fff;font-size:2rem;cursor:pointer;transition:var(--transition)}
.lightbox-close:hover{color:var(--gold-light)}
.lightbox-prev,.lightbox-next{position:absolute;top:50%;transform:translateY(-50%);color:rgba(255,255,255,0.7);font-size:2.5rem;cursor:pointer;transition:var(--transition);padding:16px}
.lightbox-prev{left:20px}
.lightbox-next{right:20px}
.lightbox-prev:hover,.lightbox-next:hover{color:var(--gold-light)}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:60px;align-items:start}
.contact-form-wrap{background:var(--white);border-radius:var(--radius);padding:52px;box-shadow:var(--shadow-md);border:1px solid var(--border)}
.contact-form-wrap h3{font-family:'Playfair Display',serif;font-size:1.8rem;color:var(--text-dark);margin-bottom:8px}
.contact-form-wrap>p{color:var(--text-light);margin-bottom:36px;font-size:0.9rem}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.form-field{display:flex;flex-direction:column;gap:8px}
.form-field.full{grid-column:span 2}
.form-field label{font-size:0.72rem;letter-spacing:2px;text-transform:uppercase;color:var(--text-light);font-weight:600}
.form-field input,.form-field select,.form-field textarea{width:100%;border:1.5px solid var(--border);border-radius:6px;padding:12px 16px;font-size:0.92rem;color:var(--text-dark);font-family:'Poppins',sans-serif;background:var(--off-white);transition:border-color 0.3s,box-shadow 0.3s;outline:none;resize:none}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(184,145,42,0.12);background:var(--white)}
.form-submit{margin-top:28px}
.form-submit .btn-gold{width:100%;padding:15px;font-size:0.9rem;text-align:center}
.availability-indicator{display:flex;align-items:center;gap:8px;margin-bottom:20px;font-size:0.82rem;color:#2D9A4E}
.avail-dot{width:8px;height:8px;border-radius:50%;background:#2D9A4E;animation:pulse 1.5s infinite}
@keyframes pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.4);opacity:0.6}}
.contact-info{display:flex;flex-direction:column;gap:28px}
.contact-info-card{background:var(--white);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow-sm);border:1px solid var(--border)}
.contact-info-card h4{font-family:'Playfair Display',serif;font-size:1.1rem;color:var(--text-dark);margin-bottom:16px;display:flex;align-items:center;gap:10px}
.contact-info-card h4 span{color:var(--gold)}
.contact-info-card p,.contact-info-card a{font-size:0.9rem;color:var(--text-light);line-height:1.8}
.contact-info-card a:hover{color:var(--gold)}
.map-embed{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-md);border:1px solid var(--border)}
.map-embed iframe{display:block;width:100%;height:320px;border:none}

/* About */
.about-intro{background:var(--off-white)}
.timeline{margin-top:64px}
.timeline-item{display:grid;grid-template-columns:1fr 80px 1fr;gap:0;margin-bottom:0}
.tl-content-left{padding:40px;text-align:right}
.tl-content-right{padding:40px}
.timeline-item:nth-child(even) .tl-content-left{order:3;text-align:left}
.timeline-item:nth-child(even) .tl-content-right{order:1;text-align:right}
.timeline-item:nth-child(even) .tl-center{order:2}
.tl-year{font-family:'Playfair Display',serif;font-size:2.8rem;color:var(--gold);font-weight:700;line-height:1}
.tl-title{font-family:'Playfair Display',serif;font-size:1.3rem;color:var(--text-dark);margin:8px 0}
.tl-desc{font-size:0.88rem;color:var(--text-light);line-height:1.7}
.tl-center{display:flex;flex-direction:column;align-items:center}
.tl-line{flex:1;width:2px;background:var(--border)}
.tl-dot{width:16px;height:16px;border-radius:50%;background:var(--gold);border:3px solid var(--white);box-shadow:0 0 0 2px var(--gold);flex-shrink:0}
.tl-img{border-radius:var(--radius);overflow:hidden;height:220px}
.values-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;margin-top:56px}
.value-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:40px 28px;text-align:center;transition:var(--transition)}
.value-card:hover{border-color:var(--gold);box-shadow:var(--shadow-md);transform:translateY(-4px)}
.value-icon{font-size:2.4rem;margin-bottom:16px}
.value-card h4{font-family:'Playfair Display',serif;font-size:1.1rem;color:var(--text-dark);margin-bottom:10px}
.value-card p{font-size:0.85rem;color:var(--text-light);line-height:1.7}

/* Amenities Page */
.amenity-listing{display:grid;grid-template-columns:1fr 1fr;gap:0;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-md);border:1px solid var(--border);margin-bottom:40px}
.amenity-listing.reverse{direction:rtl}
.amenity-listing.reverse>*{direction:ltr}
.amenity-listing-img{height:380px}
.amenity-listing-body{padding:52px 48px;background:var(--white);display:flex;flex-direction:column;justify-content:center}
.amenity-listing-body h2{font-family:'Playfair Display',serif;font-size:1.8rem;color:var(--text-dark);margin-bottom:12px}
.amenity-listing-body p{color:var(--text-light);margin-bottom:24px;line-height:1.8}
.amenity-listing-features{display:flex;flex-direction:column;gap:10px}
.amenity-feature-row{display:flex;align-items:center;gap:12px;font-size:0.88rem;color:var(--text-mid)}
.amenity-feature-row::before{content:'✦';color:var(--gold);font-size:0.6rem;flex-shrink:0}
.services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:48px}
.service-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:32px 24px;text-align:center;transition:var(--transition)}
.service-card:hover{border-color:var(--gold);box-shadow:var(--shadow-sm)}
.service-icon{font-size:2rem;margin-bottom:14px}
.service-card h4{font-family:'Playfair Display',serif;font-size:1rem;color:var(--text-dark);margin-bottom:8px}
.service-card p{font-size:0.82rem;color:var(--text-light);line-height:1.6}

/* Dining Page */
.dining-listing{display:grid;grid-template-columns:1fr 1fr;gap:0;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-md);border:1px solid var(--border);margin-bottom:40px}
.dining-listing.reverse{direction:rtl}
.dining-listing.reverse>*{direction:ltr}
.dining-listing-img{height:420px}
.dining-listing-body{padding:52px 48px;background:var(--white);display:flex;flex-direction:column;justify-content:center}
.dining-listing-body h2{font-family:'Playfair Display',serif;font-size:1.9rem;color:var(--text-dark);margin-bottom:12px}
.dining-listing-body p{color:var(--text-light);margin-bottom:24px;line-height:1.8}
.dining-tag{display:inline-block;background:var(--light-bg);color:var(--gold);border:1px solid var(--border);font-size:0.72rem;letter-spacing:2px;text-transform:uppercase;padding:5px 14px;border-radius:20px;margin-bottom:16px;font-weight:600}
.private-cta{background:var(--light-bg);border:1px solid var(--border);border-radius:var(--radius);padding:56px;text-align:center;margin-top:16px}
.private-cta h3{font-family:'Playfair Display',serif;font-size:2rem;color:var(--text-dark);margin-bottom:12px}
.private-cta p{color:var(--text-light);max-width:520px;margin:0 auto 32px}

/* Scroll Reveal */
.reveal{opacity:0;transform:translateY(40px);transition:opacity 0.7s ease,transform 0.7s ease}
.r-left{opacity:0;transform:translateX(-40px);transition:opacity 0.7s ease,transform 0.7s ease}
.r-right{opacity:0;transform:translateX(40px);transition:opacity 0.7s ease,transform 0.7s ease}
.r-scale{opacity:0;transform:scale(0.9);transition:opacity 0.7s ease,transform 0.7s ease}
.revealed{opacity:1!important;transform:none!important}
.d1{transition-delay:0.1s}.d2{transition-delay:0.2s}.d3{transition-delay:0.3s}.d4{transition-delay:0.4s}.d5{transition-delay:0.5s}.d6{transition-delay:0.6s}
.page-transition{position:fixed;inset:0;background:var(--white);z-index:8000;opacity:0;pointer-events:none;transition:opacity 0.4s ease}
.page-transition.active{opacity:1;pointer-events:all}

/* Inline booking bar on rooms page */
.inline-booking{background:var(--light-bg);border:1px solid var(--border);border-radius:var(--radius);padding:32px 40px;margin-bottom:48px;display:flex;align-items:flex-end;gap:20px;flex-wrap:wrap}
.inline-booking .booking-field input,.inline-booking .booking-field select{border-bottom-color:var(--border)}

/* Inclusions grid */
.inclusions-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:48px}
.inclusion-item{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:28px 20px;text-align:center;transition:var(--transition)}
.inclusion-item:hover{border-color:var(--gold);box-shadow:var(--shadow-sm)}
.inclusion-icon{font-size:1.8rem;margin-bottom:12px}
.inclusion-item p{font-size:0.85rem;color:var(--text-mid);font-weight:500}

/* Responsive */
@media(max-width:1100px){.rooms-grid{grid-template-columns:repeat(2,1fr)}.amenities-grid{grid-template-columns:repeat(2,1fr)}.values-grid{grid-template-columns:repeat(2,1fr)}.services-grid{grid-template-columns:repeat(2,1fr)}.footer-grid{grid-template-columns:1fr 1fr;gap:40px}.dining-grid{grid-template-columns:1fr 1fr}.inclusions-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:900px){.intro-grid{grid-template-columns:1fr;gap:48px}.intro-images{height:360px}.dining-featured{grid-template-columns:1fr}.dining-featured-img{height:320px}.room-listing,.dining-listing,.amenity-listing{grid-template-columns:1fr}.room-listing.reverse,.dining-listing.reverse,.amenity-listing.reverse{direction:ltr}.room-listing-img,.dining-listing-img,.amenity-listing-img{height:280px}.contact-grid{grid-template-columns:1fr}.timeline-item{grid-template-columns:1fr}.tl-center{display:none}.tl-content-right{order:1!important;text-align:left!important}.tl-content-left{order:2!important;text-align:left!important}}
@media(max-width:768px){.navbar{padding:0 24px;height:100px}.brand-logo{height:75px}.nav-links{display:none}.hamburger{display:flex}.booking-bar{margin:0 16px;padding:24px;transform:translateY(-30px)}.container{padding:0 24px}section{padding:72px 0}.rooms-grid{grid-template-columns:1fr}.amenities-grid{grid-template-columns:repeat(2,1fr)}.dining-grid{grid-template-columns:1fr}.values-grid{grid-template-columns:1fr 1fr}.services-grid{grid-template-columns:1fr 1fr}.form-grid{grid-template-columns:1fr}.form-field.full{grid-column:span 1}.footer-grid{grid-template-columns:1fr;gap:32px}.gallery-grid{columns:2}.page-hero{height:300px}.inclusions-grid{grid-template-columns:repeat(2,1fr)}.contact-form-wrap{padding:32px 24px}.contact-info-card{padding:24px}}
@media(max-width:480px){.gallery-grid{columns:2}.amenities-grid{grid-template-columns:repeat(2,1fr);gap:12px}.values-grid{grid-template-columns:repeat(2,1fr);gap:12px}.services-grid{grid-template-columns:repeat(2,1fr);gap:12px}.hero-btns{flex-direction:column;align-items:center}.booking-bar{flex-direction:column}.booking-field{min-width:auto;width:100%}.inclusions-grid{grid-template-columns:repeat(2,1fr);gap:12px}.contact-form-wrap{padding:24px 16px}.contact-grid{gap:32px}.amenity-card,.value-card,.service-card{padding:20px 12px}.inclusion-item{padding:16px 10px}}
