:root {
  --rv-booking-green: #213a32;
  --rv-booking-cream: #f7f4ef;
  --rv-booking-soft: #edf3ee;
  --rv-booking-ink: #182522;
  --rv-booking-muted: rgba(24, 37, 34, 0.68);
  --rv-booking-line: rgba(24, 37, 34, 0.14);
  --rv-booking-card: rgba(255, 255, 255, 0.94);
  --rv-booking-shadow: 0 28px 80px rgba(8, 20, 18, 0.22);
}

.rv-booking-overlay,
.rv-booking-overlay *,
.rv-booking-page-shell,
.rv-booking-page-shell * {
  box-sizing: border-box;
}

.rv-booking-open { overflow: hidden; }

.rv-booking-overlay {
  position: fixed;
  inset: 0;
  z-index: 99980;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 18px;
  background: rgba(14, 28, 24, 0.58);
  backdrop-filter: blur(10px);
}

.rv-booking-overlay.is-open { display: flex; }

.rv-booking-modal {
  width: min(980px, 100%);
  max-height: min(880px, calc(100vh - 28px));
  overflow: hidden;
  border-radius: 32px;
  background:
    radial-gradient(circle at 20% 0%, rgba(223, 237, 226, 0.96), transparent 34rem),
    linear-gradient(135deg, #fffaf2 0%, #f8f5ee 42%, #edf3ee 100%);
  color: var(--rv-booking-ink);
  box-shadow: var(--rv-booking-shadow);
  border: 1px solid rgba(255,255,255,0.64);
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

.rv-booking-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 24px 26px 16px;
  border-bottom: 1px solid var(--rv-booking-line);
}

.rv-booking-brand {
  display: flex;
  align-items: center;
  gap: 12px;
}

.rv-booking-mark {
  width: 48px;
  height: 48px;
  border-radius: 999px;
  background: var(--rv-booking-green);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: 30px;
  font-weight: 700;
  box-shadow: 0 16px 34px rgba(33, 58, 50, 0.25);
}

.rv-booking-kicker {
  display: block;
  margin: 0 0 3px;
  color: var(--rv-booking-muted);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-weight: 800;
}

.rv-booking-title {
  margin: 0;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(30px, 5vw, 46px);
  line-height: 0.95;
  color: var(--rv-booking-green);
}

.rv-booking-close {
  border: 0;
  width: 44px;
  height: 44px;
  border-radius: 999px;
  background: rgba(33, 58, 50, 0.10);
  color: var(--rv-booking-green);
  font-size: 26px;
  line-height: 1;
  cursor: pointer;
}

.rv-booking-body {
  max-height: calc(100vh - 190px);
  overflow-y: auto;
  overflow-x: hidden;
  padding: 18px 26px 26px;
}

.rv-booking-flow {
  border: 1px solid var(--rv-booking-line);
  border-radius: 24px;
  padding: 14px;
  margin-bottom: 18px;
  background: rgba(255,255,255,0.58);
  box-shadow: 0 12px 30px rgba(8,20,18,0.05);
}

.rv-booking-flow-top {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: baseline;
  margin-bottom: 10px;
}

.rv-booking-flow-label {
  color: var(--rv-booking-muted);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.rv-booking-flow-current {
  color: var(--rv-booking-green);
  font-size: 14px;
  font-weight: 900;
  text-align: right;
}

.rv-booking-progress-track {
  height: 6px;
  border-radius: 999px;
  overflow: hidden;
  background: rgba(33, 58, 50, 0.12);
  margin-bottom: 12px;
}

.rv-booking-progress-track span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: var(--rv-booking-green);
  transition: width 220ms ease;
}

.rv-booking-steps {
  list-style: none;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin: 0;
  padding: 0;
}

.rv-booking-step {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--rv-booking-muted);
  font-size: 12px;
  font-weight: 900;
}

.rv-booking-step-number {
  flex: 0 0 auto;
  width: 28px;
  height: 28px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--rv-booking-line);
  background: rgba(255,255,255,0.86);
  color: var(--rv-booking-muted);
  font-size: 12px;
  font-weight: 900;
}

