/*
Theme Name: Park & Bed HMS
Theme URI: https://parkandbed.com/
Author: IT DEPARTMENT / Antigravity
Description: Premium Luxury Hotel Management System and Website for Park & Bed.
Version: 2.0.0
Text Domain: parkandbed
*/

/* ============================================================
   PARK BED & BREAKFAST HOTEL — Premium Luxury Design System v2.0
   Minimalist Luxury · Gold · Ivory · Cinematic
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;0,700;1,300;1,400;1,500&family=Inter:wght@300;400;500;600;700;800&display=swap');

/* ---------- CSS Custom Properties ---------- */
:root {
  /* ── Snow Theme Premium Palette (Reverted from Midnight Forest) ── */
  --navy-deep: #051730;
  --bg-main: #f0f9ff;
  /* Light blue from manage-booking.php */
  --bg-sec: #f8fafc;
  /* Very light gray/ivory */
  --bg-card: #ffffff;
  --text-primary: #0f172a;
  /* Solid dark for visibility */
  --text-sec: #334155;
  --text-muted: #64748b;
  --text-accent: #b88632;
  /* Deeper gold for light background visibility */
  --gold-accent: #EBD293;
  --gold-dark: #d4a03d;
  --white: #ffffff;

  /* Accents */
  --success: #0d5c38;
  --warning: var(--gold-accent);
  --error: #9b3e3e;
  /* Soft red for premium feel */
  --charcoal: #1a1208;
  --dark-900: #EBD293;
  --dark-800: #EBE6D8;
  --dark-700: #1a2b4a;
  --dark-600: #2a3b5a;
  --dark-500: #4a5b7a;
  --ivory: #fdfbf7;
  --ivory-dark: #f5f0e5;
  --parchment: #e8e1d1;
  --cream: #fffefc;
  --neutral-100: #f8f9fa;
  --wa-green: #25d366;
  --amber: #d97706;

  /* Gold Palette for Premium Elements */
  --gold-50: #fdfaf3;
  --gold-100: #f9f2de;
  --gold-200: #f1e2b6;
  --gold-300: #e8cf8d;
  --gold-400: #dfb965;
  --gold-500: #d4a03d;
  --gold-600: #b88632;
  --gold-700: #966b2a;
  --gold-800: #7a5624;
  --gold-900: #644720;

  /* ── Shadows ── */
  --shadow-sm: 0 4px 12px rgba(5, 23, 48, 0.1);
  --shadow-md: 0 10px 30px rgba(5, 23, 48, 0.15);
  --shadow-lg: 0 20px 60px rgba(5, 23, 48, 0.2);
  --shadow-gold: 0 12px 40px rgba(5, 23, 48, 0.2);

  /* ── Typography ── */
  --font-display: 'Cormorant Garamond', 'Playfair Display', Georgia, serif;
  --font-sans: 'Inter', system-ui, -apple-system, sans-serif;

  /* ── Spacing ── */
  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.25rem;
  --space-6: 1.5rem;
  --space-8: 2rem;
  --space-10: 2.5rem;
  --space-12: 3rem;
  --space-16: 4rem;
  --space-20: 5rem;
  --space-24: 6rem;

  /* ── Layout ── */
  --header-height: 68px;
  --topbar-height: 0px;
  --container-max: 1320px;
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 24px;
  --radius-full: 999px;

  /* ── Transitions ── */
  --trans-fast: 0.2s ease;
  --trans-base: 0.3s ease;
  --trans-slow: 0.5s ease;
  --ease-luxury: cubic-bezier(0.4, 0, 0.2, 1);
}

/* ============================================================
   RESET & BASE
   ============================================================ */
*,
*::before,
*::after {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  scroll-padding-top: calc(var(--topbar-height) + var(--header-height));
  -webkit-text-size-adjust: 100%;
  font-size: 16px;
}

body {
  font-family: var(--font-sans);
  font-size: 1rem;
  line-height: 1.65;
  color: var(--white);
  background: var(--bg-main);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

a {
  text-decoration: none;
  color: inherit;
  transition: color var(--trans-fast);
}

ul,
ol {
  list-style: none;
}

button {
  font-family: inherit;
  cursor: pointer;
  border: none;
  background: none;
}

body.no-scroll {
  overflow: hidden;
}

/* Antigravity Particles Background */
#particles-bg {
    position: fixed;
    top: 0; left: 0; width: 100%; height: 100%;
    z-index: -1;
    pointer-events: none;
    overflow: hidden;
}
.particle {
    position: absolute;
    background: var(--text-primary);
    border-radius: 50%;
    opacity: 0.15;
    animation: float 15s infinite linear;
}
@keyframes float {
    0% { transform: translateY(100vh) scale(0); opacity: 0; }
    10% { opacity: 0.3; }
    90% { opacity: 0.3; }
    100% { transform: translateY(-100px) scale(1); opacity: 0; }
}

/* ============================================================
   LAYOUT UTILITIES
   ============================================================ */
.container {
  width: 100%;
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--space-6);
}

.section-pad {
  padding: var(--space-24) 0;
}

@media (max-width: 768px) {
  .section-pad {
    padding: var(--space-16) 0;
  }
}

/* ── Section Header ── */
.section-header {
  text-align: center;
  max-width: 720px;
  margin: 0 auto var(--space-16);
}

.section-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  font-size: 0.8rem;
  font-weight: 800;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--gold-700);
  margin-bottom: var(--space-4);
}

.section-eyebrow::before,
.section-eyebrow::after {
  content: '';
  width: 32px;
  height: 1px;
  background: var(--gold-400);
}

.section-heading {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4.5vw, 3.2rem);
  font-weight: 600;
  color: var(--charcoal);
  line-height: 1.15;
  margin-bottom: var(--space-5);
}

.section-heading em {
  font-style: italic;
  color: var(--gold-600);
}

.section-subheading {
  font-size: 1.05rem;
  color: var(--dark-500);
  line-height: 1.75;
  max-width: 560px;
  margin: 0 auto;
}

.section-cta {
  text-align: center;
  margin-top: var(--space-12);
}

/* ── Premium Glass Card ── */
.glass-card,
.card {
  background: var(--bg-card);
  backdrop-filter: blur(24px) saturate(180%);
  -webkit-backdrop-filter: blur(24px) saturate(180%);
  border: 1px solid var(--border-glass);
  box-shadow: var(--shadow-md);
  border-radius: var(--radius-xl);
  transition: transform var(--trans-base), box-shadow var(--trans-base);
}

.glass-card:hover,
.card:hover {
  transform: translateY(-5px);
  box-shadow: 0 20px 40px rgba(200, 153, 53, 0.1);
  border-color: rgba(200, 153, 53, 0.3);
}

/* ============================================================
   INNER PAGE HEADERS & UTILITIES
   ============================================================ */
.page-header {
  position: relative;
  padding: calc(var(--header-height) + var(--space-20)) var(--space-6) var(--space-16);
  background-color: var(--dark-900);
  background-size: cover;
  background-position: center;
  color: var(--white);
  text-align: center;
  overflow: hidden;
}

.page-header-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(26, 18, 8, 0.7) 0%, rgba(26, 18, 8, 0.4) 100%);
  z-index: 1;
}

.page-header .container {
  position: relative;
  z-index: 2;
}

.page-title {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 5vw, 4rem);
  font-weight: 700;
  color: var(--white);
  margin-bottom: var(--space-4);
  line-height: 1.1;
}

.page-subtitle {
  font-size: 1.1rem;
  color: rgba(255, 255, 255, .8);
  max-width: 650px;
  margin: 0 auto;
  line-height: 1.6;
}

.room-filter-bar {
  background: var(--ivory-dark);
  padding: var(--space-4) 0;
  border-bottom: 1px solid var(--parchment);
}

.filter-bar-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-4);
}

.filter-pills {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
}

.filter-pill {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 6px 14px;
  background: var(--white);
  border: 1px solid var(--parchment);
  border-radius: var(--radius-full);
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--dark-600);
}

.filter-pill i {
  color: var(--gold-500);
  font-size: 1rem;
}

.filter-count {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--dark-500);
}

/* Room Details Specifics */
.room-details-header {
  padding: calc(var(--header-height) + var(--space-12)) 0 var(--space-10);
  background: var(--ivory-dark);
  color: var(--charcoal);
}

.back-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  color: var(--gold-500);
  font-weight: 700;
  font-size: 0.9rem;
  letter-spacing: 0.5px;
  margin-bottom: var(--space-6);
  transition: color var(--trans-fast);
}

.back-link:hover {
  color: var(--gold-600);
  transform: translateX(-3px);
}

.room-details-top {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  align-items: flex-start;
}

@media (min-width: 768px) {
  .room-details-top {
    flex-direction: row;
    justify-content: space-between;
  }
}

.room-details-title-wrapper {
  flex: 1;
}

.room-badge-top {
  display: inline-block;
  padding: 4px 12px;
  background: var(--gold-50);
  color: var(--gold-700);
  border: 1px solid var(--gold-200);
  border-radius: var(--radius-sm);
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: var(--space-3);
}

.room-details-title {
  font-family: var(--font-display);
  font-size: clamp(2.2rem, 4vw, 3.5rem);
  font-weight: 700;
  color: var(--charcoal);
  margin-bottom: var(--space-4);
  line-height: 1.1;
}

.room-features-list {
  display: flex;
  gap: var(--space-5);
  flex-wrap: wrap;
  color: var(--dark-500);
  font-size: 0.9rem;
  font-weight: 500;
}

.room-features-list span {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.room-features-list i {
  color: var(--gold-500);
  font-size: 1.1rem;
}

.room-details-price-card {
  text-align: right;
  background: rgba(255, 255, 255, 0.7);
  backdrop-filter: blur(10px);
  padding: var(--space-5) var(--space-6);
  border-radius: var(--radius-lg);
  box-shadow: 0 10px 30px rgba(5, 23, 48, 0.08);
  border: 1px solid rgba(5, 23, 48, 0.1);
}

.price-main {
  font-family: var(--font-display);
  font-size: 2.2rem;
  font-weight: 700;
  color: #051730;
  line-height: 1;
}

.price-main span {
  font-family: var(--font-sans);
  font-size: 0.85rem;
  font-weight: 500;
  color: rgba(5, 23, 48, 0.6);
}

.room-gallery-main {
  margin-top: calc(var(--space-8) * -1);
  position: relative;
  z-index: 10;
  padding-bottom: var(--space-12);
}

.room-gallery-main img {
  width: 100%;
  height: 500px;
  object-fit: cover;
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xl);
}

.room-content-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-12);
  align-items: start;
}

@media (min-width: 1024px) {
  .room-content-grid {
    grid-template-columns: 2fr 1fr;
  }
}

.room-details-text h2 {
  font-family: var(--font-display);
  font-size: 1.8rem;
  color: #051730;
  margin-bottom: var(--space-4);
}

.room-details-text p {
  color: var(--dark-600);
  line-height: 1.8;
  margin-bottom: var(--space-8);
  font-size: 1.05rem;
}

.amenities-list-basic {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}

@media (min-width: 640px) {
  .amenities-list-basic {
    grid-template-columns: 1fr 1fr;
  }
}

.amenity-item-basic {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--parchment);
  color: var(--dark-700);
  font-weight: 500;
}

.amenity-item-basic i {
  color: var(--gold-500);
  font-size: 1.3rem;
}

.booking-sidebar-card {
  position: sticky;
  top: calc(var(--header-height) + var(--space-6));
  background: var(--white);
  border: 1px solid var(--parchment);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
  box-shadow: var(--shadow-lg);
}

.booking-sidebar-card h3 {
  font-family: var(--font-display);
  font-size: 1.5rem;
  color: var(--charcoal);
  margin-bottom: var(--space-2);
}

.booking-sidebar-card>p {
  font-size: 0.9rem;
  color: var(--dark-500);
  margin-bottom: var(--space-6);
  line-height: 1.6;
}

.booking-rate-box {
  background: var(--ivory);
  border: 1px solid var(--parchment);
  padding: var(--space-4);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-6);
}

.rate-box-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-weight: 700;
  color: var(--charcoal);
  margin-bottom: 4px;
}

.rate-box-amount {
  font-size: 1.2rem;
  color: var(--gold-600);
}

.rate-box-bottom {
  font-size: 0.8rem;
  color: var(--gold-700);
  font-weight: 600;
}


.booking-badges {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-top: var(--space-5);
}

.mini-badge {
  padding: 4px 10px;
  background: var(--ivory-dark);
  border: 1px solid var(--parchment);
  border-radius: var(--radius-sm);
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--dark-500);
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn-gold {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: 0.9rem 2.2rem;
  background: var(--gold-accent); /* Gold */
  color: #051730 !important; /* Navy */
  font-family: var(--font-sans);
  font-size: 0.95rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  border-radius: 12px;
  box-shadow: var(--shadow-md);
  transition: all var(--trans-base);
  white-space: nowrap;
}

.btn-gold:hover {
  background: var(--gold-dark);
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
  color: #051730 !important;
}

.btn-gold-outline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: 0.875rem 2rem;
  background: transparent;
  color: var(--gold-accent);
  font-size: 0.9rem;
  font-weight: 700;
  letter-spacing: 0.5px;
  border-radius: var(--radius-full);
  border: 2px solid var(--gold-accent);
  transition: all var(--trans-fast);
  white-space: nowrap;
}

.btn-gold-outline:hover {
  background: var(--gold-accent);
  color: #051730 !important;
  transform: translateY(-2px);
  box-shadow: var(--shadow-gold);
}

.btn-hero-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: 1rem 2.25rem;
  background: var(--gold-accent);
  color: #051730 !important;
  font-size: 0.95rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  border-radius: var(--radius-full);
  box-shadow: 0 10px 30px rgba(200, 153, 53, 0.4);
  transition: all var(--trans-fast);
  white-space: nowrap;
  position: relative;
  overflow: hidden;
}

.btn-hero-primary::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.4), transparent);
  opacity: 0;
  transition: opacity var(--trans-fast);
}

.btn-hero-primary:hover {
  background: var(--gold-dark);
  transform: translateY(-4px) scale(1.05);
  box-shadow: 0 20px 40px rgba(0,0,0,0.4);
  color: #051730 !important;
}

.btn-hero-primary:hover::before {
  opacity: 0.2;
}

.btn-hero-outline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: 1rem 2.25rem;
  background: rgba(255, 255, 255, .05);
  color: var(--white);
  font-size: 0.95rem;
  font-weight: 600;
  border-radius: var(--radius-full);
  border: 1.5px solid rgba(255, 255, 255, .3);
  transition: all var(--trans-fast);
  white-space: nowrap;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

.btn-hero-outline:hover {
  background: rgba(255, 255, 255, .2);
  border-color: var(--white);
  transform: translateY(-4px) scale(1.05);
  color: var(--white);
  box-shadow: 0 15px 35px rgba(0, 0, 0, 0.2), 0 0 15px rgba(255, 255, 255, 0.1);
}

.btn-wa {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: 0.9rem 2.2rem;
  background: var(--wa-green);
  color: var(--white);
  font-size: 0.95rem;
  font-weight: 700;
  border-radius: 12px;
  box-shadow: var(--shadow-md);
  transition: all var(--trans-base);
  white-space: nowrap;
}

.btn-wa:hover {
  background: #1fba59;
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
  color: var(--white);
}

.map-wrapper {
  height: 100%;
  min-height: 400px;
  background: var(--white);
  padding: 12px;
  border-radius: 24px;
  border: 1px solid var(--gold-200);
  box-shadow: var(--shadow-lg);
  overflow: hidden;
}

/* ============================================================
   TOP BAR
   ============================================================ */
.top-bar {
  background: var(--dark-900);
  color: rgba(255, 255, 255, .75);
  font-size: 0.78rem;
  height: var(--topbar-height);
  display: none;
}

@media (min-width: 768px) {
  .top-bar {
    display: block;
  }
}

.top-bar-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--space-6);
  height: 100%;
}

.top-bar-left,
.top-bar-right {
  display: flex;
  align-items: center;
  gap: var(--space-6);
}

