/* ================================================================
   HOTEL AMIN INTERNATIONAL — Serene Minimal  ·  theme.css
   One file covers every frontend page.
   Fonts   : Cormorant (headings) · Outfit (body)
   Palette : Ivory #F7F3EE · Navy #1C2F45 · Gold #B8923A
   Usage   : <link rel="stylesheet" href="{{ asset('css/theme.css') }}">
   ================================================================ */

/* ───────────────────────────────────────────────────────────────
   §0  GOOGLE FONTS
───────────────────────────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Cormorant:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400;1,500;1,600&family=Outfit:wght@300;400;500;600;700&display=swap');


/* ───────────────────────────────────────────────────────────────
   §1  DESIGN TOKENS
───────────────────────────────────────────────────────────────── */
:root {
  /* Ivory scale */
  --ivory        : #F7F3EE;
  --ivory-alt    : #FDFAF6;
  --ivory-warm   : #EDE8DF;
  --ivory-dark   : #DDD5C8;
  --ivory-border : #D6CEC3;

  /* Navy scale */
  --navy         : #1C2F45;
  --navy-mid     : #2E5070;
  --navy-light   : #4A6A88;
  --navy-pale    : #D0DCE8;

  /* Gold scale */
  --gold         : #B8923A;
  --gold-mid     : #C8A050;
  --gold-light   : #D8B878;
  --gold-pale    : #F5ECD8;
  --gold-dark    : #8A6A1A;

  /* Semantic aliases (blade templates reference these) */
  --ink          : #1C2F45;
  --ocean        : #2E5070;
  --coral        : #B8923A;
  --amber        : #D8B878;
  --sand         : #F5ECD8;
  --mint         : #4A6A88;
  --muted        : #7A8A9A;
  --white        : #F7F3EE;

  /* Text */
  --text-primary   : #1C2F45;
  --text-secondary : #4A5A6A;
  --text-muted     : #7A8A9A;
  --text-light     : #9AAABB;

  /* Borders */
  --border-main   : #E8E0D5;
  --border-soft   : #F0EAE2;
  --border-gold   : rgba(184,146,58,.22);
  --border-navy   : rgba(28,47,69,.12);

  /* Shadows */
  --shadow-xs  : 0 1px 4px rgba(28,47,69,.06);
  --shadow-sm  : 0 2px 12px rgba(28,47,69,.07);
  --shadow-md  : 0 4px 24px rgba(28,47,69,.10);
  --shadow-lg  : 0 8px 40px rgba(28,47,69,.13);
  --shadow-gold: 0 4px 18px rgba(184,146,58,.22);

  /* Typography */
  --font-heading : 'Cormorant', Georgia, serif;
  --font-body    : 'Outfit', system-ui, sans-serif;
}


/* ───────────────────────────────────────────────────────────────
   §2  RESET & BASE
───────────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }

body {
  font-family: var(--font-body);
  background: var(--ivory);
  color: var(--text-primary);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  line-height: 1.6;
}

h1,h2,h3,h4,h5,h6 {
  font-family: var(--font-heading);
  color: var(--navy);
  line-height: 1.2;
  font-weight: 400;
}
h1 { font-style: italic; font-weight: 300; font-size: clamp(2rem,5vw,3.5rem); }
h2 { font-size: clamp(1.6rem,3vw,2.4rem); }
h3 { font-size: clamp(1.2rem,2vw,1.7rem); }

p  { color: var(--text-secondary); line-height: 1.75; }
a  { color: var(--navy-mid); text-decoration: none; transition: color .2s; }
a:hover { color: var(--gold); }
strong { color: var(--gold); font-weight: 600; }
img { max-width: 100%; display: block; }

::selection { background: rgba(184,146,58,.18); color: var(--navy); }
::-webkit-scrollbar { width: 4px; }
::-webkit-scrollbar-track  { background: var(--ivory); }
::-webkit-scrollbar-thumb  { background: var(--ivory-dark); border-radius: 2px; }
::-webkit-scrollbar-thumb:hover { background: var(--gold); }

[x-cloak] { display: none !important; }


/* ───────────────────────────────────────────────────────────────
   §3  LAYOUT / ANNOUNCEMENT BAR
───────────────────────────────────────────────────────────────── */
.hero-offset { padding-top: var(--nav-offset, 100px); }
@media(max-width:768px){ .hero-offset { padding-top: var(--nav-offset, 120px); } }

/* Announcement bar */
.announce-bar-wrap {
  background: #EDE8DF;
  border-top: 1px solid var(--ivory-border);
  border-bottom: 1px solid var(--ivory-border);
  padding: .85rem 1.5rem;
  font-family: var(--font-body);
}
.announce-bar-inner {
  max-width: 1280px; margin: 0 auto;
  display: flex; align-items: center; justify-content: center;
  gap: 0; flex-wrap: wrap;
}
@media(max-width:640px){
  .announce-bar-inner { flex-direction: column; gap: .5rem; text-align: center; }
  .announce-bar-divline { display: none !important; }
}


/* ───────────────────────────────────────────────────────────────
   §4  NAVBAR
───────────────────────────────────────────────────────────────── */
.nav-wrap {
  position: fixed; top: 0; left: 0; right: 0; z-index: 150;
  padding: .32rem 0;
  background: rgba(247,243,238,.95);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border-main);
  transition: background .4s, box-shadow .3s, padding .3s;
}
.nav-wrap.compact { padding: .28rem 0; box-shadow: var(--shadow-md); }
@media(max-width:768px){
  .nav-wrap { background: rgba(247,243,238,.98); box-shadow: var(--shadow-md); }
}
@media(max-width:390px){ .nav-wrap { padding: .35rem 0; } }

.nav-inner {
  max-width: 1280px; margin: 0 auto; padding: 0 2rem;
  display: flex; align-items: center; justify-content: space-between; min-width: 0;
}
.nav-logo-anchor { text-decoration: none; display: flex; align-items: center; flex-shrink: 0; min-width: 0; }
.nav-logo-img    { height: 56px; width: auto; max-width: 200px; object-fit: contain; display: block; flex-shrink: 0; }

.desk-nav { display: flex; align-items: center; gap: .1rem; }
.nav-link  {
  color: var(--text-secondary); font-size: .82rem; letter-spacing: .06em;
  text-transform: uppercase; text-decoration: none; padding: 5px 9px;
  border-radius: 100px; font-weight: 500; transition: color .22s, background .22s;
}
.nav-link:hover { color: var(--navy); background: var(--ivory-warm); }

.mob-menu {
  display: none; position: fixed; inset: 0; z-index: 300;
  background: var(--ivory); flex-direction: column; align-items: center;
  justify-content: center; gap: 2rem;
}
.mob-menu.open { display: flex; }
.mob-btn { display: none; }

@media(max-width:768px){
  .desk-nav { display: none !important; }
  .mob-btn  { display: flex !important; }
  .nav-inner { padding: 0 1rem !important; }
  .nav-logo-img { height: 44px !important; max-width: 150px !important; }
}
@media(max-width:390px){
  .nav-logo-img { height: 40px !important; max-width: 130px !important; }
  .nav-inner    { padding: 0 .6rem !important; }
  .mob-btn span { width: 20px !important; }
}


/* ───────────────────────────────────────────────────────────────
   §5  BUTTONS
───────────────────────────────────────────────────────────────── */
.btn-fire, .btn-gold {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--navy); color: var(--ivory) !important;
  font-family: var(--font-body); font-size: .82rem; font-weight: 600;
  letter-spacing: .06em; text-transform: uppercase; padding: .9rem 2rem;
  border-radius: 100px; border: none; cursor: pointer; text-decoration: none;
  transition: background .22s, transform .22s, box-shadow .22s;
}
.btn-fire:hover, .btn-gold:hover {
  background: var(--navy-mid); transform: translateY(-2px);
  box-shadow: var(--shadow-md); color: var(--ivory) !important;
}
.btn-ol {
  /* display: inline-flex; align-items: center; gap: 6px;
  border: 1.5px solid var(--ivory-dark); color: var(--navy) !important;
  background: transparent; font-family: var(--font-body); font-size: .82rem;
  font-weight: 600; letter-spacing: .06em; text-transform: uppercase;
  padding: .88rem 1.9rem; border-radius: 100px; text-decoration: none;
  transition: border-color .22s, background .22s, color .22s; */

  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:1.05rem 2.3rem;
  font-size:.88rem;
  font-family:'Outfit',sans-serif;
  font-weight:600;
  letter-spacing:.06em;
  text-transform:uppercase;
  border-radius:100px;
  border:1.5px solid rgba(255,255,255,.55);color:rgba(255,255,255,.9);
  background:transparent;text-decoration:none;transition:border-color .22s,background .22s,color .22s
}
.btn-ol:hover { border-color: var(--navy); background: var(--ivory-warm); }


/* ───────────────────────────────────────────────────────────────
   §6  FORMS
───────────────────────────────────────────────────────────────── */
.inp,
.c-field input, .c-field select, .c-field textarea,
.filter-select {
  width: 100%; border: 1.5px solid var(--border-main) !important;
  border-radius: 8px !important; padding: .75rem 1rem !important;
  font-family: var(--font-body) !important; font-size: .88rem !important;
  color: var(--text-primary) !important; background: #fff !important;
  outline: none; transition: border-color .22s, box-shadow .22s;
  -webkit-appearance: none;
}
.inp:focus,
.c-field input:focus, .c-field select:focus, .c-field textarea:focus,
.filter-select:focus {
  border-color: var(--navy-light) !important;
  box-shadow: 0 0 0 3px rgba(46,80,112,.1) !important;
}
.inp::placeholder, .c-field input::placeholder,
.c-field textarea::placeholder { color: var(--text-light); }

.lbl, .c-field label, .filter-group label {
  display: block; font-size: .68rem !important; font-weight: 600 !important;
  letter-spacing: .1em !important; text-transform: uppercase !important;
  color: var(--text-muted) !important; margin-bottom: .35rem !important;
}


/* ───────────────────────────────────────────────────────────────
   §7  SHARED UTILITIES
───────────────────────────────────────────────────────────────── */
.page-wrap  { max-width: 1100px; margin: 0 auto; padding: 3.5rem 2rem; }
.wide-wrap  { max-width: 1280px; margin: 0 auto; padding: 0 2rem; }

.sec-label {
  font-family: var(--font-body); font-size: .7rem; font-weight: 600;
  letter-spacing: .2em; text-transform: uppercase; color: var(--gold);
  margin-bottom: .6rem; display: block;
}
.divider {
  height: 1px; margin: 3rem 0;
  background: linear-gradient(90deg, transparent, var(--ivory-border), transparent);
}
.section-divider { display: flex; align-items: center; gap: 12px; margin: 0 auto 12px; width: fit-content; }
.section-divider .line  { width: 32px; height: 1px; background: var(--gold); opacity: .5; }
.section-divider .stars { font-size: 10px; color: var(--gold); letter-spacing: 3px; }
.section-label-text {
  font-family: var(--font-body); font-size: .68rem; font-weight: 600;
  letter-spacing: .18em; text-transform: uppercase; color: var(--gold);
  display: block; margin-bottom: .5rem;
}
.gold-accent { display: inline-block; width: 36px; height: 2px; background: var(--gold); margin-bottom: 1rem; border-radius: 1px; }

.badge-gold { background: var(--gold-pale); color: var(--gold-dark); font-family: var(--font-body); font-size: .7rem; font-weight: 600; padding: .25rem .75rem; border-radius: 100px; }
.badge-navy { background: var(--navy-pale); color: var(--navy); font-family: var(--font-body); font-size: .7rem; font-weight: 600; padding: .25rem .75rem; border-radius: 100px; }

.rv  { opacity: 0; transform: translateY(24px); transition: all .55s ease; }
.rv.in, .rv.visible { opacity: 1; transform: none; }
.d1 { transition-delay: .1s; } .d2 { transition-delay: .2s; } .d3 { transition-delay: .3s; }

.pulse {
  display: inline-block; width: 7px; height: 7px; background: var(--gold);
  border-radius: 50%; animation: blink 1.3s ease-in-out infinite;
  vertical-align: middle; margin-right: 4px;
}
@keyframes blink { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.35;transform:scale(.65)} }
@keyframes fadeUp { from{opacity:0;transform:translateY(28px)} to{opacity:1;transform:none} }
@keyframes shimmer { 0%{background-position:200% 0} 100%{background-position:-200% 0} }
@keyframes wave { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-12px)} }
@keyframes spin  { to{transform:rotate(360deg)} }
@keyframes fadeUpSm { from{opacity:0;transform:translateY(14px)} to{opacity:1;transform:none} }

.a1{animation:fadeUp .7s .1s both} .a2{animation:fadeUp .7s .22s both}
.a3{animation:fadeUp .7s .34s both} .a4{animation:fadeUp .7s .46s both} .a5{animation:fadeUp .7s .58s both}


/* ───────────────────────────────────────────────────────────────
   §8  FOOTER
───────────────────────────────────────────────────────────────── */
.ft-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 2.5rem; margin-bottom: 2.5rem; }
@media(max-width:960px){ .ft-grid { grid-template-columns: 1fr 1fr; } }
@media(max-width:480px){ .ft-grid { grid-template-columns: 1fr; } }

.ft-bottom {
  border-top: 1px solid rgba(255,255,255,.1);
  padding-top: 1.5rem; display: flex; align-items: center;
  justify-content: space-between; flex-wrap: wrap; gap: .8rem;
}

