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

/* ============================================================================
   ELITA MODERN — presentation overlay (loaded LAST, after style.css)
   v2 — calmer & lighter, more compact, real logo, flag-only switcher.
   PRESENTATION ONLY — no reservation / booking / pricing logic touched.
   ============================================================================ */

/* ----------------------------------------------------------------------------
   0. CALMER PALETTE — re-tune the theme's own tokens (cascades everywhere)
   ---------------------------------------------------------------------------- */
:root{
  /* NIGHT (default) — refined neutral charcoal, gold only as a soft accent */
  --bg:#17161b; --bg2:#1d1b22;
  --accent:#cba877; --accent-soft:#e3cda0;
  --card:rgba(34,32,39,.92); --card-soft:rgba(28,26,32,.85);
  --border:rgba(255,255,255,.08);
  --text-muted:rgba(235,231,225,.66);
  --brand-primary:#cba877; --brand-accent:#e3cda0;
  --phed-bg:#17161b; --phed-bg-elev:#222027;
  --phed-border:rgba(255,255,255,.10);
  --phed-shadow-lg:0 18px 44px rgba(0,0,0,.42);

  --em-gold:#cba877; --em-gold-soft:#e3cda0; --em-gold-deep:#b8965a;
  --em-ease:cubic-bezier(.22,.61,.36,1);
  --em-spring:cubic-bezier(.34,1.56,.64,1);
  --em-radius:18px; --em-radius-lg:24px;
  --em-shadow:0 18px 44px rgba(0,0,0,.34);
  --em-shadow-soft:0 12px 30px rgba(40,30,15,.10);
}
body.day-mode{
  /* DAY — calm ivory, white cards, gold accent */
  --bg:#f6f3ec; --bg2:#efe9dd;
  --accent:#b8965a; --accent-soft:#caa66e;
  --card:#ffffff; --card-soft:#fbf8f1;
  --border:rgba(40,30,12,.12);
  --text-muted:rgba(48,42,34,.64);
  --brand-primary:#b8965a; --brand-accent:#caa66e;
  --phed-bg:#f6f3ec; --phed-bg-elev:#ffffff;
  --phed-border:rgba(40,30,12,.14);
  --phed-shadow-lg:0 14px 34px rgba(70,50,20,.10);
  --em-gold:#b8965a; --em-gold-soft:#caa66e; --em-gold-deep:#9c7c44;
  --em-shadow:0 14px 34px rgba(70,50,20,.12);
}