.top-bar-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.top-bar-item i {
  font-size: 0.85rem;
  color: var(--gold-400);
}

.top-bar a {
  color: rgba(255, 255, 255, .75);
  transition: color var(--trans-fast);
}

.top-bar a:hover {
  color: var(--white);
}

.top-bar-socials {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.top-bar-socials a {
  font-size: 1rem;
  color: rgba(255, 255, 255, .6);
  transition: color var(--trans-fast);
}

.top-bar-socials a:hover {
  color: var(--gold-400);
}

/* ============================================================
   HEADER / NAVIGATION
   ============================================================ */
.header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 1000;
  background: rgba(240, 249, 255, 0.95) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
  border-bottom: 1px solid rgba(0,0,0,0.05) !important;
  transition: all 0.5s cubic-bezier(0.4, 0, 0.2, 1);
  overflow: visible;
}

/* Standardized Header State */
.header--transparent:not(.scrolled),
.header.scrolled {
  background: rgba(240, 249, 255, 0.98) !important;
  box-shadow: 0 4px 30px rgba(0, 0, 0, 0.08) !important;
}

.header .nav-link,
.header .hotel-name,
.header .hotel-tagline {
  color: #051730 !important;
  text-shadow: none !important;
}

.header .hamburger span {
  background: #051730 !important;
}

@media (min-width: 768px) {
  .header {
    top: 0;
  }
}

.header.scrolled .header-logo img {
  filter: drop-shadow(0 2px 8px rgba(0, 0, 0, .05));
}

.header.scrolled-solid {
  top: 0 !important;
}

.header-inner {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  width: 100% !important;
  max-width: 1200px !important;
  height: var(--header-height) !important;
  margin: 0 auto !important;
  padding: 0 40px !important;
  position: relative !important;
  z-index: 10 !important;
  overflow: visible !important;
}

.header-logo {
  display: flex !important;
  align-items: center !important;
  gap: 15px !important;
  flex: 0 0 auto !important;
  z-index: 15 !important;
  margin-right: 40px !important;
}

.nav-desktop {
  flex: 1 1 auto !important;
  display: flex !important;
  justify-content: flex-end !important;
  align-items: center !important;
  margin-left: 40px !important;
}

/* Base Logo Wrapper */
.logo-badge-wrap {
  width: 110px;
  height: 110px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  transition: all 0.6s cubic-bezier(0.34, 1.56, 0.64, 1);
  z-index: 100;
  transform: translateY(0);
}

.logo-badge-wrap::before {
  content: '';
  position: absolute;
  inset: 0;
  background: #ffffff;
  border-radius: 50%;
  opacity: 0;
  transform: scale(0.5);
  transition: all 0.6s cubic-bezier(0.34, 1.56, 0.64, 1);
  z-index: -1;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.25);
}

.header-logo img {
  height: 100% !important;
  /* Force to fill container */
  width: 100% !important;
  object-fit: contain;
  transition: all 0.6s cubic-bezier(0.34, 1.56, 0.64, 1);
  filter: drop-shadow(0 4px 15px rgba(0, 0, 0, .15));
  transform: scale(1);
  /* Fill the circle more aggressively */
}

/* SCROLL EFFECT */
.header.scrolled .logo-badge-wrap {
  transform: scale(1);
}

.header.scrolled .logo-badge-wrap::before {
  opacity: 1;
  transform: scale(1);
  background: #ffffff;
  box-shadow: 0 6px 24px rgba(0, 0, 0, 0.15);
}

.header.scrolled .header-logo img {
  transform: scale(1);
  filter: drop-shadow(0 2px 8px rgba(0, 0, 0, 0.1));
}

/* Hover: White contrast flip */
.header-logo:hover .logo-badge-wrap::before {
  background: #ffffff;
  box-shadow: 0 15px 50px rgba(0, 0, 0, 0.2);
  transform: scale(1.05);
}

.header-logo:hover img {
  transform: scale(1.35);
}

/* Signature Entrance Animation */
@keyframes logoEntrance {
  0% {
    transform: scale(0.2);
    opacity: 0;
  }

  100% {
    transform: scale(1);
    opacity: 1;
  }
}

.logo-badge-wrap {
  animation: logoEntrance 1s cubic-bezier(0.34, 1.56, 0.64, 1) forwards;
}

.header-logo-text {
  display: flex;
  flex-direction: column;
  transition: all 0.5s ease;
  margin-left: 15px;
}

.header.scrolled .header-logo-text {
  transform: none;
}

.hotel-name {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.15rem;
  color: #051730;
  line-height: 1.2;
  transition: color var(--trans-fast);
}

.header.scrolled .hotel-name {
  color: #051730;
}

.hotel-tagline {
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--gold-accent);
  transition: color var(--trans-fast);
}

.header.scrolled .hotel-tagline {
  color: var(--gold-accent);
}

/* Desktop Nav */
.nav-desktop {
  display: none !important;
  align-items: center !important;
  margin: 0 auto !important;
  padding-left: 50px !important; /* Extra breathing room from logo */
}

@media (min-width: 1024px) {
  .nav-desktop {
    display: flex !important;
    gap: 10px !important;
  }
}

.nav-link {
  display: inline-block !important;
  margin-right: 25px !important;
  padding: 10px 0 !important;
  font-size: 0.95rem !important;
  font-weight: 700 !important;
  color: var(--navy-deep) !important;
  transition: all 0.3s ease !important;
  white-space: nowrap !important;
  position: relative !important;
}

.nav-link:last-child {
  margin-right: 0 !important;
}

.header.scrolled .nav-link {
  color: var(--navy-deep) !important;
}

.nav-link::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0;
  height: 2px;
  background: var(--gold-accent);
  transition: width var(--trans-fast);
}

.nav-link:hover {
  color: var(--navy-deep);
}

.nav-link:hover::after {
  width: 100%;
}

.nav-link.active {
  color: var(--navy-deep) !important;
}

.nav-link.active::after {
  width: 100%;
}

html {
  scroll-behavior: auto !important;
}

.btn-nav-cta {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  margin-left: var(--space-4);
  padding: 0.75rem 1.75rem;
  background: var(--gold-accent); /* Gold */
  color: #051730 !important; /* Navy text */
  font-size: 0.9rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  border-radius: var(--radius-full);
  transition: all var(--trans-fast);
  box-shadow: 0 4px 15px rgba(200, 153, 53, 0.3);
  white-space: nowrap;
}

.btn-nav-cta:hover {
  background: var(--gold-dark);
  transform: translateY(-2px);
  box-shadow: 0 8px 30px rgba(200, 153, 53, .4);
  color: var(--navy-deep);
}

/* Hamburger */
.hamburger {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 44px;
  height: 44px;
  gap: 5px;
  border-radius: var(--radius-sm);
  transition: background var(--trans-fast);
}

@media (min-width: 1024px) {
  .hamburger {
    display: none;
  }
}

.hamburger:hover {
  background: rgba(255, 255, 255, .1);
}

.header.scrolled .hamburger:hover {
  background: var(--neutral-100);
}

.hamburger span {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--dark-900);
  border-radius: 2px;
  transition: transform var(--trans-base), opacity var(--trans-base), background var(--trans-fast);
}

.header.scrolled .hamburger span {
  background: var(--dark-900);
}

.hamburger.open span:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}

.hamburger.open span:nth-child(2) {
  opacity: 0;
}

.hamburger.open span:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

/* Mobile Nav */
.nav-mobile {
  position: fixed;
  top: var(--header-height);
  left: 0;
  width: 100%;
  height: calc(100dvh - var(--header-height));
  background: var(--cream);
  transform: translateX(100%);
  transition: transform var(--trans-base);
  z-index: 999;
  overflow-y: auto;
}

@media (min-width: 768px) {
  .nav-mobile {
    top: calc(var(--topbar-height) + var(--header-height));
  }
}

.nav-mobile.open {
  transform: translateX(0);
}

.nav-mobile-inner {
  display: flex;
  flex-direction: column;
  padding: var(--space-6);
  gap: var(--space-1);
}

.nav-mobile .nav-link {
  color: var(--charcoal) !important;
  font-size: 1.1rem;
  padding: var(--space-5) var(--space-6);
  border-bottom: 1px solid var(--parchment);
  font-weight: 600;
  display: block;
}

.nav-mobile .nav-link:hover {
  color: var(--dark-900);
  background: var(--neutral-100);
}

.nav-mobile .nav-link.active {
  background: var(--lime-500);
  color: var(--dark-900) !important;
}

.btn-mobile-cta {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  margin-top: var(--space-4);
  padding: var(--space-4);
  background: var(--gold-500);
  color: var(--charcoal);
  font-size: 1rem;
  font-weight: 700;
  border-radius: var(--radius-md);
  text-align: center;
}

.nav-mobile-contact {
  margin-top: var(--space-6);
  padding-top: var(--space-6);
  border-top: 1px solid var(--parchment);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.nav-mobile-contact a {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  color: var(--dark-600);
  font-size: 0.92rem;
}

.nav-mobile-contact i {
  color: var(--gold-500);
  font-size: 1.1rem;
}

/* ============================================================
   HERO SECTION
   ============================================================ */
.hero {
  position: relative;
  height: 100vh;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  overflow: hidden;
  background: var(--charcoal);
}

/* Cinematic Hero Slider */
.hero-slider {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.hero-slide {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  visibility: hidden;
  transition: opacity 1.5s var(--trans-slow), visibility 1.5s var(--trans-slow);
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding-left: 5%;
  overflow: hidden;
}

.hero-slide.active {
  opacity: 1;
  visibility: visible;
  z-index: 1;
}

.hero-slide .hero-content {
  opacity: 1;
  will-change: transform, opacity;
}

.hero-slide.active .hero-content {
  opacity: 1;
  transform: translateX(0);
}

.hero-slide-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  z-index: -1;
  transition: opacity 1.5s ease-in-out;
  animation: kenBurns 20s infinite alternate ease-in-out;
  will-change: transform;
}

@keyframes kenBurns {
  0% {
    transform: scale(1) translate(0, 0);
  }

  100% {
    transform: scale(1.15) translate(-1%, -1%);
  }
}

.hero-slide.active .hero-slide-bg {
  opacity: 1;
}

/* Slider Overlays */
.hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg,
      rgba(15, 10, 5, 0.45) 0%,
      rgba(15, 10, 5, 0.2) 30%,
      rgba(15, 10, 5, 0) 60%), linear-gradient(to bottom,
      rgba(15, 10, 5, 0) 0%,
      rgba(15, 10, 5, 0.4) 100%);
  z-index: 2;
  pointer-events: none;
}

/* Slider Navigation Controls */
.hero-slider-nav {
  display: none !important;
}

@media (max-width: 768px) {
  .hero-slider-nav {
    bottom: var(--space-20);
    width: 100%;
    justify-content: center;
  }
}

.slider-control {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid rgba(255, 255, 255, 0.2);
  color: var(--white);
  font-size: 1.2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--trans-fast);
}

.slider-control:hover {
  background: var(--lime-500);
  color: var(--dark-900);
  border-color: var(--lime-500);
  transform: scale(1.1);
}

.slider-dots {
  display: flex;
  gap: var(--space-3);
}

.dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.3);
  border: 1px solid rgba(255, 255, 255, 0.2);
  transition: all var(--trans-fast);
  padding: 0;
}

.dot.active {
  background: var(--lime-500);
  transform: scale(1.3);
  box-shadow: 0 0 15px rgba(206, 232, 88, 0.6);
}

/* Particles */
.hero-particles {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  overflow: hidden;
}

.particle {
  position: absolute;
  width: 2px;
  height: 2px;
  background: #EBD293;
  border-radius: 50%;
  box-shadow: 0 0 5px rgba(200, 153, 53, 0.3);
  animation: particleFloat var(--dur, 12s) var(--delay, 0s) infinite ease-in-out;
  opacity: 0;
}

.particle:nth-child(1) {
  left: 5%;
  top: 20%;
  --dur: 9s;
  --delay: 0s;
}

.particle:nth-child(2) {
  left: 15%;
  top: 60%;
  --dur: 11s;
  --delay: 1s;
  width: 2px;
  height: 2px;
}

.particle:nth-child(3) {
  left: 25%;
  top: 35%;
  --dur: 8s;
  --delay: 2s;
}

.particle:nth-child(4) {
  left: 35%;
  top: 75%;
  --dur: 13s;
  --delay: 0.5s;
  width: 2px;
  height: 2px;
}

.particle:nth-child(5) {
  left: 45%;
  top: 15%;
  --dur: 10s;
  --delay: 3s;
}

.particle:nth-child(6) {
  left: 55%;
  top: 50%;
  --dur: 7s;
  --delay: 1.5s;
  width: 2px;
  height: 2px;
}

.particle:nth-child(7) {
  left: 65%;
  top: 80%;
  --dur: 12s;
  --delay: 0.8s;
}

.particle:nth-child(8) {
  left: 75%;
  top: 30%;
  --dur: 9s;
  --delay: 2.5s;
  width: 2px;
  height: 2px;
}

.particle:nth-child(9) {
  left: 85%;
  top: 65%;
  --dur: 11s;
  --delay: 0.3s;
}

.particle:nth-child(10) {
  left: 92%;
  top: 45%;
  --dur: 8s;
  --delay: 1.8s;
  width: 2px;
  height: 2px;
}

.particle:nth-child(11) {
  left: 10%;
  top: 88%;
  --dur: 14s;
  --delay: 0.6s;
}

.particle:nth-child(12) {
  left: 50%;
  top: 92%;
  --dur: 9s;
  --delay: 2.2s;
  width: 2px;
  height: 2px;
}

.particle:nth-child(13) {
  left: 80%;
  top: 10%;
  --dur: 10s;
  --delay: 1.1s;
}

.particle:nth-child(14) {
  left: 30%;
  top: 8%;
  --dur: 8s;
  --delay: 3.5s;
  width: 2px;
  height: 2px;
}

.particle:nth-child(15) {
  left: 70%;
  top: 95%;
  --dur: 12s;
  --delay: 0.9s;
}

.particle:nth-child(16) {
  left: 22%;
  top: 50%;
  --dur: 11s;
  --delay: 2.8s;
}

.particle:nth-child(17) {
  left: 60%;
  top: 70%;
  --dur: 9s;
  --delay: 0.4s;
  width: 2px;
  height: 2px;
}

.particle:nth-child(18) {
  left: 88%;
  top: 25%;
  --dur: 13s;
  --delay: 1.6s;
}

@keyframes particleFloat {
  0% {
    transform: translate(0, 0) scale(1);
    opacity: 0;
  }

  20% {
    opacity: 0.6;
  }

  50% {
    transform: translate(20px, -50px) scale(1.5);
    opacity: 0.8;
  }

  80% {
    opacity: 0.4;
  }

  100% {
    transform: translate(40px, -100px) scale(1);
    opacity: 0;
  }
}

/* Hero Content */
.hero-content {
  position: relative;
  z-index: 10;
  text-align: left;
  max-width: 580px;
  margin-left: 0;
  padding: 40px 50px;
  background: rgba(10, 8, 5, 0.8);
  backdrop-filter: blur(25px);
  -webkit-backdrop-filter: blur(25px);
  border: 1px solid rgba(200, 153, 53, 0.25);
  border-radius: 40px;
  box-shadow: 0 30px 60px rgba(0, 0, 0, 0.5);
  will-change: transform, opacity;
}

.hero-content * {
  color: #ffffff !important;
}

@media (max-width: 768px) {
  .hero-content {
    text-align: center;
    margin-left: 0;
  }
}

.hero-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 10px 24px;
  background: rgba(0, 0, 0, 0.3);
  border: 1.5px solid rgba(200, 153, 53, 0.5);
  border-radius: var(--radius-full);
  color: var(--white);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  margin-bottom: var(--space-6);
}

.hero-badge i {
  font-size: 1.1rem;
  color: var(--gold-accent);
}

.hero-title {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-2);
  margin-bottom: var(--space-6);
}

