/* ===================================================================
   ProBook – Public Booking Form Styles
   =================================================================== */

/* ── Reset & Base ─────────────────────────────────────────────────── */
.probook-wrap *,
.probook-wrap *::before,
.probook-wrap *::after { box-sizing: border-box; margin: 0; padding: 0; }

.probook-wrap {
  font-family: var(--pb-font-b);
  font-size: var(--pb-font-size);
  color: var(--pb-text);
  background: var(--pb-bg);
  padding: 40px 20px 80px;
  min-height: 100vh;
}

/* ── Container ────────────────────────────────────────────────────── */
.pb-container {
  max-width: 820px;
  margin: 0 auto;
}

/* ── Progress Bar ─────────────────────────────────────────────────── */
.pb-progress {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  margin-bottom: 48px;
  position: relative;
}

.pb-progress-track {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  height: 2px;
  background: #e2e8f0;
  width: calc(100% - 80px);
  z-index: 0;
}

.pb-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--pb-primary), var(--pb-secondary));
  transition: width .5s ease;
  border-radius: 2px;
}

.pb-step-dot {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  flex: 1;
}

.pb-step-dot-inner {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: #fff;
  border: 2px solid #e2e8f0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--pb-font-h);
  font-weight: 700;
  font-size: 14px;
  color: #94a3b8;
  transition: all .35s ease;
  box-shadow: 0 2px 8px rgba(0,0,0,.06);
}

.pb-step-dot.active .pb-step-dot-inner {
  background: linear-gradient(135deg, var(--pb-primary), var(--pb-secondary));
  border-color: var(--pb-primary);
  color: #fff;
  box-shadow: 0 4px 16px rgba(79,70,229,.35);
  transform: scale(1.1);
}

.pb-step-dot.done .pb-step-dot-inner {
  background: var(--pb-primary);
  border-color: var(--pb-primary);
  color: #fff;
}

.pb-step-label {
  font-size: 11px;
  font-weight: 600;
  color: #94a3b8;
  letter-spacing: .05em;
  text-transform: uppercase;
  white-space: nowrap;
}

.pb-step-dot.active .pb-step-label { color: var(--pb-primary); }
.pb-step-dot.done  .pb-step-label  { color: var(--pb-primary); }

/* ── Card ─────────────────────────────────────────────────────────── */
.pb-card {
  background: var(--pb-card);
  border-radius: var(--pb-radius);
  box-shadow: 0 8px 40px rgba(0,0,0,.08), 0 2px 8px rgba(0,0,0,.04);
  overflow: hidden;
  animation: pbFadeUp .45s ease both;
}

@keyframes pbFadeUp {
  from { opacity: 0; transform: translateY(24px); }
  to   { opacity: 1; transform: translateY(0); }
}

.pb-card-header {
  background: linear-gradient(135deg, var(--pb-primary) 0%, var(--pb-secondary) 100%);
  padding: 32px 40px;
  position: relative;
  overflow: hidden;
}

.pb-card-header::before {
  content: '';
  position: absolute;
  width: 200px;
  height: 200px;
  background: rgba(255,255,255,.08);
  border-radius: 50%;
  top: -60px;
  right: -40px;
}

.pb-card-header::after {
  content: '';
  position: absolute;
  width: 120px;
  height: 120px;
  background: rgba(255,255,255,.06);
  border-radius: 50%;
  bottom: -30px;
  left: 30px;
}

.pb-card-header h2 {
  font-family: var(--pb-font-h);
  font-size: 22px;
  font-weight: 800;
  color: #fff;
  position: relative;
  z-index: 1;
}

.pb-card-header p {
  font-size: 14px;
  color: rgba(255,255,255,.8);
  margin-top: 6px;
  position: relative;
  z-index: 1;
}

.pb-step-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(255,255,255,.2);
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  padding: 4px 12px;
  border-radius: 20px;
  margin-bottom: 12px;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.pb-card-body {
  padding: 40px;
}

/* ── Form Fields ──────────────────────────────────────────────────── */
.pb-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}

.pb-form-grid.pb-cols-1 { grid-template-columns: 1fr; }