.rv-booking-step-label {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.rv-booking-step.is-active .rv-booking-step-number {
  background: var(--rv-booking-green);
  color: #fff;
  border-color: var(--rv-booking-green);
  box-shadow: 0 10px 22px rgba(33, 58, 50, 0.22);
}

.rv-booking-step.is-active .rv-booking-step-label {
  color: var(--rv-booking-green);
}

.rv-booking-step.is-complete .rv-booking-step-number {
  background: rgba(33, 58, 50, 0.13);
  color: var(--rv-booking-green);
  border-color: rgba(33, 58, 50, 0.22);
}


.rv-booking-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.rv-booking-grid.two { grid-template-columns: repeat(2, minmax(0, 1fr)); }

.rv-booking-card {
  border: 1px solid var(--rv-booking-line);
  border-radius: 24px;
  padding: 18px;
  background: var(--rv-booking-card);
  box-shadow: 0 16px 38px rgba(8,20,18,0.07);
  cursor: pointer;
  text-align: left;
  color: inherit;
  transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease;
}

.rv-booking-card:hover,
.rv-booking-card:focus {
  transform: translateY(-2px);
  box-shadow: 0 24px 46px rgba(8,20,18,0.12);
  border-color: rgba(33, 58, 50, 0.32);
  outline: none;
}

.rv-booking-card strong {
  display: block;
  font-size: 18px;
  color: var(--rv-booking-green);
  margin-bottom: 6px;
}

.rv-booking-card span,
.rv-booking-card p {
  color: var(--rv-booking-muted);
  font-size: 14px;
  margin: 0;
}

.rv-booking-price {
  display: inline-flex;
  margin-top: 12px;
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(33, 58, 50, 0.08);
  color: var(--rv-booking-green) !important;
  font-weight: 800;
  font-size: 13px !important;
}

.rv-booking-panel {
  border: 1px solid var(--rv-booking-line);
  border-radius: 26px;
  padding: 18px;
  background: rgba(255,255,255,0.76);
}

.rv-booking-panel h3 {
  margin: 0 0 8px;
  color: var(--rv-booking-green);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: 32px;
}

.rv-booking-muted { color: var(--rv-booking-muted); }

.rv-booking-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.rv-booking-form-grid > *,
.rv-booking-summary > *,
.rv-booking-grid > *,
.rv-booking-slots > * {
  min-width: 0;
}

.rv-booking-field label {
  display: block;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--rv-booking-muted);
  margin-bottom: 6px;
}

.rv-booking-field input,
.rv-booking-field textarea,
.rv-booking-field select {
  width: 100%;
  min-width: 0;
  max-width: 100%;
  border: 1px solid var(--rv-booking-line);
  border-radius: 16px;
  background: rgba(255,255,255,0.86);
  color: var(--rv-booking-ink);
  padding: 12px 13px;
  font: inherit;
}

.rv-booking-field textarea { min-height: 92px; resize: vertical; }
.rv-booking-field.full { grid-column: 1 / -1; }

.rv-booking-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 18px;
}

