/* ═══════════════════════════════════════════════════════════════
   BOOKING DRAWER — v2 (Two-Column Dates, CrDatePicker, Real-Time Cost)
   Side-panel drawer for booking requests on facility & space pages.
   680px desktop, 100vw mobile.
   ═══════════════════════════════════════════════════════════════ */

/* ===== OVERLAY ===== */
.cr-bk-overlay {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background-color: rgba(0, 0, 0, 0.5);
  backdrop-filter: blur(4px);
  z-index: 9998;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}
.cr-bk-overlay.open {
  opacity: 1;
  pointer-events: all;
}

/* ===== DRAWER CONTAINER ===== */
.cr-bk-drawer {
  position: fixed;
  top: 0; right: 0;
  height: 100vh;
  width: 680px;
  background-color: var(--cr-bg-primary);
  border-left: 1px solid var(--cr-border);
  z-index: 9999;
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: var(--cr-shadow-xl);
}
.cr-bk-drawer.open {
  transform: translateX(0);
}

@media (max-width: 768px) {
  .cr-bk-drawer { width: 100vw; }
}

/* ===== HEADER ===== */
.cr-bk-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--cr-space-5) var(--cr-space-6);
  border-bottom: 1px solid var(--cr-border);
  flex-shrink: 0;
}
.cr-bk-header-left {
  display: flex;
  align-items: center;
  gap: var(--cr-space-3);
}
.cr-bk-header-title {
  font-size: var(--cr-font-size-xl);
  font-weight: var(--cr-font-weight-bold);
  letter-spacing: -0.01em;
}
.cr-bk-header-left .cr-badge,
.cr-bk-header-left .pricing-badge {
  min-width: auto;
  cursor: default;
  pointer-events: none;
  white-space: nowrap;
}
.cr-bk-close {
  background: none;
  border: none;
  color: var(--cr-text-tertiary);
  font-size: var(--cr-font-size-xl);
  cursor: pointer;
  padding: var(--cr-space-1);
  line-height: 1;
  transition: all 0.2s;
  width: 28px; height: 28px;
  display: flex; align-items: center; justify-content: center;
  border-radius: var(--cr-radius-full);
}
.cr-bk-close:hover {
  color: var(--cr-text-primary);
  background: var(--cr-bg-hover);
}

/* ===== BREADCRUMB STEPPER (removed — mini stepper in header is the only stepper) ===== */
.cr-bk-steps { display: none; }

/* ===== HEADER STEPPER (inline, right side of header) ===== */
.cr-bk-mini-stepper {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-left: auto;
  margin-right: var(--cr-space-3);
}
.cr-bk-mini-step {
  font-size: 11px;
  font-weight: var(--cr-font-weight-medium);
  color: var(--cr-text-tertiary);
  letter-spacing: 0.01em;
  cursor: pointer;
  transition: color 0.15s;
  white-space: nowrap;
}
.cr-bk-mini-step:hover:not(.active) { color: var(--cr-text-secondary); }
.cr-bk-mini-step.done { color: var(--cr-text-secondary); }
.cr-bk-mini-step.active {
  color: var(--cr-text-primary);
  font-weight: var(--cr-font-weight-semibold);
  cursor: default;
}
.cr-bk-mini-step.disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.cr-bk-mini-sep {
  width: 3px; height: 3px;
  border-radius: var(--cr-radius-full);
  background: color-mix(in srgb, var(--cr-text-primary) 25%, transparent);
  flex-shrink: 0;
}

/* ===== BODY ===== */
.cr-bk-body {
  flex: 1;
  overflow-y: auto;
  padding: var(--cr-space-5) var(--cr-space-6);
}

/* Step panels */
.step-section { display: none; }
.step-section.active {
  display: block;
  animation: crBkFadeIn 0.2s ease;
}
@keyframes crBkFadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

/* Section labels */
.cr-bk-section-label {
  font-size: var(--cr-font-size-xs);
  font-weight: var(--cr-font-weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--cr-text-tertiary);
  margin-bottom: var(--cr-space-3);
}
.cr-bk-section-label:not(:first-child) {
  margin-top: var(--cr-space-5);
}

/* ===== TWO-COLUMN DATES LAYOUT ===== */
.cr-bk-dates-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--cr-space-5);
  align-items: start;
}
@media (max-width: 768px) {
  .cr-bk-dates-grid {
    grid-template-columns: 1fr;
  }
}

/* Calendar column — use cr-datepicker-lg from existing datepicker CSS */
.cr-bk-cal-wrapper {
  min-height: 0;
}

/* Selected dates column */
.cr-bk-selected-col {
  display: flex;
  flex-direction: column;
  gap: var(--cr-space-3);
}

