/* ═══════════════════════════════════════════════════════════════
   Cam-Itinerary — Stay Detail (two-column card layout, Sambor)
   ═══════════════════════════════════════════════════════════════ */

.sd-page { max-width: 1200px; margin: 0 auto; padding: 20px 32px 72px; }

.sd-back {
  display: inline-flex; align-items: center; gap: 7px; text-decoration: none;
  font-size: 13.5px; font-weight: 700; color: var(--fg-2); padding: 8px 0; margin-bottom: 8px;
  transition: color var(--dur-base) var(--ease-out);
}
.sd-back:hover { color: var(--fg-1); }
.sd-back svg { width: 17px; height: 17px; }

.sd-grid { display: grid; grid-template-columns: minmax(0, 1fr); gap: 28px; align-items: start; max-width: 920px; }
.sd-content { min-width: 0; display: flex; flex-direction: column; gap: 20px; }

/* ─── Gallery ─── */
.sd-gallery {
  display: grid; grid-template-columns: repeat(4, 1fr); grid-template-rows: 1fr 1fr;
  gap: 8px; height: 380px; border-radius: var(--radius-xl); overflow: hidden;
}
.sd-gallery .g-cell { position: relative; cursor: pointer; overflow: hidden; background: var(--color-gray-100); }
.sd-gallery .g-cell:first-child { grid-column: 1 / 3; grid-row: 1 / 3; }
.sd-gallery .g-cell img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform var(--dur-base) var(--ease-out); }
.sd-gallery .g-cell:hover img { transform: scale(1.04); }
.sd-gallery .g-more {
  position: absolute; inset: 0; background: rgba(15,26,23,0.52); color: white;
  display: flex; align-items: center; justify-content: center; gap: 8px;
  font-size: 13px; font-weight: 700; -webkit-backdrop-filter: blur(1px); backdrop-filter: blur(1px);
}
.sd-gallery .g-more svg { width: 17px; height: 17px; stroke-width: 2; }

/* ─── Title block ─── */
.sd-head { display: flex; flex-direction: column; gap: 10px; }
.sd-head-top { display: flex; align-items: center; justify-content: space-between; gap: 14px; }
.sd-loc { display: inline-flex; align-items: center; gap: 6px; font-size: 13.5px; font-weight: 600; color: var(--fg-2); }
.sd-loc svg { width: 15px; height: 15px; color: var(--color-forest-500); }
.sd-save {
  width: 40px; height: 40px; border-radius: 999px; flex-shrink: 0; cursor: pointer;
  background: var(--color-gray-50); border: 1px solid var(--color-gray-200); color: var(--fg-2);
  display: grid; place-items: center; transition: all var(--dur-base) var(--ease-out);
}
.sd-save:hover { background: var(--color-gray-100); color: var(--color-danger); }
.sd-save.on { color: var(--color-danger); }
.sd-save.on svg { fill: var(--color-danger); }
.sd-save svg { width: 19px; height: 19px; }
.sd-head h1 { font-family: var(--font-display); font-weight: 800; font-size: clamp(26px, 3.2vw, 34px); letter-spacing: -0.02em; line-height: 1.08; margin: 0; color: var(--fg-1); }
.sd-chips { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.sd-chip {
  display: inline-flex; align-items: center; gap: 6px; font-size: 12.5px; font-weight: 700;
  padding: 6px 12px; border-radius: var(--radius-full); background: var(--bg-sunken); color: var(--fg-1);
}
.sd-chip.type { background: var(--color-forest-50); color: var(--color-forest-700); }
.sd-chip.rating { background: var(--color-forest-500); color: white; }
.sd-chip.rating svg { width: 13px; height: 13px; fill: var(--color-amber-300); stroke: none; }
.sd-chip.muted { background: transparent; color: var(--fg-3); padding-left: 2px; }

/* ─── Cards ─── */
.sd-card { background: white; border-radius: var(--radius-xl); box-shadow: var(--shadow-1); padding: 24px 26px; }
.sd-card > h2 { font-family: var(--font-display); font-weight: 800; font-size: 20px; letter-spacing: -0.01em; margin: 0 0 14px; color: var(--fg-1); }
.sd-card-head { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; margin-bottom: 16px; }
.sd-card-head h2 { font-family: var(--font-display); font-weight: 800; font-size: 20px; letter-spacing: -0.01em; margin: 0; color: var(--fg-1); }
.sd-card-meta { font-size: 13px; color: var(--fg-3); font-weight: 600; }
.sd-lead { font-size: 14.5px; line-height: 1.65; color: var(--fg-1); margin: 0; }

/* About highlights */
.sd-highlights { display: grid; grid-template-columns: 1fr 1fr; gap: 12px 22px; margin-top: 18px; }
.sd-hl { display: flex; align-items: flex-start; gap: 10px; font-size: 13.5px; color: var(--fg-1); line-height: 1.4; }
.sd-hl .hl-ic { width: 30px; height: 30px; border-radius: var(--radius-md); flex-shrink: 0; background: var(--color-forest-50); color: var(--color-forest-600); display: grid; place-items: center; }
.sd-hl .hl-ic svg { width: 16px; height: 16px; stroke-width: 2; }
.sd-hl .hl-t { font-weight: 700; }
.sd-hl .hl-s { color: var(--fg-3); font-size: 12.5px; margin-top: 1px; }

/* ─── Amenities ─── */
.amen-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px 18px; }
.amen { display: flex; align-items: center; gap: 11px; font-size: 13.5px; font-weight: 600; color: var(--fg-1); }
.amen .a-ic { width: 34px; height: 34px; border-radius: var(--radius-md); flex-shrink: 0; background: var(--bg-sunken); color: var(--color-forest-600); display: grid; place-items: center; }
.amen .a-ic svg { width: 18px; height: 18px; stroke-width: 1.85; }

