/* ─────────────────────────────────────────────────────────────────
   CRO Block 16 — Booking
   Self-contained, fully tokenized rewrite. The legacy
   cro-booking.css is intentionally not loaded.
   ───────────────────────────────────────────────────────────────── */

.block-cro-block-16 {
  background: var(--scheme-bg);
  color: var(--scheme-fg);
  font-family: var(--ds-font-body);
  padding-top: var(--ds-section-py-lg);
  padding-bottom: var(--ds-section-py-lg);
  overflow: hidden;
}
@media (max-width: 767px) {
  .block-cro-block-16 { padding-top: var(--ds-section-py-sm); padding-bottom: var(--ds-section-py-sm); }
}

/* Default scheme = ink (highest-contrast dark for conversion focus) */
.block-cro-block-16 {
  --scheme-bg: var(--ds-ink);
  --scheme-fg: #fff;
  --scheme-fg-soft: rgba(255,247,227,.85);
  --scheme-fg-mute: rgba(255,247,227,.65);
  --scheme-rule: var(--ds-rule-dark);
  --scheme-card-bg: rgba(255,255,255,.04);
  --scheme-card-fg: #fff;
}

.block-cro-block-16 .container,
.block-cro-block-16 .container-fluid {
  max-width: var(--ds-container-lg);
  margin-left: auto; margin-right: auto;
  padding-left: var(--ds-space-5); padding-right: var(--ds-space-5);
}
@media (max-width: 767px) {
  .block-cro-block-16 .container,
  .block-cro-block-16 .container-fluid {
    padding-left: var(--ds-space-4); padding-right: var(--ds-space-4);
  }
}

/* Section header colors */
.block-cro-block-16 .section-tag {
  display: inline-block;
  font-family: var(--ds-font-mono);
  font-size: var(--ds-fs-eyebrow);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #fff;
  background: var(--ds-cta);
  padding: var(--ds-space-2) var(--ds-space-4);
  border-radius: 999px;
  margin-bottom: var(--ds-space-4);
  box-shadow: var(--ds-shadow-cta);
}
.block-cro-block-16 .section-title h1,
.block-cro-block-16 .section-title h2 { color: #fff; }
.block-cro-block-16 .section-subtitle,
.block-cro-block-16 .section-subtitle p { color: var(--scheme-fg-soft); }

/* ── Benefits row ────────────────────────────────────────── */
.block-cro-block-16 .booking-benefits {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--ds-space-3) var(--ds-space-5);
  margin-bottom: var(--ds-space-6);
}
.block-cro-block-16 .booking-benefits > span {
  display: inline-flex;
  align-items: center;
  gap: var(--ds-space-2);
  font-family: var(--ds-font-body);
  font-size: var(--ds-fs-body-sm);
  font-weight: 600;
  color: var(--scheme-fg-soft);
}
.block-cro-block-16 .benefit-check {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px; height: 20px;
  border-radius: 50%;
  background: var(--ds-trust);
  color: #fff;
  font-size: 0.75rem;
  font-weight: 700;
}

/* ── Two-column grid ────────────────────────────────────── */
.block-cro-block-16 .row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--ds-space-6);
  align-items: start;
}
@media (max-width: 991px) {
  .block-cro-block-16 .row { grid-template-columns: 1fr; gap: var(--ds-space-5); }
}
.block-cro-block-16 .col-lg-6,
.block-cro-block-16 .col-lg-12 {
  width: auto; max-width: none; padding: 0;
}
.block-cro-block-16 .col-lg-12 { grid-column: 1 / -1; }

/* ── Calendar widget container (left column) ─────────────── */
.block-cro-block-16 .calendar-widget-container {
  background: var(--scheme-card-bg);
  border: 1px solid var(--scheme-rule);
  border-radius: var(--ds-radius);
  padding: var(--ds-space-5);
  box-shadow: var(--ds-shadow-md);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  display: flex;
  flex-direction: column;
  gap: var(--ds-space-4);
}

