/* ReservationBody.css — стили тела карточки брони (ReservationBody.js).
 *
 * F632.W5 — выделены из монолита calendar-v2.css (Класс F: стили карточки были
 * размазаны внутри 1970-строчного файла сетки). Каркас shell — в drawer-shared.css;
 * здесь — содержимое карточки: drawer-секции/поля/статус, вкладки, история, контакт,
 * source-бейдж, продление. Деньги/чек — в ReservationReceipt.css; B24-привязка и
 * оверлей «Добавить ресурс» — в ReservationActions.css.
 *
 * Всё на токенах tokens.css, dark-safe (без light-hex fallback на поверхностях).
 * Подключается ПОСЛЕ calendar-v2.css и drawer-shared.css (index.html).
 */

/* — Booking drawer (reuses Drawer.js base; per-content styles) ─ */
.cv2-drawer-content { padding: var(--space-5); }
.cv2-drawer-content h2 {
  font-size: var(--text-xl);
  font-weight: var(--font-semibold);
  letter-spacing: var(--tracking-tight);
  margin: 0 0 var(--space-4);
}
.cv2-drawer-section {
  margin-bottom: var(--space-4); /* F632.W7 — плотнее (был space-5): карточка не растянута */
  padding-bottom: var(--space-4);
  border-bottom: 1px solid var(--color-border);
}
.cv2-drawer-section:last-child { border-bottom: 0; }
.cv2-drawer-field {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: var(--space-3);
  padding: var(--space-2) 0;
  font-size: var(--text-sm);
}
.cv2-drawer-field-label { color: var(--color-text-muted); }
.cv2-drawer-field-value { color: var(--color-text); }
.cv2-drawer-status-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: var(--radius-full);
  color: var(--brand-on-cta); /* F632.W7 — theme-stable белый на насыщенном чипе (НЕ text-inverse, тот в dark флипается в тёмный → низкий контраст) */
  font-size: var(--text-xs);
  font-weight: var(--font-medium);
  background: var(--color-status-confirmed);
}
.cv2-drawer-status-badge[data-status="pending"]     { background: var(--color-status-pending); }
.cv2-drawer-status-badge[data-status="confirmed"]   { background: var(--color-status-confirmed); }
.cv2-drawer-status-badge[data-status="checked_in"]  { background: var(--color-status-checked-in); }
.cv2-drawer-status-badge[data-status="checked_out"] { background: var(--color-status-checked-out); }
.cv2-drawer-status-badge[data-status="cancelled"]   { background: var(--color-status-cancelled); }
.cv2-drawer-status-badge[data-status="no_show"]     { background: var(--color-status-no-show); }

/* F66.W6 — заголовок секции карточки (напр. «ОПЛАТА»). */
.cv2-drawer-section-title {
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
  text-transform: uppercase;
  letter-spacing: var(--tracking-caps);
  color: var(--color-text-subtle);
  margin-bottom: var(--space-2);
}

/* F4.W4.fix4 — inline status picker в detail drawer (канон Trello/Linear).
   Цвет фона select наследует data-status через атрибут (см. правила ниже). */
.cv2-status-picker-wrap { display: flex; align-items: center; }
.cv2-status-picker {
  appearance: none;
  -webkit-appearance: none;
  border: 1px solid transparent;
  border-radius: var(--radius-md);
  padding: 6px 28px 6px 12px;
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  color: var(--brand-on-cta); /* F632.W7 — theme-stable белый (см. status-badge) */
  background: var(--color-status-confirmed) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2'><polyline points='6 9 12 15 18 9'/></svg>") no-repeat right 8px center / 12px 12px;
  cursor: pointer;
  transition: filter var(--dur-fast) var(--ease-decelerate), box-shadow var(--dur-fast) var(--ease-decelerate);
}
.cv2-status-picker:hover { filter: brightness(1.08); box-shadow: var(--shadow-pop); }
.cv2-status-picker:focus-visible { outline: none; box-shadow: var(--focus-ring); } /* F632.W7 — WCAG 2.4.11 */
.cv2-status-picker:disabled { opacity: 0.6; cursor: wait; }
.cv2-status-picker[data-status="pending"]     { background-color: var(--color-status-pending); }
.cv2-status-picker[data-status="confirmed"]   { background-color: var(--color-status-confirmed); }
.cv2-status-picker[data-status="checked_in"]  { background-color: var(--color-status-checked-in); }
.cv2-status-picker[data-status="checked_out"] { background-color: var(--color-status-checked-out); }
.cv2-status-picker[data-status="cancelled"]   { background-color: var(--color-status-cancelled); }
.cv2-status-picker[data-status="no_show"]     { background-color: var(--color-status-no-show); }
.cv2-status-picker option { color: var(--color-text); background: var(--color-bg); }

