/* =========================================================
   ICONIC STAY / MACH HOTEL — APPLE CLEAN PREMIUM THEME (FULL)
   Path: public/assets/css/theme.css
   Dark default + Light toggle
   Public site + Reception/Admin PMS (RX) — safe + scoped
   ========================================================= */

/* =========================
   THEME TOKENS (PUBLIC)
   ========================= */
:root{
  --bg:#0b0f14;
  --bg2:#070a0e;
  --soft:#0f1620;

  --card: rgba(255,255,255,.05);
  --card2: rgba(255,255,255,.08);
  --cardSolid:#101826;

  --border: rgba(255,255,255,.10);
  --border2: rgba(255,255,255,.14);

  --shadow-sm: 0 10px 28px rgba(0,0,0,.20);
  --shadow: 0 18px 60px rgba(0,0,0,.35);

  --text: rgba(255,255,255,.92);
  --text2: rgba(255,255,255,.78);
  --muted: rgba(255,255,255,.68);
  --muted2: rgba(255,255,255,.54);

  /* Apple-clean gold accent (subtle) */
  --gold:#caa24a;
  --gold2:#e1bd71;
  --btnTextDark:#141414;

  --inputBg: rgba(255,255,255,.07);
  --inputBorder: rgba(255,255,255,.14);
  --inputText: rgba(255,255,255,.92);

  --r-lg:22px;
  --r-md:16px;
  --r-sm:12px;
  --r-pill:999px;

  --focus: 0 0 0 .22rem rgba(202,162,74,.22);

  /* Hero image (can be overridden inline on .hero-lux via style="--hero-image:url('...')" ) */
  --hero-image: url("/images/hero/mach_front_view.webp");
}

/* LIGHT MODE */
html[data-theme="light"]{
  --bg:#ffffff;
  --bg2:#f6f7fb;
  --soft:#f2f4f8;

  --card: rgba(13,18,26,.03);
  --card2: rgba(13,18,26,.05);
  --cardSolid:#ffffff;

  --border: rgba(13,18,26,.10);
  --border2: rgba(13,18,26,.14);

  --shadow-sm: 0 10px 24px rgba(13,18,26,.10);
  --shadow: 0 16px 44px rgba(13,18,26,.10);

  --text: rgba(13,18,26,.92);
  --text2: rgba(13,18,26,.76);
  --muted: rgba(13,18,26,.62);
  --muted2: rgba(13,18,26,.48);

  --inputBg: rgba(13,18,26,.03);
  --inputBorder: rgba(13,18,26,.14);
  --inputText: rgba(13,18,26,.92);

  --focus: 0 0 0 .22rem rgba(202,162,74,.18);
}

/* =========================
   BASE (APPLE CLEAN)
   ========================= */
*{ font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; }

html, body{
  background: var(--bg);
  color: var(--text);
  max-width: 100%;
  overflow-x: hidden;
  height: 100%;
}

img, iframe{ max-width: 100%; }
a{ color: inherit; text-decoration: none; }
a:hover{ color: var(--gold); }

.text-muted{ color: var(--muted) !important; }
.text-white-75{ color: var(--muted) !important; }
.text-white-50{ color: var(--muted2) !important; }
html[data-theme="light"] .text-white{ color: var(--text) !important; }

:focus-visible{
  outline: none;
  box-shadow: var(--focus);
  border-radius: 12px;
}

@media (prefers-reduced-motion: reduce){
  *{ transition: none !important; animation: none !important; scroll-behavior: auto !important; }
}

/* Typography polish */
h1,h2,h3,h4,h5{ letter-spacing: -.02em; }
.lead{ color: var(--text2); }
.small, small{ color: var(--muted); }
.fw-semibold{ font-weight: 650 !important; }

/* Container rhythm (mobile first) */
.container{ padding-left: 18px; padding-right: 18px; }
@media (min-width: 992px){
  .container{ padding-left: 16px; padding-right: 16px; }
}

/* =========================
   PUBLIC BRAND (LOGO / DOT)
   ========================= */
.brand-logo{
  height: 36px;
  width: auto;
  border-radius: 12px;
  box-shadow: 0 10px 26px rgba(0,0,0,.18);
  display: block;
  opacity: .96;
}
@media (min-width: 992px){
  .brand-logo{ height: 38px; }
}

.brand-dot{
  width: 12px;
  height: 12px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--gold), var(--gold2));
  box-shadow: 0 12px 24px rgba(202,162,74,.30);
}

/* ===============================
   PREMIUM BRAND (Standalone Logo)
   =============================== */

/* ===== TRUE STANDALONE LOGO (NO RADIUS) ===== */

/* Make transparent logo feel tight (remove square-canvas vibe) */
.brand-logo{
  height: 36px;
  width: auto;

  border-radius: 12px; /* soft, luxury rounding */
  padding: 2px;        /* gives breathing room */
  background: transparent;

  transition: transform .18s ease, filter .18s ease;
}

/* Depth */
html[data-theme="dark"] .brand-logo{
  filter:
    drop-shadow(0 8px 18px rgba(0,0,0,.65));
}

html[data-theme="light"] .brand-logo{
  filter:
    drop-shadow(0 6px 14px rgba(0,0,0,.15));
}

.navbar-brand:hover .brand-logo{
  transform: translateY(-1px) scale(1.04);
}
/* 3D depth: dark mode */
html[data-theme="dark"] .brand-logo{
  filter:
    drop-shadow(0 10px 24px rgba(0,0,0,.75))
    drop-shadow(0 2px 6px rgba(0,0,0,.55))
    drop-shadow(0 0 12px rgba(225,189,113,.12));
}

/* 3D depth: light mode */
html[data-theme="light"] .brand-logo{
  filter:
    drop-shadow(0 10px 22px rgba(0,0,0,.18))
    drop-shadow(0 2px 5px rgba(0,0,0,.12));
}

.navbar-brand:hover .brand-logo{
  transform: translateY(-1px) scale(1.05);
}

/* =========================
   PUBLIC NAVBAR — FINAL POLISH
   ========================= */

/* Brand */
.brand-text{
  font-weight: 850;
  letter-spacing: -.02em;
}

/* Your logo is a dark/blue logo: in dark mode it becomes less visible.
   We fix visibility using a subtle glow + contrast pop (no ugly border). */
html[data-theme="dark"] .brand-logo{
  border-radius: 12px;         /* hotel-friendly */
  filter:
    drop-shadow(0 10px 22px rgba(0,0,0,.70))
    drop-shadow(0 2px 6px rgba(0,0,0,.55))
    drop-shadow(0 0 10px rgba(77,163,255,.22)); /* subtle blue lift */
  opacity: .98;
}

html[data-theme="light"] .brand-logo{
  border-radius: 12px;
  filter: drop-shadow(0 10px 18px rgba(0,0,0,.12));
  opacity: .98;
}