.pb-field {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.pb-field.pb-span-2 { grid-column: span 2; }

.pb-label {
  font-size: 13px;
  font-weight: 600;
  color: #475569;
  letter-spacing: .03em;
}

.pb-label .req { color: var(--pb-primary); margin-left: 2px; }

.pb-input,
.pb-select,
.pb-textarea {
  width: 100%;
  padding: 12px 16px;
  border: 2px solid #e2e8f0;
  border-radius: calc(var(--pb-radius) * 0.625);
  font-family: var(--pb-font-b);
  font-size: 15px;
  color: var(--pb-text);
  background: var(--pb-bg);
  transition: border-color .2s, box-shadow .2s;
  outline: none;
}

.pb-input:focus,
.pb-select:focus,
.pb-textarea:focus {
  border-color: var(--pb-primary);
  box-shadow: 0 0 0 4px rgba(79,70,229,.12);
}

.pb-input.error,
.pb-select.error { border-color: #ef4444; }

.pb-textarea { resize: vertical; min-height: 100px; }

.pb-error-msg {
  font-size: 12px;
  color: #ef4444;
  margin-top: -4px;
}

/* ── Buttons ──────────────────────────────────────────────────────── */
.pb-btn {
  display: inline-flex;
  align-items: center;
  flex-direction: row !important;
  flex-wrap: nowrap;
  justify-content: center;
  gap: 8px;
  padding: 14px 32px;
  border-radius: var(--pb-btn-radius);
  font-family: var(--pb-font-h);
  font-size: 15px;
  font-weight: 700;
  cursor: pointer;
  transition: all .2s ease;
  border: none;
  letter-spacing: .02em;
  white-space: nowrap;
  line-height: 1;
}

/* Ensure icon inside button never causes a column layout */
.pb-btn i,
.pb-btn .fas,
.pb-btn .fab,
.pb-btn .far {
  display: inline-block;
  flex-shrink: 0;
  line-height: 1;
}

.pb-btn-primary {
  background: linear-gradient(135deg, var(--pb-primary), var(--pb-secondary));
  color: #fff;
  box-shadow: 0 4px 16px rgba(79,70,229,.35);
}

.pb-btn-primary:hover {
  background: linear-gradient(135deg, #3730a3, #6d28d9);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(79,70,229,.45);
  color: #fff;
}

.pb-btn-primary:active { transform: translateY(0); }

.pb-btn-outline {
  background: transparent;
  color: var(--pb-primary);
  border: 2px solid var(--pb-primary);
}

.pb-btn-outline:hover {
  background: var(--pb-primary);
  color: #fff;
}

.pb-btn-ghost {
  background: #f1f5f9;
  color: #64748b;
}

.pb-btn-ghost:hover { background: #e2e8f0; }

.pb-btn:disabled {
  opacity: .5;
  cursor: not-allowed;
  transform: none !important;
}

.pb-btn-loading .pb-spinner {
  width: 18px;
  height: 18px;
  border: 2px solid rgba(255,255,255,.4);
  border-top-color: #fff;
  border-radius: 50%;
  animation: pbSpin .6s linear infinite;
}

@keyframes pbSpin { to { transform: rotate(360deg); } }

/* ── Footer Nav ───────────────────────────────────────────────────── */
.pb-footer-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 24px 40px;
  border-top: 1px solid #f1f5f9;
  background: #fafbfc;
}

/* ── Property Type Cards (Step 2) ─────────────────────────────────── */
.pb-prop-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-bottom: 28px;
}

.pb-prop-card {
  border: 2px solid #e2e8f0;
  border-radius: var(--pb-radius);
  padding: 28px 24px;
  cursor: pointer;
  transition: all .25s ease;
  text-align: center;
}

.pb-prop-card:hover {
  border-color: var(--pb-primary);
  box-shadow: 0 4px 16px rgba(79,70,229,.12);
}

.pb-prop-card.selected {
  border-color: var(--pb-primary);
  background: linear-gradient(135deg, rgba(79,70,229,.06), rgba(124,58,237,.06));
  box-shadow: 0 4px 16px rgba(79,70,229,.15);
}

.pb-prop-card-icon {
  width: 64px;
  height: 64px;
  border-radius: 16px;
  background: linear-gradient(135deg, var(--pb-primary), var(--pb-secondary));
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 16px;
  font-size: 24px;
  color: #fff;
}

.pb-prop-card h3 {
  font-family: var(--pb-font-h);
  font-size: 16px;
  font-weight: 700;
  color: var(--pb-text);
  margin-bottom: 6px;
}

.pb-prop-card p {
  font-size: 13px;
  color: #64748b;
}

/* Sub-options */
.pb-sub-options {
  display: none;
  animation: pbFadeUp .3s ease;
}

.pb-sub-options.visible { display: block; }

.pb-radio-group {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.pb-radio-chip {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  border: 2px solid #e2e8f0;
  border-radius: 40px;
  cursor: pointer;
  font-size: 14px;
  font-weight: 500;
  transition: all .2s;
  color: #475569;
}

.pb-radio-chip input[type="radio"] { display: none; }

.pb-radio-chip:hover { border-color: var(--pb-primary); color: var(--pb-primary); }

.pb-radio-chip.selected {
  border-color: var(--pb-primary);
  background: var(--pb-primary);
  color: #fff;
}

/* ── Service Category Cards (Step 3) ──────────────────────────────── */
.pb-cat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 20px;
  margin-bottom: 32px;
}

.pb-cat-card {
  border: 2px solid #e2e8f0;
  border-radius: var(--pb-radius);
  padding: 28px 20px;
  cursor: pointer;
  transition: all .25s ease;
  text-align: center;
  position: relative;
  overflow: hidden;
}

.pb-cat-card::before {
  content: '';
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity .25s;
}

.pb-cat-card:hover { transform: translateY(-4px); }
.pb-cat-card:hover::before { opacity: 1; }

.pb-cat-card.selected {
  border-color: var(--pb-primary);
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(79,70,229,.2);
}

.pb-cat-icon {
  width: 72px;
  height: 72px;
  border-radius: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 16px;
  font-size: 28px;
  color: #fff;
  transition: transform .25s;
}

.pb-cat-card:hover .pb-cat-icon { transform: scale(1.1) rotate(-5deg); }

.pb-cat-card h3 {
  font-family: var(--pb-font-h);
  font-size: 15px;
  font-weight: 700;
  color: var(--pb-text);
  margin-bottom: 6px;
}

.pb-cat-card p {
  font-size: 12px;
  color: #94a3b8;
}

.pb-cat-badge {
  position: absolute;
  top: 12px;
  right: 12px;
  background: var(--pb-primary);
  color: #fff;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  font-size: 11px;
  font-weight: 700;
  display: none;
  align-items: center;
  justify-content: center;
}

.pb-cat-card.selected .pb-cat-badge { display: flex; }

/* ── Selected Services Summary ───────────────────────────────────── */
.pb-selected-summary {
  border: 2px solid #e2e8f0;
  border-radius: var(--pb-radius);
  overflow: hidden;
  display: none;
  animation: pbFadeUp .35s ease;
}

.pb-selected-summary.visible { display: block; }

.pb-summary-header {
  background: linear-gradient(135deg, var(--pb-primary), var(--pb-secondary));
  padding: 16px 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.pb-summary-header h4 {
  font-family: var(--pb-font-h);
  font-size: 14px;
  font-weight: 700;
  color: #fff;
}

.pb-summary-header .pb-total-chip {
  background: rgba(255,255,255,.25);
  color: #fff;
  padding: 4px 12px;
  border-radius: 20px;
  font-size: 14px;
  font-weight: 700;
}

.pb-summary-items { padding: 16px 24px; }

.pb-summary-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 0;
  border-bottom: 1px solid #f1f5f9;
  font-size: 14px;
}

.pb-summary-item:last-child { border-bottom: none; }

.pb-summary-item-name { color: #475569; flex: 1; }

.pb-summary-item-price {
  font-weight: 700;
  color: var(--pb-primary);
  margin-right: 12px;
}

.pb-summary-item-remove {
  color: #94a3b8;
  cursor: pointer;
  padding: 4px;
  border-radius: 6px;
  transition: color .2s, background .2s;
  border: none;
  background: none;
  font-size: 14px;
}

.pb-summary-item-remove:hover { color: #ef4444; background: #fee2e2; }

/* ── Modal (Service Picker) ───────────────────────────────────────── */
.pb-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.5);
  z-index: 99999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  opacity: 0;
  visibility: hidden;
  transition: all .3s ease;
  backdrop-filter: blur(4px);
}

.pb-modal-overlay.open {
  opacity: 1;
  visibility: visible;
}

.pb-modal {
  background: var(--pb-card);
  border-radius: var(--pb-radius);
  width: 100%;
  max-width: 640px;
  max-height: 85vh;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: 0 24px 64px rgba(0,0,0,.25);
  transform: scale(.95) translateY(20px);
  transition: transform .3s ease;
}

.pb-modal-overlay.open .pb-modal {
  transform: scale(1) translateY(0);
}

.pb-modal-header {
  padding: 24px 28px;
  background: linear-gradient(135deg, var(--pb-primary), var(--pb-secondary));
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.pb-modal-header h3 {
  font-family: var(--pb-font-h);
  font-size: 18px;
  font-weight: 800;
  color: #fff;
}

.pb-modal-close {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  background: rgba(255,255,255,.2);
  border: none;
  color: #fff;
  font-size: 18px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .2s;
}

.pb-modal-close:hover { background: rgba(255,255,255,.35); }

.pb-modal-body {
  padding: 24px 28px;
  overflow-y: auto;
  flex: 1;
}

.pb-service-group { margin-bottom: 24px; }

.pb-service-group-title {
  font-family: var(--pb-font-h);
  font-size: 13px;
  font-weight: 700;
  color: #94a3b8;
  letter-spacing: .08em;
  text-transform: uppercase;
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.pb-service-group-title::after {
  content: '';
  flex: 1;
  height: 1px;
  background: #f1f5f9;
}

.pb-service-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 16px;
  border: 2px solid #e2e8f0;
  border-radius: 12px;
  margin-bottom: 8px;
  cursor: pointer;
  transition: all .2s ease;
}

.pb-service-item:hover { border-color: var(--pb-primary); background: rgba(79,70,229,.04); }

.pb-service-item.selected {
  border-color: var(--pb-primary);
  background: linear-gradient(135deg, rgba(79,70,229,.08), rgba(124,58,237,.08));
}

.pb-service-item-check {
  width: 24px;
  height: 24px;
  border-radius: 8px;
  border: 2px solid #e2e8f0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  color: transparent;
  transition: all .2s;
  flex-shrink: 0;
  margin-right: 12px;
}

.pb-service-item.selected .pb-service-item-check {
  background: var(--pb-primary);
  border-color: var(--pb-primary);
  color: #fff;
}

.pb-service-item-name {
  font-size: 14px;
  font-weight: 500;
  color: var(--pb-text);
  flex: 1;
}

.pb-service-item-desc {
  font-size: 12px;
  color: #94a3b8;
  margin-top: 2px;
}

.pb-service-item-price {
  font-family: var(--pb-font-h);
  font-size: 16px;
  font-weight: 700;
  color: var(--pb-primary);
  flex-shrink: 0;
}

.pb-modal-footer {
  padding: 20px 28px;
  border-top: 1px solid #f1f5f9;
  display: flex;
  justify-content: flex-end;
}

/* ── Calendar (Step 4) ────────────────────────────────────────────── */
.pb-calendar-wrap {
  border: 2px solid #e2e8f0;
  border-radius: var(--pb-radius);
  overflow: hidden;
  margin-bottom: 28px;
}

.pb-cal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 24px;
  background: linear-gradient(135deg, var(--pb-primary), var(--pb-secondary));
}

.pb-cal-nav {
  background: rgba(255,255,255,.2);
  border: none;
  color: #fff;
  width: 36px;
  height: 36px;
  border-radius: 10px;
  cursor: pointer;
  font-size: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .2s;
}

.pb-cal-nav:hover { background: rgba(255,255,255,.35); }

.pb-cal-title {
  font-family: var(--pb-font-h);
  font-size: 18px;
  font-weight: 800;
  color: #fff;
}

.pb-cal-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  background: var(--pb-card);
}

.pb-cal-dow {
  padding: 14px 4px;
  text-align: center;
  font-size: 12px;
  font-weight: 700;
  color: #94a3b8;
  letter-spacing: .06em;
  text-transform: uppercase;
  border-bottom: 2px solid #f1f5f9;
}

.pb-cal-day {
  padding: 12px 4px;
  text-align: center;
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  transition: all .2s;
  border-bottom: 1px solid #f8fafc;
  position: relative;
  color: var(--pb-text);
}

.pb-cal-day:hover:not(.disabled):not(.empty) {
  background: rgba(79,70,229,.08);
  color: var(--pb-primary);
  font-weight: 700;
}

.pb-cal-day.selected {
  background: linear-gradient(135deg, var(--pb-primary), var(--pb-secondary));
  color: #fff;
  font-weight: 700;
  border-radius: 8px;
}

.pb-cal-day.today {
  font-weight: 800;
}

.pb-cal-day.today::after {
  content: '';
  position: absolute;
  bottom: 4px;
  left: 50%;
  transform: translateX(-50%);
  width: 4px;
  height: 4px;
  background: var(--pb-primary);
  border-radius: 50%;
}

.pb-cal-day.selected.today::after { background: rgba(255,255,255,.7); }

.pb-cal-day.disabled {
  color: #cbd5e1;
  cursor: not-allowed;
  background: none;
}

.pb-cal-day.has-bookings::before {
  content: '';
  position: absolute;
  top: 4px;
  right: 6px;
  width: 6px;
  height: 6px;
  background: var(--pb-accent);
  border-radius: 50%;
}

.pb-cal-day.empty { cursor: default; }

/* ── Time Slots ───────────────────────────────────────────────────── */
.pb-timeslots {
  display: none;
  animation: pbFadeUp .35s ease;
}

.pb-timeslots.visible { display: block; }

.pb-timeslots-header {
  font-family: var(--pb-font-h);
  font-size: 15px;
  font-weight: 700;
  color: var(--pb-text);
  margin-bottom: 16px;
}

.pb-timeslots-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 12px;
}