/* ===== AVAILABILITY LEGEND (matches cr-avail-legend from availability modal exactly) ===== */
.cr-bk-legend {
  display: flex;
  align-items: center;
  gap: var(--cr-space-4);
  padding: var(--cr-space-3) 0;
  font-size: var(--cr-font-size-xs);
  color: var(--cr-text-secondary);
}
.cr-bk-legend-item {
  display: flex;
  align-items: center;
  gap: var(--cr-space-1);
}
.cr-bk-legend-dot {
  width: 8px; height: 8px;
  border-radius: var(--cr-radius-full);
  flex-shrink: 0;
}
.cr-bk-legend-dot.avail { background: var(--cr-success); }
.cr-bk-legend-dot.pending { background: var(--cr-warning, #f59e0b); }
.cr-bk-legend-dot.booked { background: var(--cr-error, #ef4444); }

/* ===== CARD CHIPS (selected dates) ===== */
.cr-bk-card-chips {
  display: flex;
  flex-direction: column;
  gap: var(--cr-space-2);
}
.cr-bk-card-chip {
  display: flex;
  align-items: center;
  padding: var(--cr-space-3);
  background: transparent;
  border: 1px solid var(--cr-border);
  border-radius: var(--cr-radius-md);
  gap: var(--cr-space-3);
  transition: border-color 0.15s;
}
.cr-bk-card-chip:hover { border-color: var(--cr-border-hover); }
.cr-bk-card-chip-icon {
  width: 38px;
  flex-shrink: 0;
  text-align: center;
  line-height: 1.1;
}
.cr-bk-card-chip-icon .month {
  font-size: 9px;
  text-transform: uppercase;
  color: var(--cr-text-tertiary);
  letter-spacing: 0.05em;
  font-weight: var(--cr-font-weight-medium);
}
.cr-bk-card-chip-icon .day {
  font-size: var(--cr-font-size-xl);
  font-weight: var(--cr-font-weight-bold);
  color: var(--cr-text-primary);
  line-height: 1;
}
.cr-bk-card-chip-info { flex: 1; min-width: 0; }
.cr-bk-card-chip-date {
  font-size: var(--cr-font-size-sm);
  font-weight: var(--cr-font-weight-medium);
  color: var(--cr-text-primary);
}
.cr-bk-card-chip-remove {
  background: none; border: none; cursor: pointer;
  color: var(--cr-text-tertiary);
  width: 24px; height: 24px;
  display: flex; align-items: center; justify-content: center;
  border-radius: var(--cr-radius-full);
  transition: all 0.15s;
  flex-shrink: 0;
  font-size: var(--cr-font-size-sm);
}
.cr-bk-card-chip-remove:hover {
  background: color-mix(in srgb, var(--cr-error) 12%, transparent);
  color: var(--cr-error);
}
.cr-bk-chip-summary {
  font-size: var(--cr-font-size-xs);
  color: var(--cr-text-tertiary);
  margin-top: var(--cr-space-2);
}
/* Empty dates state — card with arrow pointing at calendar */
.cr-bk-empty-dates {
  display: flex;
  align-items: center;
  gap: var(--cr-space-4);
  padding: var(--cr-space-5) var(--cr-space-4);
  border: 1px dashed var(--cr-border);
  border-radius: var(--cr-radius-md);
  margin-top: var(--cr-space-6);
}
.cr-bk-empty-arrow {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--cr-radius-full);
  background: var(--cr-bg-hover);
  color: var(--cr-text-tertiary);
  animation: crBkArrowPulse 2s ease-in-out infinite;
}
@keyframes crBkArrowPulse {
  0%, 100% { transform: translateX(0); }
  50% { transform: translateX(-4px); }
}
.cr-bk-empty-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.cr-bk-empty-title {
  font-size: var(--cr-font-size-sm);
  font-weight: var(--cr-font-weight-semibold);
  color: var(--cr-text-primary);
}
.cr-bk-empty-desc {
  font-size: var(--cr-font-size-xs);
  color: var(--cr-text-tertiary);
  line-height: 1.4;
}
.cr-bk-no-dates {
  font-size: var(--cr-font-size-sm);
  color: var(--cr-text-tertiary);
  padding: var(--cr-space-4) 0;
}

/* ===== DATE CONFIG CARDS (Extras step) — Accordion ===== */
.cr-bk-date-config-card {
  border: 1px solid var(--cr-border);
  border-radius: var(--cr-radius-md);
  overflow: hidden;
  margin-bottom: var(--cr-space-3);
}
.cr-bk-date-config-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--cr-space-3) var(--cr-space-4);
  cursor: pointer;
  transition: background 0.15s;
  user-select: none;
}
.cr-bk-date-config-header:hover {
  background: var(--cr-bg-hover);
}
.cr-bk-date-config-header .date-label {
  font-size: var(--cr-font-size-sm);
  font-weight: var(--cr-font-weight-semibold);
}
.cr-bk-date-config-right {
  display: flex;
  align-items: center;
  gap: var(--cr-space-2);
}
.cr-bk-date-config-chevron {
  font-size: var(--cr-font-size-lg);
  color: var(--cr-text-tertiary);
  transition: transform 0.2s ease;
  transform: rotate(90deg);
  line-height: 1;
}
.cr-bk-date-config-card.open .cr-bk-date-config-chevron {
  transform: rotate(270deg);
}
/* Body hidden by default, shown when .open */
.cr-bk-date-config-body {
  padding: 0 var(--cr-space-4);
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.25s ease, padding 0.25s ease;
}
.cr-bk-date-config-card.open .cr-bk-date-config-body {
  max-height: 800px;
  padding: var(--cr-space-4);
  border-top: 1px solid var(--cr-border);
}
.cr-bk-field-row { margin-bottom: var(--cr-space-4); }
.cr-bk-field-row:last-child { margin-bottom: 0; }
.cr-bk-field-label {
  display: block;
  font-size: var(--cr-font-size-xs);
  font-weight: var(--cr-font-weight-medium);
  color: var(--cr-text-secondary);
  margin-bottom: var(--cr-space-1);
}
.cr-bk-input {
  width: 100%;
  padding: var(--cr-space-2) var(--cr-space-3);
  border: 1px solid var(--cr-border);
  border-radius: var(--cr-radius-md);
  background: var(--cr-bg-primary);
  color: var(--cr-text-primary);
  font-family: var(--cr-font-family);
  font-size: var(--cr-font-size-sm);
  transition: border-color 0.15s;
}
.cr-bk-input:focus {
  outline: none;
  border-color: var(--cr-border-focus);
}
select.cr-bk-input { appearance: auto; }

/* Guest tiers — mirrors price card pc-tier-row pattern */
.cr-bk-tier-grid {
  display: grid;
  gap: var(--cr-space-1);
}
.cr-bk-tier-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--cr-space-1) var(--cr-space-3);
  border: 1px solid var(--cr-border);
  border-radius: var(--cr-radius-sm);
  font-size: var(--cr-font-size-xs);
  cursor: pointer;
  transition: all 0.15s;
}
.cr-bk-tier-row:hover {
  border-color: var(--cr-border-hover, var(--cr-text-tertiary));
  background: var(--cr-bg-hover);
}
.cr-bk-tier-row.active {
  border-color: var(--cr-text-primary);
  background: var(--cr-bg-hover);
}
.cr-bk-tier-range {
  color: var(--cr-text-secondary);
}
.cr-bk-tier-rate {
}

/* Type badges (shoot/prep/strike) */
.cr-bk-type-badge {
  display: inline-flex;
  align-items: center;
  padding: 1px var(--cr-space-2);
  border-radius: var(--cr-radius-sm);
  font-size: 9px;
  font-weight: var(--cr-font-weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.cr-bk-type-badge.shoot {
  background: color-mix(in srgb, var(--cr-success) 12%, transparent);
  color: var(--cr-success);
}
.cr-bk-type-badge.prep {
  background: color-mix(in srgb, var(--cr-warning) 12%, transparent);
  color: var(--cr-warning);
}
.cr-bk-type-badge.strike {
  background: var(--cr-bg-tertiary);
  color: var(--cr-text-tertiary);
}

/* Add-on rows */
.cr-bk-addon-row {
  display: flex;
  align-items: center;
  gap: var(--cr-space-3);
  padding: var(--cr-space-2) var(--cr-space-3);
  border: 1px solid var(--cr-border);
  border-radius: var(--cr-radius-sm);
  margin-bottom: var(--cr-space-2);
  cursor: pointer;
  transition: all 0.15s;
  background: var(--cr-bg-primary);
}
.cr-bk-addon-row:hover { border-color: var(--cr-border-hover); }
.cr-bk-addon-row.selected {
  border-color: var(--cr-text-primary);
}
.cr-bk-addon-row input[type="checkbox"] {
  accent-color: var(--cr-text-primary);
  cursor: pointer;
  flex-shrink: 0;
}
.cr-bk-addon-name {
  flex: 1;
  font-size: var(--cr-font-size-xs);
}
.cr-bk-addon-price {
  font-size: var(--cr-font-size-xs);
  color: var(--cr-text-secondary);
  flex-shrink: 0;
}

/* ===== FORM FIELDS (Project step) ===== */
.cr-bk-form-field { margin-bottom: var(--cr-space-4); }
.cr-bk-form-field:last-child { margin-bottom: 0; }
.cr-bk-form-label {
  display: block;
  font-size: var(--cr-font-size-xs);
  font-weight: var(--cr-font-weight-medium);
  color: var(--cr-text-secondary);
  margin-bottom: var(--cr-space-2);
}
.cr-bk-form-label .req { color: var(--cr-error); }
.cr-bk-textarea {
  width: 100%;
  min-height: 80px;
  padding: var(--cr-space-3);
  border: 1px solid var(--cr-border);
  border-radius: var(--cr-radius-md);
  background: var(--cr-bg-primary);
  color: var(--cr-text-primary);
  font-family: var(--cr-font-family);
  font-size: var(--cr-font-size-sm);
  resize: vertical;
  transition: border-color 0.15s;
}
.cr-bk-textarea:focus {
  outline: none;
  border-color: var(--cr-border-focus);
}

/* ===== CARD ROWS (Stage/Set selection) ===== */
.cr-bk-card-row {
  border: 1px solid var(--cr-border);
  padding: var(--cr-space-4);
  border-radius: var(--cr-radius-md);
  margin-bottom: var(--cr-space-3);
  cursor: pointer;
  transition: all 0.2s ease;
  background-color: var(--cr-bg-secondary);
}
.cr-bk-card-row:hover {
  border-color: var(--cr-border-hover);
  background-color: var(--cr-bg-hover);
}
.cr-bk-card-row.selected {
  border: 2px solid var(--cr-accent);
  background-color: var(--cr-bg-tertiary);
}
.cr-bk-card-row-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: var(--cr-space-2);
}
.cr-bk-card-row-title {
  font-weight: var(--cr-font-weight-bold);
  color: var(--cr-text-primary);
  font-size: var(--cr-font-size-base);
}
.cr-bk-card-row-price {
  font-weight: var(--cr-font-weight-bold);
  color: var(--cr-accent);
  font-size: var(--cr-font-size-base);
}
.cr-bk-card-row-description {
  font-size: var(--cr-font-size-sm);
  color: var(--cr-text-secondary);
}

/* Sets grid */
.cr-bk-date-sets-section {
  background-color: var(--cr-bg-secondary);
  padding: var(--cr-space-4);
  border-radius: var(--cr-radius-md);
  margin-bottom: var(--cr-space-4);
}
.cr-bk-date-sets-header {
  font-weight: var(--cr-font-weight-bold);
  margin-bottom: var(--cr-space-4);
  font-size: var(--cr-font-size-base);
}
.cr-bk-sets-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--cr-space-3);
}
.cr-bk-set-item {
  display: flex;
  align-items: flex-start;
  gap: var(--cr-space-3);
  padding: var(--cr-space-3);
  border: 1px solid var(--cr-border);
  border-radius: var(--cr-radius-md);
  background-color: var(--cr-bg-tertiary);
  cursor: pointer;
  transition: all 0.2s ease;
}
.cr-bk-set-item:hover {
  border-color: var(--cr-border-hover);
  background-color: var(--cr-bg-hover);
}
.cr-bk-set-item.selected {
  border-color: var(--cr-accent);
  background-color: var(--cr-bg-active);
}
.cr-bk-set-item input[type="checkbox"] {
  margin-top: var(--cr-space-1);
  flex-shrink: 0;
  cursor: pointer;
  accent-color: var(--cr-accent);
}
.cr-bk-set-item-name {
  font-size: var(--cr-font-size-sm);
  font-weight: var(--cr-font-weight-medium);
  color: var(--cr-text-primary);
}
.cr-bk-set-item-price {
  font-size: var(--cr-font-size-xs);
  color: var(--cr-text-secondary);
}