/* Logo contrast chip (works for transparent logos) */
.brand-logo-wrap{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:.28rem .55rem;
  border-radius:14px;
  background: rgba(255,255,255,.14);          /* gives logo contrast in dark mode */
  border: 1px solid rgba(255,255,255,.18);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
}

.brand-logo-img{
  height: 34px;
  width: auto;
  display:block;
}

/* Light mode: make it cleaner so it doesn't look “boxed” */
html[data-theme="light"] .brand-logo-wrap{
  background: rgba(255,255,255,.70);
  border-color: rgba(0,0,0,.06);
}

/* CTA sizing */
.nav-cta{
  height: 44px;
  padding: 0 14px;
  border-radius: 14px !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .35rem;
  font-weight: 900;
  white-space: nowrap;
}

/* On small screens, make CTA full width inside the collapsed menu */
@media (max-width: 991.98px){
  .nav-cta{
    width: 100%;
    justify-content: center;
  }
  .navbar-nav .nav-item.d-flex{
    flex-direction: column;
    align-items: stretch !important;
  }
}

/* =========================
   PREMIUM BURGER (rx-burger)
   ========================= */
.rx-burger{
  border: 1px solid rgba(255,255,255,.18) !important;
  border-radius: 14px;
  padding: .50rem .62rem;
  background: rgba(255,255,255,.06);
  width: 50px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease, background .16s ease;
}
html[data-theme="light"] .rx-burger{
  border-color: rgba(13,18,26,.14) !important;
  background: rgba(13,18,26,.04);
}
.rx-burger:hover{
  transform: translateY(-1px);
  border-color: rgba(202,162,74,.30) !important;
  box-shadow: 0 12px 26px rgba(0,0,0,.12);
}

/* Lines */
.rx-burger-lines{
  position: relative;
  width: 20px;
  height: 2px;
  background: rgba(255,255,255,.92);
  border-radius: 999px;
  display: inline-block;
  transition: transform .18s ease, background .18s ease;
}
.rx-burger-lines::before,
.rx-burger-lines::after{
  content:"";
  position: absolute;
  left: 0;
  width: 20px;
  height: 2px;
  background: rgba(255,255,255,.92);
  border-radius: 999px;
  transition: transform .18s ease, top .18s ease, opacity .18s ease;
}
.rx-burger-lines::before{ top: -6px; }
.rx-burger-lines::after{ top: 6px; }

html[data-theme="light"] .rx-burger-lines,
html[data-theme="light"] .rx-burger-lines::before,
html[data-theme="light"] .rx-burger-lines::after{
  background: rgba(13,18,26,.92);
}

/* Animate to X when expanded */
.rx-burger[aria-expanded="true"] .rx-burger-lines{
  background: transparent;
}
.rx-burger[aria-expanded="true"] .rx-burger-lines::before{
  top: 0;
  transform: rotate(45deg);
}
.rx-burger[aria-expanded="true"] .rx-burger-lines::after{
  top: 0;
  transform: rotate(-45deg);
}

/* ===============================
   NAV PILLS
   =============================== */

.nav-pill{
  border-radius: 999px;
  padding: .52rem .82rem !important;
  font-weight: 700;
  transition: background .15s ease, transform .15s ease;
}

html[data-theme="dark"] .nav-pill{
  color: rgba(255,255,255,.78) !important;
}
html[data-theme="dark"] .nav-pill:hover{
  background: rgba(255,255,255,.08);
  color: rgba(255,255,255,.95) !important;
  transform: translateY(-1px);
}
html[data-theme="dark"] .nav-pill.active{
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.14);
}

html[data-theme="light"] .nav-pill{
  color: rgba(13,18,26,.75) !important;
}
html[data-theme="light"] .nav-pill:hover{
  background: rgba(13,18,26,.06);
  transform: translateY(-1px);
}
html[data-theme="light"] .nav-pill.active{
  background: rgba(13,18,26,.08);
  border: 1px solid rgba(13,18,26,.12);
}



/* ===============================
   MOBILE COLLAPSE PANEL
   =============================== */

@media (max-width: 991.98px){
  #publicNav{
    margin-top:.75rem;
    padding:.85rem;
    border-radius:18px;
    background: rgba(16,24,38,.80);
    -webkit-backdrop-filter: blur(14px);
    backdrop-filter: blur(14px);
    border:1px solid rgba(255,255,255,.12);
    box-shadow:0 18px 60px rgba(0,0,0,.35);
  }

  html[data-theme="light"] #publicNav{
    background: rgba(255,255,255,.92);
    border-color: rgba(13,18,26,.12);
  }

  .nav-cta,
  .btn-icon{
    width:100%;
    justify-content:center;
  }
}

/* =========================
   NAVBAR — APPLE CLEAN GLASS
   ========================= */
.nav-glass,
.rx-nav{
  position: sticky;
  top: 0;
  z-index: 1030;
  -webkit-backdrop-filter: blur(16px) saturate(140%);
  backdrop-filter: blur(16px) saturate(140%);
  background: rgba(10,14,20,.62);
  border-bottom: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 10px 26px rgba(0,0,0,.18);
  padding: .55rem 0;
  transition: padding .22s cubic-bezier(.4,0,.2,1), background .22s ease, box-shadow .22s ease, border-color .22s ease;
}

html[data-theme="light"] .nav-glass,
html[data-theme="light"] .rx-nav{
  background: rgba(255,255,255,.82);
  border-bottom: 1px solid rgba(13,18,26,.10);
  box-shadow: 0 10px 24px rgba(0,0,0,.08);
}

/* Scrolled state (JS adds .nav-scrolled on scroll) */
.nav-scrolled{
  padding: .30rem 0 !important;
  background: rgba(10,14,20,.80) !important;
  border-bottom-color: rgba(255,255,255,.14) !important;
  box-shadow: 0 16px 42px rgba(0,0,0,.28);
}
html[data-theme="light"] .nav-scrolled{
  background: rgba(255,255,255,.92) !important;
  box-shadow: 0 16px 40px rgba(0,0,0,.10);
}

/* Public nav links */
.nav-glass .nav-link{
  position: relative;
  font-weight: 650;
  padding: .55rem .75rem !important;
  border-radius: 12px;
  color: rgba(255,255,255,.78) !important;
  transition: transform .16s ease, color .16s ease, background .16s ease, box-shadow .16s ease;
}
html[data-theme="light"] .nav-glass .nav-link{ color: rgba(13,18,26,.75) !important; }

.nav-glass .nav-link:hover{
  color: rgba(255,255,255,.95) !important;
  background: rgba(255,255,255,.06);
  transform: translateY(-1px);
  box-shadow: 0 10px 22px rgba(0,0,0,.14);
}
html[data-theme="light"] .nav-glass .nav-link:hover{
  color: rgba(13,18,26,.92) !important;
  background: rgba(13,18,26,.05);
  box-shadow: 0 10px 22px rgba(0,0,0,.08);
}