/* WhatsApp float */
.wa-float { position: fixed; bottom: 1.6rem; right: 1.6rem; z-index: 500; display: flex; flex-direction: column; align-items: flex-end; gap: .5rem; }
.wa-tooltip { background: rgba(13,26,40,.85); color: #fff; font-size: .75rem; font-weight: 600; padding: .4rem .85rem; border-radius: 8px; white-space: nowrap; opacity: 0; transform: translateX(8px); transition: all .2s; pointer-events: none; }
.wa-float:hover .wa-tooltip { opacity: 1; transform: translateX(0); }
.wa-btn { position: relative; width: 58px; height: 58px; border-radius: 50%; background: #25D366; display: flex; align-items: center; justify-content: center; box-shadow: 0 4px 20px rgba(37,211,102,.45); text-decoration: none; transition: transform .2s, box-shadow .2s; }
.wa-btn:hover { transform: scale(1.08); box-shadow: 0 6px 28px rgba(37,211,102,.6); }
@keyframes wa-pulse{0%{transform:scale(1);opacity:.6}70%{transform:scale(1.55);opacity:0}100%{transform:scale(1.55);opacity:0}}
.wa-btn::before { content:''; position:absolute; inset:0; border-radius:50%; background:#25D366; animation:wa-pulse 2s ease-out infinite; z-index:-1; }

/* Progress bar + back-to-top */
#progress-bar { position:fixed;top:0;left:0;height:3px;width:0%;z-index:99999;background:linear-gradient(90deg,var(--gold-dark),var(--gold),var(--gold-light));transition:width .1s linear;pointer-events:none; }
#back-top { position:fixed;    bottom: 6.5rem;right: 1.90rem;z-index:499;width:44px;height:44px;border-radius:50%;background:rgba(28,47,69,.8);backdrop-filter:blur(8px);border:1.5px solid rgba(255,255,255,.15);color:#fff;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transform:translateY(12px);transition:opacity .3s,transform .3s,background .2s;pointer-events:none; }
#back-top.show { opacity:1;transform:translateY(0);pointer-events:auto; }
#back-top:hover { background:var(--navy-mid);border-color:var(--navy-mid); }

/* Cookie banner */
.cookie-banner { position:fixed;bottom:0;left:0;right:0;z-index:9998;background:rgba(28,47,69,.98);border-top:1px solid rgba(184,146,58,.22);backdrop-filter:blur(10px);padding:1rem 1.5rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-family:var(--font-body); }
.cookie-banner p { font-size:.84rem;color:rgba(255,255,255,.75);margin:0; }
.cookie-banner a { color:var(--gold-light);text-decoration:underline; }
.cookie-accept { background:var(--gold);color:#fff;border:none;border-radius:6px;padding:.6rem 1.2rem;font-size:.8rem;font-weight:700;cursor:pointer;font-family:var(--font-body);transition:opacity .2s; }
.cookie-accept:hover { opacity:.88; }
.cookie-decline { background:transparent;color:rgba(255,255,255,.5);border:1px solid rgba(255,255,255,.15);border-radius:6px;padding:.6rem 1rem;font-size:.8rem;cursor:pointer;font-family:var(--font-body);transition:all .2s; }
.cookie-decline:hover { color:#fff;border-color:rgba(255,255,255,.4); }


/* ───────────────────────────────────────────────────────────────
   §9  HOME PAGE
───────────────────────────────────────────────────────────────── */
.hero {
  min-height: 100vh; display: flex; align-items: center; justify-content: center;
  position: relative; overflow: hidden; background: var(--navy);
  padding-top: var(--nav-offset, 100px); padding-bottom: 0; box-sizing: border-box;
}
.hero-mesh {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 80% 60% at 20% 50%, rgba(46,80,112,.65) 0%, transparent 70%),
    radial-gradient(ellipse 60% 80% at 80% 30%, rgba(184,146,58,.14) 0%, transparent 60%);
}
.hero-grid {
  position: absolute; inset: 0; opacity: .04;
  background-image:
    linear-gradient(rgba(245,236,216,.5) 1px, transparent 1px),
    linear-gradient(90deg, rgba(245,236,216,.5) 1px, transparent 1px);
  background-size: 60px 60px;
}
.hero-content { position:relative;z-index:2;text-align:center;max-width:880px;width:100%;padding:2rem 1.5rem 5rem; }

/* Discount pills */
.hero-pill-wrap { display:inline-flex;border-radius:100px;overflow:hidden;border:1px solid rgba(255,255,255,.14);flex-wrap:wrap;justify-content:center;max-width:100%; }
.hero-pill { padding:.45rem 1.1rem;font-size:.75rem;font-weight:700;letter-spacing:.04em;display:flex;align-items:center;gap:.35rem;color:#fff;white-space:nowrap; }

/* Countdown */
.hero-cd-box { display:inline-flex;background:rgba(255,255,255,.07);border:1px solid rgba(245,236,216,.22);border-radius:10px;overflow:hidden;backdrop-filter:blur(10px); }
.hero-cd-inner { padding:.75rem 1.4rem;text-align:center;font-family:var(--font-heading);font-size:2rem;font-weight:500;color:var(--gold-pale); }

/* Availability chips */
.a-chip { display:flex;align-items:center;gap:.4rem;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:100px;padding:.3rem .85rem;font-size:.75rem;color:rgba(255,255,255,.75); }
.dot-g { width:6px;height:6px;background:#6FCF97;border-radius:50%;animation:blink 1.5s infinite; }
.dot-y { width:6px;height:6px;background:var(--gold);border-radius:50%;animation:blink 1.2s infinite; }
.dot-r { width:6px;height:6px;background:#E07060;border-radius:50%;animation:blink .9s infinite; }

/* Proof strip */
.proof-strip { background:var(--navy-mid);padding:1.1rem 2rem;display:flex;align-items:center;justify-content:center;gap:2.5rem;flex-wrap:wrap;border-bottom:1px solid rgba(184,146,58,.18); }
.proof-divider { width:1px;height:32px;background:rgba(255,255,255,.12); }

/* Booking section */
.bw-section { padding:5rem 1.5rem;background:var(--ivory-alt); }
.bw-inner   { max-width:900px;margin:0 auto; }
.bw-intro   { text-align:center;margin-bottom:2.5rem; }

/* Room cards */
.room-card {
  background:#fff;border-radius:14px;overflow:hidden;
  box-shadow:var(--shadow-sm);border:1px solid var(--border-soft);
  transition:transform .3s,box-shadow .3s,border-color .3s;position:relative;
}
.room-card:hover { transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--border-gold); }
.room-card.hidden { display:none; }
.room-img { height:215px;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center; }
.room-img .ov { position:absolute;inset:0;background:linear-gradient(to top,rgba(28,47,69,.7) 0%,transparent 60%); }

/* Availability bar */
.av-bar  { height:5px;background:var(--ivory-dark);border-radius:100px;overflow:hidden;margin-top:.4rem; }
.av-fill { height:100%;border-radius:100px; }

/* Amenity pills */
.a-pill { display:flex;align-items:center;gap:.55rem;background:#fff;border:1px solid var(--border-soft);border-radius:100px;padding:.55rem 1.1rem;font-size:.8rem;font-weight:500;transition:all .25s;cursor:default; }
.a-pill:hover { background:var(--navy);color:#fff;border-color:var(--navy);transform:scale(1.04); }

/* Review cards on home */
.rev-card { background:#fff;border-radius:12px;padding:1.8rem;box-shadow:var(--shadow-sm);border-top:2px solid var(--gold);border:1px solid var(--border-soft);border-top:3px solid var(--gold) !important;transition:transform .3s; }
.rev-card:hover { transform:translateY(-5px); }

/* Offer cards (home + offers page) */
.offer-card {
  background:#fff;border-radius:16px;overflow:hidden;box-shadow:var(--shadow-sm);
  border:1px solid var(--border-soft);margin-bottom:1.5rem;
  display:grid;grid-template-columns:1fr 260px;transition:box-shadow .22s,border-color .22s;
}
@media(max-width:768px){ .offer-card { grid-template-columns:1fr; } }
.offer-card:hover { box-shadow:var(--shadow-lg);border-color:var(--border-gold); }

/* CTA/booking sections */
.cta-section { background:var(--navy); }
.booking-section, #book { background:var(--ivory-alt); }
/* section:nth-child(even) { background:var(--ivory-alt); } */

/* Timer display */
.timer-display, .countdown-display {
  font-family:var(--font-body);font-size:.9rem;font-weight:700;
  color:var(--gold-dark);background:rgba(184,146,58,.1);
  border:1px solid var(--border-gold);border-radius:6px;padding:3px 12px;letter-spacing:.1em;
}

@media(max-width:768px){
  .hero-content { padding:1.5rem 1rem 4rem; }
  .hero-cd-inner { font-size:1.5rem;padding:.6rem 1rem; }
  .hero-pill { font-size:.65rem;padding:.4rem .8rem; }
  .proof-strip { gap:1rem;padding:1rem; }
  .proof-divider { display:none; }
  .bw-section { padding:3rem 1rem; }
  #rooms,#amenities,#reviews { padding:3rem 1rem !important; }
  .room-img { height:180px; }
}
@media(max-width:390px){
  .hero-content { padding:1rem .75rem 3.5rem; }
  .hero-pill-wrap { border-radius:10px; }
  .hero-pill { font-size:.62rem;padding:.35rem .7rem; }
  .a-chip { font-size:.62rem;padding:.25rem .65rem; }
  .proof-strip { gap:.75rem;padding:.85rem .75rem; }
}


/* ───────────────────────────────────────────────────────────────
   §10  ROOMS PAGE
───────────────────────────────────────────────────────────────── */
.rooms-hero-spacer { background:var(--navy);height:var(--nav-offset,100px); }
.rooms-wrap { max-width:1280px;margin:0 auto;padding:0 2rem; }
@media(max-width:640px){ .rooms-wrap { padding:0 1rem; } }
@media(max-width:390px){ .rooms-wrap { padding:0 .75rem; } }

.filter-wrap { background:#fff;border-radius:14px;box-shadow:var(--shadow-sm);border:1px solid var(--border-soft);padding:1.2rem 1.5rem;margin-bottom:2rem;display:flex;align-items:center;gap:1rem;flex-wrap:wrap; }
.filter-group { display:flex;flex-direction:column;gap:.3rem;min-width:130px;flex:1; }
.filter-btn-clear { padding:.52rem 1.1rem;border:1.5px solid var(--border-main);border-radius:8px;background:#fff;font-size:.8rem;font-weight:600;color:var(--text-muted);cursor:pointer;font-family:var(--font-body);white-space:nowrap;transition:all .2s;align-self:flex-end; }
.filter-btn-clear:hover { border-color:var(--gold);color:var(--gold); }
.results-count { font-size:.8rem;color:var(--text-muted);align-self:flex-end;white-space:nowrap; }

@media(max-width:768px){
  .filter-wrap { padding:1rem;gap:.75rem; }
  .filter-group { min-width:calc(50% - .375rem);flex:none; }
  .filter-btn-clear,.results-count { width:100%;text-align:center;align-self:center; }
  #roomGrid { grid-template-columns:1fr !important; }
}
@media(max-width:390px){ .filter-group { min-width:100%; } }


/* ───────────────────────────────────────────────────────────────
   §11  ROOM DETAIL PAGE
───────────────────────────────────────────────────────────────── */
.room-hero { height:100vh;min-height:600px;display:flex;flex-direction:column;justify-content:flex-end;position:relative;background:var(--navy);overflow:hidden; }
.hero-bg   { position:absolute;inset:0;background:linear-gradient(135deg,#0D1A28,var(--navy)); }
.hero-overlay { position:absolute;inset:0;background:linear-gradient(to top,rgba(13,26,40,.88) 0%,rgba(13,26,40,.38) 50%,rgba(13,26,40,.08) 100%); }
.hero-content { position:relative;z-index:2;width:100%;max-width:1280px;margin:0 auto;padding:2rem 2rem 4rem;box-sizing:border-box;word-break:break-word;overflow-wrap:break-word; }

.room-hero-mob-spacer { display:none;background:var(--navy);height:var(--nav-offset,100px); }
@media(max-width:1024px){
  .room-hero-mob-spacer { display:block; }
  .room-hero { height:auto;min-height:60vw;justify-content:flex-end; }
  .hero-content { padding:1.5rem 1.25rem 2.5rem; }
}
@media(max-width:390px){
  .room-hero { min-height:65vw; }
  .hero-content { padding:1rem 1rem 2rem; }
  .hero-content h1 { font-size:clamp(1.4rem,8vw,2.5rem) !important; }
}

.page-layout { max-width:1280px;margin:0 auto;padding:3rem 2rem;display:grid;grid-template-columns:1fr 380px;gap:2.5rem;align-items:start;overflow:hidden; }
.left-col, .right-col { min-width:0;max-width:100%;overflow-x:hidden; }
.right-col-sticky { position:sticky;top:var(--nav-offset,90px);align-self:start; }
@media(max-width:1024px){
  .page-layout { grid-template-columns:1fr;padding:1.5rem 1rem; }
  .page-layout > .left-col  { order:2; }
  .page-layout > .right-col { order:1; }
  .right-col-sticky { position:static !important;top:auto !important; }
}

/* Gallery grid */
.gallery { display:grid;grid-template-columns:2fr 1fr;grid-template-rows:200px 200px;gap:10px;border-radius:16px;overflow:hidden;margin-bottom:2.5rem;width:100%;max-width:100%;box-sizing:border-box; }
.gallery > * { min-width:0;max-width:100%;overflow:hidden; }
.gallery img { display:block;width:100%;height:100%;object-fit:cover;max-width:100%; }
.g-main { grid-row:1/3;background:linear-gradient(135deg,#0D1A28,var(--navy));position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:6rem; }
.g-sub  { background:linear-gradient(135deg,#1a2a3a,#2a4a5a);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:3rem; }
.g-label { position:absolute;bottom:.6rem;left:.8rem;background:rgba(0,0,0,.6);color:#fff;font-size:.65rem;padding:.2rem .6rem;border-radius:6px;letter-spacing:.04em; }

.detail-grid  { display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin:1.5rem 0; }
@media(max-width:640px){ .detail-grid { grid-template-columns:repeat(2,1fr); } }
.detail-box   { background:var(--ivory-warm);border-radius:10px;padding:1rem;text-align:center;border:1px solid var(--border-soft); }
.detail-icon  { font-size:1.4rem;margin-bottom:.4rem; }
.detail-label { font-size:.6rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.2rem; }
.detail-val   { font-size:1.1rem;font-weight:600;color:var(--navy);font-family:var(--font-heading); }

.feat-pill { display:inline-flex;align-items:center;gap:.5rem;background:#fff;border:1px solid var(--border-main);border-radius:100px;padding:.5rem 1rem;font-size:.8rem;font-weight:500;cursor:default;transition:all .25s;margin:.3rem; }
.feat-pill:hover { background:var(--navy);color:#fff;border-color:var(--navy);transform:translateY(-2px); }

.policy-box   { background:var(--ivory-warm);border-radius:10px;padding:1rem 1.2rem;margin-bottom:.8rem;border-left:3px solid var(--gold); }
.policy-title { font-size:.82rem;font-weight:600;margin-bottom:.3rem;color:var(--navy); }
.policy-text  { font-size:.8rem;color:var(--text-muted);line-height:1.7; }

.room-card-sm { background:#fff;border-radius:12px;overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--border-soft);transition:transform .3s;text-decoration:none;color:var(--text-primary);display:block; }
.room-card-sm:hover { transform:translateY(-5px);box-shadow:var(--shadow-md); }

.sec-head { font-size:.65rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:.75rem; }

/* Sticky price bar */
.price-bar { position:fixed;top:0;left:0;right:0;z-index:160;background:rgba(28,47,69,.97);backdrop-filter:blur(24px);border-bottom:1px solid rgba(184,146,58,.2);padding:.7rem 2rem;transform:translateY(-100%);transition:transform .35s;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap; }
.price-bar.show { transform:translateY(0); }

/* Share toast */
.share-toast { position:fixed;bottom:5rem;left:50%;transform:translateX(-50%) translateY(10px);background:rgba(28,47,69,.9);color:#fff;font-size:.8rem;font-weight:600;padding:.55rem 1.3rem;border-radius:8px;opacity:0;transition:all .3s;pointer-events:none;z-index:9999;white-space:nowrap; }
.share-toast.show { opacity:1;transform:translateX(-50%) translateY(0); }

/* Mobile floating book bar */
.mob-book-bar { display:none;position:fixed;bottom:0;left:0;right:0;z-index:490;background:rgba(28,47,69,.97);backdrop-filter:blur(16px);border-top:1px solid rgba(184,146,58,.2);padding:.75rem 1rem;align-items:center;justify-content:space-between;gap:.6rem; }
@media(max-width:1024px){ .mob-book-bar { display:flex; } }
.mob-price-label  { font-size:.65rem;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:.06em;display:block;margin-bottom:.1rem; }
.mob-price-amount { font-family:var(--font-heading);font-size:1.2rem;font-weight:500;color:var(--gold-light);line-height:1; }

/* Lightbox (shared) */
.lb-backdrop { position:fixed;inset:0;background:rgba(0,0,0,.94);z-index:99999;display:flex;flex-direction:column;align-items:center;justify-content:space-between; }
.lb-topbar   { width:100%;display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem;background:rgba(0,0,0,.4);flex-shrink:0; }
.lb-counter  { color:rgba(255,255,255,.55);font-size:.82rem;font-weight:600;letter-spacing:.06em;min-width:56px; }
.lb-caption  { color:#fff;font-size:.88rem;font-weight:500;flex:1;text-align:center;padding:0 1rem; }
.lb-close    { width:36px;height:36px;background:rgba(255,255,255,.1);border:1.5px solid rgba(255,255,255,.2);border-radius:50%;color:#fff;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;flex-shrink:0; }
.lb-close:hover { background:rgba(255,255,255,.25); }
.lb-main     { flex:1;display:flex;align-items:center;justify-content:center;width:100%;position:relative;padding:.5rem 70px;overflow:hidden; }
.lb-main img { max-width:92vw;max-height:80vh;border-radius:10px;object-fit:contain; }
.lb-btn      { position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;background:rgba(255,255,255,.1);backdrop-filter:blur(8px);border:1.5px solid rgba(255,255,255,.18);border-radius:50%;color:#fff;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;z-index:2; }
.lb-btn:hover { background:rgba(255,255,255,.25); }
.lb-prev { left:12px; } .lb-next { right:12px; }
.lb-thumbs   { display:flex;gap:6px;overflow-x:auto;padding:.6rem 1rem;max-width:100%;scrollbar-width:none;background:rgba(0,0,0,.4);flex-shrink:0;justify-content:center; }
.lb-thumbs::-webkit-scrollbar { display:none; }
.lb-thumb    { width:64px;height:46px;border-radius:6px;object-fit:cover;cursor:pointer;border:2.5px solid transparent;opacity:.5;transition:all .2s;flex-shrink:0; }
.lb-thumb.active,.lb-thumb:hover { border-color:#fff;opacity:1; }

@media(max-width:640px){
  .room-hero { height:60vw;min-height:260px; }
  .hero-content { padding:0 1rem 4.5rem; }
  .hero-content h1 { font-size:clamp(1.6rem,8vw,3rem); }
  .gallery { grid-template-columns:1fr !important;grid-template-rows:220px 130px 130px !important;border-radius:10px;width:100% !important; }
  .g-main  { grid-row:1/2 !important; }
  .g-sub   { grid-column:1 !important; }
  .page-layout { padding:1rem .75rem !important; }
  .lb-prev { left:4px !important; } .lb-next { right:4px !important; }
  .lb-main { padding:.5rem 52px !important; }
}

/* Sidebar booking widget overrides */
#book .booking-widget  { padding:1.4rem 1.2rem;border-radius:14px; }
#book .bw-step-num     { width:26px;height:26px;font-size:.75rem; }
#book .bw-step-label   { font-size:.68rem; }
#book .bw-step-title   { font-size:1rem;margin-bottom:.9rem; }
#book .bw-grid-2       { gap:.6rem; }
#book .bw-date-btn     { padding:.55rem .8rem;font-size:.84rem;min-height:42px; }
#book .bw-counter      { padding:.4rem .7rem;gap:.5rem; }
#book .bw-counter-btn  { width:26px;height:26px;font-size:1rem; }
#book .bw-btn-primary  { font-size:.9rem;padding:.8rem; }
#book .bw-mode-tab     { font-size:.72rem;padding:.55rem .5rem; }


/* ───────────────────────────────────────────────────────────────
   §12  GENERIC PAGE HEROES
───────────────────────────────────────────────────────────────── */
.about-hero,.contact-hero,.fac-hero,.gal-hero,.blog-hero,.rv-hero,.av-hero,.post-hero {
  background:linear-gradient(150deg,#0D1A28 0%,var(--navy) 55%,#243D58 100%);
  padding:8rem 2rem 5rem;position:relative;overflow:hidden;
}
.about-hero::before,.contact-hero::before,.fac-hero::before,.gal-hero::before,
.blog-hero::before,.rv-hero::before,.av-hero::before,.post-hero::before {
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 60% 50%,rgba(184,146,58,.08),transparent 65%);
}
.about-hero-inner,.contact-hero-inner,.fac-hero-inner,.gal-hero-inner,
.blog-hero-inner,.rv-hero-inner,.av-hero-inner,.post-hero-inner {
  position:relative;z-index:1;
}
.gal-hero   { padding:8rem 2rem 4rem; }
.about-hero-inner,.contact-hero-inner { max-width:1100px;margin:0 auto; }
.post-hero-inner { max-width:780px;margin:0 auto; }

@media(max-width:768px){
  .about-hero,.contact-hero,.fac-hero,.gal-hero,
  .blog-hero,.rv-hero,.av-hero,.post-hero { padding:6rem 1.5rem 3.5rem; }
}

/* Offers hero (warm dark gold, not red) */
.offers-hero { text-align: center; background:linear-gradient(150deg,#2A1A04 0%,#6A4A10 55%,#3A2408 100%);padding:8rem 2rem 5rem;position:relative;overflow:hidden; }
.offers-hero::before { content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 50%,rgba(184,146,58,.1),transparent 65%); }
.offers-hero-inner { position:relative;z-index:1; }

/* Restaurant hero */
.rest-hero {text-align: center;background:linear-gradient(150deg,#2C1A06 0%,#5A3810 60%,#3A2408 100%);padding:8rem 2rem 5rem;position:relative;overflow:hidden; }
.rest-hero::before { content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 60%,rgba(200,160,10,.14),transparent 65%); }
.rest-hero-inner { position:relative;z-index:1; }


/* ───────────────────────────────────────────────────────────────
   §13  ABOUT PAGE
───────────────────────────────────────────────────────────────── */
.stats-grid { display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin:3rem 0; }
@media(max-width:640px){ .stats-grid { grid-template-columns:repeat(2,1fr); } }
.stat-box   { text-align:center;padding:1.5rem 1rem;background:#fff;border-radius:14px;box-shadow:var(--shadow-sm);border:1px solid var(--border-soft); }
.stat-num   { font-family:var(--font-heading);font-size:2.4rem;font-weight:400;color:var(--gold);line-height:1; }
.stat-label { font-size:.78rem;color:var(--text-muted);margin-top:.4rem; }

.story-grid { display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:center; }
@media(max-width:768px){ .story-grid { grid-template-columns:1fr; } }
.story-img  { border-radius:16px;overflow:hidden;height:380px;background:var(--navy);position:relative; }
.story-img img { width:100%;height:100%;object-fit:cover; }

.values-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem; }
@media(max-width:640px){ .values-grid { grid-template-columns:1fr; } }
.value-card  { background:#fff;border-radius:14px;padding:1.5rem;box-shadow:var(--shadow-sm);border:1px solid var(--border-soft);border-top:3px solid var(--gold) !important; }

.amenity-pill { display:inline-flex;align-items:center;gap:.4rem;background:#fff;border:1px solid var(--border-main);border-radius:100px;padding:.5rem 1rem;font-size:.8rem;font-weight:500;margin:.25rem; }

.team-grid   { display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1.5rem; }
.team-card   { background:#fff;border-radius:16px;padding:1.5rem 1rem;text-align:center;box-shadow:var(--shadow-sm);border:1px solid var(--border-soft);transition:transform .25s,box-shadow .25s; }
.team-card:hover { transform:translateY(-5px);box-shadow:var(--shadow-md); }
.team-photo  { width:90px;height:90px;border-radius:50%;object-fit:cover;margin:0 auto .9rem;display:block;border:3px solid var(--gold-pale); }
.team-name   { font-size:.92rem;font-weight:600;color:var(--navy);margin-bottom:.25rem;line-height:1.3; }
.team-role   { font-size:.75rem;color:var(--text-muted);line-height:1.5; }
.team-fb     { display:inline-flex;align-items:center;gap:.3rem;margin-top:.6rem;font-size:.72rem;color:#1877f2;text-decoration:none;font-weight:600; }
.team-fb:hover { text-decoration:underline; }

.review-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.2rem; }
.review-card { background:#fff;border-radius:16px;padding:1.6rem;box-shadow:var(--shadow-sm);border:1px solid var(--border-soft);display:flex;flex-direction:column;gap:.6rem;transition:box-shadow .22s,border-color .22s; }
.review-card:hover { box-shadow:var(--shadow-md);border-color:var(--border-gold); }
.review-text   { font-family:var(--font-heading);font-style:italic;font-size:1rem;color:var(--text-secondary);line-height:1.85;flex:1; }
.review-author { font-size:.84rem;font-weight:600;color:var(--navy); }
.review-meta   { font-size:.75rem;color:var(--text-muted); }
.stars { color:#C8A020;font-size:.95rem;letter-spacing:.05em; }

.rooms-row { display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem; }


/* ───────────────────────────────────────────────────────────────
   §14  CONTACT PAGE
───────────────────────────────────────────────────────────────── */
.c-wrap  { max-width:1100px;margin:0 auto;padding:3.5rem 2rem; }
.c-grid  { display:grid;grid-template-columns:1fr 400px;gap:3rem;align-items:start; }
@media(max-width:960px){ .c-grid { grid-template-columns:1fr; } }
.c-card  { background:#fff;border-radius:18px;padding:2.5rem;box-shadow:var(--shadow-md);border:1px solid var(--border-soft); }
.c-field { margin-bottom:1.2rem; }
.c-row   { display:grid;grid-template-columns:1fr 1fr;gap:1rem; }
@media(max-width:560px){ .c-row { grid-template-columns:1fr; } }

.c-btn {
  width:100%;padding:1rem;display:flex;align-items:center;justify-content:center;gap:.5rem;
  background:var(--navy);color:#fff;border:none;border-radius:10px;
  font-size:.95rem;font-weight:600;cursor:pointer;font-family:var(--font-body);
  transition:background .2s,transform .2s,box-shadow .2s;margin-top:.5rem;
}
.c-btn:hover { background:var(--navy-mid);transform:translateY(-2px);box-shadow:var(--shadow-md); }
.c-btn:disabled { opacity:.6;cursor:not-allowed;transform:none; }
.c-success { display:none;text-align:center;padding:2rem;background:#f4fbf0;border:1.5px solid #b8e8a0;border-radius:12px;margin-top:1rem; }

.info-stack { display:flex;flex-direction:column;gap:1.1rem; }
.i-card  { background:#fff;border-radius:14px;padding:1.4rem 1.6rem;box-shadow:var(--shadow-sm);border:1px solid var(--border-soft); }
.i-head  { font-size:.68rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);margin-bottom:1rem; }
.i-item  { display:flex;gap:.85rem;align-items:flex-start;margin-bottom:.9rem; }
.i-item:last-child { margin-bottom:0; }
.i-icon  { width:36px;height:36px;border-radius:9px;background:var(--ivory-warm);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1rem;border:1px solid var(--border-soft); }
.i-lbl   { font-size:.72rem;color:var(--text-muted);margin-bottom:.1rem; }
.i-val   { font-size:.87rem;font-weight:600;color:var(--navy);line-height:1.5; }
.i-val a { color:var(--navy-mid);text-decoration:none; }
.i-val a:hover { text-decoration:underline; }

.quick-btns { display:flex;gap:.7rem;flex-wrap:wrap; }
.qbtn { flex:1;min-width:100px;padding:.7rem .5rem;border-radius:10px;font-size:.78rem;font-weight:700;text-align:center;text-decoration:none;display:flex;align-items:center;justify-content:center;gap:.35rem;transition:transform .15s;border:1.5px solid; }
.qbtn:hover { transform:translateY(-2px); }
.qbtn-call  { background:var(--navy-pale);color:var(--navy);border-color:var(--navy-pale); }
.qbtn-wa    { background:#f0fdf4;color:#15803d;border-color:#bbf7d0; }
.qbtn-email { background:var(--ivory-warm);color:var(--navy);border-color:var(--ivory-border); }

.hours-row  { display:flex;justify-content:space-between;font-size:.84rem;padding:.32rem 0;border-bottom:1px solid var(--border-soft); }
.hours-row:last-child { border-bottom:none; }
.open-time  { color:#4A8A5A;font-weight:700; }

.map-wrap { border-radius:14px;overflow:hidden;box-shadow:var(--shadow-sm); }
.map-ph   { height:220px;background:linear-gradient(135deg,var(--navy),var(--navy-mid));display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;cursor:pointer;transition:filter .2s; }
.map-ph:hover { filter:brightness(1.1); }
.map-pin-btn { width:48px;height:48px;border-radius:50%;background:var(--gold);display:flex;align-items:center;justify-content:center;font-size:1.3rem;box-shadow:var(--shadow-gold); }

.faq-sec  { margin-top:3.5rem; }
.faq-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;margin-top:1.8rem; }
.faq-item { background:#fff;border-radius:12px;padding:1.1rem 1.3rem;box-shadow:var(--shadow-xs);border:1px solid var(--border-soft);cursor:pointer; }
.faq-q    { font-size:.88rem;font-weight:600;display:flex;justify-content:space-between;align-items:center;gap:.5rem;color:var(--navy); }
.faq-a    { font-size:.84rem;color:var(--text-secondary);line-height:1.75;margin-top:.7rem;display:none; }
.faq-item.open .faq-a { display:block; }
.faq-arrow { transition:transform .2s;color:var(--gold);font-size:.8rem; }
.faq-item.open .faq-arrow { transform:rotate(180deg); }


/* ───────────────────────────────────────────────────────────────
   §15  FACILITIES PAGE
───────────────────────────────────────────────────────────────── */
.amenity-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.2rem; }
.amenity-card { background:#fff;border-radius:16px;padding:1.8rem 1.2rem;text-align:center;box-shadow:var(--shadow-sm);border:1px solid var(--border-soft);transition:transform .22s,box-shadow .22s,border-color .22s; }
.amenity-card:hover { transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--border-gold); }
.amenity-icon { font-size:2.2rem;margin-bottom:.8rem; }
.amenity-name { font-size:.92rem;font-weight:600;color:var(--navy); }

.feature-section { display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;margin:2rem 0; }
@media(max-width:768px){ .feature-section { grid-template-columns:1fr; } }
.feature-section.reverse > * { direction:ltr; }
.feature-img { border-radius:14px;overflow:hidden;height:300px;background:var(--navy);position:relative;display:flex;align-items:center;justify-content:center;font-size:5rem; }
.feature-img img { width:100%;height:100%;object-fit:cover;position:absolute;inset:0; }

.policy-grid  { display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem; }
.policy-card  { background:#fff;border-radius:12px;padding:1.2rem 1.4rem;box-shadow:var(--shadow-xs);border:1px solid var(--border-soft); }
.policy-title { font-size:.84rem;font-weight:600;margin-bottom:.35rem;color:var(--navy); }
.policy-text  { font-size:.8rem;color:var(--text-muted);line-height:1.7; }

/* Facility item (home page services grid) */
.facility-item { background:#fff;border:1px solid var(--border-soft);border-radius:12px;box-shadow:var(--shadow-xs);transition:transform .22s,box-shadow .22s,border-color .22s; }
.facility-item:hover { transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--border-gold); }


/* ───────────────────────────────────────────────────────────────
   §16  GALLERY PAGE
───────────────────────────────────────────────────────────────── */
.filter-bar  { display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center;margin-bottom:2.5rem;align-items:center; }
.filter-sep  { width:1px;height:24px;background:var(--border-main);margin:0 .3rem;align-self:center; }
.filter-btn  { padding:.45rem 1.1rem;border-radius:100px;font-size:.8rem;font-weight:600;text-decoration:none;border:1.5px solid var(--border-main);background:#fff;color:var(--text-muted);transition:all .18s;white-space:nowrap;cursor:pointer;font-family:var(--font-body); }
.filter-btn:hover,.filter-btn.active { background:var(--navy);color:#fff;border-color:var(--navy); }

.gal-section-head { font-size:.68rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:1.2rem;display:flex;align-items:center;gap:.7rem; }
.gal-section-head::after { content:'';flex:1;height:1px;background:var(--border-main); }

.photo-grid    { columns:3;column-gap:10px;margin-bottom:3rem; }
@media(max-width:768px){ .photo-grid { columns:2; } }
@media(max-width:480px){ .photo-grid { columns:1; } }
.photo-item    { break-inside:avoid;margin-bottom:10px;border-radius:10px;overflow:hidden;position:relative;cursor:pointer;display:block; }
.photo-item img { width:100%;display:block;transition:transform .4s; }
.photo-item:hover img { transform:scale(1.04); }
.photo-overlay { position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(28,47,69,.7),transparent);padding:.6rem .8rem;opacity:0;transition:opacity .2s; }
.photo-item:hover .photo-overlay { opacity:1; }
.photo-overlay-text { color:#fff;font-size:.75rem;font-weight:600; }
.photo-cat-tag { position:absolute;top:.6rem;left:.6rem;background:rgba(28,47,69,.65);color:#fff;font-size:.65rem;font-weight:600;padding:.2rem .55rem;border-radius:5px;letter-spacing:.04em; }

.empty-gal { text-align:center;padding:3rem 1rem;color:var(--text-muted);background:#fff;border-radius:14px;margin-bottom:2rem;border:1px solid var(--border-soft); }


/* ───────────────────────────────────────────────────────────────
   §17  RESTAURANT PAGE
───────────────────────────────────────────────────────────────── */
/* Restaurant page restores ivory body */
body.page-restaurant { background: var(--ivory); }

.info-strip   { display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:3rem; }
.info-box     { background:#fff;border-radius:14px;padding:1.3rem;text-align:center;box-shadow:var(--shadow-sm);border:1px solid var(--border-soft);border-bottom:3px solid var(--gold) !important; }
.info-icon    { font-size:1.8rem;margin-bottom:.5rem; }
.info-label   { font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:.3rem;font-weight:600; }
.info-val     { font-size:.95rem;font-weight:600;color:var(--navy); }

.featured-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.2rem;margin-bottom:3rem; }
.feat-card    { background:#fff;border-radius:14px;overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--border-soft);display:flex;flex-direction:column;transition:transform .25s,box-shadow .25s; }
.feat-card:hover { transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--border-gold); }
.feat-img     { height:190px;background:var(--ivory-warm);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:3.5rem; }
.feat-img img { width:100%;height:100%;object-fit:cover;position:absolute;inset:0; }
.feat-body    { padding:1.2rem;flex:1;display:flex;flex-direction:column;gap:.35rem; }
.feat-name    { font-family:var(--font-heading);font-size:1.1rem;color:var(--navy);font-weight:400; }
.feat-desc    { font-size:.82rem;color:var(--text-muted);line-height:1.65;flex:1; }
.feat-price   { font-family:var(--font-heading);font-size:1.2rem;font-weight:500;color:var(--gold);margin-top:.4rem; }
.feat-badge   { position:absolute;top:.7rem;left:.7rem;background:var(--gold);color:#fff;font-size:.62rem;font-weight:700;padding:.22rem .6rem;border-radius:6px;letter-spacing:.05em; }
.feat-star    { color:var(--gold); }

.cat-tabs   { display:flex;gap:.5rem;overflow-x:auto;padding-bottom:.5rem;margin-bottom:2rem;scrollbar-width:none; }
.cat-tabs::-webkit-scrollbar { display:none; }
.cat-tab    { flex-shrink:0;padding:.55rem 1.2rem;border-radius:100px;font-size:.82rem;font-weight:600;cursor:pointer;border:1.5px solid var(--ivory-border);background:#fff;color:var(--text-muted);transition:all .18s;display:flex;align-items:center;gap:.4rem;font-family:var(--font-body); }
.cat-tab:hover { border-color:var(--gold);color:var(--gold); }
.cat-tab.active { background:var(--navy);color:#fff;border-color:var(--navy); }

.menu-cat-head { display:flex;align-items:center;gap:1rem;margin-bottom:1.2rem;padding-bottom:.8rem;border-bottom:2px solid var(--ivory-border); }
.menu-cat-icon { font-size:2rem; }
.menu-cat-name { font-family:var(--font-heading);font-size:1.4rem;font-weight:400;color:var(--navy); }
.menu-cat-desc { font-size:.8rem;color:var(--text-muted); }

.menu-grid  { display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:.8rem;margin-bottom:2.5rem; }
.menu-item  { background:#fff;border-radius:12px;padding:1rem 1.2rem;display:flex;gap:.9rem;align-items:flex-start;border:1px solid var(--border-soft);transition:border-color .2s,box-shadow .2s; }
.menu-item:hover { border-color:var(--gold);box-shadow:var(--shadow-xs); }
.menu-item.unavailable { opacity:.45; }
.menu-item-img  { width:72px;height:60px;border-radius:8px;object-fit:cover;flex-shrink:0;background:var(--ivory-warm);display:flex;align-items:center;justify-content:center;font-size:1.6rem;overflow:hidden; }
.menu-item-img img { width:100%;height:100%;object-fit:cover; }
.menu-item-body { flex:1;min-width:0; }
.menu-item-name { font-size:.9rem;font-weight:600;color:var(--navy);margin-bottom:.2rem;display:flex;align-items:center;gap:.4rem; }
.menu-item-desc { font-size:.78rem;color:var(--text-muted);line-height:1.6;margin-bottom:.3rem; }
.menu-item-price { font-family:var(--font-heading);font-size:1rem;font-weight:500;color:var(--gold); }
.menu-item-unavail { font-size:.7rem;color:#C05050;font-weight:600; }

.rest-cta { background:linear-gradient(135deg,var(--navy),var(--navy-mid));border-radius:16px;padding:2.5rem;text-align:center;margin-top:2rem; }


/* ───────────────────────────────────────────────────────────────
   §18  OFFERS PAGE
───────────────────────────────────────────────────────────────── */
.offer-body    { padding:2rem; }
.offer-badge   { display:inline-flex;align-items:center;gap:.4rem;background:var(--gold-pale);color:var(--gold-dark);font-size:.7rem;font-weight:700;padding:.28rem .7rem;border-radius:100px;margin-bottom:1rem;letter-spacing:.04em;border:1px solid var(--border-gold); }
.offer-discount { font-family:var(--font-heading);font-size:3rem;font-weight:500;color:var(--gold);line-height:1; }
.offer-rooms   { display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.8rem; }
.offer-room-tag { background:var(--ivory-warm);color:var(--navy-mid);border:1px solid var(--border-main);border-radius:6px;padding:.2rem .6rem;font-size:.74rem;font-weight:600; }
.offer-img     { background:var(--navy);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:4rem;min-height:200px; }
.offer-img img { width:100%;height:100%;object-fit:cover;position:absolute;inset:0; }

.countdown { display:inline-flex;align-items:center;gap:.4rem;background:rgba(184,146,58,.08);border:1px solid var(--border-gold);border-radius:8px;padding:.4rem .9rem;font-size:.85rem;color:var(--gold-dark);font-weight:700;margin-top:.8rem; }

.always-on { background:var(--ivory-alt);border:1px solid var(--ivory-border);border-radius:14px;padding:1.8rem;text-align:center;margin-bottom:2rem; }

.rules-grid  { display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem; }
.rule-card   { background:#fff;border-radius:14px;padding:1.4rem;box-shadow:var(--shadow-xs);border:1px solid var(--border-soft);border-left:3px solid var(--gold) !important; }
.rule-name   { font-size:.92rem;font-weight:600;margin-bottom:.4rem;color:var(--navy); }
.rule-disc   { font-family:var(--font-heading);font-size:1.8rem;font-weight:400;color:var(--gold);line-height:1;margin-bottom:.4rem; }
.rule-meta   { font-size:.78rem;color:var(--text-muted);line-height:1.6; }


/* ───────────────────────────────────────────────────────────────
   §19  BLOG PAGE + BLOG POST
───────────────────────────────────────────────────────────────── */
.cat-bar { display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:2.5rem;justify-content:center; }
.cat-btn { padding:.45rem 1.1rem;border-radius:100px;font-size:.8rem;font-weight:600;text-decoration:none;border:1.5px solid var(--border-main);background:#fff;color:var(--text-muted);transition:all .18s; }
.cat-btn:hover,.cat-btn.active { background:var(--navy);color:#fff;border-color:var(--navy); }

.featured-card { background:#fff;border-radius:18px;overflow:hidden;box-shadow:var(--shadow-md);border:1px solid var(--border-soft);display:grid;grid-template-columns:1.2fr 1fr;margin-bottom:3rem; }
@media(max-width:768px){ .featured-card { grid-template-columns:1fr; } }
.featured-img  { height:100%;min-height:280px;background:var(--navy);position:relative;overflow:hidden; }
.featured-img img { width:100%;height:100%;object-fit:cover;position:absolute;inset:0;transition:transform .4s; }
.featured-card:hover .featured-img img { transform:scale(1.04); }
.featured-body  { padding:2.2rem; }
.featured-label { font-size:.65rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);margin-bottom:.6rem; }

.blog-grid      { display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem; }
.blog-card      { background:#fff;border-radius:16px;overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--border-soft);transition:transform .25s,box-shadow .25s;text-decoration:none;color:var(--text-primary);display:flex;flex-direction:column; }
.blog-card:hover { transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:var(--border-gold); }
.blog-card-img  { height:190px;background:var(--navy);position:relative;overflow:hidden; }
.blog-card-img img { width:100%;height:100%;object-fit:cover;position:absolute;inset:0;transition:transform .4s; }
.blog-card:hover .blog-card-img img { transform:scale(1.05); }
.blog-card-body { padding:1.3rem;flex:1;display:flex;flex-direction:column;gap:.5rem; }
.blog-cat-tag   { display:inline-flex;align-items:center;background:var(--ivory-warm);color:var(--navy-mid);border:1px solid var(--border-main);border-radius:6px;padding:.2rem .6rem;font-size:.72rem;font-weight:600;width:fit-content; }
.blog-title     { font-family:var(--font-heading);font-size:1.1rem;color:var(--navy);font-weight:400;line-height:1.35; }
.blog-excerpt   { font-size:.84rem;color:var(--text-muted);line-height:1.7;flex:1; }
.blog-meta      { display:flex;align-items:center;gap:.6rem;font-size:.75rem;color:var(--text-light);padding-top:.6rem;border-top:1px solid var(--border-soft);margin-top:auto; }
.blog-read-more { color:var(--gold);font-weight:700;font-size:.8rem;display:inline-flex;align-items:center;gap:.3rem;margin-top:.5rem; }
.empty-blog     { text-align:center;padding:4rem 1rem;color:var(--text-muted); }

/* Blog post */
.post-wrap     { max-width:780px;margin:0 auto;padding:3rem 2rem; }
.cover-img     { width:100%;height:420px;object-fit:cover;border-radius:16px;margin-bottom:2.5rem;box-shadow:var(--shadow-md); }
@media(max-width:640px){ .cover-img { height:240px;border-radius:10px; } }
.post-content  { font-size:.95rem;line-height:1.95;color:var(--text-secondary); }
.post-content h1,.post-content h2,.post-content h3 { font-family:var(--font-heading);color:var(--navy);margin:2rem 0 .8rem;line-height:1.3; }
.post-content h2 { font-size:1.5rem; }
.post-content h3 { font-size:1.2rem; }
.post-content p  { margin-bottom:1.2rem; }
.post-content ul,.post-content ol { padding-left:1.5rem;margin-bottom:1.2rem; }
.post-content li { margin-bottom:.4rem; }
.post-content a  { color:var(--navy-mid);text-decoration:underline; }
.post-content a:hover { color:var(--gold); }
.post-content strong { font-weight:700;color:var(--navy); }
.post-content blockquote { border-left:3px solid var(--gold);padding:.8rem 1.2rem;background:var(--gold-pale);border-radius:0 8px 8px 0;margin:1.5rem 0;font-style:italic;color:var(--text-secondary);font-family:var(--font-heading); }
.post-content hr  { border:none;border-top:1px solid var(--border-main);margin:2rem 0; }
.post-content img { width:100%;border-radius:10px;margin:1rem 0; }
.post-content code { background:var(--ivory-warm);padding:.15rem .4rem;border-radius:4px;font-size:.85em;font-family:monospace; }

.related-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem;margin-top:1.5rem; }
.related-card { background:#fff;border-radius:12px;overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--border-soft);text-decoration:none;color:var(--text-primary);display:block;transition:transform .2s; }
.related-card:hover { transform:translateY(-4px); }
.related-img  { height:140px;background:var(--navy);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:2rem; }
.related-img img { width:100%;height:100%;object-fit:cover;position:absolute;inset:0; }


/* ───────────────────────────────────────────────────────────────
   §20  REVIEWS PAGE
───────────────────────────────────────────────────────────────── */
.rating-summary { background:#fff;border-radius:18px;padding:2rem;box-shadow:var(--shadow-sm);border:1px solid var(--border-soft);display:grid;grid-template-columns:auto 1fr;gap:2rem;align-items:center;margin-bottom:2.5rem; }
@media(max-width:600px){ .rating-summary { grid-template-columns:1fr; } }
.big-score  { text-align:center; }
.big-num    { font-family:var(--font-heading);font-size:4rem;font-weight:400;color:var(--navy);line-height:1; }
.big-stars  { color:#C8A020;font-size:1.3rem;letter-spacing:.1em;margin:.3rem 0; }
.big-count  { font-size:.8rem;color:var(--text-muted); }
.bar-row    { display:flex;align-items:center;gap:.7rem;margin-bottom:.4rem; }
.bar-label  { font-size:.8rem;font-weight:600;color:var(--navy);min-width:12px;text-align:right; }
.bar-stars  { color:#C8A020;font-size:.72rem;min-width:64px; }
.bar-track  { flex:1;height:7px;background:var(--ivory-dark);border-radius:100px;overflow:hidden; }
.bar-fill   { height:100%;background:linear-gradient(90deg,var(--gold-dark),var(--gold));border-radius:100px;transition:width .6s ease; }
.bar-count  { font-size:.75rem;color:var(--text-muted);min-width:24px; }

.filter-label { font-size:.74rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-right:.2rem; }
.reviews-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.2rem; }
.rv-card { background:#fff;border-radius:16px;padding:1.6rem;box-shadow:var(--shadow-sm);border:1px solid var(--border-soft);border-top:2px solid #C8A020 !important;display:flex;flex-direction:column;gap:.75rem;transition:transform .2s,box-shadow .2s; }
.rv-card:hover { transform:translateY(-3px);box-shadow:var(--shadow-md); }
.rv-stars      { color:#C8A020;font-size:.95rem;letter-spacing:.05em; }
.rv-text       { font-family:var(--font-heading);font-style:italic;font-size:.98rem;color:var(--text-secondary);line-height:1.85;flex:1; }
.rv-author-row { display:flex;align-items:center;gap:.75rem;padding-top:.6rem;border-top:1px solid var(--border-soft); }
.rv-avatar     { width:38px;height:38px;border-radius:50%;background:var(--navy);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.85rem;flex-shrink:0; }
.rv-name       { font-size:.84rem;font-weight:600;color:var(--navy); }
.rv-meta       { font-size:.74rem;color:var(--text-muted); }
.rv-room-tag   { display:inline-flex;align-items:center;gap:.3rem;background:var(--ivory-warm);color:var(--navy-mid);border:1px solid var(--border-main);border-radius:6px;padding:.18rem .55rem;font-size:.7rem;font-weight:600; }
.rv-date       { font-size:.7rem;color:var(--text-light); }
.no-results    { text-align:center;padding:3.5rem 1rem;color:var(--text-muted); }
.write-review-box { background:var(--ivory-warm);border:1px solid var(--ivory-border);border-radius:16px;padding:2rem;text-align:center;margin-top:2.5rem; }


/* ───────────────────────────────────────────────────────────────
   §21  EVENT HALL PAGE
───────────────────────────────────────────────────────────────── */
.eh-hero         { position:relative;min-height:92vh;display:flex;align-items:center;justify-content:center;overflow:hidden;padding-top:100px; }
.eh-hero-bg      { position:absolute;inset:0;background:linear-gradient(150deg,#0D1A28 0%,var(--navy) 55%,#243D58 100%); }
.eh-hero-pattern { position:absolute;inset:0;opacity:.05;background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='1'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E"); }
.eh-hero-overlay { position:absolute;inset:0;background:linear-gradient(180deg,rgba(13,26,40,.2) 0%,rgba(13,26,40,.55) 100%); }
.eh-hero-content { position:relative;z-index:2;text-align:center;padding:2rem;max-width:860px; }
.eh-hero-badge   { display:inline-flex;align-items:center;gap:.5rem;background:rgba(184,146,58,.14);border:1px solid rgba(184,146,58,.4);border-radius:100px;padding:.4rem 1.1rem;font-size:.74rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#D8B878;margin-bottom:1.5rem; }
.eh-hero-title   { font-family:var(--font-heading);font-size:clamp(2.5rem,7vw,5rem);font-weight:300;font-style:italic;color:#fff;line-height:1.1;margin-bottom:1rem; }
.eh-hero-sub     { font-size:1.05rem;color:rgba(255,255,255,.65);margin-bottom:2.5rem;line-height:1.6; }
.eh-cta-row      { display:flex;gap:1rem;justify-content:center;flex-wrap:wrap; }
.eh-btn-primary  { display:inline-flex;align-items:center;gap:.5rem;background:var(--gold);color:#fff;padding:.9rem 2.2rem;border-radius:100px;font-weight:600;text-decoration:none;font-size:.88rem;transition:opacity .22s,transform .22s;box-shadow:var(--shadow-gold); }
.eh-btn-primary:hover { opacity:.88;transform:translateY(-2px); }
.eh-btn-secondary { display:inline-flex;align-items:center;gap:.5rem;background:rgba(255,255,255,.1);color:#fff;border:1.5px solid rgba(255,255,255,.28);padding:.9rem 2.2rem;border-radius:100px;font-weight:500;text-decoration:none;font-size:.88rem;transition:all .22s; }
.eh-btn-secondary:hover { background:rgba(255,255,255,.18); }

.eh-stats        { background:var(--navy-mid);padding:1.5rem 2rem;border-bottom:1px solid rgba(184,146,58,.18); }
.eh-stats-inner  { max-width:1100px;margin:0 auto;display:flex;justify-content:space-around;align-items:center;flex-wrap:wrap;gap:1.5rem; }
.eh-stat         { text-align:center;color:#fff; }
.eh-stat-num     { font-family:var(--font-heading);font-size:2.2rem;font-weight:400;color:var(--gold-light);line-height:1; }
.eh-stat-lbl     { font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-top:.3rem; }

.eh-sec-label    { font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);font-weight:700;margin-bottom:.6rem;display:block; }
.eh-sec-title    { font-family:var(--font-heading);font-size:clamp(1.8rem,4vw,2.8rem);font-weight:400;margin-bottom:1rem;color:var(--navy); }
.eh-sec-sub      { color:var(--text-secondary);font-size:.95rem;line-height:1.7;max-width:600px;margin-bottom:2.5rem; }

.eh-section-wrap { padding:4rem 0; }
.eh-section-wrap.alt { background:var(--ivory-alt); }
.eh-section      { max-width:1100px;margin:0 auto;padding:0 2rem; }

.eh-events-grid  { display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1.2rem; }
.eh-event-card   { background:#fff;border:1px solid var(--border-soft);border-radius:14px;padding:1.5rem;text-align:center;box-shadow:var(--shadow-xs);transition:all .22s; }
.eh-event-card:hover { border-color:var(--gold);background:var(--ivory-alt);transform:translateY(-3px);box-shadow:var(--shadow-md); }
.eh-event-icon   { font-size:2.2rem;margin-bottom:.7rem; }
.eh-event-name   { font-weight:600;font-size:.92rem;color:var(--navy);margin-bottom:.3rem; }
.eh-event-desc   { font-size:.78rem;color:var(--text-muted);line-height:1.55; }

.eh-packages     { display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.5rem; }
.eh-pkg          { border-radius:18px;overflow:hidden;border:2px solid var(--border-main);transition:all .22s;background:#fff; }
.eh-pkg:hover    { border-color:var(--navy);transform:translateY(-4px);box-shadow:var(--shadow-lg); }
.eh-pkg.featured { border-color:var(--navy);box-shadow:var(--shadow-md); }
.eh-pkg-header   { padding:1.5rem;background:var(--ivory-warm); }
.eh-pkg.featured .eh-pkg-header { background:var(--navy); }
.eh-pkg-icon     { font-size:2rem;margin-bottom:.5rem; }
.eh-pkg-name     { font-weight:700;font-size:1.05rem;color:var(--navy);margin-bottom:.2rem; }
.eh-pkg.featured .eh-pkg-name,.eh-pkg.featured .eh-pkg-time { color:#fff; }
.eh-pkg-time     { font-size:.77rem;color:var(--text-muted); }
.eh-pkg.featured .eh-pkg-time { color:rgba(255,255,255,.65); }
.eh-pkg-body     { padding:1.5rem; }
.eh-pkg-price    { font-family:var(--font-heading);font-size:2rem;font-weight:400;color:var(--gold);margin-bottom:1rem; }
.eh-pkg-features { list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem; }
.eh-pkg-features li { font-size:.82rem;color:var(--text-secondary);display:flex;align-items:center;gap:.45rem; }
.eh-pkg-features li::before { content:'✓';color:#4A8A5A;font-weight:700;flex-shrink:0; }
.eh-pkg-cta      { display:block;width:100%;margin-top:1.3rem;padding:.75rem;background:var(--navy);color:#fff;border-radius:100px;text-align:center;font-weight:600;text-decoration:none;font-size:.84rem;letter-spacing:.04em;font-family:var(--font-body);transition:background .22s,transform .22s; }
.eh-pkg-cta:hover { background:var(--navy-mid);transform:translateY(-2px); }

.eh-features-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem; }
.eh-feat          { display:flex;align-items:center;gap:.7rem;padding:.9rem 1rem;background:var(--ivory-warm);border-radius:10px;border:1px solid var(--ivory-border); }
.eh-feat-icon     { font-size:1.4rem;flex-shrink:0; }
.eh-feat-label    { font-size:.82rem;font-weight:600;color:var(--navy); }

.eh-seating       { display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1.2rem; }
.eh-seat          { background:#fff;border:1px solid var(--border-soft);border-radius:12px;padding:1.2rem;text-align:center; }
.eh-seat-icon     { font-size:2rem;margin-bottom:.5rem; }
.eh-seat-name     { font-weight:600;font-size:.87rem;color:var(--navy); }
.eh-seat-cap      { font-family:var(--font-heading);font-size:1.6rem;font-weight:400;color:var(--gold);margin:.2rem 0; }
.eh-seat-desc     { font-size:.74rem;color:var(--text-muted); }

.eh-gallery       { display:grid;grid-template-columns:2fr 1fr 1fr;grid-template-rows:200px 200px;gap:.75rem; }
@media(max-width:768px){ .eh-gallery { grid-template-columns:1fr 1fr;grid-template-rows:auto; } }
.eh-gallery-item  { border-radius:12px;overflow:hidden;background:var(--navy); }
.eh-gallery-item:first-child { grid-row:span 2; }
.eh-gallery-img   { width:100%;height:100%;object-fit:cover; }
.eh-gallery-placeholder { display:flex;align-items:center;justify-content:center;height:100%;min-height:160px;color:rgba(255,255,255,.25);font-size:.8rem;text-align:center;padding:1rem; }

.eh-faq           { display:flex;flex-direction:column;gap:.75rem; }
.eh-faq-item      { border:1px solid var(--border-soft);border-radius:12px;overflow:hidden;background:#fff; }
.eh-faq-q         { width:100%;background:none;border:none;padding:1.1rem 1.3rem;text-align:left;font-weight:600;font-size:.9rem;color:var(--navy);cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-family:var(--font-body); }
.eh-faq-q:hover   { background:var(--ivory-alt); }
.eh-faq-a         { padding:0 1.3rem 1.1rem;font-size:.86rem;color:var(--text-secondary);line-height:1.7;display:none; }
.eh-faq-item.open .eh-faq-a { display:block; }
.eh-faq-arrow     { transition:transform .2s;color:var(--gold);flex-shrink:0; }
.eh-faq-item.open .eh-faq-arrow { transform:rotate(180deg); }

.eh-cta-section   { background:var(--navy);padding:5rem 2rem;text-align:center; }
.eh-cta-inner     { max-width:700px;margin:0 auto; }
.eh-contact-methods { display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:2rem; }
.eh-contact-card  { background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:14px;padding:1.5rem 2rem;text-align:center;text-decoration:none;transition:all .22s;min-width:150px; }
.eh-contact-card:hover { background:rgba(255,255,255,.15);transform:translateY(-2px); }
.eh-contact-icon  { font-size:1.8rem;margin-bottom:.6rem; }
.eh-contact-label { font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-bottom:.3rem; }
.eh-contact-value { font-weight:600;color:#fff;font-size:.92rem; }
.eh-notice        { background:var(--gold-pale,#F5ECD8);border:1.5px solid rgba(184,146,58,.3);border-radius:12px;padding:1.1rem 1.4rem;font-size:.85rem;color:var(--gold-dark,#8A6A1A);margin-top:1.5rem;line-height:1.7;font-family:var(--font-body); }


/* ───────────────────────────────────────────────────────────────
   §22  AVAILABILITY CALENDAR PAGE
───────────────────────────────────────────────────────────────── */
.av-wrap       { max-width:1100px;margin:0 auto;padding:2.5rem 2rem; }
.av-nav        { display:flex;align-items:center;justify-content:space-between;background:#fff;border-radius:14px;padding:1rem 1.4rem;box-shadow:var(--shadow-sm);border:1px solid var(--border-soft);margin-bottom:2rem; }
.av-nav-btn    { display:flex;align-items:center;gap:.4rem;padding:.55rem 1.1rem;border:1.5px solid var(--border-main);border-radius:9px;background:#fff;font-size:.84rem;font-weight:600;color:var(--navy-mid);cursor:pointer;text-decoration:none;transition:all .2s;font-family:var(--font-body); }
.av-nav-btn:hover { background:var(--navy);color:#fff;border-color:var(--navy); }
.av-month-title { font-family:var(--font-heading);font-size:1.3rem;font-weight:400;color:var(--navy); }
.av-legend      { display:flex;align-items:center;gap:1.2rem;flex-wrap:wrap;margin-bottom:1.5rem; }
.leg-item       { display:flex;align-items:center;gap:.4rem;font-size:.78rem;color:var(--text-muted); }
.leg-dot        { width:12px;height:12px;border-radius:3px; }
.av-table-wrap  { overflow-x:auto;border-radius:14px;box-shadow:var(--shadow-sm);border:1px solid var(--border-soft); }
.av-table       { width:100%;border-collapse:collapse;background:#fff;min-width:600px; }
.av-table th    { background:var(--ivory-warm);padding:.6rem .4rem;font-size:.68rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);border-bottom:2px solid var(--border-main);text-align:center; }
.av-table th.room-col { text-align:left;padding-left:1rem;min-width:140px; }
.av-table td    { padding:.5rem .3rem;border-bottom:1px solid var(--border-soft);text-align:center;vertical-align:middle; }
.av-table td.room-info { padding:.6rem 1rem;text-align:left; }
.av-table tr:last-child td { border-bottom:none; }
.av-table tr:hover td { background:var(--ivory-alt); }
.day-th         { width:36px;min-width:36px; }
.day-th.today-col { background:rgba(184,146,58,.12);color:var(--gold-dark); }
.day-th.weekend-col { background:var(--ivory-warm); }
.av-cell        { width:32px;height:30px;border-radius:5px;display:inline-flex;align-items:center;justify-content:center;font-size:.76rem;font-weight:700;cursor:default; }
.av-full        { background:#fde8e8;color:#A03030; }
.av-low         { background:var(--gold-pale);color:var(--gold-dark); }
.av-good        { background:#e0f4e8;color:#2A6A3A; }
.av-past        { background:var(--ivory-warm);color:var(--text-light); }
.room-thumb     { width:44px;height:36px;border-radius:6px;object-fit:cover;flex-shrink:0; }
.room-name      { font-size:.86rem;font-weight:600;color:var(--navy);line-height:1.2; }
.room-meta      { font-size:.72rem;color:var(--text-muted); }
.av-cta         { background:var(--ivory-warm);border:1px solid var(--ivory-border);border-radius:14px;padding:1.8rem;text-align:center;margin-top:2rem; }
.av-cta h3      { font-family:var(--font-heading);font-size:1.2rem;font-weight:400;margin-bottom:.4rem; }
.av-cta-btn     { display:inline-flex;align-items:center;gap:.5rem;background:var(--navy);color:#fff;padding:.75rem 2rem;border-radius:10px;font-weight:600;font-size:.9rem;text-decoration:none;margin-top:.8rem;transition:transform .2s,background .2s; }
.av-cta-btn:hover { transform:translateY(-2px);background:var(--navy-mid); }


/* ───────────────────────────────────────────────────────────────
   §23  BOOKING WIDGET (partials/booking-widget-assets)
───────────────────────────────────────────────────────────────── */
.booking-widget { background:#fff;border-radius:20px;padding:2.5rem;box-shadow:var(--shadow-lg);overflow:visible;position:relative;border:1px solid var(--border-soft); }

/* Steps */
.bw-steps     { display:flex;align-items:center;margin-bottom:2.5rem; }
.bw-step      { display:flex;align-items:center;gap:.45rem;flex-shrink:0; }
.bw-step-num  { width:30px;height:30px;border-radius:50%;background:var(--ivory-warm);color:var(--text-muted);font-weight:700;display:flex;align-items:center;justify-content:center;font-size:.82rem;transition:all .3s; }
.bw-step.active .bw-step-num { background:var(--navy);color:#fff;box-shadow:0 0 0 4px rgba(28,47,69,.15); }
.bw-step.done   .bw-step-num { background:#4A8A5A;color:#fff;box-shadow:0 0 0 4px rgba(74,138,90,.15); }
.bw-step-label  { font-size:.76rem;font-weight:600;color:var(--text-light);white-space:nowrap; }
.bw-step.active .bw-step-label,.bw-step.done .bw-step-label { color:var(--text-primary); }
.bw-step-line   { flex:1;height:2px;background:var(--ivory-dark);margin:0 .65rem;transition:background .4s; }

/* Titles */
.bw-step-title { font-size:1.15rem;font-weight:400;color:var(--navy);margin:0 0 1.2rem;font-family:var(--font-heading);font-style:italic; }
.bw-step-sub   { color:var(--text-muted);font-size:.86rem;margin:-.7rem 0 1.2rem; }

/* Fields */
.bw-grid-2  { display:grid;grid-template-columns:1fr 1fr;gap:1rem;position:relative; }
.bw-field   { display:flex;flex-direction:column;gap:.4rem;position:relative; }
.bw-field label { font-size:.72rem;font-weight:600;color:var(--text-secondary);letter-spacing:.06em;text-transform:uppercase; }
.bw-field label small { font-weight:400;color:var(--text-light);text-transform:none;letter-spacing:0; }
.bw-input   { border:1.5px solid var(--border-main);border-radius:10px;padding:.68rem 1rem;font-size:.93rem;outline:none;transition:border-color .2s,box-shadow .2s;width:100%;box-sizing:border-box;font-family:var(--font-body);background:#fff;color:var(--text-primary); }
.bw-input:focus { border-color:var(--navy-light);box-shadow:0 0 0 3px rgba(46,80,112,.1); }
textarea.bw-input { resize:vertical; }

/* Date picker */
.bw-date-btn { display:flex;align-items:center;gap:8px;width:100%;padding:.68rem 1rem;background:#fff;border:1.5px solid var(--border-main);border-radius:10px;font-size:.93rem;font-family:var(--font-body);color:var(--text-primary);cursor:pointer;text-align:left;transition:border-color .2s,box-shadow .2s;min-height:48px; }
.bw-date-btn:hover { border-color:var(--navy-light); }
.bw-date-btn.bw-date-active { border-color:var(--navy-light);box-shadow:0 0 0 3px rgba(46,80,112,.1); }
.bw-date-btn span { flex:1; }
.bw-cal-pop { position:absolute;top:calc(100% + 8px);left:0;z-index:9999;background:#fff;border-radius:14px;box-shadow:var(--shadow-lg);padding:14px;min-width:290px;border:1.5px solid var(--border-main); }
.bw-cal-pop.align-right { left:auto;right:0; }
.bw-cal-head { display:flex;align-items:center;justify-content:space-between;margin-bottom:10px; }
.bw-cal-nav  { width:30px;height:30px;border:1.5px solid var(--border-main);border-radius:8px;background:var(--ivory-warm);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;color:var(--text-primary);transition:all .15s;line-height:1; }
.bw-cal-nav:hover { background:var(--navy);color:#fff;border-color:var(--navy); }
.bw-cal-title { font-weight:700;font-size:14px;color:var(--navy);letter-spacing:-.2px; }
.bw-cal-dow   { display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:4px; }
.bw-cal-dow span { text-align:center;font-size:10px;font-weight:700;color:var(--text-light);padding:4px 0;text-transform:uppercase;letter-spacing:.04em; }
.bw-cal-grid  { display:grid;grid-template-columns:repeat(7,1fr);gap:2px; }
.bw-cal-cell  { width:100%;aspect-ratio:1;border:none;background:transparent;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;color:var(--text-primary);transition:all .12s;display:flex;align-items:center;justify-content:center;font-family:var(--font-body); }
.bw-cal-cell:hover:not(:disabled) { background:var(--navy);color:#fff; }
.bw-cal-other { color:var(--text-light) !important; }
.bw-cal-dis   { color:var(--text-light) !important;cursor:not-allowed !important;background:transparent !important; }
.bw-cal-today { font-weight:800;color:var(--gold-dark);background:var(--gold-pale); }
.bw-cal-sel   { background:var(--navy) !important;color:#fff !important;font-weight:700; }
.bw-cal-in-range { background:rgba(28,47,69,.08);color:var(--navy); }

/* Counter */
.bw-counter       { display:flex;align-items:center;gap:.75rem;border:1.5px solid var(--border-main);border-radius:10px;padding:.5rem .95rem;background:#fff;width:fit-content; }
.bw-counter-btn   { width:30px;height:30px;border-radius:50%;border:none;background:var(--ivory-warm);cursor:pointer;font-size:1.1rem;font-weight:700;color:var(--text-primary);display:flex;align-items:center;justify-content:center;transition:background .2s; }
.bw-counter-btn:hover { background:var(--navy-pale);color:var(--navy); }
.bw-counter-val   { font-size:1.08rem;font-weight:700;min-width:1.8rem;text-align:center; }

/* Nights badge */
.bw-nights-badge { margin-top:.8rem;background:var(--ivory-warm);border:1px solid var(--ivory-border);border-radius:8px;padding:.48rem 1rem;font-size:.88rem;color:var(--navy-mid);font-weight:600;display:inline-flex;align-items:center;gap:.4rem; }

/* Discount hint */
.bw-discount-hint { background:var(--ivory-alt);border:1px solid var(--ivory-border);border-radius:10px;padding:.9rem 1.1rem;margin-top:1.2rem; }
.bw-discount-hint-title { font-size:.7rem;font-weight:700;color:#4A8A5A;letter-spacing:.08em;text-transform:uppercase;margin-bottom:.5rem; }
.bw-discount-hint-row   { display:flex;justify-content:space-between;font-size:.8rem;color:var(--text-primary);margin-bottom:.2rem; }

/* Summary bar */
.bw-summary-bar { display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;background:var(--ivory-warm);border:1px solid var(--ivory-border);border-radius:10px;padding:.75rem 1.1rem;font-size:.85rem;font-weight:600;color:var(--text-primary);margin-bottom:1.4rem; }
.bw-pill        { background:var(--navy);color:#fff;border-radius:20px;padding:.2rem .72rem;font-size:.74rem; }
.bw-edit-link   { margin-left:auto;color:var(--navy-mid);background:none;border:none;cursor:pointer;font-size:.82rem;text-decoration:underline;font-family:var(--font-body); }

/* Mode tabs */
.bw-mode-tabs   { display:flex;border:2px solid var(--navy);border-radius:12px;overflow:hidden;margin-bottom:1.5rem; }
.bw-mode-tab    { flex:1;padding:.7rem 1rem;text-align:center;font-size:.8rem;font-weight:700;cursor:pointer;transition:all .2s;border:none;font-family:var(--font-body);background:#fff;color:var(--navy); }
.bw-mode-tab.active { background:var(--navy);color:#fff; }
.bw-mode-tab-sep { width:2px;background:var(--navy); }

/* Preference selector */
.bw-pref-wrap { background:var(--ivory-warm);border-radius:12px;padding:.3rem;display:flex;gap:.25rem;margin-bottom:1rem; }
.bw-pref-btn  { flex:1;padding:.5rem .6rem;border-radius:9px;font-size:.72rem;font-weight:600;cursor:pointer;transition:all .18s;border:none;font-family:var(--font-body);text-align:center;background:transparent;color:var(--text-muted);line-height:1.3; }
.bw-pref-btn.active { background:#fff;color:var(--navy);box-shadow:var(--shadow-xs);font-weight:700; }
.bw-pref-btn .pref-icon { font-size:1rem;display:block;margin-bottom:.15rem; }
.bw-pref-hint { font-size:.74rem;color:var(--text-muted);margin-bottom:1rem;min-height:1.1em; }

/* Option cards */
.bw-options-list { display:flex;flex-direction:column;gap:.85rem; }
.bw-option-card  { border:1.5px solid var(--border-main);border-radius:14px;padding:0;cursor:pointer;position:relative;transition:all .2s;background:#fff; }
.bw-option-card:hover { border-color:var(--navy-pale);box-shadow:var(--shadow-sm);transform:translateY(-1px); }
.bw-option-card.selected { border-color:var(--navy);box-shadow:0 0 0 3px rgba(28,47,69,.1); }
.bw-option-card.recommended { border-color:var(--gold); }
.bw-option-card.best-value  { border-color:#4A8A5A; }
.bw-option-card.selected::after { content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--navy);border-radius:14px 14px 0 0; }

.bw-option-pill { display:inline-flex;align-items:center;font-size:.58rem;font-weight:700;padding:.18rem .5rem;border-radius:100px;letter-spacing:.04em;text-transform:uppercase;margin-left:.4rem;vertical-align:middle; }
.bw-option-pill.amber { background:var(--gold-pale);color:var(--gold-dark);border:1px solid var(--border-gold); }
.bw-option-pill.green { background:#e0f4e8;color:#2A6A3A;border:1px solid #b8e8c0; }
.bw-option-pill.blue  { background:var(--navy-pale);color:var(--navy);border:1px solid var(--navy-pale); }

.bw-option-inner    { padding:1rem 1.1rem; }
.bw-option-top      { display:flex;align-items:flex-start;gap:.75rem; }
.bw-option-left     { flex:1;min-width:0; }
.bw-option-name-row { display:flex;align-items:center;flex-wrap:wrap;gap:.1rem;line-height:1.4; }
.bw-option-name     { font-size:.95rem;font-weight:600;color:var(--navy);font-family:var(--font-heading); }
.bw-option-meta     { font-size:.71rem;color:var(--text-muted);margin-top:.3rem;display:flex;flex-wrap:wrap;gap:.28rem;align-items:center; }
.bw-cap-badge       { background:var(--ivory-warm);border:1px solid var(--border-main);border-radius:5px;padding:.1rem .38rem;font-size:.65rem;font-weight:600;color:var(--text-secondary);white-space:nowrap; }
.bw-option-price-block { text-align:right;flex-shrink:0;min-width:90px; }
.bw-option-rack     { font-size:.68rem;color:var(--text-light);text-decoration:line-through;margin-bottom:.06rem; }
.bw-option-total    { font-family:var(--font-heading);font-size:1.3rem;font-weight:500;color:var(--navy);line-height:1.1; }
.bw-option-nights   { font-size:.63rem;color:var(--text-light);margin-top:.06rem; }
.bw-option-save     { display:inline-block;background:#e0f4e8;color:#2A6A3A;font-size:.62rem;font-weight:700;padding:.13rem .4rem;border-radius:4px;margin-top:.2rem; }
.bw-radio { width:20px;height:20px;border-radius:50%;border:2px solid var(--ivory-dark);flex-shrink:0;margin-top:.15rem;transition:all .18s;background:#fff; }
.bw-radio.checked { border-color:var(--navy);background:var(--navy);box-shadow:inset 0 0 0 4px #fff; }
.bw-features    { display:flex;flex-wrap:wrap;gap:.28rem;margin-top:.65rem;padding-top:.65rem;border-top:1px solid var(--border-soft); }
.bw-feat-chip   { background:var(--ivory-warm);border:1px solid var(--border-soft);border-radius:100px;padding:.13rem .5rem;font-size:.67rem;color:var(--text-secondary); }

/* Manual mode */
.bw-manual-list { display:flex;flex-direction:column;gap:.9rem;margin-top:.4rem; }
.bw-manual-card { border:1.5px solid var(--border-main);border-radius:12px;padding:1.1rem;transition:border-color .2s,background .2s; }
.bw-manual-card.has-selection { border-color:var(--navy);background:var(--ivory-alt); }
.bw-manual-row  { display:flex;align-items:center;gap:1rem; }
.bw-manual-info { flex:1;min-width:0; }
.bw-manual-name { font-size:.95rem;font-weight:600;color:var(--navy);font-family:var(--font-heading); }
.bw-manual-sub  { font-size:.77rem;color:var(--text-muted);margin-top:.15rem; }
.bw-manual-price { font-size:1rem;font-weight:700;color:var(--navy);white-space:nowrap;text-align:right; }
.bw-manual-price small { display:block;font-size:.68rem;font-weight:400;color:var(--text-light); }
.bw-avail-badge { display:inline-flex;align-items:center;gap:.3rem;font-size:.7rem;padding:.18rem .6rem;border-radius:100px;font-weight:600;margin-top:.3rem; }
.bw-avail-good  { background:#e0f4e8;color:#2A6A3A;border:1px solid #b8e8c0; }
.bw-avail-low   { background:var(--gold-pale);color:var(--gold-dark);border:1px solid var(--border-gold); }
.bw-avail-none  { background:#fde8e8;color:#A03030;border:1px solid #f4b8b8; }

/* Capacity bar */
.bw-capacity-bar-wrap { background:var(--ivory-warm);border:1px solid var(--ivory-border);border-radius:10px;padding:.9rem 1.1rem;margin-top:1.2rem; }
.bw-capacity-bar-wrap.ok   { background:#e8f8ec;border-color:#b8e8c0; }
.bw-capacity-bar-wrap.over { background:#fde8e8;border-color:#f4b8b8; }
.bw-capacity-row  { display:flex;justify-content:space-between;align-items:center;font-size:.84rem;margin-bottom:.5rem; }
.bw-capacity-bar  { height:8px;background:var(--ivory-dark);border-radius:100px;overflow:hidden; }
.bw-capacity-fill { height:100%;border-radius:100px;transition:width .3s,background .3s; }

/* Manual total */
.bw-manual-total         { background:var(--navy);border-radius:10px;padding:1rem 1.3rem;display:flex;align-items:center;justify-content:space-between;margin-top:1.2rem; }
.bw-manual-total-label   { color:rgba(255,255,255,.65);font-size:.8rem; }
.bw-manual-total-amount  { font-family:var(--font-heading);font-size:1.5rem;font-weight:400;color:#fff; }
.bw-manual-total-savings { font-size:.72rem;color:rgba(255,255,255,.55);margin-top:.1rem;text-align:right; }

/* Breakdown table */
.bw-breakdown-toggle { background:none;border:none;cursor:pointer;font-size:.79rem;color:var(--navy-mid);text-decoration:underline;font-family:var(--font-body);padding:0;display:flex;align-items:center;gap:.35rem;margin-left:.75rem;margin-bottom:.75rem; }
.bw-breakdown-table  { margin-top:.8rem;overflow-x:auto;border-radius:8px;border:1px solid var(--border-main); }
.bw-breakdown-table table { width:100%;border-collapse:collapse;font-size:.79rem; }
.bw-breakdown-table th { background:var(--ivory-warm);padding:.48rem .65rem;text-align:left;font-weight:600;color:var(--text-muted);border-bottom:1px solid var(--border-main);white-space:nowrap; }
.bw-breakdown-table td { padding:.48rem .65rem;border-bottom:1px solid var(--border-soft); }
.bw-breakdown-table tr:last-child td { border-bottom:none; }
.bw-rule-badge    { background:var(--gold-pale);color:var(--gold-dark);padding:.15rem .5rem;border-radius:5px;font-size:.73rem;font-weight:600;white-space:nowrap; }
.bw-discount-pct  { background:#e0f4e8;color:#2A6A3A;padding:.15rem .5rem;border-radius:5px;font-size:.73rem;font-weight:600; }
.bw-old-price     { text-decoration:line-through;color:var(--text-light);margin-right:.3rem;font-size:.77rem; }
.bw-extra-row td  { color:var(--gold-dark);background:var(--gold-pale); }
.bw-total-row td  { background:#e8f8ec;font-weight:700; }
tfoot td          { padding:.52rem .65rem; }

/* Confirm summary */
.bw-confirm-summary { background:var(--ivory-warm);border:1px solid var(--ivory-border);border-radius:12px;padding:1.2rem 1.4rem;display:flex;flex-direction:column;gap:.55rem;margin-bottom:1.7rem; }
.bw-cs-row   { display:flex;justify-content:space-between;align-items:center;font-size:.9rem;color:var(--text-primary); }
.bw-cs-total { font-size:1.05rem;font-weight:700;color:var(--navy);padding-top:.55rem;border-top:1px solid var(--ivory-border);margin-top:.2rem; }

/* Widget buttons */
.bw-btn-primary   { width:100%;padding:.95rem;background:var(--navy);color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:700;cursor:pointer;transition:transform .2s,box-shadow .2s,background .2s;margin-top:.6rem;font-family:var(--font-body);display:block;text-align:center; }
.bw-btn-primary:hover:not(:disabled) { background:var(--navy-mid);transform:translateY(-2px);box-shadow:var(--shadow-md); }
.bw-btn-primary:disabled { opacity:.5;cursor:not-allowed;transform:none !important; }
.bw-btn-secondary { padding:.8rem 1.6rem;background:var(--ivory-warm);color:var(--text-primary);border:1px solid var(--ivory-border);border-radius:10px;font-size:.9rem;font-weight:600;cursor:pointer;font-family:var(--font-body);transition:background .2s; }
.bw-btn-secondary:hover { background:var(--ivory-dark); }
.bw-step-actions  { display:flex;gap:1rem;margin-top:1.2rem; }
.bw-step-actions .bw-btn-primary { flex:1;margin-top:0; }

.bw-error       { background:#fde8e8;border:1px solid #f4b8b8;border-radius:8px;padding:.75rem 1rem;color:#A03030;font-size:.86rem;margin:.7rem 0;display:flex;align-items:center;gap:.5rem; }
.bw-unavailable { text-align:center;padding:2.5rem 1rem; }
.bw-success     { text-align:center;padding:1.5rem; }
.bw-success-details { background:#e8f8ec;border:1px solid #b8e8c0;border-radius:12px;padding:1.1rem;text-align:left;max-width:420px;margin:1rem auto 0;display:flex;flex-direction:column;gap:.5rem; }

@media(max-width:640px){
  .bw-grid-2 { grid-template-columns:1fr; }
  .booking-widget { padding:1.5rem; }
  .bw-option-total { font-size:1.1rem; }
  .bw-steps .bw-step-label { display:none; }
  .bw-manual-total { flex-direction:column;gap:.4rem;text-align:center; }
}
@media(max-width:480px){
  .booking-widget { padding:1.5rem 1.1rem !important;border-radius:14px; }
  .bw-steps { margin-bottom:1.5rem; }
  .bw-grid-2 { grid-template-columns:1fr !important;gap:.7rem; }
  .bw-counter { width:100%;justify-content:space-between; }
  .bw-mode-tabs { flex-direction:column;border-radius:10px; }
  .bw-mode-tab  { border-radius:8px !important;text-align:center; }
  .bw-summary-bar { flex-direction:column;align-items:flex-start;gap:.35rem; }
  .bw-edit-link { margin-left:0; }
}


/* ───────────────────────────────────────────────────────────────
   §24  BOOKING CONFIRMATION PAGE  (standalone)
───────────────────────────────────────────────────────────────── */
body.page-confirmation {
  font-family: var(--font-body);
  background: var(--ivory);
  color: var(--text-primary);
  min-height: 100vh;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  padding: 2rem 1rem;
}
.conf-card   { background:#fff;border-radius:20px;max-width:520px;width:100%;box-shadow:var(--shadow-lg);overflow:hidden;border:1px solid var(--border-soft); }
.hdr         { background:var(--navy);padding:2.5rem 2rem;text-align:center; }
.hdr-brand   { color:#fff;font-family:var(--font-heading);font-size:1.1rem;font-style:italic;font-weight:400;margin-bottom:.2rem; }
.hdr-sub     { font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(184,146,58,.85); }
.tick-wrap   { display:flex;justify-content:center;padding:2rem 2rem 1rem; }
.tick        { width:76px;height:76px;border-radius:50%;background:linear-gradient(135deg,#5CB87A,#3A9A5A);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 24px rgba(90,184,122,.3); }
.tick svg    { width:36px;height:36px;stroke:#fff;fill:none;stroke-width:3;stroke-linecap:round;stroke-linejoin:round; }
.conf-body   { padding:0 2rem 2rem; }
.ref-badge   { display:inline-flex;align-items:center;gap:.45rem;background:var(--gold-pale);border:1.5px solid var(--border-gold);border-radius:8px;padding:.4rem 1rem;font-size:.84rem;font-weight:700;color:var(--gold-dark);margin-bottom:1.2rem;font-family:var(--font-heading);font-style:italic; }
.conf-row    { display:flex;justify-content:space-between;align-items:center;padding:.55rem 0;border-bottom:1px solid var(--border-soft);font-size:.87rem; }
.conf-row:last-of-type { border-bottom:none; }
.row-label   { color:var(--text-muted); }
.row-val     { font-weight:600;color:var(--navy);text-align:right; }
.advance-box { background:var(--gold-pale);border:1.5px solid var(--border-gold);border-radius:12px;padding:1.1rem;margin:1.2rem 0;text-align:center; }
.advance-amt { font-family:var(--font-heading);font-size:1.8rem;font-weight:500;color:var(--gold-dark); }
.btn-pay     { display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.95rem;background:#e2136e;color:#fff;border-radius:10px;font-size:.95rem;font-weight:700;text-decoration:none;margin-bottom:.8rem;transition:filter .2s; }
.btn-pay:hover { filter:brightness(.9); }
.btn-home    { display:flex;align-items:center;justify-content:center;gap:.4rem;width:100%;padding:.8rem;background:var(--ivory-warm);color:var(--navy);border-radius:10px;font-size:.9rem;font-weight:600;text-decoration:none;border:1px solid var(--ivory-border);transition:background .2s; }
.btn-home:hover { background:var(--ivory-dark); }
.btn-print   { display:flex;align-items:center;justify-content:center;gap:.4rem;width:100%;padding:.7rem;background:none;color:var(--navy-mid);border:1.5px solid var(--navy-pale);border-radius:9px;font-size:.84rem;font-weight:600;cursor:pointer;font-family:var(--font-body);margin-bottom:.7rem;transition:all .2s; }
.btn-print:hover { background:var(--ivory-warm); }
.wa-box      { background:#f0fdf4;border:1px solid #b8e8a0;border-radius:10px;padding:.9rem 1rem;text-align:center;margin-bottom:1rem; }
.wa-box p    { font-size:.82rem;color:var(--text-primary);margin-bottom:.5rem; }
.conf-wa-btn { display:inline-flex;align-items:center;gap:.4rem;background:#25D366;color:#fff;padding:.5rem 1.2rem;border-radius:8px;font-size:.82rem;font-weight:700;text-decoration:none; }


/* ───────────────────────────────────────────────────────────────
   §25  ADVANCE PAYMENT PAGE  (standalone)
───────────────────────────────────────────────────────────────── */
body.page-advance {
  font-family: var(--font-body);
  background: var(--ivory);
  color: var(--text-primary);
  min-height: 100vh;
}
.ap-wrap  { min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem 1rem; }
.ap-card  { background:#fff;border-radius:20px;max-width:520px;width:100%;box-shadow:var(--shadow-lg);overflow:hidden;border:1px solid var(--border-soft); }
.ap-hdr   { background:var(--navy);padding:1.8rem 2rem;text-align:center; }
.ap-hdr .hdr-brand  { color:#fff;font-family:var(--font-heading);font-size:1.1rem;font-style:italic;font-weight:400; }
.ap-hdr .hdr-sub    { font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(184,146,58,.85);margin:.1rem 0 .9rem; }
.ap-hdr .hdr-title  { font-family:var(--font-heading);color:#fff;font-size:1.25rem;font-style:italic;font-weight:400; }
.ap-hdr .hdr-caption { color:rgba(255,255,255,.45);font-size:.77rem;margin-top:.2rem; }
.ap-body  { padding:1.8rem 2rem; }
.info-row { display:flex;justify-content:space-between;font-size:.86rem;padding:.5rem 0;border-bottom:1px solid var(--border-soft); }
.info-row:last-child { border-bottom:none; }
.il { color:var(--text-muted); }
.iv { font-weight:600;color:var(--navy); }
.adv-box  { background:var(--gold-pale);border:1.5px solid var(--border-gold);border-radius:12px;padding:1.1rem;margin:1.1rem 0;text-align:center; }
.adv-amt  { font-family:var(--font-heading);font-size:1.6rem;font-weight:500;color:var(--gold-dark); }
.adv-sub  { font-size:.74rem;color:var(--text-muted);margin-top:.25rem; }
.method-grid  { display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;margin:1.1rem 0; }
.method-btn   { border:1.5px solid var(--border-main);border-radius:10px;padding:.65rem .4rem;text-align:center;cursor:pointer;background:var(--ivory-alt);transition:all .15s;font-family:var(--font-body); }
.method-btn:hover { border-color:var(--gold);background:var(--gold-pale); }
.method-btn.selected { border-color:var(--method-color,var(--gold));background:color-mix(in srgb,var(--method-color,var(--gold)) 8%,#fff);box-shadow:0 0 0 3px color-mix(in srgb,var(--method-color,var(--gold)) 18%,transparent); }
.method-icon  { font-size:1.2rem;margin-bottom:.15rem; }
.method-name  { font-size:.72rem;font-weight:600;color:var(--navy); }
.method-btn.selected .method-name { color:var(--method-color,var(--gold)); }
.pay-section       { background:var(--ivory-warm);border:1.5px solid var(--ivory-border);border-radius:12px;padding:1.2rem;margin-top:1rem; }
.pay-section-title { font-size:.78rem;font-weight:700;color:var(--text-muted);margin-bottom:.9rem;text-transform:uppercase;letter-spacing:.05em; }
.account-display   { background:#fff;border:1px solid var(--border-main);border-radius:8px;padding:.65rem 1rem;margin:.5rem 0 .9rem;display:flex;align-items:center;justify-content:space-between; }
.account-number    { font-size:1rem;font-weight:700;font-family:monospace;letter-spacing:1px;color:var(--navy); }
.copy-btn          { font-size:.7rem;color:var(--text-muted);background:var(--ivory-warm);border:1px solid var(--border-main);border-radius:5px;padding:.25rem .55rem;cursor:pointer;font-family:var(--font-body);transition:all .15s; }
.copy-btn:hover    { color:var(--gold);border-color:var(--gold); }
.steps { font-size:.8rem;color:var(--text-secondary);line-height:1.75;margin:.4rem 0 .9rem; }
.steps ol { padding-left:1.2rem; }
.submit-btn { width:100%;border:none;padding:.9rem;border-radius:8px;font-weight:700;font-size:.9rem;cursor:pointer;font-family:var(--font-body);transition:all .2s;margin-top:1rem;color:#fff;background:var(--method-color,var(--gold)); }
.submit-btn:hover  { filter:brightness(.92);transform:translateY(-1px); }
.submit-btn:disabled { opacity:.55;cursor:not-allowed;transform:none; }
.success-icon { width:68px;height:68px;border-radius:50%;background:linear-gradient(135deg,#5CB87A,#3A9A5A);display:inline-flex;align-items:center;justify-content:center;font-size:1.9rem;margin-bottom:.9rem; }
.home-link { display:inline-block;background:var(--navy);color:#fff;text-decoration:none;padding:.7rem 2rem;border-radius:8px;font-weight:600;font-size:.87rem;margin-top:1.2rem;transition:background .2s; }
.home-link:hover { background:var(--navy-mid); }
.toast      { position:fixed;top:20px;right:20px;z-index:1000;padding:.85rem 1.3rem;border-radius:10px;font-weight:600;font-size:.84rem;box-shadow:var(--shadow-md); }
.toast-ok   { background:#e8f8ec;color:#2A6A3A;border:1.5px solid #b8e8c0; }
.toast-err  { background:#fde8e8;color:#A03030;border:1.5px solid #f4b8b8; }
.fade-up    { animation:fadeUpSm .45s ease; }
.spin       { width:14px;height:14px;border:2px solid #fff;border-top-color:transparent;border-radius:50%;display:inline-block;animation:spin .7s linear infinite;vertical-align:middle;margin-right:6px; }


/* ───────────────────────────────────────────────────────────────
   §26  404 PAGE  (standalone)
───────────────────────────────────────────────────────────────── */
body.page-404 {
  font-family: var(--font-body);
  background: linear-gradient(150deg, #0D1A28 0%, var(--navy) 55%, #243D58 100%);
  min-height: 100vh; display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  text-align: center; padding: 2rem; position: relative; overflow: hidden;
  color: #fff;
}
body.page-404 h1 { color: #fff; }
body.page-404 p  { color: rgba(255,255,255,.55); }
body.page-404::before { content:'';position:absolute;width:500px;height:500px;background:rgba(184,146,58,.04);border-radius:50%;top:-100px;right:-100px;pointer-events:none; }
body.page-404::after  { content:'';position:absolute;width:400px;height:400px;background:rgba(28,47,69,.4);border-radius:50%;bottom:-80px;left:-80px;pointer-events:none; }
.err-card     { position:relative;z-index:1;max-width:520px;width:100%; }
.err-num      { font-family:var(--font-heading);font-size:clamp(7rem,20vw,12rem);font-weight:300;font-style:italic;color:rgba(255,255,255,.07);line-height:1;margin-bottom:-1.5rem;user-select:none; }
.wave         { font-size:3.5rem;margin-bottom:1rem;display:block;animation:wave 2.5s ease-in-out infinite; }
.err-btn-home { display:inline-flex;align-items:center;gap:.5rem;background:var(--gold);color:#fff;padding:.85rem 2rem;border-radius:10px;font-size:.9rem;font-weight:700;text-decoration:none;transition:transform .2s,box-shadow .2s; }
.err-btn-home:hover { transform:translateY(-2px);box-shadow:var(--shadow-gold);color:#fff; }
.btn-contact  { display:inline-flex;align-items:center;gap:.5rem;background:rgba(255,255,255,.08);color:rgba(255,255,255,.7);padding:.85rem 2rem;border-radius:10px;font-size:.9rem;font-weight:600;text-decoration:none;border:1px solid rgba(255,255,255,.12);transition:all .2s; }
.btn-contact:hover { background:rgba(255,255,255,.14);color:#fff; }
.quick-links  { margin-top:2.5rem;padding-top:2rem;border-top:1px solid rgba(255,255,255,.08); }
.quick-links p { color:rgba(255,255,255,.3);font-size:.77rem;margin-bottom:.9rem;text-transform:uppercase;letter-spacing:.1em; }
.links-row    { display:flex;gap:.6rem;justify-content:center;flex-wrap:wrap; }
.q-link       { color:rgba(255,255,255,.4);font-size:.8rem;text-decoration:none;padding:.3rem .75rem;border-radius:6px;border:1px solid rgba(255,255,255,.08);transition:all .2s; }
.q-link:hover { color:#fff;background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.2); }
.err-brand    { position:absolute;top:1.5rem;left:50%;transform:translateX(-50%);text-align:center;z-index:2; }
.err-brand-name { font-family:var(--font-heading);color:#fff;font-size:1.1rem;font-style:italic;font-weight:400;line-height:1; }
.err-brand-sub  { font-size:.55rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(184,146,58,.8); }


/* ───────────────────────────────────────────────────────────────
   §27  PRINT STYLES
───────────────────────────────────────────────────────────────── */
@media print {
  .btn-pay,.btn-print,.wa-box,.wa-float,nav,footer,
  #progress-bar,#back-top,.cookie-banner,.mob-book-bar { display:none !important; }
  body   { background:#fff !important;color:#000 !important; }
  .conf-card,.ap-card { box-shadow:none !important;border:1px solid #ddd !important; }
}