/*
 * Shared Design System Variables (Tokens)
 * Defines the single source of truth for colors, typography, spacing, and shapes.
 */
:root {
  /* Typography */
  --font-family-base: "Source Sans Pro", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --font-size-base: 0.875rem; /* 14px */
  --font-size-sm: 0.75rem;    /* 12px */
  --font-size-lg: 1.125rem;   /* 18px */
  --font-size-h1: 1.5rem;     /* 24px */
  --font-size-h2: 1.25rem;    /* 20px */
  
  /* Colors - Brand */
  --color-primary: #0f4c81;
  --color-primary-hover: #0c3c66;
  --color-accent: #2f80ed;
  --color-accent-soft: #eaf3ff;
  
  /* Colors - Status */
  --color-success: #2e9f5b;
  --color-danger: #d64545;
  --color-warning: #d99513;
  --color-info: #1f98a8;
  
  /* Colors - Interface */
  --color-secondary: #6f7a85;
  --color-text: #1f2933;
  --color-text-muted: #6b7785;
  --color-text-inverse: #ffffff;
  --color-bg-page: #f5f7fb;
  --color-bg-card: #ffffff;
  --color-bg-header: #f8fafc;
  --color-border: #dbe3ec;
  --color-border-strong: #c5d1de;
  --color-focus-ring: rgba(47, 128, 237, 0.25);

  --color-success-soft-bg: #edf9f2;
  --color-success-soft-border: #bde6ce;
  --color-success-soft-text: #1d7f48;
  --color-danger-soft-bg: #fdf0f2;
  --color-danger-soft-border: #f1b8bf;
  --color-danger-soft-text: #b43240;
  --color-warning-soft-bg: #fff8e9;
  --color-warning-soft-border: #f0d79f;
  --color-warning-soft-text: #9c6a00;

  /* Spacing & Shapes */
  --border-radius: 0.5rem;
  --radius-sm: 0.25rem;

  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;

  --shadow-card: 0 6px 18px rgba(28, 45, 64, 0.08);
  --shadow-soft: 0 2px 8px rgba(28, 45, 64, 0.06);
  --transition: 0.2s ease;
}

body {
  font-family: var(--font-family-base) !important;
  font-size: var(--font-size-base) !important;
  color: var(--color-text);
  line-height: 1.5;
}

.ui-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-1);
  min-height: 2rem;
  padding: var(--space-1) var(--space-3);
  border-radius: var(--border-radius);
  border: 1px solid transparent;
  font-size: var(--font-size-base);
  font-weight: 600;
  text-decoration: none;
  line-height: 1;
  transition: all var(--transition);
}

.ui-btn:hover,
.ui-btn:focus {
  text-decoration: none;
}

.ui-btn:focus {
  box-shadow: 0 0 0 0.15rem var(--color-focus-ring);
}

.ui-btn--primary {
  background-color: var(--color-primary) !important;
  border-color: var(--color-primary) !important;
  color: var(--color-text-inverse) !important;
}

.ui-btn--primary:hover,
.ui-btn--primary:focus {
  background-color: var(--color-primary-hover) !important;
  border-color: var(--color-primary-hover) !important;
  color: var(--color-text-inverse) !important;
}

.ui-btn--secondary {
  background-color: var(--color-bg-card) !important;
  border-color: var(--color-border-strong) !important;
  color: var(--color-text) !important;
}

.ui-btn--secondary:hover,
.ui-btn--secondary:focus {
  background-color: var(--color-bg-header) !important;
  border-color: var(--color-border-strong) !important;
  color: var(--color-text) !important;
}

.ui-btn--ghost {
  background-color: var(--color-bg-card) !important;
  border-color: var(--color-border) !important;
  color: var(--color-primary) !important;
}

.ui-btn--ghost:hover,
.ui-btn--ghost:focus {
  background-color: var(--color-accent-soft) !important;
  border-color: var(--color-accent) !important;
  color: var(--color-primary) !important;
}

.ui-btn--danger {
  background-color: var(--color-bg-card) !important;
  border-color: var(--color-danger) !important;
  color: var(--color-danger) !important;
}

.ui-btn--danger:hover,
.ui-btn--danger:focus {
  background-color: var(--color-danger) !important;
  border-color: var(--color-danger) !important;
  color: var(--color-text-inverse) !important;
}

.ui-btn--icon {
  width: 1.8rem;
  min-height: 1.8rem;
  padding: 0;
  border-radius: var(--border-radius);
}

.ui-dropdown-item {
  font-size: var(--font-size-base);
  padding: var(--space-2) var(--space-3);
}

/* ─── Общие компоненты CRM ─────────────────────────────────────────────────── */