@media (max-width: 768px) {
  .hero-title {
    align-items: center;
  }
}

.hero-line {
  display: block;
  font-family: var(--font-display);
  font-size: clamp(2.4rem, 6vw, 4rem);
  font-weight: 600;
  color: #ffffff !important;
  line-height: 1.1;
  opacity: 1;
  text-shadow: 0 4px 30px rgba(0, 0, 0, 0.6);
}

.hero-line:nth-child(1) {}

.hero-line:nth-child(2) {}

.hero-line:nth-child(3) {}

.hero-line--accent {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(2.6rem, 6vw, 4.5rem);
  font-weight: 500;
  color: #EBD293;
  background: linear-gradient(90deg,
      #EBD293 0%,
      #f2d58a 25%,
      #ffffff 50%,
      #f2d58a 75%,
      #EBD293 100%);
  background-size: 200% auto;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent !important;
  animation: goldShimmer 4s infinite linear;
  margin: -10px 0 15px;
}

@keyframes goldShimmer {
  0% {
    background-position: -200% center;
  }

  100% {
    background-position: 200% center;
  }
}

.hero-line--sub {
  font-size: 1.1rem;
  font-weight: 400;
  color: #ffffff;
  letter-spacing: 0.5px;
  margin-bottom: 20px;
}

.hero-subtitle {
  font-size: 0.95rem;
  font-weight: 400;
  color: rgba(255, 255, 255, 0.8) !important;
  line-height: 1.5;
  max-width: 480px;
  margin: 0 0 20px;
  opacity: 1;
}

.hero-divider {
  width: 50px;
  height: 2px;
  background: #EBD293;
  margin-bottom: 20px;
}

@media (max-width: 768px) {
  .hero-subtitle {
    margin: 0 auto var(--space-10);
  }
}

.hero-actions {
  display: flex;
  align-items: center;
  gap: 20px;
  opacity: 1;
}

.btn-hero-primary {
  background: transparent !important;
  color: #EBD293 !important;
  border: 1.5px solid #EBD293 !important;
  padding: 12px 30px;
  border-radius: var(--radius-full) !important;
  font-weight: 600;
  font-size: 1rem;
  display: flex;
  align-items: center;
  gap: 10px;
  transition: all 0.3s ease;
}

.btn-hero-primary:hover {
  background: rgba(200, 153, 53, 0.1) !important;
  transform: translateY(-2px);
}

.btn-hero-primary i {
  color: #EBD293;
  font-size: 1.2rem;
}

.btn-hero-outline {
  background: transparent !important;
  color: #ffffff !important;
  border: 1.5px solid rgba(200, 153, 53, 0.6) !important;
  padding: 12px 30px;
  border-radius: var(--radius-full);
  font-weight: 500;
  display: flex;
  align-items: center;
  gap: 10px;
  transition: all 0.3s ease;
}

.btn-hero-outline:hover {
  background: rgba(200, 153, 53, 0.1) !important;
  border-color: #EBD293 !important;
}

/* Loyalty Section Button Overrides (Readability & Luxury Fix) */
.loyalty-promo-section .btn-hero-primary {
  background: #ffffff !important;
  color: #051730 !important;
  /* Deep Black/Navy */
  border: 2px solid #EBD293 !important;
  /* Gold */
  font-weight: 800 !important;
  text-transform: uppercase;
  letter-spacing: 1px;
  box-shadow: 0 10px 30px rgba(200, 153, 53, 0.3);
  animation: luxuryPulse 2.5s infinite ease-in-out;
  position: relative;
  overflow: hidden;
}

.loyalty-promo-section .btn-hero-primary:hover {
  background: #051730 !important;
  color: #ffffff !important;
  border-color: #ffffff !important;
  transform: translateY(-3px) scale(1.02);
  box-shadow: 0 15px 40px rgba(5, 23, 48, 0.4);
}

@keyframes luxuryPulse {
  0% {
    box-shadow: 0 0 0 0 rgba(200, 153, 53, 0.6);
    transform: scale(1);
  }

  50% {
    box-shadow: 0 0 0 15px rgba(200, 153, 53, 0);
    transform: scale(1.03);
  }

  100% {
    box-shadow: 0 0 0 0 rgba(200, 153, 53, 0);
    transform: scale(1);
  }
}

.loyalty-promo-section .btn-hero-outline {
  background: #051730 !important;
  color: #ffffff !important;
  border: 2px solid #EBD293 !important;
  font-weight: 800 !important;
  text-transform: uppercase;
  letter-spacing: 1px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3);
  animation: luxuryPulse 2.5s infinite ease-in-out;
  animation-delay: 0.5s;
  /* Staggered pulse */
}

.loyalty-promo-section .btn-hero-outline:hover {
  background: #ffffff !important;
  color: #051730 !important;
  border-color: #051730 !important;
  transform: translateY(-3px) scale(1.02);
  box-shadow: 0 15px 40px rgba(5, 23, 48, 0.4);
}

@media (max-width: 768px) {
  .hero-actions {
    justify-content: center;
  }
}

/* Hero Trust Bar */
.hero-trust-container {
  position: absolute;
  bottom: 110px;
  /* Elevated to clear booking bar */
  left: 0;
  width: 100%;
  z-index: 20;
}

.hero-trust {
  display: flex;
  flex-wrap: nowrap !important;
  /* Force single line */
  align-items: center;
  justify-content: flex-start;
  gap: 25px;
  /* Tighter gap to fit */
  padding-left: calc(5% + 50px);
  max-width: 580px;
  /* Match card width */
  opacity: 0;
  animation: fadeSlideUp 0.9s var(--ease-luxury) 1.5s forwards;
}

@media (max-width: 768px) {
  .hero-trust {
    justify-content: center;
  }
}

.hero-trust-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.trust-icon {
  width: 38px;
  height: 38px;
  background: var(--navy-deep);
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 50%;
  color: var(--gold-accent);
  font-size: 0.95rem;
  flex-shrink: 0;
  box-shadow: 0 6px 15px rgba(200, 153, 53, 0.2);
}

.trust-text {
  display: flex;
  flex-direction: column;
  text-align: left;
}

.trust-text strong {
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--white);
  line-height: 1.2;
}

.trust-text span {
  font-size: 0.75rem;
  color: rgba(255, 255, 255, .6);
}

.hero-trust-divider {
  width: 1px;
  height: 36px;
  background: rgba(255, 255, 255, .2);
}

@media (max-width: 480px) {
  .hero-trust-divider {
    display: none;
  }
}

/* Floating Price Badge */
.hero-price-badge {
  position: absolute;
  right: var(--space-8);
  bottom: var(--space-16);
  z-index: 3;
  opacity: 0;
  animation: fadeSlideLeft 0.9s var(--ease-luxury) 1.7s forwards;
}

.price-badge-inner {
  background: rgba(255, 255, 255, .1);
  backdrop-filter: blur(16px);
  border: 1px solid rgba(255, 255, 255, .2);
  border-radius: var(--radius-lg);
  padding: var(--space-5) var(--space-6);
  text-align: center;
  min-width: 160px;
}

.price-badge-label {
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: rgba(255, 255, 255, .6);
  font-weight: 600;
  margin-bottom: var(--space-1);
}

.price-badge-amount {
  font-family: var(--font-display);
  font-size: 2.2rem;
  font-weight: 700;
  color: var(--white);
  line-height: 1;
  margin-bottom: var(--space-1);
}

.price-badge-per {
  font-size: 0.78rem;
  color: rgba(255, 255, 255, .55);
  margin-bottom: var(--space-4);
}

.price-badge-cta {
  display: block;
  padding: var(--space-2) var(--space-4);
  background: var(--gold-accent);
  color: var(--navy-deep);
  font-size: 0.8rem;
  font-weight: 700;
  border-radius: var(--radius-full);
  transition: all var(--trans-fast);
}

.price-badge-cta:hover {
  background: var(--gold-dark);
  transform: scale(1.04);
  box-shadow: var(--shadow-gold);
}

@media (max-width: 768px) {
  .hero-price-badge {
    display: none;
  }
}

/* Scroll Indicator */
.hero-scroll-indicator {
  position: absolute;
  bottom: var(--space-8);
  left: 50%;
  transform: translateX(-50%);
  z-index: 3;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  color: rgba(255, 255, 255, .5);
  font-size: 0.7rem;
  letter-spacing: 2px;
  text-transform: uppercase;
  font-weight: 600;
  opacity: 0;
  animation: fadeIn 1s var(--ease-luxury) 2s forwards;
}

.scroll-line {
  width: 1px;
  height: 50px;
  background: linear-gradient(to bottom, var(--gold-accent), transparent);
  animation: scrollPulse 2s ease-in-out infinite;
}

@keyframes scrollPulse {

  0%,
  100% {
    transform: scaleY(1);
    opacity: 0.6;
  }

  50% {
    transform: scaleY(0.7);
    opacity: 1;
  }
}

/* ============================================================
   KEYFRAME ANIMATIONS
   ============================================================ */
@keyframes fadeSlideDown {
  from {
    opacity: 0;
    transform: translateY(-20px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes fadeSlideUp {
  from {
    opacity: 0;
    transform: translateY(40px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes fadeSlideLeft {
  from {
    opacity: 0;
    transform: translateX(40px);
  }

  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

@keyframes shimmer {
  0% {
    background-position: -200% center;
  }

  100% {
    background-position: 200% center;
  }
}

/* ============================================================
   BOOKING BAR (PREMIUM REFINEMENT)
   ============================================================ */
.booking-section {
  position: relative;
  z-index: 50;
  margin-top: -64px;
  padding: 0 20px;
}

.booking-bar {
  background: rgba(255, 255, 255, 0.9);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border: 1px solid rgba(235, 210, 147, 0.3);
  border-radius: 24px;
  padding: 12px;
  box-shadow: 
    0 10px 40px rgba(5, 23, 48, 0.08),
    0 0 0 1px rgba(5, 23, 48, 0.02);
  max-width: 1300px;
  margin: 0 auto;
}

.booking-bar-inner {
  display: grid;
  grid-template-columns: 1fr;
  align-items: center;
  background: #ffffff;
  border-radius: 18px;
  padding: 8px;
  border: 1px solid rgba(148, 163, 184, 0.1);
}

@media (min-width: 1100px) {
  .booking-bar-inner {
    grid-template-columns: 1.2fr 0.6fr 0.6fr 1.6fr 1.2fr auto;
    gap: 0;
  }
}

.booking-field {
  padding: 12px 24px;
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 6px;
  border-right: 1px solid rgba(148, 163, 184, 0.15);
}

.booking-field:last-of-type {
  border-right: none;
}

@media (max-width: 1099px) {
  .booking-field {
    border-right: none;
    border-bottom: 1px solid rgba(148, 163, 184, 0.15);
  }
}

.booking-field label {
  font-family: var(--font-sans);
  font-size: 0.65rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: #94a3b8 !important;
  display: flex;
  align-items: center;
  gap: 8px;
}

.booking-field label i {
  color: #EBD293;
  font-size: 0.8rem;
}

.input-with-icon {
  position: relative;
  display: flex;
  align-items: center;
}

.input-with-icon > i:first-child {
  position: absolute;
  left: 0;
  font-size: 1.1rem;
  color: #051730;
  pointer-events: none;
  opacity: 0.7;
}

.booking-field input,
.booking-field select {
  width: 100%;
  padding: 8px 0 8px 28px;
  border: none !important;
  background: transparent !important;
  font-family: var(--font-sans);
  font-size: 1rem;
  font-weight: 600;
  color: #051730 !important;
  cursor: pointer;
  outline: none !important;
  box-shadow: none !important;
}

.booking-field input::placeholder {
  color: #94a3b8 !important;
  font-weight: 400;
}

/* Custom Dropdown Arrow */
.input-with-icon select {
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%23EBD293' viewBox='0 0 256 256'%3E%3Cpath d='M213.66,101.66l-80,80a8,8,0,0,1-11.32,0l-80-80a8,8,0,0,1,11.32-11.32L128,164.69l74.34-74.35a8,8,0,0,1,11.32,11.32Z'%3E%3C/path%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right center;
  padding-right: 25px;
}

.btn-check-avail {
  background: #051730;
  color: #EBD293 !important;
  padding: 0 40px;
  height: 64px;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  font-size: 0.9rem;
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  margin-left: 12px;
  position: relative;
  overflow: hidden;
}

@media (max-width: 1099px) {
  .btn-check-avail {
    margin: 12px 0 0 0;
    width: 100%;
  }
}

.btn-check-avail:hover {
  background: #EBD293;
  color: #051730 !important;
  transform: scale(1.02);
  box-shadow: 0 10px 30px rgba(235, 210, 147, 0.3);
}

/* Luxury Flatpickr Theme */
.flatpickr-calendar {
  background: #ffffff !important;
  border: 1px solid rgba(148, 163, 184, 0.15) !important;
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.15) !important;
  border-radius: 20px !important;
  padding: 15px !important;
}

.flatpickr-months .flatpickr-month {
  background: transparent !important;
  color: #051730 !important;
  fill: #051730 !important;
}

.flatpickr-current-month .flatpickr-monthDropdown-months {
  font-weight: 700 !important;
}

.flatpickr-weekday {
  color: #94a3b8 !important;
  font-weight: 700 !important;
}

.flatpickr-day {
  border-radius: 10px !important;
  color: #051730 !important;
}

.flatpickr-day.selected, 
.flatpickr-day.startRange, 
.flatpickr-day.endRange {
  background: #051730 !important;
  border-color: #051730 !important;
  color: #EBD293 !important;
}

.flatpickr-day.inRange {
  background: rgba(235, 210, 147, 0.2) !important;
  box-shadow: -5px 0 0 rgba(235, 210, 147, 0.2), 5px 0 0 rgba(235, 210, 147, 0.2) !important;
}

.flatpickr-day:hover {
  background: #EBD293 !important;
  color: #051730 !important;
}

.flatpickr-day-price {
  color: #b88632 !important;
  font-weight: 700 !important;
}

/* ============================================================
   ABOUT SECTION
   ============================================================ */
.about-section {
  background: linear-gradient(135deg, #ffffff 0%, #f0f9ff 100%);
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

/* Premium Noise/Grain Texture */
.about-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E");
  opacity: 0.015;
  pointer-events: none;
  z-index: 1;
}

/* Soft Gold/Champagne Glow Effects */
.about-section::after {
  content: '';
  position: absolute;
  top: -10%;
  right: -10%;
  width: 60%;
  height: 60%;
  background: radial-gradient(circle, rgba(235, 210, 147, 0.12) 0%, transparent 70%);
  filter: blur(80px);
  z-index: 0;
  pointer-events: none;
  animation: float-glow 20s ease-in-out infinite alternate;
}

@keyframes float-glow {
  0% { transform: translate(0, 0) rotate(0deg); }
  100% { transform: translate(-5%, 5%) rotate(5deg); }
}

.about-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-16);
  align-items: center;
}

@media (min-width: 1024px) {
  .about-grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-20);
  }
}

/* Images block */
.about-images {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
  min-height: 420px;
}

@media (min-width: 1024px) {
  .about-images {
    min-height: 520px;
  }
}

.about-img-main img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}

.about-img-main:hover img {
  transform: scale(1.03);
}

.about-img-main {
  grid-column: 1 / 3;
  position: relative;
  border-radius: 24px;
  overflow: hidden;
  aspect-ratio: 4 / 3;
  box-shadow: 0 20px 50px rgba(5, 23, 48, 0.15), 0 0 20px rgba(235, 210, 147, 0.1);
  transition: box-shadow 0.6s ease;
}

.about-img-main:hover {
  box-shadow: 0 30px 70px rgba(5, 23, 48, 0.2), 0 0 30px rgba(235, 210, 147, 0.2);
}

.about-img-main::before {
  content: '';
  position: absolute;
  inset: 0;
  border: 1px solid rgba(235, 210, 147, 0.4);
  border-radius: 24px;
  z-index: 2;
  pointer-events: none;
  transition: border-color 0.6s ease;
}

.about-img-main:hover::before {
  border-color: rgba(235, 210, 147, 0.7);
}

.about-img-tag {
  position: absolute;
  bottom: var(--space-6);
  left: var(--space-6);
  z-index: 10;
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: 12px 24px;
  background: #ffffff !important;
  color: var(--navy-deep) !important;
  border-radius: var(--radius-full);
  font-size: 0.85rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 1px;
  box-shadow: 0 15px 40px rgba(5, 23, 48, 0.1);
  border: 1px solid rgba(235, 210, 147, 0.4);
}

.about-img-tag i {
  font-size: 1rem;
}

.about-img-secondary {
  grid-column: 1 / 2;
  border-radius: 24px;
  overflow: hidden;
  aspect-ratio: 1;
  box-shadow: 0 15px 40px rgba(5, 23, 48, 0.12);
  transition: all 0.6s ease;
}

.about-img-secondary img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}

.about-img-secondary:hover {
  transform: translateY(-5px);
  box-shadow: 0 25px 50px rgba(5, 23, 48, 0.18);
}

.about-img-secondary:hover img {
  transform: scale(1.03);
}

.about-years-badge {
  display: none;
  /* 10+ Years already shown inside the counters card */
}

.years-number {
  font-family: var(--font-display);
  font-size: 3.5rem;
  font-weight: 700;
  color: var(--charcoal);
  line-height: 1;
}

.years-label {
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--dark-900);
  letter-spacing: 1px;
  text-transform: uppercase;
  line-height: 1.4;
  margin-top: var(--space-2);
}