/* Availability badge */
.block-cro-block-16 .availability-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--ds-space-2);
  align-self: flex-start;
  font-family: var(--ds-font-mono);
  font-size: var(--ds-fs-eyebrow);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ds-cream);
  background: color-mix(in srgb, var(--ds-trust) 70%, transparent);
  padding: var(--ds-space-2) var(--ds-space-3);
  border-radius: 999px;
}
.block-cro-block-16 .availability-badge .pulse-dot {
  font-size: 0;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--ds-trust);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--ds-trust) 35%, transparent);
  animation: cro16-pulse 2s ease-in-out infinite;
}
@keyframes cro16-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.55; }
}

/* Calendar header */
.block-cro-block-16 .calendar-header-section { color: var(--scheme-fg); }
.block-cro-block-16 .calendar-title {
  font-family: var(--ds-font-display);
  font-size: var(--ds-fs-display-md);
  font-weight: 400;
  letter-spacing: 0.005em;
  text-transform: uppercase;
  color: #fff;
  margin: 0 0 var(--ds-space-2);
  line-height: 1.05;
}
.block-cro-block-16 .calendar-availability {
  font-size: var(--ds-fs-body-sm);
  color: var(--scheme-fg-soft);
  margin: 0 0 var(--ds-space-3);
  line-height: 1.5;
}
.block-cro-block-16 .calendar-info-box {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: var(--ds-radius-sm);
  padding: var(--ds-space-2) var(--ds-space-3);
}
.block-cro-block-16 .calendar-info-text {
  margin: 0;
  font-size: var(--ds-fs-body-sm);
  color: var(--scheme-fg-soft);
}

/* Multi-step form container */
.block-cro-block-16 .msf-container {
  background: var(--ds-paper);
  color: var(--ds-ink);
  border-radius: var(--ds-radius);
  padding: var(--ds-space-5);
}
.block-cro-block-16 .msf-loading {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--ds-space-3);
  color: var(--ds-ink-soft);
  font-size: var(--ds-fs-body-sm);
  min-height: 240px;
  justify-content: center;
}
.block-cro-block-16 .msf-loading p { margin: 0; }
.block-cro-block-16 .msf-spinner {
  width: 32px; height: 32px;
  border: 3px solid var(--ds-rule);
  border-top-color: var(--ds-cta);
  border-radius: 50%;
  animation: cro16-spin 800ms linear infinite;
}
@keyframes cro16-spin {
  to { transform: rotate(360deg); }
}

/* Multi-step form internals */
.block-cro-block-16 .msf-wrapper {
  display: flex;
  flex-direction: column;
  gap: var(--ds-space-5);
}

/* Progress bar */
.block-cro-block-16 .msf-progress { display: flex; flex-direction: column; gap: var(--ds-space-3); }
.block-cro-block-16 .msf-progress-track {
  height: 4px;
  background: var(--ds-rule);
  border-radius: 999px;
  overflow: hidden;
}
.block-cro-block-16 .msf-progress-bar {
  height: 100%;
  background: var(--ds-cta);
  border-radius: 999px;
  transition: width var(--ds-duration) var(--ds-ease-out);
}
.block-cro-block-16 .msf-progress-steps {
  display: flex;
  justify-content: space-between;
  gap: var(--ds-space-3);
}
.block-cro-block-16 .msf-step-indicator {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--ds-space-1);
  flex: 1;
  text-align: center;
}
.block-cro-block-16 .msf-step-dot {
  width: 32px; height: 32px;
  border-radius: 50%;
  background: var(--ds-rule);
  color: var(--ds-ink-soft);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--ds-font-mono);
  font-size: var(--ds-fs-body-sm);
  font-weight: 700;
  transition: background var(--ds-duration-fast), color var(--ds-duration-fast);
}
.block-cro-block-16 .msf-step-indicator.active .msf-step-dot {
  background: var(--ds-cta);
  color: #fff;
  box-shadow: var(--ds-shadow-cta);
}
.block-cro-block-16 .msf-step-indicator.completed .msf-step-dot {
  background: var(--ds-trust);
  color: #fff;
}
.block-cro-block-16 .msf-step-label {
  font-family: var(--ds-font-mono);
  font-size: var(--ds-fs-eyebrow);
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ds-ink-soft);
}
.block-cro-block-16 .msf-step-indicator.active .msf-step-label { color: var(--ds-ink); }