/* Discount items */
.cr-bk-discount-item {
  border: 1px solid var(--cr-border);
  padding: var(--cr-space-3);
  border-radius: var(--cr-radius-md);
  margin-bottom: var(--cr-space-2);
  background-color: var(--cr-bg-secondary);
  display: flex;
  align-items: center;
  gap: var(--cr-space-3);
  cursor: pointer;
  transition: all 0.2s ease;
}
.cr-bk-discount-item:hover {
  border-color: var(--cr-border-hover);
  background-color: var(--cr-bg-hover);
}
.cr-bk-discount-item.selected {
  border: 2px solid var(--cr-accent);
  background-color: var(--cr-bg-tertiary);
}
.cr-bk-discount-item input[type="checkbox"] {
  flex-shrink: 0;
  cursor: pointer;
  accent-color: var(--cr-accent);
}
.cr-bk-discount-name {
  flex: 1;
  font-weight: var(--cr-font-weight-medium);
  font-size: var(--cr-font-size-sm);
}
.cr-bk-discount-desc {
  font-size: var(--cr-font-size-xs);
  color: var(--cr-text-secondary);
}
.cr-bk-discount-price {
  font-weight: var(--cr-font-weight-bold);
  color: var(--cr-accent);
  font-size: var(--cr-font-size-sm);
  flex-shrink: 0;
}

/* ===== REVIEW STEP — Day Cards ===== */
.cr-bk-day-card {
  border: 1px solid var(--cr-border);
  border-radius: var(--cr-radius-md);
  overflow: hidden;
  transition: border-color 0.15s;
  margin-bottom: var(--cr-space-3);
}
.cr-bk-day-card:hover { border-color: var(--cr-border-hover); }
.cr-bk-day-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--cr-space-3) var(--cr-space-4);
  cursor: pointer;
  user-select: none;
}
.cr-bk-day-header:hover { background: transparent; }
.cr-bk-day-left {
  display: flex;
  align-items: center;
  gap: var(--cr-space-2);
}
.cr-bk-day-chevron {
  width: 14px; height: 14px;
  color: var(--cr-text-tertiary);
  transition: transform 0.2s ease;
  flex-shrink: 0;
}
.cr-bk-day-card.open .cr-bk-day-chevron { transform: rotate(180deg); }
.cr-bk-day-date {
  font-size: var(--cr-font-size-sm);
  font-weight: var(--cr-font-weight-semibold);
  color: var(--cr-text-primary);
}
.cr-bk-day-amount {
  font-size: var(--cr-font-size-sm);
  font-weight: var(--cr-font-weight-semibold);
  font-variant-numeric: tabular-nums;
  color: var(--cr-text-primary);
  text-align: right;
}
/* Expandable line items */
.cr-bk-day-items {
  max-height: 0; overflow: hidden; opacity: 0;
  padding: 0 var(--cr-space-4);
  transition: max-height 0.25s ease, opacity 0.2s ease, padding 0.25s ease;
  border-top: 1px solid transparent;
}
.cr-bk-day-card.open .cr-bk-day-items {
  max-height: 400px; opacity: 1;
  padding: 20px var(--cr-space-4);
  border-top-color: color-mix(in srgb, var(--cr-border) 50%, transparent);
}
.cr-bk-rv-line {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 7px var(--cr-space-4);
  font-size: var(--cr-font-size-xs);
  color: var(--cr-text-secondary);
  line-height: 1.5;
}
.cr-bk-rv-line + .cr-bk-rv-line {
  border-top: 1px solid color-mix(in srgb, var(--cr-border) 25%, transparent);
}
.cr-bk-rv-line span:last-child {
  flex-shrink: 0;
  margin-left: var(--cr-space-4);
  text-align: right;
  font-variant-numeric: tabular-nums;
}

/* ===== REVIEW — Booking-Level Extras ===== */
.cr-bk-rv-extras {
  padding: var(--cr-space-2) var(--cr-space-4) var(--cr-space-4);
  border-top: none;
  margin: 0 1px;
}
.cr-bk-rv-extras-line {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 6px 0;
  font-size: var(--cr-font-size-xs);
  color: var(--cr-text-secondary);
}
.cr-bk-rv-extras-line + .cr-bk-rv-extras-line {
  border-top: 1px solid color-mix(in srgb, var(--cr-border) 30%, transparent);
}
.cr-bk-rv-extras-line.discount { color: var(--cr-success); }
.cr-bk-rv-extras-line span:last-child,
.cr-bk-rv-extras-line .cr-bk-rv-included {
  flex-shrink: 0;
  min-width: 80px;
  text-align: right;
  font-variant-numeric: tabular-nums;
}
.cr-bk-rv-included {
  font-weight: var(--cr-font-weight-medium);
  color: var(--cr-success);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

/* ===== REVIEW — Total Bar ===== */
.cr-bk-rv-total {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--cr-space-4);
  border-top: none;
  margin: 0 1px var(--cr-space-4);
}
.cr-bk-rv-total-label {
  font-size: var(--cr-font-size-md);
  font-weight: var(--cr-font-weight-bold);
}
.cr-bk-rv-total-amount {
  font-size: var(--cr-font-size-xl);
  font-weight: var(--cr-font-weight-bold);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
}