/* About Content */
.about-content {
  display: flex !important;
  flex-direction: column !important;
  gap: 2rem !important;
}

body section.about-section .about-lead {
  font-size: 1.15rem !important;
  font-weight: 600 !important;
  color: #1a1208 !important;
  line-height: 1.8 !important;
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
}

body section.about-section .about-body {
  font-size: 1rem !important;
  color: var(--text-sec) !important;
  line-height: 1.8 !important;
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  margin-bottom: 20px !important;
}


/* Counters - Premium Glassmorphic */
.about-counters {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 1.5rem !important;
  padding: var(--space-8);
  background: #ffffff;
  border-radius: 24px;
  border: 1px solid rgba(235, 210, 147, 0.4);
  box-shadow: 0 15px 50px rgba(5, 23, 48, 0.04);
  transition: all 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

.about-counters:hover {
  box-shadow: 0 25px 60px rgba(5, 23, 48, 0.08);
  border-color: var(--gold-accent);
  transform: translateY(-4px);
}

@media (min-width: 480px) {
  .about-counters {
    grid-template-columns: repeat(4, 1fr);
  }
}

.counter-item {
  text-align: center;
}

.counter-number {
  font-family: var(--font-display);
  font-size: 2.2rem;
  font-weight: 700;
  color: var(--gold-accent);
  line-height: 1;
  margin-bottom: var(--space-1);
}

.counter-label {
  font-size: 0.75rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  color: var(--navy-deep);
}

/* Feature Pills */
.about-features {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 1rem !important;
}

/* About section: force Get In Touch button to be compact & fully visible */
.about-section .btn-gold {
  align-self: flex-start !important;
  width: auto !important;
  background: var(--gold-500) !important;
  color: var(--charcoal) !important;
  padding: 0.875rem 2.5rem !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
  box-shadow: 0 6px 20px rgba(201, 168, 76, 0.35) !important;
  border: none !important;
}

.about-section .btn-gold:hover {
  background: var(--gold-400) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 12px 30px rgba(201, 168, 76, 0.45) !important;
}

.feature-pill {
  display: inline-flex !important;
  align-items: center !important;
  gap: 0.6rem !important;
  flex-shrink: 0 !important;
  padding: 12px 24px;
  background: linear-gradient(135deg, #ffffff 0%, #f8f9fa 100%);
  border: 1px solid rgba(235, 210, 147, 0.5);
  border-radius: var(--radius-full);
  font-size: 0.9rem;
  font-weight: 800;
  color: var(--navy-deep);
  transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
  box-shadow: 0 10px 30px rgba(5, 23, 48, 0.05);
  cursor: pointer;
}

.feature-pill--promo {
  background: linear-gradient(135deg, #fffbeb 0%, #fff7ed 100%);
  border-color: rgba(245, 158, 11, 0.3);
  color: #b45309;
}

.feature-pill--promo i {
  color: #f59e0b !important;
}

.feature-pill i {
  color: var(--gold-accent);
  font-size: 1.2rem;
  transition: transform 0.3s ease;
}

.feature-pill:hover {
  transform: translateY(-5px) scale(1.02);
  border-color: var(--gold-accent);
  box-shadow: 0 20px 40px rgba(5, 23, 48, 0.08);
  background: #ffffff;
}

.feature-pill:hover i {
  transform: scale(1.2);
}

/* ============================================================
   ROOMS SECTION
   ============================================================ */
.rooms-section {
  background: var(--ivory);
}

.rooms-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
}

@media (min-width: 768px) {
  .rooms-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1100px) {
  .rooms-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.room-card {
  background: var(--white);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-md);
  transition: transform var(--trans-base), box-shadow var(--trans-base);
  display: flex;
  flex-direction: column;
}

.room-card:hover {
  transform: translateY(-8px);
  box-shadow: var(--shadow-xl);
}

.room-card-img-wrap {
  position: relative;
  overflow: hidden;
  aspect-ratio: 4 / 3;
}

.room-card-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--trans-slow);
}

.room-card:hover .room-card-img {
  transform: scale(1.08);
}

.room-badge {
  position: absolute;
  top: var(--space-4);
  left: var(--space-4);
  z-index: 2;
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: var(--space-1) var(--space-3);
  background: var(--gold-500);
  color: var(--charcoal);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  border-radius: var(--radius-full);
}

.room-badge.bestseller {
  background: var(--gold-500);
}

.room-card-overlay {
  position: absolute;
  inset: 0;
  background: rgba(26, 18, 8, .5);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity var(--trans-base);
}

.room-card:hover .room-card-overlay {
  opacity: 1;
}

.room-overlay-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-6);
  background: var(--gold-500);
  color: var(--charcoal);
  font-size: 0.88rem;
  font-weight: 700;
  border-radius: var(--radius-full);
  transform: translateY(10px);
  transition: transform var(--trans-base), opacity 0.2s;
  opacity: 0;
}

.room-card:hover .room-overlay-btn {
  transform: translateY(0);
  opacity: 1;
}

.room-overlay-btn:hover {
  background: var(--gold-400);
  color: var(--charcoal);
}

.room-card-body {
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  flex: 1;
}

.room-card-name {
  font-family: var(--font-display);
  font-size: 1.4rem;
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1.2;
}

.room-card-desc {
  font-size: 0.88rem;
  color: var(--text-sec);
  line-height: 1.7;
}

.room-card-meta {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.meta-item {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--text-sec);
}

.meta-item i {
  color: var(--gold-500);
}

.room-card-amenities {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.amenity-chip {
  display: inline-flex;
  align-items: center;
  padding: 4px 12px;
  background-color: #f1f5f9;
  color: var(--navy-deep);
  font-size: 0.74rem;
  font-weight: 600;
  border-radius: var(--radius-full);
  border: 1px solid #e2e8f0;
}

.room-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: var(--space-4);
  border-top: 1px solid var(--parchment);
  margin-top: auto;
}

.room-price {
  display: flex;
  align-items: baseline;
  gap: 4px;
}

.price-from {
  font-size: 0.75rem;
  color: var(--text-muted);
}

.price-amount {
  font-family: var(--font-display);
  font-size: 1.7rem;
  font-weight: 700;
  color: var(--gold-600);
  line-height: 1;
}

.price-per {
  font-size: 0.75rem;
  color: var(--dark-500);
}

.room-actions {
  display: flex;
  gap: var(--space-2);
}

.btn-room-outline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-2) var(--space-4);
  border: 1.5px solid var(--parchment);
  border-radius: var(--radius-md);
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--dark-700);
  transition: all var(--trans-fast);
}

.btn-room-outline:hover {
  border-color: var(--gold-400);
  color: var(--gold-600);
  background: var(--gold-50);
}

.btn-room-gold {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-2) var(--space-4);
  background: var(--gold-500);
  color: var(--charcoal);
  border-radius: var(--radius-md);
  font-size: 0.82rem;
  font-weight: 700;
  transition: all var(--trans-fast);
}

.btn-room-gold:hover {
  background: var(--gold-400);
  color: var(--charcoal);
  box-shadow: var(--shadow-gold);
  transform: translateY(-1px);
}

/* ============================================================
   AMENITIES SECTION
   ============================================================ */
.amenities-section {
  position: relative;
  overflow: hidden;
  padding: var(--space-24) 0;
}

.amenities-section .section-eyebrow {
  color: var(--text-primary);
}

.amenities-section .section-heading {
  color: var(--text-primary);
}

.amenities-section .section-heading em {
  color: var(--text-primary);
  opacity: 0.8;
}

.amenities-section .section-subheading {
  color: var(--text-sec);
}

.amenities-grid {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: center !important;
  gap: 30px !important;
  width: 100% !important;
}


@media (min-width: 640px) {
  .amenities-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (min-width: 1024px) {
  .amenities-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

.amenity-card {
  flex: 1 1 250px !important;
  max-width: 320px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  text-align: center !important;
  padding: 40px 30px !important;
  background: #ffffff !important;
  border: 1px solid rgba(235, 210, 147, 0.4) !important;
  border-radius: 24px !important;
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1) !important;
  box-shadow: 0 10px 30px rgba(5, 23, 48, 0.05) !important;
  position: relative !important;
  overflow: visible !important;
}


.amenity-card:hover {
  border-color: var(--gold-accent) !important;
  transform: translateY(-8px) !important;
  box-shadow: 0 20px 40px rgba(5, 23, 48, 0.1) !important;
}

.amenity-icon-ring {
  width: 72px;
  height: 72px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  border: 2px solid rgba(235, 210, 147, 0.3);
  background: rgba(235, 210, 147, 0.1);
  color: var(--gold-500);
  font-size: 1.75rem;
  margin-bottom: var(--space-5);
  transition: all var(--trans-base);
  position: relative;
}

.amenity-icon-ring::before {
  content: '';
  position: absolute;
  inset: -5px;
  border-radius: 50%;
  border: 1px solid rgba(235, 210, 147, 0.2);
}

.amenity-card:hover .amenity-icon-ring {
  background: var(--gold-accent);
  border-color: var(--gold-accent);
  box-shadow: 0 0 25px rgba(235, 210, 147, 0.4);
  color: var(--navy-deep);
}

.amenity-card h4 {
  font-family: var(--font-display);
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--navy-deep);
  margin-bottom: var(--space-3);
  transition: color var(--trans-fast);
}

.amenity-card:hover h4 {
  color: var(--gold-600);
}

.amenity-card p {
  font-size: 0.88rem;
  color: var(--text-sec);
  line-height: 1.6;
  transition: color var(--trans-fast);
}

.amenity-card:hover p {
  color: var(--navy-deep);
}

/* ============================================================
   GALLERY SECTION
   ============================================================ */
.gallery-section {
  background: var(--cream);
}

.gallery-masonry {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-4);
}

@media (min-width: 768px) {
  .gallery-masonry {
    grid-template-columns: repeat(3, 1fr);
  }
}

.gallery-item {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  cursor: pointer;
  aspect-ratio: 1;
  background: var(--white);
}

.gallery-item.gallery-wide {
  grid-column: span 2;
  aspect-ratio: 16 / 9;
}

.gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--trans-slow);
  display: block;
}

.gallery-overlay {
  position: absolute;
  inset: 0;
  background: rgba(5, 23, 48, 0.4);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  opacity: 0;
  transition: opacity var(--trans-base);
  color: var(--white);
  backdrop-filter: blur(4px);
}

.gallery-item:hover .gallery-overlay {
  opacity: 1;
}

/* ============================================================
   ULTIMATE 3D SPHERE GALLERY (Sphere-App Integration)
   ============================================================ */
.gallery-section.sphere-app-root {
  --sphere-radius: 1200px;
  --sphere-circ: calc(var(--sphere-radius) * 3.14);
  --segments-x: 37;
  --segments-y: 37;
  --sphere-rotation-y: 0deg;
  --sphere-rotation-x: 0deg;
  --rot-y: calc(360deg / var(--segments-x));
  --rot-x: calc(360deg / var(--segments-y));
  --item-width: calc((var(--sphere-circ) / var(--segments-x)));
  --item-height: calc((var(--sphere-circ) / var(--segments-y)));
  --sphere-bg-scrim: rgba(0, 0, 0, 0.6);
  --sphere-item-bg: rgba(255, 255, 255, 0.15);
  --sphere-gradient-center: rgba(253, 249, 240, 0);
  --sphere-gradient-edge: rgba(220, 200, 160, 0.7);

  position: relative;
  background: radial-gradient(circle at center, #ffffff 0%, #fdf9f0 40%, #f4e8d1 100%);
  padding: 0;
  overflow: hidden;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  z-index: 1;
}

.sphere-gallery-header {
  position: absolute;
  top: 40px;
  left: 0;
  right: 0;
  z-index: 9999;
  text-align: center;
  pointer-events: none;
}

.sphere-gallery-header .section-heading {
  color: #1a1a1a !important;
  text-shadow: 0 1px 12px rgba(255,250,242,0.95), 0 0 30px rgba(255,250,242,1) !important;
  text-align: center !important;
}

.sphere-gallery-header .section-subheading {
  color: rgba(0, 0, 0, 0.75) !important;
  text-shadow: 0 1px 8px rgba(255,250,242,0.9) !important;
  text-align: left !important;
}

.sphere-gallery-header .section-eyebrow {
  color: #1a1a1a !important;
  text-shadow: 0 1px 8px rgba(255,250,242,0.9) !important;
  display: flex !important;
  justify-content: center !important;
  width: 100% !important;
  margin-left: 0 !important;
}

.sphere-gallery-header .section-eyebrow::before,
.sphere-gallery-header .section-eyebrow::after {
  background: #1a1a1a !important;
}

.sphere-main {
  display: flex;
  width: 100%;
  height: 100vh;
  justify-content: center;
  align-items: center;
  overflow: hidden;
  touch-action: none;
}

.stage {
  perspective: calc(var(--sphere-radius) * 2.5);
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.sphere {
  position: relative;
  width: 0;
  height: 0;
  transform: translateZ(-1300px) rotateX(0deg) rotateY(290deg);
  transform-style: preserve-3d;
  will-change: transform;
}

.sphere-overlay {
  background-image: radial-gradient(var(--sphere-gradient-center) 40%, var(--sphere-gradient-edge) 100%);
  position: absolute;
  inset: 0;
  z-index: 5;
  pointer-events: none;
}

.sphere-overlay--blur {
  backdrop-filter: blur(8px);
  mask-image: radial-gradient(rgba(0, 0, 0, 0) 40%, rgba(0, 0, 0, 1) 100%);
  position: absolute;
  inset: 0;
  z-index: 4;
  pointer-events: none;
}

.item {
  width: calc(var(--item-width) * var(--item-size-x));
  height: calc(var(--item-height) * var(--item-size-y));
  position: absolute;
  transform-origin: 50% 50%;
  top: -999px;
  bottom: -999px;
  left: -999px;
  right: -999px;
  margin: auto;
  backface-visibility: visible;
  transform-style: preserve-3d;
  transition: transform 0.4s cubic-bezier(0.2, 0.8, 0.2, 1);
  transform:
    rotateY(calc(var(--rot-y) * (var(--offset-x) + ((var(--item-size-x) - 1) / 2)) + var(--rot-y-delta, 0deg))) rotateX(calc(calc(var(--rot-x) * (var(--offset-y) - ((var(--item-size-y) - 1) / 2))) + var(--rot-x-delta, 0deg))) translateZ(var(--sphere-radius));
}

.item__image {
  position: absolute;
  inset: 8px;
  border-radius: 12px;
  background-color: var(--sphere-item-bg);
  overflow: hidden;
  backface-visibility: visible;
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.1);
  transition: transform 0.4s ease, box-shadow 0.4s ease;
  cursor: pointer;
}

.item__image img {
  object-fit: cover;
  width: 100%;
  height: 100%;
  pointer-events: none;
}

.item__image:hover {
  transform: scale(1.05) translateZ(20px);
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2);
}