.pb-slot {
  border: 2px solid #e2e8f0;
  border-radius: 12px;
  padding: 14px 16px;
  cursor: pointer;
  transition: all .2s;
  display: flex;
  align-items: center;
  gap: 12px;
}

.pb-slot:hover:not(.unavailable) {
  border-color: var(--pb-primary);
  background: rgba(79,70,229,.04);
}

.pb-slot.selected {
  border-color: var(--pb-primary);
  background: linear-gradient(135deg, rgba(79,70,229,.1), rgba(124,58,237,.1));
}

.pb-slot.unavailable {
  opacity: .45;
  cursor: not-allowed;
  background: #f8fafc;
}

.pb-slot-icon {
  font-size: 18px;
  color: var(--pb-primary);
  opacity: .7;
}

.pb-slot-info { flex: 1; }

.pb-slot-time {
  font-size: 14px;
  font-weight: 600;
  color: var(--pb-text);
}

.pb-slot-avail {
  font-size: 11px;
  color: #94a3b8;
  margin-top: 2px;
}

.pb-slot.selected .pb-slot-time { color: var(--pb-primary); }
.pb-slot.selected .pb-slot-avail { color: var(--pb-secondary); }

/* ── Payment (Step 5) ─────────────────────────────────────────────── */
.pb-order-summary {
  background: linear-gradient(135deg, rgba(79,70,229,.06), rgba(124,58,237,.06));
  border: 2px solid rgba(79,70,229,.15);
  border-radius: 16px;
  padding: 24px;
  margin-bottom: 28px;
}