/* Subtle underline */
.nav-glass .nav-link::after{
  content:"";
  position:absolute;
  left: 14px;
  right: 14px;
  bottom: 8px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(202,162,74,0), rgba(202,162,74,.9), rgba(202,162,74,0));
  opacity: 0;
  transform: translateY(4px);
  transition: opacity .16s ease, transform .16s ease;
}
.nav-glass .nav-link:hover::after{ opacity: .9; transform: translateY(0); }

.nav-glass .nav-link.active{
  color: rgba(255,255,255,.96) !important;
  background: rgba(255,255,255,.08);
  box-shadow: inset 0 0 0 1px rgba(202,162,74,.18);
}
html[data-theme="light"] .nav-glass .nav-link.active{
  color: rgba(13,18,26,.96) !important;
  background: rgba(13,18,26,.06);
  box-shadow: inset 0 0 0 1px rgba(202,162,74,.20);
}
.nav-glass .nav-link.active::after{ opacity: 1; transform: translateY(0); }

/* Navbar toggler */
.navbar-toggler{
  border: 1px solid rgba(255,255,255,.18) !important;
  border-radius: 14px;
  padding: .48rem .60rem;
  background: rgba(255,255,255,.06);
  transition: transform .16s ease, box-shadow .16s ease, background .16s ease, border-color .16s ease;
}
html[data-theme="light"] .navbar-toggler{
  border-color: rgba(13,18,26,.14) !important;
  background: rgba(13,18,26,.04);
}
.navbar-toggler:hover{
  transform: translateY(-1px);
  border-color: rgba(202,162,74,.28) !important;
  box-shadow: 0 12px 26px rgba(0,0,0,.14);
}
.navbar-toggler-icon{ opacity: .9; }
html[data-theme="dark"] .navbar-toggler-icon{ filter: invert(1) brightness(2); }

/* =========================
   BUTTONS (APPLE CLEAN)
   ========================= */
.btn{ border-radius: var(--r-md) !important; }

.btn-gold{
  background: linear-gradient(135deg,var(--gold),var(--gold2));
  border: 0;
  color: var(--btnTextDark);
  font-weight: 850;
  letter-spacing: .2px;
  box-shadow: 0 14px 34px rgba(202,162,74,.22);
  transition: transform .16s ease, filter .16s ease, box-shadow .16s ease;
}
.btn-gold:hover{
  transform: translateY(-1px);
  filter: saturate(1.02);
  box-shadow: 0 18px 40px rgba(202,162,74,.26);
}

.btn-outline-light{ border-color: rgba(255,255,255,.92)!important; }
html[data-theme="light"] .btn-outline-light{
  border-color: rgba(13,18,26,.18) !important;
  color: rgba(13,18,26,.86) !important;
}

/* Premium small icon button */
.btn-icon{
  width: 44px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  padding: 0;
}

/* Thumb-friendly on mobile */
@media (max-width: 576px){
  .btn, .rx-action{ min-height: 44px; }
}

/* =========================
   HERO — APPLE CLEAN COVER (DYNAMIC)
   Use: <header class="hero-lux" style="--hero-image:url('...')">
   ========================= */
.hero-lux{
  min-height:72vh;
  display:flex;
  align-items:center;
  border-radius:0 0 28px 28px;
  overflow:hidden;
  position:relative;
  background-repeat:no-repeat;
  background-size:cover;
  background-position:center;
  background-image:
    radial-gradient(1200px 700px at 10% 0%, rgba(202,162,74,.16), transparent 60%),
    linear-gradient(180deg, rgba(0,0,0,.10), rgba(0,0,0,.70)), /* was .82 */
    var(--hero-image);
}

/* ✅ Crisp hero text (don’t force all children to .92) */
.hero-lux{ color: rgba(255,255,255,.96); }

/* ✅ Only secondary hero text is softer */
.hero-lux .text-muted,
.hero-lux .hero-muted{
  color: rgba(255,255,255,.78) !important;
}

/* ✅ Contrast boost */
.hero-lux h1,
.hero-lux p{
  text-shadow: 0 12px 30px rgba(0,0,0,.45);
}

/* HERO — keep as-is (your current block is fine) */

/* Optional: make hero facts crisp */
.hero-lux .hero-facts{ color: rgba(255,255,255,.86); }
.hero-lux .hero-facts i{ color: rgba(225,189,113,.95); }

html[data-theme="light"] .hero-lux{
  background-image:
    radial-gradient(1200px 700px at 10% 0%, rgba(202,162,74,.10), transparent 60%),
    linear-gradient(180deg, rgba(0,0,0,.06), rgba(0,0,0,.38)),
    var(--hero-image);
}

@media (max-width: 576px){
  .hero-lux{ min-height: 78vh; background-position: left 70% !important; }
}

/* Hero badge */
.badge-soft{
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  background: rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.12);
  border-radius:999px;
  padding:.52rem .78rem;
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
}
.text-gold{ color: var(--gold); }

/* =========================
   CARDS (APPLE CLEAN)
   ========================= */
.card,
.search-card,
.feature-card,
.room-card,
.glass-card{
  border-radius: var(--r-lg);
  border:1px solid var(--border);
  position:relative;
}

.search-card,
.room-card{
  background: var(--cardSolid);
  box-shadow: var(--shadow);
}

.feature-card{
  background: var(--card);
  box-shadow: var(--shadow-sm);
}

.glass-card{
  background: rgba(16,24,38,.55);
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
}

.search-card,
.feature-card,
.room-card,
.glass-card{
  overflow:hidden;
  transform: translateZ(0);
  will-change: transform;
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease, filter .16s ease;
}

/* Subtle premium sheen (not loud) */
.search-card::after,
.feature-card::after,
.room-card::after,
.glass-card::after{
  content:"";
  position:absolute;
  top:-50%;
  left:-60%;
  width: 70%;
  height: 170%;
  pointer-events:none;
  background: linear-gradient(120deg, transparent 0%, rgba(255,255,255,.10) 45%, transparent 75%);
  opacity: 0;
  transform: rotate(18deg);
  transition: opacity .16s ease, transform .45s ease;
}

@media (hover:hover) and (pointer:fine){
  .search-card:hover,
  .feature-card:hover,
  .glass-card:hover{
    transform: translateY(-3px);
    border-color: rgba(202,162,74,.22);
    box-shadow: 0 22px 64px rgba(0,0,0,.26);
    filter: saturate(1.01);
  }
  .room-card:hover{
    transform: translateY(-4px);
    border-color: rgba(202,162,74,.24);
    box-shadow: 0 26px 72px rgba(0,0,0,.28);
  }
  .search-card:hover::after,
  .feature-card:hover::after,
  .room-card:hover::after,
  .glass-card:hover::after{
    opacity: .80;
    transform: translateX(145%) rotate(18deg);
  }
}