/* ─── Rooms & rates ─── */
.rr-filter { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; margin: 0 0 16px; }
.rr-filter .rrf-lbl { font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: var(--tracking-caps); color: var(--fg-3); margin-right: 4px; }
.rr-filter .rrf-chip {
  display: inline-flex; align-items: center; gap: 7px; font-family: var(--font-body);
  font-size: 13px; font-weight: 700; color: var(--fg-2);
  background: var(--color-white); border: 1px solid var(--color-gray-200); border-radius: var(--radius-full);
  padding: 7px 14px; cursor: pointer; transition: all var(--dur-base) var(--ease-out);
}
.rr-filter .rrf-chip:hover { border-color: var(--color-forest-300); color: var(--color-forest-700); }
.rr-filter .rrf-chip .rrf-n { font-size: 11px; font-weight: 800; color: var(--fg-3); background: var(--bg-sunken); border-radius: var(--radius-full); padding: 1px 7px; min-width: 18px; text-align: center; }
.rr-filter .rrf-chip.on { background: var(--color-forest-500); border-color: var(--color-forest-500); color: var(--fg-on-forest); }
.rr-filter .rrf-chip.on .rrf-n { background: rgba(255,255,255,0.22); color: var(--fg-on-forest); }
.room-rows { display: flex; flex-direction: column; gap: 14px; }
.room-row {
  display: grid; grid-template-columns: 132px 1fr auto; gap: 18px; align-items: stretch;
  border: 1px solid var(--color-gray-200); border-radius: var(--radius-lg); padding: 14px; background: white;
  transition: box-shadow var(--dur-base) var(--ease-out), border-color var(--dur-base) var(--ease-out);
}
.room-row:hover { box-shadow: var(--shadow-1); border-color: var(--color-gray-300); }
.room-row .rr-thumb { width: 132px; height: 100%; min-height: 108px; border-radius: var(--radius-md); background-size: cover; background-position: center; background-color: var(--color-gray-100); position: relative; }
.room-row .rr-thumb .rr-photos { position: absolute; bottom: 6px; left: 6px; display: inline-flex; align-items: center; gap: 4px; background: rgba(15,26,23,0.6); color: white; font-size: 10.5px; font-weight: 600; padding: 3px 7px; border-radius: var(--radius-full); }
.room-row .rr-thumb .rr-photos svg { width: 11px; height: 11px; stroke-width: 2; }
.room-row .rr-info { min-width: 0; display: flex; flex-direction: column; }
.room-row .rr-name { font-family: var(--font-display); font-weight: 800; font-size: 16px; color: var(--fg-1); line-height: 1.2; text-decoration: none; }
.room-row .rr-name:hover { color: var(--color-cobalt-700); }
.room-row .rr-facts { display: flex; flex-wrap: wrap; gap: 8px 14px; font-size: 12.5px; color: var(--fg-2); margin-top: 7px; }
.room-row .rr-facts .f { display: inline-flex; align-items: center; gap: 5px; }
.room-row .rr-facts svg { width: 14px; height: 14px; color: var(--fg-3); stroke-width: 1.9; }
.room-row .rr-perks { display: flex; flex-wrap: wrap; gap: 6px; margin-top: auto; padding-top: 10px; }
.room-row .rr-perk { display: inline-flex; align-items: center; gap: 5px; font-size: 11.5px; font-weight: 600; color: var(--color-forest-700); background: var(--color-forest-50); border-radius: var(--radius-full); padding: 4px 9px; }
.room-row .rr-perk svg { width: 11px; height: 11px; stroke-width: 2.6; }
.room-row .rr-avail { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 700; color: var(--color-forest-600); margin-top: 10px; }
.room-row .rr-avail svg { width: 14px; height: 14px; stroke-width: 2; flex-shrink: 0; }
.room-row .rr-avail.low { color: var(--color-warning); }
.room-row .rr-right { display: flex; flex-direction: column; align-items: flex-end; justify-content: space-between; gap: 10px; text-align: right; min-width: 138px; padding-left: 14px; border-left: 1px solid var(--color-gray-100); }
.room-row .rr-price { display: flex; flex-direction: column; align-items: flex-end; }
.room-row .rr-price .amt { font-family: var(--font-display); font-weight: 800; font-size: 22px; color: var(--fg-1); letter-spacing: -0.01em; line-height: 1; }
.room-row .rr-price .per { font-size: 11.5px; color: var(--fg-3); margin-top: 3px; }
.room-row .rr-price .tax { font-size: 10.5px; color: var(--fg-3); margin-top: 2px; }
.room-row .rr-qty { display: inline-flex; align-items: center; gap: 2px; background: var(--bg-sunken); border-radius: var(--radius-md); padding: 3px; }
.room-row .rr-qty .qbtn { width: 30px; height: 30px; border: 0; background: white; border-radius: var(--radius-sm); color: var(--fg-1); cursor: pointer; display: grid; place-items: center; box-shadow: var(--shadow-0); transition: background var(--dur-base) var(--ease-out); }
.room-row .rr-qty .qbtn:hover:not(:disabled) { background: var(--color-forest-50); color: var(--color-forest-700); }
.room-row .rr-qty .qbtn:disabled { opacity: 0.4; cursor: not-allowed; background: transparent; box-shadow: none; }
.room-row .rr-qty .qbtn svg { width: 15px; height: 15px; stroke-width: 2.4; }
.room-row .rr-qty .qval { min-width: 26px; text-align: center; font-weight: 800; font-size: 15px; color: var(--fg-1); }
.room-row .rr-select {
  display: inline-flex; align-items: center; justify-content: center; gap: 6px; width: 100%;
  padding: 10px 16px; border-radius: var(--radius-md); text-decoration: none;
  background: var(--color-forest-500); color: white; font-weight: 700; font-size: 13.5px;
  box-shadow: var(--shadow-brand); transition: background var(--dur-base) var(--ease-out);
}
.room-row .rr-select:hover { background: var(--color-forest-600); }
.room-row .rr-select.disabled { background: var(--color-gray-200); color: var(--fg-3); box-shadow: none; pointer-events: none; cursor: default; }
.room-row .rr-select svg { width: 14px; height: 14px; stroke-width: 2.4; }