html{scroll-behavior:smooth;}
body{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;color:#ece8e2;}
body.day-mode{color:#2b2925 !important;}

/* the root paints the FULL page (base sets html,body{height:100%}, so the body
   gradient alone only covers the first viewport — below-fold showed html's dark navy) */
html{background:#141318 !important;}
html:has(body.day-mode){background:#f1ece1 !important;}

/* calm, quiet backdrops (no heavy gold washes) */
body{
  background:
    radial-gradient(1200px 700px at 50% -10%, rgba(203,168,119,.07), transparent 60%),
    linear-gradient(180deg,#17161b 0%,#141318 100%) !important;
}
body.day-mode{
  background:
    radial-gradient(1200px 700px at 50% -12%, rgba(184,150,90,.10), transparent 58%),
    linear-gradient(180deg,#f7f4ed 0%,#f1ece1 100%) !important;
}
body::before,body::after{opacity:.25 !important;}

/* ============================================================================
   1. HEADER + NAV — compact glass bar
   ============================================================================ */
.site-header{
  padding:10px clamp(16px,3.2vw,34px) !important;
  background:linear-gradient(180deg, rgba(20,19,24,.86), rgba(20,19,24,.42) 70%, transparent) !important;
  -webkit-backdrop-filter:blur(16px) saturate(1.1);
  backdrop-filter:blur(16px) saturate(1.1) !important;
  border-bottom:1px solid rgba(255,255,255,.07) !important;
  transition:padding .3s var(--em-ease), background .3s var(--em-ease);
}
body.day-mode .site-header{
  background:linear-gradient(180deg, rgba(247,244,237,.92), rgba(247,244,237,.5) 70%, transparent) !important;
  border-bottom:1px solid rgba(40,30,12,.1) !important;
}
.site-header.em-scrolled{padding-top:7px !important;padding-bottom:7px !important;
  box-shadow:0 8px 26px rgba(0,0,0,.18);}

/* elegant header nav — clean serious text, gold underline that grows from
   centre on hover; NO boxes/backgrounds (even in the mobile drawer) */
.site-header .main-nav-list a,
.site-header .main-nav a{
  background:transparent !important;border:0 !important;border-radius:0 !important;min-height:0 !important;box-shadow:none !important;
  padding:6px 3px !important;font-weight:600 !important;font-size:13px !important;letter-spacing:.13em !important;
  text-transform:uppercase;color:inherit !important;opacity:.82;text-shadow:none !important;
  transition:color .25s var(--em-ease), opacity .25s var(--em-ease) !important;transform:none !important;
}
.site-header .main-nav-list a:hover,
.site-header .main-nav a:hover{color:var(--em-gold) !important;opacity:1 !important;transform:none !important;text-shadow:none !important;}
.site-header .main-nav a::after,
.site-header .main-nav-list a::after{
  left:0 !important;right:0 !important;width:auto !important;bottom:-3px !important;height:2px !important;border-radius:2px;
  background:linear-gradient(90deg,var(--em-gold-deep),var(--em-gold-soft)) !important;
  transform:scaleX(0) !important;transform-origin:center !important;transition:transform .32s var(--em-ease) !important;
}
.site-header .main-nav a:hover::after,
.site-header .main-nav-list a:hover::after,
.site-header .current-menu-item > a::after,
.site-header .main-nav-list .current-menu-item > a::after,
.site-header .main-nav a[aria-current]::after{transform:scaleX(1) !important;}
/* mobile drawer: clean text rows with a hairline divider — still no boxes */
@media (max-width:760px){
  .site-header .main-nav-list a,
  .site-header .main-nav a{
    width:100% !important;padding:14px 8px !important;font-size:15px !important;letter-spacing:.05em !important;
    border-bottom:1px solid var(--border) !important;border-radius:0 !important;justify-content:flex-start;
  }
  .site-header .main-nav-list a::after,
  .site-header .main-nav a::after{display:none !important;}
}

/* ============================================================================
   2. LOGO — real brand image, revealed left-to-right ("written")
   ============================================================================ */
.logo{display:inline-flex;align-items:center;padding:0 !important;animation:none !important;}
.logo-wordmark-wrap{display:none !important;}   /* hide the text fallback */
/* bigger, NO background plate, crisp & readable */
.site-logo-img{
  display:block;height:clamp(58px,5.6vw,76px);width:auto;
  background:transparent !important;border:0 !important;box-shadow:none !important;padding:0 !important;
  filter:drop-shadow(0 2px 6px rgba(0,0,0,.2));
}
/* dark header: render the dark+gold logo as crisp white so it reads with no plate */
body:not(.day-mode) .site-logo-img{filter:brightness(0) invert(1) drop-shadow(0 3px 9px rgba(0,0,0,.45)) !important;}
/* reveal wipe on load */
html.em-js .site-logo-img{clip-path:inset(0 100% 0 0);}
html.em-js .logo.em-written .site-logo-img{animation:emLogoWipe 1.35s var(--em-ease) .15s forwards;}
@keyframes emLogoWipe{to{clip-path:inset(0 0 0 0);}}

/* ============================================================================
   3. LANGUAGE SWITCHER — flags only, real flag images
   ============================================================================ */
.lang-switch{position:relative;}
.lang-current-code{display:none !important;}      /* no SQ/EN text */
.lang-current-btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 9px !important;border-radius:999px !important;
  background:rgba(255,255,255,.06) !important;
  border:1px solid rgba(255,255,255,.16) !important;
  color:inherit !important;cursor:pointer;line-height:0;
  transition:transform .2s var(--em-spring), background .25s, border-color .25s;
}
body.day-mode .lang-current-btn{background:rgba(40,30,12,.05) !important;border-color:rgba(40,30,12,.16) !important;}
.lang-current-btn:hover{transform:translateY(-1px);border-color:var(--em-gold) !important;}
.lang-current-btn::after{content:"\25BE";font-size:9px;opacity:.5;line-height:1;}
.lang-current-btn[aria-expanded="true"]::after{opacity:.9;}

/* the flag swatch (current) */
.lang-current-flag{
  display:inline-block !important;width:28px;height:20px;border-radius:4px;
  font-size:0 !important;color:transparent !important;overflow:hidden;
  background-size:cover !important;background-position:center !important;background-repeat:no-repeat !important;
  box-shadow:0 1px 3px rgba(0,0,0,.35), inset 0 0 0 1px rgba(255,255,255,.18);
}

.lang-options{
  position:absolute;top:calc(100% + 9px);right:0;z-index:60;
  display:flex;flex-direction:column;gap:4px;
  padding:8px !important;min-width:auto;width:max-content;
  border-radius:16px !important;
  background:linear-gradient(165deg, rgba(30,28,34,.98), rgba(22,21,26,.98)) !important;
  border:1px solid rgba(255,255,255,.1) !important;
  box-shadow:var(--em-shadow) !important;
  -webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);
  opacity:0;transform:translateY(-8px) scale(.97);pointer-events:none;
  transition:opacity .2s var(--em-ease), transform .24s var(--em-spring);
}
body.day-mode .lang-options{
  background:linear-gradient(165deg,#fffdf9,#f6f1e8) !important;border-color:rgba(40,30,12,.14) !important;
}
.lang-switch.is-open .lang-options,
.lang-switch.open .lang-options{opacity:1;transform:none;pointer-events:auto;}

/* each option becomes a flag chip (label text hidden) */
.lang-btn{
  display:flex !important;align-items:center;justify-content:center;
  width:38px;height:28px;padding:0 !important;
  border-radius:8px !important;border:1px solid transparent !important;
  background:transparent !important;font-size:0 !important;color:transparent !important;cursor:pointer;
  transition:transform .16s var(--em-spring), background .18s, border-color .18s;
  position:relative;overflow:hidden;
}
.lang-btn::before{
  content:"";position:absolute;inset:4px;border-radius:4px;
  background-size:cover !important;background-position:center !important;background-repeat:no-repeat !important;
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.12);
}
.lang-btn:hover{transform:scale(1.06);background:rgba(255,255,255,.08) !important;}
body.day-mode .lang-btn:hover{background:rgba(40,30,12,.06) !important;}
.lang-btn.active,
.lang-btn[aria-pressed="true"]{border-color:var(--em-gold) !important;background:rgba(203,168,119,.16) !important;}

/* flag images (relative to this CSS file: assets/elita-modern.css -> flags/) */
.lang-current-flag[data-flag="AL"]{background-image:url('flags/al.png');}
.lang-current-flag[data-flag="GB"]{background-image:url('flags/gb.png');}
.lang-current-flag[data-flag="IT"]{background-image:url('flags/it.png');}
.lang-current-flag[data-flag="FR"]{background-image:url('flags/fr.png');}
.lang-current-flag[data-flag="DE"]{background-image:url('flags/de.png');}
.lang-btn[data-flag="AL"]::before{background-image:url('flags/al.png');}
.lang-btn[data-flag="GB"]::before{background-image:url('flags/gb.png');}
.lang-btn[data-flag="IT"]::before{background-image:url('flags/it.png');}
.lang-btn[data-flag="FR"]::before{background-image:url('flags/fr.png');}
.lang-btn[data-flag="DE"]::before{background-image:url('flags/de.png');}

/* day/night toggle — small round chip */
.day-night-toggle{
  width:36px;height:36px;border-radius:50% !important;
  display:inline-flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.06) !important;border:1px solid rgba(255,255,255,.16) !important;
  color:inherit !important;cursor:pointer;
  transition:transform .3s var(--em-spring), background .25s, border-color .25s;
}
.day-night-toggle:hover{transform:rotate(-16deg) scale(1.05);border-color:var(--em-gold) !important;}
body.day-mode .day-night-toggle{background:rgba(40,30,12,.05) !important;border-color:rgba(40,30,12,.16) !important;}

/* ============================================================================
   4. BUTTONS — softer gold, refined
   ============================================================================ */
.btn{
  border-radius:12px !important;font-weight:700 !important;letter-spacing:.005em;
  transition:transform .2s var(--em-spring), box-shadow .25s, background .25s, color .2s !important;
  position:relative;overflow:hidden;
}
.btn:hover{transform:translateY(-2px);}
.btn:active{transform:translateY(0) scale(.985);}
.btn-primary,#headerBookBtn{
  background:linear-gradient(135deg,var(--em-gold-deep),var(--em-gold)) !important;
  color:#fff !important;border:none !important;
  box-shadow:0 8px 22px rgba(184,150,90,.26) !important;
}
body.day-mode .btn-primary,body.day-mode #headerBookBtn{color:#2b2114 !important;}
.btn-primary:hover,#headerBookBtn:hover{box-shadow:0 14px 32px rgba(184,150,90,.36) !important;}
.btn-primary::after,#headerBookBtn::after{
  content:"";position:absolute;top:0;left:-120%;width:55%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.45),transparent);
  transform:skewX(-18deg);transition:left .6s var(--em-ease);
}
.btn-primary:hover::after,#headerBookBtn:hover::after{left:150%;}
.btn-ghost{
  background:rgba(255,255,255,.05) !important;border:1px solid rgba(255,255,255,.18) !important;color:inherit !important;
}
.btn-ghost:hover{border-color:var(--em-gold) !important;}
body.day-mode .btn-ghost{background:rgba(40,30,12,.04) !important;border-color:rgba(40,30,12,.18) !important;color:#2b2925 !important;}

/* "Rezervo tani" CTA — gentle pulse to draw the eye (class added by JS) */
.em-cta{animation:emCtaPulse 2.3s var(--em-ease) infinite;}
.em-cta i{margin-right:8px;}
@keyframes emCtaPulse{
  0%,100%{box-shadow:0 8px 22px rgba(184,150,90,.28);transform:translateY(0);}
  50%{box-shadow:0 10px 30px rgba(216,173,110,.5), 0 0 0 6px rgba(216,173,110,.14);transform:translateY(-1px);}
}
.em-cta:hover{animation-play-state:paused;}

/* ============================================================================
   5. HERO — compact
   ============================================================================ */
.hero{padding-top:clamp(22px,3.5vw,46px) !important;padding-bottom:clamp(8px,1.5vw,18px) !important;}
.hero-kicker{
  color:var(--em-gold) !important;font-weight:700 !important;
  letter-spacing:.2em !important;text-transform:uppercase;font-size:11px !important;
  display:inline-flex;align-items:center;gap:7px;
}
.hero-kicker::before{content:"\2726";font-size:12px;color:var(--em-gold-soft);}
.hero-title{
  font-family:"Cormorant Garamond",Georgia,serif !important;
  font-size:clamp(36px,5vw,62px) !important;font-weight:700 !important;
  line-height:1.04 !important;margin:.1em 0 .22em !important;
}
.hero-subtitle{font-size:clamp(14px,1.2vw,17px) !important;max-width:540px;opacity:.9;}
.hero-badges{gap:8px !important;margin-top:18px !important;}
.badge{
  border-radius:999px !important;padding:7px 13px !important;
  background:rgba(255,255,255,.05) !important;border:1px solid rgba(255,255,255,.14) !important;
  -webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);
  font-size:12.5px;font-weight:600;
  transition:transform .2s var(--em-spring), border-color .25s;
}
.badge:hover{transform:translateY(-2px);border-color:var(--em-gold) !important;}
.badge i{color:var(--em-gold) !important;}
body.day-mode .badge{background:rgba(40,30,12,.04) !important;border-color:rgba(40,30,12,.12) !important;}