.viewer {
  position: fixed;
  inset: 0;
  z-index: 2000;
  pointer-events: none;
  display: flex;
  align-items: center;
  justify-content: center;
}

.viewer .frame {
  width: 80vw;
  height: 80vh;
  max-width: 1000px;
  max-height: 800px;
  pointer-events: none;
}

.scrim {
  position: absolute;
  inset: 0;
  background-color: var(--sphere-bg-scrim);
  opacity: 0;
  z-index: 9998;
  transition: opacity 0.4s ease;
  backdrop-filter: blur(8px);
  pointer-events: none;
}

[data-enlarging="true"] .scrim {
  opacity: 1;
  pointer-events: all;
}

.enlarge-pop {
  border-radius: 24px;
  overflow: hidden;
  box-shadow: 0 30px 100px rgba(0, 0, 0, 0.5);
  transition: all 0.5s cubic-bezier(0.4, 0, 0.2, 1);
  display: flex;
  align-items: center;
  justify-content: center;
}

.enlarge-pop img {
  max-width: 100%;
  max-height: 80vh;
  object-fit: contain;
  border-radius: 8px;
}

[data-enlarging="true"] .enlarge-pop {
  opacity: 1;
}

.sphere-hint {
  position: absolute;
  bottom: 40px;
  left: 0;
  right: 0;
  text-align: center;
  color: rgba(0, 0, 0, 0.4);
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 2px;
  z-index: 100;
  pointer-events: none;
}

/* Lightbox */
.lightbox {
  position: fixed;
  inset: 0;
  z-index: 2000;
  background: rgba(10, 8, 5, .95);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--trans-base);
}

.lightbox.active {
  opacity: 1;
  pointer-events: all;
}

.lightbox-content {
  max-width: 90vw;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-4);
}

.lightbox-content img {
  max-width: 100%;
  max-height: 80vh;
  border-radius: var(--radius-md);
  object-fit: contain;
  box-shadow: var(--shadow-xl);
}

.lightbox-caption {
  color: rgba(255, 255, 255, .7);
  font-size: 0.9rem;
  font-weight: 500;
  text-align: center;
  letter-spacing: 0.5px;
}

.lightbox-close,
.lightbox-prev,
.lightbox-next {
  position: absolute;
  background: rgba(255, 255, 255, .1);
  border: 1px solid rgba(255, 255, 255, .2);
  color: var(--white);
  border-radius: 50%;
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.3rem;
  transition: all var(--trans-fast);
  cursor: pointer;
  backdrop-filter: blur(6px);
}

.lightbox-close {
  top: var(--space-6);
  right: var(--space-6);
}

.lightbox-prev {
  left: var(--space-6);
  top: 50%;
  transform: translateY(-50%);
}

.lightbox-next {
  right: var(--space-6);
  top: 50%;
  transform: translateY(-50%);
}

.lightbox-close:hover,
.lightbox-prev:hover,
.lightbox-next:hover {
  background: var(--gold-500);
  color: var(--charcoal);
  border-color: var(--gold-500);
}

/* ============================================================
   TESTIMONIALS SECTION
   ============================================================ */
.testimonials-section {
  background: var(--ivory);
  overflow: hidden;
}

.testimonials-wrapper {
  position: relative;
  overflow: hidden;
}

.testimonials-track {
  display: flex;
  transition: transform var(--trans-slow);
  gap: var(--space-6);
}

.testimonial-card {
  flex: 0 0 calc(100% - var(--space-0));
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  min-height: 280px;
  background: var(--white);
  border: 1px solid var(--parchment);
  box-shadow: var(--shadow-md);
  transition: box-shadow var(--trans-base), transform var(--trans-base);
}

@media (min-width: 768px) {
  .testimonial-card {
    flex: 0 0 calc(50% - var(--space-3));
  }
}

@media (min-width: 1100px) {
  .testimonial-card {
    flex: 0 0 calc(33.333% - var(--space-4));
  }
}

.testimonial-card:hover {
  box-shadow: var(--shadow-lg);
  transform: translateY(-4px);
}

.testimonial-quote {
  font-size: 2rem;
  color: var(--gold-400);
  line-height: 1;
}

.testimonial-stars {
  display: flex;
  gap: 3px;
  color: var(--gold-500);
  font-size: 1rem;
}

.testimonial-text {
  font-size: 0.95rem;
  color: var(--dark-600);
  line-height: 1.8;
  font-style: italic;
  flex: 1;
}

.testimonial-author {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding-top: var(--space-4);
  border-top: 1px solid var(--parchment);
}

.author-avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--gold-500);
  color: var(--charcoal);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-size: 1.3rem;
  font-weight: 700;
  flex-shrink: 0;
}

.author-info {
  flex: 1;
}

.author-info strong {
  display: block;
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--charcoal);
}

.author-info span {
  display: block;
  font-size: 0.78rem;
  color: var(--dark-500);
}

.testimonial-platform {
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--gold-600);
  background: var(--gold-50);
  border: 1px solid var(--gold-200);
  border-radius: var(--radius-full);
  padding: 2px 10px;
  letter-spacing: 0.5px;
}

/* Testimonials Controls */
.testimonials-controls {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-6);
  margin-top: var(--space-10);
}

.testimonial-btn {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  border: 1.5px solid var(--parchment);
  background: var(--white);
  color: var(--dark-600);
  font-size: 1.2rem;
  transition: all var(--trans-fast);
  box-shadow: var(--shadow-sm);
}

.testimonial-btn:hover {
  background: var(--gold-500);
  border-color: var(--gold-500);
  color: var(--charcoal);
  transform: scale(1.08);
}

.testimonial-dots {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.testimonial-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--parchment);
  cursor: pointer;
  transition: all var(--trans-fast);
}

.testimonial-dot.active {
  background: var(--gold-500);
  width: 24px;
  border-radius: var(--radius-full);
}



.location-info {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

.location-desc {
  font-size: 1.1rem;
  color: var(--gold-accent);
  line-height: 1.8;
  opacity: 0.85;
}

.location-details {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.location-item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
}

.location-icon {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--white);
  border: 1px solid var(--gold-200);
  border-radius: 12px; /* Premium squared-circle */
  color: var(--gold-700);
  font-size: 1.25rem;
  flex-shrink: 0;
  box-shadow: var(--shadow-sm);
  transition: all var(--trans-base);
}

.location-item:hover .location-icon {
  background: var(--gold-700);
  color: var(--white);
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
}

.location-item>div strong {
  display: block;
  font-size: 0.75rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--gold-800);
  margin-bottom: 4px;
}

.location-item>div span,
.location-item>div a {
  font-size: 1.05rem;
  color: var(--gold-accent);
  line-height: 1.6;
  font-weight: 500;
}

.location-item>div a:hover {
  color: var(--gold-700);
  text-decoration: underline;
}

.location-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  padding-top: var(--space-2);
}

.location-map {
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-xl);
  min-height: 400px;
}

.map-wrapper {
  width: 100%;
  height: 100%;
  min-height: 400px;
}

.map-wrapper iframe {
  width: 100%;
  height: 100%;
  min-height: 400px;
  border: none;
  display: block;
}

/* ============================================================
   CTA BANNER
   ============================================================ */
.cta-banner {
  position: relative;
  overflow: hidden;
  padding: var(--space-24) 0;
  text-align: center;
}

.cta-banner-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.cta-banner-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.cta-banner-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(10, 8, 5, 0.85), rgba(26, 18, 8, 0.8));
  z-index: 1;
}

.cta-banner-content {
  position: relative;
  z-index: 2;
  max-width: 700px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-6);
  padding: 0 var(--space-6);
}

.cta-banner-heading {
  font-family: var(--font-display);
  font-size: clamp(2.2rem, 5vw, 3.5rem);
  font-weight: 600;
  color: #ffffff;
  line-height: 1.15;
}

.cta-banner-heading em {
  font-style: italic;
  color: var(--gold-400);
}

.cta-banner-sub {
  font-size: 1.1rem;
  color: rgba(255, 255, 255, 0.9);
  line-height: 1.75;
  max-width: 600px;
}

.cta-banner-perks {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-5);
}

.cta-banner-perks span {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  color: rgba(255, 255, 255, 0.85);
  font-size: 0.95rem;
  font-weight: 500;
}

.cta-banner-perks i {
  color: var(--gold-400);
  font-size: 1rem;
}

/* ============================================================
   FOOTER
   ============================================================ */
.footer {
  background: #051730;
  color: #EBD293;
}

.footer-top {
  padding: var(--space-12) 0 var(--space-8);
}

.footer-top .container {
  max-width: 98% !important;
  width: 98% !important;
  margin: 0 auto;
  padding: 0 40px;
}

.footer-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: var(--space-12) !important;
  width: 100% !important;
}

@media (min-width: 1200px) {
  .footer-grid {
    grid-template-columns: 1fr 0.8fr 1fr 1.8fr !important;
  }
}

@media (min-width: 640px) {
  .footer-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .footer-grid {
    grid-template-columns: 1.2fr 1fr 1fr 1.2fr;
    gap: var(--space-6);
    max-width: 1100px;
    margin: 0 auto;
  }
}

.footer-col {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.footer-brand {
  gap: var(--space-6);
}

.footer-logo-link {
  display: inline-block;
}

.footer-logo {
  height: 64px;
  width: auto;
  object-fit: contain;
  filter: brightness(1.1);
  mix-blend-mode: screen;
}

.footer-tagline {
  font-size: 0.9rem;
  line-height: 1.6;
  color: rgba(235, 210, 147, 0.85);
}

.footer-socials {
  display: flex;
  gap: var(--space-3);
}

.social-icon {
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(5, 23, 48, .07);
  border: 1px solid rgba(5, 23, 48, .1);
  border-radius: 50%;
  font-size: 1.1rem;
  color: var(--text-sec);
  transition: all var(--trans-fast);
}

.social-icon:hover {
  background: var(--gold-accent);
  border-color: var(--gold-accent);
  color: var(--white);
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(5, 23, 48, .3);
}

.footer-col-title {
  font-family: var(--font-display);
  font-size: 1.05rem;
  font-weight: 700;
  color: #EBD293;
  margin-bottom: var(--space-2);
  padding-bottom: var(--space-2);
  border-bottom: 1px solid rgba(235, 210, 147, 0.2);
}

.footer-links {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.footer-links a {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: 0.9rem;
  color: rgba(235, 210, 147, 0.7);
  font-weight: 500;
  transition: all var(--trans-fast);
}

.footer-links a i {
  font-size: 0.7rem;
  color: #EBD293;
}

.footer-links a:hover {
  color: #ffffff;
  padding-left: 5px;
}

}

.footer-links a:hover i {
  transform: translateX(3px);
}

.footer-contact-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.footer-contact-list li {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  font-size: 0.9rem;
  color: rgba(235, 210, 147, 0.8);
  line-height: 1.5;
}

.footer-contact-list i {
  color: #EBD293;
}

.footer-contact-list a {
  color: rgba(255, 255, 255, 0.85);
  transition: color var(--trans-fast);
}

.footer-contact-list a:hover {
  color: #ffffff;
}

.footer-contact-list i {
  color: #EBD293;
  font-size: 1rem;
  flex-shrink: 0;
  margin-top: 2px;
}

.footer-book-col {
  gap: var(--space-4);
}

.footer-book-text {
  font-size: 0.88rem;
  color: rgba(255, 255, 255, 0.7);
  line-height: 1.7;
}

.footer-book-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: 0.75rem 1.25rem;
  background: #EBD293;
  color: #051730;
  font-size: 0.85rem;
  font-weight: 700;
  border-radius: var(--radius-md);
  transition: all var(--trans-fast);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.footer-book-btn:hover {
  background: #ffffff;
  transform: translateY(-2px);
  box-shadow: 0 5px 15px rgba(0,0,0,0.3);
}

}

.footer-manage-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: 0.7rem 1.2rem;
  background: transparent;
  color: #EBD293;
  font-size: 0.85rem;
  font-weight: 600;
  border-radius: var(--radius-md);
  border: 1px solid rgba(235, 210, 147, 0.4);
  transition: all var(--trans-fast);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.footer-manage-btn:hover {
  background: rgba(235, 210, 147, 0.1);
  border-color: #EBD293;
  color: #ffffff;
}

.footer-book-content-wrapper {
  display: flex;
  gap: var(--space-6);
  align-items: flex-start;
  margin-top: var(--space-4);
}

.footer-book-actions {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

@media (max-width: 1024px) {
  .footer-book-content-wrapper {
    flex-direction: column;
    width: 100%;
  }
  .footer-book-actions, .footer-cert-badges {
    width: 100%;
  }
}

.footer-cert-badges {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.cert-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 0.4rem 0.8rem;
  background: rgba(235, 210, 147, 0.1);
  border: 1px solid rgba(235, 210, 147, 0.2);
  border-radius: var(--radius-full);
  font-size: 0.72rem;
  font-weight: 600;
  color: #EBD293;
}

.cert-badge i {
  font-size: 0.9rem;
}

/* Footer Bottom */
.footer-bottom {
  border-top: 1px solid rgba(235, 210, 147, 0.1);
  padding: var(--space-4) 0;
}

.footer-bottom-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-1);
  text-align: center;
  font-size: 0.82rem;
  color: rgba(235, 210, 147, 0.4);
  max-width: 95% !important;
  margin: 0 auto;
}

@media (min-width: 768px) {
  .footer-bottom-inner {
    flex-direction: row;
    justify-content: space-between;
    text-align: left;
  }
}

.footer-powered a {
  color: var(--gold-500);
  transition: color var(--trans-fast);
}

.footer-powered a:hover {
  color: var(--white);
}

/* ============================================================
   FLOATING HUB
   ============================================================ */
.floating-hub {
  position: fixed;
  right: var(--space-6);
  bottom: var(--space-8);
  z-index: 1100;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-3);
}

.hub-item {
  position: relative;
  width: 54px;
  height: 54px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  color: var(--white);
  box-shadow: var(--shadow-lg);
  transition: all var(--trans-fast);
}

.hub-item:hover {
  transform: scale(1.1) translateY(-3px);
}

.hub-book {
  background: var(--gold-500);
  color: var(--charcoal);
}

.hub-book:hover {
  background: var(--gold-400);
  box-shadow: var(--shadow-gold);
}

.hub-wa {
  background: var(--wa-green);
}

.hub-wa:hover {
  background: #1fba59;
  box-shadow: 0 8px 24px rgba(37, 211, 102, .4);
}

.hub-me {
  background: #0084ff;
}

.hub-me:hover {
  background: #0071e3;
  box-shadow: 0 8px 24px rgba(0, 132, 255, .4);
}

.hub-tooltip {
  position: absolute;
  right: calc(100% + 10px);
  top: 50%;
  transform: translateY(-50%);
  background: var(--dark-900);
  color: var(--white);
  font-size: 0.78rem;
  font-weight: 600;
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-sm);
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--trans-fast);
}

.hub-item:hover .hub-tooltip {
  opacity: 1;
}

/* ============================================================
   BACK TO TOP
   ============================================================ */
.back-to-top {
  position: relative;
  width: 54px;
  height: 0;
  opacity: 0;
  visibility: hidden;
  border-radius: 50%;
  background: var(--white);
  color: var(--gold-700);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  box-shadow: var(--shadow-lg);
  transition: all var(--trans-base);
  border: 1px solid var(--gold-200);
  overflow: hidden;
}

.back-to-top.visible {
  height: 54px;
  opacity: 1;
  visibility: visible;
  margin-bottom: var(--space-3);
}

.back-to-top:hover {
  background: var(--gold-50);
  color: var(--gold-600);
  transform: translateY(-3px) scale(1.1);
}

