/* KHL brand standards: Montserrat headings, Roboto body, approved palette. */
:root {
  --forest: #4d268a;
  --forest-2: #351765;
  --cream: #f7f5fb;
  --paper: #fff;
  --ink: #27213a;
  --muted: #716b7d;
  --line: #e5e0ec;
  --clay: #ff7770;
  --sage: #09d1b8;
  --gold: #ffa300;
  --shadow: 0 24px 55px rgba(77, 38, 138, .14);
}

body { font-family: "Roboto", sans-serif; }
.site-header, .hero { background: #fff; }
.site-header { border-bottom-color: rgba(77, 38, 138, .1); }
.brand img { display: block; width: 195px; height: auto; }
.header-brand img { width: 122px; }
footer .brand img { width: 210px; }
.header-link, .text-link, .button, .eyebrow { font-family: "Montserrat", sans-serif; }
.eyebrow { color: var(--forest); letter-spacing: 1.8px; }
.hero h1, .section-heading h2, .rooms-intro h2, .rules h2, dialog h2, .card-header h3, .summary-card h3, .room-feature-grid h3, .month-nav strong, .room-number, .rules-grid span, .dialog-footer strong { font-family: "Montserrat", sans-serif; font-weight: 800; }
.hero h1, .section-heading h2, .rooms-intro h2, .rules h2, dialog h2 { letter-spacing: -3px; line-height: 1.02; }
.hero h1 em { font-style: normal; font-weight: 800; }
.hero-visual { background: #dff9f5; }
.hero-visual:before { background: linear-gradient(125deg, rgba(255, 255, 255, .5), transparent 55%), repeating-linear-gradient(90deg, transparent 0 69px, rgba(77, 38, 138, .05) 70px); }
.hero-visual.has-photo{background-position:center;background-size:cover}.hero-visual.has-photo:before{background:linear-gradient(180deg,rgba(21,61,53,.04),rgba(21,61,53,.18))}.hero-visual.has-photo .arch{display:none}
.arch { background: #a9ebe1; box-shadow: inset 0 0 0 18px rgba(255, 255, 255, .3); }
.window-light { background: linear-gradient(150deg, #f5fffd, #bceee7); border-color: rgba(255, 255, 255, .8); }
.window-light:before, .window-light:after { background: rgba(77, 38, 138, .17); }
.table { background: var(--clay); }
.table:after { background: #bd514d; }
.chair { border-color: var(--forest); }
.plant span { background: var(--gold); }
.plant b { background: var(--sage); }
.pulse { background: var(--sage); box-shadow: 0 0 0 4px #b9f5ed; }
.calendar-status i { background: var(--sage); }
.sage { background: var(--sage); }
.terracotta { background: var(--clay); }
.gold { background: var(--gold); }
.booking-shell { background: #f7f5fb; }
.rooms-intro { background: #fff; }
.room-feature-grid article { background: #f7f5fb; }
.room-choice { background: #faf9fd; }
.room-choice.selected { background: #f4effb; }
.booking-card, .summary-card { box-shadow: 0 8px 24px rgba(77, 38, 138, .08); }
.room-sketch { background: #c5f3ed; }
.room-sketch:after { background: var(--clay); box-shadow: 0 12px 0 -7px #bd514d; }
.room-sketch.small { background: #f2eafb; }
.room-sketch.small:after { background: var(--sage); }
.room-sketch.warm { background: #fff0d6; }
.room-photo { display: block; width: 100%; height: 145px; object-fit: cover; }
.rules-grid span { color: var(--gold); }
.policy-intro { max-width: 480px; color: #ded3ee; font-size: 13px; line-height: 1.7; }
.rules-grid article { padding: 17px 18px; border: 1px solid rgba(255,255,255,.18); background: rgba(255,255,255,.06); }
.rules-grid article h3 { margin: 0 0 8px; color: #fff; font-size: 15px; letter-spacing: -.3px; }
.rules-grid article p { margin: 0; color: #e7eee8; font-size: 13px; line-height: 1.6; }
.cancellation-policy{display:grid;grid-template-columns:.9fr 1.1fr;gap:60px;padding:72px 7vw;background:#fff}.cancellation-policy h2{margin:0;color:var(--forest);font:800 38px/1.03 Montserrat,sans-serif;letter-spacing:-2px}.cancellation-policy p{max-width:520px;color:var(--muted);font-size:14px;line-height:1.7}.cancellation-windows{display:grid;gap:9px}.cancellation-windows article{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 18px;border-left:4px solid var(--sage);background:#f7f5fb}.cancellation-windows strong{color:var(--forest);font:700 12px Montserrat,sans-serif}.cancellation-windows span{color:var(--muted);font-size:12px}@media(max-width:850px){.cancellation-policy{grid-template-columns:1fr;gap:20px}}
footer { background: #351765; color: #ded3ee; }
dialog::backdrop { background: rgba(53, 23, 101, .58); }
.review-icon { background: #d8faf5; }
.review-summary { background: #f7f5fb; }
dialog { max-height: calc(100vh - 30px); overflow: auto; }

/* Booking summary follows the Step 1 card in the reading order. */
.booking-layout { grid-template-columns: 1fr; }
.summary-card { order: initial; display: grid; grid-template-columns: minmax(170px, 1.2fr) minmax(350px, 2fr) minmax(210px, .8fr); gap: 22px; align-items: center; padding: 22px 24px; }
.summary-divider { display: none; }
.summary-card dl { display: grid; grid-template-columns: repeat(3, 1fr); gap: 15px; margin: 0; }
.summary-card dl div { display: block; margin: 0; padding-left: 14px; border-left: 1px solid var(--line); }
.summary-card dd { margin: 5px 0 0; text-align: left; }
.summary-card .full { margin-top: 0; }
.summary-card .aside-note { margin-top: 10px; }
.duration-choice { display: block; margin: 0 0 15px; }
.duration-choice span { display: block; margin-bottom: 6px; color: var(--forest); font-size: 11px; font-weight: 700; }
.duration-choice select { width: 100%; }
.time-list { grid-template-columns: 1fr; }
.time-button { display: grid; gap: 5px; padding: 10px 8px; text-align: left; }
.time-button strong { font-size: 12px; }
.time-button small { color: var(--muted); font-size: 10px; line-height: 1.4; }
.time-button.after-hours-time { border: 2px solid var(--clay); background: #fff4ee; }
.time-button.after-hours-time small { margin-top: 1px; padding-top: 5px; border-top: 1px solid #edb3a2; color: #7e321e; font-size: 10px; font-weight: 700; }
.time-button.selected small { color: #fff; }
.time-button.after-hours-time.selected { border-color: var(--purple); background: #ffe8dc; color: var(--forest); box-shadow: inset 0 0 0 2px #fff; }
.time-button.after-hours-time.selected small { border-top-color: #cf8b78; color: #672612; }

@media(max-width: 760px) {
  .summary-card { display: block; }
  .summary-card dl { display: block; margin: 16px 0; }
  .summary-card dl div { display: flex; margin: 10px 0; padding-left: 0; border-left: 0; }
  .summary-card dd { margin: 0; text-align: right; }
  .summary-card .full { margin-top: 15px; }
}
