/* ============================================================
   Bartonville Parks & Recreation — Frontend Styles
   ============================================================ */

:root {
  --bpr-primary:   #2d6a4f;
  --bpr-secondary: #52b788;
  --bpr-accent:    #e67e22;
  --bpr-danger:    #c0392b;
  --bpr-warning:   #f39c12;
  --bpr-success:   #27ae60;
  --bpr-gray-100:  #f8f9fa;
  --bpr-gray-200:  #e9ecef;
  --bpr-gray-400:  #adb5bd;
  --bpr-gray-600:  #6c757d;
  --bpr-gray-800:  #343a40;
  --bpr-radius:    8px;
  --bpr-shadow:    0 2px 8px rgba(0,0,0,.10);
  --bpr-shadow-lg: 0 4px 20px rgba(0,0,0,.15);
  --bpr-font:      -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

/* ─── Base ─────────────────────────────────────────────────── */
.bpr-reservation-wrap,
.bpr-form-wrap,
.bpr-calendar-wrap,
.bpr-facilities-wrap,
.bpr-events-wrap,
.bpr-my-account {
  font-family: var(--bpr-font);
  max-width: 900px;
  margin: 0 auto;
  padding: 0 16px;
}

/* ─── Step Indicator ───────────────────────────────────────── */
.bpr-step-indicator {
  display: flex;
  justify-content: space-between;
  margin-bottom: 32px;
  counter-reset: step;
  position: relative;
  padding: 0;
  list-style: none;
}
.bpr-step-indicator::before {
  content: '';
  position: absolute;
  top: 20px;
  left: 0; right: 0;
  height: 2px;
  background: var(--bpr-gray-200);
  z-index: 0;
}
.bpr-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: var(--bpr-gray-400);
  z-index: 1;
  flex: 1;
  text-align: center;
}
.bpr-step span {
  width: 40px; height: 40px;
  border-radius: 50%;
  background: var(--bpr-gray-200);
  color: var(--bpr-gray-600);
  display: flex; align-items: center; justify-content: center;
  font-weight: 700;
  font-size: 15px;
  transition: all .25s;
}
.bpr-step.active span {
  background: var(--bpr-primary);
  color: #fff;
}
.bpr-step.done span {
  background: var(--bpr-success);
  color: #fff;
}
.bpr-step.active, .bpr-step.done { color: var(--bpr-gray-800); font-weight: 600; }

/* ─── Facility Cards ───────────────────────────────────────── */
.bpr-facility-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 16px;
  margin-bottom: 24px;
}
.bpr-facility-card {
  border: 2px solid var(--bpr-gray-200);
  border-radius: var(--bpr-radius);
  padding: 20px;
  cursor: pointer;
  transition: all .2s;
  background: #fff;
}
.bpr-facility-card:hover {
  border-color: var(--bpr-secondary);
  box-shadow: var(--bpr-shadow);
  transform: translateY(-2px);
}
.bpr-facility-card.selected {
  border-color: var(--bpr-primary);
  background: rgba(45,106,79,.05);
  box-shadow: var(--bpr-shadow);
}
.bpr-facility-icon { font-size: 32px; margin-bottom: 8px; }
.bpr-facility-name { font-size: 16px; font-weight: 700; margin: 0 0 8px; color: var(--bpr-gray-800); }
.bpr-facility-meta { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 8px; }
.bpr-facility-rate { font-size: 14px; font-weight: 600; color: var(--bpr-primary); }
.bpr-facility-free { color: var(--bpr-success); }
.bpr-facility-min, .bpr-facility-cap { font-size: 12px; color: var(--bpr-gray-600); }
.bpr-facility-desc { font-size: 13px; color: var(--bpr-gray-600); margin: 8px 0; }
.bpr-facility-amenities { display: flex; flex-wrap: wrap; gap: 4px; margin-top: 8px; }
.bpr-amenity-tag {
  background: var(--bpr-gray-100);
  border: 1px solid var(--bpr-gray-200);
  border-radius: 4px;
  padding: 2px 8px;
  font-size: 11px;
  color: var(--bpr-gray-600);
}