/* ===== REVIEW — Info Cards ===== */
.cr-bk-rv-info-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--cr-space-4);
  margin-bottom: var(--cr-space-4);
}
.cr-bk-rv-info-card {
  border: 1px solid var(--cr-border);
  border-radius: var(--cr-radius-md);
  padding: var(--cr-space-3) var(--cr-space-4);
}
.cr-bk-rv-info-card.full { grid-column: 1 / -1; }
.cr-bk-rv-info-title {
  font-size: 10px;
  font-weight: var(--cr-font-weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--cr-text-tertiary);
  margin-bottom: var(--cr-space-2);
}
.cr-bk-rv-info-text {
  font-size: var(--cr-font-size-xs);
  color: var(--cr-text-secondary);
  line-height: 1.6;
}
.cr-bk-rv-info-text .muted { color: var(--cr-text-tertiary); }
.cr-bk-rv-project-name {
  font-size: var(--cr-font-size-sm);
  font-weight: var(--cr-font-weight-semibold);
  color: var(--cr-text-primary);
  margin-bottom: 2px;
}
.cr-bk-rv-project-detail {
  font-size: var(--cr-font-size-xs);
  color: var(--cr-text-tertiary);
  line-height: 1.5;
}

/* ===== REVIEW — Payment Accordion ===== */
.cr-bk-rv-pay-selected {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--cr-space-3);
  border: 1px solid var(--cr-accent);
  border-radius: var(--cr-radius-md);
  background: color-mix(in srgb, var(--cr-accent) 4%, transparent);
  cursor: pointer;
  transition: all 0.15s;
}
.cr-bk-rv-pay-selected:hover {
  background: color-mix(in srgb, var(--cr-accent) 8%, transparent);
}
.cr-bk-rv-pay-sel-left {
  display: flex;
  align-items: center;
  gap: var(--cr-space-2);
}
.cr-bk-rv-pay-sel-name {
  font-size: var(--cr-font-size-sm);
  font-weight: var(--cr-font-weight-medium);
  color: var(--cr-text-primary);
}
.cr-bk-rv-pay-sel-fee {
  font-size: 10px;
  color: var(--cr-text-tertiary);
}
.cr-bk-rv-pay-change {
  font-size: var(--cr-font-size-xs);
  color: var(--cr-accent);
  font-weight: var(--cr-font-weight-medium);
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 4px;
}
.cr-bk-rv-pay-change-chev {
  width: 12px; height: 12px;
  transition: transform 0.2s;
}
.cr-bk-rv-pay-accordion.open .cr-bk-rv-pay-change-chev { transform: rotate(180deg); }
.cr-bk-rv-pay-sel-instr {
  font-size: 10px;
  color: var(--cr-text-tertiary);
  padding: 3px 0 0 22px;
}
/* Expandable options list */
.cr-bk-rv-pay-expand {
  max-height: 0; overflow: hidden;
  transition: max-height 0.3s ease, margin 0.3s ease;
  margin-top: 0;
}
.cr-bk-rv-pay-accordion.open .cr-bk-rv-pay-expand {
  max-height: 500px;
  margin-top: var(--cr-space-2);
}
.cr-bk-rv-pay-option {
  display: flex;
  align-items: center;
  gap: var(--cr-space-2);
  padding: var(--cr-space-2) var(--cr-space-3);
  border: 1px solid var(--cr-border);
  border-radius: var(--cr-radius-md);
  margin-bottom: 6px;
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
  font-size: var(--cr-font-size-xs);
}
.cr-bk-rv-pay-option:hover {
  border-color: var(--cr-border-hover);
  background: var(--cr-bg-hover);
}
.cr-bk-rv-pay-option.active {
  border-color: var(--cr-accent);
  background: color-mix(in srgb, var(--cr-accent) 5%, transparent);
}
.cr-bk-rv-pay-option input[type="radio"] {
  accent-color: var(--cr-accent);
  margin: 0;
  width: 13px; height: 13px;
  flex-shrink: 0;
}
.cr-bk-rv-pay-option-label {
  flex: 1;
  display: flex;
  align-items: center;
  font-weight: var(--cr-font-weight-medium);
  color: var(--cr-text-primary);
}
.cr-bk-rv-pay-option-meta {
  font-size: 10px;
  color: var(--cr-text-tertiary);
  flex-shrink: 0;
}
.cr-bk-rv-pay-icon {
  display: inline-block;
  vertical-align: -2px;
  margin-right: 4px;
}
/* Payment terms text */
.cr-bk-rv-pay-terms {
  font-size: var(--cr-font-size-xs);
  color: var(--cr-text-secondary);
  line-height: 1.6;
}

