* { box-sizing: border-box; }
body { margin: 0; background: #f8f8fb; color: var(--ink); font-family: Arial, Helvetica, sans-serif; }
.b2-shell { min-height: 100vh; }
.b2-hero { height: 350px; background-position: center; background-size: cover; margin-bottom: 32px; }
.b2-page { width: min(1320px, calc(100% - 40px)); margin: 65px auto 74px; display: grid; grid-template-columns: 360px minmax(0, 1fr); gap: 30px; align-items: start; }
.b2-card { background: #fff; border: 1px solid var(--line); border-radius: 14px; box-shadow: none; }
.b2-side { position: sticky; top: 24px; }
.b2-side-title { margin: -48px 0 24px; min-height: 24px; font-size: 18px; font-weight: 700; color: var(--ink); }
.b2-search-card { padding: 20px; border-color: #e2dfeb; }
.b2-date-fields { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin: 0 0 14px; }
.b2-field label { display: block; margin-bottom: 7px; color: var(--muted); font-size: 12px; font-weight: 700; }
.b2-field input { width: 100%; height: 42px; border: 1px solid #d7d4e2; border-radius: 6px; background: #fff; padding: 8px 10px; font-size: 14px; color: var(--ink); }
.b2-calendar { border: 1px solid #e0deea; border-radius: 8px; padding: 17px 16px 22px; background: #fff; }
.b2-cal-head { display: flex; align-items: center; justify-content: space-between; min-height: 34px; margin-bottom: 16px; color: #292631; font-size: 15px; }
.b2-cal-nav { width: 32px; height: 32px; border: 0; border-radius: 50%; background: #fff; color: #2f296f; font-size: 20px; line-height: 1; }
.b2-cal-nav:hover { background: #f0edf9; }
.b2-cal-grid { display: grid; grid-template-columns: repeat(7, minmax(0, 1fr)); gap: 10px 8px; text-align: center; }
.b2-cal-week { margin-bottom: 12px; color: #4b4657; font-size: 12px; font-weight: 700; }
.b2-day { display: inline-flex; align-items: center; justify-content: center; width: 34px; height: 34px; margin: 0 auto; border: 0; border-radius: 8px; background: transparent; color: #6d6877; font-size: 14px; line-height: 1; }
button.b2-day { cursor: pointer; }
button.b2-day:hover { background: #f0edf9; color: #2f296f; }
.b2-muted { color: #dedce5; }
.b2-range { background: #eeeaf8; color: #2f296f; }
.b2-selected { background: #3f347f; color: #fff; }
.b2-guest-summary { display: flex; align-items: center; gap: 12px; margin: 20px 0 6px; padding: 12px 14px; border: 1px solid #2f296f; border-radius: 5px; color: var(--ink); }
.b2-guest-summary i { color: #2f296f; font-size: 20px; }
.b2-guest-summary strong { display: block; font-size: 14px; }
.b2-guest-summary span { display: block; margin-top: 2px; color: #4f4b59; }
.b2-step-row { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 14px 0; border-top: 1px solid #e8e5ee; }
.b2-step-row:first-of-type { border-top: 0; }
#b2-child-ages { padding: 10px 0 4px; border-top: 1px solid #e8e5ee; }
.b2-child-age-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 6px 0; }
.b2-child-age-row label { font-size: 13px; color: var(--muted,#6b6678); }
.b2-child-age-row select { border: 1px solid #d7d4e2; border-radius: 6px; padding: 6px 10px; font-size: 13px; color: var(--ink,#34323c); background: #fff; }
.b2-step-controls { display: inline-flex; align-items: center; gap: 16px; }
.b2-step { width: 34px; height: 34px; border: 1px solid #3f347f; border-radius: 50%; background: #fff; color: #3f347f; font-size: 20px; line-height: 1; }
.b2-count { min-width: 18px; text-align: center; font-weight: 700; color: var(--ink); }
.b2-button { width: 100%; height: 50px; border: 0; border-radius: 5px; padding: 0 16px; background: #3f347f; color: #fff; font-weight: 700; white-space: nowrap; font-size: 16px; }
.b2-alert { margin-top: 12px; color: #b91c1c; font-size: 13px; }
.b2-results { min-width: 0; }
.b2-result-head { display: flex; justify-content: flex-end; gap: 14px; align-items: end; margin: -48px 0 24px; min-height: 24px; text-align: right; }
.b2-result-head h2 { margin: 0; color: var(--ink); font-size: 18px; }
.b2-result-head p { margin: 0; color: #3d3a45; font-size: 16px; font-weight: 700; }
.b2-room { overflow: hidden; margin-bottom: 16px; }
.b2-room-main { display: grid; grid-template-columns: 210px minmax(0, 1fr) 210px; gap: 22px; padding: 0; }
.b2-room-img { width: 100%; height: 190px; overflow: hidden; background: #e5e7eb; }
.b2-room-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.b2-room-photo { display: block; width: 100%; height: 100%; border: 0; padding: 0; background: transparent; cursor: zoom-in; }
.b2-room-photo:focus { outline: 3px solid rgba(63, 52, 127, .28); outline-offset: -3px; }
.b2-room-text { padding: 24px 0 20px; min-width: 0; }
.b2-room h3 { margin: 0 0 12px; color: var(--ink); font-size: 24px; line-height: 1.15; }
.b2-services { display: flex; flex-wrap: wrap; gap: 14px; margin: 10px 0 12px; color: #6e6a7a; font-size: 12px; font-weight: 700; }
.b2-service { display: inline-flex; align-items: center; gap: 6px; }
.b2-desc { color: #45414e; font-size: 14px; line-height: 1.45; max-height: 84px; overflow: hidden; }
.b2-price { text-align: right; align-self: start; padding: 28px 24px 20px 0; }
.b2-price span { display: block; color: #4c4856; font-size: 13px; }
.b2-price strong { display: block; margin: 6px 0 12px; color: var(--ink); font-size: 27px; }
.b2-outline { border: 0; background: #efebff; color: #1f193e; height: 50px; border-radius: 5px; padding: 0 20px; font-weight: 700; }
.b2-proposals { border-top: 1px solid #e7e4ed; background: #fff; }
.b2-rate { display: grid; grid-template-columns: minmax(0, 1fr) 180px 140px; gap: 18px; align-items: center; padding: 22px 24px; border-top: 1px solid #e7e4ed; }
.b2-rate:first-child { border-top: 0; }
.b2-rate-default { background: linear-gradient(180deg, #fbf9ff 0%, #fff 100%); border-left: 4px solid var(--brand, #3f347f); }
.b2-rate h4 { margin: 0 0 6px; color: var(--ink); font-size: 21px; }
.b2-rate h4 .b2-pill { display: inline-block; margin-left: 8px; padding: 3px 9px; border-radius: 999px; background: #25843a; color: #fff; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; vertical-align: middle; }
.b2-rate p { margin: 0; color: #4f4b58; font-size: 14px; }
.b2-rate small { display: block; margin-top: 10px; color: #25843a; font-weight: 700; }
.b2-rate-price { color: var(--ink); font-size: 26px; font-weight: 800; white-space: nowrap; text-align: right; }
.b2-rate-price span { display: block; margin-top: 5px; color: #4a4652; font-size: 11px; text-transform: uppercase; }
.b2-select { display: inline-flex; align-items: center; justify-content: center; width: 100%; height: 50px; border: 0; border-radius: 5px; background: #3f347f; color: #fff; padding: 0 14px; text-decoration: none; font-weight: 700; }
.b2-no { padding: 36px; color: #4b4655; }
.b2-no h2 { margin: 0 0 10px; color: var(--ink); font-size: 26px; }
.b2-no p { margin: 0; font-size: 15px; line-height: 1.5; }
.b2-request { display: inline-flex; margin-top: 16px; align-items: center; justify-content: center; height: 44px; border-radius: 5px; background: #3f347f; color: #fff; padding: 0 16px; font-weight: 700; text-decoration: none; }
.b2-footer { width: min(1320px, calc(100% - 40px)); margin: 0 auto; padding: 24px 0; display: flex; justify-content: space-between; gap: 18px; color: #45414f; font-size: 13px; }
.b2-footer-brand { display: flex; align-items: center; justify-content: flex-end; gap: 10px; min-width: 220px; color: #6a6575; font-size: 12px; }
.b2-footer-brand img { display: block; width: 190px; max-width: 100%; height: auto; }
.b2-photo-modal { position: fixed; inset: 0; z-index: 1000; display: none; align-items: center; justify-content: center; padding: 24px; background: rgba(20, 18, 28, .78); }
.b2-photo-modal.is-open { display: flex; }
.b2-photo-dialog { width: min(980px, 100%); max-height: calc(100vh - 48px); border-radius: 12px; overflow: hidden; background: #fff; box-shadow: 0 24px 80px rgba(0, 0, 0, .35); }
.b2-photo-head { display: flex; align-items: center; justify-content: space-between; gap: 14px; padding: 14px 16px; border-bottom: 1px solid #ece9f3; }
.b2-photo-head strong { color: var(--ink); font-size: 16px; }
.b2-photo-close { width: 36px; height: 36px; border: 0; border-radius: 50%; background: #f1eef8; color: #2f296f; font-size: 24px; line-height: 1; }
.b2-photo-stage { position: relative; background: #15121c; }
.b2-photo-stage img { display: block; width: 100%; max-height: calc(100vh - 156px); object-fit: contain; }
.b2-photo-nav { position: absolute; top: 50%; transform: translateY(-50%); width: 42px; height: 42px; border: 0; border-radius: 50%; background: rgba(255,255,255,.9); color: #2f296f; font-size: 28px; line-height: 1; }
.b2-photo-prev { left: 14px; }
.b2-photo-next { right: 14px; }
.b2-photo-count { padding: 10px 16px; color: #6a6575; font-size: 13px; text-align: center; }

.b2-avail-card { margin-top: 18px; padding: 22px 24px 18px; }
.b2-avail-card h3 { margin: 0 0 6px; color: var(--ink); font-size: 19px; }
.b2-avail-sub { margin: 0 0 18px; color: #6a6575; font-size: 13px; }
.b2-avail-row { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.b2-avail-month { background: #fafaff; border: 1px solid #ece9f3; border-radius: 10px; padding: 12px 12px 14px; }
.b2-avail-month-head { text-align: center; padding: 4px 0 10px; color: var(--ink); font-weight: 700; font-size: 14px; text-transform: capitalize; }
.b2-avail-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; }
.b2-avail-week { margin-bottom: 6px; color: #8a86a0; font-size: 11px; text-align: center; text-transform: uppercase; }
.b2-avail-week span { padding: 2px 0; }
.b2-avail-day { display: flex; align-items: center; justify-content: center; height: 32px; border-radius: 6px; font-size: 13px; line-height: 1; text-decoration: none; }
.b2-avail-empty { background: transparent; }
.b2-avail-past { color: #c4c1d2; }
.b2-avail-none { color: #b6b1c4; }
.b2-avail-has { position: relative; background: #d8f5e3; color: #1f6f37; font-weight: 700; cursor: pointer; transition: background .12s ease; }
.b2-avail-has:hover { background: #1f6f37; color: #fff; }
.b2-avail-has-ms { background: #fef3d8; color: #8a5b00; }
.b2-avail-has-ms:hover { background: #c08200; color: #fff; }
.b2-avail-ms { position: absolute; top: 2px; right: 3px; padding: 1px 4px; border-radius: 6px; background: #c08200; color: #fff; font-size: 9px; font-weight: 800; font-style: normal; line-height: 1; }
.b2-avail-has:hover .b2-avail-ms { background: #fff; color: #1f6f37; }
.b2-avail-has-ms:hover .b2-avail-ms { background: #fff; color: #c08200; }

.b2-ms-card { margin-top: 14px; padding: 16px 22px; display: grid; grid-template-columns: 48px minmax(0, 1fr) auto; gap: 16px; align-items: center; background: linear-gradient(180deg, #fffbef 0%, #fff 100%); border-color: #f0d97a; }
.b2-ms-ico { width: 48px; height: 48px; border-radius: 50%; background: #c08200; color: #fff; display: flex; align-items: center; justify-content: center; font-size: 20px; }
.b2-ms-body h4 { margin: 0 0 4px; color: var(--ink); font-size: 16px; }
.b2-ms-body p { margin: 0; color: #6a6575; font-size: 14px; }
.b2-ms-btn { display: inline-flex; align-items: center; height: 42px; padding: 0 18px; border-radius: 8px; background: #3f347f; color: #fff; font-weight: 700; text-decoration: none; white-space: nowrap; }
.b2-ms-btn:hover { background: #2f296f; color: #fff; }
@media (max-width: 640px) { .b2-ms-card { grid-template-columns: 1fr; text-align: center; } .b2-ms-ico { margin: 0 auto; } .b2-ms-btn { justify-content: center; } }
.b2-avail-legend { display: flex; gap: 18px; align-items: center; padding-top: 16px; margin-top: 16px; border-top: 1px solid #ece9f3; color: #4f4b58; font-size: 12px; }
.b2-avail-legend span { display: inline-flex; align-items: center; gap: 6px; }
.b2-avail-dot { width: 10px; height: 10px; border-radius: 50%; display: inline-block; }
.b2-avail-dot-has { background: #d8f5e3; border: 1px solid #1f6f37; }
.b2-avail-dot-none { background: #f1eef6; border: 1px solid #b6b1c4; }

@media (max-width: 980px) { .b2-page { grid-template-columns: 1fr; margin-top: 28px; } .b2-side { position: static; } .b2-side-title, .b2-result-head { margin: 0 0 16px; } .b2-room-main { grid-template-columns: 190px minmax(0, 1fr); } .b2-price { grid-column: 1 / -1; text-align: left; padding: 0 20px 18px; } .b2-rate { grid-template-columns: 1fr; } .b2-rate-price { text-align: left; } }
@media (max-width: 640px) { .b2-hero { height: 170px; } .b2-page, .b2-footer { width: min(100% - 24px, 1320px); } .b2-room-main { grid-template-columns: 1fr; } .b2-room-img { height: 220px; } .b2-room-text, .b2-price, .b2-rate { padding-left: 18px; padding-right: 18px; } .b2-date-fields { grid-template-columns: 1fr; } .b2-calendar { padding: 14px 10px 18px; } .b2-cal-grid { gap: 7px 3px; } .b2-day { width: 31px; height: 31px; } .b2-footer { display: block; } .b2-footer-brand { justify-content: flex-start; margin-top: 16px; min-width: 0; } .b2-footer-brand img { width: 170px; } .b2-photo-modal { padding: 12px; } .b2-photo-nav { width: 36px; height: 36px; font-size: 24px; } .b2-avail-row { grid-template-columns: 1fr; } }