/* ─── Form Fields ───────────────────────────────────────────── */
.bpr-fields-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-bottom: 20px;
}
.bpr-field { display: flex; flex-direction: column; gap: 6px; }
.bpr-field--full { grid-column: 1 / -1; }
.bpr-field label {
  font-size: 14px;
  font-weight: 600;
  color: var(--bpr-gray-800);
}
.bpr-required { color: var(--bpr-danger); }
.bpr-input {
  width: 100%;
  padding: 10px 14px;
  border: 1.5px solid var(--bpr-gray-200);
  border-radius: var(--bpr-radius);
  font-size: 15px;
  font-family: var(--bpr-font);
  transition: border-color .2s, box-shadow .2s;
  box-sizing: border-box;
  background: #fff;
}
.bpr-input:focus {
  outline: none;
  border-color: var(--bpr-primary);
  box-shadow: 0 0 0 3px rgba(45,106,79,.15);
}
.bpr-input.bpr-error { border-color: var(--bpr-danger); }
textarea.bpr-input { resize: vertical; min-height: 80px; }
select.bpr-input { cursor: pointer; }
.bpr-field-help { font-size: 12px; color: var(--bpr-gray-600); margin: 0; }
.bpr-field-error { font-size: 12px; color: var(--bpr-danger); margin: 0; display: none; }
.bpr-field-error.visible { display: block; }

/* ─── Datetime grid ─────────────────────────────────────────── */
.bpr-datetime-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 16px;
  margin-bottom: 20px;
}

/* ─── Availability / Fee ────────────────────────────────────── */
.bpr-availability-msg {
  padding: 12px 16px;
  border-radius: var(--bpr-radius);
  margin: 12px 0;
  font-weight: 600;
  display: none;
}
.bpr-availability-msg.available {
  background: rgba(39,174,96,.1);
  border: 1px solid rgba(39,174,96,.3);
  color: var(--bpr-success);
  display: block;
}
.bpr-availability-msg.unavailable {
  background: rgba(192,57,43,.08);
  border: 1px solid rgba(192,57,43,.3);
  color: var(--bpr-danger);
  display: block;
}
.bpr-fee-preview {
  background: var(--bpr-gray-100);
  border: 1px solid var(--bpr-gray-200);
  border-radius: var(--bpr-radius);
  padding: 16px 20px;
  margin-top: 12px;
}
.bpr-fee-row { display: flex; justify-content: space-between; padding: 4px 0; font-size: 15px; }
.bpr-fee-row--total { border-top: 1px solid var(--bpr-gray-200); margin-top: 8px; padding-top: 12px; font-size: 18px; }

/* ─── Checkboxes / Radios ───────────────────────────────────── */
.bpr-checkbox-label, .bpr-radio-label {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  cursor: pointer;
  font-size: 14px;
  line-height: 1.5;
}
.bpr-checkbox-label input, .bpr-radio-label input {
  margin-top: 2px;
  width: 18px; height: 18px;
  accent-color: var(--bpr-primary);
  cursor: pointer;
  flex-shrink: 0;
}
.bpr-checkbox-group { display: flex; flex-wrap: wrap; gap: 10px; }

/* ─── Signature ─────────────────────────────────────────────── */
.bpr-signature-wrap {
  border: 1.5px solid var(--bpr-gray-200);
  border-radius: var(--bpr-radius);
  overflow: hidden;
  background: #fff;
  position: relative;
}
.bpr-signature-pad {
  display: block;
  width: 100%;
  height: 150px;
  cursor: crosshair;
  touch-action: none;
}
.bpr-signature-clear {
  position: absolute;
  bottom: 8px; right: 8px;
}

/* ─── Agreement Box ─────────────────────────────────────────── */
.bpr-agreement-box {
  border: 1.5px solid var(--bpr-gray-200);
  border-radius: var(--bpr-radius);
  padding: 20px;
  background: var(--bpr-gray-100);
}
.bpr-agreement-box h3 { margin: 0 0 12px; font-size: 16px; }
.bpr-agreement-text { max-height: 140px; overflow-y: auto; margin-bottom: 16px; font-size: 13px; color: var(--bpr-gray-600); }

/* ─── Review Summary ────────────────────────────────────────── */
.bpr-review-summary {
  background: var(--bpr-gray-100);
  border-radius: var(--bpr-radius);
  padding: 20px;
  margin-bottom: 24px;
}
.bpr-review-summary table { width: 100%; border-collapse: collapse; }
.bpr-review-summary td { padding: 8px 12px; border-bottom: 1px solid var(--bpr-gray-200); font-size: 14px; }
.bpr-review-summary td:first-child { font-weight: 600; width: 40%; }