/* ─── Rooms cart bar (shared selection + Reserve) ─── */
.rr-cart {
  display: flex; align-items: center; justify-content: space-between; gap: 18px;
  margin-top: 16px; padding: 16px 20px;
  background: white; border: 1px solid var(--color-gray-200); border-radius: var(--radius-lg);
  box-shadow: var(--shadow-1);
  position: sticky; bottom: 16px; z-index: 5;
  transition: border-color var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out);
}
.rr-cart:not(.empty) { border-color: var(--color-forest-200); box-shadow: var(--shadow-2); }
.rr-cart .rc-left { min-width: 0; }
.rr-cart .rc-rooms { font-family: var(--font-display); font-weight: 800; font-size: 16px; color: var(--fg-1); line-height: 1.2; }
.rr-cart .rc-rooms strong { color: var(--color-forest-600); }
.rr-cart .rc-sub { font-size: 12.5px; color: var(--fg-3); margin-top: 3px; }
.rr-cart .rc-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px; flex-shrink: 0;
  padding: 12px 24px; border-radius: var(--radius-md); text-decoration: none;
  font-family: var(--font-body); font-weight: 700; font-size: 14px;
  background: var(--color-forest-500); color: var(--fg-on-forest);
  box-shadow: var(--shadow-brand); transition: background var(--dur-base) var(--ease-out);
}
.rr-cart .rc-btn:hover { background: var(--color-forest-600); }
.rr-cart .rc-btn.disabled { background: var(--color-gray-200); color: var(--fg-3); box-shadow: none; pointer-events: none; cursor: default; }
.rr-cart .rc-btn svg { width: 15px; height: 15px; stroke-width: 2.4; }