/* F507.W4.3 — source-бейдж брони (происхождение: Telegram-бот). Зеркалит
   cv2-pay-chip. Telegram-синий насыщенный → белый текст читаем в обеих темах. */
.cv2-source-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 3px 10px;
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
  color: var(--brand-on-cta); /* F632.W7 — theme-stable белый на насыщенном канале */
}
.cv2-source-badge.is-telegram-bot { background: var(--color-source-telegram); }
/* F622.W5 — external-block с OTA-площадки (iCal-импорт). Нейтрально-тёмный slate
   (не бренд канала — generic «внешний блок»), белый текст читаем в обеих темах. */
.cv2-source-badge.is-ical-import { background: var(--color-source-ota); }
.cv2-source-badge svg { width: 14px; height: 14px; }

/* F4.W4.5 — B24 contact picker + inline create */
.cv2-create-contact-toggle {
  align-self: flex-start;
  font-size: var(--text-sm);
  padding: 6px 10px;
}
.cv2-create-contact-inline {
  border: 1px dashed var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-3);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-top: var(--space-1);
}
.cv2-contact-b24-link {
  color: var(--brand-primary);
  text-decoration: none;
  font-weight: var(--font-medium);
  border-radius: var(--radius-sm);
}
.cv2-contact-b24-link:hover { text-decoration: underline; }
.cv2-contact-b24-link:focus-visible { outline: none; box-shadow: var(--focus-ring); } /* F632.W7 */

/* F637.W1 — identity-header операторской консоли: имя крупно + кликабельные
   контакты (tel:/mailto:) первым блоком карточки (канон Mews/Resy folio header). */
.cv2-rb-identity { display: flex; flex-direction: column; gap: var(--space-1); }
.cv2-rb-identity-name {
  font-size: var(--text-lg);
  font-weight: var(--font-semibold);
  letter-spacing: var(--tracking-tight);
  color: var(--color-text);
}
a.cv2-rb-identity-name {
  display: inline-flex; align-items: center; gap: 6px; width: fit-content;
  text-decoration: none; border-radius: var(--radius-sm);
}
a.cv2-rb-identity-name:hover { text-decoration: underline; }
a.cv2-rb-identity-name:focus-visible { outline: none; box-shadow: var(--focus-ring); }
.cv2-rb-identity-crm-ico { display: inline-flex; color: var(--color-text-muted); }
.cv2-rb-identity-crm-ico svg { width: 14px; height: 14px; }
.cv2-rb-identity-contacts { display: flex; flex-wrap: wrap; gap: var(--space-1) var(--space-3); }
.cv2-rb-identity-contact {
  font-size: var(--text-sm);
  color: var(--brand-primary);
  text-decoration: none;
  border-radius: var(--radius-sm);
}
.cv2-rb-identity-contact:hover { text-decoration: underline; }
.cv2-rb-identity-contact:focus-visible { outline: none; box-shadow: var(--focus-ring); }

/* F68.W6 — вкладки «Чек»/«История» в карточке брони + timeline истории */
.cv2-drawer-tabs {
  display: flex;
  gap: var(--space-1);
  padding: 0 var(--space-4);
  border-bottom: 1px solid var(--color-border);
}
.cv2-drawer-tab {
  appearance: none;
  border: none;
  background: transparent;
  color: var(--color-text-muted);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  padding: var(--space-3) var(--space-2);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  transition: color var(--dur-fast) var(--ease-standard), border-color var(--dur-fast) var(--ease-standard);
}
.cv2-drawer-tab:hover { color: var(--color-text); }
.cv2-drawer-tab:focus-visible { outline: none; color: var(--color-text); box-shadow: var(--focus-ring); border-radius: var(--radius-sm); } /* F632.W7 */
.cv2-drawer-tab.is-active {
  color: var(--brand-primary);
  border-bottom-color: var(--brand-primary);
}
.cv2-tab-panel { display: none; }
.cv2-tab-panel.is-active { display: block; }

.cv2-history-loading,
.cv2-history-empty {
  padding: var(--space-5) var(--space-4);
  text-align: center;
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}
.cv2-history-list {
  list-style: none;
  margin: 0;
  padding: var(--space-3) var(--space-4);
}
.cv2-history-item {
  display: flex;
  gap: var(--space-3);
  padding: var(--space-2) 0;
  position: relative;
}
.cv2-history-item::before {
  content: "";
  position: absolute;
  left: 11px;
  top: 26px;
  bottom: -6px;
  width: 1px;
  background: var(--color-border);
}
.cv2-history-item:last-child::before { display: none; }
.cv2-history-icon {
  flex: 0 0 auto;
  width: 24px;
  height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--color-bg-muted);
  color: var(--color-text-muted);
  border: 1px solid var(--color-border);
  z-index: 1;
}
.cv2-history-icon svg { width: 14px; height: 14px; }
.cv2-history-body { flex: 1 1 auto; min-width: 0; }
.cv2-history-text { font-size: var(--text-sm); color: var(--color-text); line-height: 1.4; }
.cv2-history-sub { font-size: var(--text-xs); color: var(--color-text-muted); margin-top: 2px; word-break: break-word; }
.cv2-history-time { font-size: var(--text-xs); color: var(--color-text-subtle); margin-top: 2px; }