/* ============================================================
   BOOKING MODAL
   ============================================================ */
.exely-modal {
  position: fixed;
  inset: 0;
  z-index: 2000;
  background: rgba(10, 8, 5, .8);
  backdrop-filter: blur(6px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-6);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--trans-base);
}

.exely-modal.active {
  opacity: 1;
  pointer-events: all;
}

.exely-modal-container {
  background: var(--white);
  border-radius: var(--radius-xl);
  width: 100%;
  max-width: 900px;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  box-shadow: var(--shadow-xl);
  transform: scale(0.95) translateY(20px);
  transition: transform var(--trans-base);
}

.exely-modal.active .exely-modal-container {
  transform: scale(1) translateY(0);
}

.exely-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-5) var(--space-6);
  border-bottom: 1px solid var(--parchment);
}

.exely-modal-header h3 {
  font-family: var(--font-display);
  font-size: 1.3rem;
  font-weight: 600;
  color: var(--charcoal);
}

.exely-modal-close {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--neutral-100);
  color: var(--dark-600);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.3rem;
  line-height: 1;
  transition: all var(--trans-fast);
}

.exely-modal-close:hover {
  background: var(--gold-500);
  color: var(--charcoal);
}

.exely-modal-body {
  flex: 1;
  overflow-y: auto;
  padding: var(--space-6);
  min-height: 400px;
}

/* ============================================================
   RESPONSIVE UTILITIES
   ============================================================ */
@media (max-width: 480px) {
  .hero-content {
    padding-top: calc(var(--header-height) + var(--space-8));
    padding-bottom: var(--space-12);
  }

  .hero-line {
    font-size: clamp(2rem, 10vw, 3.5rem);
  }

  .about-images {
    grid-template-columns: 1fr;
  }

  .about-img-main {
    grid-column: 1;
  }

  .about-img-secondary {
    display: none;
  }

  .about-years-badge {
    position: absolute;
    right: var(--space-4);
    bottom: var(--space-4);
    width: 90px;
    height: 90px;
    aspect-ratio: auto;
  }

  .years-number {
    font-size: 2rem;
  }

  .years-label {
    font-size: 0.65rem;
  }

  .about-counters {
    grid-template-columns: repeat(2, 1fr);
  }

  .rooms-grid {
    grid-template-columns: 1fr;
  }

  .gallery-masonry {
    grid-template-columns: 1fr;
  }

  .gallery-item.gallery-wide {
    grid-column: 1;
  }
}

/* ============================================================
   MISC
   ============================================================ */
.btn,
.btn-primary,
.btn-outline,
.btn-green,
.btn-red,
.btn-outline-green {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-6);
  font-weight: 600;
  font-size: 0.9rem;
  border-radius: var(--radius-full);
  transition: all var(--trans-fast);
  white-space: nowrap;
}

.btn-primary {
  background: var(--gold-500);
  color: var(--charcoal);
}

.btn-primary:hover {
  background: var(--gold-400);
  transform: translateY(-2px);
  box-shadow: var(--shadow-gold);
}

.btn-outline {
  background: transparent;
  color: var(--white);
  border: 2px solid rgba(255, 255, 255, .35);
}

.btn-outline:hover {
  background: rgba(255, 255, 255, .1);
  border-color: rgba(255, 255, 255, .6);
}

.btn-green {
  background: var(--green-700);
  color: var(--white);
}

.btn-green:hover {
  background: var(--green-600);
}

.btn-outline-green {
  border: 1.5px solid var(--parchment);
  color: var(--dark-700);
  background: var(--white);
}

.btn-outline-green:hover {
  border-color: var(--gold-400);
  color: var(--gold-600);
  background: var(--gold-50);
}

.btn-red {
  background: var(--red-600);
  color: var(--white);
}

.btn-red:hover {
  background: #991b1b;
}

/* Legacy class compatibility for rooms.php, room-details.php etc */
.reveal,
.card-reveal {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.7s var(--ease-luxury), transform 0.7s var(--ease-luxury);
}

.reveal.active,
.card-reveal.active {
  opacity: 1;
  transform: translateY(0);
}

.section-label {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--gold-500);
  margin-bottom: var(--space-3);
}

.section-label::before {
  content: '';
  width: 28px;
  height: 1.5px;
  background: var(--gold-400);
}

.section-title {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 4vw, 2.8rem);
  font-weight: 600;
  color: var(--charcoal);
  line-height: 1.2;
  margin-bottom: var(--space-4);
}

.section-subtitle {
  font-size: 1rem;
  color: var(--dark-500);
  max-width: 600px;
  line-height: 1.75;
}

.bg-light {
  background: var(--cream);
}

/* Booking bar for rooms/other pages */
.booking-bar-legacy {
  background: var(--white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xl);
  padding: var(--space-6);
  margin-top: -40px;
  position: relative;
  z-index: 10;
}

/* Grid helpers used in other pages */
.grid-2 {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-12);
}

@media (min-width: 1024px) {
  .grid-2 {
    grid-template-columns: 1fr 1fr;
  }
}

.text-center {
  text-align: center;
}

.mt-12 {
  margin-top: var(--space-12);
}

.flex-1 {
  flex: 1;
}

.relative {
  position: relative;
}

.z-10 {
  z-index: 10;
}

.-mt-10 {
  margin-top: -2.5rem;
}

.w-full {
  width: 100%;
}

.mt-8 {
  margin-top: var(--space-8);
}

.pt-6 {
  padding-top: var(--space-6);
}

/* Rooms page grid */
.rooms-grid-full {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
}

@media (min-width: 640px) {
  .rooms-grid-full {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1100px) {
  .rooms-grid-full {
    grid-template-columns: repeat(3, 1fr);
  }
}

.rooms-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
}

@media (min-width: 640px) {
  .rooms-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1100px) {
  .rooms-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

/* ============================================================
   FLATPICKR CUSTOM PRICING STYLES
   ============================================================ */
.flatpickr-day {
  height: 48px !important;
  line-height: normal !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  padding-top: 4px !important;
}

.flatpickr-day-price {
  display: block;
  font-size: 0.65rem;
  font-weight: 800;
  color: var(--lime-700);
  margin-top: 2px;
  line-height: 1;
}

.flatpickr-day.selected .flatpickr-day-price,
.flatpickr-day.startRange .flatpickr-day-price,
.flatpickr-day.endRange .flatpickr-day-price {
  color: var(--dark-900);
}

.flatpickr-day.flatpickr-disabled .flatpickr-day-price {
  opacity: 0.3;
}

@media (max-width: 768px) {
  .flatpickr-day {
    height: 42px !important;
  }

  .flatpickr-day-price {
    font-size: 0.58rem;
  }
}

/* ============================================================
   PREMIUM PAYMENT MODAL & CHECKOUT UI
   ============================================================ */
.pm-overlay {
  position: fixed;
  inset: 0;
  background: rgba(10, 10, 10, 0.85);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  z-index: 2000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
  opacity: 0;
  pointer-events: none;
  transition: all 0.4s var(--ease-luxury);
}

.pm-overlay.active {
  opacity: 1;
  pointer-events: auto;
}

.pm-modal {
  width: 100%;
  max-width: 480px;
  max-height: 90vh;
  background: var(--dark-900);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-xl);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: var(--shadow-xl);
  transform: translateY(30px) scale(0.95);
  transition: all 0.5s var(--ease-luxury);
}

.pm-overlay.active .pm-modal {
  transform: translateY(0) scale(1);
}

.pm-header {
  padding: var(--space-5) var(--space-6);
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  text-align: center;
  position: relative;
  flex-shrink: 0;
}

.pm-close {
  position: absolute;
  top: var(--space-4);
  right: var(--space-4);
  width: 32px;
  height: 32px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.05);
  color: var(--neutral-400);
  cursor: pointer;
  transition: all var(--trans-fast);
  font-size: 0.9rem;
}

.pm-close:hover {
  background: var(--red-600);
  color: #fff;
  transform: rotate(90deg);
}

.pm-header h2 {
  font-family: var(--font-display);
  font-size: 1.3rem;
  color: #fff;
  margin-bottom: 2px;
}

.pm-header p {
  color: var(--neutral-400);
  font-size: 0.8rem;
}

.pm-body {
  padding: var(--space-4) var(--space-5);
  overflow-y: auto;
  flex: 1;
}

.pm-methods-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-2);
  margin-top: var(--space-3);
}

@media (max-width: 420px) {
  .pm-methods-grid {
    grid-template-columns: 1fr;
  }
}

.pm-method-btn {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.08);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--space-3);
  cursor: pointer;
  transition: all 0.2s ease;
  position: relative;
  overflow: hidden;
}

.pm-method-btn::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--lime-500);
  opacity: 0;
  transition: all var(--trans-base);
  z-index: 0;
}

.pm-method-btn:hover {
  transform: translateY(-4px);
  border-color: var(--lime-500);
  background: rgba(206, 232, 88, 0.05);
}

.pm-method-btn.selected {
  border-color: var(--lime-500);
  background: rgba(206, 232, 88, 0.1);
  box-shadow: 0 0 20px rgba(206, 232, 88, 0.15);
}

.pm-method-icon {
  font-size: 1.2rem;
  color: var(--lime-500);
  position: relative;
  z-index: 1;
  flex-shrink: 0;
}

.pm-method-info {
  position: relative;
  z-index: 1;
  min-width: 0;
}

.pm-method-name {
  display: block;
  font-weight: 600;
  color: #fff;
  font-size: 0.85rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.pm-method-sub {
  display: block;
  font-size: 0.7rem;
  color: var(--neutral-400);
  margin-top: 1px;
}

/* Categories */
.pm-cat-title {
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--lime-500);
  margin: var(--space-4) 0 var(--space-2);
  font-weight: 800;
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.pm-cat-title::after {
  content: '';
  flex: 1;
  height: 1px;
  background: rgba(255, 255, 255, 0.05);
}

.pm-footer {
  padding: var(--space-4) var(--space-5);
  border-top: 1px solid rgba(255, 255, 255, 0.05);
  text-align: center;
  flex-shrink: 0;
}

.pm-summary {
  background: rgba(206, 232, 88, 0.05);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-4);
  display: flex;
  justify-content: space-between;
  align-items: center;
  color: #fff;
  border: 1px dashed rgba(206, 232, 88, 0.2);
  font-size: 0.9rem;
}

.btn-pm-pay {
  width: 100%;
  padding: 0.9rem;
  background: var(--lime-500);
  color: var(--dark-900);
  border: none;
  border-radius: var(--radius-md);
  font-weight: 800;
  font-size: 0.95rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  cursor: pointer;
  transition: all var(--trans-base);
}

.btn-pm-pay:hover {
  background: #fff;
  transform: translateY(-2px);
  box-shadow: 0 10px 25px rgba(255, 255, 255, 0.2);
}

.btn-pm-pay:disabled {
  background: var(--neutral-700);
  color: var(--neutral-400);
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

.pm-loader {
  display: none;
  width: 24px;
  height: 24px;
  border: 3px solid rgba(0, 0, 0, 0.1);
  border-top-color: var(--dark-900);
  border-radius: 50%;
  animation: pmRotate 0.8s linear infinite;
}

@keyframes pmRotate {
  to {
    transform: rotate(360deg);
  }
}

.pm-secure-badge {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  margin-top: var(--space-4);
  font-size: 0.75rem;
  color: var(--neutral-500);
}

.pm-secure-badge i {
  color: var(--lime-500);
}

/* ============================================================
   RESPONSIVE OPTIMIZATIONS & READABILITY FIXES
   ============================================================ */

@media (max-width: 768px) {

  /* Fix oversized page headers on mobile */
  .page-header {
    padding: calc(var(--header-height) + var(--space-12)) var(--space-4) var(--space-10) !important;
  }

  .room-detail-hero {
    height: 350px !important;
    margin-top: var(--header-height) !important;
  }

  /* Improved contrast for small mobile text */
  .section-subheading,
  .page-subtitle,
  .footer-tagline {
    color: rgba(255, 255, 255, 0.85) !important;
  }

  .about-body {
    font-size: 0.95rem;
    color: var(--dark-800);
  }

  /* Ensure booking bar fields stack nicely on small mobile */
  .booking-bar-inner {
    grid-template-columns: 1fr !important;
  }

  .room-card-actions {
    flex-direction: column;
  }

  .room-card-actions a {
    width: 100%;
  }
}

@media (max-width: 480px) {

  /* Handle very small screens */
  .page-title {
    font-size: 2.2rem !important;
  }

  .section-heading {
    font-size: 1.8rem !important;
  }

  .booking-bar {
    padding: var(--space-4) !important;
  }
}

/* ============================================================
   FRONTEND ENHANCEMENTS � LOYALTY & PORTAL
   ============================================================ */

.nav-link--portal {
  font-weight: 700 !important;
  color: var(--gold-500) !important;
  display: flex;
  align-items: center;
  gap: 6px;
}

.nav-link--portal:hover {
  color: var(--gold-400) !important;
}

/* Loyalty & Promotion Blocks */
.loyalty-cta-banner {
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
  animation: slideInUp 0.6s ease;
}

@keyframes slideInUp {
  from {
    transform: translateY(20px);
    opacity: 0;
  }

  to {
    transform: translateY(0);
    opacity: 1;
  }
}

@media (max-width: 900px) {
  .loyalty-grid {
    grid-template-columns: 1fr !important;
  }
}

.btn-wa {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 24px;
  background: #25D366;
  color: #fff;
  border-radius: var(--radius-full);
  font-weight: 700;
  text-decoration: none;
  transition: all 0.3s;
}

.btn-wa:hover {
  background: #128C7E;
  transform: translateY(-2px);
  box-shadow: 0 5px 15px rgba(37, 211, 102, 0.3);
}

/* Room Modal Specifics */
#room-detail-overlay.active {
  display: flex;
  align-items: center;
  justify-content: center;
}

.pm-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.7);
  backdrop-filter: blur(8px);
  z-index: 2000;
  display: none;
  padding: 24px;
}

.pm-modal {
  background: #fff;
  border-radius: 24px;
  overflow: hidden;
  box-shadow: 0 30px 60px rgba(0, 0, 0, 0.5);
  animation: modalIn 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

@keyframes modalIn {
  from {
    transform: scale(0.9) translateY(20px);
    opacity: 0;
  }

  to {
    transform: scale(1) translateY(0);
    opacity: 1;
  }
}

.pm-modal-header {
  padding: 24px 32px;
  border-bottom: 1px solid var(--border);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.pm-modal-body {
  padding: 32px;
  max-height: 70vh;
  overflow-y: auto;
}

.pm-modal-footer {
  padding: 24px 32px;
  background: var(--bg);
  border-top: 1px solid var(--border);
  display: flex;
  justify-content: flex-end;
}

.pm-modal-close {
  background: var(--bg);
  border: none;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  transition: all 0.2s;
}

.pm-modal-close:hover {
  background: var(--red);
  color: #fff;
}

/* ============================================================
   ROOMS & SUITES (PREMIUM POLISH)
   ============================================================ */
.rooms-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)) !important;
  gap: 40px !important;
  /* Slightly larger gap for premium breathing room */
  width: 100% !important;
  align-items: stretch !important;
  margin-bottom: 80px !important;
  /* FORCE space below the grid so the button never overlaps */
}

.room-card {
  background: #ffffff !important;
  border-radius: 20px !important;
  /* Smoother curve */
  overflow: hidden !important;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.05) !important;
  /* Softer, more elegant shadow */
  display: flex !important;
  flex-direction: column !important;
  /* REMOVED transform transition so it doesn't fight GSAP scrolling animations */
  transition: box-shadow 0.4s ease !important;
  height: 100% !important;
  /* Force equal height */
  border: 1px solid rgba(0, 0, 0, 0.03) !important;
}

.room-card:hover {
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.08) !important;
}

.room-card-img-wrap {
  position: relative !important;
  width: 100% !important;
  height: 260px !important;
  /* Slightly taller for better photo display */
  overflow: hidden !important;
}