.rv-booking-btn,
.rv-booking-btn-secondary {
  border: 0;
  border-radius: 999px;
  padding: 12px 18px;
  font-weight: 900;
  cursor: pointer;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

.rv-booking-btn {
  background: var(--rv-booking-green);
  color: #fff;
  box-shadow: 0 14px 30px rgba(33, 58, 50, 0.22);
}

.rv-booking-btn-secondary {
  background: rgba(33, 58, 50, 0.10);
  color: var(--rv-booking-green);
}

.rv-booking-btn:disabled,
.rv-booking-btn-secondary:disabled,
.rv-booking-card:disabled {
  opacity: 0.55;
  cursor: not-allowed;
  transform: none;
}

.rv-booking-slots {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-top: 14px;
}

.rv-booking-slot {
  border: 1px solid var(--rv-booking-line);
  border-radius: 999px;
  background: rgba(255,255,255,0.84);
  padding: 11px 10px;
  color: var(--rv-booking-green);
  font-weight: 900;
  cursor: pointer;
}

.rv-booking-slot.is-selected {
  background: var(--rv-booking-green);
  color: #fff;
  border-color: var(--rv-booking-green);
}

.rv-booking-summary {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 10px;
  margin: 12px 0 16px;
}

.rv-booking-summary div {
  border: 1px solid var(--rv-booking-line);
  border-radius: 18px;
  padding: 12px;
  background: rgba(255,255,255,0.66);
}

.rv-booking-summary small {
  display:block;
  color: var(--rv-booking-muted);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .11em;
  font-size: 11px;
  margin-bottom: 4px;
}

.rv-booking-notice {
  border-radius: 20px;
  padding: 14px 16px;
  background: rgba(33, 58, 50, 0.09);
  color: var(--rv-booking-green);
  font-weight: 700;
}

.rv-booking-error {
  border-radius: 18px;
  padding: 12px 14px;
  background: rgba(137, 40, 38, 0.10);
  color: #8a2e2b;
  font-weight: 800;
  margin: 10px 0;
}

.rv-booking-checkbox {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  color: var(--rv-booking-muted);
  font-size: 14px;
}

.rv-booking-checkbox input { margin-top: 3px; }

.rv-booking-loading {
  min-height: 180px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--rv-booking-green);
  font-weight: 900;
}