/* Step content */
.block-cro-block-16 .msf-content { display: flex; flex-direction: column; gap: var(--ds-space-4); }
.block-cro-block-16 .msf-step { display: flex; flex-direction: column; gap: var(--ds-space-4); }
.block-cro-block-16 .msf-step-header { display: flex; flex-direction: column; gap: var(--ds-space-1); }
.block-cro-block-16 .msf-step-number {
  font-family: var(--ds-font-mono);
  font-size: var(--ds-fs-eyebrow);
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ds-cta);
}
.block-cro-block-16 .msf-step-title {
  font-family: var(--ds-font-display);
  font-size: var(--ds-fs-display-sm);
  font-weight: 400;
  letter-spacing: 0.005em;
  text-transform: uppercase;
  color: var(--ds-ink);
  margin: 0;
  line-height: 1.1;
}
.block-cro-block-16 .msf-step-subtitle {
  margin: 0;
  font-size: var(--ds-fs-body-sm);
  color: var(--ds-ink-soft);
  line-height: 1.5;
}
.block-cro-block-16 .msf-step-body { display: flex; flex-direction: column; gap: var(--ds-space-3); }

/* Pill grid (selectable options) */
.block-cro-block-16 .msf-pill-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--ds-space-2);
}
@media (max-width: 575px) {
  .block-cro-block-16 .msf-pill-grid { grid-template-columns: repeat(2, 1fr); }
}
.block-cro-block-16 .msf-pill-grid.msf-cols-2 { grid-template-columns: repeat(2, 1fr); }
.block-cro-block-16 .msf-pill {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--ds-space-1);
  padding: var(--ds-space-3);
  background: #fff;
  border: 1.5px solid var(--ds-rule);
  border-radius: var(--ds-radius-sm);
  font-family: var(--ds-font-body);
  font-size: var(--ds-fs-body-sm);
  font-weight: 600;
  color: var(--ds-ink);
  cursor: pointer;
  min-height: 80px;
  text-align: center;
  transition: border-color var(--ds-duration-fast), background var(--ds-duration-fast),
              transform var(--ds-duration-fast);
}
.block-cro-block-16 .msf-pill:hover {
  border-color: var(--ds-ink);
  transform: translateY(-1px);
}
.block-cro-block-16 .msf-pill.selected,
.block-cro-block-16 .msf-pill[data-selected="true"],
.block-cro-block-16 .msf-pill.active {
  border-color: var(--ds-cta);
  background: color-mix(in srgb, var(--ds-cta) 8%, white);
  color: var(--ds-cta-dk);
}
.block-cro-block-16 .msf-pill-icon {
  display: inline-flex;
  width: 28px; height: 28px;
  color: var(--ds-cta);
}
.block-cro-block-16 .msf-pill-icon svg { width: 100%; height: 100%; }

/* Form fields */
.block-cro-block-16 .msf-field { display: flex; flex-direction: column; gap: var(--ds-space-1); }
.block-cro-block-16 .msf-label {
  font-family: var(--ds-font-mono);
  font-size: var(--ds-fs-eyebrow);
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ds-ink-soft);
}
.block-cro-block-16 .msf-input,
.block-cro-block-16 .msf-textarea,
.block-cro-block-16 .msf-select {
  width: 100%;
  padding: var(--ds-space-3) var(--ds-space-4);
  border: 1.5px solid var(--ds-rule);
  border-radius: var(--ds-radius-sm);
  font-family: var(--ds-font-body);
  font-size: var(--ds-fs-body);
  color: var(--ds-ink);
  background: #fff;
  min-height: 48px;
  transition: border-color var(--ds-duration-fast), box-shadow var(--ds-duration-fast);
}
.block-cro-block-16 .msf-input:focus,
.block-cro-block-16 .msf-textarea:focus,
.block-cro-block-16 .msf-select:focus {
  outline: none;
  border-color: var(--ds-cta);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--ds-cta) 18%, transparent);
}
.block-cro-block-16 .msf-textarea { min-height: 96px; resize: vertical; }