/* ─── Buttons ───────────────────────────────────────────────── */
.bpr-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 10px 22px;
  border-radius: var(--bpr-radius);
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
  border: 2px solid transparent;
  text-decoration: none;
  transition: all .2s;
  font-family: var(--bpr-font);
  line-height: 1;
}
.bpr-btn:disabled, .bpr-btn[disabled] { opacity: .5; cursor: not-allowed; }
.bpr-btn-primary { background: var(--bpr-primary); color: #fff; border-color: var(--bpr-primary); }
.bpr-btn-primary:hover:not(:disabled) { background: #1b4332; border-color: #1b4332; }
.bpr-btn-secondary { background: #fff; color: var(--bpr-primary); border-color: var(--bpr-primary); }
.bpr-btn-secondary:hover:not(:disabled) { background: rgba(45,106,79,.08); }
.bpr-btn-danger { background: var(--bpr-danger); color: #fff; border-color: var(--bpr-danger); }
.bpr-btn-sm { padding: 6px 14px; font-size: 13px; }
.bpr-btn-lg { padding: 14px 32px; font-size: 17px; }

/* ─── Step nav ──────────────────────────────────────────────── */
.bpr-step-nav {
  display: flex;
  gap: 12px;
  justify-content: flex-end;
  margin-top: 24px;
  padding-top: 20px;
  border-top: 1px solid var(--bpr-gray-200);
}
.bpr-form-actions { margin-top: 20px; }

/* ─── Step title ────────────────────────────────────────────── */
.bpr-step-title { font-size: 22px; font-weight: 700; margin: 0 0 24px; color: var(--bpr-gray-800); }

/* ─── Notices ───────────────────────────────────────────────── */
.bpr-notice {
  padding: 12px 16px;
  border-radius: var(--bpr-radius);
  font-size: 14px;
  margin-top: 8px;
}
.bpr-notice--warning {
  background: rgba(243,156,18,.1);
  border: 1px solid rgba(243,156,18,.4);
  color: #7d5a00;
}
.bpr-form-message {
  margin-top: 16px;
  padding: 12px 16px;
  border-radius: var(--bpr-radius);
  display: none;
  font-weight: 500;
}
.bpr-form-message.success { background: rgba(39,174,96,.1); color: var(--bpr-success); border: 1px solid rgba(39,174,96,.3); display: block; }
.bpr-form-message.error   { background: rgba(192,57,43,.08); color: var(--bpr-danger);  border: 1px solid rgba(192,57,43,.3); display: block; }

/* ─── Confirmation ──────────────────────────────────────────── */
.bpr-confirmation { text-align: center; padding: 40px 20px; }
.bpr-confirmation-icon { font-size: 64px; margin-bottom: 16px; }
.bpr-confirmation-num {
  font-size: 20px;
  background: var(--bpr-gray-100);
  border-radius: var(--bpr-radius);
  padding: 16px;
  margin: 20px auto;
  max-width: 300px;
}

/* ─── Calendar ──────────────────────────────────────────────── */
.bpr-calendar-wrap { max-width: 1000px; }
.bpr-cal-filter { margin-bottom: 16px; display: flex; align-items: center; gap: 12px; }
.bpr-legend { display: flex; gap: 16px; margin-bottom: 12px; flex-wrap: wrap; }
.bpr-legend-item {
  display: flex; align-items: center; gap: 6px;
  font-size: 13px; color: var(--bpr-gray-600);
}
.bpr-legend-item::before { content:''; width:14px; height:14px; border-radius:3px; display:inline-block; }
.bpr-legend--reserved::before  { background: #2d6a4f; }
.bpr-legend--event::before     { background: #e67e22; }
.bpr-legend--blocked::before   { background: #c0392b; }
.bpr-cal-cta { text-align: center; margin-top: 20px; }

/* ─── Facilities List ───────────────────────────────────────── */
.bpr-facility-grid--list { grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); }
.bpr-facility-info-card {
  border: 1.5px solid var(--bpr-gray-200);
  border-radius: var(--bpr-radius);
  padding: 24px;
  background: #fff;
  display: flex; flex-direction: column; gap: 12px;
  box-shadow: var(--bpr-shadow);
}
.bpr-facility-info-header { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; }
.bpr-facility-info-header h3 { margin: 0; font-size: 18px; }
.bpr-facility-rules summary { cursor: pointer; font-weight: 600; color: var(--bpr-primary); font-size: 14px; padding: 6px 0; }
.bpr-facility-rules > div { font-size: 13px; color: var(--bpr-gray-600); padding: 8px 0; border-top: 1px solid var(--bpr-gray-200); }

/* ─── Events ────────────────────────────────────────────────── */
.bpr-event-card {
  display: flex;
  gap: 20px;
  border: 1.5px solid var(--bpr-gray-200);
  border-radius: var(--bpr-radius);
  overflow: hidden;
  margin-bottom: 20px;
  background: #fff;
  box-shadow: var(--bpr-shadow);
}
.bpr-event-thumb { width: 200px; flex-shrink: 0; overflow: hidden; }
.bpr-event-thumb img { width: 100%; height: 100%; object-fit: cover; }
.bpr-event-info { padding: 20px; flex: 1; }
.bpr-event-date { color: var(--bpr-primary); font-weight: 700; font-size: 14px; margin-bottom: 6px; }
.bpr-event-title { font-size: 20px; margin: 0 0 8px; }
.bpr-event-title a { color: var(--bpr-gray-800); text-decoration: none; }
.bpr-event-title a:hover { color: var(--bpr-primary); }
.bpr-event-location { font-size: 13px; color: var(--bpr-gray-600); margin-bottom: 10px; }

/* ─── My Account ────────────────────────────────────────────── */
.bpr-account-nav { display: flex; gap: 12px; margin-bottom: 24px; flex-wrap: wrap; }
.bpr-my-reservations { display: grid; gap: 16px; }
.bpr-my-res-card {
  border: 1.5px solid var(--bpr-gray-200);
  border-radius: var(--bpr-radius);
  overflow: hidden;
}
.bpr-my-res-header {
  display: flex; justify-content: space-between; align-items: center;
  padding: 12px 16px;
  background: var(--bpr-gray-100);
  font-size: 14px;
}
.bpr-my-res-body { padding: 16px; font-size: 14px; line-height: 1.6; }
.bpr-my-res-body p { margin: 0 0 4px; }
.bpr-my-res-actions { padding: 12px 16px; border-top: 1px solid var(--bpr-gray-200); }

/* ─── Status Badges ─────────────────────────────────────────── */
.bpr-status {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .5px;
}
.bpr-status--pending   { background: rgba(243,156,18,.15); color: #7d5a00; }
.bpr-status--confirmed { background: rgba(39,174,96,.15);  color: #1e8449; }
.bpr-status--cancelled { background: rgba(192,57,43,.12);  color: var(--bpr-danger); }
.bpr-status--completed { background: rgba(52,73,94,.1);    color: var(--bpr-gray-800); }
.bpr-status--rejected  { background: rgba(192,57,43,.12);  color: var(--bpr-danger); }

/* ─── Tree Sign ─────────────────────────────────────────────── */
.bpr-sign-section { margin: 24px 0; }
.bpr-sign-section h3 { margin-bottom: 8px; }
.bpr-sign-preview-wrap { display: flex; gap: 24px; align-items: flex-start; }
.bpr-sign-preview {
  background: #1a5276;
  border: 3px solid #aab7b8;
  border-radius: 4px;
  padding: 16px 20px;
  min-width: 180px;
  flex-shrink: 0;
}
.bpr-sign-line {
  color: #f8c471;
  font-family: 'Georgia', serif;
  font-size: 14px;
  font-weight: bold;
  text-align: center;
  min-height: 20px;
  line-height: 1.5;
  text-transform: uppercase;
}
.bpr-sign-inputs { flex: 1; display: flex; flex-direction: column; gap: 8px; }
.bpr-examples-grid { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 12px; }
.bpr-example-sign { cursor: pointer; opacity: .85; transition: opacity .2s; }
.bpr-example-sign:hover { opacity: 1; }
.bpr-payment-section { margin-top: 24px; }

/* ─── Form description ──────────────────────────────────────── */
.bpr-description { font-size: 14px; color: var(--bpr-gray-600); margin-bottom: 16px; }
.bpr-form-description { font-size: 15px; color: var(--bpr-gray-600); margin-bottom: 20px; }

/* ─── Loading overlay ───────────────────────────────────────── */
.bpr-loading { pointer-events: none; opacity: .65; }
.bpr-spinner {
  display: inline-block;
  width: 18px; height: 18px;
  border: 2px solid rgba(255,255,255,.4);
  border-top-color: #fff;
  border-radius: 50%;
  animation: bprSpin .7s linear infinite;
}
@keyframes bprSpin { to { transform: rotate(360deg); } }

/* ─── Responsive ────────────────────────────────────────────── */
@media (max-width: 640px) {
  .bpr-step-indicator { flex-wrap: wrap; gap: 8px; }
  .bpr-step-indicator::before { display: none; }
  .bpr-fields-grid { grid-template-columns: 1fr; }
  .bpr-datetime-grid { grid-template-columns: 1fr; }
  .bpr-facility-grid { grid-template-columns: 1fr; }
  .bpr-sign-preview-wrap { flex-direction: column; }
  .bpr-event-card { flex-direction: column; }
  .bpr-event-thumb { width: 100%; height: 200px; }
  .bpr-step-nav { justify-content: stretch; flex-direction: column-reverse; }
  .bpr-step-nav .bpr-btn { width: 100%; }
}

/* ─── Multi-booking cart bar ──────────────────────────────── */
.bpr-cart-bar {
  position: sticky;
  top: 0;
  z-index: 100;
  background: var(--bpr-primary);
  color: #fff;
  padding: 10px 20px;
  border-radius: var(--bpr-radius);
  margin-bottom: 16px;
  box-shadow: var(--bpr-shadow-lg);
}
.bpr-cart-bar__inner {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}
.bpr-cart-bar__label { font-weight: 600; flex: 1; min-width: 160px; }
.bpr-cart-bar__total { font-size: 18px; font-weight: 800; }

/* ─── Facility card photo ─────────────────────────────────── */
.bpr-facility-photo {
  width: 100%;
  aspect-ratio: 16/9;
  overflow: hidden;
  border-radius: var(--bpr-radius) var(--bpr-radius) 0 0;
}
.bpr-facility-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.bpr-facility-card__body { padding: 12px; }

/* ─── Resident discount badge/section ────────────────────── */
.bpr-resident-badge {
  display: inline-block;
  background: #e8f5e9;
  color: #2e7d32;
  border: 1px solid #a5d6a7;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 600;
  padding: 2px 6px;
}
.bpr-resident-section {
  background: var(--bpr-gray-100);
  border: 1px solid var(--bpr-gray-200);
  border-radius: var(--bpr-radius);
  padding: 12px 16px;
  margin-bottom: 16px;
}
.bpr-fee-row--resident { color: #27ae60; font-weight: 600; }

/* ─── Step 1 actions / prompt ─────────────────────────────── */
.bpr-step1-actions { margin-top: 16px; }
.bpr-step1-actions .bpr-step-nav {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.bpr-step-prompt {
  text-align: center;
  color: var(--bpr-gray-600);
  padding: 12px 0;
  font-style: italic;
}
.bpr-step2-hint { font-size: 14px; color: var(--bpr-gray-600); margin-bottom: 12px; }

/* ─── Fee preview ─────────────────────────────────────────── */
.bpr-fee-preview {
  background: var(--bpr-gray-100);
  border: 1px solid var(--bpr-gray-200);
  border-radius: var(--bpr-radius);
  padding: 12px 16px;
  margin: 12px 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.bpr-fee-row {
  display: flex;
  justify-content: space-between;
  font-size: 14px;
  padding: 2px 0;
}
.bpr-fee-row--total {
  font-size: 18px;
  font-weight: 800;
  border-top: 2px solid var(--bpr-gray-200);
  padding-top: 8px;
  margin-top: 4px;
  color: var(--bpr-primary);
}

/* ─── Ball diamond add-ons ─────────────────────────────────── */
.bpr-diamond-addons {
  background: #fffbf0;
  border: 1.5px solid #f59e0b;
  border-radius: var(--bpr-radius);
  padding: 16px;
  margin: 12px 0;
}
.bpr-diamond-addons h3 {
  margin: 0 0 12px;
  font-size: 15px;
  color: #78350f;
  display: flex;
  align-items: center;
  gap: 6px;
}
.bpr-addons-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 10px;
}
.bpr-addon-card {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  background: #fff;
  border: 1.5px solid var(--bpr-gray-200);
  border-radius: var(--bpr-radius);
  cursor: pointer;
  transition: border-color .15s, background .15s;
  user-select: none;
  font-size: 13px;
}
.bpr-addon-card:has(input:checked) {
  border-color: #f59e0b;
  background: #fffbf0;
}
.bpr-addon-card input[type=checkbox] { margin: 0; flex-shrink: 0; }
.bpr-addon-icon { font-size: 18px; flex-shrink: 0; }
.bpr-addon-label { flex: 1; font-weight: 600; }
.bpr-addon-price { color: var(--bpr-primary); font-weight: 700; white-space: nowrap; }

/* ─── Cart review (multi-booking step 4) ──────────────────── */
.bpr-cart-review {
  background: var(--bpr-gray-100);
  border: 1px solid var(--bpr-gray-200);
  border-radius: var(--bpr-radius);
  padding: 14px 16px;
  margin-bottom: 16px;
}
.bpr-cart-review h3 { margin: 0 0 10px; font-size: 14px; color: var(--bpr-gray-600); }
.bpr-cart-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 0;
  border-bottom: 1px solid var(--bpr-gray-200);
  font-size: 13px;
}
.bpr-cart-item:last-child { border-bottom: none; }
.bpr-cart-item span { flex: 1; }

/* ─── Availability messages ────────────────────────────────── */
.bpr-avail--ok       { color: #27ae60; font-weight: 600; }
.bpr-avail--taken    { color: #c0392b; font-weight: 600; }
.bpr-avail--checking { color: var(--bpr-gray-600); font-style: italic; }

/* ─── Full facilities card (listing page) ─────────────────── */
.bpr-facility-grid--cards {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 24px;
}
.bpr-facility-card-full {
  border: 1px solid var(--bpr-gray-200);
  border-radius: var(--bpr-radius);
  background: #fff;
  box-shadow: var(--bpr-shadow);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: box-shadow .15s;
}
.bpr-facility-card-full:hover { box-shadow: var(--bpr-shadow-lg); }
.bpr-facility-card-full__gallery {
  display: grid;
  grid-template-columns: 2fr 1fr;
  grid-template-rows: repeat(2, 90px);
  gap: 2px;
  background: var(--bpr-gray-200);
}
.bpr-facility-img { width: 100%; height: 100%; object-fit: cover; display: block; }
.bpr-facility-img--main { grid-row: span 2; }
.bpr-facility-card-full__icon {
  font-size: 64px;
  text-align: center;
  padding: 24px;
  background: var(--bpr-gray-100);
}
.bpr-facility-card-full__body { padding: 18px; display: flex; flex-direction: column; gap: 10px; flex: 1; }
.bpr-facility-card-full__header { display: flex; justify-content: space-between; align-items: flex-start; gap: 8px; }
.bpr-facility-card-full__name { margin: 0; font-size: 20px; font-weight: 700; }
.bpr-facility-card-full__rate { display: flex; flex-direction: column; align-items: flex-end; gap: 2px; flex-shrink: 0; }
.bpr-rate-badge {
  background: var(--bpr-primary);
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  padding: 3px 8px;
  border-radius: 4px;
}
.bpr-rate-badge--free { background: var(--bpr-success); }
.bpr-rate-min, .bpr-capacity { font-size: 11px; color: var(--bpr-gray-600); }
.bpr-facility-card-full__desc { color: var(--bpr-gray-600); font-size: 14px; margin: 0; }
.bpr-facility-rules { border: 1px solid var(--bpr-gray-200); border-radius: 6px; padding: 0 12px; }
.bpr-facility-rules summary { cursor: pointer; padding: 8px 0; font-weight: 600; font-size: 13px; list-style: none; }
.bpr-facility-rules summary::-webkit-details-marker { display: none; }
.bpr-facility-rules summary::before { content: '▶ '; font-size: 10px; }
details[open] .bpr-facility-rules summary::before { content: '▼ '; }
.bpr-facility-rules__body { padding: 8px 0 12px; font-size: 13px; color: var(--bpr-gray-800); line-height: 1.7; }
.bpr-facility-card-full__actions { display: flex; gap: 8px; flex-wrap: wrap; margin-top: auto; }

/* ─── Facility type filter nav ─────────────────────────────── */
.bpr-facility-filter-nav {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 20px;
}
.bpr-filter-btn {
  padding: 7px 16px;
  border-radius: 20px;
  border: 1.5px solid var(--bpr-gray-200);
  background: #fff;
  color: var(--bpr-gray-800);
  text-decoration: none;
  font-size: 13px;
  font-weight: 600;
  transition: all .15s;
}
.bpr-filter-btn.active,
.bpr-filter-btn:hover {
  background: var(--bpr-primary);
  color: #fff;
  border-color: var(--bpr-primary);
}

/* ─── My Account page ─────────────────────────────────────── */
.bpr-my-account__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 24px;
  padding-bottom: 16px;
  border-bottom: 2px solid var(--bpr-gray-200);
}
.bpr-my-account__user { display: flex; align-items: center; gap: 14px; }
.bpr-my-account__avatar {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: var(--bpr-primary);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  font-weight: 800;
  flex-shrink: 0;
}
.bpr-my-account__actions { display: flex; gap: 8px; flex-wrap: wrap; }
.bpr-my-reservations { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 16px; }
.bpr-my-res-card {
  border: 1.5px solid var(--bpr-gray-200);
  border-radius: var(--bpr-radius);
  background: #fff;
  overflow: hidden;
}
.bpr-my-res-card--confirmed { border-left: 4px solid var(--bpr-success); }
.bpr-my-res-card--pending   { border-left: 4px solid var(--bpr-warning); }
.bpr-my-res-card--cancelled { border-left: 4px solid var(--bpr-danger); opacity: .7; }
.bpr-my-res-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 14px;
  background: var(--bpr-gray-100);
  border-bottom: 1px solid var(--bpr-gray-200);
}
.bpr-my-res-num { font-weight: 800; font-size: 13px; color: var(--bpr-gray-600); }
.bpr-my-res-body { padding: 12px 14px; font-size: 14px; }
.bpr-my-res-body p { margin: 3px 0; }
.bpr-my-res-footer {
  padding: 10px 14px;
  border-top: 1px solid var(--bpr-gray-200);
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
}
.bpr-my-res-fees { font-size: 13px; color: var(--bpr-gray-600); }
.bpr-my-res-links { display: flex; gap: 6px; flex-wrap: wrap; }
.bpr-success { color: var(--bpr-success); }
.bpr-warning { color: var(--bpr-warning); }

/* ─── Review summary (step 4) ─────────────────────────────── */
.bpr-review-summary { background: var(--bpr-gray-100); border-radius: var(--bpr-radius); padding: 14px; margin-bottom: 16px; }
.bpr-review-row { display: flex; gap: 12px; padding: 5px 0; border-bottom: 1px solid var(--bpr-gray-200); font-size: 14px; }
.bpr-review-row:last-child { border-bottom: none; }
.bpr-review-row span:first-child { color: var(--bpr-gray-600); min-width: 100px; }
.bpr-review-row--total { font-size: 17px; font-weight: 800; color: var(--bpr-primary); }

/* ─── Confirmation screen ─────────────────────────────────── */
.bpr-confirmation { text-align: center; padding: 32px 16px; }
.bpr-confirmation-icon { font-size: 64px; margin-bottom: 12px; }
.bpr-confirmation-nums { margin: 16px 0; }
.bpr-confirmation-num {
  display: inline-block;
  background: var(--bpr-primary);
  color: #fff;
  font-size: 18px;
  font-weight: 800;
  padding: 8px 20px;
  border-radius: 6px;
  margin: 4px;
}

/* ─── Mobile responsive ────────────────────────────────────── */
@media (max-width: 600px) {
  .bpr-facility-grid { grid-template-columns: 1fr; }
  .bpr-addons-grid   { grid-template-columns: 1fr 1fr; }
  .bpr-cart-bar__inner { flex-direction: column; align-items: flex-start; }
  .bpr-facility-card-full__gallery { grid-template-columns: 1fr; grid-template-rows: 180px; }
  .bpr-facility-img--main { grid-row: span 1; }
  .bpr-facility-img--thumb { display: none; }
}