/* Mobile static */
@media (max-width: 576px){
  .search-card, .feature-card, .room-card, .glass-card{
    border-color: rgba(202,162,74,.14);
    box-shadow: 0 14px 40px rgba(0,0,0,.22);
  }
  html[data-theme="light"] .search-card,
  html[data-theme="light"] .feature-card,
  html[data-theme="light"] .room-card,
  html[data-theme="light"] .glass-card{
    box-shadow: 0 14px 36px rgba(13,18,26,.10);
    border-color: rgba(13,18,26,.14);
  }
}

html[data-theme="light"] .search-card,
html[data-theme="light"] .feature-card,
html[data-theme="light"] .room-card,
html[data-theme="light"] .glass-card{
  border-color: rgba(13,18,26,.14);
}

/* Room card link behavior */
a.room-card{
  display:block;
  color: inherit;
}
a.room-card:hover{ color: inherit; }

.room-price{ color: var(--text) !important; }
html[data-theme="dark"] .room-price{ color: rgba(255,255,255,.92) !important; }

/* Room thumb supports blade var: style="--room-thumb:url('...')" */
.room-thumb{
  height:220px;
  border-bottom:1px solid var(--border);
  background:
    linear-gradient(180deg, rgba(0,0,0,.06), rgba(0,0,0,.62)),
    var(--room-thumb, url("/images/rooms/rooms.webp"));
  background-size: cover;
  background-position: center;
  transition: transform .6s ease;
  position: relative;
}
.room-card:hover .room-thumb{ transform: scale(1.03); }

/* =========================================
   Room badge styles (RoomType editable badge)
   Base = glass pill (already defined)
   ========================================= */

/* Make sure badge text looks crisp on images */
.room-badge{
  position:absolute;
  top:14px;
  left:14px;
  z-index: 5;           /* ✅ makes it sit above overlays */
  display:inline-flex;
  align-items:center;
  gap:.45rem;

  /* make it readable on any image */
  color: rgba(255,255,255,.96);
  text-shadow: 0 8px 22px rgba(0,0,0,.55);

  /* “premium glass” stronger */
  background: rgba(10,14,20,.62);
  -webkit-backdrop-filter: blur(16px);
  backdrop-filter: blur(16px);
  border: 1px solid rgba(255,255,255,.18);

  padding: .42rem .72rem;
  border-radius: 999px;
  font-weight: 850;
  font-size: .86rem;
  letter-spacing: .2px;
}

.room-badge--gold{
  border-color: rgba(225,189,113,.45) !important;
  background: rgba(225,189,113,.20) !important;
  color: rgba(255,255,255,.98) !important;
}

.room-badge--dark{
  border-color: rgba(255,255,255,.16) !important;
  background: rgba(10,14,20,.58) !important;
}

.room-badge--primary{
  border-color: rgba(99,102,241,.40) !important;
  background: rgba(99,102,241,.16) !important;
}

.room-badge--success{
  border-color: rgba(34,197,94,.35) !important;
  background: rgba(34,197,94,.14) !important;
}

.room-badge--warning{
  border-color: rgba(255,195,77,.35) !important;
  background: rgba(255,195,77,.14) !important;
}

.room-badge--danger{
  border-color: rgba(255,77,79,.30) !important;
  background: rgba(255,77,79,.14) !important;
}

.room-badge--info{
  border-color: rgba(56,189,248,.35) !important;
  background: rgba(56,189,248,.14) !important;
}

.room-badge--secondary{
  border-color: rgba(148,163,184,.30) !important;
  background: rgba(148,163,184,.12) !important;
}

.room-badge--light{
  border-color: rgba(255,255,255,.20) !important;
  background: rgba(255,255,255,.14) !important;
}
/* Slight icon sizing */
.room-badge i{
  font-size: .98em;
  opacity: .98;
}

/* Search urgency badges */
.room-badge--low{
  border-color: rgba(255,195,77,.35) !important;
  background: rgba(255,195,77,.14) !important;
}
.room-badge--sold{
  border-color: rgba(255,77,79,.30) !important;
  background: rgba(255,77,79,.14) !important;
}

/* Rooms list: a touch more premium spacing */
.room-card .fw-semibold{ font-size: 1.02rem; }
@media (min-width: 992px){
  .room-card .fw-semibold{ font-size: 1.08rem; }
}

/* Small premium pills + chips */
.pill-soft{
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  padding:.44rem .70rem;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.86);
  font-weight: 850;
  font-size: .80rem;
}
html[data-theme="light"] .pill-soft{
  border-color: rgba(13,18,26,.12);
  background: rgba(13,18,26,.03);
  color: rgba(13,18,26,.80);
}

.amenity-chip{
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  padding:.46rem .72rem;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.86);
  font-size: .86rem;
}
html[data-theme="light"] .amenity-chip{
  border-color: rgba(13,18,26,.12);
  background: rgba(13,18,26,.03);
  color: rgba(13,18,26,.82);
}

/* =========================
   INPUTS (PUBLIC) — FIX SELECT/DROPDOWN VISIBILITY
   ========================= */
.form-control,
.form-select{
  background: var(--inputBg) !important;
  border:1px solid var(--inputBorder) !important;
  color: var(--inputText) !important;
  border-radius: var(--r-md) !important;
  min-height: 44px;
}
.form-control::placeholder{ color: var(--muted2) !important; opacity: 1; }

html[data-theme="light"] .form-control,
html[data-theme="light"] .form-select{
  background:#fff !important;
}

/* Input group text fix (prevents ugly dark blocks) */
.input-group-text{
  background: rgba(255,255,255,.06) !important;
  border: 1px solid var(--inputBorder) !important;
  color: var(--muted) !important;
  border-radius: var(--r-md) !important;
}
html[data-theme="light"] .input-group-text{
  background: rgba(13,18,26,.03) !important;
}

/* Ensure select options readable */
html[data-theme="dark"] select option{
  background: #0f1620;
  color: rgba(255,255,255,.92);
}

html[data-theme="light"] select option{
  background: #0f1620;
  color: rgba(255,255,255,.92);
}

/* Focus */
.form-control:focus,
.form-select:focus,
textarea:focus{
  border-color: rgba(202,162,74,.55) !important;
  box-shadow: var(--focus) !important;
  background: var(--inputBg) !important;
}

/* =========================
   GALLERY
   ========================= */
.gallery-tile{
  border-radius:18px;
  overflow:hidden;
  border:1px solid var(--border);
  box-shadow: var(--shadow-sm);
  cursor:pointer;
}
.gallery-tile img{
  width:100%;
  height:160px;
  object-fit:cover;
  transition:transform .6s ease;
}
.gallery-tile:hover img{ transform:scale(1.06); }