/* F68.W7.C — «Продлить выезд»: ярлык-кнопка + inline qty-stepper в шапке карточки */
.cv2-extend-wrap .cv2-extend-value { display: flex; align-items: center; }
.cv2-extend-open-btn { min-height: 36px; }
.cv2-extend-stepper { display: flex; align-items: center; gap: var(--space-2); flex-wrap: wrap; }
.cv2-extend-stepper .cv2-step-hint { color: var(--color-text-muted); font-size: var(--text-xs); }
.cv2-extend-stepper .cv2-step-btn {
  width: 44px; height: 44px; min-width: 44px;
  display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid var(--color-border); background: var(--color-bg); color: var(--color-text);
  border-radius: var(--radius-md); cursor: pointer; font-size: var(--text-md);
  touch-action: manipulation; transition: background var(--dur-fast) var(--ease-standard);
}
.cv2-extend-stepper .cv2-step-btn:hover:not(:disabled) { background: var(--color-bg-subtle); }
.cv2-extend-stepper .cv2-step-btn:disabled { opacity: 0.4; cursor: default; }
.cv2-extend-stepper .cv2-step-num { min-width: 28px; text-align: center; font-variant-numeric: tabular-nums; }
.cv2-extend-stepper .cv2-extend-apply { min-height: 44px; }
.cv2-extend-stepper .cv2-extend-cancel { min-height: 44px; min-width: 44px; }

/* F637.W3 — операторская консоль: статус (1 клик) + «Продлить выезд» в ОДНОМ ряду
   (канон Mews/Resy quick-actions). Дети-поля стопкой (label над контролом); кластер —
   flex с переносом на узком экране. extendWrap скрыт (display:none) пока folio не наполнит
   его → при отсутствии товара-продлителя в ряду остаётся только статус. */
.cv2-status-extend-row {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: var(--space-2) var(--space-4);
}
.cv2-status-extend-row > .cv2-drawer-field {
  grid-template-columns: 1fr;
  gap: 2px;
}
.cv2-status-extend-row > .cv2-status-field { flex: 0 0 auto; }
.cv2-status-extend-row > .cv2-extend-wrap { flex: 1 1 auto; }

/* F637.W4 — свёрнутая секция «Детали» (WAI-ARIA disclosure): редкое под сгибом.
   Чевронная кнопка-триггер + ленивое содержимое; default свёрнуто (style.display:none). */
.cv2-details-toggle {
  display: flex; align-items: center; gap: var(--space-2); width: 100%;
  appearance: none; border: none; background: transparent; text-align: left; cursor: pointer;
  color: var(--color-text-muted); font-family: var(--font-sans);
  font-size: var(--text-sm); font-weight: var(--font-medium);
  padding: var(--space-3) 0;
  transition: color var(--dur-fast) var(--ease-standard);
}
.cv2-details-toggle:hover { color: var(--color-text); }
.cv2-details-toggle:focus-visible { outline: none; box-shadow: var(--focus-ring); border-radius: var(--radius-sm); }
.cv2-details-chevron { display: inline-flex; color: var(--color-text-subtle); transition: transform var(--dur-fast) var(--ease-standard); }
.cv2-details-chevron svg { width: 16px; height: 16px; }
.cv2-details-toggle[aria-expanded="true"] .cv2-details-chevron { transform: rotate(90deg); }
.cv2-details-content > .cv2-drawer-section:last-child { border-bottom: 0; }

/* F4.W4.fix4 — drawer footer для detail-view с кнопками Закрыть / Редактировать.
   F68.W3 — sticky action bar: full-bleed (негативные поля гасят padding
   .cv2-drawer-content) + position:sticky bottom:0 → залипает при скролле длинного
   чека (Stripe/Linear drawer canon). Тач-норма кнопок 44px. */
.cv2-drawer-footer {
  display: flex;
  gap: var(--space-3);
  justify-content: flex-end;
  position: sticky;
  bottom: 0;
  margin: var(--space-4) calc(-1 * var(--space-5)) calc(-1 * var(--space-5));
  padding: var(--space-3) var(--space-5);
  border-top: 1px solid var(--color-border);
  background: var(--color-bg);
  z-index: 2;
}
.cv2-drawer-footer .cv2-action-btn { min-height: 44px; }

/* — Mobile (< 768px) — поле карточки в одну колонку — */
@media (max-width: 767px) {
  .cv2-drawer-field { grid-template-columns: 1fr; gap: 2px; }
}