/* ─── Property policies ─── */
.policy-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px 22px; }
.policy { display: flex; align-items: flex-start; gap: 12px; }
.policy .p-ic { width: 38px; height: 38px; border-radius: var(--radius-md); flex-shrink: 0; background: var(--bg-sunken); color: var(--color-forest-600); display: grid; place-items: center; }
.policy .p-ic svg { width: 19px; height: 19px; stroke-width: 1.85; }
.policy .p-k { font-size: 13.5px; font-weight: 700; color: var(--fg-1); line-height: 1.2; }
.policy .p-v { font-size: 12.5px; color: var(--fg-2); margin-top: 3px; line-height: 1.4; }

/* ═══ Sticky reserve column ═══ */
.sd-aside { position: sticky; top: 84px; display: flex; flex-direction: column; gap: 16px; }

.sd-reserve { background: white; border-radius: var(--radius-xl); box-shadow: var(--shadow-2); border: 1px solid var(--color-gray-100); padding: 22px; }
.sd-reserve-eyebrow { font-family: var(--font-sub); font-weight: 300; font-size: 12px; text-transform: uppercase; letter-spacing: var(--tracking-caps); color: var(--fg-3); margin-bottom: 12px; }
.sd-reserve-top { display: flex; align-items: flex-end; justify-content: space-between; gap: 12px; padding-bottom: 18px; border-bottom: 1px solid var(--color-gray-100); }
.sd-reserve-price { display: flex; align-items: baseline; gap: 7px; }
.sd-reserve-price .amt { font-family: var(--font-display); font-weight: 800; font-size: 30px; color: var(--fg-1); letter-spacing: -0.02em; }
.sd-reserve-price .per { font-size: 13px; color: var(--fg-3); }
.sd-reserve-rate { display: inline-flex; align-items: center; gap: 5px; font-weight: 800; font-size: 15px; color: var(--fg-1); }
.sd-reserve-rate svg { width: 16px; height: 16px; fill: var(--color-amber-500); }

.sd-reserve-fields { margin: 16px 0; display: flex; flex-direction: column; gap: 10px; }
.rf-row { display: grid; gap: 10px; }
.rf-row.two { grid-template-columns: 1fr 1fr; }
.rf { border: 1px solid var(--color-gray-200); border-radius: var(--radius-md); padding: 9px 13px; display: flex; flex-direction: column; gap: 2px; cursor: pointer; transition: border-color var(--dur-base) var(--ease-out); }
.rf:hover { border-color: var(--color-forest-300); }
.rf .rf-k { font-size: 10.5px; text-transform: uppercase; letter-spacing: 0.05em; font-weight: 700; color: var(--fg-3); }
.rf .rf-v { font-size: 13.5px; font-weight: 700; color: var(--fg-1); }

.sd-book-btn {
  display: flex; align-items: center; justify-content: center; gap: 8px; width: 100%;
  padding: 14px; border-radius: var(--radius-md); text-decoration: none;
  background: var(--color-forest-500); color: white; font-weight: 800; font-size: 15px;
  box-shadow: var(--shadow-brand); transition: background var(--dur-base) var(--ease-out);
}
.sd-book-btn:hover { background: var(--color-forest-600); }
.sd-contact-btn {
  display: flex; align-items: center; justify-content: center; gap: 8px; width: 100%; margin-top: 9px;
  padding: 12px; border-radius: var(--radius-md); text-decoration: none;
  background: white; border: 1px solid var(--color-gray-200); color: var(--fg-1); font-weight: 700; font-size: 14px;
  transition: all var(--dur-base) var(--ease-out);
}
.sd-contact-btn:hover { background: var(--color-gray-50); border-color: var(--color-gray-300); }