.pb-order-summary h4 {
  font-family: var(--pb-font-h);
  font-size: 16px;
  font-weight: 800;
  color: var(--pb-text);
  margin-bottom: 16px;
}

.pb-order-row {
  display: flex;
  justify-content: space-between;
  font-size: 14px;
  color: #475569;
  margin-bottom: 8px;
}

.pb-order-total-row {
  display: flex;
  justify-content: space-between;
  font-size: 20px;
  font-weight: 800;
  color: var(--pb-primary);
  margin-top: 16px;
  padding-top: 16px;
  border-top: 2px solid rgba(79,70,229,.15);
}

.pb-payment-section {
  border: 2px solid #e2e8f0;
  border-radius: 16px;
  overflow: hidden;
  margin-bottom: 24px;
}

.pb-payment-section-header {
  padding: 16px 20px;
  background: #f8fafc;
  border-bottom: 2px solid #e2e8f0;
  font-size: 13px;
  font-weight: 700;
  color: #64748b;
  letter-spacing: .05em;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: 8px;
}

.pb-payment-section-body { padding: 20px; }

#pb-stripe-element {
  border: 2px solid #e2e8f0;
  border-radius: 10px;
  padding: 14px 16px;
  transition: border-color .2s;
}

#pb-stripe-element.StripeElement--focus { border-color: var(--pb-primary); }