.hero-image-frame{
  border-radius:var(--em-radius-lg) !important;overflow:hidden;
  box-shadow:var(--em-shadow) !important;border:1px solid var(--border);
}
.hero-image-frame::after{
  content:"";position:absolute;inset:0;pointer-events:none;border-radius:inherit;
  background:linear-gradient(195deg,transparent 60%,rgba(15,12,8,.4));
}
.hero-slide{transition:opacity 1.1s var(--em-ease) !important;}
.hero-slider .hero-slide{animation:emHeroFade 21s infinite !important;}
.hero-slider .hero-slide:nth-child(1){animation-delay:0s !important;}
.hero-slider .hero-slide:nth-child(2){animation-delay:7s !important;}
.hero-slider .hero-slide:nth-child(3){animation-delay:14s !important;}
@keyframes emHeroFade{
  0%{opacity:0;transform:scale(1.07);}
  5%{opacity:1;}33%{opacity:1;transform:scale(1);}40%{opacity:0;}100%{opacity:0;transform:scale(1);}
}
.hero-tag{
  background:linear-gradient(135deg,var(--em-gold-deep),var(--em-gold)) !important;
  color:#fff !important;font-weight:800 !important;letter-spacing:.1em;
  border-radius:999px !important;box-shadow:0 8px 20px rgba(0,0,0,.28);z-index:2;
}
body.day-mode .hero-tag{color:#2b2114 !important;}

/* ============================================================================
   6. SECTIONS — compact, NO dash after headings
   ============================================================================ */
.section{padding-top:clamp(34px,4.5vw,62px) !important;padding-bottom:clamp(8px,1.5vw,18px) !important;}
.section-header h2{
  font-family:"Cormorant Garamond",Georgia,serif !important;
  font-size:clamp(28px,3.4vw,42px) !important;font-weight:700 !important;line-height:1.08;
}
.section-header h2::after{display:none !important;content:none !important;}  /* remove the --- dash */
.section-header > p{opacity:.82;}

/* scroll reveal (only when JS adds .em-js, so no-JS shows content) */
html.em-js .em-reveal{opacity:0;transform:translateY(22px);
  transition:opacity .65s var(--em-ease), transform .75s var(--em-ease);}
html.em-js .em-reveal.em-left{transform:translateX(-28px);}
html.em-js .em-reveal.em-right{transform:translateX(28px);}
html.em-js .em-reveal.em-in{opacity:1;transform:none;}
html.em-js .em-stagger > *{opacity:0;transform:translateY(18px);
  transition:opacity .55s var(--em-ease), transform .65s var(--em-ease);}
html.em-js .em-stagger.em-in > *{opacity:1;transform:none;}
html.em-js .em-stagger.em-in > *:nth-child(2){transition-delay:.06s;}
html.em-js .em-stagger.em-in > *:nth-child(3){transition-delay:.12s;}
html.em-js .em-stagger.em-in > *:nth-child(4){transition-delay:.18s;}
html.em-js .em-stagger.em-in > *:nth-child(5){transition-delay:.24s;}
html.em-js .em-stagger.em-in > *:nth-child(6){transition-delay:.3s;}

/* ============================================================================
   7. CARDS — calmer, lighter
   ============================================================================ */
.booking-card,.room-card,.facility-card,.policy-card,.info-card,.note-card,.contact-card{
  border-radius:var(--em-radius) !important;
  background:var(--card) !important;border:1px solid var(--border) !important;
  box-shadow:var(--em-shadow) !important;
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px) !important;
  transition:transform .28s var(--em-ease), box-shadow .28s var(--em-ease), border-color .28s !important;
}
body.day-mode .booking-card,body.day-mode .room-card,body.day-mode .facility-card,
body.day-mode .policy-card,body.day-mode .info-card,body.day-mode .note-card,body.day-mode .contact-card{
  box-shadow:var(--em-shadow-soft) !important;
}
.room-card:hover,.facility-card:hover,.policy-card:hover,.contact-card:hover{
  transform:translateY(-5px);border-color:var(--em-gold) !important;
  box-shadow:0 24px 50px rgba(0,0,0,.32) !important;
}
body.day-mode .room-card:hover,body.day-mode .facility-card:hover,
body.day-mode .policy-card:hover,body.day-mode .contact-card:hover{box-shadow:0 20px 42px rgba(90,60,25,.16) !important;}
.room-card img,.facility-card img,.media-frame img{transition:transform .7s var(--em-ease) !important;}
.room-card:hover img,.facility-card:hover img{transform:scale(1.05);}