.gallery-modal-img{
  width:100%;
  max-height:80vh;
  object-fit:contain;
  border-radius:16px;
}

/* =========================
   FOOTER (PUBLIC)
   ========================= */
.footer-dark{
  position: relative;
  background:
    radial-gradient(900px 420px at 15% -10%, rgba(225,189,113,.16), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,.02), rgba(0,0,0,.10));
  border-top: 1px solid rgba(255,255,255,.10);
}
html[data-theme="light"] .footer-dark{
  background:
    radial-gradient(900px 420px at 15% -10%, rgba(225,189,113,.10), transparent 55%),
    linear-gradient(180deg, #ffffff, #f6f7f9);
  border-top: 1px solid rgba(0,0,0,.08);
}

footer, .footer-dark{ margin-bottom: 0 !important; padding-bottom: 0; }

.footer-brand-name{ font-weight: 750; letter-spacing: .2px; color: #fff; }
html[data-theme="light"] .footer-brand-name{ color: #0b0f14; }

.footer-muted{ color: rgba(255,255,255,.62) !important; }
html[data-theme="light"] .footer-muted{ color: rgba(0,0,0,.60) !important; }

.footer-title{
  color: rgba(255,255,255,.92);
  font-weight: 700;
  font-size: .95rem;
  margin-bottom: .6rem;
  letter-spacing: .2px;
}
html[data-theme="light"] .footer-title{ color: #0b0f14; }

.footer-link{
  color: rgba(255,255,255,.70);
  transition: opacity .16s ease, transform .16s ease;
}
.footer-link:hover{
  color: rgba(255,255,255,.95);
  transform: translateY(-1px);
}
html[data-theme="light"] .footer-link{ color: rgba(0,0,0,.65); }
html[data-theme="light"] .footer-link:hover{ color: #0b0f14; }


/* =========================
   PUBLIC FOOTER — Premium, clean
   ========================= */
/* =========================
   PUBLIC FOOTER
   ========================= */
.pub-footer{
  border-top: 1px solid rgba(255,255,255,.10);
  background:
    radial-gradient(900px 500px at 20% 0%, rgba(202,162,74,.08), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.01));
}

html[data-theme="light"] .pub-footer{
  border-top-color: rgba(0,0,0,.08);
  background: linear-gradient(180deg, rgba(0,0,0,.02), rgba(0,0,0,.01));
}

.pub-footer-quote{
  color: rgba(255,255,255,.75);
  font-size: 1rem;
  line-height: 1.6;
}

html[data-theme="light"] .pub-footer-quote{
  color: rgba(0,0,0,.65);
}

.pub-footer-h{
  font-weight: 800;
  margin-bottom: .75rem;
  color: rgba(255,255,255,.92);
}

html[data-theme="light"] .pub-footer-h{
  color: rgba(0,0,0,.82);
}

.pub-footer-links{
  list-style:none;
  padding:0;
  margin:0;
  display:flex;
  flex-direction:column;
  gap:.5rem;
}

.pub-footer-links a,
.pub-link{
  color: rgba(255,255,255,.70);
  text-decoration:none;
}

.pub-footer-links a:hover,
.pub-link:hover{
  color: rgba(255,255,255,.92);
}

html[data-theme="light"] .pub-footer-links a,
html[data-theme="light"] .pub-link{
  color: rgba(0,0,0,.65);
}

html[data-theme="light"] .pub-footer-links a:hover,
html[data-theme="light"] .pub-link:hover{
  color: rgba(0,0,0,.90);
}

/* Footer social icons */
.footer-icon-link{
  width:44px;
  height:44px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:50%;
  font-size:1.1rem;

  background: rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  color: rgba(255,255,255,.85);

  transition: all .25s ease;
}

.footer-icon-link:hover{
  background: rgba(202,162,74,.18);
  border-color: rgba(202,162,74,.35);
  color: #fff;
  transform: translateY(-2px);
}

html[data-theme="light"] .footer-icon-link{
  background: rgba(0,0,0,.05);
  border-color: rgba(0,0,0,.08);
  color: rgba(0,0,0,.75);
}

html[data-theme="light"] .footer-icon-link:hover{
  background: rgba(202,162,74,.20);
  border-color: rgba(202,162,74,.35);
  color: #000;
}

.pub-footer-hr{
  opacity:.15;
}

.staff-link{
  opacity:.75;
  transition: opacity .2s ease;
}

.staff-link:hover{
  opacity:1;
}

/* =========================
   MOBILE STICKY BAR (PUBLIC)
   ========================= */
.mobile-sticky-bar{
  position:fixed;
  bottom:0;left:0;right:0;
  padding:.75rem 1rem;
  background: rgba(255,255,255,.96);
  border-top:1px solid rgba(0,0,0,.08);
  z-index:1050;
  margin: 0 !important;
}
html[data-theme="dark"] .mobile-sticky-bar{
  background: rgba(16,24,38,.92);
  border-top:1px solid rgba(255,255,255,.10);
}
@media(min-width:1200px){ .mobile-sticky-bar{ display:none; } }

body{ padding-bottom: 0 !important; }
body.has-stickybar{ padding-bottom: 84px !important; }

/* =========================
   BOOTSTRAP VISIBILITY FIXES (PUBLIC)
   ========================= */
html[data-theme="dark"]{
  --bs-body-color: rgba(255,255,255,.92);
  --bs-secondary-color: rgba(255,255,255,.68);
  --bs-border-color: rgba(255,255,255,.14);
  --bs-body-bg: #0b0f14;
}

/* Dropdown menus */
html[data-theme="dark"] .dropdown-menu{
  background: rgba(16,24,38,.98) !important;
  border-color: rgba(255,255,255,.14) !important;
  box-shadow: 0 18px 60px rgba(0,0,0,.35) !important;
  border-radius: 16px;
  overflow: hidden;
}
html[data-theme="dark"] .dropdown-item{ color: rgba(255,255,255,.90) !important; }
html[data-theme="dark"] .dropdown-item:hover,
html[data-theme="dark"] .dropdown-item:focus{
  background: rgba(255,255,255,.08) !important;
  color: rgba(255,255,255,.98) !important;
}
html[data-theme="dark"] .dropdown-divider{ border-color: rgba(255,255,255,.12) !important; }

/* Alerts */
.alert{
  border-radius: 16px !important;
  border: 1px solid var(--border) !important;
  box-shadow: var(--shadow-sm);
}
html[data-theme="dark"] .alert{
  background: rgba(255,255,255,.06) !important;
  color: rgba(255,255,255,.92) !important;
}
html[data-theme="dark"] .alert-success{ background: rgba(18,190,117,.14) !important; border-color: rgba(18,190,117,.28) !important; }
html[data-theme="dark"] .alert-danger{ background: rgba(255,77,79,.14) !important; border-color: rgba(255,77,79,.28) !important; }
html[data-theme="dark"] .alert-warning{ background: rgba(255,193,7,.16) !important; border-color: rgba(255,193,7,.30) !important; }
html[data-theme="dark"] .alert-info{ background: rgba(84,130,255,.14) !important; border-color: rgba(84,130,255,.28) !important; }

html[data-theme="light"] .alert{
  background: rgba(13,18,26,.04) !important;
  color: rgba(13,18,26,.92) !important;
  border-color: rgba(13,18,26,.12) !important;
}

/* Tables */
.table-responsive,
.table-premium-wrap{
  border-radius: 18px;
  overflow: hidden;
}

.table{
  color: var(--text) !important;
  border-color: var(--border) !important;
}
.table > :not(caption) > * > *{
  background-color: transparent !important;
  border-color: var(--border) !important;
  vertical-align: middle;
}
.table thead th{
  position: sticky;
  top: 0;
  z-index: 2;
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .10em;
  text-transform: uppercase;
  color: var(--text2) !important;
  background: rgba(16,24,38,.86) !important;
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--border) !important;
}
html[data-theme="light"] .table thead th{
  background: rgba(255,255,255,.92) !important;
  color: rgba(13,18,26,.72) !important;
}

.table-striped > tbody > tr:nth-of-type(odd){
  background: rgba(255,255,255,.03) !important;
}
html[data-theme="light"] .table-striped > tbody > tr:nth-of-type(odd){
  background: rgba(13,18,26,.02) !important;
}
.table-hover > tbody > tr:hover{
  background: rgba(202,162,74,.08) !important;
}
html[data-theme="light"] .table-hover > tbody > tr:hover{
  background: rgba(202,162,74,.10) !important;
}

/* Table shell */
.table-wrap,
.rx-table-card{
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid var(--border);
  background: var(--cardSolid);
  box-shadow: var(--shadow);
}
html[data-theme="light"] .table-wrap,
html[data-theme="light"] .rx-table-card{ background:#fff; }

/* Scrollbar */
.table-responsive,
.rx-table-responsive,
.table-scroll{
  position: relative;
  overflow-x: auto;
  overflow-y: hidden;
  max-width: 100%;
}
@supports (-webkit-overflow-scrolling: touch){
  .table-responsive,
  .rx-table-responsive,
  .table-scroll{ -webkit-overflow-scrolling: touch; }
}
.table,
.rx-table{ min-width: 820px; }
@media (min-width: 992px){
  .table,
  .rx-table{ min-width: 100%; }
}
.table-responsive::-webkit-scrollbar,
.rx-table-responsive::-webkit-scrollbar{ height: 10px; }
.table-responsive::-webkit-scrollbar-thumb,
.rx-table-responsive::-webkit-scrollbar-thumb{
  background: rgba(255,255,255,.16);
  border-radius: 999px;
}
html[data-theme="light"] .table-responsive::-webkit-scrollbar-thumb,
html[data-theme="light"] .rx-table-responsive::-webkit-scrollbar-thumb{
  background: rgba(13,18,26,.20);
}

/* Pagination */
.pagination svg{ width: 18px !important; height: 18px !important; }
.pagination{ align-items: center; gap: 6px; }
.pagination .page-link{
  background: var(--cardSolid);
  border: 1px solid var(--border);
  color: var(--text);
  min-width: 40px;
  text-align: center;
  border-radius: 12px;
}
.pagination .page-link:hover{
  color: var(--gold);
  background: rgba(202,162,74,.10);
}
.pagination .page-item.active .page-link{
  background: linear-gradient(135deg,var(--gold),var(--gold2)) !important;
  color: var(--btnTextDark) !important;
  border: none !important;
}

/* Toasts */
.toast{ color: rgba(255,255,255,.92); }
.toast-header{ color: rgba(255,255,255,.95); }
.toast-header small{ color: rgba(255,255,255,.65) !important; }
.toast .btn-close{ filter: invert(1); opacity: .8; }
.toast .btn-close:hover{ opacity: 1; }

/* Flatpickr */
.flatpickr-calendar{
  border: 1px solid var(--border);
  background: rgba(18, 23, 34, .98);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  box-shadow: 0 18px 60px rgba(0,0,0,.45);
  border-radius: 18px;
  overflow: hidden;
}
.flatpickr-months{ border-bottom: 1px solid var(--border); }
.flatpickr-current-month, .flatpickr-weekday, .flatpickr-day{ color: rgba(255,255,255,.92); }
.flatpickr-day:hover{ background: rgba(225,189,113,.16); border-color: rgba(225,189,113,.30); }
.flatpickr-day.selected, .flatpickr-day.startRange, .flatpickr-day.endRange{
  background: rgba(225,189,113,.30);
  border-color: rgba(225,189,113,.55);
  color: #fff;
}
.flatpickr-day.disabled{ opacity: .25; cursor: not-allowed; }
.flatpickr-time input, .flatpickr-time .flatpickr-am-pm{ color: rgba(255,255,255,.9); }

/* Intl-tel-input */
.iti{ width: 100%; }
.iti__country-list{
  background: var(--cardSolid);
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
}
.iti__country-name,
.iti__dial-code{ color: var(--text); }

/* Map shell */
/* =========================================================
   CONTACT PAGE — Card alignment + Map card behavior
   ========================================================= */

.contact-card{ height:100%; }

.map-shell{
  position:relative;
  height:100%;
  min-height:420px;              /* keeps map tall enough */
  border-radius:18px;
  overflow:hidden;               /* makes iframe obey radius */
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
}

.map-shell iframe,
.map-shell .map-frame{
  width:100%;
  height:100%;
  min-height:420px;
  display:block;
  border:0;
}

/* keep overlay above iframe */
.map-overlay{
  position:absolute;
  inset:12px 12px auto 12px;
  z-index:2;
  pointer-events:none;
}

.map-chip{
  display:inline-flex;
  align-items:center;
  gap:.35rem;
  padding:.45rem .7rem;
  border-radius:999px;
  background: rgba(0,0,0,.55);
  color: rgba(255,255,255,.92);
  border:1px solid rgba(255,255,255,.16);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
}

/* Mobile tuning */
@media (max-width: 991.98px){
  .map-shell,
  .map-shell iframe,
  .map-shell .map-frame{
    min-height:320px;
  }
}

/* =========================================================
   RX / PMS THEME — SCOPED (SAFE)
   Use: <body class="rx-shell"> for dashboards
   ========================================================= */
body.rx-shell{
  --rx-bg:#0b0f14;
  --rx-bg2:#070a0e;
  --rx-soft:#0f1620;

  --rx-card: rgba(255,255,255,.06);
  --rx-card2: rgba(255,255,255,.10);
  --rx-border: rgba(255,255,255,.10);
  --rx-border2: rgba(255,255,255,.14);

  --rx-text: rgba(255,255,255,.92);
  --rx-muted: rgba(255,255,255,.62);

  --rx-shadow: 0 16px 60px rgba(0,0,0,.35);
  --rx-shadow-sm: 0 10px 30px rgba(0,0,0,.22);

  --rx-accent:#4da3ff;
  --rx-accent2:#2b7cff;

  --rx-radius: 18px;
  --rx-radius-sm: 14px;

  background: radial-gradient(1200px 900px at 10% -10%, rgba(77,163,255,.16), transparent 60%),
              radial-gradient(900px 700px at 90% 10%, rgba(102,255,214,.08), transparent 60%),
              linear-gradient(180deg, var(--rx-bg), var(--rx-bg2));
  color: var(--rx-text);
  min-height: 100vh;
}

.rx-ambient{
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(700px 380px at 14% 6%, rgba(77,163,255,.10), transparent 60%),
    radial-gradient(700px 380px at 86% 12%, rgba(255,154,77,.06), transparent 60%);
  opacity: .9;
  z-index: 0;
}

.rx-fluid, .rx-mtop, .rx-aside, .rx-main, .rx-topbar-wrap, .rx-content-wrap{
  position: relative;
  z-index: 1;
}

.offcanvas.rx-offcanvas{
  position: fixed !important;
  top: 0; bottom: 0;
  z-index: 1050;
}

.rx-fluid{ min-height: 100vh; }
.rx-aside{
  min-height: 100vh;
  position: sticky;
  top: 0;
  padding: 16px;
  background: transparent;
}
.rx-main{
  min-height: 100vh;
  padding: 16px;
  display: flex;
  flex-direction: column;
}
.rx-content-wrap{
  flex: 1 1 auto;
  padding: 18px 14px 10px;
}
@media (min-width: 992px){
  .rx-content-wrap{ padding: 22px 22px 12px; }
}
.rx-container{ padding-bottom: 0 !important; }
.table-wrap{ margin-bottom: 0 !important; }

.rx-side{
  border-radius: 18px;
  padding: 14px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 16px 60px rgba(0,0,0,.35);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
}
.rx-side-head{ padding-bottom: 10px; border-bottom: 1px solid rgba(255,255,255,.08); }
.rx-side-foot{ border-top: 1px solid rgba(255,255,255,.08); padding-top: 12px; }

.rx-nav-title{
  color: rgba(255,255,255,.55);
  font-size: .75rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  margin: 14px 0 8px;
}
.rx-navlink{
  display:flex;
  align-items:center;
  gap:10px;
  border-radius: 14px;
  padding: 10px 10px;
  color: rgba(255,255,255,.82);
  border: 1px solid transparent;
  transition: background .12s ease, border-color .12s ease, transform .12s ease;
}
.rx-navlink i{ font-size: 1.05rem; width: 18px; text-align:center; opacity:.95; }
.rx-navlink:hover{
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.12);
  transform: translateY(-1px);
}
.rx-navlink.active{
  background: linear-gradient(135deg, rgba(77,163,255,.16), rgba(255,255,255,.06));
  border-color: rgba(77,163,255,.26);
  color:#fff;
}

.rx-logout{
  border-radius: 14px;
  padding: 10px 12px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.88);
}
.rx-logout:hover{
  border-color: rgba(255,77,113,.30);
  box-shadow: 0 0 0 5px rgba(255,77,113,.10);
}

.rx-mtop{
  background: rgba(11,15,20,.78);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(255,255,255,.08);
}

.rx-topbar{
  position: sticky;
  top: 0;
  z-index: 1040;
  padding: 14px 0;
  background: rgba(11,15,20,.82);
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(255,255,255,.08);
}

.rx-actions{
  display:flex;
  align-items:center;
  gap:.55rem !important;
  flex-wrap: nowrap;
  white-space: nowrap;
}
.rx-actions > .dropdown{ display:flex; }
@media (max-width: 576px){ .rx-actions{ gap:.4rem !important; } }

.rx-icon-btn{
  width: 38px;
  height: 38px;
  border-radius: 999px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.16);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,.92);
  transition: transform .16s ease, background .16s ease, border-color .16s ease, box-shadow .16s ease;
}
.rx-icon-btn:hover{
  transform: translateY(-1px);
  background: rgba(255,255,255,.10);
  border-color: rgba(77,163,255,.40);
  box-shadow: 0 12px 26px rgba(0,0,0,.18);
}

