/* ¢w¢w Booking Page Layout ¢w¢w */
.booking-page { padding-bottom: 68px }

/* ¢w¢w Page Header ¡X matches contact page .page-header ¢w¢w */
.booking-page .page-header { margin-bottom: 24px; padding: 32px 0 20px; border-bottom: 1px solid var(--border, #e2e8f0) }
.booking-page .page-header h1 { font-size: 32px; font-weight: 800; letter-spacing: -.3px; color: var(--text, #1e293b); margin: 0 0 8px }
.booking-page .page-header .page-meta { font-size: 14px; color: var(--text-light, #94a3b8) }
@media (max-width: 768px) {
  .booking-page .page-header { padding: 20px 0 16px }
  .booking-page .page-header h1 { font-size: 24px }
}

/* ¢w¢w Alert ¢w¢w */
.bk-alert { display: flex; align-items: center; gap: 10px; padding: 14px 16px; border-radius: var(--radius); font-size: 14px; font-weight: 500; margin-bottom: 20px }
.bk-alert__icon { width: 20px; height: 20px; flex-shrink: 0 }
.bk-alert--success { background: #f0fdf4; color: #166534; border: 1px solid #bbf7d0 }
.bk-alert--error   { background: #fef2f2; color: #991b1b; border: 1px solid #fecaca }
.bk-alert--info    { background: #eff6ff; color: #1e40af; border: 1px solid #bfdbfe }

/* ¢w¢w Section Label ¢w¢w */
.bk-section-label { font-size: 12px; font-weight: 700; color: var(--text-light); letter-spacing: .5px; text-transform: uppercase; margin-bottom: 12px }

/* ¢w¢w Event Cards Grid ¢w¢w */
.booking-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; margin-bottom: 32px }

.booking-card {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 20px;
  background: var(--white);
  position: relative;
  box-shadow: var(--shadow);
  transition: box-shadow var(--transition), border-color var(--transition)
}
.booking-card:hover { box-shadow: var(--shadow-md); border-color: #cbd5e1 }
.booking-card--full { opacity: .65 }

.booking-card__title { margin: 0 0 10px; font-size: 17px; font-weight: 700; color: var(--text); padding-right: 72px }

.booking-card__meta { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 10px }
.booking-card__meta-item { display: inline-flex; align-items: center; gap: 5px; font-size: 13px; color: var(--text-mid) }
.booking-card__meta-item svg { width: 14px; height: 14px; color: var(--text-light) }

/* ¢w¢w Price Tag ¢w¢w */
.bk-price-tag { display: inline-flex; align-items: center; font-size: 13px; font-weight: 700; color: var(--primary); background: var(--primary-light); padding: 2px 10px; border-radius: 999px }
.bk-price-tag--free { color: #166534; background: #dcfce7 }

/* ¢w¢w Price Preview in form ¢w¢w */
.bk-price-preview { margin-top: 10px; font-size: 14px; color: var(--text-mid); background: var(--bg); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 10px 14px }
.bk-price-preview strong { color: var(--primary); font-size: 16px }

.booking-card__desc { font-size: 13px; color: var(--text-mid); line-height: 1.65; margin-bottom: 14px; border-top: 1px solid var(--border-light); padding-top: 10px }
.booking-card__desc p { margin: 0 0 6px }
.booking-card__desc ul, .booking-card__desc ol { padding-left: 18px; margin: 0 0 6px }

/* ¢w¢w Progress Bar ¢w¢w */
.booking-card__bar-wrap { margin-top: 14px }
.booking-card__bar-track { height: 6px; background: var(--bg); border-radius: 999px; overflow: hidden }
.booking-card__bar-fill { height: 100%; background: var(--success); border-radius: 999px; transition: width .3s }
.booking-card__bar-fill--hot { background: var(--warning) }
.booking-card--full .booking-card__bar-fill { background: var(--danger) }
.booking-card__bar-label { margin-top: 7px; font-size: 13px; color: var(--text-mid) }
.booking-card__bar-label strong { color: var(--text) }

/* ¢w¢w Badges ¢w¢w */
.bk-badge { position: absolute; right: 14px; top: 14px; padding: 3px 10px; border-radius: 999px; font-size: 12px; font-weight: 700 }
.bk-badge--full { background: #fee2e2; color: #991b1b }
.bk-badge--low  { background: var(--accent-light); color: #92400e }

/* ¢w¢w Booking Form Wrapper ¢w¢w */
.bk-form-wrap { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius); box-shadow: var(--shadow); overflow: hidden }
.bk-form-header { padding: 18px 22px 16px; border-bottom: 1px solid var(--border-light) }
.bk-form-header__title { font-size: 16px; font-weight: 800; color: var(--text) }
.bk-form-header__sub { font-size: 12px; color: var(--text-light); margin-top: 3px }

.bk-no-slot { padding: 20px 22px; color: #92400e; background: var(--accent-light); font-size: 14px; font-weight: 500; border-top: 1px solid #fde68a }

/* ¢w¢w Form Grid ¢w¢w */
.bk-form { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 0; padding: 20px 22px 22px }
.bk-form__field { display: flex; flex-direction: column; gap: 6px; padding: 0 6px 14px }
.bk-form__field--full { grid-column: 1 / -1; padding-left: 0; padding-right: 0 }
.bk-form__field label { font-size: 12px; font-weight: 700; color: var(--text-mid) }
.bk-form__field input,
.bk-form__field select {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  font-size: 14px;
  color: var(--text);
  background: var(--white);
  transition: border-color var(--transition), box-shadow var(--transition)
}
.bk-form__field input:focus,
.bk-form__field select:focus { border-color: var(--primary); outline: none; box-shadow: 0 0 0 3px var(--primary-glow) }

.bk-form__submit { padding-top: 4px }

/* ¢w¢w Submit Button ¡X matches site's primary button style ¢w¢w */
.booking-submit-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 11px 28px;
  border: none;
  border-radius: var(--radius-sm);
  background: var(--primary-light);
  color: var(--primary);
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  font-family: inherit;
  transition: background var(--transition), color var(--transition), transform var(--transition)
}
.booking-submit-btn:hover { background: var(--primary); color: #fff; transform: translateY(-1px) }
.booking-submit-btn:active { transform: translateY(0) }
.booking-submit-btn:disabled { opacity: .5; cursor: not-allowed; transform: none }

/* ¢w¢w Confirm Page ¢w¢w */
.bk-confirm-layout { display: grid; grid-template-columns: 1fr 340px; gap: 24px; align-items: start }
.bk-confirm-card { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius); box-shadow: var(--shadow); overflow: hidden }
.bk-confirm-card__head { padding: 14px 20px; font-weight: 800; font-size: 15px; color: var(--text); background: var(--bg); border-bottom: 1px solid var(--border) }
.bk-confirm-table { width: 100%; border-collapse: collapse; font-size: 14px }
.bk-confirm-table th, .bk-confirm-table td { padding: 11px 20px; border-bottom: 1px solid var(--border-light); text-align: left }
.bk-confirm-table th { color: var(--text-light); font-weight: 600; width: 100px }
.bk-confirm-table td { color: var(--text) }
.bk-confirm-table tr:last-child th, .bk-confirm-table tr:last-child td { border-bottom: none }
.bk-confirm-table__total th, .bk-confirm-table__total td { font-weight: 800; font-size: 16px; color: var(--primary) }

.bk-confirm-pay { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius); box-shadow: var(--shadow); overflow: hidden }
.bk-confirm-pay form { padding: 16px 20px 0 }
.bk-pay-btn { display: flex; align-items: center; justify-content: center; gap: 8px; width: 100%; padding: 14px; border: none; border-radius: var(--radius-sm); background: var(--primary); color: #fff; font-size: 15px; font-weight: 700; cursor: pointer; transition: background var(--transition) }
.bk-pay-btn:hover { background: #0b7a6e }
.bk-confirm-note { display: flex; align-items: center; gap: 6px; margin: 14px 20px 0; font-size: 12px; color: var(--text-light) }
.bk-back-link { display: block; text-align: center; margin: 14px 20px 16px; font-size: 13px; color: var(--text-light); text-decoration: underline }
.bk-back-link:hover { color: var(--danger) }

/* ¢w¢w Success / Cancel Box ¢w¢w */
.bk-success-box { text-align: center; background: var(--white); border: 1px solid #bbf7d0; border-radius: var(--radius); padding: 40px 24px; max-width: 600px; margin: 0 auto }
.bk-success-icon { margin-bottom: 16px }
.bk-success-icon svg { width: 64px; height: 64px }
.bk-success-box h2 { font-size: 24px; font-weight: 800; color: var(--text); margin: 0 0 8px }
.bk-success-box p { font-size: 14px; color: var(--text-mid); margin: 0 }

/* ¢w¢w Responsive ¢w¢w */
@media (max-width: 768px) {
  .booking-page { padding-bottom: 50px }
  .booking-grid { grid-template-columns: 1fr }
  .bk-form { grid-template-columns: 1fr; padding: 16px }
  .bk-form__field { padding-left: 0; padding-right: 0 }
}