.room-card-img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  transition: transform 0.7s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.room-card:hover .room-card-img {
  transform: scale(1.04) !important;
}

.room-card-body {
  padding: 30px !important;
  display: flex !important;
  flex-direction: column !important;
  flex-grow: 1 !important;
}

.room-card-name {
  font-family: 'Cormorant Garamond', serif !important;
  font-size: 1.6rem !important;
  font-weight: 600 !important;
  color: #051730 !important;
  margin-bottom: 12px !important;
  line-height: 1.2 !important;
}

.room-card-desc {
  font-size: 0.95rem !important;
  color: #334155 !important; /* Darker Slate for visibility */
  line-height: 1.6 !important;
  margin-bottom: 24px !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 3 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  min-height: 4.8em !important;
}

.room-card-meta {
  font-size: 0.9rem !important;
  font-weight: 600 !important;
  color: #0a1f3d !important; /* Deep Navy */
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  margin-bottom: auto !important;
}

.room-card-footer {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  margin-top: 24px !important;
  padding-top: 20px !important;
  border-top: 1px solid rgba(0, 0, 0, 0.1) !important;
}

.room-price {
  display: flex !important;
  align-items: baseline !important;
  gap: 4px !important;
}

.price-from {
  font-size: 0.8rem !important;
  text-transform: uppercase !important;
  letter-spacing: 1px !important;
  color: #64748b !important; /* Darker for visibility */
}

.price-amount {
  font-size: 1.75rem !important;
  font-weight: 700 !important;
  color: #051730 !important;
  letter-spacing: -0.5px !important;
}

.price-per {
  font-size: 0.85rem !important;
  color: #475569 !important; /* Darker for visibility */
}

/* Premium Button Styling for Cards */
.room-actions {
  display: flex !important;
  gap: 12px !important;
}

.btn-room-outline {
  padding: 8px 16px !important;
  border: 1px solid #cbd5e1 !important;
  border-radius: 8px !important;
  font-size: 0.9rem !important;
  font-weight: 600 !important;
  color: #051730 !important;
  transition: all 0.3s ease !important;
}

.btn-room-outline:hover {
  border-color: #051730 !important;
  background: #051730 !important;
  color: #ffffff !important;
}

.btn-room-gold {
  padding: 8px 20px !important;
  background: #EBD293 !important;
  border: 1px solid #EBD293 !important;
  border-radius: 8px !important;
  font-size: 0.9rem !important;
  font-weight: 600 !important;
  color: #ffffff !important;
  transition: all 0.3s ease !important;
  box-shadow: 0 4px 10px rgba(200, 153, 53, 0.3) !important;
}

.btn-room-gold:hover {
  background: #B8B09F !important;
  border-color: #B8B09F !important;
  box-shadow: 0 6px 15px rgba(200, 153, 53, 0.4) !important;
  transform: translateY(-2px) !important;
}

/* ============================================================
   GLOBAL CTA BUTTONS (ULTRA PREMIUM)
   ============================================================ */
.section-cta {
  display: flex !important;
  justify-content: center !important;
  margin-top: 20px !important;
  padding-bottom: 40px !important;
  width: 100% !important;
  clear: both !important;
}

.btn-gold-outline {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 12px !important;
  padding: 18px 45px !important;
  background: linear-gradient(135deg, #d4af37 0%, #aa7c11 100%) !important;
  /* Metallic gold sheen */
  border: none !important;
  border-radius: 50px !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
  color: #ffffff !important;
  /* White text */
  text-transform: uppercase !important;
  letter-spacing: 2px !important;
  box-shadow: 0 10px 30px rgba(200, 153, 53, 0.4) !important;
  /* Rich glowing shadow */
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.btn-gold-outline i {
  font-size: 1.4rem !important;
}

.btn-gold-outline:hover {
  background: linear-gradient(135deg, #c49a2a 0%, #996c0b 100%) !important;
  /* Darker metallic gold on hover */
  box-shadow: 0 15px 40px rgba(200, 153, 53, 0.6) !important;
  transform: translateY(-4px) !important;
}



/* ============================================================
   RESPONSIVE MOBILE PASS v1.0 — Park & Bed
   Pure responsiveness layer. No design changes.
   Appended safely. Does not override desktop styles.
   ============================================================ */

/* ── Global Touch Optimization ── */
html {
  -webkit-tap-highlight-color: transparent;
}

button,
a,
input,
select,
textarea {
  touch-action: manipulation;
}

/* ── Minimum Touch Targets (44px per Apple HIG / Google MD) ── */
.btn-gold,
.btn-hero-primary,
.btn-hero-outline,
.btn-nav-cta,
.btn-check-avail,
.btn-room-gold,
.btn-room-outline,
.btn-wa,
.social-icon,
.hamburger,
.footer-book-btn,
.footer-manage-btn {
  min-height: 44px;
}

.booking-field input,
.booking-field select {
  min-height: 48px;
}

/* ── Smooth Touch Scrolling ── */
.nav-mobile,
.testimonials-track {
  -webkit-overflow-scrolling: touch;
  scroll-behavior: smooth;
}

/* ============================================================
   MOBILE — max-width: 767px
   ============================================================ */
@media (max-width: 767px) {

  /* Container: tighter padding */
  .container {
    padding: 0 var(--space-4);
  }

  /* Header height for mobile */
  :root {
    --header-height: 60px;
  }

  /* Logo size */
  .logo-badge-wrap {
    width: 72px !important;
    height: 72px !important;
  }

  .header-logo-text {
    margin-left: 10px;
  }

  .hotel-name {
    font-size: 0.95rem !important;
  }

  .hotel-tagline {
    font-size: 0.58rem;
  }

  /* Hamburger: always visible on dark hero */
  .hamburger span {
    background: #ffffff !important;
  }

  .header.scrolled .hamburger span {
    background: var(--dark-900) !important;
  }

  /* Hero section */
  .hero-content {
    padding-left: var(--space-4);
    padding-right: var(--space-4);
    padding-bottom: var(--space-12);
  }

  .hero-actions {
    flex-direction: column;
    align-items: center;
    gap: var(--space-3);
    margin-bottom: var(--space-8);
  }

  .hero-actions .btn-hero-primary,
  .hero-actions .btn-hero-outline {
    width: 100%;
    max-width: 340px;
    justify-content: center;
  }

  .trust-icon {
    width: 36px;
    height: 36px;
    font-size: 0.9rem;
  }

  .trust-text strong {
    font-size: 0.85rem;
  }

  .trust-text span {
    font-size: 0.68rem;
  }

  /* Booking bar */
  .booking-section {
    margin-top: -20px;
  }

  .booking-bar {
    border-radius: var(--radius-lg) !important;
    padding: var(--space-4) !important;
  }

  .booking-bar-inner {
    grid-template-columns: 1fr !important;
    gap: var(--space-3);
  }

  .btn-check-avail {
    width: 100%;
    justify-content: center;
    padding: var(--space-4);
    font-size: 1rem;
  }

  /* Section headings */
  .section-heading {
    font-size: clamp(1.6rem, 6vw, 2.5rem) !important;
  }

  .section-subheading {
    font-size: 0.92rem;
  }

  .section-header {
    margin-bottom: var(--space-10);
  }

  /* About section */
  .about-images {
    min-height: auto !important;
    gap: var(--space-3);
  }

  .about-grid {
    gap: var(--space-10);
  }

  .about-counters {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: var(--space-3) !important;
    padding: var(--space-4);
  }

  .counter-number {
    font-size: 1.8rem;
  }

  /* Rooms section */
  .rooms-grid {
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)) !important;
    gap: var(--space-6) !important;
    margin-bottom: var(--space-12) !important;
  }

  .room-card-body {
    padding: 20px !important;
  }

  .room-card-name {
    font-size: 1.3rem !important;
  }

  /* Gallery section */
  .gallery-masonry {
    grid-template-columns: 1fr !important;
    gap: var(--space-3);
  }

  .gallery-wide,
  .gallery-tall {
    grid-column: auto !important;
    grid-row: auto !important;
  }

  /* Location section */
  .location-map,
  .map-wrapper,
  .map-wrapper iframe {
    min-height: 280px;
  }

  .location-actions {
    flex-direction: column;
  }

  .location-actions .btn-gold,
  .location-actions .btn-wa {
    width: 100%;
    justify-content: center;
  }

  /* CTA Banner */
  .cta-banner {
    padding: var(--space-16) 0;
  }

  .cta-banner-perks {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-3);
  }

  /* Footer */
  .footer-top {
    padding: var(--space-12) 0 var(--space-8);
  }

  .footer-grid {
    grid-template-columns: 1fr !important;
    gap: var(--space-8);
  }

  .social-icon {
    width: 44px;
    height: 44px;
  }

  .footer-book-btn,
  .footer-manage-btn {
    width: 100%;
    justify-content: center;
    padding: var(--space-4);
  }

  /* Page header (inner pages) */
  .page-header {
    padding: calc(var(--header-height) + var(--space-10)) var(--space-4) var(--space-8) !important;
  }

  .page-title {
    font-size: clamp(1.8rem, 8vw, 2.8rem) !important;
  }

  .page-subtitle {
    font-size: 0.92rem;
  }

  /* Nav mobile UX */
  .nav-mobile {
    top: var(--header-height) !important;
    height: calc(100dvh - var(--header-height)) !important;
  }

  .nav-mobile .nav-link {
    font-size: 1rem;
    padding: var(--space-4) var(--space-5);
    min-height: 56px;
    display: flex;
    align-items: center;
  }

  .btn-mobile-cta {
    min-height: 52px;
    font-size: 1rem;
  }

  /* Room detail page */
  .room-gallery-main img {
    height: 240px;
    border-radius: var(--radius-lg);
  }

  .booking-sidebar-card {
    position: static;
  }

  .room-features-list {
    flex-direction: column;
    gap: var(--space-3);
  }

  .room-details-price-card {
    text-align: left;
    width: 100%;
  }

  /* book.php page */
  .bk-room-card {
    grid-template-columns: 1fr !important;
  }

  .room-img {
    min-height: 200px;
    border-radius: 12px 12px 0 0;
  }

  .room-pricing {
    border-left: none !important;
    border-top: 1px solid rgba(0, 0, 0, 0.08);
    align-items: flex-start !important;
    text-align: left !important;
    padding: 16px 20px !important;
  }

  .review-grid {
    grid-template-columns: 1fr !important;
  }

  .form-row {
    grid-template-columns: 1fr !important;
  }

  .sb-sep {
    display: none;
  }

  /* Contact form */
  .form-grid-2 {
    grid-template-columns: 1fr !important;
  }

  /* Body padding for sticky CTA */
  body.has-sticky-cta {
    padding-bottom: 72px;
  }
}

/* ============================================================
   TABLET — 768px to 1023px
   ============================================================ */
@media (min-width: 768px) and (max-width: 1023px) {

  .container {
    padding: 0 var(--space-5);
  }

  .logo-badge-wrap {
    width: 90px !important;
    height: 90px !important;
  }

  /* Booking bar: 2-col on tablet, CTA spans full width */
  .booking-bar-inner {
    grid-template-columns: 1fr 1fr !important;
    gap: var(--space-3);
  }

  .btn-check-avail {
    grid-column: 1 / -1;
    width: 100%;
    justify-content: center;
  }

  /* Rooms: 2-col on tablet */
  .rooms-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: var(--space-6) !important;
  }

  /* Gallery: 2-col on tablet */
  .gallery-masonry {
    grid-template-columns: repeat(2, 1fr) !important;
  }

  .gallery-wide {
    grid-column: span 2;
  }

  /* Footer: 2-col at tablet */
  .footer-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: var(--space-8);
  }
}

/* ============================================================
   BOOKING BAR — 1100px: reset any inline max-width overrides
   ============================================================ */
@media (min-width: 1100px) {
  .booking-bar-inner .booking-field {
    max-width: none !important;
  }
}

/* ============================================================
   ULTRAWIDE — min-width: 1600px
   ============================================================ */
@media (min-width: 1600px) {
  .container {
    max-width: 1440px;
  }

  .hero-content {
    max-width: 960px;
  }
}

/* ============================================================
   MOBILE STICKY "BOOK NOW" CTA BAR
   ============================================================ */
.mobile-sticky-cta {
  display: none;
  /* JS/CSS controls visibility */
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 900;
  background: var(--navy-deep);
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  padding: var(--space-3) var(--space-4);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  box-shadow: 0 -8px 30px rgba(0, 0, 0, 0.4);
  transform: translateY(100%);
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.mobile-sticky-cta.visible {
  transform: translateY(0);
}

.mobile-sticky-cta-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  max-width: 480px;
  margin: 0 auto;
}

.mobile-sticky-cta-text {
  display: flex;
  flex-direction: column;
}

.mobile-sticky-cta-label {
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.5);
}

.mobile-sticky-cta-price {
  font-family: var(--font-display);
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--gold-accent);
}

.mobile-sticky-cta-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-6);
  background: var(--gold-accent);
  color: var(--navy-deep);
  font-size: 0.88rem;
  font-weight: 800;
  border-radius: var(--radius-full);
  white-space: nowrap;
  box-shadow: var(--shadow-gold);
  min-height: 44px;
  transition: background var(--trans-fast), color var(--trans-fast);
  flex-shrink: 0;
}

.mobile-sticky-cta-btn:hover,
.mobile-sticky-cta-btn:active {
  background: var(--gold-dark);
  color: var(--navy-deep);
}

@media (max-width: 767px) {
  .mobile-sticky-cta {
    display: block;
  }
}

/* ============================================================
   FOCUS RING — Keyboard Accessibility
   ============================================================ */
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible {
  outline: 2px solid var(--gold-accent);
  outline-offset: 3px;
}

/* ============================================================
   END OF RESPONSIVE MOBILE PASS
   ============================================================ */

/* Marketing Toast */
.marketing-toast {
    position: fixed;
    z-index: 9999;
    background: rgba(5, 23, 48, 0.95);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid rgba(235, 210, 147, 0.4);
    border-radius: 20px;
    padding: 16px 20px;
    display: flex;
    align-items: center;
    gap: 16px;
    box-shadow: 0 20px 50px rgba(5, 23, 48, 0.6), 0 0 30px rgba(235, 210, 147, 0.1);
    transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.4s ease;
    max-width: 420px;
    color: #ffffff;
    opacity: 0;
    pointer-events: none;
}

.marketing-toast-img-wrap {
    width: 60px;
    height: 60px;
    border-radius: var(--radius-md);
    overflow: hidden;
    border: 1px solid rgba(235, 210, 147, 0.4);
    flex-shrink: 0;
}
.marketing-toast-img-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}


/* Positions */
.marketing-toast.pos-bottom-left { bottom: 30px; left: 30px; transform: translateX(-120%); }
.marketing-toast.pos-bottom-right { bottom: 30px; right: 30px; transform: translateX(120%); }
.marketing-toast.pos-top-right { top: 100px; right: 30px; transform: translateX(120%); }

.marketing-toast.active { transform: translateX(0) !important; opacity: 1; pointer-events: all; }

.marketing-toast-icon {
    width: 45px;
    height: 45px;
    background: var(--navy-deep);
    color: #051730;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.4rem;
    flex-shrink: 0;
}
.marketing-toast-content { flex: 1; }
.marketing-toast-text {
    font-size: 0.85rem;
    line-height: 1.4;
    margin-bottom: 8px;
    font-weight: 500;
}
.marketing-toast-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 0.8rem;
    font-weight: 800;
    text-transform: uppercase;
    color: var(--gold-accent);
    text-decoration: none;
    letter-spacing: 1px;
    transition: all var(--trans-fast);
}
.marketing-toast-btn:hover { 
    color: #ffffff;
    transform: translateX(3px);
}
.marketing-toast-close {
    position: absolute;
    top: 12px;
    right: 12px;
    color: rgba(255, 255, 255, 0.5);
    cursor: pointer;
    font-size: 1.1rem;
    transition: color 0.2s, transform 0.2s;
}
.marketing-toast-close:hover { 
    color: var(--gold-accent); 
    transform: scale(1.1);
}