.rx-user-pill{
  max-width: 240px;
  padding: .48rem .78rem;
  border-radius: 999px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.18);
  color: rgba(255,255,255,.92);
  display: inline-flex;
  align-items: center;
  gap: .4rem;
}
.rx-user-name{
  display: inline-block;
  max-width: 140px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  vertical-align: bottom;
}

.rx-dd,
.rx-dropdown{
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(15,22,32,.95);
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
  box-shadow: 0 20px 70px rgba(0,0,0,.45);
}
.rx-dd .dropdown-item,
.rx-dropdown .dropdown-item{ color: rgba(255,255,255,.88); padding: .6rem .9rem; }
.rx-dd .dropdown-item:hover,
.rx-dropdown .dropdown-item:hover{ background: rgba(255,255,255,.08); color:#fff; }

.rx-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height: 22px;
  padding: 0 .55rem;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  font-weight: 900;
  font-size: .68rem;
  letter-spacing: .08em;
  line-height: 1;
  white-space: nowrap;
}
.rx-pill--blue{  border-color: rgba(77,163,255,.30);  background: rgba(77,163,255,.10); }
.rx-pill--red{   border-color: rgba(255,77,113,.28);  background: rgba(255,77,113,.10); }
.rx-pill--green{ border-color: rgba(87,255,187,.22);  background: rgba(87,255,187,.08); }
.rx-pill--amber{ border-color: rgba(255,195,77,.28);  background: rgba(255,195,77,.10); }
.rx-pill--gold{  border-color: rgba(255,215,128,.22); background: rgba(255,215,128,.10); }