/* Step navigation */
.block-cro-block-16 .msf-step-nav,
.block-cro-block-16 .msf-actions {
  display: flex;
  justify-content: space-between;
  gap: var(--ds-space-3);
  margin-top: var(--ds-space-3);
}
.block-cro-block-16 .msf-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--ds-space-2);
  padding: var(--ds-space-3) var(--ds-space-5);
  border-radius: var(--ds-radius-sm);
  font-family: var(--ds-font-body);
  font-weight: 700;
  font-size: var(--ds-fs-body);
  border: 1.5px solid transparent;
  cursor: pointer;
  min-height: 48px;
  transition: background var(--ds-duration-fast), color var(--ds-duration-fast),
              border-color var(--ds-duration-fast), transform var(--ds-duration-fast);
}
.block-cro-block-16 .msf-btn-primary,
.block-cro-block-16 .msf-btn-next,
.block-cro-block-16 .msf-btn-submit {
  background: var(--ds-cta);
  color: #fff;
  box-shadow: var(--ds-shadow-cta);
}
.block-cro-block-16 .msf-btn-primary:hover,
.block-cro-block-16 .msf-btn-next:hover,
.block-cro-block-16 .msf-btn-submit:hover {
  background: var(--ds-cta-dk);
  transform: translateY(-1px);
}
.block-cro-block-16 .msf-btn-secondary,
.block-cro-block-16 .msf-btn-back {
  background: transparent;
  color: var(--ds-ink);
  border-color: var(--ds-rule);
}
.block-cro-block-16 .msf-btn-secondary:hover,
.block-cro-block-16 .msf-btn-back:hover {
  border-color: var(--ds-ink);
  background: var(--ds-paper-2);
}

/* Hide non-active steps */
.block-cro-block-16 .msf-step:not(.active) { display: none; }
.block-cro-block-16 .msf-step.active { display: flex; }

/* Error / success messaging */
.block-cro-block-16 .msf-error {
  background: color-mix(in srgb, var(--ds-cta) 14%, white);
  border: 1px solid color-mix(in srgb, var(--ds-cta) 35%, transparent);
  color: var(--ds-cta-dk);
  padding: var(--ds-space-2) var(--ds-space-3);
  border-radius: var(--ds-radius-sm);
  font-size: var(--ds-fs-body-sm);
}
.block-cro-block-16 .msf-success {
  background: color-mix(in srgb, var(--ds-trust) 14%, white);
  border: 1px solid color-mix(in srgb, var(--ds-trust) 35%, transparent);
  color: var(--ds-trust-dk);
  padding: var(--ds-space-3) var(--ds-space-4);
  border-radius: var(--ds-radius-sm);
  font-size: var(--ds-fs-body);
  text-align: center;
}

/* Social proof */
.block-cro-block-16 .social-proof-box {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: var(--ds-radius-sm);
  padding: var(--ds-space-3) var(--ds-space-4);
}
.block-cro-block-16 .social-proof-header {
  display: flex;
  align-items: center;
  gap: var(--ds-space-3);
  margin-bottom: var(--ds-space-2);
}
.block-cro-block-16 .avatar-stack {
  display: inline-flex;
}
.block-cro-block-16 .avatar-stack .avatar {
  width: 32px; height: 32px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--ds-font-mono);
  font-size: var(--ds-fs-eyebrow);
  font-weight: 700;
  color: var(--ds-ink);
  background: var(--ds-cream);
  border: 2px solid var(--ds-ink);
  margin-left: -8px;
}
.block-cro-block-16 .avatar-stack .avatar:first-child { margin-left: 0; }
.block-cro-block-16 .social-proof-title {
  font-family: var(--ds-font-mono);
  font-size: var(--ds-fs-eyebrow);
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #fff;
}
.block-cro-block-16 .social-proof-text {
  margin: 0;
  font-size: var(--ds-fs-body-sm);
  color: var(--scheme-fg-soft);
  line-height: 1.5;
}