/* ===== FOOTER ===== */
.cr-bk-footer {
  border-top: 1px solid var(--cr-border);
  padding: var(--cr-space-4) var(--cr-space-6);
  background-color: var(--cr-bg-secondary);
  flex-shrink: 0;
  display: none;
  justify-content: space-between;
  align-items: center;
}
.cr-bk-footer.visible {
  display: flex;
}
.cr-bk-footer-cost {
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.cr-bk-footer-cost .label {
  font-size: 10px;
  color: var(--cr-text-tertiary);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.cr-bk-footer-cost .amount {
  font-size: var(--cr-font-size-lg);
  font-weight: var(--cr-font-weight-bold);
}
.cr-bk-footer-actions {
  display: flex;
  gap: var(--cr-space-3);
  align-items: center;
}
.cr-bk-btn-back {
  background: none;
  border: 1px solid var(--cr-border);
  border-radius: var(--cr-radius-md);
  padding: var(--cr-space-2) var(--cr-space-4);
  color: var(--cr-text-secondary);
  font-family: var(--cr-font-family);
  font-size: var(--cr-font-size-sm);
  font-weight: var(--cr-font-weight-medium);
  cursor: pointer;
  transition: all 0.2s;
}
.cr-bk-btn-back:hover {
  border-color: var(--cr-border-hover);
  background: var(--cr-bg-hover);
  color: var(--cr-text-primary);
}
.cr-bk-btn-back:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.cr-bk-btn-next {
  background: var(--cr-text-primary);
  color: var(--cr-bg-primary);
  border: none;
  border-radius: var(--cr-radius-md);
  padding: var(--cr-space-2) var(--cr-space-6);
  font-family: var(--cr-font-family);
  font-size: var(--cr-font-size-sm);
  font-weight: var(--cr-font-weight-semibold);
  cursor: pointer;
  transition: opacity 0.2s;
}
.cr-bk-btn-next:hover { opacity: 0.85; }
.cr-bk-btn-next:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.cr-bk-btn-next.submit { background: var(--cr-info, #3b82f6); }

/* ===== CONFIRMATION SCREEN ===== */
.confirmation-screen {
  display: none;
  text-align: center;
  padding: var(--cr-space-10) var(--cr-space-6);
  flex: 1;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
.confirmation-screen.active { display: flex; }
.confirmation-icon {
  font-size: var(--cr-font-size-3xl);
  transform: scale(2.2);
  margin-bottom: var(--cr-space-6);
  animation: crBkScaleIn 0.4s ease;
}
@keyframes crBkScaleIn {
  from { transform: scale(0); opacity: 0; }
  to { transform: scale(1); opacity: 1; }
}
.confirmation-title {
  font-size: var(--cr-font-size-2xl);
  font-weight: var(--cr-font-weight-bold);
  margin-bottom: var(--cr-space-4);
}
.confirmation-message {
  color: var(--cr-text-secondary);
  margin-bottom: var(--cr-space-6);
  max-width: 400px;
  line-height: 1.6;
}
.confirmation-code {
  background-color: var(--cr-bg-secondary);
  padding: var(--cr-space-4);
  border-radius: var(--cr-radius-md);
  font-family: monospace;
  font-size: var(--cr-font-size-base);
  font-weight: var(--cr-font-weight-bold);
  margin-bottom: var(--cr-space-8);
  color: var(--cr-info);
  letter-spacing: 1px;
}
.confirmation-code:hover {
  background-color: var(--cr-bg-hover);
  border-color: var(--cr-border-hover, var(--cr-text-tertiary));
}
.confirmation-code {
  border: 1px solid transparent;
  transition: all 0.15s;
}
.confirmation-copy-hint {
  font-size: var(--cr-font-size-xs);
  color: var(--cr-text-tertiary);
  margin-top: calc(-1 * var(--cr-space-4));
  margin-bottom: var(--cr-space-6);
  transition: color 0.15s;
}
.confirmation-buttons {
  display: flex;
  gap: var(--cr-space-4);
  justify-content: center;
  flex-wrap: wrap;
}

/* Help text */
.cr-bk-help-text {
  font-size: var(--cr-font-size-xs);
  color: var(--cr-text-tertiary);
  margin-top: var(--cr-space-2);
}

/* ===== SKELETON LOADING ===== */
.cr-bk-skeleton {
  padding: var(--cr-space-2) 0;
}
.cr-bk-skel-row {
  margin-bottom: var(--cr-space-5);
}
.cr-bk-skel-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--cr-space-5);
  align-items: start;
}
.cr-bk-skel-legend {
  margin-top: var(--cr-space-3);
}
@media (max-width: 768px) {
  .cr-bk-skel-grid { grid-template-columns: 1fr; }
}

/* ===== CUSTOM FEE ROWS ===== */
.cr-bk-custom-fee-row {
  display: flex;
  align-items: center;
  gap: var(--cr-space-2);
  margin-bottom: var(--cr-space-2);
}
.cr-bk-custom-fee-row .cr-bk-input {
  font-size: var(--cr-font-size-xs);
  padding: var(--cr-space-1) var(--cr-space-2);
  height: 30px;
}

/* ===== ADDON SEARCH ===== */
.cr-bk-addon-search {
  height: 30px;
  padding: var(--cr-space-1) var(--cr-space-2);
}

/* ===== SM TOGGLE ROW ===== */
.cr-bk-sm-row {
  border-top: 1px solid var(--cr-border);
  padding-top: var(--cr-space-3);
  margin-top: var(--cr-space-2);
}
.cr-bk-sm-rate {
  font-size: var(--cr-font-size-xs);
  color: var(--cr-text-secondary);
}

/* ===== REVIEW DETAIL LINE ===== */
.cr-bk-rv-detail {
  padding: 0 var(--cr-space-3);
}
.cr-bk-rv-line.discount span:last-child {
  color: var(--cr-success);
}

/* ===== MOBILE ===== */
@media (max-width: 768px) {
  .cr-bk-body { padding: var(--cr-space-4); }
  .cr-bk-header { padding: var(--cr-space-4); }
  .cr-bk-header-title { font-size: var(--cr-font-size-lg); }

  .cr-bk-footer { padding: var(--cr-space-3) var(--cr-space-4); }
  .cr-bk-sets-grid { grid-template-columns: 1fr; }
  .cr-bk-rv-info-row { grid-template-columns: 1fr; }
  .confirmation-buttons { flex-direction: column; }
}

/* ═══════════════════════════════════════════════════════════════
   OFFER DRAWER — Shared styles for host offer + producer accept
   Reuses all .cr-bk-* classes above. Only additions here.
   ═══════════════════════════════════════════════════════════════ */

/* ── Producer search results ── */
.cr-offer-results {
  max-height: 240px;
  overflow-y: auto;
  margin-top: var(--cr-space-2);
}
.cr-offer-results .cr-bk-card-row {
  cursor: pointer;
  transition: background 0.15s;
}
.cr-offer-results .cr-bk-card-row:hover {
  background: var(--cr-bg-hover);
}

/* ── Addon rows (shared between offer drawer and future acceptance drawer) ── */
.cr-offer-addon-row {
  cursor: pointer;
}

/* ── Facility radio cards ── */
.cr-offer-fac-card {
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
}
.cr-offer-fac-card:hover {
  background: var(--cr-bg-hover);
}
.cr-offer-fac-card.selected {
  border-color: var(--cr-info);
  background: color-mix(in srgb, var(--cr-info) 6%, var(--cr-bg-primary));
}

/* ═══════════════════════════════════════════════════════════════
   DEAL MEMO FLYOUT — Producer acceptance drawer
   ═══════════════════════════════════════════════════════════════ */

/* ── Action Banner Bar ── */
.cr-deal-banner {
  display: flex;
  align-items: center;
  gap: var(--cr-space-4);
  padding: var(--cr-space-4) var(--cr-space-5);
  margin-bottom: var(--cr-space-5);
  border: 1px solid color-mix(in srgb, var(--cr-warning) 35%, transparent);
  border-radius: var(--cr-radius-md);
  background: color-mix(in srgb, var(--cr-warning) 5%, transparent);
}
.cr-deal-banner-icon {
  width: 40px;
  height: 40px;
  border-radius: var(--cr-radius-md);
  background: color-mix(in srgb, var(--cr-warning) 12%, transparent);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.cr-deal-banner-icon svg {
  width: 20px;
  height: 20px;
  color: var(--cr-warning);
}
.cr-deal-banner-content { flex: 1; min-width: 0; }
.cr-deal-banner-title {
  font-size: var(--cr-font-size-sm);
  font-weight: var(--cr-font-weight-semibold);
  color: var(--cr-text-primary);
  line-height: 1.3;
}
.cr-deal-banner-meta {
  font-size: var(--cr-font-size-xs);
  color: var(--cr-text-secondary);
  margin-top: 2px;
}
.cr-deal-banner-actions {
  display: flex;
  gap: var(--cr-space-3);
  flex-shrink: 0;
}

/* ── Payment banner variant ── */
.cr-deal-banner--payment {
  border-color: color-mix(in srgb, var(--cr-info) 35%, transparent);
  background: color-mix(in srgb, var(--cr-info) 5%, transparent);
}
.cr-deal-banner--payment .cr-deal-banner-icon {
  background: color-mix(in srgb, var(--cr-info) 12%, transparent);
}
.cr-deal-banner--payment .cr-deal-banner-icon svg {
  color: var(--cr-info);
}

/* ── Withdrawal alert card ── */
.cr-dm-alert-card {
  display: flex;
  align-items: flex-start;
  gap: var(--cr-space-2);
  padding: var(--cr-space-3) var(--cr-space-4);
  background: color-mix(in srgb, var(--cr-warning) 8%, transparent);
  border: 1px solid color-mix(in srgb, var(--cr-warning) 25%, transparent);
  border-radius: var(--cr-radius-md);
  margin-bottom: var(--cr-space-4);
  font-size: var(--cr-font-size-xs);
  color: var(--cr-text-secondary);
  line-height: 1.5;
}
.cr-dm-alert-icon {
  flex-shrink: 0;
  color: var(--cr-warning);
  display: flex;
  align-items: center;
  margin-top: 1px;
}

/* ── Toggle-reveal sections ── */
.cr-dm-toggle {
  border: 1px solid var(--cr-border);
  border-radius: var(--cr-radius-md);
  margin-bottom: var(--cr-space-3);
  overflow: hidden;
}
.cr-dm-toggle-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--cr-space-3) var(--cr-space-4);
  cursor: pointer;
  transition: background 0.15s;
  user-select: none;
}
.cr-dm-toggle-header:hover { background: var(--cr-bg-hover); }
.cr-dm-toggle-header-left {
  display: flex;
  align-items: center;
  gap: var(--cr-space-3);
}
.cr-dm-toggle-icon {
  width: 28px;
  height: 28px;
  border-radius: var(--cr-radius-sm);
  background: var(--cr-bg-tertiary);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.cr-dm-toggle-icon svg {
  width: 14px;
  height: 14px;
  color: var(--cr-text-secondary);
}
.cr-dm-toggle-label {
  font-size: var(--cr-font-size-sm);
  font-weight: var(--cr-font-weight-medium);
  color: var(--cr-text-primary);
}
.cr-dm-toggle-chev {
  width: 16px;
  height: 16px;
  color: var(--cr-text-tertiary);
  transition: transform 0.2s ease;
  flex-shrink: 0;
}
.cr-dm-toggle.open .cr-dm-toggle-chev { transform: rotate(180deg); }
.cr-dm-toggle-body {
  display: none;
  padding: var(--cr-space-2) var(--cr-space-4) var(--cr-space-4);
}
.cr-dm-toggle.open .cr-dm-toggle-body { display: block; }

/* ── Agreement text ── */
.cr-dm-agreement-text {
  font-size: var(--cr-font-size-xs);
  color: var(--cr-text-secondary);
  line-height: 1.7;
  max-height: 300px;
  overflow-y: auto;
  padding: var(--cr-space-3);
  background: var(--cr-bg-secondary);
  border-radius: var(--cr-radius-sm);
  border: 1px solid var(--cr-border);
}

/* ── Facility rules ── */
/* Rules grid — override toggle body padding so items go edge-to-edge */
.cr-dm-toggle-body:has(.cr-dm-rules-grid) { padding: 0; }
.cr-dm-rules-grid {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.cr-dm-rule-item {
  display: flex;
  align-items: flex-start;
  gap: var(--cr-space-3);
  padding: var(--cr-space-3) var(--cr-space-4);
  border-bottom: 1px solid var(--cr-border);
}
.cr-dm-rule-item:last-child { border-bottom: none; }
.cr-dm-rule-icon {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  margin-top: 2px;
}
.cr-dm-rule-icon.allowed { color: var(--cr-success); }
.cr-dm-rule-icon.restricted { color: var(--cr-warning); }
.cr-dm-rule-icon.prohibited { color: var(--cr-error); }
.cr-dm-rule-content { flex: 1; min-width: 0; }
.cr-dm-rule-name {
  font-size: var(--cr-font-size-sm);
  font-weight: var(--cr-font-weight-medium);
  color: var(--cr-text-primary);
  line-height: 1.4;
}
.cr-dm-rule-value {
  font-size: var(--cr-font-size-xs);
  color: var(--cr-text-secondary);
  margin-top: 1px;
}
.cr-dm-rule-value.allowed { color: var(--cr-success); }
.cr-dm-rule-value.restricted { color: var(--cr-warning); }
.cr-dm-rule-value.prohibited { color: var(--cr-error); }
.cr-dm-rule-note {
  font-size: var(--cr-font-size-xs);
  color: var(--cr-text-tertiary);
  line-height: 1.5;
  margin-top: var(--cr-space-1);
}
.cr-dm-rule-category {
  font-size: 10px;
  font-weight: var(--cr-font-weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--cr-text-tertiary);
  padding: var(--cr-space-2) var(--cr-space-4);
  margin: 0;
  background: var(--cr-bg-secondary);
  border-bottom: 1px solid var(--cr-border);
}
.cr-dm-rule-category:first-child { margin-top: 0; }

/* ── Accept confirmation modal ── */
.cr-dm-confirm-overlay {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 10001;
  background: rgba(0,0,0,0.4);
  align-items: center;
  justify-content: center;
}
.cr-dm-confirm-overlay.open { display: flex; }
.cr-dm-confirm-modal {
  background: var(--cr-bg-primary);
  border: 1px solid var(--cr-border);
  border-radius: var(--cr-radius-lg);
  padding: var(--cr-space-6);
  max-width: 380px;
  width: 90%;
  box-shadow: var(--cr-shadow-lg);
}
.cr-dm-confirm-title {
  font-size: var(--cr-font-size-md);
  font-weight: var(--cr-font-weight-bold);
  color: var(--cr-text-primary);
  margin-bottom: var(--cr-space-2);
}
.cr-dm-confirm-text {
  font-size: var(--cr-font-size-sm);
  color: var(--cr-text-secondary);
  line-height: 1.6;
  margin-bottom: var(--cr-space-5);
}
.cr-dm-confirm-actions {
  display: flex;
  gap: var(--cr-space-3);
  justify-content: flex-end;
}
.cr-dm-confirm-cancel {
  background: none;
  border: 1px solid var(--cr-border);
  border-radius: var(--cr-radius-md);
  padding: var(--cr-space-2) var(--cr-space-4);
  font-family: var(--cr-font-family);
  font-size: var(--cr-font-size-sm);
  color: var(--cr-text-secondary);
  cursor: pointer;
  transition: all 0.15s;
}
.cr-dm-confirm-cancel:hover { background: var(--cr-bg-secondary); }
.cr-dm-confirm-accept {
  background: var(--cr-accent);
  color: var(--cr-btn-primary-text, #f0f0f0);
  border: none;
  border-radius: var(--cr-radius-md);
  padding: var(--cr-space-2) var(--cr-space-4);
  font-family: var(--cr-font-family);
  font-size: var(--cr-font-size-sm);
  font-weight: var(--cr-font-weight-medium);
  cursor: pointer;
  transition: all 0.15s;
}
.cr-dm-confirm-accept:hover { background: var(--cr-accent-hover); }

/* ── Project details form (offer acceptance) ── */
.cr-dm-form-fields {
  display: flex;
  flex-direction: column;
  gap: var(--cr-space-3);
  margin-bottom: var(--cr-space-4);
}
.cr-dm-form-field {
  display: flex;
  flex-direction: column;
  gap: var(--cr-space-1);
}
.cr-dm-form-field label {
  font-size: var(--cr-font-size-sm);
  font-weight: var(--cr-font-weight-medium);
  color: var(--cr-text-secondary);
}
.cr-dm-form-field .cr-input,
.cr-dm-form-field .cr-select {
  width: 100%;
  box-sizing: border-box;
}
.cr-dm-field-error.cr-input,
.cr-dm-field-error.cr-select {
  border-color: var(--cr-error) !important;
}

/* ── Project details section wrapper (inline in drawer) ── */
.cr-dm-project-section {
  margin-bottom: var(--cr-space-5);
  padding-bottom: var(--cr-space-4);
  border-bottom: 1px solid var(--cr-border);
}

/* ── Payment terms rows ── */
.cr-dm-payment-row {
  display: flex;
  align-items: flex-start;
  gap: var(--cr-space-3);
  padding: var(--cr-space-3) 0;
  font-size: var(--cr-font-size-xs);
  color: var(--cr-text-secondary);
}
.cr-dm-payment-row + .cr-dm-payment-row {
  border-top: 1px solid color-mix(in srgb, var(--cr-border) 50%, transparent);
}
.cr-dm-payment-row .pay-label {
  flex: 1;
  font-weight: var(--cr-font-weight-medium);
  color: var(--cr-text-primary);
}
.cr-dm-payment-row .pay-value {
  font-variant-numeric: tabular-nums;
  text-align: right;
}
.cr-dm-payment-icon {
  width: 16px;
  height: 16px;
  color: var(--cr-text-tertiary);
  flex-shrink: 0;
  margin-top: 1px;
}

/* ── Inline decline area ── */
.cr-dm-decline-area {
  display: none;
  margin-top: var(--cr-space-4);
  padding-top: var(--cr-space-4);
  border-top: 1px solid var(--cr-border);
}
.cr-dm-decline-area.open {
  display: block;
  animation: crBkFadeIn 0.2s ease;
}
.cr-dm-decline-label {
  font-size: var(--cr-font-size-sm);
  font-weight: var(--cr-font-weight-semibold);
  color: var(--cr-text-primary);
  margin-bottom: var(--cr-space-2);
}
.cr-dm-decline-hint {
  font-size: var(--cr-font-size-xs);
  color: var(--cr-text-tertiary);
  margin-bottom: var(--cr-space-3);
}
.cr-dm-decline-textarea {
  width: 100%;
  min-height: 80px;
  padding: var(--cr-space-3);
  border: 1px solid var(--cr-border);
  border-radius: var(--cr-radius-md);
  background: var(--cr-bg-primary);
  color: var(--cr-text-primary);
  font-family: var(--cr-font-family);
  font-size: var(--cr-font-size-sm);
  resize: vertical;
  transition: border-color 0.15s;
  box-sizing: border-box;
}
.cr-dm-decline-textarea:focus {
  outline: none;
  border-color: var(--cr-border-focus);
}
.cr-dm-decline-actions {
  display: flex;
  justify-content: flex-end;
  gap: var(--cr-space-3);
  margin-top: var(--cr-space-3);
}
.cr-dm-decline-cancel {
  padding: var(--cr-space-2) var(--cr-space-4);
  border: 1px solid var(--cr-border);
  border-radius: var(--cr-radius-md);
  background: var(--cr-bg-primary);
  color: var(--cr-text-secondary);
  font-family: var(--cr-font-family);
  font-size: var(--cr-font-size-sm);
  font-weight: var(--cr-font-weight-medium);
  cursor: pointer;
  transition: all 0.15s;
}
.cr-dm-decline-cancel:hover { background: var(--cr-bg-hover); }
.cr-dm-decline-submit {
  padding: var(--cr-space-2) var(--cr-space-4);
  border: none;
  border-radius: var(--cr-radius-md);
  background: var(--cr-error);
  color: #fff;
  font-family: var(--cr-font-family);
  font-size: var(--cr-font-size-sm);
  font-weight: var(--cr-font-weight-medium);
  cursor: pointer;
  transition: all 0.15s;
}
.cr-dm-decline-submit:hover { opacity: 0.9; }

/* ── Agreement PDF link ── */
.cr-dm-agreement-link {
  display: flex;
  align-items: center;
  gap: var(--cr-space-3);
  padding: var(--cr-space-3) var(--cr-space-4);
  border: 1px solid var(--cr-border);
  border-radius: var(--cr-radius-md);
  background: var(--cr-bg-secondary);
  cursor: pointer;
  transition: all 0.15s;
  text-decoration: none;
  color: var(--cr-text-primary);
}
.cr-dm-agreement-link:hover {
  border-color: var(--cr-border-hover);
  background: var(--cr-bg-hover);
}
.cr-dm-agreement-link-icon {
  width: 32px;
  height: 32px;
  border-radius: var(--cr-radius-sm);
  background: color-mix(in srgb, var(--cr-error) 10%, transparent);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.cr-dm-agreement-link-icon svg {
  width: 16px;
  height: 16px;
  color: var(--cr-error);
}
.cr-dm-agreement-link-text { flex: 1; }
.cr-dm-agreement-link-name {
  font-size: var(--cr-font-size-sm);
  font-weight: var(--cr-font-weight-medium);
}
.cr-dm-agreement-link-meta {
  font-size: var(--cr-font-size-xs);
  color: var(--cr-text-tertiary);
}

/* ═══════════════════════════════════════════════════════════════
   OFFER DRAWER SHARED — facility header card, date items, message
   ═══════════════════════════════════════════════════════════════ */
.cr-bk-offer-header-card {
  border: 1px solid var(--cr-border);
  border-radius: var(--cr-radius-md);
  padding: var(--cr-space-4);
  margin-bottom: var(--cr-space-5);
}
.cr-bk-offer-from {
  display: flex;
  align-items: center;
  gap: var(--cr-space-3);
  margin-bottom: var(--cr-space-3);
}
.cr-bk-offer-from .facility-avatar {
  width: 40px;
  height: 40px;
  border-radius: var(--cr-radius-md);
  background: var(--cr-bg-tertiary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: var(--cr-font-weight-bold);
  font-size: var(--cr-font-size-xs);
  color: var(--cr-text-secondary);
}
.cr-bk-offer-from .facility-info { flex: 1; }
.cr-bk-offer-from .facility-name {
  font-size: var(--cr-font-size-sm);
  font-weight: var(--cr-font-weight-semibold);
  color: var(--cr-text-primary);
}
.cr-bk-offer-from .facility-loc {
  font-size: var(--cr-font-size-xs);
  color: var(--cr-text-tertiary);
}
.cr-bk-offer-from:last-child {
  margin-bottom: 0;
}
.cr-bk-offer-message {
  font-size: var(--cr-font-size-sm);
  color: var(--cr-text-secondary);
  line-height: 1.6;
  padding: var(--cr-space-3);
  background: var(--cr-bg-primary);
  border-radius: var(--cr-radius-sm);
  border: 1px solid var(--cr-border);
}
.cr-bk-offer-dates {
  display: flex;
  flex-direction: column;
  gap: var(--cr-space-2);
}
.cr-bk-offer-date-item {
  display: flex;
  align-items: center;
  padding: var(--cr-space-3) var(--cr-space-4);
  border: 1px solid var(--cr-border);
  border-radius: var(--cr-radius-md);
  gap: var(--cr-space-3);
}
.cr-bk-offer-date-item .date-icon {
  width: 38px;
  text-align: center;
  line-height: 1.1;
  flex-shrink: 0;
}
.cr-bk-offer-date-item .date-icon .month {
  font-size: 9px;
  text-transform: uppercase;
  color: var(--cr-text-tertiary);
  letter-spacing: 0.05em;
  font-weight: var(--cr-font-weight-medium);
}
.cr-bk-offer-date-item .date-icon .day {
  font-size: var(--cr-font-size-xl);
  font-weight: var(--cr-font-weight-bold);
  color: var(--cr-text-primary);
  line-height: 1;
}
.cr-bk-offer-date-item .date-info { flex: 1; }
.cr-bk-offer-date-item .date-label {
  font-size: var(--cr-font-size-sm);
  font-weight: var(--cr-font-weight-medium);
  color: var(--cr-text-primary);
}
.cr-bk-offer-date-item .date-amount {
  font-size: var(--cr-font-size-sm);
  font-weight: var(--cr-font-weight-semibold);
  font-variant-numeric: tabular-nums;
  color: var(--cr-text-primary);
}

/* ── Day cards (deal memo production dates) ── */
.cr-dm-day-card {
  border: 1px solid var(--cr-border);
  border-radius: var(--cr-radius-md);
  padding: var(--cr-space-3) var(--cr-space-4);
}
.cr-bk-offer-dates .cr-dm-day-card + .cr-dm-day-card {
  margin-top: var(--cr-space-3);
}
.cr-dm-day-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--cr-space-3);
}
.cr-dm-day-date {
  font-size: var(--cr-font-size-md);
  font-weight: var(--cr-font-weight-semibold);
  color: var(--cr-text-primary);
}
.cr-dm-day-time {
  font-size: var(--cr-font-size-xs);
  font-weight: var(--cr-font-weight-regular);
  color: var(--cr-text-tertiary);
  margin-left: var(--cr-space-1);
}
.cr-dm-day-meta {
  font-size: var(--cr-font-size-xs);
  color: var(--cr-text-tertiary);
  margin-top: 2px;
}
/* Toggle button */
.cr-dm-day-toggle {
  display: flex;
  align-items: center;
  gap: var(--cr-space-1);
  background: none;
  border: 1px solid var(--cr-border);
  border-radius: var(--cr-radius-sm);
  padding: 2px var(--cr-space-2);
  cursor: pointer;
  color: var(--cr-text-tertiary);
  font-size: var(--cr-font-size-xs);
  font-family: var(--cr-font-family);
  flex-shrink: 0;
  transition: color 0.15s, border-color 0.15s;
}
.cr-dm-day-toggle:hover {
  color: var(--cr-text-primary);
  border-color: var(--cr-text-tertiary);
}
.cr-dm-day-toggle.open .cr-dm-day-toggle-icon svg {
  transform: rotate(180deg);
}
.cr-dm-day-toggle-icon {
  display: flex;
  align-items: center;
}
.cr-dm-day-toggle-icon svg {
  transition: transform 0.2s;
}
/* Collapsible body — hidden by default */
.cr-dm-day-body {
  display: none;
  margin-top: var(--cr-space-3);
}
.cr-dm-day-card.open .cr-dm-day-body {
  display: block;
  animation: crBkFadeIn 0.2s ease;
}
.cr-dm-day-lines {
  border-top: 1px solid var(--cr-border);
}
.cr-dm-day-line-item {
  display: flex;
  justify-content: space-between;
  font-size: var(--cr-font-size-xs);
  color: var(--cr-text-secondary);
  padding: var(--cr-space-2) 0;
  border-bottom: 1px solid color-mix(in srgb, var(--cr-border) 50%, transparent);
  font-variant-numeric: tabular-nums;
}
.cr-dm-day-line-item:last-child {
  border-bottom: none;
}
.cr-dm-day-subtotal {
  display: flex;
  justify-content: space-between;
  font-size: var(--cr-font-size-sm);
  font-weight: var(--cr-font-weight-semibold);
  color: var(--cr-text-primary);
  padding-top: var(--cr-space-2);
  border-top: 1px solid var(--cr-border);
  font-variant-numeric: tabular-nums;
}

/* ── Offer card: expandable warning text ── */
.cr-dm-warn-text {
  display: none;
  text-align: right;
  font-size: var(--cr-font-size-xs);
  color: var(--cr-text-tertiary);
  line-height: 1.4;
  margin-top: var(--cr-space-2);
  padding-top: var(--cr-space-2);
  border-top: 1px solid var(--cr-border);
}
.cr-dm-warn-text.open {
  display: block;
  animation: crBkFadeIn 0.2s ease;
}
#dm-warn-toggle {
  transition: opacity 0.15s;
}
#dm-warn-toggle.open {
  opacity: 0.6;
}

/* ── Smaller form fields in Details card ── */
#cr-dm-drawer .cr-dm-form-field .cr-input,
#cr-dm-drawer .cr-dm-form-field .cr-select {
  padding: var(--cr-space-2) var(--cr-space-3);
  font-size: var(--cr-font-size-xs);
}
#cr-dm-drawer .cr-dm-form-field label {
  font-size: 11px;
}
/* Deal memo footer — decline button and accent accept button */
#cr-dm-drawer .cr-bk-footer-decline {
  background: none;
  border: 1px solid color-mix(in srgb, var(--cr-error) 40%, transparent);
  border-radius: var(--cr-radius-md);
  padding: var(--cr-space-2) var(--cr-space-4);
  color: var(--cr-error);
  font-family: var(--cr-font-family);
  font-size: var(--cr-font-size-sm);
  font-weight: var(--cr-font-weight-medium);
  cursor: pointer;
  transition: all 0.2s;
}
#cr-dm-drawer .cr-bk-footer-decline:hover {
  background: color-mix(in srgb, var(--cr-error) 8%, transparent);
}
#cr-dm-drawer .cr-bk-btn-next {
  background: var(--cr-accent);
  color: var(--cr-btn-primary-text, #f0f0f0);
}
#cr-dm-drawer .cr-bk-btn-next:hover {
  background: var(--cr-accent-hover);
  opacity: 1;
}