.facility-icon,.policy-icon,.contact-icon{
  border-radius:14px !important;
  background:rgba(203,168,119,.14) !important;border:1px solid rgba(203,168,119,.22);
}
.facility-icon i,.policy-icon i,.contact-icon i{color:var(--em-gold) !important;}
.check-list li::marker{color:var(--em-gold);}
.media-frame{border-radius:var(--em-radius-lg) !important;overflow:hidden;box-shadow:var(--em-shadow) !important;}

/* ============================================================================
   8. FOOTER — modern, multi-column
   ============================================================================ */
.site-footer{
  margin-top:clamp(36px,5vw,72px) !important;
  padding:clamp(30px,4vw,54px) clamp(18px,4vw,40px) 18px !important;
  border-top:1px solid var(--border);
  background:linear-gradient(180deg, rgba(255,255,255,.02), transparent) !important;
}
body.day-mode .site-footer{background:linear-gradient(180deg, rgba(40,30,12,.03), transparent) !important;}
.footer-grid{
  display:grid;gap:clamp(24px,3.4vw,52px);
  grid-template-columns:1.6fr 1.1fr 1.1fr;
  max-width:1180px;margin:0 auto 26px;
}
.footer-brand{text-align:center;}
.footer-brand .footer-logo{
  height:92px;width:auto;margin:0 auto 14px;display:block;
  background:transparent;padding:0;
}
body:not(.day-mode) .footer-brand .footer-logo{filter:brightness(0) invert(1);}
.footer-tagline{color:var(--text-muted);font-size:13.5px;max-width:320px;line-height:1.6;margin:0 auto;}
.footer-social{display:flex;gap:10px;margin-top:16px;justify-content:center;}
.footer-social a{
  width:38px;height:38px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;
  background:rgba(203,168,119,.12);border:1px solid rgba(203,168,119,.24);color:var(--em-gold);
  transition:transform .2s var(--em-spring), background .25s, color .2s;
}
.footer-social a:hover{transform:translateY(-3px);background:var(--em-gold);color:#fff;}
body.day-mode .footer-social a:hover{color:#fff;}
.site-footer h4{
  font-size:13px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;
  color:var(--em-gold);margin-bottom:14px;
}
.footer-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px;}
.footer-list li{display:flex;align-items:center;gap:10px;font-size:13.5px;color:var(--text-muted);}
.footer-list li i{color:var(--em-gold);width:16px;text-align:center;}
.footer-list a{color:inherit;transition:color .2s;}
.footer-list a:hover{color:var(--em-gold);}
.footer-links{gap:8px;}
.footer-book p{color:var(--text-muted);font-size:13.5px;margin-bottom:14px;line-height:1.6;}
.footer-bottom{
  max-width:1180px;margin:0 auto;padding-top:18px;border-top:1px solid var(--border);
  display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;
  font-size:12.5px;color:var(--text-muted);
}
.footer-manager-link{color:var(--em-gold);font-weight:700;}
/* DAY MODE footer — force readable dark text (base set it white) */
body.day-mode .site-footer{color:#2b2925 !important;}
body.day-mode .site-footer .footer-tagline,
body.day-mode .site-footer .footer-list li,
body.day-mode .site-footer .footer-list a,
body.day-mode .site-footer .footer-bottom,
body.day-mode .site-footer .footer-copy,
body.day-mode .site-footer .footer-powered,
body.day-mode .site-footer .footer-book p{color:#4a4136 !important;}
body.day-mode .site-footer h4{color:var(--em-gold) !important;}
body.day-mode .site-footer .footer-list a:hover,
body.day-mode .site-footer .footer-manager-link{color:var(--em-gold-deep) !important;}

.whatsapp-float .wa-icon{background:#25d366 !important;color:#fff !important;box-shadow:inset 0 0 0 1px rgba(255,255,255,.3) !important;}
.whatsapp-float .wa-icon i{color:#fff !important;}

/* ============================================================================
   8b. INNER PAGES — rooms / facilities / policies / contact polish
   ============================================================================ */
/* --- ROOMS --- */
.room-grid,.room-grid-stacked{
  display:grid !important;gap:clamp(18px,2.4vw,28px) !important;
  grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  max-width:1180px;margin:0 auto !important;
}
.room-card{display:flex !important;flex-direction:column;overflow:hidden;}
.room-grid .room-card .room-slider{
  position:relative;border-radius:var(--em-radius) var(--em-radius) 0 0;overflow:hidden;
  height:clamp(200px,20vw,250px) !important;min-height:0 !important;border-right:0 !important;
}
.room-grid .room-card .room-slider-track{height:100% !important;}
.room-grid .room-card .room-slide{width:100% !important;height:100% !important;min-height:0 !important;object-fit:cover !important;}
.room-slider-btn{
  position:absolute;top:50%;transform:translateY(-50%);z-index:2;
  width:38px;height:38px;border-radius:50%;border:0;cursor:pointer;
  background:rgba(20,18,16,.55);color:#fff;font-size:14px;
  -webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);
  opacity:0;transition:opacity .25s, background .2s;
}
.room-card:hover .room-slider-btn{opacity:1;}
.room-slider-btn:hover{background:var(--em-gold);}
.room-slider-prev{left:10px;}.room-slider-next{right:10px;}
.room-body{padding:18px 20px 20px !important;display:flex;flex-direction:column;gap:8px;}
.room-body h3{font-family:"Cormorant Garamond",serif !important;font-size:26px !important;font-weight:700 !important;}
.room-price{color:var(--em-gold) !important;font-weight:700 !important;font-size:15px !important;}
.room-feature-list{
  list-style:none !important;margin:6px 0 4px !important;padding:0 !important;
  display:grid;grid-template-columns:repeat(2,1fr);gap:7px 14px;
}
.room-feature-list li{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-muted);}
.room-feature-icon{color:var(--em-gold);width:18px;text-align:center;display:inline-flex;justify-content:center;}
.room-select,.btn-outline{
  margin-top:8px;align-self:flex-start;
  background:transparent !important;border:1.5px solid var(--em-gold) !important;color:var(--em-gold) !important;
  border-radius:12px !important;padding:10px 18px !important;font-weight:700 !important;cursor:pointer;
  transition:background .2s, color .2s, transform .2s var(--em-spring) !important;
}
.room-select:hover,.btn-outline:hover{background:var(--em-gold) !important;color:#fff !important;transform:translateY(-2px);}
body.day-mode .room-select:hover,body.day-mode .btn-outline:hover{color:#2b2114 !important;}

/* homepage 4-type rooms preview */
.home-rooms-grid{
  display:grid;gap:clamp(14px,2vw,22px);
  grid-template-columns:repeat(4,1fr);max-width:1180px;margin:0 auto;
}
.home-room-card{
  display:flex !important;flex-direction:column;overflow:hidden;text-decoration:none;color:inherit;
}
.home-room-media{border-radius:var(--em-radius) var(--em-radius) 0 0 !important;margin:0 !important;aspect-ratio:4/3;}
.home-room-media img{width:100%;height:100%;object-fit:cover;}
.home-room-body{padding:14px 16px 18px;display:flex;flex-direction:column;gap:4px;}
.home-room-body h3{font-family:"Cormorant Garamond",serif !important;font-size:23px !important;font-weight:700 !important;}
.home-room-link{margin-top:6px;color:var(--em-gold);font-weight:700;font-size:13px;letter-spacing:.02em;
  transition:letter-spacing .2s var(--em-ease);}
.home-room-card:hover .home-room-link{letter-spacing:.08em;}
@media (max-width:880px){.home-rooms-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:480px){.home-rooms-grid{grid-template-columns:1fr;}}

/* --- FACILITIES --- */
.facility-grid{
  display:grid !important;gap:clamp(16px,2.2vw,24px) !important;
  grid-template-columns:repeat(auto-fill,minmax(240px,1fr)) !important;
  max-width:1180px;margin:0 auto !important;
}
.facility-card{padding:24px 22px !important;text-align:center;}
.facility-icon,.policy-icon,.contact-icon{
  width:54px;height:54px;display:inline-flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:8px;
}
.facility-card h3{font-family:"Cormorant Garamond",serif !important;font-size:22px !important;font-weight:700 !important;margin-bottom:6px;}

/* --- POLICIES --- */
.policy-intro{
  max-width:820px;margin:0 auto clamp(20px,3vw,32px) !important;text-align:center;
  color:var(--text-muted) !important;font-size:15px;line-height:1.7;
}
.policy-visual-grid{
  display:grid !important;gap:14px !important;
  grid-template-columns:repeat(auto-fit,minmax(200px,1fr)) !important;
  max-width:1180px;margin:0 auto clamp(22px,3vw,34px) !important;
}
.policy-visual-card{position:relative;border-radius:var(--em-radius) !important;overflow:hidden;margin:0;box-shadow:var(--em-shadow);}
.policy-visual-card img{width:100%;height:150px;object-fit:cover;display:block;transition:transform .6s var(--em-ease);}
.policy-visual-card:hover img{transform:scale(1.06);}
.policy-visual-card figcaption{
  position:absolute;left:0;right:0;bottom:0;padding:18px 12px 10px;font-size:13px;font-weight:700;color:#fff;
  background:linear-gradient(transparent,rgba(12,9,6,.85));
}
.policy-grid{
  display:grid !important;gap:clamp(14px,2vw,20px) !important;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr)) !important;
  max-width:1180px;margin:0 auto !important;
}
.policy-card{padding:22px 20px !important;}
.policy-card h3{font-family:"Cormorant Garamond",serif !important;font-size:20px !important;font-weight:700 !important;margin-bottom:6px;}
.policy-card p{font-size:13.5px;color:var(--text-muted) !important;line-height:1.6;}

/* --- CONTACT --- */
.contact-layout{
  display:grid !important;gap:clamp(20px,3vw,36px) !important;
  grid-template-columns:1fr 1.1fr !important;max-width:1180px;margin:0 auto !important;align-items:start;
}
.contact-panel{padding:24px 22px !important;display:flex;flex-direction:column;gap:6px;}
.contact-row{
  display:flex;align-items:flex-start;gap:14px;padding:12px 6px;
  border-bottom:1px solid var(--border);
}
.contact-row:last-child{border-bottom:0;}
.contact-row .label{font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--em-gold);margin-bottom:2px;}
.contact-row a,.contact-row div > a{color:inherit;transition:color .2s;word-break:break-word;}
.contact-row a:hover{color:var(--em-gold);}
.contact-icon{flex:0 0 auto;width:46px;height:46px;border-radius:12px !important;}
.contact-media{display:flex;flex-direction:column;gap:16px;}
.map-frame{position:relative;border-radius:var(--em-radius-lg) !important;overflow:hidden;box-shadow:var(--em-shadow);min-height:300px;}
.map-frame iframe{width:100%;height:100%;min-height:300px;border:0;display:block;filter:saturate(.95);}
.contact-photo-stack img{width:100%;height:220px;object-fit:cover;display:block;}

/* ============================================================================
   8c. MENU PAGE — distinctive online restaurant menu
   ============================================================================ */
#menu .section-header h2{font-size:clamp(30px,4vw,46px) !important;}
.menu-toolbar{
  max-width:1180px;margin:0 auto clamp(14px,2vw,22px) !important;
  display:flex;gap:12px;align-items:center;justify-content:space-between;flex-wrap:wrap;
}
.menu-search{
  position:relative;flex:1 1 260px;display:flex;align-items:center;gap:10px;
  background:var(--card) !important;border:1px solid var(--border) !important;
  border-radius:999px !important;padding:0 16px !important;min-height:46px;
}
.menu-search i{color:var(--em-gold);}
.menu-search input{
  flex:1;background:transparent !important;border:0 !important;outline:none;color:inherit !important;
  font-size:14px;min-height:44px;
}
.menu-toolbar-actions{display:flex;gap:8px;}
.menu-toolbar-actions .btn{padding:9px 14px !important;font-size:13px !important;}

.menu-layout{
  display:grid !important;gap:clamp(18px,2.6vw,30px) !important;
  grid-template-columns:1fr 340px !important;max-width:1180px;margin:0 auto !important;align-items:start;
}
.menu-categories{display:flex;flex-direction:column;gap:14px;}
.menu-category{
  border-radius:var(--em-radius) !important;overflow:hidden;
  background:var(--card) !important;border:1px solid var(--border) !important;
  box-shadow:var(--em-shadow) !important;
}
body.day-mode .menu-category{box-shadow:var(--em-shadow-soft) !important;}
.menu-category-toggle{
  width:100%;display:flex !important;align-items:center;justify-content:space-between;gap:12px;
  padding:16px 20px !important;background:transparent !important;border:0 !important;cursor:pointer;
  color:inherit !important;text-align:left;position:relative;
}
.menu-category-toggle::before{
  content:"";position:absolute;left:0;top:14px;bottom:14px;width:3px;border-radius:0 3px 3px 0;
  background:linear-gradient(var(--em-gold-deep),var(--em-gold));
}
.menu-category-title{
  font-family:"Cormorant Garamond",serif !important;font-size:24px !important;font-weight:700 !important;
}
.menu-category-meta{display:inline-flex;align-items:center;gap:12px;color:var(--text-muted);}
.menu-category-count{
  min-width:24px;height:24px;padding:0 7px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;
  background:rgba(203,168,119,.16);color:var(--em-gold);font-size:12px;font-weight:800;
}
.menu-category-toggle i{transition:transform .3s var(--em-ease);color:var(--em-gold);}
.menu-category-toggle[aria-expanded="true"] i{transform:rotate(180deg);}
.menu-category-body{padding:0 18px 12px !important;}
.menu-grid{display:flex !important;flex-direction:column;gap:0 !important;}
.menu-item{
  display:flex !important;align-items:center;justify-content:space-between;gap:14px;
  padding:13px 6px !important;border-bottom:1px dashed var(--border) !important;
}
.menu-item:last-child{border-bottom:0 !important;}
.menu-item-name{font-weight:600 !important;font-size:14.5px;line-height:1.4;}
.menu-item-actions{display:flex;align-items:center;gap:12px;flex:0 0 auto;}
.menu-item-price{
  color:var(--em-gold) !important;font-weight:800 !important;font-size:14px !important;white-space:nowrap;
}
.menu-add{
  padding:7px 14px !important;border-radius:10px !important;font-size:13px !important;
  border:1.5px solid var(--em-gold) !important;color:var(--em-gold) !important;background:transparent !important;
  transition:background .2s, color .2s, transform .15s var(--em-spring) !important;
}
.menu-add:hover{background:var(--em-gold) !important;color:#fff !important;transform:translateY(-1px);}
body.day-mode .menu-add:hover{color:#2b2114 !important;}

/* sticky order cart */
.menu-cart{
  position:sticky;top:84px;align-self:start;
  border-radius:var(--em-radius) !important;padding:20px !important;
  background:var(--card) !important;border:1px solid var(--border) !important;box-shadow:var(--em-shadow) !important;
}
.menu-cart h3{font-family:"Cormorant Garamond",serif !important;font-size:24px !important;font-weight:700 !important;margin-bottom:12px;}
.menu-cart-list{max-height:300px;overflow:auto;margin-bottom:12px;}
.menu-empty{color:var(--text-muted);font-size:13px;padding:14px 0;text-align:center;}
.menu-cart-total{
  display:flex;justify-content:space-between;align-items:center;
  padding:12px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-bottom:14px;
  font-size:15px;
}
.menu-cart-total strong{color:var(--em-gold);font-size:18px;}
.menu-cart-actions{display:flex;gap:8px;}
.menu-cart-actions .btn{flex:1;}
#menuWhatsBtn{background:#25d366 !important;color:#fff !important;border:0 !important;}
.menu-cart-note{font-size:11.5px;color:var(--text-muted);margin-top:10px;line-height:1.5;text-align:center;}
.menu-table-booking{margin-top:18px;padding-top:16px;border-top:1px solid var(--border);}
.menu-table-booking h4{font-family:"Cormorant Garamond",serif !important;font-size:19px !important;font-weight:700 !important;margin-bottom:4px;}
.menu-table-booking p{font-size:12.5px;color:var(--text-muted);margin-bottom:10px;}

/* ============================================================================
   8d. BOOKING PAGE — presentation only (no logic/markup names touched)
   ============================================================================ */
.booking-whatsapp-panel .booking-card{max-width:1080px;margin:0 auto;padding:clamp(20px,3vw,38px) !important;}
.booking-panel-head{text-align:center !important;justify-content:center !important;flex-direction:column !important;align-items:center !important;}
.booking-panel-head h2{font-family:"Cormorant Garamond",serif !important;font-size:clamp(28px,3.6vw,42px) !important;font-weight:700 !important;width:100%;text-align:center !important;}
.booking-panel-head p{color:var(--text-muted) !important;}
.booking-form .field-row{display:grid !important;grid-template-columns:1fr 1fr !important;gap:16px !important;margin-bottom:16px;}
.booking-form label{display:flex;flex-direction:column;gap:6px;}
.booking-form label > span{font-size:11px !important;font-weight:800 !important;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted) !important;}
.booking-form input,.booking-form select,.booking-form textarea{
  min-height:48px;border-radius:12px !important;padding:0 14px !important;
  background:var(--card-soft) !important;border:1px solid var(--border) !important;color:inherit !important;
  transition:border-color .15s, box-shadow .15s !important;
}
.booking-form textarea{padding:12px 14px !important;min-height:80px;}
.booking-form input:focus,.booking-form select:focus,.booking-form textarea:focus{
  border-color:var(--em-gold) !important;box-shadow:0 0 0 4px rgba(203,168,119,.16) !important;outline:none;
}

/* payment method -> icon buttons (built by JS from the hidden <select>) */
.em-hidden-select{display:none !important;}
.em-pay-options{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:8px;}
.em-pay-btn{
  display:flex;flex-direction:column;align-items:center;gap:8px;padding:15px 10px;cursor:pointer;
  border-radius:14px;border:1.5px solid var(--border);background:var(--card-soft);color:inherit;
  transition:border-color .2s, background .2s, transform .15s var(--em-spring), box-shadow .2s;
}
.em-pay-btn i{font-size:22px;color:var(--text-muted);transition:color .2s;}
.em-pay-btn span{font-size:12.5px;font-weight:700;}
.em-pay-btn:hover{transform:translateY(-2px);border-color:rgba(203,168,119,.5);}
.em-pay-btn.is-active{border-color:var(--em-gold);background:rgba(203,168,119,.14);box-shadow:0 0 0 3px rgba(203,168,119,.16);}
.em-pay-btn.is-active i{color:var(--em-gold);}

/* card / bank reveal panels */
#cardFieldsWrap,#bankTransferDetails{
  margin:12px 0 4px;padding:18px 20px;border-radius:var(--em-radius);
  background:rgba(203,168,119,.06) !important;border:1px solid rgba(203,168,119,.3) !important;
  animation:emPanelIn .3s var(--em-ease);
}
@keyframes emPanelIn{from{opacity:0;transform:translateY(-6px);}to{opacity:1;transform:none;}}
#cardFieldsWrap h4,#bankTransferDetails h4{font-family:"Cormorant Garamond",serif !important;font-size:20px !important;font-weight:700 !important;margin-bottom:10px;color:var(--em-gold) !important;}
.bank-details-list{list-style:none;margin:10px 0 0;padding:0;display:flex;flex-direction:column;gap:8px;font-size:13.5px;}
.bank-details-list li{display:flex;justify-content:space-between;gap:14px;border-bottom:1px dashed var(--border);padding-bottom:7px;}
.bank-details-list strong{color:var(--text-muted);font-weight:700;}
.field-info-note{font-size:12px;color:var(--text-muted) !important;line-height:1.55;margin-top:8px;}
.card-refundable-note{color:#c98b54 !important;font-weight:600;}

/* room picker cards + steppers — 2 per row, big clear photo on top */
.room-picker-grid{display:grid !important;grid-template-columns:repeat(2,minmax(0,1fr)) !important;gap:18px !important;margin-bottom:6px;}
.room-picker-card{
  border-radius:var(--em-radius) !important;overflow:hidden;padding:0 !important;
  display:flex !important;flex-direction:column !important;align-items:stretch !important;
  background:var(--card-soft) !important;border:1.5px solid var(--border) !important;
  transition:transform .2s var(--em-ease), border-color .2s, box-shadow .2s !important;
}
.room-picker-card:hover{border-color:rgba(203,168,119,.5) !important;box-shadow:var(--em-shadow) !important;}
.room-picker-card.is-selected,.room-picker-card[aria-selected="true"],.room-picker-card.selected{
  border-color:var(--em-gold) !important;box-shadow:0 0 0 3px rgba(203,168,119,.2) !important;
}
.room-picker-media{flex:0 0 auto !important;width:100% !important;height:200px !important;border-radius:0 !important;border:0 !important;overflow:hidden;}
.room-picker-media img{width:100% !important;height:200px !important;min-height:0 !important;object-fit:cover !important;display:block;}
.room-picker-info{padding:16px 18px !important;}
.room-picker-info h4{font-family:"Cormorant Garamond",serif !important;font-size:21px !important;font-weight:700 !important;}
.room-picker-price{color:var(--em-gold) !important;font-weight:800 !important;display:block;margin-top:2px;}
.room-picker-controls{display:flex;flex-direction:column;gap:10px;margin:14px 0 4px;}
.compact-counter{display:flex;align-items:center;justify-content:space-between;gap:10px;}
.compact-counter-label{display:inline-flex;align-items:center;gap:8px;font-size:13.5px;font-weight:700;}
.em-cc-ico{color:var(--em-gold);font-size:15px;}
.qty-control{display:inline-flex;align-items:center;gap:8px;}
.qty-control .qty-btn,.qty-control .guest-btn{
  width:34px;height:34px;border-radius:10px;border:1.5px solid var(--em-gold);background:transparent;color:var(--em-gold);
  font-size:18px;font-weight:700;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;
  transition:background .15s,color .15s,transform .12s var(--em-spring);
}
.qty-control .qty-btn:hover,.qty-control .guest-btn:hover{background:var(--em-gold);color:#fff;transform:translateY(-1px);}
body.day-mode .qty-control .qty-btn:hover,body.day-mode .qty-control .guest-btn:hover{color:#2b2114;}
.room-qty-input,.room-person-input{
  width:50px !important;min-height:34px !important;text-align:center;padding:0 !important;border-radius:9px !important;
  -moz-appearance:textfield;appearance:textfield;
}
.room-qty-input::-webkit-outer-spin-button,.room-qty-input::-webkit-inner-spin-button,
.room-person-input::-webkit-outer-spin-button,.room-person-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}
.room-line-total{display:flex;justify-content:space-between;align-items:center;margin-top:10px;padding-top:10px;border-top:1px dashed var(--border);font-size:13px;}
.room-line-total-value{color:var(--em-gold) !important;font-weight:800;}

/* breakfast toggle */
.em-breakfast{display:flex !important;align-items:center;gap:14px;margin:16px 0;padding:14px 16px;border:1px solid var(--border);border-radius:var(--em-radius);background:var(--card-soft);}
.em-bf-ico{flex:0 0 auto;width:46px;height:46px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;font-size:20px;background:rgba(203,168,119,.14);color:var(--em-gold);}
.em-bf-copy{flex:1;}
.em-bf-copy h4{font-family:"Cormorant Garamond",serif !important;font-size:19px !important;font-weight:700 !important;}
.em-bf-copy > p{font-size:12.5px;color:var(--text-muted);}
.em-bf-status{font-size:13px;font-weight:700;margin-top:3px;}
.em-bf-on{color:#3a9d5d;}
.em-bf-off{color:var(--text-muted);}
.em-breakfast:not(:has(#breakfastToggle:checked)) .em-bf-on{display:none;}
.em-breakfast:has(#breakfastToggle:checked) .em-bf-off{display:none;}
.breakfast-toggle{position:relative;display:inline-block;width:54px;height:30px;flex:0 0 auto;cursor:pointer;}
.breakfast-toggle input{position:absolute;opacity:0;width:100%;height:100%;margin:0;cursor:pointer;z-index:1;}
.breakfast-slider{position:absolute;inset:0;border-radius:999px;background:var(--border);transition:background .25s;}
.breakfast-slider::before{content:"";position:absolute;top:3px;left:3px;width:24px;height:24px;border-radius:50%;background:#fff;transition:transform .25s var(--em-spring);box-shadow:0 2px 5px rgba(0,0,0,.3);}
.breakfast-toggle input:checked + .breakfast-slider{background:linear-gradient(135deg,var(--em-gold-deep),var(--em-gold)) !important;}
.breakfast-toggle input:checked + .breakfast-slider::before{transform:translateX(24px);}

/* summary, stay info, price table */
.booking-summary{margin-top:18px;border-top:1px solid var(--border);padding-top:16px;display:flex !important;flex-direction:column !important;gap:12px !important;align-items:stretch !important;}
.booking-summary > *{width:100% !important;}
.em-price-table{margin:0 0 14px;border:1px solid var(--border);border-radius:14px;overflow:hidden;}
.em-price-row{display:grid;grid-template-columns:1fr auto auto;gap:14px;padding:10px 14px;font-size:13.5px;align-items:center;}
.em-price-row + .em-price-row{border-top:1px dashed var(--border);}
.em-price-row span:last-child{color:var(--em-gold);font-weight:800;text-align:right;min-width:84px;}
.em-price-row span:nth-child(2){color:var(--text-muted);text-align:center;}
.em-price-head{background:rgba(203,168,119,.1);font-weight:800;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);}
.em-price-head span:last-child{color:var(--text-muted) !important;}
.booking-total{display:flex;justify-content:space-between;align-items:center;font-size:16px;margin-top:6px;}
.booking-total strong,.booking-total .booking-total-value{color:var(--em-gold) !important;font-size:24px !important;}
.em-stay-info{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;margin-top:12px;padding:10px 16px;border-radius:999px;background:rgba(203,168,119,.12);color:var(--em-gold);font-weight:700;font-size:14px;}
.em-stay-info i{color:var(--em-gold);}
.em-stay-info .em-dot{opacity:.45;}
.booking-engine-note{color:var(--text-muted) !important;font-size:12.5px;margin-top:10px;text-align:center;}

/* notes — a clearly-labelled box */
.field-full{display:block !important;margin:16px 0 !important;padding:14px 16px !important;border:1px solid var(--border) !important;border-radius:14px !important;background:var(--card-soft) !important;}
.field-full > span{display:block;font-size:12px !important;font-weight:800 !important;letter-spacing:.06em;text-transform:uppercase;color:var(--em-gold) !important;margin-bottom:8px !important;}
.field-full textarea{background:var(--card) !important;border:1px solid var(--border) !important;width:100%;border-radius:10px !important;min-height:74px;}
.em-notes-hint{margin-top:8px;font-size:11.5px;color:var(--text-muted);opacity:.85;}

/* policies / terms — a clearly-clickable check + short text */
.booking-terms{display:flex;align-items:center;justify-content:center;gap:12px;font-size:13.5px;color:var(--text-muted);margin:18px auto;padding:10px 18px;border:1px solid var(--border);border-radius:999px;background:var(--card-soft);cursor:pointer;text-align:left;width:fit-content;max-width:100%;transition:border-color .2s, box-shadow .2s, background .2s;}
.booking-terms:hover{border-color:var(--em-gold);box-shadow:0 0 0 4px rgba(203,168,119,.1);}
.booking-terms input{appearance:none;-webkit-appearance:none;width:26px;height:26px;flex:0 0 auto;margin:0;border-radius:7px;border:2px solid var(--em-gold);background:rgba(203,168,119,.1);cursor:pointer;position:relative;transition:background .18s, transform .18s var(--em-spring), box-shadow .2s;}
.booking-terms:hover input{box-shadow:0 0 0 4px rgba(203,168,119,.18);transform:scale(1.05);}
.booking-terms input:checked{background:var(--em-gold);transform:scale(1.06);}
.booking-terms input:checked::after{content:"\2713";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#fff;font-size:15px;font-weight:900;animation:emTick .32s var(--em-spring);}
@keyframes emTick{0%{transform:scale(0) rotate(-18deg);opacity:0;}60%{transform:scale(1.35) rotate(6deg);}100%{transform:scale(1) rotate(0);opacity:1;}}
body.day-mode .booking-terms input:checked::after{color:#2b2114;}
.booking-terms span{max-width:none;}
.booking-terms a{color:var(--em-gold) !important;font-weight:700;}

/* submit */
.booking-form-help{color:var(--text-muted) !important;font-size:12.5px;text-align:center;margin-top:8px;}
.booking-actions{margin-top:14px;}
.booking-actions .btn{width:100%;min-height:54px;font-size:16px !important;}

/* ============================================================================
   9. RESPONSIVE / MOBILE — clean, no glitches
   ============================================================================ */
@media (max-width:880px){
  .footer-grid{grid-template-columns:1fr 1fr;}
}
@media (max-width:720px){
  .site-header{
    flex-wrap:nowrap !important;gap:8px !important;
    padding:7px 12px !important;
  }
  .site-logo-img{height:44px !important;}
  .header-right{gap:6px !important;}
  #headerBookBtn,.install-app-btn,.admin-mobile-link{display:none !important;} /* declutter; CTA is in hero + drawer */
  .hero-title{font-size:clamp(30px,8vw,44px) !important;}
  .room-grid,.room-grid-stacked{grid-template-columns:1fr !important;}
  .room-feature-list{grid-template-columns:1fr 1fr;}
  .contact-layout{grid-template-columns:1fr !important;}
  .menu-layout{grid-template-columns:1fr !important;}
  .menu-cart{position:static !important;order:-1;}
  .booking-form .field-row{grid-template-columns:1fr !important;}
  .room-picker-grid{grid-template-columns:1fr !important;}
  .booking-whatsapp-panel .booking-card{padding:18px !important;}
  .footer-grid{grid-template-columns:1fr;gap:26px;text-align:center;}
  .footer-col,.footer-list,.footer-list li{justify-content:center;}
  .footer-list li{justify-content:center;}
  .footer-bottom{flex-direction:column;align-items:center;text-align:center;gap:8px;}
}
@media (max-width:380px){
  .main-nav-list a{font-size:13px;}
}

/* ============================================================================
   10. REDUCED MOTION
   ============================================================================ */
@media (prefers-reduced-motion:reduce){
  html.em-js .site-logo-img{clip-path:none !important;animation:none !important;}
  html.em-js .em-reveal,html.em-js .em-stagger > *{opacity:1 !important;transform:none !important;transition:none !important;}
  .hero-slide{transition:opacity .4s ease !important;}
}