.rv-booking-page-shell {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 32px 18px;
  background:
    radial-gradient(circle at top left, rgba(78, 117, 97, 0.18), transparent 34rem),
    linear-gradient(135deg, #fbfaf7 0%, #f7f4ef 48%, #edf3ee 100%);
  color: var(--rv-booking-ink);
  font-family: Inter, system-ui, sans-serif;
}

.rv-booking-launch-card {
  width: min(760px, 100%);
  border-radius: 34px;
  padding: 36px;
  background: rgba(255,255,255,0.86);
  border: 1px solid var(--rv-booking-line);
  box-shadow: 0 24px 70px rgba(8,20,18,0.12);
  text-align: center;
}

.rv-booking-launch-card h1 {
  margin: 12px 0;
  color: var(--rv-booking-green);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(42px, 8vw, 68px);
  line-height: .9;
}

@media (max-width: 920px) {
  .rv-booking-modal { width: min(100%, 920px); }
  .rv-booking-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 760px) {
  .rv-booking-overlay {
    padding: 8px;
    align-items: flex-end;
  }

  .rv-booking-modal {
    max-height: calc(100vh - 12px);
    border-radius: 28px 28px 18px 18px;
  }

  .rv-booking-head { padding: 18px 18px 12px; }
  .rv-booking-body { padding: 14px 18px 20px; max-height: calc(100vh - 136px); }
  .rv-booking-flow { padding: 12px; border-radius: 20px; }
  .rv-booking-flow-top { align-items: flex-start; flex-direction: column; gap: 4px; }
  .rv-booking-flow-current { text-align: left; }
  .rv-booking-grid, .rv-booking-grid.two, .rv-booking-form-grid, .rv-booking-summary { grid-template-columns: 1fr; }
  .rv-booking-slots { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .rv-booking-actions { align-items: stretch; flex-direction: column-reverse; }
  .rv-booking-btn, .rv-booking-btn-secondary { width: 100%; }
}


@media (max-width: 480px) {
  .rv-booking-head { gap: 10px; }
  .rv-booking-brand { align-items: flex-start; }
  .rv-booking-mark { width: 42px; height: 42px; font-size: 26px; flex: 0 0 42px; }
  .rv-booking-title { font-size: clamp(30px, 11vw, 42px); }
  .rv-booking-close { width: 42px; height: 42px; flex: 0 0 42px; }
}

/* Confirmation screen polish */
.rv-booking-success {
  text-align: center;
  border: 1px solid var(--rv-booking-line);
  border-radius: 28px;
  padding: clamp(22px, 4vw, 34px);
  background: rgba(255,255,255,0.72);
  box-shadow: 0 18px 42px rgba(8,20,18,0.07);
}

.rv-booking-success-icon {
  width: 58px;
  height: 58px;
  margin: 0 auto 14px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--rv-booking-green);
  color: #fff;
  font-size: 30px;
  font-weight: 900;
  box-shadow: 0 16px 34px rgba(33,58,50,0.24);
}

.rv-booking-success h3 {
  margin: 6px 0 8px;
  font-family: "Cormorant Garamond", Georgia, serif;
  color: var(--rv-booking-green);
  font-size: clamp(34px, 6vw, 52px);
  line-height: 0.98;
}

.rv-booking-success p {
  max-width: 640px;
  margin: 0 auto 18px;
}

.rv-booking-success-summary {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-top: 18px;
  text-align: left;
}

.rv-booking-success-summary div {
  min-width: 0;
  border: 1px solid var(--rv-booking-line);
  border-radius: 18px;
  padding: 12px 14px;
  background: rgba(255,255,255,0.86);
}

.rv-booking-success-summary small {
  display: block;
  margin-bottom: 4px;
  color: var(--rv-booking-muted);
  font-size: 11px;
  line-height: 1.2;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.rv-booking-success-summary strong {
  display: block;
  color: var(--rv-booking-ink);
  font-size: 14px;
  line-height: 1.25;
  overflow-wrap: anywhere;
}

@media (max-width: 760px) {
  .rv-booking-success-summary {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 520px) {
  .rv-booking-success-summary {
    grid-template-columns: 1fr;
  }
}


/* Slot confirmation prompt */
.rv-booking-slot-confirm-backdrop {
  position: fixed;
  inset: 0;
  z-index: 99995;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
  background: rgba(14, 28, 24, 0.46);
  backdrop-filter: blur(8px);
}

.rv-booking-slot-confirm {
  width: min(560px, 100%);
  border: 1px solid rgba(255,255,255,0.68);
  border-radius: 28px;
  padding: clamp(20px, 4vw, 28px);
  background:
    radial-gradient(circle at top left, rgba(237,243,238,0.96), transparent 24rem),
    linear-gradient(135deg, #fffaf2 0%, #f8f5ee 48%, #edf3ee 100%);
  box-shadow: 0 28px 80px rgba(8, 20, 18, 0.28);
}

.rv-booking-slot-confirm h3 {
  margin: 6px 0 14px;
  font-family: "Cormorant Garamond", Georgia, serif;
  color: var(--rv-booking-green);
  font-size: clamp(34px, 7vw, 50px);
  line-height: 0.95;
}

.rv-booking-slot-confirm-summary {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin: 14px 0;
}

.rv-booking-slot-confirm-summary div {
  min-width: 0;
  border: 1px solid var(--rv-booking-line);
  border-radius: 18px;
  padding: 12px;
  background: rgba(255,255,255,0.78);
}

.rv-booking-slot-confirm-summary small {
  display: block;
  margin-bottom: 4px;
  color: var(--rv-booking-muted);
  font-size: 11px;
  line-height: 1.2;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.rv-booking-slot-confirm-summary strong {
  display: block;
  color: var(--rv-booking-ink);
  font-size: 14px;
  line-height: 1.25;
  overflow-wrap: anywhere;
}

.rv-booking-slot-confirm-actions {
  margin-top: 18px;
}

@media (max-width: 760px) {
  .rv-booking-slot-confirm-backdrop {
    align-items: flex-end;
    padding: 10px;
  }

  .rv-booking-slot-confirm {
    border-radius: 28px 28px 18px 18px;
  }

  .rv-booking-slot-confirm-summary {
    grid-template-columns: 1fr;
  }
}

/* Client next-available appointment view */
.rv-booking-availability-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: start;
  margin: 14px 0;
  border: 1px solid var(--rv-booking-line);
  border-radius: 24px;
  padding: 16px;
  background: rgba(255,255,255,0.62);
}

.rv-booking-availability-head strong {
  display: block;
  margin: 4px 0 3px;
  color: var(--rv-booking-green);
  font-size: 18px;
}

.rv-booking-week-controls {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
}

.rv-booking-week-controls .rv-booking-btn-secondary {
  padding: 10px 13px;
  font-size: 13px;
}

.rv-booking-day-list {
  display: grid;
  gap: 10px;
  margin-top: 12px;
}

.rv-booking-day {
  border: 1px solid var(--rv-booking-line);
  border-radius: 22px;
  padding: 12px;
  background: rgba(255,255,255,0.72);
}

.rv-booking-day.is-empty {
  background: rgba(33, 58, 50, 0.045);
}

.rv-booking-day-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin-bottom: 10px;
}

.rv-booking-day-head strong {
  color: var(--rv-booking-green);
  font-size: 15px;
}

.rv-booking-day-head span {
  color: var(--rv-booking-muted);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.09em;
}

.rv-booking-slots.compact {
  grid-template-columns: repeat(6, minmax(0, 1fr));
  margin-top: 0;
}

.rv-booking-slots.compact .rv-booking-slot {
  padding: 10px 9px;
  font-size: 13px;
}

.rv-booking-day-empty {
  grid-column: 1 / -1;
  border-radius: 16px;
  padding: 11px 12px;
  background: rgba(33, 58, 50, 0.06);
  color: var(--rv-booking-muted);
  font-weight: 800;
}

@media (max-width: 840px) {
  .rv-booking-availability-head {
    grid-template-columns: 1fr;
  }

  .rv-booking-week-controls {
    justify-content: stretch;
  }

  .rv-booking-week-controls .rv-booking-btn-secondary {
    flex: 1 1 auto;
  }

  .rv-booking-slots.compact {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 520px) {
  .rv-booking-slots.compact {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .rv-booking-week-controls {
    flex-direction: column;
  }

  .rv-booking-week-controls .rv-booking-btn-secondary {
    width: 100%;
  }
}


/* Booksy-inspired client appointment picker */
.rv-booking-appointment-picker {
  border: 1px solid var(--rv-booking-line);
  border-radius: 28px;
  background: rgba(255,255,255,0.82);
  box-shadow: 0 18px 44px rgba(8,20,18,0.08);
  padding: clamp(14px, 3vw, 24px);
}

.rv-booking-picker-titlebar {
  display: grid;
  grid-template-columns: 48px minmax(0,1fr) 48px;
  align-items: center;
  gap: 10px;
  text-align: center;
  margin-bottom: 16px;
}

.rv-booking-picker-titlebar h3 {
  margin: 0;
  color: var(--rv-booking-ink);
  font-size: clamp(22px, 4vw, 28px);
  line-height: 1.1;
  font-family: Inter, system-ui, sans-serif;
  font-weight: 900;
}

.rv-booking-picker-titlebar p {
  margin: 5px 0 0;
  color: var(--rv-booking-muted);
  font-size: 13px;
  line-height: 1.3;
}

.rv-booking-picker-arrow {
  width: 42px;
  height: 42px;
  border-radius: 999px;
  border: 1px solid var(--rv-booking-line);
  background: rgba(255,255,255,0.9);
  color: var(--rv-booking-ink);
  font-size: 30px;
  line-height: 1;
  cursor: pointer;
  box-shadow: 0 10px 24px rgba(8,20,18,0.08);
}

.rv-booking-picker-arrow:disabled {
  opacity: .32;
  cursor: not-allowed;
  box-shadow: none;
}

.rv-booking-date-strip {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(68px, 1fr);
  gap: 8px;
  overflow-x: auto;
  padding: 2px 2px 14px;
  border-bottom: 1px solid var(--rv-booking-line);
  scroll-snap-type: x proximity;
  -webkit-overflow-scrolling: touch;
}

.rv-booking-date-chip {
  position: relative;
  min-height: 82px;
  border: 1px solid var(--rv-booking-line);
  border-radius: 11px;
  background: rgba(255,255,255,.96);
  color: var(--rv-booking-ink);
  display: grid;
  place-items: center;
  gap: 1px;
  padding: 9px 7px 12px;
  cursor: pointer;
  scroll-snap-align: start;
}

.rv-booking-date-chip span,
.rv-booking-date-chip small {
  color: var(--rv-booking-muted);
  font-size: 12px;
  font-weight: 700;
}

.rv-booking-date-chip strong {
  font-size: 18px;
  line-height: 1;
  font-weight: 900;
}

.rv-booking-date-chip.has-slots::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 7px;
  width: 24px;
  height: 4px;
  border-radius: 999px;
  background: var(--rv-booking-green);
  transform: translateX(-50%);
}

.rv-booking-date-chip.is-active {
  color: #fff;
  border-color: #2b8fa6;
  background: #2b8fa6;
  box-shadow: 0 12px 24px rgba(43,143,166,0.24);
}

.rv-booking-date-chip.is-active span,
.rv-booking-date-chip.is-active small { color: rgba(255,255,255,.88); }
.rv-booking-date-chip.is-active::after { background: #fff; }
.rv-booking-date-chip:disabled { opacity: .48; cursor: not-allowed; }
.rv-booking-date-chip:disabled::after { background: rgba(24,37,34,.18); }

.rv-booking-period-tabs {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 4px;
  margin: 20px auto 18px;
  width: min(420px, 100%);
  padding: 4px;
  border-radius: 11px;
  background: rgba(33,58,50,0.07);
}

.rv-booking-period-tabs button {
  min-height: 40px;
  border: 0;
  border-radius: 9px;
  background: transparent;
  color: var(--rv-booking-muted);
  font: inherit;
  cursor: pointer;
}

.rv-booking-period-tabs button.is-active {
  background: #fff;
  color: var(--rv-booking-ink);
  box-shadow: 0 8px 18px rgba(8,20,18,.08);
}

.rv-booking-period-tabs button:disabled {
  opacity: .45;
  cursor: not-allowed;
}

.rv-booking-slot-rail {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(86px, 1fr);
  gap: 10px;
  overflow-x: auto;
  padding: 8px 2px 18px;
  border-bottom: 1px solid var(--rv-booking-line);
  -webkit-overflow-scrolling: touch;
  scroll-snap-type: x proximity;
}

.rv-booking-slot-pill {
  min-height: 42px;
  border: 1px solid var(--rv-booking-line);
  border-radius: 9px;
  background: #fff;
  color: var(--rv-booking-ink);
  font: inherit;
  font-weight: 700;
  cursor: pointer;
  scroll-snap-align: start;
}

.rv-booking-slot-pill:hover,
.rv-booking-slot-pill:focus,
.rv-booking-slot-pill.is-selected {
  outline: none;
  background: var(--rv-booking-green);
  border-color: var(--rv-booking-green);
  color: #fff;
}

.rv-booking-no-period-slots {
  grid-column: 1 / -1;
  min-height: 42px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  padding: 0 14px;
  background: rgba(33,58,50,.06);
  color: var(--rv-booking-muted);
  font-weight: 800;
}

.rv-booking-selection-card {
  margin-top: 20px;
  border-radius: 12px;
  background: rgba(33,58,50,.07);
  padding: 18px;
  display: grid;
  grid-template-columns: minmax(0,1fr) auto;
  gap: 14px;
  align-items: start;
}

.rv-booking-selection-main strong,
.rv-booking-selection-meta strong {
  display: block;
  color: var(--rv-booking-ink);
  font-size: 16px;
  line-height: 1.25;
}

.rv-booking-selection-main span,
.rv-booking-selection-meta span,
.rv-booking-selection-staff {
  color: var(--rv-booking-muted);
  font-size: 13px;
}

.rv-booking-selection-meta {
  text-align: right;
  white-space: nowrap;
}

.rv-booking-selection-meta strong { font-size: 17px; }

.rv-booking-selection-staff {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  gap: 8px;
  padding-top: 14px;
  border-top: 1px solid var(--rv-booking-line);
}

.rv-booking-staff-avatar {
  width: 28px;
  height: 28px;
  border-radius: 999px;
  background: var(--rv-booking-green);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-weight: 800;
  font-size: 18px;
}

.rv-booking-picker-actions {
  margin-top: 14px;
}

@media (max-width: 760px) {
  .rv-booking-appointment-picker {
    border-radius: 22px;
    padding: 14px;
    margin-inline: -4px;
  }

  .rv-booking-picker-titlebar {
    grid-template-columns: 40px minmax(0,1fr) 40px;
  }

  .rv-booking-picker-arrow {
    width: 38px;
    height: 38px;
    font-size: 28px;
  }

  .rv-booking-date-strip {
    grid-auto-columns: 66px;
  }

  .rv-booking-date-chip {
    min-height: 76px;
  }

  .rv-booking-slot-rail {
    grid-auto-columns: 86px;
  }

  .rv-booking-selection-card {
    grid-template-columns: 1fr;
  }

  .rv-booking-selection-meta {
    text-align: left;
  }
}

/* Manage/reschedule link on confirmation */
.rv-booking-manage-link {
  margin: 18px auto 0;
  max-width: 560px;
  border: 1px solid var(--rv-booking-line);
  border-radius: 20px;
  padding: 14px 16px;
  background: rgba(33,58,50,0.07);
  text-align: left;
}

.rv-booking-manage-link strong,
.rv-booking-manage-link span {
  display: block;
}

.rv-booking-manage-link strong {
  color: var(--rv-booking-green);
  font-weight: 900;
}

.rv-booking-manage-link span {
  color: var(--rv-booking-muted);
  font-size: 13px;
  margin: 3px 0 10px;
}

.rv-booking-manage-link a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  padding: 10px 14px;
  background: var(--rv-booking-green);
  color: #fff;
  font-weight: 900;
  text-decoration: none;
}

/* Payment choice cards */
.rv-payment-options {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.rv-payment-option {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  border: 1px solid var(--rv-booking-line);
  border-radius: 18px;
  background: rgba(255,255,255,.78);
  padding: 13px 14px;
  cursor: pointer;
}

.rv-payment-option.is-selected {
  border-color: rgba(33,58,50,.55);
  background: rgba(33,58,50,.08);
  box-shadow: 0 10px 26px rgba(8,20,18,.08);
}

.rv-payment-option input {
  width: auto;
  margin-top: 3px;
}

.rv-payment-option strong,
.rv-payment-option small {
  display: block;
}

.rv-payment-option strong {
  color: var(--rv-booking-green);
  font-weight: 900;
}

.rv-payment-option small {
  color: var(--rv-booking-muted);
  margin-top: 3px;
  line-height: 1.35;
}

@media (max-width: 760px) {
  .rv-payment-options {
    grid-template-columns: 1fr;
  }
}


/* Confirmation calendar actions */
.rv-booking-calendar-actions{margin-top:14px;border:1px solid var(--rv-booking-line);border-radius:20px;padding:14px;background:rgba(255,255,255,.72);}
.rv-booking-calendar-actions strong,.rv-booking-calendar-actions span{display:block;}
.rv-booking-calendar-actions strong{color:var(--rv-booking-green);font-weight:900;margin-bottom:3px;}
.rv-booking-calendar-actions span{color:var(--rv-booking-muted);font-size:14px;margin-bottom:10px;}
.rv-booking-calendar-actions>div{display:flex;gap:10px;flex-wrap:wrap;}
.rv-booking-calendar-actions a{flex:1 1 180px;}
@media(max-width:760px){.rv-booking-success-summary{grid-template-columns:1fr!important;}.rv-booking-calendar-actions>div,.rv-booking-actions{flex-direction:column;align-items:stretch;}.rv-booking-calendar-actions a,.rv-booking-actions button,.rv-booking-actions a{width:100%;}}