.sd-why { background: var(--bg-sunken); border-radius: var(--radius-xl); padding: 20px 22px; }
.sd-why-eyebrow { font-family: var(--font-sub); font-weight: 300; font-size: 12px; text-transform: uppercase; letter-spacing: var(--tracking-caps); color: var(--fg-3); margin-bottom: 14px; }
.sd-why ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 12px; }
.sd-why li { display: flex; align-items: flex-start; gap: 10px; font-size: 13px; font-weight: 600; color: var(--fg-1); line-height: 1.35; }
.sd-why li svg { width: 17px; height: 17px; color: var(--color-forest-500); flex-shrink: 0; margin-top: 1px; }

/* ═══════════════════════════════════════════════════════════════
   Room Detail page (RoomDetail.html) — shares this stylesheet
   ═══════════════════════════════════════════════════════════════ */
.sd-wrap { max-width: 1200px; margin: 0 auto; padding: 20px 32px 96px; }
.sd-main { display: flex; flex-direction: column; gap: 20px; }

.rd-back {
  display: inline-flex; align-items: center; gap: 7px; text-decoration: none;
  font-size: 13.5px; font-weight: 700; color: var(--fg-2); padding: 6px 0; margin-bottom: 12px;
  transition: color var(--dur-base) var(--ease-out);
}
.rd-back:hover { color: var(--color-forest-600); }
.rd-back svg { width: 16px; height: 16px; flex-shrink: 0; }
.rd-back span { color: var(--fg-1); }

/* Title + price/CTA row */
.rd-head {
  display: flex; align-items: center; justify-content: space-between; gap: 22px;
  background: white; border-radius: var(--radius-xl); box-shadow: var(--shadow-1);
  padding: 22px 26px; flex-wrap: wrap;
}
.rd-head .rd-l { min-width: 0; flex: 1; }
.rd-head h1 { font-family: var(--font-display); font-weight: 800; font-size: clamp(22px, 2.6vw, 28px); letter-spacing: -0.02em; line-height: 1.1; margin: 0 0 12px; color: var(--fg-1); }
.rd-facts { display: flex; flex-wrap: wrap; gap: 10px 18px; }
.rd-facts .f { display: inline-flex; align-items: center; gap: 6px; font-size: 13px; font-weight: 600; color: var(--fg-2); }
.rd-facts .f svg { width: 15px; height: 15px; color: var(--fg-3); stroke-width: 1.9; flex-shrink: 0; }
.rd-cta { display: flex; align-items: center; gap: 16px; flex-shrink: 0; }
.rd-price { font-family: var(--font-display); font-weight: 800; font-size: 26px; color: var(--fg-1); letter-spacing: -0.02em; white-space: nowrap; }
.rd-price small { font-size: 13px; font-weight: 600; color: var(--fg-3); }

/* Shared CTA button (also used by sticky bar) */
.bw-cta {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 13px 26px; border-radius: var(--radius-md); text-decoration: none; white-space: nowrap;
  background: var(--color-forest-500); color: white; font-weight: 800; font-size: 15px;
  box-shadow: var(--shadow-brand); transition: background var(--dur-base) var(--ease-out);
}
.bw-cta:hover { background: var(--color-forest-600); }
.bw-cta svg { width: 16px; height: 16px; stroke-width: 2.4; }

/* Sections rendered as cards */
.sd-section { background: white; border-radius: var(--radius-xl); box-shadow: var(--shadow-1); padding: 24px 26px; }
.sd-section > h2 { font-family: var(--font-display); font-weight: 800; font-size: 20px; letter-spacing: -0.01em; margin: 0 0 12px; color: var(--fg-1); }
.sec-sub { font-size: 13.5px; color: var(--fg-2); margin: 0 0 18px; line-height: 1.5; }

/* What's included */
.rd-perks-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px 20px; }
.rd-perk { display: flex; align-items: center; gap: 10px; font-size: 13.5px; font-weight: 600; color: var(--fg-1); }
.rd-perk svg { width: 18px; height: 18px; color: var(--color-forest-500); stroke-width: 2.4; flex-shrink: 0; }

/* Good to know */
.rules-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px 22px; }
.rule { display: flex; align-items: flex-start; gap: 12px; }
.rule > svg { width: 38px; height: 38px; padding: 9px; box-sizing: border-box; border-radius: var(--radius-md); background: var(--bg-sunken); color: var(--color-forest-600); stroke-width: 1.85; flex-shrink: 0; }
.rule .ru-k { font-size: 13.5px; font-weight: 700; color: var(--fg-1); line-height: 1.2; }
.rule .ru-v { font-size: 12.5px; color: var(--fg-2); margin-top: 3px; line-height: 1.4; }