@media (max-width: 640px) {
    .marketing-toast {
        left: 15px;
        right: 15px;
        bottom: 15px;
        max-width: none;
    }
}

/* ============================================================
   BRANDING PILLARS SECTION
   ============================================================ */
.branding-section {
    position: relative;
    overflow: hidden;
    padding: var(--space-24) 0;
}


/* Premium Loyalty Section */
.loyalty-promo-section {
    padding: 120px 0 !important;
}

.loyalty-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 60px;
    align-items: center;
}

@media (max-width: 991px) {
    .loyalty-grid {
        grid-template-columns: 1fr;
        gap: 40px;
    }
}

.loyalty-sub {
    font-size: 1.1rem;
    color: var(--text-sec);
    margin-bottom: 32px;
    line-height: 1.8;
}

.loyalty-perks {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
    margin-bottom: 40px;
}

.loyalty-perk {
    display: flex;
    gap: 12px;
    align-items: flex-start;
}

.loyalty-perk i {
    font-size: 1.5rem;
    color: var(--gold-accent);
}

.loyalty-perk strong {
    display: block;
    margin-bottom: 4px;
    color: var(--navy-deep);
}

.loyalty-perk p {
    font-size: 0.85rem;
    color: var(--text-sec) !important;
}

/* Membership Card */
.loyalty-card-wrap {
    position: relative;
}

.loyalty-membership-card {
    background: #ffffff;
    border: 1px solid rgba(235, 210, 147, 0.4);
    border-radius: 32px;
    padding: 40px;
    box-shadow: 0 10px 40px rgba(5, 23, 48, 0.05);
}

.loyalty-card-user {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 24px;
}

.loyalty-user-badge {
    width: 40px;
    height: 40px;
    background: var(--gold-accent);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #051730;
    font-weight: 800;
}

.loyalty-user-name {
    font-weight: 700;
    font-size: 1rem;
    color: var(--navy-deep);
}

.loyalty-user-meta {
    font-size: 0.8rem;
    color: var(--text-muted);
}

.loyalty-points-box {
    background: var(--bg-sec);
    border-radius: 16px;
    padding: 24px;
    margin-bottom: 20px;
    border: 1px solid #e2e8f0;
}

.loyalty-points-label {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--text-muted);
    margin-bottom: 8px;
}

.loyalty-points-value {
    font-size: 2.2rem;
    font-weight: 800;
    color: var(--gold-accent);
}

.loyalty-points-value span {
    font-size: 0.9rem;
    font-weight: 400;
    color: var(--text-muted);
}

.loyalty-tier-info {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 0.85rem;
    color: var(--text-sec);
}

.loyalty-points-needed {
    color: var(--gold-accent);
}

.loyalty-progress-bar {
    height: 6px;
    width: 100%;
    background: #e2e8f0;
    border-radius: 3px;
    margin-top: 12px;
    overflow: hidden;
}

.loyalty-progress-fill {
    height: 100%;
    background: var(--gold-accent);
}

.loyalty-floating-badge {
    position: absolute;
    bottom: -20px;
    left: -20px;
    background: #ffffff;
    color: var(--navy-deep);
    padding: 16px 20px;
    border-radius: 16px;
    box-shadow: 0 10px 30px rgba(5, 23, 48, 0.08);
    border: 1px solid #e2e8f0;
    display: flex;
    align-items: center;
    gap: 12px;
    animation: float 6s infinite ease-in-out;
}

.loyalty-floating-badge i {
    font-size: 1.5rem;
    color: #b88632;
}

.loyalty-badge-title {
    font-weight: 700;
    font-size: 0.9rem;
    color: var(--navy-deep);
}

.loyalty-badge-desc {
    font-size: 0.75rem;
    color: var(--text-sec);
}

/* Location Section */
.location-section {
    padding: 120px 0 !important;
}

.location-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: center;
}

@media (max-width: 991px) {
    .location-grid {
        grid-template-columns: 1fr;
        gap: 50px;
    }
}

.location-item {
    display: flex;
    gap: 20px;
    margin-bottom: 30px;
    align-items: flex-start;
}

.location-icon {
    width: 50px;
    height: 50px;
    border-radius: 12px;
    background: rgba(235, 210, 147, 0.1);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--gold-accent);
    font-size: 1.5rem;
    flex-shrink: 0;
    border: 1px solid rgba(235, 210, 147, 0.2);
}

.location-item strong {
    display: block;
    font-family: var(--font-display);
    font-size: 1.1rem;
    color: var(--gold-accent);
    margin-bottom: 5px;
}

.location-item span, 
.location-item a {
    color: var(--text-sec) !important;
    text-decoration: none;
    font-size: 1rem;
    line-height: 1.6;
}

.location-desc {
    color: var(--text-sec) !important;
    margin-bottom: 40px;
}

.branding-particles {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
    pointer-events: none;
}

.branding-section .container {
    position: relative;
    z-index: 2;
}

.branding-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: var(--space-10);
    margin-top: var(--space-12);
}

.branding-card {
    background: #ffffff !important;
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border: 1px solid rgba(235, 210, 147, 0.4) !important;
    border-radius: 24px;
    overflow: hidden;
    box-shadow: 0 10px 40px rgba(5, 23, 48, 0.05);
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    display: flex;
    flex-direction: column;
    height: 100%;
}

.branding-card:hover {
    transform: translateY(-10px);
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.2);
    border-color: var(--gold-accent) !important;
}

.card-header-browser {
    padding: 16px 24px;
    display: flex;
    gap: 8px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.browser-dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
}
.browser-dot.blue { background: #3b82f6; }
.browser-dot.purple { background: #a855f7; }
.browser-dot.pink { background: #ec4899; }

.card-img-wrap {
    position: relative;
    height: 240px;
    overflow: hidden;
}

.card-img-wrap img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    transition: transform 0.6s ease;
}

.branding-card:hover .card-img-wrap img {
    transform: scale(1.1);
}

.card-content {
    padding: 32px;
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.card-content h3 {
    font-family: var(--font-display);
    font-size: 1.8rem;
    color: var(--navy-deep) !important;
    margin: 0;
}

.card-content p {
    font-size: 1.05rem;
    line-height: 1.7;
    color: var(--text-sec) !important;
    margin: 0;
}

.card-accent-line {
    width: 40px;
    height: 3px;
    background: #EBD293;
    border-radius: 2px;
}

.highlight-gold {
    color: #b88632;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
}

/* Dynamic Fade Card Styles */
.fade-card-container {
    position: relative;
    height: 100%;
    min-height: 480px;
    background: rgba(255, 255, 255, 0.7);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border: 1px solid rgba(148, 163, 184, 0.2);
    border-radius: 24px;
    overflow: hidden;
    box-shadow: 0 10px 40px rgba(15, 23, 42, 0.05);
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    display: flex;
    flex-direction: column;
}

.fade-card-container:hover {
    transform: translateY(-10px);
    box-shadow: 0 20px 50px rgba(15, 23, 42, 0.1);
    border-color: rgba(5, 23, 48, 0.15);
}

.fade-slides-wrap {
    position: relative;
    height: 240px;
    overflow: hidden;
}

.fade-slide {
    position: absolute;
    inset: 0;
    opacity: 0;
    transition: opacity 1.8s cubic-bezier(0.4, 0, 0.2, 1);
    visibility: hidden;
    overflow: hidden;
}

.fade-slide.active {
    opacity: 1;
    visibility: visible;
}

.fade-slide img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    transform: scale(1);
    transition: transform 6s linear;
}

.fade-slide.active img {
    transform: scale(1.15);
}

.fade-content-wrap {
    padding: 32px;
    flex-grow: 1;
    position: relative;
    background: white;
}

.fade-caption {
    position: absolute;
    inset: 32px;
    opacity: 0;
    transform: translateY(15px);
    transition: opacity 1s ease, transform 1s cubic-bezier(0.2, 1, 0.3, 1);
    display: flex;
    flex-direction: column;
    gap: 12px;
    pointer-events: none;
}

.fade-caption.active {
    opacity: 1;
    transform: translateY(0);
    transition-delay: 0.5s;
    pointer-events: all;
}

.fade-caption h3 {
    font-family: var(--font-display);
    font-size: 1.8rem;
    color: #051730;
    margin: 0;
}

.fade-caption p {
    font-size: 1.05rem;
    line-height: 1.7;
    color: #475569;
    margin: 0;
}

.fade-progress-bar {
    position: absolute;
    bottom: 0;
    left: 0;
    height: 3px;
    background: linear-gradient(90deg, #EBD293, #b88632);
    width: 0%;
    transition: width 6s linear;
    z-index: 10;
}

.booking-section {
    background: #051730 !important; /* Deep Navy to remove the gold bar */
    padding: 0;
    margin-top: -30px; /* Slight overlap with hero for seamless look */
    position: relative;
    z-index: 20;
}

/* ============================================================
   PREMIUM HERO (CINEMATIC REFINEMENT)
   ============================================================ */
.hero-premium {
  position: relative;
  width: 100%;
  height: 100vh;
  overflow: hidden;
  background: #000;
  z-index: 1;
}

.hero-premium-slides {
  position: absolute;
  inset: 0;
  z-index: 1;
}

.p-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 0.9s ease-in-out;
  z-index: 1;
}

.p-slide.active {
  opacity: 1;
  z-index: 2;
}

.p-slide-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  transform: scale(1);
  transition: transform 6s ease-out;
  z-index: 1;
}

.p-slide.active .p-slide-bg {
  transform: scale(1.08); /* Slow Ken Burns Zoom */
}

/* Overlays (Balanced Contrast - Now behind text) */
.p-hero-overlay {
  position: absolute;
  inset: 0;
  z-index: 2;
  background: linear-gradient(to top, rgba(5, 15, 35, 0.85) 0%, rgba(5, 15, 35, 0.4) 30%, transparent 60%);
  pointer-events: none;
}

.p-hero-overlay-side {
  position: absolute;
  inset: 0;
  z-index: 2;
  background: linear-gradient(to right, rgba(5, 15, 35, 0.6) 0%, transparent 55%);
  pointer-events: none;
}

/* Floating Particles */
.p-hero-particles {
  position: absolute;
  inset: 0;
  z-index: 4;
  pointer-events: none;
}

.p-particle {
  position: absolute;
  border-radius: 50%;
  background: rgba(245, 200, 66, 0.5);
  animation: p-float 4s ease-in-out infinite;
  box-shadow: 0 0 10px rgba(245, 200, 66, 0.3);
}

@keyframes p-float {
  0%, 100% { transform: translateY(0) scale(1); opacity: 0.3; }
  50% { transform: translateY(-20px) scale(1.2); opacity: 0.8; }
}

/* Content Stacking */
.p-hero-content {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 0 0 160px 8%;
  z-index: 10; /* Solidly in front */
  pointer-events: none;
}

.p-hero-content > * {
  pointer-events: auto;
}

.p-eyebrow {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 20px;
  opacity: 0;
  transform: translateY(20px);
  transition: all 0.7s ease 0.1s;
}

.p-eyebrow-line {
  height: 1px;
  width: 40px;
  background: linear-gradient(to right, #EBD293, transparent);
}

.p-eyebrow-text {
  color: #EBD293;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 3px;
}

.p-title {
  color: #ffffff !important;
  font-family: 'Inter', 'Outfit', sans-serif !important;
  font-size: clamp(2.8rem, 8vw, 6.5rem);
  font-weight: 900;
  line-height: 0.95;
  max-width: 1100px;
  margin-bottom: 25px;
  text-shadow: 0 4px 60px rgba(0,0,0,0.4) !important;
  opacity: 0;
  transform: translateY(30px);
  transition: all 0.7s ease 0.3s;
  letter-spacing: -0.03em;
}

.p-subtitle {
  color: #ffffff !important;
  font-family: 'Inter', 'Outfit', sans-serif !important;
  font-size: clamp(1.1rem, 2vw, 1.8rem);
  font-weight: 400;
  max-width: 800px;
  margin-bottom: 50px;
  line-height: 1.4;
  text-shadow: 0 2px 30px rgba(0,0,0,0.6) !important;
  opacity: 0;
  transform: translateY(20px);
  transition: all 0.7s ease 0.5s;
  letter-spacing: 0.02em;
}

.p-slide.active .p-eyebrow,
.p-slide.active .p-title,
.p-slide.active .p-subtitle,
.p-slide.active .p-actions {
  opacity: 1;
  transform: translateY(0);
}

.p-actions {
  display: flex;
  align-items: center;
  gap: 25px;
  opacity: 0;
  transform: translateY(15px);
  transition: all 0.7s ease 0.7s;
}

.p-btn-primary {
  padding: 18px 45px;
  background: #f5c842 !important; /* Solid Premium Gold */
  color: #051730 !important;
  border-radius: 8px;
  font-weight: 800;
  font-size: 0.95rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  box-shadow: 0 10px 30px rgba(245, 200, 66, 0.4);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.p-btn-primary:hover {
  transform: translateY(-5px) scale(1.03);
  box-shadow: 0 15px 40px rgba(245, 200, 66, 0.5);
  background: #e8a020 !important;
}

.p-btn-outline {
  padding: 18px 45px;
  background: rgba(255, 255, 255, 0.05);
  backdrop-filter: blur(5px);
  color: #ffffff !important;
  border: 1px solid rgba(255, 255, 255, 0.4);
  border-radius: 8px;
  font-weight: 700;
  font-size: 0.95rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  transition: all 0.3s ease;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.p-btn-outline:hover {
  background: rgba(255, 255, 255, 0.15);
  border-color: #ffffff;
  transform: translateY(-3px);
}

/* Indicators */
.p-indicators {
  position: absolute;
  bottom: 100px;
  left: 8%;
  display: flex;
  gap: 12px;
  z-index: 15;
}

.p-indicator {
  width: 8px;
  height: 8px;
  background: rgba(255,255,255,0.2);
  border-radius: 4px;
  cursor: pointer;
  overflow: hidden;
  position: relative;
  transition: width 0.4s ease;
}

.p-indicator.active {
  width: 45px;
}

.p-progress-fill {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 0;
  background: #EBD293;
}

/* Counter */
.p-counter {
  position: absolute;
  right: 6%;
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 15px;
  z-index: 15;
}

.p-counter-curr {
  color: #EBD293;
  font-size: 2.2rem;
  font-weight: 900;
  line-height: 1;
}

.p-counter-line {
  width: 1px;
  height: 60px;
  background: rgba(255,255,255,0.2);
}

.p-counter-total {
  color: rgba(255,255,255,0.4);
  font-size: 0.9rem;
}

/* Bottom Bar / Trust Signals */
.p-hero-footer {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 60px;
  background: rgba(5,10,25,0.6);
  backdrop-filter: blur(15px);
  border-top: 1px solid rgba(255,255,255,0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 60px;
  z-index: 15;
  padding: 0 40px;
}

.footer-item {
  display: flex;
  align-items: center;
  gap: 10px;
}

.footer-item i {
  color: #EBD293;
  font-size: 0.9rem;
}

.footer-item span {
  color: rgba(255,255,255,0.7);
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1px;
}

@media (max-width: 1024px) {
  .p-hero-footer {
    display: none;
  }
  .p-counter {
    display: none;
  }
}

/* Final Cleanup: Remove unwanted gold background bars */
.booking-section {
    background: #051730 !important;
    padding: 20px 0;
    margin-top: -1px;
}

.booking-bar.glass-card {
    background: #ffffff !important;
    border: none !important;
    box-shadow: 0 15px 40px rgba(0,0,0,0.2) !important;
    border-radius: 20px !important;
}

.booking-field {
    border-right: 1px solid rgba(0,0,0,0.05) !important;
}

.booking-field:last-of-type {
    border-right: none !important;
}

.booking-field label i {
    color: #051730 !important; /* Navy icons for white background */
}

.input-with-icon i {
    color: #051730 !important;
}

#check-avail-btn {
    background: #051730 !important;
    color: #ffffff !important;
    border-radius: 12px !important;
}