.pb-stripe-secure {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: #94a3b8;
  margin-top: 10px;
}

/* ── Success Screen ───────────────────────────────────────────────── */
.pb-success-screen {
  text-align: center;
  padding: 60px 40px;
  animation: pbFadeUp .5s ease;
}

.pb-success-icon {
  width: 100px;
  height: 100px;
  border-radius: 50%;
  background: linear-gradient(135deg, #22c55e, #16a34a);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 28px;
  font-size: 42px;
  color: #fff;
  box-shadow: 0 12px 32px rgba(34,197,94,.35);
  animation: pbBounce .6s .3s ease both;
}

@keyframes pbBounce {
  0%   { transform: scale(0); }
  60%  { transform: scale(1.15); }
  100% { transform: scale(1); }
}

.pb-success-ref {
  display: inline-block;
  background: linear-gradient(135deg, var(--pb-primary), var(--pb-secondary));
  color: #fff;
  padding: 8px 24px;
  border-radius: 40px;
  font-family: var(--pb-font-h);
  font-size: 16px;
  font-weight: 800;
  letter-spacing: .05em;
  margin-bottom: 20px;
}

.pb-success-screen h2 {
  font-family: var(--pb-font-h);
  font-size: 28px;
  font-weight: 800;
  color: var(--pb-text);
  margin-bottom: 12px;
}

.pb-success-screen p {
  font-size: 16px;
  color: #64748b;
  max-width: 440px;
  margin: 0 auto;
  line-height: 1.6;
}

/* ── Alert ────────────────────────────────────────────────────────── */
.pb-alert {
  padding: 14px 18px;
  border-radius: 12px;
  font-size: 14px;
  font-weight: 500;
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 20px;
  display: none;
}

.pb-alert.visible { display: flex; }
.pb-alert.error   { background: #fee2e2; color: #991b1b; border: 1px solid #fca5a5; }
.pb-alert.success { background: #dcfce7; color: #166534; border: 1px solid #86efac; }

/* ── Responsive ───────────────────────────────────────────────────── */
@media (max-width: 640px) {
  .pb-card-header { padding: 24px 24px; }
  .pb-card-body   { padding: 24px; }
  .pb-footer-nav  { padding: 20px 24px; flex-direction: column; gap: 12px; }
  .pb-footer-nav .pb-btn { width: 100%; }
  .pb-form-grid   { grid-template-columns: 1fr; }
  .pb-field.pb-span-2 { grid-column: span 1; }
  .pb-prop-cards  { grid-template-columns: 1fr; }
  .pb-cat-grid    { grid-template-columns: 1fr 1fr; }
  .pb-progress    { gap: 0; }
  .pb-step-label  { display: none; }
}

/* ── Extras / Parking / Addons (v2) ────────────────────────────── */
.pb-extras-section{margin-top:20px;padding:20px;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:14px}
.pb-extras-question{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.pb-extras-num{width:26px;height:26px;border-radius:50%;background:var(--pb-primary);color:#fff;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.pb-extras-question label{font-weight:600;font-size:15px;color:var(--pb-text);margin:0}
.pb-yn-buttons{display:flex;gap:12px;margin-bottom:4px}
.pb-yn-btn{flex:1;padding:12px 0;border:2px solid #e2e8f0;border-radius:10px;background:#fff;font-size:14px;font-weight:700;cursor:pointer;color:#64748b;transition:all .2s;letter-spacing:.5px}
.pb-yn-btn.active.pb-yn-yes{border-color:#10b981;background:#ecfdf5;color:#059669}
.pb-yn-btn.active.pb-yn-no{border-color:#ef4444;background:#fef2f2;color:#dc2626}
.pb-yn-btn:hover{transform:translateY(-1px)}
.pb-extras-checks{display:flex;flex-direction:column;gap:12px;margin-top:4px}
.pb-check-item{display:flex;align-items:flex-start;gap:12px;cursor:pointer;padding:10px 14px;border:1.5px solid #e2e8f0;border-radius:10px;background:#fff;transition:border-color .2s}
.pb-check-item:hover{border-color:var(--pb-primary)}
.pb-check-item input[type=checkbox]{display:none}
.pb-check-box{position:relative;width:22px;height:22px;flex-shrink:0;margin-top:1px}
.pb-check-box input[type=checkbox]{position:absolute;inset:0;opacity:0;width:100%;height:100%;margin:0;cursor:pointer;z-index:2}
.pb-check-mark{position:absolute;inset:0;width:22px;height:22px;border:2px solid #cbd5e1;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s;background:#fff;pointer-events:none}
.pb-check-mark i{color:#fff;font-size:11px;opacity:0;transition:opacity .2s}
.pb-check-box input[type=checkbox]:checked~.pb-check-mark{background:var(--pb-primary);border-color:var(--pb-primary)}
.pb-check-box input[type=checkbox]:checked~.pb-check-mark i{opacity:1}
.pb-check-label{font-size:14px;color:var(--pb-text);line-height:1.5;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.pb-info-tip{color:#94a3b8;cursor:help}
.pb-info-tip:hover{color:var(--pb-primary)}

/* Keyholder form */
.pb-keyholder-form{margin-top:16px;padding:18px;background:#fff;border:1.5px solid var(--pb-primary);border-radius:12px}
.pb-keyholder-title{display:flex;align-items:center;gap:8px;font-weight:700;font-size:14px;color:var(--pb-primary);margin-bottom:16px}

/* Single-selection badge */
.pb-single-badge{display:inline-flex;align-items:center;padding:2px 8px;background:#f0fdf4;color:#16a34a;border:1px solid #bbf7d0;border-radius:20px;font-size:11px;font-weight:600;margin-left:8px}

/* Payment info boxes */
.pb-payment-info-box{display:flex;gap:14px;padding:16px;background:#eff6ff;border:1.5px solid #bfdbfe;border-radius:12px;font-size:14px;color:#1e40af;line-height:1.6}
.pb-payment-info-box i{font-size:18px;margin-top:2px;flex-shrink:0}
.pb-payment-info-box p{margin:0}
.pb-bank-details{margin:10px 0 0;background:#dbeafe;border-radius:8px;padding:12px;font-family:'Courier New',monospace;font-size:13px;color:#1e3a8a;white-space:pre-wrap;word-break:break-word}

/* Success payment note */
.pb-success-payment-note{display:flex;align-items:flex-start;gap:10px;margin-top:16px;padding:14px 16px;background:#f0fdf4;border:1.5px solid #bbf7d0;border-radius:12px;font-size:14px;color:#166534;text-align:left;line-height:1.5}
.pb-success-payment-note i{font-size:16px;margin-top:1px;flex-shrink:0}

/* Order summary extras */
.pb-order-extras span:first-child{color:#64748b;font-style:italic}
.pb-order-extras span:last-child{color:#ef4444;font-weight:600}

/* Category card selection state */
.pb-cat-card.has-selection{border-color:var(--pb-primary)}
.pb-cat-badge.has-items{background:var(--pb-primary);color:#fff}

/* Payment method tabs */
.pb-pay-tabs{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}
.pb-pay-tab{display:flex;align-items:center;gap:8px;padding:10px 18px;border:1.5px solid var(--pb-border,#e2e8f0);border-radius:calc(var(--pb-btn-radius,12px));background:#fff;color:#64748b;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;font-family:inherit}
.pb-pay-tab:hover{border-color:var(--pb-primary);color:var(--pb-primary)}
.pb-pay-tab.active{border-color:var(--pb-primary);background:var(--pb-primary);color:#fff;box-shadow:0 4px 12px color-mix(in srgb,var(--pb-primary) 30%,transparent)}


/* Extras checks: collapse to 1 col on small screens */
@media (max-width: 540px) {
  .pb-extras-checks {
    grid-template-columns: 1fr !important;
  }
}


/* ── Always-visible addon checkboxes ─────────────────────────────── */
.pb-addons-always {
  display: block !important;
  margin-top: 20px;
}

/* Price badge inside label */
.pb-addon-price {
  display: inline-flex;
  align-items: center;
  padding: 1px 8px;
  background: #f0fdf4;
  color: #16a34a;
  border: 1px solid #bbf7d0;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 700;
  margin-left: 4px;
  white-space: nowrap;
}

/* Highlight whole row when checked */
.pb-check-item:has(input[type=checkbox]:checked) {
  border-color: var(--pb-primary);
  background: #fafaff;
}

/* ══════════════════════════════════════════════════════════════════
   PUBLIC BOOKING FORM – MOBILE RESPONSIVE
   ══════════════════════════════════════════════════════════════════ */

/* Booking wrapper – full width on mobile */
@media (max-width: 600px) {
  .pb-wrap {
    padding: 0 4px;
  }

  /* Progress bar label text */
  .pb-step-label {
    font-size: 10px;
  }

  /* Header */
  .pb-form-header {
    padding: 16px 16px 14px;
  }
  .pb-form-title {
    font-size: 17px;
  }

  /* Step body */
  .pb-step-body {
    padding: 16px 14px;
  }

  /* Category cards – single column */
  .pb-cat-grid,
  .pb-service-grid {
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }

  /* Service / option cards – full row */
  .pb-svc-card,
  .pb-cat-card {
    padding: 12px 14px !important;
  }

  /* Calendars: shrink day cells */
  .pb-cal-day {
    width: 36px !important;
    height: 36px !important;
    font-size: 13px !important;
  }
  .pb-cal-header {
    padding: 10px 12px !important;
  }

  /* Timeslot grid – 2 columns */
  .pb-slots-grid {
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
  }

  /* Address form grids – single column */
  .pb-form-grid-2,
  .pb-address-grid {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }

  /* Order summary table */
  .pb-order-table td:first-child {
    max-width: 130px;
    word-break: break-word;
  }

  /* Payment tabs wrap */
  .pb-pay-tabs {
    flex-direction: column;
    gap: 8px;
  }
  .pb-pay-tab {
    width: 100%;
    justify-content: center;
  }

  /* Step nav buttons */
  .pb-step-nav {
    flex-direction: row;
    gap: 10px;
    flex-wrap: wrap;
  }

  /* Success screen */
  .pb-success-icon {
    width: 64px !important;
    height: 64px !important;
    font-size: 26px !important;
  }
}

/* Medium tablets */
@media (max-width: 860px) and (min-width: 601px) {
  .pb-cat-grid,
  .pb-service-grid {
    grid-template-columns: 1fr 1fr !important;
  }
  .pb-slots-grid {
    grid-template-columns: repeat(3, 1fr) !important;
  }
}
.pb-check-item:has(input[type=checkbox]:checked) .pb-check-box{background:var(--pb-primary);border-color:var(--pb-primary)}
.pb-check-item:has(input[type=checkbox]:checked) .pb-check-box i{color:#fff;opacity:1}