/* ═══════════════════════════════════════════════════════════════
   Reports — отчёты, командировки, лейаут
   Извлечено из checklist_operational.css строки 8595–9067
   ═══════════════════════════════════════════════════════════════ */

/* ═══════════════════════════════════════════════════════════════════════════
   ВКЛАДКА ОТЧЁТЫ — командировки
   ═══════════════════════════════════════════════════════════════════════════ */

/* Общий лэйаут */
.reports-layout {
    display: grid;
    grid-template-columns: 220px 1fr;
    height: 100%;
    overflow: hidden;
}

/* Левая колонка — список планов */
.reports-sidebar {
    border-right: 1px solid var(--color-border, #e0e0e0);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    background: var(--color-bg-sidebar, #f9f9f9);
}
.reports-sidebar-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 12px 8px;
    border-bottom: 1px solid var(--color-border, #e0e0e0);
}
.reports-sidebar-title {
    font-weight: 600;
    font-size: var(--text-sm);
    color: var(--color-text-primary, #1a1a1a);
}
.reports-new-btn {
    width: 26px; height: 26px;
    border: none;
    border-radius: var(--radius-sm);
    background: var(--color-primary, #007982);
    color: #fff;
    font-size: var(--text-lg);
    line-height: 1;
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
}
.reports-new-btn:hover { opacity: 0.85; }

.reports-plans-list { flex: 1; overflow-y: auto; padding: 8px 0; }
.reports-plans-empty { padding: 16px 12px; font-size: var(--text-xs); color: var(--color-text-secondary, #888); }

.rplan-item {
    padding: 8px 12px;
    cursor: pointer;
    border-bottom: 1px solid transparent;
    transition: background 0.12s;
}
.rplan-item:hover { background: var(--color-hover, #f0f0f0); }
.rplan-item.active { background: #e6f3f4; border-left: 3px solid var(--color-primary, #007982); padding-left: 11px; }
.rplan-row1 { display: flex; align-items: center; justify-content: space-between; gap: var(--space-2); margin-bottom: 2px; }
.rplan-responsible { font-size: var(--text-sm); font-weight: 500; color: var(--color-text-primary, #1a1a1a); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.rplan-date { font-size: var(--text-xs); color: var(--color-text-secondary, #888); display: block; }

.rplan-status {
    font-size: 10px;
    padding: 1px 8px;
    border-radius: var(--radius-lg);
    white-space: nowrap;
    flex-shrink: 0;
}
.rplan-status--draft    { background: #f0e9c8; color: #7a6000; }
.rplan-status--active   { background: #c8e8ea; color: #005a60; }
.rplan-status--completed { background: #d4edda; color: #155724; }

/* Правая часть */
.reports-main {
    display: flex;
    flex-direction: column;
    overflow: hidden;
    position: relative;
}

.reports-empty-state {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--space-3);
    color: var(--color-text-secondary, #888);
}
.reports-empty-icon { font-size: 40px; }
.reports-empty-text { font-size: var(--text-base); }

.reports-form-wrap {
    display: flex;
    flex-direction: column;
    height: 100%;
    overflow: hidden;
}

/* Строка вкладок */
.reports-tabs-bar {
    display: flex;
    align-items: center;
    gap: 2px;
    padding: 8px 16px 0;
    border-bottom: 1px solid var(--color-border, #e0e0e0);
    background: var(--color-bg, #fff);
    flex-shrink: 0;
}
.reports-tab-btn {
    padding: 8px 16px;
    border: 1px solid transparent;
    border-bottom: none;
    border-radius: 6px 6px 0 0;
    background: none;
    font-size: var(--text-sm);
    cursor: pointer;
    color: var(--color-text-secondary, #666);
    position: relative;
    bottom: -1px;
}
.reports-tab-btn:hover { background: #f5f5f5; }
.reports-tab-btn.active {
    background: #fff;
    color: var(--color-primary, #007982);
    border-color: var(--color-border, #e0e0e0);
    border-bottom-color: #fff;
    font-weight: 600;
}
.reports-tabs-actions {
    margin-left: auto;
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding-bottom: 4px;
}
.reports-status-badge {
    font-size: var(--text-xs);
    padding: 2px 8px;
    border-radius: var(--radius-lg);
}

/* Панель вкладки */
.reports-tab-panel {
    flex: 1;
    overflow-y: auto;
    padding: var(--space-2, 8px) var(--space-4, 16px);
}

/* Кнопки */
.btn-sm {
    padding: 4px 12px;
    border: 1px solid var(--color-border, #ccc);
    border-radius: var(--radius-sm);
    font-size: var(--text-sm);
    cursor: pointer;
    background: #fff;
}
.btn-sm:hover { background: #f5f5f5; }
.btn-sm.btn-primary {
    background: var(--color-primary, #007982);
    border-color: var(--color-primary, #007982);
    color: #fff;
}
.btn-sm.btn-primary:hover { opacity: 0.88; }

/* Форма плана командировки */
.trip-form { display: flex; flex-direction: column; gap: var(--space-2, 8px); max-width: 760px; }
.trip-form-row { display: flex; flex-direction: column; gap: 2px; }
.trip-label { font-size: var(--text-xs); font-weight: 600; color: var(--color-text-secondary, #666); text-transform: uppercase; letter-spacing: 0.03em; }
.trip-input {
    border: 1px solid var(--color-border, #ddd);
    border-radius: var(--radius-sm);
    padding: 4px 8px;
    font-size: var(--text-sm);
    outline: none;
    background: #fff;
}
.trip-input:focus { border-color: var(--color-primary, #007982); }
.trip-textarea {
    border: 1px solid var(--color-border, #ddd);
    border-radius: var(--radius-sm);
    padding: var(--space-2);
    font-size: var(--text-sm);
    outline: none;
    resize: vertical;
    font-family: inherit;
    background: #fff;
}
.trip-textarea:focus { border-color: var(--color-primary, #007982); }
.trip-date-range { display: flex; align-items: center; gap: var(--space-2); }
.trip-date-sep { color: var(--color-text-secondary, #888); }

.trip-dyn-list { display: flex; flex-direction: column; gap: var(--space-2); }
.trip-dyn-row { display: flex; align-items: center; gap: var(--space-2); }
.trip-dyn-row .trip-input { flex: 1; }
.trip-dyn-del {
    width: 24px; height: 24px;
    border: none; background: none;
    color: #999; font-size: var(--text-md);
    cursor: pointer; flex-shrink: 0;
    border-radius: var(--radius-xs);
    line-height: 1;
}
.trip-dyn-del:hover { background: #fde8e8; color: var(--color-danger, #cc3333); }

.trip-add-row-btn {
    align-self: flex-start;
    margin-top: 2px;
    border: 1px dashed var(--color-primary, #007982);
    background: none;
    color: var(--color-primary, #007982);
    font-size: var(--text-xs);
    padding: 3px 8px;
    border-radius: var(--radius-xs);
    cursor: pointer;
}
.trip-add-row-btn:hover { background: #e6f3f4; }

.trip-link-doc-btn {
    align-self: flex-start;
    margin-top: 4px;
    border: none;
    background: none;
    color: var(--color-primary, #007982);
    font-size: var(--text-xs);
    cursor: pointer;
    text-decoration: underline;
    padding: var(--space-0);
}
.trip-link-doc-btn:hover { opacity: 0.75; }

/* Бейдж «письмо привязано» рядом с кнопкой */
.trip-doc-linked-badge {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    font-size: var(--text-xs);
    font-weight: 600;
    color: var(--color-success, #10b981);
    background: var(--color-success-50, #d1fae5);
    border-radius: var(--radius-pill);
    padding: 2px 8px;
    margin-top: 4px;
    white-space: nowrap;
    align-self: flex-start;
}

/* Кнопка «Добавить к командировке» в форме документа */
.btn-doc-attach-trip {
    padding: 8px 16px;
    background: var(--color-success, #10b981);
    color: #fff;
    border: none;
    border-radius: var(--radius-sm);
    font-size: var(--text-sm);
    font-weight: 600;
    cursor: pointer;
    margin-left: 8px;
}
.btn-doc-attach-trip:hover { opacity: 0.9; }
.btn-doc-attach-trip:disabled { opacity: 0.6; cursor: not-allowed; }
.btn-doc-attach-done {
    background: var(--color-text-muted, #6b7280) !important;
    cursor: default !important;
}
.btn-doc-download-pdf {
    padding: 8px 16px;
    background: var(--color-primary, #2563eb);
    color: #fff;
    border: none;
    border-radius: var(--radius-sm);
    font-size: var(--text-sm);
    font-weight: 600;
    cursor: pointer;
    margin-left: 8px;
}
.btn-doc-download-pdf:hover { opacity: 0.9; }

/* Кнопка скачать PDF в карточке командировки (Отчёты) */
.btn-trip-dl-pdf {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    padding: 2px 8px;
    background: var(--color-primary, #2563eb);
    color: #fff;
    border: none;
    border-radius: var(--radius-pill);
    font-size: var(--text-xs);
    font-weight: 600;
    cursor: pointer;
    margin-top: 4px;
    margin-left: 6px;
    white-space: nowrap;
}
.btn-trip-dl-pdf:hover { opacity: 0.85; }

/* Фон редактируемой таблицы ценностей (форма ввода сопроводительного письма) */
.doc-editable-table--items { background: #f0f7ff; border-radius: var(--radius-sm); overflow: hidden; }
.doc-editable-table--items thead tr { background: #dbeafe; }
.doc-editable-table--items tbody tr:nth-child(even) { background: #e8f2ff; }
.doc-editable-table--items .doc-table-input { background: transparent; }

/* Чек-листы в ежедневном отчёте */
.trip-check-list { display: flex; flex-direction: column; gap: var(--space-1); }
.trip-check-item { display: flex; align-items: center; gap: var(--space-2); font-size: var(--text-sm); cursor: pointer; }
.trip-check-item input { cursor: pointer; width: 15px; height: 15px; }
.trip-check-role { color: var(--color-text-secondary, #888); font-size: var(--text-xs); }
.trip-empty-hint { font-size: var(--text-xs); color: var(--color-text-secondary, #aaa); font-style: italic; }

/* Секции утро/вечер */
.daily-section-label {
    font-size: var(--text-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-primary, #007982);
    border-bottom: 2px solid var(--color-primary, #007982);
    padding-bottom: 4px;
    margin-bottom: 4px;
}
.daily-section-label--evening { margin-top: 8px; color: #5a3e8a; border-bottom-color: #5a3e8a; }

/* Ежедневные отчёты — лэйаут */
.daily-layout {
    display: grid;
    grid-template-columns: 160px 1fr;
    height: 100%;
    gap: var(--space-0);
}
.daily-list-col {
    border-right: 1px solid var(--color-border, #e0e0e0);
    display: flex;
    flex-direction: column;
    overflow: hidden;
}
.daily-list-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-2);
    font-size: var(--text-xs);
    font-weight: 600;
    border-bottom: 1px solid var(--color-border, #e0e0e0);
    background: var(--color-bg-sidebar, #f9f9f9);
}
.daily-list { flex: 1; overflow-y: auto; }
.daily-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-2);
    cursor: pointer;
    font-size: var(--text-xs);
    border-bottom: 1px solid var(--color-border, #f0f0f0);
}
.daily-item:hover { background: #f5f5f5; }
.daily-item.active { background: #e6f3f4; font-weight: 600; }
.daily-item--complete .daily-item-status { color: var(--color-primary, #007982); }
.daily-item--draft .daily-item-status { color: #bbb; }

.daily-form-col { overflow-y: auto; padding: 16px 20px; }
.daily-form-actions {
    display: flex;
    gap: var(--space-2);
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid var(--color-border, #eee);
}

/* Итоговый отчёт */
.trip-readonly-list { display: flex; flex-wrap: wrap; gap: var(--space-2); }
.trip-readonly-chip {
    background: #e6f3f4;
    color: #005a60;
    border-radius: var(--radius-xl);
    padding: 3px 8px;
    font-size: var(--text-xs);
}
.trip-counter {
    font-size: var(--text-base);
    font-weight: 600;
    color: var(--color-primary, #007982);
    padding: 8px 0;
}
.trip-eq-name {
    flex: 1;
    font-size: var(--text-sm);
}
.trip-eq-lost-label {
    font-size: var(--text-xs);
    color: var(--color-text-secondary, #666);
    display: flex;
    align-items: center;
    gap: var(--space-1);
    flex-shrink: 0;
}

/* Счётчик символов и валидация */
.trip-char-counter {
    font-size: var(--text-xs);
    color: var(--color-danger, #cc3333);
    margin-top: 2px;
    text-align: right;
}
.trip-char-counter--ok {
    color: var(--color-primary, #007982);
}
.trip-min-hint {
    font-weight: 400;
    font-size: 10px;
    color: var(--color-text-secondary, #999);
    text-transform: none;
    letter-spacing: 0;
    margin-left: 4px;
}
.btn-sm:disabled,
.btn-sm[disabled] {
    opacity: 0.4;
    cursor: not-allowed;
    pointer-events: auto;
}

/* ── SAFE HOVER OVERRIDES ────────────────────────────────────────
   Гарантия контраста на hover для всех типов кнопок системы.
   Закрывают баги типа: «hover меняет фон на тёмный, текст остаётся
   тёмным» или «hover делает фон белым, а текст уже белый». */

/* Primary-style: тёмный фиолетовый фон + БЕЛЫЙ текст всегда. На
   hover bg чуть темнее (primary-hover), текст остаётся #fff. */
.btn-primary,
.btn-primary:hover,
.btn-primary:focus-visible,
button.btn-primary,
button.btn-primary:hover,
.btn-confirm,
.btn-confirm:hover,
.btn-add-phase,
.btn-add-phase:hover,
.btn-add-task,
.btn-add-task:hover,
.passport-btn--primary,
.passport-btn--primary:hover {
    color: #fff;
}
.btn-primary:hover,
.btn-confirm:hover,
.btn-add-phase:hover,
.btn-add-task:hover,
.passport-btn--primary:hover {
    background: var(--color-primary-hover, var(--color-primary-strong, #524F81));
    border-color: var(--color-primary-hover, var(--color-primary-strong, #524F81));
}

/* Secondary / ghost / cancel — белый/светлый фон + ТЁМНЫЙ текст
   всегда. На hover фон чуть темнее, текст остаётся тёмным. */
.btn-secondary,
.btn-secondary:hover,
.btn-cancel,
.btn-cancel:hover,
.btn-ghost,
.btn-ghost:hover,
.passport-btn:not(.passport-btn--primary),
.passport-btn:not(.passport-btn--primary):hover {
    color: var(--color-text, var(--color-text-strong, #3A3A3C));
}

/* Danger — красный фон + БЕЛЫЙ текст всегда. */
.btn-danger,
.btn-danger:hover {
    color: #fff;
}