.terminated-banner {
  background-color: var(--color-danger);
  color: var(--color-text-inverse);
  padding: var(--surface-padding-y, 0.5rem) var(--surface-padding-x, 0.75rem);
  margin-bottom: var(--space-2);
  border-radius: var(--surface-radius, var(--border-radius));
  font-weight: 600;
  text-align: center;
}

.crm-section {
  margin-bottom: var(--space-3);
  border-radius: var(--surface-radius, var(--border-radius));
  box-shadow: var(--shadow-soft);
  border: 1px solid var(--color-border);
  background-color: var(--color-bg-card);
}

.crm-section__header {
  background-color: var(--color-bg-header);
  color: var(--color-text);
  border-bottom: 1px solid var(--color-border);
  padding: var(--surface-padding-y, 0.5rem) var(--surface-padding-x, 0.75rem);
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 38px;
}

.crm-section__title {
  font-size: var(--font-size-base);
  font-weight: 700;
  margin: 0;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--color-primary);
}

.crm-section__body {
  background-color: var(--color-bg-card);
  padding: var(--surface-padding-y, 0.5rem) var(--surface-padding-x, 0.75rem);
}

.crm-section__body .card {
  border-color: var(--color-border);
  border-radius: var(--surface-radius, var(--border-radius));
  box-shadow: none;
  margin-bottom: var(--space-2);
}

.crm-section__body .card .card-header {
  background-color: var(--color-bg-header);
  border-bottom: 1px solid var(--color-border);
  padding: var(--surface-padding-y, 0.5rem) var(--surface-padding-x, 0.75rem);
}

.crm-section__body .card .card-body {
  padding: var(--surface-padding-y, 0.5rem) var(--surface-padding-x, 0.75rem);
}

.crm-section__body .card:last-child {
  margin-bottom: 0;
}

.crm-section__body .row {
  margin-left: -0.35rem;
  margin-right: -0.35rem;
}

.crm-section__body .row > [class*='col-'] {
  padding-left: 0.35rem;
  padding-right: 0.35rem;
}

.crm-field__label {
  font-size: var(--font-size-label);
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: 0;
}

.crm-field__value {
  font-size: var(--font-size-base);
  color: var(--color-text);
  font-weight: 600;
}

.insured-card {
  border: 1px solid var(--color-border);
  border-radius: var(--surface-radius, var(--border-radius));
  padding: var(--surface-padding-y, 0.5rem) var(--surface-padding-x, 0.75rem);
  background-color: var(--color-bg-card);
  height: 100%;
  box-shadow: var(--shadow-soft);
  transition: all var(--transition);
}

.insured-card:hover {
  border-color: var(--color-border-strong);
  transform: translateY(-1px);
}

.insured-card__name {
  font-size: var(--font-size-base);
  font-weight: 700;
  color: var(--color-primary);
  margin-bottom: var(--space-1);
}

.crm-btn-group {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  flex-wrap: wrap;
}

/* ─── Аватар пользователя/клиента ───────────────────────────────────────────── */
.entity-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}

/* ─── Подзаголовки внутри секций (для группировки таблиц) ───────────────────── */
.section-sub-label {
  font-size: .75rem;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--color-text-muted);
  display: block;
  margin-bottom: .5rem;
  font-weight: 600;
}

.ui-btn--icon-only {
    width: 2rem;
    padding: 0;
}

/* ─── Модалка генерации отчетов ─────────────────────────────────────────────── */
#report_modal .modal-dialog {
  max-width: 500px;
}

#report_modal .modal-body {
  min-height: 220px;
  display: flex;
  align-items: center;
  justify-content: center;
}

#report_modal .overlay-wrapper {
  padding: var(--space-4);
  width: 100%;
}

#report_modal .overlay {
  flex-direction: column !important;
  gap: var(--space-2);
}

#report_modal .overlay > div {
  word-wrap: break-word;
  word-break: break-word;
  overflow-wrap: break-word;
  text-align: center;
  width: 100%;
}

#report_modal .overlay a {
  display: inline-block;
  margin: var(--space-1);
  color: var(--color-primary);
  text-decoration: underline;
  word-wrap: break-word;
  word-break: break-all;
  max-width: 100%;
}

#report_modal .overlay a:hover {
  color: var(--color-primary-hover);
}

/* ─── Toast notifications ─────────────────────────────────────────────────── */

.crm-toast-stack {
    position: fixed;
    bottom: 1.25rem;
    right: 1.25rem;
    z-index: 9999;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    max-width: 22rem;
    pointer-events: none;
}

.crm-toast {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.6rem 0.75rem;
    border-radius: var(--border-radius);
    border: 1px solid transparent;
    box-shadow: var(--shadow-card);
    font-size: var(--font-size-sm);
    font-weight: 500;
    line-height: 1.4;
    pointer-events: all;
    animation: crm-toast-in 0.2s ease;
}