/* ── Expectations (right column) ────────────────────────── */
.block-cro-block-16 .booking-expectations {
  background: var(--scheme-card-bg);
  border: 1px solid var(--scheme-rule);
  border-radius: var(--ds-radius);
  padding: var(--ds-space-5);
  display: flex;
  flex-direction: column;
  gap: var(--ds-space-4);
  color: var(--scheme-fg);
}
.block-cro-block-16 .booking-expectations h3 {
  font-family: var(--ds-font-display);
  font-size: var(--ds-fs-display-sm);
  font-weight: 400;
  letter-spacing: 0.005em;
  text-transform: uppercase;
  color: #fff;
  margin: 0;
  line-height: 1.1;
  display: flex;
  align-items: center;
  gap: var(--ds-space-2);
}
.block-cro-block-16 .expectations-emoji { font-size: 1.4rem; line-height: 1; }
.block-cro-block-16 .expectations-intro {
  margin: 0;
  font-size: var(--ds-fs-body-sm);
  color: var(--scheme-fg-soft);
  line-height: 1.55;
}
.block-cro-block-16 .expectations-list {
  display: flex;
  flex-direction: column;
  gap: var(--ds-space-3);
}
.block-cro-block-16 .expectation-item {
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: var(--ds-space-3);
  align-items: start;
  padding: var(--ds-space-3);
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--ds-radius-sm);
  transition: border-color var(--ds-duration-fast), background var(--ds-duration-fast);
}
.block-cro-block-16 .expectation-item:hover {
  border-color: var(--ds-cta);
  background: rgba(255,255,255,.06);
}
.block-cro-block-16 .expectation-icon {
  width: 44px; height: 44px;
  border-radius: var(--ds-radius-sm);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  background: color-mix(in srgb, var(--ds-cta) 20%, transparent);
  border: 1px solid color-mix(in srgb, var(--ds-cta) 35%, transparent);
  flex-shrink: 0;
}
.block-cro-block-16 .expectation-content h4 {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--ds-space-2);
  font-family: var(--ds-font-body);
  font-size: var(--ds-fs-body);
  font-weight: 700;
  margin: 0 0 var(--ds-space-1);
  color: #fff;
}
.block-cro-block-16 .time-badge {
  display: inline-flex;
  align-items: center;
  font-family: var(--ds-font-mono);
  font-size: var(--ds-fs-eyebrow);
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 2px var(--ds-space-2);
  border-radius: 999px;
  background: color-mix(in srgb, var(--ds-trust) 24%, transparent);
  color: var(--ds-cream);
  border: 1px solid color-mix(in srgb, var(--ds-trust) 40%, transparent);
}
.block-cro-block-16 .expectation-content p {
  margin: 0;
  font-size: var(--ds-fs-body-sm);
  color: var(--scheme-fg-soft);
  line-height: 1.55;
}

/* Urgency box */
.block-cro-block-16 .booking-urgency-box {
  display: flex;
  align-items: center;
  gap: var(--ds-space-3);
  padding: var(--ds-space-3) var(--ds-space-4);
  background: color-mix(in srgb, var(--ds-cta) 18%, transparent);
  border: 1px solid color-mix(in srgb, var(--ds-cta) 50%, transparent);
  border-radius: var(--ds-radius-sm);
}
.block-cro-block-16 .urgency-icon { font-size: 1.4rem; line-height: 1; }
.block-cro-block-16 .urgency-text {
  font-family: var(--ds-font-body);
  font-size: var(--ds-fs-body-sm);
  color: #fff;
  line-height: 1.5;
}
.block-cro-block-16 .urgency-text strong { color: var(--ds-cta); font-weight: 800; }

/* Phone CTA box */
.block-cro-block-16 .phone-cta-box {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--ds-space-3);
  padding: var(--ds-space-3) var(--ds-space-4);
  border: 1px dashed rgba(255,255,255,.25);
  border-radius: var(--ds-radius-sm);
  flex-wrap: wrap;
}
.block-cro-block-16 .phone-cta-text {
  font-size: var(--ds-fs-body-sm);
  color: var(--scheme-fg-soft);
}
.block-cro-block-16 .phone-cta-button {
  display: inline-flex;
  align-items: center;
  gap: var(--ds-space-2);
  padding: var(--ds-space-2) var(--ds-space-4);
  background: rgba(255,255,255,.10);
  color: #fff !important;
  border: 1.5px solid rgba(255,255,255,.40);
  border-radius: var(--ds-radius-sm);
  font-family: var(--ds-font-body);
  font-size: var(--ds-fs-body-sm);
  font-weight: 700;
  text-decoration: none !important;
  transition: background var(--ds-duration-fast), border-color var(--ds-duration-fast);
}
.block-cro-block-16 .phone-cta-button:hover {
  background: rgba(255,255,255,.18);
  border-color: #fff;
}