.rx-action{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.35rem;
  height: 38px;
  padding: 0 .85rem;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.05);
  color: rgba(255,255,255,.90);
  font-weight: 850;
  font-size: .82rem;
  transition: transform .12s ease, box-shadow .16s ease, border-color .16s ease, background .16s ease;
}
.rx-action:hover{
  transform: translateY(-1px);
  border-color: rgba(77,163,255,.45);
  box-shadow: 0 0 0 5px rgba(77,163,255,.10);
  background: rgba(255,255,255,.08);
}
.rx-action--primary{ border-color: rgba(77,163,255,.30); background: rgba(77,163,255,.10); }
.rx-action--danger{ border-color: rgba(255,77,113,.28); background: rgba(255,77,113,.10); }
.rx-action--success{ border-color: rgba(87,255,187,.22); background: rgba(87,255,187,.08); }
.rx-action--muted{ opacity: .65; cursor: not-allowed; transform:none !important; box-shadow:none !important; }

.rx-unit{
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.10);
  padding: 10px 10px;
  transition: transform .12s ease, border-color .12s ease, background .12s ease;
  min-height: 86px;
}
.rx-unit:hover{
  transform: translateY(-2px);
  border-color: rgba(255,255,255,.18);
  background: rgba(255,255,255,.05);
}
.rx-unit-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 8px;
}
.rx-unit-no{
  font-weight: 900;
  letter-spacing: .3px;
  color: rgba(255,255,255,.95);
}
.rx-unit-pill{
  display:inline-flex;
  align-items:center;
  padding: .28rem .45rem;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.86);
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .06em;
}
.rx-unit-sub{ margin-top: 8px; color: rgba(255,255,255,.58); font-size: .82rem; }
.rx-unit-lock{ margin-top: 6px; color: rgba(255,255,255,.55); font-size: .80rem; }