@keyframes crm-toast-in {
    from { opacity: 0; transform: translateY(0.5rem); }
    to   { opacity: 1; transform: translateY(0); }
}

.crm-toast--danger {
    background-color: var(--color-danger-soft-bg);
    border-color: var(--color-danger-soft-border);
    color: var(--color-danger-soft-text);
}

.crm-toast--warning {
    background-color: var(--color-warning-soft-bg);
    border-color: var(--color-warning-soft-border);
    color: var(--color-warning-soft-text);
}

.crm-toast__icon {
    flex-shrink: 0;
    font-size: 0.875rem;
}

.crm-toast__body {
    flex: 1;
}

.crm-toast__link {
    font-weight: 700;
    text-decoration: underline;
    color: inherit;
}

.crm-toast__link:hover {
    opacity: 0.8;
}

.crm-toast__close {
    flex-shrink: 0;
    background: none;
    border: none;
    padding: 0 0 0 0.25rem;
    font-size: 1rem;
    line-height: 1;
    cursor: pointer;
    color: inherit;
    opacity: 0.6;
    transition: opacity var(--transition);
}

.crm-toast__close:hover {
    opacity: 1;
}

.custom-dropdown-menu {
  padding: var(--space-2);
  min-width: 0;
  width: max-content;
  max-width: 240px;
  flex-direction: column;
  gap: var(--space-2);
}

.custom-dropdown-menu.show {
  display: flex;
}

.custom-dropdown-menu h5 {
  margin: 0;
  padding: 0 var(--space-1);
  font-size: var(--font-size-base);
  font-weight: 400;
  color: var(--color-text-muted);
  white-space: nowrap;
}

.custom-dropdown-menu .dropdown-divider {
  margin: 0;
}

.custom-dropdown-menu .btn {
  align-self: stretch;
  white-space: nowrap;
}
/* Form components */
.crm-form-price-preview {
  background-color: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--border-radius);
  padding: var(--space-3);
  min-height: 4rem;
}

.crm-form-price-preview p {
  margin: 0;
  font-size: var(--font-size-lg);
  font-weight: 700;
  color: var(--color-text);
}

/* ─── DataTables Actions Dropdown ───────────────────────────────────────── */
.ui-btn--sm {
  min-height: 1.75rem;
  padding: var(--space-1) var(--space-2);
  font-size: var(--font-size-sm);
}

.travel-actions-dropdown {
  display: inline-block;
  position: relative;
}

.travel-actions-dropdown .dropdown-toggle::after {
  display: none;
}

.travel-actions-dropdown .dropdown-toggle::before {
  display: none;
}

.travel-actions-dropdown .dropdown-menu {
  min-width: 200px;
  max-width: 280px;
  border-radius: var(--border-radius);
  box-shadow: var(--shadow-card);
  border: 1px solid var(--color-border);
  padding: var(--space-1);
  right: auto !important;
  left: 0 !important;
  top: 100% !important;
  bottom: auto !important;
  transform: none !important;
  margin-top: 0.125rem;
  margin-bottom: 0;
}

/* Dropup - раскрытие вверх для нижних строк */
.travel-actions-dropdown.dropup .dropdown-menu {
  top: auto !important;
  bottom: 100% !important;
  margin-top: 0 !important;
  margin-bottom: 0.125rem !important;
}

.travel-actions-dropdown .dropdown-menu.show {
  display: block;
}

.travel-actions-dropdown .dropdown-header {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  font-weight: 600;
  padding: var(--space-2) var(--space-3);
  margin-bottom: 0;
}

.travel-actions-dropdown .dropdown-divider {
  margin: var(--space-1) 0;
  border-color: var(--color-border);
}

.travel-actions-dropdown .ui-dropdown-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  border-radius: var(--radius-sm);
  transition: all var(--transition);
  text-decoration: none;
  color: var(--color-text);
  padding: var(--space-1) var(--space-2);
  font-size: var(--font-size-sm);
}

.travel-actions-dropdown .ui-dropdown-item:hover {
  background-color: var(--color-accent-soft);
  color: var(--color-primary);
  text-decoration: none;
}

.travel-actions-dropdown .ui-dropdown-item.text-danger {
  color: var(--color-danger);
}

.travel-actions-dropdown .ui-dropdown-item.text-danger:hover {
  background-color: var(--color-danger-soft-bg);
  color: var(--color-danger);
}

/* DataTables styling for actions column */
#datatable tbody td:first-child {
  text-align: center;
  vertical-align: middle;
  padding: 0.25rem;
}