/* ── Location Agreement Lightbox ── */
.cr-dm-lightbox {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 10002;
  align-items: center;
  justify-content: center;
}
.cr-dm-lightbox.open {
  display: flex;
}
.cr-dm-lightbox-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(4px);
}
.cr-dm-lightbox-panel {
  position: relative;
  background: var(--cr-bg-primary);
  border: none;
  border-radius: 0;
  box-shadow: none;
  width: 100vw;
  height: 100vh;
  max-width: none;
  max-height: none;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.cr-dm-lightbox-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--cr-space-4) var(--cr-space-6);
  border-bottom: 1px solid var(--cr-border);
  flex-shrink: 0;
}
.cr-dm-lightbox-title {
  font-size: var(--cr-font-size-md);
  font-weight: var(--cr-font-weight-semibold);
  color: var(--cr-text-primary);
}
.cr-dm-lightbox-actions {
  display: flex;
  align-items: center;
  gap: var(--cr-space-2);
}
.cr-dm-lightbox-btn {
  background: none;
  border: none;
  padding: var(--cr-space-2);
  border-radius: var(--cr-radius-sm);
  color: var(--cr-text-tertiary);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.15s;
  text-decoration: none;
}
.cr-dm-lightbox-btn:hover {
  color: var(--cr-text-primary);
  background: var(--cr-bg-hover);
}
.cr-dm-lightbox-body {
  flex: 1;
  overflow-y: auto;
  position: relative;
}
.cr-dm-lightbox-watermark {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(-35deg);
  font-size: 80px;
  font-weight: var(--cr-font-weight-bold);
  color: color-mix(in srgb, var(--cr-text-tertiary) 12%, transparent);
  text-transform: uppercase;
  letter-spacing: 0.15em;
  pointer-events: none;
  user-select: none;
  white-space: nowrap;
  z-index: 1;
}
.cr-dm-lightbox-content {
  position: relative;
  z-index: 0;
  padding: var(--cr-space-8) var(--cr-space-6);
  max-width: 720px;
  margin: 0 auto;
}
.cr-dm-lightbox-doc p {
  margin: 0;
}
