:root{
  /* === Booking Engine theme variables (defaults: Belle Époque) === */
  --bg:#f6f7fb;
  --panel:#ffffff;
  --text:#0f172a;
  --muted:#64748b;
  --line:rgba(15,23,42,.10);
  --shadow: 0 12px 28px rgba(2,6,23,.08);
  --radius: 18px;
  --radius2: 14px;

  /* Brand (override these per-hotel) */
  --brand-primary:#2956a0;          /* Belle Époque blue */
  --brand-primary-hover:#25558b;
  --brand-secondary:#c7dd7d;        /* showcase green */
  --brand-secondary-strong:#6b8b25; /* darker green (buttons/accents) */
  --brand-header:#2e2b2b;           /* dark header */
  --brand-on-primary:#ffffff;

  /* Backward-compat tokens used by the engine */
  --accent: var(--brand-primary);
  --accent-hover: var(--brand-primary-hover);
  --accent2: var(--brand-secondary-strong);
  --accent2-soft: var(--brand-secondary);
  --danger:#dc2626;
}

*{box-sizing:border-box}
body{
  margin:0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background:
    radial-gradient(900px 420px at 15% 0%, rgba(41,86,160,.18), transparent 60%),
    radial-gradient(900px 420px at 80% 10%, rgba(107,139,37,.14), transparent 60%),
    var(--bg);
  color:var(--text);
}
.wrap{max-width:1200px;margin:0 auto;padding:22px 14px 40px}
header{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:18px;}
h1{margin:0;font-size:22px}
.sub{color:var(--muted);font-size:13px;margin-top:6px}
.headerRight{display:flex;gap:10px;align-items:center;flex-wrap:wrap;}
.panel{background: var(--panel);border:1px solid var(--line);border-radius: var(--radius);box-shadow: var(--shadow);}
.chip{background: rgba(41,86,160,.08);border:1px solid rgba(41,86,160,.16);padding:8px 10px;border-radius:999px;font-size:12px;color:#3730a3;font-weight:700;}
.btn{border:0;background: linear-gradient(135deg, var(--accent), var(--accent-hover));color:white;padding:11px 14px;border-radius: 12px;cursor:pointer;font-weight:750;box-shadow: 0 10px 18px rgba(41,86,160,.20);transition: transform .06s ease;}
.btn:active{transform: translateY(1px)}
.btn.secondary{background: #fff;border:1px solid var(--line);box-shadow:none;font-weight:700;color:var(--text);}
.btn.success{background: linear-gradient(135deg, var(--accent2), #15803d);box-shadow: 0 10px 18px rgba(22,163,74,.16);}
.btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none;}
.field label{display:block;font-size:12px;color:var(--muted);margin:0 0 6px}
.field input, .field select{width:100%;background: #fff;border:1px solid var(--line);color:var(--text);padding:10px 10px;border-radius: 12px;outline:none;}
.field input:focus, .field select:focus{border-color: rgba(41,86,160,.35);box-shadow: 0 0 0 4px rgba(41,86,160,.10);}
.search{padding:14px;display:grid;grid-template-columns: 1.1fr 1.1fr .8fr auto;gap:10px;align-items:end;}
.content{margin-top:14px;display:grid;grid-template-columns: 1fr 360px;gap:14px}
@media (max-width: 980px){ .content{grid-template-columns:1fr} }
.left{padding:14px}
.right{padding:14px;position: sticky;top: 14px;align-self:start;height: fit-content;}
.sectionTitle{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-bottom:10px}
.sectionTitle h2{margin:0;font-size:16px}
.muted{color:var(--muted);font-size:13px}
.mt16{margin-top:16px}
.mt10{margin-top:10px}

.roomsSetup{display:grid;grid-template-columns: repeat(2, minmax(0,1fr));gap:12px;margin-top:10px}
@media (max-width: 860px){ .roomsSetup{grid-template-columns:1fr} }
.roomCard{border:1px solid var(--line);border-radius: var(--radius);background: #fff;padding:12px;}
.roomCardHead{display:flex;justify-content:space-between;gap:10px;align-items:center;flex-wrap:wrap}
.roomCardHead .t{font-weight:950}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px}
.childrenList{margin-top:10px;display:flex;flex-direction:column;gap:8px}
.childRow{display:grid;grid-template-columns: 1fr auto;gap:10px;align-items:center;border:1px solid var(--line);border-radius: 12px;padding:10px;background: rgba(2,6,23,.02);}
.childRow .lbl{font-size:12px;color:var(--muted)}
.tabs{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
.tab{padding:9px 10px;border-radius:999px;border:1px solid var(--line);background: #fff;cursor:pointer;font-weight:800;font-size:12px;color:var(--text);}
.tab[aria-selected="true"]{background: rgba(41,86,160,.10);border-color: rgba(41,86,160,.22);color:#3730a3;}

.roomList{display:flex;flex-direction:column;gap:12px;margin-top:12px}
.roomHCard{border:1px solid var(--line);border-radius: var(--radius);overflow:hidden;background:#fff;box-shadow: 0 10px 26px rgba(2,6,23,.06);}
.roomTop{display:grid;grid-template-columns: 320px 1fr 260px;gap:0;align-items:stretch;min-height: 210px;}
@media (max-width: 980px){
  .roomTop{grid-template-columns: 260px 1fr}
  .roomAside{grid-column: 1 / -1; border-left:0; border-top:1px solid var(--line);}
}
@media (max-width: 640px){
  .roomTop{grid-template-columns: 1fr}
  .roomMedia{border-right:0; border-bottom:1px solid var(--line);}
  .roomInfo{border-right:0}
}
.roomMedia{position:relative;background: rgba(2,6,23,.05);border-right:1px solid var(--line);min-height: 210px;}
.roomMedia img{width:100%;height:100%;object-fit:cover;display:block;}
.navBtn{position:absolute;top:50%;transform:translateY(-50%);border:1px solid var(--line);background: rgba(255,255,255,.85);color:var(--text);width:34px;height:34px;border-radius:999px;cursor:pointer;}
.navBtn.prev{left:10px}.navBtn.next{right:10px}
.badge{position:absolute;left:10px;bottom:10px;background: rgba(255,255,255,.88);border:1px solid var(--line);padding:6px 8px;border-radius:999px;font-size:12px;backdrop-filter: blur(6px);color: var(--muted);font-weight:700;}
.roomInfo{padding:12px;border-right:1px solid var(--line);display:flex;flex-direction:column;gap:10px;}
.roomName{font-size:16px;font-weight:950;margin:0}
.meta{color:var(--muted);font-size:12px;display:flex;gap:8px;flex-wrap:wrap}
.meta span{background: rgba(2,6,23,.03);border:1px solid var(--line);padding:6px 8px;border-radius:999px}
.amenities{display:flex;gap:8px;flex-wrap:wrap;color:var(--muted);font-size:12px;}
.amenities span{background: rgba(2,6,23,.03);border:1px solid var(--line);padding:6px 8px;border-radius:999px;}
.roomAside{padding:12px;display:flex;flex-direction:column;justify-content:space-between;gap:10px;background: rgba(2,6,23,.015);border-left:1px solid var(--line);}
.priceBlock .from{font-size:12px;color:var(--muted)}
.priceBlock .amt{font-size:24px;font-weight:950}
.priceBlock .per{font-size:12px;color:var(--muted);margin-left:4px}
.asideBtns{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.linkBtn{background: #fff;border:1px solid var(--line);color: var(--text);padding:9px 10px;border-radius: 12px;cursor:pointer;font-weight:850;}
.linkBtn.primary{background: linear-gradient(135deg, var(--accent2), #15803d);border:0;box-shadow: 0 10px 18px rgba(22,163,74,.14);color:white;}
.rates{display:none;border-top:1px solid var(--line);padding:12px;gap:10px;flex-direction:column;background:#fff;}
.rate{border:1px solid var(--line);background: rgba(2,6,23,.02);border-radius: var(--radius2);padding:10px;}
.rateTop{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;flex-wrap:wrap;}
.rateName{font-weight:950}
.rateSmall{color:var(--muted);font-size:12px;margin-top:4px;max-width:520px}
.ratePrice{text-align:right;min-width: 180px;}
.ratePrice .avg{font-size:18px;font-weight:950}
.ratePrice .lbl{font-size:12px;color:var(--muted)}
.rateBtns{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px;justify-content:flex-end}
.empty{margin-top:12px;padding:12px;border-radius: 12px;border:1px solid var(--line);background: rgba(2,6,23,.02);color:var(--muted);font-size:13px;}
.loading{padding:12px;color:var(--muted);font-size:13px;}
.err{padding:12px;color:#7f1d1d;font-size:13px;background: rgba(220,38,38,.10);border:1px solid rgba(220,38,38,.18);border-radius: 12px;}
.cartLine{display:flex;justify-content:space-between;gap:10px;padding:10px 0;border-top:1px solid var(--line);color:var(--muted);font-size:13px;}
.cartLine strong{color:var(--text)}
.cartItem{border:1px solid var(--line);background: rgba(2,6,23,.02);border-radius: var(--radius2);padding:10px;margin-top:10px;}
.cartItem .t{font-weight:950}
.cartItem .s{color:var(--muted);font-size:12px;margin-top:4px}
.total{display:flex;justify-content:space-between;align-items:flex-end;border-top:1px solid var(--line);margin-top:12px;padding-top:12px;}
.note{margin-top:10px;color:#7c2d12;font-size:12px;background: rgba(251,146,60,.10);border:1px solid rgba(251,146,60,.18);padding:10px;border-radius: 12px;}
.modalBackdrop{position:fixed;inset:0;background: rgba(2,6,23,.45);display:none;align-items:center;justify-content:center;padding:16px;z-index: 50;}
.modal{width:min(860px, 100%);max-height: calc(100vh - 32px);border-radius: var(--radius);border:1px solid var(--line);background: #fff;box-shadow: var(--shadow);overflow:hidden;display:flex;flex-direction:column;position:relative;}
.modalHead{padding:12px 14px;display:flex;align-items:center;justify-content:space-between;gap:10px;border-bottom:1px solid var(--line);flex: 0 0 auto;}
.modalHead .mt{font-weight:990}
.modalBody{padding:14px;overflow:auto;-webkit-overflow-scrolling: touch;flex: 1 1 auto;min-height: 0;}
.modalFooter{padding:12px 14px;border-top:1px solid var(--line);display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap;flex: 0 0 auto;}
.closeBtn{width:36px;height:36px;border-radius: 999px;border:1px solid var(--line);background: #fff;color:var(--text);cursor:pointer;font-size:16px;}
.breakdown{margin-top:10px;border-top:1px solid var(--line);padding-top:10px;color:var(--muted);font-size:13px;}
.breakdown ul{margin:8px 0 0;padding:0 0 0 16px;}
.breakdown li{margin:4px 0}
.formGrid{display:grid;grid-template-columns: 1fr 1fr;gap:10px}
@media (max-width: 720px){ .formGrid{grid-template-columns:1fr} }
.hr{height:1px;background: var(--line);margin:12px 0}
.inlineHint{color:var(--muted);font-size:12px;margin-top:6px}
.pillOk{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background: rgba(22,163,74,.10);border:1px solid rgba(22,163,74,.18);color:#166534;font-size:12px;font-weight:850;}
.pillWarn{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background: rgba(220,38,38,.10);border:1px solid rgba(220,38,38,.18);color:#7f1d1d;font-size:12px;font-weight:850;}
.pillInfo{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background: rgba(41,86,160,.10);border:1px solid rgba(41,86,160,.18);color:#3730a3;font-size:12px;font-weight:850;}

.busyOverlay{
  position:absolute;
  inset:0;
  background: rgba(255,255,255,.78);
  backdrop-filter: blur(2px);
  display:none;
  align-items:center;
  justify-content:center;
  z-index: 60;
}
.busyBox{
  display:flex;
  align-items:center;
  gap:12px;
  padding:12px 14px;
  border-radius: 14px;
  border:1px solid var(--line);
  background:#fff;
  box-shadow: var(--shadow);
  max-width: 520px;
}
.spinner{
  width:22px;height:22px;border-radius:999px;
  border:3px solid rgba(41,86,160,.18);
  border-top-color: rgba(41,86,160,.90);
  animation: spin .8s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
.busyTitle{font-weight:950}
.busySub{color:var(--muted);font-size:12px;margin-top:2px}


.chipSm{
  display:inline-block;
  padding:4px 8px;
  border-radius:999px;
  font-size:12px;
  background:#f2f2f2;
  margin:0 6px 6px 0;
}
.modalGallery{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:8px;
  margin-bottom:12px;
}
.modalGallery img{
  width:100%;
  height:90px;
  object-fit:cover;
  border-radius:8px;
}
.amenGroup{ margin-top:12px; }
.amenGroupTitle{ font-weight:700; margin-bottom:6px; }
.amenList{ margin:0; padding-left:18px; }


/* =======================================================================
   Booking.com-like room details modal layout helpers
   (JS adds these classes: rtDetailsGrid/Left/Right, amenTwoCols, rtDescription)
   ======================================================================= */

.rtNoScroll { overflow: hidden; }

.rtDetailsGrid{
  display:grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(280px, .85fr);
  gap: 22px;
  align-items:start;
  font-size: 12px;
}
.rtDetailsLeft{ min-width:0; }
.rtDetailsRight{
  min-width:0;
  padding-left: 6px;
}

@media (max-width: 980px){
  .rtDetailsGrid{ grid-template-columns: 1fr; }
  .rtDetailsRight{ padding-left:0; }
}

/* Description under gallery */
.rtDescription{
  margin-top: 10px;
  padding-top: 12px;
  border-top: 1px solid var(--line);
  color: var(--muted);
  font-size: 13px;
  line-height: 1.6;
}

/* Two columns amenities list (avoid mega scroll) */
.amenTwoCols{
  list-style:none;
  padding-left:0;
  margin: 0;
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  column-gap: 18px;
  row-gap: 6px;
}
@media (max-width: 560px){
  .amenTwoCols{ grid-template-columns: 1fr; }
}
.amenTwoCols li{
  display:flex;
  gap: 8px;
  align-items:flex-start;
  break-inside: avoid;
}
.amenTwoCols li::before{
  content:"✓";
  color: var(--accent2);
  font-weight: 700;
  line-height: 1.1;
  margin-top: 2px;
}

/* =======================================================================
   Multi-tenant theming
   - Default palette above is Belle Époque
   - For Albicia/Teracite (or any hotel), load a small CSS AFTER booking.css
     that only overrides variables, e.g.:

     :root{
       --brand-primary:#5e5e5e;
       --brand-primary-hover:#4b4b4b;
       --brand-secondary:#e9f2d0;
       --brand-secondary-strong:#cee094;
       --brand-header:#2e2b2b;
     }

   You can also scope overrides:
     body[data-hotel-theme="albicia"]{ ...variables... }
   ======================================================================= */