.rx-unit--available{ box-shadow: inset 0 0 0 1px rgba(87,255,187,.08); }
.rx-unit--booked{    box-shadow: inset 0 0 0 1px rgba(77,163,255,.12); }
.rx-unit--occupied{  box-shadow: inset 0 0 0 1px rgba(255,77,113,.12); }
.rx-unit--oos{       box-shadow: inset 0 0 0 1px rgba(255,195,77,.12); }

.rx-unit--booked .rx-unit-pill{ border-color: rgba(77,163,255,.30); background: rgba(77,163,255,.10); }
.rx-unit--occupied .rx-unit-pill{ border-color: rgba(255,77,113,.28); background: rgba(255,77,113,.10); }
.rx-unit--oos .rx-unit-pill{ border-color: rgba(255,195,77,.28); background: rgba(255,195,77,.10); }
.rx-unit--available .rx-unit-pill{ border-color: rgba(87,255,187,.22); background: rgba(87,255,187,.08); }

body.rx-collapsed .rx-aside{
  width: 76px !important;
  flex: 0 0 76px !important;
  max-width: 76px !important;
}
body.rx-collapsed .rx-main{
  flex: 1 1 auto !important;
  max-width: calc(100% - 76px) !important;
}
body.rx-collapsed .rx-brand-text,
body.rx-collapsed .rx-nav-text,
body.rx-collapsed .rx-nav-section-title,
body.rx-collapsed .rx-foot-note,
body.rx-collapsed .rx-logout .rx-nav-text{ display:none !important; }
body.rx-collapsed .rx-navlink{ justify-content:center; padding:10px 6px; }
body.rx-collapsed .rx-logout{ padding: 10px 8px !important; }

.rx-footer{
  border-top: 1px solid rgba(255,255,255,.10);
  background: linear-gradient(to top, rgba(0,0,0,.25), rgba(0,0,0,.05));
  -webkit-backdrop-filter: blur(6px);
  backdrop-filter: blur(6px);
  padding: .6rem 0;
  font-size: .75rem;
  opacity: .78;
}
.rx-footer-link{
  color: rgba(255,255,255,.75);
  text-decoration: none;
}
.rx-footer-link:hover{ color: #fff; text-decoration: underline; }

/* Accent polish */
.page-item.active .page-link,
.list-group-item.active{
  border-color: rgba(202,162,74,.24) !important;
}
.badge.bg-primary,
.badge-gold,
.status-gold{
  background: linear-gradient(135deg,var(--gold),var(--gold2)) !important;
  color: var(--btnTextDark) !important;
  font-weight: 900;
  border: none;
}

/* Scrollbar accent */
@media (hover:hover){
  ::-webkit-scrollbar-thumb{
    background: linear-gradient(180deg,var(--gold),var(--gold2));
    border-radius: 999px;
  }
}

/* =========================
   Public shell helpers
   ========================= */
.public-shell{
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Setup banner (premium, not ugly alert) */
.setup-banner{
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.06);
  border-radius: 18px;
  padding: 14px 14px;
  box-shadow: 0 14px 40px rgba(0,0,0,.18);
}
html[data-theme="light"] .setup-banner{
  border: 1px solid rgba(15,20,30,.10);
  background: rgba(255,255,255,.85);
}

/* =========================
   FOOTER — premium content shell
   ========================= */
.footer-logo{
  height: 38px;
  width: auto;
  border-radius: 12px;
  box-shadow: 0 14px 40px rgba(0,0,0,.22);
  opacity: .96;
}

.footer-trust{
  display: grid;
  gap: .45rem;
  margin-top: .25rem;
}
.footer-trust-item{
  display:flex;
  align-items:center;
  gap:.55rem;
  color: rgba(255,255,255,.72);
  font-size: .92rem;
}
.footer-trust-item i{
  color: rgba(225,189,113,.92);
  opacity: .95;
}
html[data-theme="light"] .footer-trust-item{
  color: rgba(13,18,26,.66);
}

.footer-list li{ margin: .45rem 0; }

.footer-card{
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  box-shadow: 0 16px 60px rgba(0,0,0,.24);
}
html[data-theme="light"] .footer-card{
  background: rgba(255,255,255,.92);
  border-color: rgba(13,18,26,.10);
  box-shadow: 0 16px 44px rgba(13,18,26,.10);
}

/* Footer icon pills */
.icon-pill{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  padding: .55rem .75rem;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.92);
  box-shadow: 0 10px 28px rgba(0,0,0,.16);
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease, background .16s ease;
}
.icon-pill:hover{
  transform: translateY(-1px);
  border-color: rgba(202,162,74,.28);
  background: rgba(255,255,255,.08);
  color: rgba(255,255,255,.96);
}
html[data-theme="light"] .icon-pill{
  background: rgba(13,18,26,.03);
  border-color: rgba(13,18,26,.12);
  color: rgba(13,18,26,.86);
  box-shadow: 0 10px 24px rgba(13,18,26,.08);
}
html[data-theme="light"] .icon-pill:hover{
  background: rgba(13,18,26,.05);
  color: rgba(13,18,26,.92);
}

.icon-pill--wa{
  border-color: rgba(34,197,94,.28);
}
.icon-pill--wa:hover{
  border-color: rgba(34,197,94,.45);
}

/* Footer bottom */
.footer-bottom{
  display:flex;
  flex-wrap: wrap;
  gap: .75rem 1rem;
  justify-content: space-between;
  align-items: center;
}
.footer-quote{
  color: rgba(255,255,255,.70);
  font-size: .92rem;
}
html[data-theme="light"] .footer-quote{
  color: rgba(13,18,26,.60);
}
.footer-hr{
  border-color: rgba(255,255,255,.10) !important;
}
html[data-theme="light"] .footer-hr{
  border-color: rgba(13,18,26,.10) !important;
}
.dot-sep{ opacity: .55; padding: 0 .35rem; }