.booking-hero{min-height:420px;background-image:linear-gradient(90deg, rgba(49,38,31,.56) 0%, rgba(49,38,31,.24) 48%, rgba(49,38,31,.12) 100%),linear-gradient(180deg, rgba(35,26,21,.08), rgba(35,26,21,.28)),var(--hero-image);background-position:center;background-size:cover;background-repeat:no-repeat}
.booking-hero .inner{min-height:420px;display:flex;flex-direction:column;justify-content:flex-end;padding:82px 0 42px}
.booking-hero .hero-title{max-width:860px;margin-bottom:14px}
.booking-hero .hero-sub{max-width:780px;color:rgba(255,255,255,.92)}
.booking-intro{padding-top:42px}
.booking-split{grid-template-columns:1.08fr .92fr}
.booking-split .content{padding:52px 48px}
.booking-eyebrow{display:inline-block;margin-bottom:16px;color:var(--green-dark);font-size:.8rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase}
.booking-actions{display:flex;gap:12px;flex-wrap:wrap}
.booking-note{padding:30px 28px}
.booking-note h3{margin-top:0}
.booking-list{display:grid;gap:10px;padding-left:18px}
.booking-list li:last-child{margin-bottom:0}
.booking-preview{padding:28px}
.booking-preview-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:18px}
.booking-preview-head h2{margin:6px 0 0}
.booking-frame-wrap{border:1px solid rgba(112,91,74,.12);border-radius:22px;overflow:hidden;background:#f8f3ec}
.booking-frame{display:block;width:100%;height:960px;border:0;background:#fff}
.booking-modal{position:fixed;inset:0;z-index:1200;display:grid;place-items:center;padding:22px}
.booking-modal[hidden]{display:none}
.booking-modal-backdrop{position:absolute;inset:0;background:rgba(28,22,18,.62);backdrop-filter:blur(4px)}
.booking-modal-dialog{position:relative;display:grid;grid-template-rows:auto 1fr;width:min(1240px,100%);height:min(90vh,940px);border-radius:26px;overflow:hidden;background:#fff;box-shadow:0 28px 80px rgba(24,18,14,.28)}
.booking-modal-head{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 22px;border-bottom:1px solid rgba(112,91,74,.12);background:#f8f3ec}
.booking-modal-head h2{margin:0;font-size:1.35rem}
.booking-modal-frame{display:block;width:100%;height:100%;border:0;background:#fff}
body.booking-modal-open{overflow:hidden}
@media (max-width: 980px){
  .booking-split{grid-template-columns:1fr}
  .booking-split .content{padding:34px 24px 28px}
  .booking-preview-head,.booking-modal-head{align-items:flex-start;flex-direction:column}
  .booking-frame{height:820px}
}
@media (max-width: 820px){
  .booking-hero{min-height:320px}
  .booking-hero .inner{min-height:320px;padding:72px 0 28px}
  .booking-modal{padding:0}
  .booking-modal-dialog{width:100%;height:100vh;border-radius:0}
  .booking-frame{height:760px}
}
