/* Extracted page styles for booking.html to comply with CSP */
:root{
  --brand: #2aa6b8; /* sea-blue */
  --bg: #e9f8fa;
  --card: #ffffff;
  --text: #08323b;
  --muted: #5aa6ad;
  --radius: 12px;
  --container: 1100px;
}
*{box-sizing:border-box}
body{margin:0;font-family: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Noto Sans Thai", Arial; background:var(--bg); color:var(--text);} 
a{color:inherit;text-decoration:none}
/* Page-level header (avoid styling all <header> tags globally) */
.page-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:18px;background:linear-gradient(90deg, rgba(42,166,184,0.12), rgba(42,166,184,0.06));border-radius:var(--radius)}
.brand{display:flex;align-items:center;gap:12px}
.brand .logo{width:56px;height:56px;border-radius:8px;background:var(--brand);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:18px}
.brand h1{margin:0;font-size:18px}
nav{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
/* header alignment (match index) */
.header-right { display:flex; gap:12px; align-items:center }
#main-nav { display:flex; align-items:center; gap:10px }
#main-nav a { display:flex; align-items:center; height:38px }
nav a{padding:8px 12px;border-radius:10px;color:var(--text);font-weight:600}
nav a:hover{background:rgba(0,0,0,0.04)}
.lang-toggle{display:flex;gap:8px;align-items:center}
.lang-toggle button{padding:6px 12px;border-radius:8px;border:1px solid transparent;background:#fff;cursor:pointer;height:36px;line-height:1}
.lang-toggle button.active{background:var(--brand);color:#fff}
/* main margin-top is provided by shared-header.css using --space-section */
.card{background:var(--card);padding:12px;border-radius:12px;box-shadow:0 8px 20px rgba(3,50,59,0.04)}
.muted{color:var(--muted)}
.contact-inline{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
form.grid{display:grid;gap:12px}
@media(min-width:800px){ form.grid.cols-2{grid-template-columns:1fr 1fr} }
/* horizontal search bar layout */
.search-grid{grid-template-columns:1fr}
/* At small tablets/large phones, show two columns so Check-in/Check-out sit side-by-side */
@media(min-width:480px){
  .search-grid{grid-template-columns:1fr 1fr;align-items:end}
  .search-grid .actions{grid-column:1 / -1}
}
@media(min-width:720px){
  .search-grid{grid-template-columns:1fr 1fr 1fr 1fr auto;align-items:end}
  .search-grid .actions{grid-column:auto}
}
label{display:block;margin-bottom:6px;font-weight:600}
input,select,textarea{width:100%;padding:8px;border-radius:8px;border:1px solid #e6f6f7}
.btn{background:var(--brand);color:#fff;padding:8px 12px;border-radius:10px;border:none;cursor:pointer}
.room-row{transition:box-shadow 180ms, transform 120ms}
.room-row.room-selected{box-shadow:0 14px 30px rgba(3,50,59,0.08);transform:translateY(-4px);border-radius:10px}
footer{margin-top:26px;padding:18px;border-radius:var(--radius);background:linear-gradient(180deg, rgba(42,166,184,0.06), rgba(42,166,184,0.03))}
/* accessibility focus */
button:focus, a:focus, input:focus{outline:3px solid rgba(42,166,184,0.18);outline-offset:2px}

/* sticky search bar (inside content wrap, below shared header) */
.search-sticky{position:sticky;top:calc(var(--header-inner-height,72px) + 10px);z-index:5}

/* Responsive tweaks for room rows on Booking page */
@media(max-width:980px){
  .bdr-e{border-right:none}
}

/* New room card layout */
.room-card{display:grid;grid-template-columns:280px 1fr;gap:12px;padding:12px;border:1px solid #e6f6f7;border-radius:12px;background:#fff;transition:box-shadow 180ms, transform 120ms}
.room-card:hover{box-shadow:0 10px 22px rgba(3,50,59,0.06)}
.room-card.selected, .room-card.room-selected{box-shadow:0 14px 30px rgba(3,50,59,0.08);transform:translateY(-2px)}
.room-media img{width:100%;height:180px;object-fit:cover;border-radius:10px;display:block}
.room-media{position:relative}
/* Move badges above the image (non-overlay) */
.room-badges{position:static;left:auto;top:auto;display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:8px;z-index:auto}
/* Theme-aligned badge styles (chips) */
.badge{display:inline-flex;align-items:center;gap:6px;background:rgba(42,166,184,0.06);color:var(--text);padding:6px 12px;border-radius:999px;font-size:12px;font-weight:600;border:1px solid rgba(42,166,184,0.15);box-shadow:none}
.badge-roomname{background:#fff;border-color:rgba(42,166,184,0.28);color:var(--text);font-weight:700;font-size:16px}
.badge-size{background:rgba(42,166,184,0.10);border-color:rgba(42,166,184,0.22);color:var(--brand);font-weight:700}
.room-media .room-link{display:inline-block;margin-top:8px;color:var(--brand);font-weight:600;font-size:13px}
.room-body{display:flex;flex-direction:column;gap:8px}
.room-details{background:linear-gradient(180deg, rgba(42,166,184,0.06), rgba(42,166,184,0.03));border-radius:10px;padding:10px}
.amenities-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 14px;list-style:none;margin:0;padding:0;color:var(--muted)}
.amenities-grid li{display:flex;align-items:center;gap:8px}
.amen-icon{width:18px;height:18px;display:inline-block;border:1px solid #e0eef0;border-radius:4px;background:#fff}
.room-header{background:none;padding:0;border-radius:0}
.room-header strong{font-size:18px;display:block}
.room-header .muted{margin-top:4px}
.rate-table{display:flex;flex-direction:column;gap:10px;margin-top:8px}
/* Column dividers like Traveloka: remove grid gaps and rely on cell padding so lines are continuous */
.rate-header{display:grid;grid-template-columns:1.2fr 1fr auto;gap:0;align-items:center;padding:0;border-bottom:2px solid #e0f1f3;color:var(--text);font-weight:600;background:transparent;font-size:18px;line-height:1.4}
.rate-header .th{display:flex;align-items:center;background:rgba(42,166,184,0.06);padding:0 10px}
.rate-header .th strong{color:inherit;font-weight:600;font-size:inherit;line-height:inherit}
.rate-header .th:not(:last-child){border-right:1px solid #e6f6f7}
/* Rows with continuous column dividers */
.rate-row{display:grid;grid-template-columns:1.2fr 1fr auto;gap:0;align-items:center;padding:0;border:1px solid #e6f6f7;border-radius:10px;background:rgba(42,166,184,0.03)}
.rate-row > *{padding:10px}
.rate-row > :not(:last-child){border-right:1px solid #e6f6f7}
.rate-name{font-weight:600}
.rate-cta{display:flex;flex-direction:column;gap:8px;align-items:flex-end;min-width:150px}
.price{font-weight:700}

@media(max-width:800px){
  .room-card{grid-template-columns:1fr}
  .room-media img{height:200px}
  .room-badges{left:8px;top:8px}
  .badge{font-size:11px;padding:5px 8px}
  .rate-row{grid-template-columns:1fr;align-items:flex-start}
  .rate-header{grid-template-columns:1fr;}
  .rate-header .th{border-right:none;padding-right:0}
  .rate-row > :not(:last-child){border-right:none;padding-right:0}
  .rate-cta{flex-direction:row;align-items:center;justify-content:space-between;width:100%}
}

/* Ensure the header labels sit in the vertical middle of the header band on wider screens */
@media(min-width:801px){
  .rate-header{height:48px}
}

/* Room details modal (right-side panel) */
.modal[hidden]{display:none}
.modal{position:fixed;inset:0;z-index:50}
.modal-overlay{position:absolute;inset:0;background:rgba(0,0,0,0.45)}
.modal-panel{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:min(1000px, 96vw);max-height:90vh;background:#fff;border-radius:12px;box-shadow:0 20px 60px rgba(0,0,0,0.25);display:flex;flex-direction:column;overflow:hidden}
.modal-close{position:absolute;top:8px;right:8px;width:36px;height:36px;border-radius:999px;border:1px solid #e6f6f7;background:#fff;color:#333;cursor:pointer;font-size:20px;line-height:1}
.modal-content{display:grid;grid-template-columns:1.2fr 1fr;gap:16px;padding:16px;min-height:320px;max-height:90vh;overflow:hidden}
.modal-gallery{overflow:auto;border-right:1px solid #eef6f7;padding-right:10px}
.modal-gallery img{width:100%;border-radius:8px;margin-bottom:10px;display:block}
.modal-details{overflow:auto;padding-right:4px}
.modal-title{margin:0 0 8px 0;font-size:18px}
.modal-meta{color:var(--muted);margin-bottom:12px}
.modal-amenities ul{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:8px 14px}
.modal-cta{position:sticky;bottom:0;background:linear-gradient(180deg, rgba(255,255,255,0.86), #fff);padding:12px;border-top:1px solid #eef6f7;display:flex;justify-content:flex-end}
@media(max-width:900px){ .modal-content{grid-template-columns:1fr} .modal-gallery{border-right:none;padding-right:0} }

/* Tabs (Rooms | Beds) */
.tabs{display:flex;gap:6px;border-bottom:1px solid #e6f6f7}
.tabs .tab{background:#fff;border:1px solid #e6f6f7;border-bottom:none;padding:8px 12px;border-top-left-radius:10px;border-top-right-radius:10px;color:var(--text);cursor:pointer}
.tabs .tab.active{background:rgba(42,166,184,0.06);color:var(--text);font-weight:700;border-color:rgba(42,166,184,0.25)}
.tab-panel{padding-top:10px}
.hidden{display:none !important}