/* Sticky book bar (mobile) */
.sd-stickybar {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 60;
  background: rgba(255,255,255,0.92); -webkit-backdrop-filter: blur(10px) saturate(1.05); backdrop-filter: blur(10px) saturate(1.05);
  border-top: 1px solid var(--color-gray-200); padding: 12px 20px;
  transform: translateY(100%); transition: transform var(--dur-base) var(--ease-out);
}
.sd-stickybar.on { transform: translateY(0); }
.sd-stickybar-inner { max-width: 1200px; margin: 0 auto; display: flex; align-items: center; justify-content: space-between; gap: 16px; padding-left: 256px; transition: padding-left var(--dur-base) var(--ease-out); }
body.sb-collapsed .sd-stickybar-inner { padding-left: 76px; }
.sd-stickybar .sb-price { font-size: 14px; font-weight: 700; color: var(--fg-1); min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.sd-stickybar .sb-price small { color: var(--fg-3); font-weight: 600; }
.sd-stickybar .bw-cta { padding: 11px 24px; }

@media (max-width: 860px) {
  .sd-stickybar-inner { padding-left: 0; }
  body.sb-collapsed .sd-stickybar-inner { padding-left: 0; }
}
@media (max-width: 680px) {
  .sd-wrap { padding: 12px 16px 90px; }
  .rd-head { padding: 18px; }
  .rd-cta { width: 100%; justify-content: space-between; }
  .rd-perks-grid, .rules-grid { grid-template-columns: 1fr; }
  .sd-section { padding: 20px 18px; }
}

/* ─── Lightbox ─── */
.sd-lightbox { position: fixed; inset: 0; z-index: 200; background: rgba(15,26,23,0.92); display: none; align-items: center; justify-content: center; }
.sd-lightbox.on { display: flex; }
.sd-lightbox img { max-width: 88vw; max-height: 86vh; border-radius: var(--radius-md); box-shadow: var(--shadow-3); }
.sd-lightbox .lb-close { position: absolute; top: 20px; right: 24px; width: 44px; height: 44px; border-radius: 999px; background: rgba(255,255,255,0.14); border: 0; color: white; cursor: pointer; display: grid; place-items: center; }
.sd-lightbox .lb-close:hover { background: rgba(255,255,255,0.24); }
.sd-lightbox .lb-close svg { width: 22px; height: 22px; }
.sd-lightbox .lb-nav { position: absolute; top: 50%; transform: translateY(-50%); width: 52px; height: 52px; border-radius: 999px; background: rgba(255,255,255,0.14); border: 0; color: white; cursor: pointer; display: grid; place-items: center; }
.sd-lightbox .lb-nav:hover { background: rgba(255,255,255,0.24); }
.sd-lightbox .lb-nav svg { width: 26px; height: 26px; }
.sd-lightbox .lb-prev { left: 24px; }
.sd-lightbox .lb-next { right: 24px; }

/* ─── Responsive ─── */
@media (max-width: 980px) {
  .sd-grid { grid-template-columns: 1fr; }
  .sd-aside { position: static; flex-direction: column; }
}
@media (max-width: 680px) {
  .sd-page { padding: 12px 16px 56px; }
  .sd-gallery { grid-template-columns: 1fr 1fr; grid-template-rows: 160px 110px; height: auto; }
  .sd-gallery .g-cell:first-child { grid-column: 1 / 3; grid-row: 1; }
  .sd-gallery .g-cell:nth-child(n+4) { display: none; }
  .sd-gallery .g-cell:nth-child(2), .sd-gallery .g-cell:nth-child(3) { grid-row: 2; }
  .sd-highlights, .amen-grid, .policy-grid { grid-template-columns: 1fr; }
  .sd-card { padding: 20px 18px; }
  .room-row { grid-template-columns: 1fr; }
  .room-row .rr-thumb { width: 100%; height: 150px; }
  .room-row .rr-right { flex-direction: row; flex-wrap: wrap; align-items: center; justify-content: space-between; border-left: 0; border-top: 1px solid var(--color-gray-100); padding-top: 12px; padding-left: 0; gap: 12px; }
  .room-row .rr-select { width: auto; padding: 10px 22px; }
}
