/* Дашборд планового ТО — MIXING 2026 */
/* Промышленная тёмная тема */

:root {
    /* Тёмная тема для нативных виджетов на всех экранах: иконка календаря у
       <input type=date/datetime-local> видна на тёмном фоне, выпадающий
       календарь и подсветка сегмента — тёмные; <select> — тёмный список опций.
       Всё приложение (логин + 3 цеха + планшетные режимы) тёмное. */
    color-scheme: dark;
    --bg-primary: #0d1117;
    --bg-secondary: #161b22;
    --bg-tertiary: #21262d;
    --bg-card: #1c2128;
    --text-primary: #f0f6fc;
    --text-secondary: #8b949e;
    --text-muted: #6e7681;
    --border-color: #30363d;
    --accent-blue: #2196F3;
    --accent-green: #4CAF50;
    --accent-yellow: #FFC107;
    --accent-red: #F44336;
    --accent-orange: #FF9800;
    --accent-gray: #9E9E9E;
    --sidebar-width: 240px;
    --header-height: 60px;
    --transition: all 0.3s ease;
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    background: var(--bg-primary);
    color: var(--text-primary);
    min-height: 100vh;
    overflow-x: hidden;
}

.hidden {
    display: none !important;
}

/* ===== ЭКРАН ВХОДА ===== */
.login-screen {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--bg-primary) 0%, #1a237e 100%);
}

.login-container {
    background: var(--bg-card);
    border-radius: 16px;
    padding: 40px;
    width: 100%;
    max-width: 400px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
    border: 1px solid var(--border-color);
}

.login-header {
    text-align: center;
    margin-bottom: 32px;
}

.login-header h1 {
    font-size: 2rem;
    margin-bottom: 8px;
    background: linear-gradient(135deg, var(--accent-blue), var(--accent-green));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.login-header p {
    color: var(--text-secondary);
    font-size: 1.1rem;
}

/* login-by-code (A5): тумблер «По имени / По коду» (только Mixing) */
.login-mode-toggle {
    display: flex;
    gap: 6px;
    margin-bottom: 16px;
    background: var(--bg-tertiary, #21262d);
    border: 1px solid var(--border-color, #30363d);
    border-radius: 10px;
    padding: 4px;
}
.login-mode-btn {
    flex: 1;
    padding: 10px;
    border: none;
    border-radius: 7px;
    background: transparent;
    color: var(--text-secondary, #94a3b8);
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    font-family: inherit;
    transition: background 0.15s, color 0.15s;
}
.login-mode-btn.active {
    background: #4f46e5;
    color: #fff;
}
.login-mode-btn:not(.active):hover {
    color: var(--text-primary, #e6edf3);
}

/* login-by-code (A6): экранный цифровой кейпад (поле readonly → OS-клавиатура не всплывает) */
.login-code-input {
    text-align: center;
    letter-spacing: 8px;
    font-size: 24px;
    caret-color: transparent;
}
.login-keypad {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
    margin-top: 4px;
}
.login-key {
    min-height: 56px;
    border: 1px solid var(--border-color, #30363d);
    border-radius: 10px;
    background: var(--bg-tertiary, #21262d);
    color: var(--text-primary, #e6edf3);
    font-size: 22px;
    font-weight: 600;
    cursor: pointer;
    font-family: inherit;
    transition: background 0.1s, transform 0.05s;
}
.login-key:hover { background: #2d333b; }
.login-key:active { transform: scale(0.96); }
.login-key:focus-visible { outline: 2px solid #4f46e5; outline-offset: 2px; }
.login-key-action {
    color: var(--text-secondary, #94a3b8);
    font-size: 20px;
}

.login-datetime {
    margin-top: 16px;
    padding: 16px 24px;
    background: linear-gradient(135deg, var(--bg-tertiary) 0%, rgba(33, 150, 243, 0.1) 100%);
    border-radius: 12px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    text-align: center;
}

.login-datetime #login-date {
    font-size: 1.2rem;
    font-weight: 600;
    color: var(--text-primary);
    text-transform: capitalize;
}

.login-datetime #login-time {
    font-size: 2rem;
    font-weight: 700;
    color: var(--accent-blue);
    font-family: 'Courier New', monospace;
}

.login-form {
    display: flex;
    flex-direction: column;
    gap: 20px;
}
/* login-by-code (A5): обёртка имя+пароль — восстановить вертикальный отступ (был flex-gap у .login-form) */
#login-name-group {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

/* === Кредит разработчика — экран входа + сайдбары 3 цехов (восстановлено 16.05.2026) === */
.app-dev-credit {
    font-size: 0.75rem;
    color: var(--text-secondary);
    text-align: center;
    letter-spacing: 0.2px;
    line-height: 1.4;
}

.login-container .app-dev-credit {
    margin-top: 22px;
    padding-top: 16px;
    border-top: 1px solid var(--border-color);
}

.sidebar-footer .app-dev-credit,
.pk-sidebar-footer .app-dev-credit,
.ewo-sidebar-footer .app-dev-credit {
    margin-top: 4px;
    padding-top: 10px;
    border-top: 1px solid var(--border-color);
}

.form-group {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.form-group label {
    color: var(--text-secondary);
    font-size: 0.9rem;
    font-weight: 500;
}

.input-field {
    padding: 14px 16px;
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    color: var(--text-primary);
    font-size: 1rem;
    transition: var(--transition);
}

.input-field:focus {
    outline: none;
    border-color: var(--accent-blue);
    box-shadow: 0 0 0 3px rgba(33, 150, 243, 0.2);
}

.input-field::placeholder {
    color: var(--text-muted);
}

.error-message {
    color: var(--accent-red);
    font-size: 0.85rem;
    text-align: center;
    min-height: 20px;
    /* AUDIT_18 F3: explicit margin для визуального отступа после смены <p>→<div>
       (раньше использовался браузерный default <p> margin ~1em). */
    margin-top: 12px;
}

/* AUDIT_17 C1: banner для login rate-limit с countdown. Используется тот же
   #login-error контейнер, при добавлении класса .login-rate-limit-banner —
   amber карточка с иконкой, заголовком и обратным отсчётом. Снимается из JS
   когда timer достигает 0 (форма разблокируется). */
.error-message.login-rate-limit-banner {
    color: #fde68a;
    background: linear-gradient(135deg, rgba(245, 158, 11, 0.18) 0%, rgba(245, 158, 11, 0.06) 100%);
    border: 1.5px solid rgba(245, 158, 11, 0.55);
    border-radius: 10px;
    padding: 14px 16px;
    margin-top: 12px;
    font-size: 14px;
    display: flex;
    align-items: center;
    gap: 12px;
    text-align: left;
    min-height: auto;
    box-shadow: 0 4px 14px rgba(245, 158, 11, 0.18);
}
.login-rl-icon {
    font-size: 26px;
    line-height: 1;
    flex: 0 0 auto;
}
.login-rl-text {
    display: flex;
    flex-direction: column;
    gap: 4px;
    flex: 1 1 auto;
    min-width: 0;
}
.login-rl-title {
    font-weight: 700;
    color: #fbbf24;
    font-size: 14px;
}
.login-rl-hint {
    font-size: 13px;
    color: #fde68a;
    font-variant-numeric: tabular-nums;
}
.login-rl-hint b { color: #fff; font-size: 14px; }

/* ===== КНОПКИ ===== */
.btn {
    padding: 12px 24px;
    border: none;
    border-radius: 8px;
    font-size: 1rem;
    font-weight: 600;
    cursor: pointer;
    transition: var(--transition);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}

.btn-primary {
    background: linear-gradient(135deg, var(--accent-blue), #1976D2);
    color: white;
}

.btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(33, 150, 243, 0.4);
}

.btn-secondary {
    background: var(--bg-tertiary);
    color: var(--text-primary);
    border: 1px solid var(--border-color);
}

.btn-secondary:hover {
    background: var(--bg-card);
}

.btn-danger {
    background: var(--accent-red);
    color: white;
}

.btn-danger:hover {
    background: #d32f2f;
}

.btn-success {
    background: var(--accent-green);
    color: white;
}

.btn-large {
    padding: 16px 32px;
    font-size: 1.1rem;
    width: 100%;
}

.btn-small {
    padding: 8px 16px;
    font-size: 0.85rem;
}

/* ===== LAYOUTS ===== */
.app {
    display: flex;
    min-height: 100vh;
}

/* ===== SIDEBAR ===== */
.sidebar {
    width: var(--sidebar-width);
    background: var(--bg-secondary);
    border-right: 1px solid var(--border-color);
    display: flex;
    flex-direction: column;
    position: fixed;
    height: 100vh;
    z-index: 100;
}

.sidebar-header {
    padding: 20px;
    display: flex;
    align-items: center;
    gap: 12px;
    border-bottom: 1px solid var(--border-color);
}

.sidebar-header h2 {
    font-size: 1.4rem;
    background: linear-gradient(135deg, var(--accent-blue), var(--accent-green));
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

.year-badge {
    background: var(--accent-blue);
    color: white;
    padding: 4px 10px;
    border-radius: 12px;
    font-size: 0.8rem;
    font-weight: 600;
}

.nav-menu {
    list-style: none;
    flex: 1;
    padding: 12px 0;
}

.nav-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 20px;
    cursor: pointer;
    transition: var(--transition);
    color: var(--text-secondary);
    border-left: 3px solid transparent;
}

.nav-item:hover {
    background: var(--bg-tertiary);
    color: var(--text-primary);
}

.nav-item.active {
    background: rgba(33, 150, 243, 0.15);
    color: var(--accent-blue);
    border-left-color: var(--accent-blue);
}

.nav-icon {
    font-size: 1.2rem;
    width: 24px;
    text-align: center;
}

.nav-text {
    font-size: 0.95rem;
    font-weight: 500;
}

.sidebar-footer {
    padding: 16px 20px;
    border-top: 1px solid var(--border-color);
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.user-info {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

/* SSE статус подключения */
.sse-status {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 6px 10px;
    border-radius: 6px;
    font-size: 11px;
    cursor: default;
    transition: background 0.3s;
}

.sse-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    flex-shrink: 0;
    transition: background 0.3s;
}

.sse-status.sse-connected {
    background: rgba(34, 197, 94, 0.1);
    color: #4ade80;
}
.sse-status.sse-connected .sse-dot {
    background: #22c55e;
    box-shadow: 0 0 6px rgba(34, 197, 94, 0.5);
}

.sse-status.sse-connecting {
    background: rgba(250, 204, 21, 0.1);
    color: #fbbf24;
}
.sse-status.sse-connecting .sse-dot {
    background: #eab308;
    animation: sse-pulse 1.2s ease-in-out infinite;
}

.sse-status.sse-disconnected {
    background: rgba(239, 68, 68, 0.15);
    color: #f87171;
}
.sse-status.sse-disconnected .sse-dot {
    background: #ef4444;
    box-shadow: 0 0 6px rgba(239, 68, 68, 0.5);
}

.sse-reconnect-btn {
    background: none;
    border: 1px solid currentColor;
    color: inherit;
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 11px;
    cursor: pointer;
    margin-left: auto;
    transition: background 0.2s;
}
.sse-reconnect-btn:hover {
    background: rgba(255,255,255,0.1);
}

@keyframes sse-pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.3; }
}

/* SSE баннер при потере соединения */
.sse-disconnect-banner {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    background: linear-gradient(135deg, #dc2626, #b91c1c);
    color: #fff;
    padding: 10px 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    font-size: 14px;
    font-weight: 500;
    z-index: 100000;
    box-shadow: 0 2px 12px rgba(0,0,0,0.3);
    animation: sse-banner-in 0.3s ease-out;
}
.sse-disconnect-banner button {
    background: rgba(255,255,255,0.2);
    border: 1px solid rgba(255,255,255,0.4);
    color: #fff;
    padding: 4px 16px;
    border-radius: 6px;
    font-size: 13px;
    cursor: pointer;
    font-weight: 600;
    transition: background 0.2s;
}
.sse-disconnect-banner button:hover {
    background: rgba(255,255,255,0.35);
}

@keyframes sse-banner-in {
    from { transform: translateY(-100%); }
    to { transform: translateY(0); }
}

#current-user-name {
    font-weight: 600;
    font-size: 0.95rem;
}

.role-badge {
    font-size: 0.75rem;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* ===== MAIN CONTENT ===== */
.main-content {
    flex: 1;
    margin-left: var(--sidebar-width);
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

.content-header {
    height: var(--header-height);
    background: var(--bg-secondary);
    border-bottom: 1px solid var(--border-color);
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 24px;
    position: sticky;
    top: 0;
    z-index: 50;
}

.content-header h1 {
    font-size: 1.4rem;
    font-weight: 600;
}

.header-time {
    display: flex;
    gap: 16px;
    color: var(--text-secondary);
    font-size: 0.9rem;
}

.tab-content {
    display: none;
    padding: 24px;
    flex: 1;
}

.tab-content.active {
    display: block;
}

/* ===== STATS CARDS ===== */
.stats-cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 16px;
    margin-bottom: 24px;
}

/* AUDIT_14 E71: дубль .stats-badges/.stat-badge удалён — cascade всегда побеждал
   поздним блоком (~2249+ строки), ранний (grid-вариант) был мёртвым кодом. */

.stat-card {
    background: var(--bg-card);
    border-radius: 12px;
    padding: 20px;
    display: flex;
    align-items: center;
    gap: 16px;
    border: 1px solid var(--border-color);
    transition: var(--transition);
}

.stat-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3);
}

.stat-icon {
    font-size: 2rem;
    width: 50px;
    height: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 12px;
}

.stat-total .stat-icon {
    background: rgba(158, 158, 158, 0.2);
}

.stat-done .stat-icon {
    background: rgba(76, 175, 80, 0.2);
}

.stat-inprogress .stat-icon {
    background: rgba(33, 150, 243, 0.2);
}

.stat-pending .stat-icon {
    background: rgba(255, 193, 7, 0.2);
}

.stat-overdue .stat-icon {
    background: rgba(244, 67, 54, 0.2);
}

.stat-info {
    display: flex;
    flex-direction: column;
}

.stat-value {
    font-size: 1.8rem;
    font-weight: 700;
    line-height: 1;
}

.stat-done .stat-value {
    color: var(--accent-green);
}

.stat-inprogress .stat-value {
    color: var(--accent-blue);
}

.stat-pending .stat-value {
    color: var(--accent-yellow);
}

.stat-pending .stat-icon {
    background: rgba(255, 193, 7, 0.15);
    color: var(--accent-yellow);
}

/* Ф2e (12.06.2026): плашка «📅 Запланировано» — индиго Планировщика ТО */
.stat-scheduled .stat-value {
    color: #818cf8;
}

.stat-scheduled .stat-icon {
    background: rgba(99, 102, 241, 0.15);
    color: #818cf8;
}

.stat-overdue .stat-value {
    color: var(--accent-red);
}

.stat-notdone .stat-value {
    color: #9C27B0;
}

.stat-notdone .stat-icon {
    background: rgba(156, 39, 176, 0.1);
    color: #9C27B0;
}

.stat-partial .stat-value {
    color: #FF9800;
}

.stat-partial .stat-icon {
    background: rgba(255, 152, 0, 0.15);
    color: #FF9800;
}

.stat-card.active {
    border-color: var(--accent-blue);
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.2);
}

.stat-percent {
    font-size: 0.85rem;
    color: var(--accent-green);
    margin-left: 8px;
}

.stat-label {
    font-size: 0.85rem;
    color: var(--text-secondary);
    margin-top: 4px;
}

/* Пульсация для просроченных */
.stat-overdue.pulse {
    animation: pulse 1.5s infinite;
}

@keyframes pulse {

    0%,
    100% {
        box-shadow: 0 0 0 0 rgba(244, 67, 54, 0.4);
    }

    50% {
        box-shadow: 0 0 0 12px rgba(244, 67, 54, 0);
    }
}

/* Вкладка Настройки */
.settings-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    gap: 12px;
}

/* ===== 24.05.2026: Settings 3-group layout (Export / Import / Danger) =====
   Симметричный grid для секций «Управление {Х}». 1.6fr под Export (2 кнопки), 1fr под
   Import (1 кнопка), 1fr под Danger. Внутри group кнопки equal-width через flex:1. */
.settings-action-grid {
    display: grid;
    grid-template-columns: 1.6fr 1fr 1fr;
    gap: 16px;
    align-items: end;
}
.settings-action-group {
    display: flex;
    flex-direction: column;
    gap: 6px;
    min-width: 0;
}
.settings-action-group-label {
    font-size: 10.5px;
    color: var(--text-muted, #94a3b8);
    text-transform: uppercase;
    letter-spacing: 0.6px;
    font-weight: 600;
}
.settings-action-group-buttons {
    display: flex;
    gap: 6px;
    align-items: stretch;
}
.settings-action-group-buttons .btn {
    flex: 1;
    min-width: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    padding: 8px 12px;
    font-size: 13px;
}
.settings-action-group-danger .settings-action-group-label {
    color: #f87171;
}
@media (max-width: 900px) {
    .settings-action-grid {
        grid-template-columns: 1fr;
        gap: 12px;
    }
}

.btn-excel {
    background: #217346 !important;
    color: white !important;
    border-color: #217346 !important;
}

.btn-excel:hover {
    background: #1e6b41 !important;
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(33, 115, 70, 0.4);
}

/* ===== PROGRESS BAR ===== */
.progress-container {
    background: var(--bg-card);
    border-radius: 12px;
    padding: 20px;
    margin-bottom: 24px;
    border: 1px solid var(--border-color);
}

.progress-header {
    display: flex;
    justify-content: space-between;
    margin-bottom: 12px;
    font-weight: 600;
}

#progress-percent {
    color: var(--accent-green);
}

.progress-bar-segmented {
    height: 24px;
    background: var(--bg-tertiary);
    border-radius: 12px;
    overflow: hidden;
    display: flex;
}

.progress-segment {
    height: 100%;
    transition: width 0.5s ease;
}

.progress-segment.done {
    background: var(--accent-green);
}

.progress-segment.inprogress {
    background: var(--accent-blue);
}

.progress-segment.overdue {
    background: var(--accent-red);
}

.progress-segment.scheduled {
    background: var(--accent-gray);
    opacity: 0.5;
}

.progres.task-actions {
    display: flex;
    gap: 8px;
    margin-top: 12px;
    flex-wrap: wrap;
}

.task-actions-secondary {
    display: flex;
    justify-content: flex-end;
    margin-top: 8px;
    padding-top: 8px;
    border-top: 1px solid var(--border-color);
}

.progress-legend {
    display: flex;
    gap: 20px;
    margin-top: 12px;
    flex-wrap: wrap;
}

.legend-item {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 0.85rem;
    color: var(--text-secondary);
}

.legend-dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
}

.legend-dot.done {
    background: var(--accent-green);
}

.legend-dot.inprogress {
    background: var(--accent-blue);
}

.legend-dot.overdue {
    background: var(--accent-red);
}

.legend-dot.scheduled {
    background: var(--accent-gray);
    opacity: 0.5;
}

/* ===== FILTERS ===== */
.filters-panel {
    background: var(--bg-card);
    border-radius: 12px;
    padding: 16px 20px;
    margin-bottom: 24px;
    border: 1px solid var(--border-color);
}

.filter-row {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    align-items: center;
}

.filter-row+.filter-row {
    margin-top: 12px;
}

.period-selector {
    display: flex;
    background: var(--bg-tertiary);
    border-radius: 8px;
    overflow: hidden;
}

.period-btn {
    padding: 10px 20px;
    background: transparent;
    border: none;
    color: var(--text-secondary);
    font-size: 0.9rem;
    cursor: pointer;
    transition: var(--transition);
}

.period-btn:hover {
    color: var(--text-primary);
}

.period-btn.active {
    background: var(--accent-blue);
    color: white;
}

.filters-panel .input-field {
    flex: 1;
    min-width: 140px;
    padding: 10px 14px;
}

#filter-equipment {
    min-width: 200px;
}

/* ===== TASKS CONTAINER ===== */
.tasks-container {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(380px, 1fr));
    gap: 16px;
}

/* ===== EXECUTOR KANBAN (меню — панель исполнителя) ===== */
/* 24.05.2026 Batch B Phase 3d: переход с hardcoded data-shift="X" mapping на
   CSS variable --shift-color (inline-style из mixingConfig.shifts). Grid
   динамически адаптируется через --kanban-cols (set из JS, fallback 5). */
.executor-kanban {
    display: grid;
    grid-template-columns: repeat(var(--kanban-cols, 5), minmax(240px, 1fr));
    gap: 16px;
    overflow-x: auto;
    padding-bottom: 8px;
}

.kanban-column {
    display: flex;
    flex-direction: column;
    min-width: 240px;
    background: var(--bg-card);
    border: 2px solid rgba(255, 255, 255, 0.08);
    border-top: 4px solid var(--shift-color, rgba(255, 255, 255, 0.15));
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.28);
    transition: border-color 0.2s, box-shadow 0.2s;
}

.kanban-column-header {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 4px;
    padding: 14px 12px 12px;
    font-weight: 600;
    border-bottom: 2px solid rgba(255, 255, 255, 0.08);
    background: rgba(255, 255, 255, 0.03);
}

.kanban-shift-icon {
    font-size: 26px;
    line-height: 1;
}

.kanban-shift-label {
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.6px;
    color: var(--text-primary, #e2e8f0);
}

.kanban-count {
    position: absolute;
    top: 10px;
    right: 12px;
    background: var(--shift-color, var(--accent-blue, #3b82f6));
    color: #fff;
    padding: 2px 10px;
    border-radius: 12px;
    font-size: 12px;
    font-weight: 700;
    min-width: 28px;
    text-align: center;
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.3);
}

.kanban-column-mine {
    border-color: var(--shift-color, var(--accent-blue, #3b82f6));
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--shift-color, #3b82f6) 30%, transparent),
                0 2px 10px rgba(0, 0, 0, 0.28);
}

.kanban-column-mine .kanban-column-header {
    background: color-mix(in srgb, var(--shift-color, #3b82f6) 12%, transparent);
}

/* 24.05.2026 Batch O1: .kanban-column-orphan удалён — orphan tasks теперь управляются
   через Settings → Смены orphan-block (см. Batch O2). */

.kanban-column-body {
    flex: 1;
    padding: 10px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    min-height: 200px;
    overflow-y: auto;
}

.kanban-column-body .task-card {
    min-width: 0;
}

.kanban-empty {
    text-align: center;
    padding: 30px 10px;
    color: var(--text-muted, #94a3b8);
    font-size: 13px;
    font-style: italic;
}

/* Общий баннер при большом числе пустых колонок (#7) */
.kanban-empty-banner {
    padding: 14px 18px;
    margin-bottom: 10px;
    background: rgba(59, 130, 246, 0.08);
    border: 1px solid rgba(59, 130, 246, 0.25);
    border-radius: 8px;
    color: #cbd5e1;
    font-size: 14px;
    text-align: center;
    opacity: 1;
    transition: opacity 0.2s ease;
}
.kanban-empty-banner[hidden],
.kanban-empty-banner.hidden {
    opacity: 0;
}

/* ===== Баннер «Предстоящие ТО» ===== */
.upcoming-reminder {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 12px;
    padding: 14px 18px;
    margin-top: 12px;
    background: linear-gradient(135deg, rgba(245, 158, 11, 0.18), rgba(245, 158, 11, 0.06));
    border: 1px solid rgba(245, 158, 11, 0.4);
    border-left: 4px solid #f59e0b;
    border-radius: 12px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.18);
}
.upcoming-reminder-icon {
    font-size: 22px;
    line-height: 1;
}
.upcoming-reminder-title {
    font-weight: 700;
    font-size: 14px;
    color: #fcd34d;
    letter-spacing: 0.2px;
}
.upcoming-reminder-list {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.upcoming-reminder-pill {
    background: rgba(245, 158, 11, 0.14);
    border: 1px solid rgba(245, 158, 11, 0.32);
    border-radius: 999px;
    padding: 4px 12px;
    font-size: 13px;
    color: #fde68a;
    white-space: nowrap;
}
.upcoming-reminder-pill b {
    color: #fff;
    font-weight: 700;
    margin-right: 6px;
}

/* ===== Обратный отсчёт жизни задания ===== */
.task-countdown {
    padding: 6px 10px;
    font-size: 12px;
    font-weight: 600;
    color: var(--text-muted, #94a3b8);
    text-align: center;
    background: rgba(255, 255, 255, 0.03);
    border-top: 1px solid rgba(255, 255, 255, 0.05);
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
    letter-spacing: 0.3px;
}

.task-countdown.task-countdown-warn {
    color: #f59e0b;
    background: rgba(245, 158, 11, 0.1);
    border-color: rgba(245, 158, 11, 0.25);
}

.task-countdown.task-countdown-critical {
    color: #ef4444;
    background: rgba(239, 68, 68, 0.18);
    border-color: rgba(239, 68, 68, 0.35);
}

@media (max-width: 900px) {
    .executor-kanban {
        grid-template-columns: repeat(5, 260px);
    }
}

/* AUDIT_7 #7: планшет в landscape (iPad Pro 1024×768) — 3 колонки в 2 ряда, без горизонтального скролла */
@media (min-width: 769px) and (max-width: 1100px) {
    .executor-kanban {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        overflow-x: visible;
    }
    .kanban-column {
        min-width: 0;
    }
}

/* #3: планшеты — 2 колонки без горизонтального скролла */
@media (max-width: 768px) {
    .executor-kanban {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        overflow-x: visible;
    }
    .kanban-column {
        min-width: 0;
    }
}

/* #3: мобильные — одна колонка, вертикальный стек */
@media (max-width: 480px) {
    .executor-kanban {
        grid-template-columns: 1fr;
    }
    .kanban-column-header {
        padding: 10px 10px 8px;
    }
    .kanban-shift-icon { font-size: 22px; }
    .kanban-column-body {
        max-height: 60vh;
    }
}

.task-card {
    display: flex;
    flex-direction: column;
    background: var(--bg-card);
    border-radius: 14px;
    padding: 0;
    border: 1px solid var(--border-color);
    transition: var(--transition);
    cursor: pointer;
    position: relative;
    overflow: hidden;
    min-height: auto;
}

.task-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3);
}

.task-card.status-done {
    border-color: var(--accent-green);
}

.task-card.status-inprogress {
    border-color: var(--accent-blue);
}

.task-card.status-pending {
    border-color: var(--accent-yellow);
}

.task-card.status-overdue {
    border-color: var(--accent-red);
}

.task-card.status-scheduled {
    border-color: var(--accent-gray);
}

.task-card.status-partial {
    border-color: #FF9800;
}

.task-card.loading {
    opacity: 0.6;
    pointer-events: none;
    position: relative;
}

.task-card.loading::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    width: 24px;
    height: 24px;
    margin: -12px 0 0 -12px;
    border: 3px solid rgba(255,255,255,0.3);
    border-top-color: #fff;
    border-radius: 50%;
    animation: taskCardSpin 1s linear infinite;
    z-index: 10;
}

@keyframes taskCardSpin {
    to { transform: rotate(360deg); }
}

.task-card-header {
    padding: 16px 20px 12px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.04);
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 10px;
    min-height: 90px;
    /* Constrain header height for alignment */
}

.task-header-info {
    display: flex;
    flex-direction: column;
    gap: 2px;
    flex: 1;
}

.task-status-badge {
    padding: 6px 12px;
    border-radius: 16px;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
}

.task-status-badge.done {
    background: rgba(76, 175, 80, 0.2);
    color: var(--accent-green);
}

.task-status-badge.inprogress {
    background: rgba(33, 150, 243, 0.2);
    color: var(--accent-blue);
}

.task-status-badge.pending {
    background: rgba(255, 193, 7, 0.2);
    color: var(--accent-yellow);
}

.task-status-badge.overdue {
    background: rgba(244, 67, 54, 0.2);
    color: var(--accent-red);
}

.task-status-badge.scheduled {
    background: rgba(158, 158, 158, 0.2);
    color: var(--accent-gray);
}

.task-status-badge.partial {
    background: rgba(255, 152, 0, 0.2);
    color: #FF9800;
}

.task-status-badge.notdone {
    background: rgba(156, 39, 176, 0.2);
    color: #9C27B0;
}

.task-date {
    color: var(--text-secondary);
    font-size: 0.85rem;
}

.task-equipment {
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--text-primary);
    margin: 0;
    min-height: 2.8rem;
    /* Reserved space for 2 lines of text for alignment */
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    line-height: 1.35;
}

.task-status-block {
    padding: 14px 20px;
    background: rgba(0, 0, 0, 0.15);
    display: flex;
    flex-direction: column;
    gap: 8px;
    min-height: 54px;
    /* Consistently align status block */
    justify-content: center;
}

.task-status-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.task-status-label {
    font-size: 0.82rem;
    color: var(--text-secondary);
}

.task-info {
    padding: 12px 20px 16px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.task-info-row {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 4px 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.03);
    font-size: 0.82rem;
    gap: 12px;
}

.task-info-row:last-child {
    border-bottom: none;
}

.task-info-label {
    color: var(--text-muted);
    flex-shrink: 0;
}

.task-info-value {
    color: var(--text-primary);
    text-align: right;
}

.task-meta {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    color: var(--text-secondary);
    font-size: 0.85rem;
    margin-bottom: 12px;
}

.task-meta span {
    display: flex;
    align-items: center;
    gap: 4px;
}

.task-executor {
    padding-top: 12px;
    border-top: 1px solid var(--border-color);
    font-size: 0.9rem;
    color: var(--text-secondary);
}

.task-executor strong {
    color: var(--text-primary);
}

/* Карточка задания — 2-row actions:
   .task-actions-primary  — главные действия (Принять / Сдать работы / Не выполнено), grid 2 col либо 1 col для одиночных
   .task-actions-secondary — «Подробнее» отдельной строкой во всю ширину
   ✏️ редактирования вынесена из .task-actions в верхний-левый угол карточки (см. .btn-edit-task ниже) */
.task-card .task-actions {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 12px 20px 16px;
    border-top: 1px solid rgba(255, 255, 255, 0.04);
    margin-top: auto;
}

.task-card .task-actions-primary {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
}

/* Одиночная кнопка (ПРИНЯТЬ) или scheduled-note — на всю ширину */
.task-card .task-actions-primary:has(> .btn-accept),
.task-card .task-actions-primary:has(> .task-scheduled-note) {
    grid-template-columns: 1fr;
}

/* Пустой primary-row — скрываем чтобы не было лишнего gap'а перед secondary */
.task-card .task-actions-primary:empty {
    display: none;
}

.task-card .task-actions-primary > .btn {
    width: 100%;
    min-height: 44px;     /* WCAG 2.5.5 touch-target */
    padding: 10px 12px;
    margin: 0;
    font-size: 0.85rem;
    font-weight: 600;
    line-height: 1.2;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    flex: none;
}

.task-card .task-actions-secondary {
    display: flex;
    margin-top: 0;
    padding-top: 0;
    border-top: none;       /* отменяем общий .task-actions-secondary (выше в файле) */
    justify-content: stretch;
}

.task-card .task-actions-secondary > .btn-details {
    width: 100%;
    min-height: 40px;
    padding: 8px 12px;
    font-size: 0.85rem;
    margin: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

/* Кнопка редактирования ✏️ — абсолютно позиционирована в верхнем-левом углу карточки.
   .task-card.can-edit-task .task-card-header получает padding-left под её ширину. */
.task-card.can-edit-task .task-card-header {
    padding-left: 50px;
}

.task-card .btn-edit-task {
    position: absolute;
    top: 10px;
    left: 10px;
    width: 32px;
    height: 32px;
    padding: 0;
    margin: 0;
    border-radius: 8px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.95rem;
    line-height: 1;
    z-index: 2;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.10);
    color: var(--text-secondary, #8b949e);
    opacity: 0.7;
    transition: opacity 0.15s, background 0.15s, border-color 0.15s, transform 0.15s;
    cursor: pointer;
    flex: none;
}

.task-card .btn-edit-task:hover {
    opacity: 1;
    background: rgba(255, 255, 255, 0.12);
    border-color: rgba(255, 255, 255, 0.22);
    transform: none;    /* отменяем translateY у .btn:hover, если такой задан */
}

.task-card .btn-edit-task:focus-visible {
    outline: 2px solid var(--accent-yellow, #f59e0b);
    outline-offset: 2px;
    opacity: 1;
}

/* Плашка «Запланировано» — стиль внутри primary-row (alignment с кнопками) */
.task-scheduled-note {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 44px;
    padding: 8px 12px;
    color: var(--text-secondary, #8b949e);
    font-size: 0.85rem;
    background: rgba(255, 255, 255, 0.03);
    border: 1px dashed var(--border-color, #30363d);
    border-radius: 8px;
}

/* ===== КОММЕНТАРИИ В КАРТОЧКАХ ===== */
.task-comment {
    word-wrap: break-word;
    overflow-wrap: break-word;
    word-break: break-word;
    white-space: pre-wrap;
    max-width: 100%;
    padding: 10px 16px;
    background: rgba(255, 193, 7, 0.08);
    /* slightly less intense */
    border-top: 1px solid rgba(255, 255, 255, 0.04);
    font-size: 0.82rem;
    color: var(--text-secondary);
}

/* ===== ЦВЕТОВОЕ РАЗЛИЧИЕ ТО ПО СМЕНЕ ===== */
/* 24.05.2026 Batch B Phase 3d/3e: hardcoded .shift-engineer/.shift-executor mapping
   удалены. task-card получает inline --shift-color из mixingConfig.shifts. */
.task-card {
    border-left: 4px solid var(--shift-color, var(--accent-blue, #3b82f6));
}
.task-card.shift-orphan {
    border-left-color: #64748b;
    opacity: 0.92;
}

/* ===== EXECUTOR PANEL ===== */
.executor-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
    gap: 14px;
    flex-wrap: wrap;
}

/* M-12 (23.05.2026): wrapper для title + inline-pill notification (рядом с именем пользователя).
   flex-wrap позволяет переноситься на узких экранах. */
.executor-header-left {
    display: flex;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
    min-width: 0;
}

/* AUDIT_10 #14: .executor-toggle/.toggle-btn удалены — фича удалена в сессии 20 */

.notification {
    background: linear-gradient(135deg, var(--accent-yellow), var(--accent-orange));
    color: #1a1a1a;
    padding: 16px 20px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 20px;
    font-weight: 600;
}

.notification.hidden {
    display: none !important;
}

/* Контейнер для уведомления с фиксированным пространством */
#executor-notification {
    min-height: 0;
    transition: min-height 0.2s ease;
}

.notification-icon {
    font-size: 1.5rem;
}

/* M-12 (23.05.2026): inline-pill вариант notification для .executor-header-left.
   Компактный chip рядом с h2 title; при hidden — display:none (не резервирует место). */
.notification.notification-inline,
#tab-executor .notification.notification-inline {
    padding: 6px 14px;
    border-radius: 999px;
    font-size: 13px;
    line-height: 1.4;
    margin: 0;
    min-height: 0;
    transition: none;
    flex-shrink: 0;
    gap: 8px;
}

.notification.notification-inline .notification-icon {
    font-size: 1.1rem;
}

/* Перекрывает старый `#tab-executor .notification.hidden { display: block !important }`
   (используется для block-variant ниже kanban'а — сохраняет место). Inline-pill — наоборот:
   при hidden исчезает полностью, чтобы header не оставлял пустой chip-slot рядом с title. */
#tab-executor .notification.notification-inline.hidden {
    display: none !important;
    visibility: visible;
    height: auto;
    padding: 0;
    overflow: visible;
}

/* ===== СТАБИЛЬНЫЕ ФИЛЬТРЫ ПАНЕЛИ ИСПОЛНИТЕЛЯ ===== */

/* Пространство перед фильтрами всегда фиксировано */
#tab-executor .notification {
    margin-bottom: 20px;
}

#tab-executor .notification.hidden {
    display: block !important;
    visibility: hidden;
    height: 0;
    min-height: 0;
    padding: 0;
    margin: 0;
    overflow: hidden;
}

.executor-filters-stable {
    min-height: 100px;
    margin-bottom: 20px;
}

.executor-filters-stable .filter-row {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    align-items: center;
}

.executor-filters-stable .filter-row+.filter-row {
    margin-top: 12px;
}

.executor-period-selector {
    display: flex;
    background: var(--bg-tertiary);
    border-radius: 8px;
    overflow: hidden;
}

.executor-period-selector .period-btn {
    padding: 10px 16px;
    font-size: 0.85rem;
}

.executor-filters-stable #executor-filter-equipment {
    flex: 1;
    min-width: 200px;
}

/* ===== ВИЗУАЛЬНОЕ РАЗЛИЧИЕ КАРТОЧЕК ДЕНЬ/НОЧЬ ===== */
.task-card.shift-day {
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.08) 0%, rgba(255, 193, 7, 0.15) 100%);
    border-color: rgba(255, 193, 7, 0.3);
}

.task-card.shift-night {
    background: linear-gradient(135deg, var(--bg-card) 0%, rgba(103, 58, 183, 0.12) 100%);
    border-color: rgba(103, 58, 183, 0.3);
}

/* Большая плашка день/ночь */
.daynight-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    border-radius: 8px;
    font-weight: 600;
    font-size: 1rem;
}

.daynight-badge.day {
    background: linear-gradient(135deg, rgba(255, 193, 7, 0.2) 0%, rgba(255, 152, 0, 0.15) 100%);
    color: #ffc107;
}

.daynight-badge.night {
    background: linear-gradient(135deg, rgba(103, 58, 183, 0.2) 0%, rgba(81, 45, 168, 0.15) 100%);
    color: #b39ddb;
}

.daynight-badge .daynight-icon {
    font-size: 1.4rem;
}

/* 24.05.2026 Batch B Phase 3d: .shift-engineer/.shift-executor refactor —
   border-left из --shift-color (inline-style на task-card). */

/* AUDIT: MANAGER PANEL CSS удалён — фича статистики по исполнителям удалена */

.chart-bar {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 12px;
}

.chart-label {
    width: 80px;
    font-size: 0.85rem;
    color: var(--text-secondary);
}

.chart-bar-container {
    flex: 1;
    height: 24px;
    background: var(--bg-tertiary);
    border-radius: 4px;
    overflow: hidden;
}

.chart-bar-fill {
    height: 100%;
    background: var(--accent-green);
    transition: width 0.5s ease;
}

.chart-value {
    width: 50px;
    text-align: right;
    font-size: 0.85rem;
    font-weight: 600;
}

/* ===== УЛУЧШЕННАЯ МЕСЯЧНАЯ СТАТИСТИКА ===== */
.monthly-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 16px;
}

.monthly-header h3 {
    margin: 0;
    font-size: 1.2rem;
    color: var(--text-primary);
}

.btn-year-stats {
    padding: 8px 16px;
    font-size: 0.85rem;
}

.btn-year-stats.active {
    background: var(--accent-blue);
    color: white;
}

.monthly-summary,
.monthly-summary-wide {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    margin-bottom: 24px;
    padding: 16px;
    background: var(--bg-tertiary);
    border-radius: 12px;
}

.monthly-summary-wide {
    justify-content: space-between;
}

.monthly-summary-wide .summary-stat {
    flex: 1;
    min-width: 80px;
}

.summary-stat {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 12px 20px;
    background: var(--bg-card);
    border-radius: 8px;
    min-width: 100px;
}

.summary-stat.total {
    border-left: 3px solid var(--accent-blue);
}

.summary-stat.done {
    border-left: 3px solid var(--accent-green);
}

.summary-stat.overdue {
    border-left: 3px solid var(--accent-red);
}

.summary-stat.notdone {
    border-left: 3px solid var(--accent-orange);
}

.summary-stat.partial {
    border-left: 3px solid #FF9800;
}

.summary-stat.percent {
    border-left: 3px solid var(--accent-purple);
}

.summary-value {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--text-primary);
}

.summary-value.good {
    color: var(--accent-green);
}

.summary-value.medium {
    color: var(--accent-yellow);
}

.summary-value.bad {
    color: var(--accent-red);
}

.summary-label {
    font-size: 0.75rem;
    color: var(--text-secondary);
    margin-top: 4px;
}

.monthly-bars {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.chart-bar-enhanced {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 8px 12px;
    background: var(--bg-tertiary);
    border-radius: 8px;
    transition: var(--transition);
}

.chart-bar-enhanced.clickable-month {
    cursor: pointer;
}

.chart-bar-enhanced.clickable-month:hover {
    background: var(--bg-card);
    transform: translateX(4px);
}

.chart-bar-enhanced.clickable-month.selected {
    background: var(--accent-blue);
    color: white;
}

.chart-bar-enhanced.clickable-month.selected .chart-label,
.chart-bar-enhanced.clickable-month.selected .chart-value {
    color: white;
}

.chart-bar-enhanced .chart-label {
    width: 50px;
    font-weight: 600;
}

.chart-stats-mini {
    display: flex;
    gap: 8px;
    min-width: 180px;
}

.stat-mini {
    font-size: 0.75rem;
    padding: 2px 6px;
    border-radius: 4px;
    background: var(--bg-card);
}

.stat-mini.total {
    color: var(--text-secondary);
}

.stat-mini.done {
    color: var(--accent-green);
}

.stat-mini.overdue {
    color: var(--accent-red);
}

.stat-mini.notdone {
    color: var(--accent-orange);
}

.stat-mini.inprogress {
    color: var(--accent-blue);
}

.chart-bar-enhanced .chart-bar-container {
    flex: 1;
    height: 20px;
}

.chart-bar-fill.good {
    background: var(--accent-green);
}

.chart-bar-fill.medium {
    background: var(--accent-yellow);
}

.chart-bar-fill.bad {
    background: var(--accent-red);
}

.chart-value.good {
    color: var(--accent-green);
}

.chart-value.medium {
    color: var(--accent-yellow);
}

.chart-value.bad {
    color: var(--accent-red);
}

.manager-actions {
    margin-top: 24px;
}

/* ===== USERS PANEL ===== */
.users-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
}

/* AUDIT: .users-grid / .user-card-* удалены — Mixing Users переведены на .pk-tile-grid стиль */

/* ===== SETTINGS ===== */
.settings-section {
    background: var(--bg-card);
    border-radius: 12px;
    padding: 24px;
    border: 1px solid var(--border-color);
    margin-bottom: 20px;
}

.settings-section h3 {
    margin-bottom: 16px;
    font-size: 1.1rem;
}

.settings-actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}

/* ===== MODALS ===== */
.modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.7);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1000;
    backdrop-filter: blur(4px);
}

.modal-container {
    width: 100%;
    max-width: 500px;
    max-height: 90vh;
    overflow-y: auto;
}

/* Расширяем контейнер когда внутри большое модальное окно */
.modal-container:has(.modal-large:not(.hidden)) {
    max-width: 720px;
}

.modal {
    background: var(--bg-card);
    border-radius: 16px;
    border: 1px solid var(--border-color);
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
}

.modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px 24px;
    border-bottom: 1px solid var(--border-color);
}

.modal-header h3 {
    font-size: 1.2rem;
}

.modal-close {
    background: none;
    border: none;
    color: var(--text-secondary);
    font-size: 1.5rem;
    cursor: pointer;
    padding: 4px;
    line-height: 1;
}

.modal-close:hover {
    color: var(--text-primary);
}

.modal-body {
    padding: 24px;
}

.modal-footer {
    display: flex;
    gap: 12px;
    padding: 20px 24px;
    border-top: 1px solid var(--border-color);
}

.modal-footer .btn {
    flex: 1;
}

/* ===== ДЕТАЛИ ЗАДАНИЯ — REDESIGNED ===== */
.task-detail-redesigned {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.task-detail-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--border-color);
}

.task-detail-equipment {
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--text-primary);
    flex: 1;
}

.task-detail-status {
    padding: 6px 14px;
    border-radius: 20px;
    font-size: 0.85rem;
    font-weight: 600;
    white-space: nowrap;
    margin-left: 12px;
}

.task-detail-status.done {
    background: rgba(0, 200, 117, 0.15);
    color: #00c875;
}

.task-detail-status.partial {
    background: rgba(255, 152, 0, 0.15);
    color: #FF9800;
}

.task-detail-status.inprogress {
    background: rgba(33, 150, 243, 0.15);
    color: #2196f3;
}

.task-detail-status.pending {
    background: rgba(156, 39, 176, 0.15);
    color: #ab47bc;
}

.task-detail-status.overdue {
    background: rgba(233, 30, 99, 0.15);
    color: #e91e63;
}

.task-detail-status.notdone {
    background: rgba(233, 30, 99, 0.15);
    color: #e91e63;
}

.task-detail-status.scheduled {
    background: rgba(158, 158, 158, 0.15);
    color: #9e9e9e;
}

.task-detail-info-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
}

.task-detail-info-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    background: var(--bg-tertiary);
    border-radius: 8px;
    font-size: 0.9rem;
}

.task-detail-info-item .detail-icon {
    font-size: 1.1rem;
    flex-shrink: 0;
}

.task-detail-info-item .detail-label {
    color: var(--text-secondary);
    font-size: 0.8rem;
}

.task-detail-info-item .detail-value {
    color: var(--text-primary);
    font-weight: 600;
    font-size: 0.9rem;
}

.task-detail-info-item.full-width {
    grid-column: 1 / -1;
}

.task-detail-timestamps {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}

.task-detail-timestamp {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    background: var(--bg-tertiary);
    border-radius: 6px;
    font-size: 0.82rem;
    color: var(--text-secondary);
}

.task-detail-timestamp .ts-value {
    color: var(--text-primary);
    font-weight: 500;
}

/* Regulation work list in details */
.task-detail-regulations {
    background: var(--bg-tertiary);
    border-radius: 12px;
    padding: 16px;
    border-left: 3px solid var(--accent-primary);
}

.task-detail-regulations h4 {
    font-size: 0.95rem;
    margin-bottom: 12px;
    color: var(--text-primary);
}

.regulation-work-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.regulation-work-item {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    padding: 8px 10px;
    border-radius: 6px;
    font-size: 0.88rem;
    line-height: 1.4;
    transition: background 0.2s;
}

.regulation-work-item .reg-icon {
    flex-shrink: 0;
    font-size: 1rem;
    line-height: 1.4;
}

.regulation-work-item.completed {
    background: rgba(0, 200, 117, 0.08);
    color: var(--text-primary);
}

.regulation-work-item.completed .reg-icon {
    color: #00c875;
}

.regulation-work-item.not-completed {
    background: rgba(233, 30, 99, 0.08);
    color: #e57373;
}

.regulation-work-item.not-completed .reg-icon {
    color: #e91e63;
}

.regulation-work-item.not-completed .reg-text {
    text-decoration: line-through;
    text-decoration-color: rgba(233, 30, 99, 0.4);
}

/* Default regulation items (all checked, like for full "Выполнено") */
.regulation-work-item.default {
    background: rgba(0, 200, 117, 0.06);
    color: var(--text-primary);
}

.regulation-work-item.default .reg-icon {
    color: #00c875;
}

/* Separate comment section */
.task-detail-comment {
    background: var(--bg-tertiary);
    border-radius: 12px;
    padding: 16px;
    border-left: 3px solid #2196f3;
}

.task-detail-comment h4 {
    font-size: 0.95rem;
    margin-bottom: 10px;
    color: #42a5f5;
}

.task-detail-comment-text {
    background: rgba(33, 150, 243, 0.08);
    padding: 12px 14px;
    border-radius: 8px;
    font-size: 0.9rem;
    line-height: 1.5;
    color: var(--text-primary);
    white-space: pre-wrap;
    word-wrap: break-word;
}

/* ===== ДЕТАЛИ / ЗАВЕРШЕНИЕ ЗАДАНИЯ — 2-ПАНЕЛЬНЫЙ МОДАЛ (V2) ===== */
/* Расширение общего #modal-container активируется наличием V2-контента.
   Скоуп по классу .task-detail-v2 / .complete-v2 — ЕТО-detail (тот же
   #modal-task) и прочие модалки не затрагиваются. */
/* :not(.hidden) обязателен — closeAllModals не чистит innerHTML, стейл-контент
   скрытого модала иначе держал бы контейнер расширенным (как .modal-large:not(.hidden)). */
.modal-container:has(#modal-task:not(.hidden) .task-detail-v2),
.modal-container:has(#modal-complete:not(.hidden) .complete-v2) {
    max-width: min(960px, 95vw);
}

#modal-task:not(.hidden):has(.task-detail-v2),
#modal-complete:not(.hidden):has(.complete-v2) {
    display: flex;
    flex-direction: column;
    /* фиксированная высота — модал не меняет размер при выборе узла / фильтрации */
    height: 88vh;
    overflow: hidden;
}

#modal-task:not(.hidden):has(.task-detail-v2) > .modal-header,
#modal-task:not(.hidden):has(.task-detail-v2) > .modal-footer,
#modal-complete:not(.hidden):has(.complete-v2) > .modal-header,
#modal-complete:not(.hidden):has(.complete-v2) > .modal-footer {
    flex-shrink: 0;
}

#modal-task:not(.hidden):has(.task-detail-v2) > .modal-body,
#modal-complete:not(.hidden):has(.complete-v2) > .modal-body {
    flex: 1;
    min-height: 0;
    overflow: hidden;
    padding: 0;
}

.task-detail-v2,
.complete-v2 {
    display: flex;
    flex-direction: column;
    height: 100%;
    min-height: 0;
}

/* ===== ДОБАВИТЬ/РЕДАКТИРОВАТЬ ТО — 2-колоночный V2 (Фаза 1, 31.05.2026) =====
   Параметры слева (.tev2-form), живое превью регламента справа (.tev2-preview).
   Отдельный :has()-селектор по #modal-task-edit — :has() не пересекает границу
   модала (зеркало паттерна #modal-task / #modal-eto-shift). */
.modal-container:has(#modal-task-edit:not(.hidden) .task-edit-v2) {
    max-width: min(900px, 95vw);
}

#modal-task-edit:not(.hidden):has(.task-edit-v2) {
    display: flex;
    flex-direction: column;
    height: 86vh;
    overflow: hidden;
}

#modal-task-edit:not(.hidden):has(.task-edit-v2) > .modal-header,
#modal-task-edit:not(.hidden):has(.task-edit-v2) > .modal-footer {
    flex-shrink: 0;
}

#modal-task-edit:not(.hidden):has(.task-edit-v2) > .modal-body {
    flex: 1;
    min-height: 0;
    overflow: hidden;
    padding: 0;
    display: flex;
    flex-direction: column;
}

/* collision-banner вставляется как firstChild у .modal-body (mixing-modals.js) —
   body padding:0, поэтому задаём собственные поля и запрещаем сжатие. */
#modal-task-edit:not(.hidden):has(.task-edit-v2) > .modal-body > #task-edit-collision-banner {
    margin: 14px 18px 0;
    flex-shrink: 0;
}

.task-edit-v2 {
    flex: 1;
    min-height: 0;
    display: grid;
    grid-template-columns: 1.05fr 1fr;
}

.tev2-form {
    min-height: 0;
    overflow-y: auto;
    padding: 18px 20px;
    display: flex;
    flex-direction: column;
    gap: 16px;
    border-right: 1px solid var(--border-color);
}

.tev2-preview {
    min-height: 0;
    overflow-y: auto;
    padding: 18px 20px;
}

.tev2-preview .task-regulations-preview { margin-bottom: 0; }
.tev2-preview .task-regulations-preview ul { max-height: none; }

.tev2-preview-empty {
    color: var(--text-muted);
    font-size: 0.9rem;
    padding: 16px;
    border: 1px dashed var(--border-color);
    border-radius: 8px;
    text-align: center;
    line-height: 1.4;
}

/* Сегментированный «Тип ТО» */
.tev2-seg { display: flex; gap: 8px; }
.tev2-seg-btn {
    flex: 1;
    padding: 12px 10px;
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    color: var(--text-secondary);
    font-size: 0.95rem;
    font-weight: 600;
    cursor: pointer;
    transition: var(--transition);
}
.tev2-seg-btn:hover:not(:disabled) { border-color: var(--accent-blue); }
.tev2-seg-btn.active {
    background: var(--accent-blue);
    border-color: var(--accent-blue);
    color: #fff;
}
.tev2-seg-btn:disabled {
    opacity: 0.4;
    cursor: not-allowed;
    color: var(--text-muted);
}

/* Быстрые кнопки даты */
.tev2-date-quick { display: flex; gap: 6px; flex-wrap: wrap; }
.tev2-quick-btn {
    padding: 6px 12px;
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    border-radius: 6px;
    color: var(--text-secondary);
    font-size: 0.82rem;
    cursor: pointer;
    transition: var(--transition);
}
.tev2-quick-btn:hover { border-color: var(--accent-blue); color: var(--text-primary); }

/* Поиск оборудования (Фаза 2) */
.tev2-equip-search { font-size: 0.9rem; padding: 10px 14px; }

/* Обогащённое превью: группы по категориям ТО-1/ТО-2 + счётчик (Фаза 2) */
.tev2-prev-cat {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    margin: 12px 0 4px;
    padding: 6px 10px;
    border-radius: 6px;
    background: var(--cat-bg, var(--bg-tertiary));
    border-left: 3px solid var(--cat-color, var(--accent-blue));
}
.tev2-prev-cat:first-child { margin-top: 0; }
.tev2-prev-cat-h { font-weight: 700; font-size: 0.9rem; color: var(--cat-color, var(--text-primary)); }
.tev2-prev-cat-n { font-size: 0.78rem; color: var(--text-secondary); white-space: nowrap; }
.tev2-prev-ul { list-style: none; padding: 0; margin: 0; }
.tev2-prev-unit { color: var(--text-primary); font-weight: 600; }

/* Адаптив — стек в 1 колонку */
@media (max-width: 760px) {
    #modal-task-edit:not(.hidden):has(.task-edit-v2) { height: 92vh; }
    .task-edit-v2 { grid-template-columns: 1fr; grid-template-rows: 1fr 1fr; }
    .tev2-form { border-right: none; border-bottom: 1px solid var(--border-color); }
}

/* --- Верхняя зона (не скроллится) --- */
.tdv2-top {
    flex-shrink: 0;
    padding: 16px 20px 12px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.tdv2-title-row {
    display: flex;
    align-items: flex-start;
    gap: 12px;
}

.tdv2-equip {
    flex: 1;
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--text-primary);
    line-height: 1.35;
    word-break: break-word;
}

.tdv2-infobar {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.tdv2-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 5px 10px;
    background: var(--bg-tertiary);
    border-radius: 8px;
    font-size: 0.8rem;
    white-space: nowrap;
}

.tdv2-chip-label {
    color: var(--text-muted);
}

.tdv2-chip-value {
    color: var(--text-primary);
    font-weight: 600;
}

/* прогресс-сводка для выполненного / частичного */
.tdv2-progress {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 12px;
    background: var(--bg-tertiary);
    border-radius: 8px;
    font-size: 0.85rem;
}

.tdv2-progress-label {
    color: var(--text-secondary);
    white-space: nowrap;
    font-weight: 600;
}

.tdv2-progress-track {
    flex: 1;
    height: 8px;
    background: rgba(255, 255, 255, 0.07);
    border-radius: 4px;
    overflow: hidden;
}

.tdv2-progress-fill {
    height: 100%;
    border-radius: 4px;
    background: #22c55e;
}

/* комментарий задания (read-only, в деталях) */
.tdv2-comment {
    flex-shrink: 0;
    margin: 0 20px 12px;
    padding: 8px 12px;
    background: rgba(33, 150, 243, 0.08);
    border-left: 3px solid var(--accent-blue);
    border-radius: 6px;
    font-size: 0.85rem;
    color: var(--text-primary);
    line-height: 1.45;
    white-space: pre-wrap;
    word-break: break-word;
    max-height: 84px;
    overflow-y: auto;
}

.tdv2-comment-label {
    font-weight: 600;
    color: #42a5f5;
}

/* --- 2-панельная основная зона --- */
.tdv2-main {
    flex: 1;
    min-height: 0;
    display: grid;
    grid-template-columns: 232px 1fr;
    /* minmax(0,1fr) — строка ограничена высотой контейнера, иначе grid-трек
       растёт по контенту и внутренний overflow-y:auto не срабатывает */
    grid-template-rows: minmax(0, 1fr);
    border-top: 1px solid var(--border-color);
}

.tdv2-sidebar {
    overflow-y: auto;
    min-height: 0;
    padding: 10px;
    background: var(--bg-tertiary);
    border-right: 1px solid var(--border-color);
}

.tdv2-side-head {
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    color: var(--text-muted);
    padding: 2px 6px 8px;
}

.tdv2-side-item {
    display: flex;
    flex-direction: column;
    gap: 5px;
    width: 100%;
    text-align: left;
    padding: 8px 10px;
    margin-bottom: 5px;
    border-radius: 7px;
    border: 1px solid transparent;
    background: var(--bg-card);
    color: var(--text-secondary);
    cursor: pointer;
    font-size: 0.8rem;
    transition: var(--transition);
}

.tdv2-side-item:hover {
    border-color: var(--accent-blue);
}

.tdv2-side-item.active {
    border-color: var(--accent-blue);
    background: rgba(33, 150, 243, 0.14);
    color: var(--text-primary);
}

.tdv2-side-item-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 6px;
}

.tdv2-side-item-name {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-weight: 600;
}

.tdv2-side-item-count {
    flex-shrink: 0;
    font-size: 0.7rem;
    color: var(--text-muted);
}

.tdv2-side-track {
    height: 3px;
    background: rgba(255, 255, 255, 0.08);
    border-radius: 2px;
    overflow: hidden;
}

.tdv2-side-fill {
    height: 100%;
    border-radius: 2px;
}

/* --- правая панель --- */
.tdv2-right {
    display: flex;
    flex-direction: column;
    min-width: 0;
    min-height: 0;
    overflow: hidden;
}

.tdv2-toolbar {
    flex-shrink: 0;
    padding: 10px 14px;
    border-bottom: 1px solid var(--border-color);
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.tdv2-search {
    width: 100%;
    padding: 8px 10px;
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    border-radius: 6px;
    color: var(--text-primary);
    font-size: 0.85rem;
    box-sizing: border-box;
}

.tdv2-search:focus {
    outline: none;
    border-color: var(--accent-blue);
}

.tdv2-toolbar-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
}

.tdv2-statuschip {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 4px 10px;
    border-radius: 13px;
    border: 1px solid var(--border-color);
    background: transparent;
    color: var(--text-muted);
    font-size: 0.74rem;
    font-weight: 600;
    cursor: pointer;
    transition: var(--transition);
}

.tdv2-statuschip.on.done {
    border-color: #22c55e;
    background: rgba(34, 197, 94, 0.14);
    color: #22c55e;
}

.tdv2-statuschip.on.notdone {
    border-color: #ef4444;
    background: rgba(239, 68, 68, 0.14);
    color: #ef4444;
}

.tdv2-tool-btn {
    padding: 5px 11px;
    border-radius: 7px;
    border: 1px solid var(--accent-blue);
    background: rgba(33, 150, 243, 0.1);
    color: var(--text-primary);
    font-size: 0.76rem;
    font-weight: 600;
    cursor: pointer;
    transition: var(--transition);
}

.tdv2-tool-btn:hover {
    background: rgba(33, 150, 243, 0.2);
}

.tdv2-toolbar-spacer {
    flex: 1;
}

.tdv2-count {
    font-size: 0.74rem;
    color: var(--text-muted);
}

/* --- лента операций --- */
.tdv2-list {
    flex: 1;
    min-height: 0;
    overflow-y: auto;
    padding: 8px 14px 14px;
}

.tdv2-cat {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    padding: 8px 12px;
    margin: 12px 0 6px;
    border-radius: 7px;
    font-size: 0.82rem;
    font-weight: 700;
}

.tdv2-cat:first-child {
    margin-top: 2px;
}

.tdv2-cat-count {
    font-size: 0.72rem;
    font-weight: 600;
    color: var(--text-muted);
}

.tdv2-unit {
    display: flex;
    align-items: center;
    gap: 7px;
    margin: 14px 0 7px;
    padding: 7px 11px;
    background: var(--bg-secondary);
    border-left: 3px solid var(--accent-blue);
    border-radius: 6px;
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--text-primary);
}

/* первый узел сразу под заголовком категории — без лишнего отступа */
.tdv2-cat + .tdv2-unit {
    margin-top: 6px;
}

.tdv2-unit-count {
    font-size: 0.72rem;
    font-weight: 600;
    color: var(--text-muted);
}

.tdv2-op {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 9px 11px;
    margin: 4px 0;
    border: 1px solid var(--border-color);
    border-radius: 8px;
    background: var(--bg-tertiary);
    font-size: 0.88rem;
    line-height: 1.4;
}

.tdv2-op-num {
    flex-shrink: 0;
    min-width: 22px;
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--text-muted);
    text-align: center;
}

.tdv2-op-text {
    flex: 1;
    color: var(--text-primary);
    word-break: break-word;
}

.tdv2-op-icon {
    flex-shrink: 0;
    font-size: 0.95rem;
    line-height: 1.4;
}

.tdv2-op.done {
    background: rgba(34, 197, 94, 0.1);
    border-color: rgba(34, 197, 94, 0.3);
}

.tdv2-op.notdone {
    background: rgba(239, 68, 68, 0.1);
    border-color: rgba(239, 68, 68, 0.3);
}

.tdv2-op.notdone .tdv2-op-text {
    text-decoration: line-through;
    text-decoration-color: rgba(239, 68, 68, 0.5);
    color: var(--text-secondary);
}

/* --- интерактивные строки (модал завершения) --- */
.tdv2-op.checkable {
    cursor: pointer;
    transition: var(--transition);
}

.tdv2-op.checkable:hover {
    border-color: var(--accent-blue);
}

.tdv2-op-check {
    flex-shrink: 0;
    width: 20px;
    height: 20px;
    border-radius: 5px;
    border: 2px solid var(--text-muted);
    background: transparent;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 0.8rem;
    font-weight: bold;
}

.tdv2-op.checked {
    background: rgba(34, 197, 94, 0.12);
    border-color: rgba(34, 197, 94, 0.4);
}

.tdv2-op.checked .tdv2-op-check {
    background: #22c55e;
    border-color: #22c55e;
}

.tdv2-op.checked .tdv2-op-text {
    color: var(--text-secondary);
    text-decoration: line-through;
}

/* пустые состояния */
.tdv2-empty,
.tdv2-noreg {
    padding: 28px 16px;
    text-align: center;
    color: var(--text-muted);
    font-size: 0.85rem;
}

.tdv2-noreg {
    margin: 16px 20px;
    border: 1px dashed var(--border-color);
    border-radius: 8px;
}

/* комментарий в модале завершения (editable) */
.tdv2-complete-comment {
    flex-shrink: 0;
    padding: 10px 14px;
    border-top: 1px solid var(--border-color);
}

.tdv2-complete-comment label {
    display: block;
    font-size: 0.78rem;
    color: var(--text-secondary);
    margin-bottom: 5px;
}

.tdv2-complete-comment textarea {
    width: 100%;
    box-sizing: border-box;
    resize: vertical;
}

/* failMode «Не выполнено — отчёт» — компактный 1-pane */
.complete-failmode {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

/* Soft-disabled кнопка: визуально неактивна, но click ловится handler'ом
   (нужно для показа inline-hint + toast при попытке submit без отметок).
   HTML disabled блокирует click → не годится. aria-disabled выполняет
   роль ARIA-state; focus-trap (button:not([disabled])) кнопку оставляет
   в Tab-loop, что соответствует WCAG. */
.btn-soft-disabled {
    opacity: 0.5;
    cursor: not-allowed;
    filter: grayscale(0.45);
    transition: opacity 0.15s, filter 0.15s;
}
.btn-soft-disabled:hover {
    opacity: 0.62;
}
.btn-soft-disabled:focus-visible {
    outline: 2px solid var(--accent-yellow, #f59e0b);
    outline-offset: 2px;
}

/* Inline-плашка-подсказка «Отметьте хотя бы одну работу» — постоянно
   видна в модале при 0 отметок. Двойная обратная связь: пользователь
   видит почему кнопка неактивна ДО клика. */
.mix-hint-banner {
    margin: 8px 14px 0;
    padding: 9px 12px;
    background: rgba(245, 158, 11, 0.10);
    border: 1px solid rgba(245, 158, 11, 0.45);
    border-radius: 8px;
    color: #b45309;
    font-size: 13px;
    line-height: 1.4;
    display: flex;
    align-items: flex-start;
    gap: 8px;
    flex-shrink: 0;
}
.mix-hint-banner-icon {
    font-size: 1.05rem;
    line-height: 1;
    flex-shrink: 0;
}
.mix-hint-banner[hidden] { display: none; }

/* Пульс баннера при попытке клика по soft-disabled кнопке —
   привлекает внимание к подсказке. */
@keyframes mix-hint-pulse {
    0%, 100% {
        transform: scale(1);
        box-shadow: 0 0 0 0 rgba(245, 158, 11, 0.55);
        background: rgba(245, 158, 11, 0.10);
    }
    50% {
        transform: scale(1.015);
        box-shadow: 0 0 0 10px rgba(245, 158, 11, 0);
        background: rgba(245, 158, 11, 0.22);
    }
}
.mix-hint-banner.pulse {
    animation: mix-hint-pulse 0.65s ease-in-out;
}
@media (prefers-reduced-motion: reduce) {
    .mix-hint-banner.pulse { animation: none; }
}

/* Mini-модал «Общая причина пропуска» — поверх ЕТО-модала.
   z-index 1100: выше .modal-overlay (1000), ниже .mix-center-toast (100000) —
   чтобы validation-toast при пустом submit перекрывал mini-prompt. */
.eto-bulk-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.55);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1100;
    backdrop-filter: blur(3px);
    animation: eto-bulk-overlay-in 0.18s ease-out;
}
.eto-bulk-card {
    width: min(480px, 92vw);
    background: var(--bg-secondary, #161b22);
    border: 1px solid var(--border-color, #30363d);
    border-radius: 12px;
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.55);
    padding: 18px 20px 16px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    animation: eto-bulk-card-in 0.22s ease-out;
}
.eto-bulk-card h3 {
    margin: 0;
    font-size: 1rem;
    color: var(--text-primary, #c9d1d9);
    display: flex;
    align-items: center;
    gap: 8px;
}
.eto-bulk-card p {
    margin: 0;
    font-size: 0.85rem;
    color: var(--text-secondary, #8b949e);
    line-height: 1.45;
}
.eto-bulk-card textarea {
    width: 100%;
    box-sizing: border-box;
    resize: vertical;
    min-height: 70px;
}
.eto-bulk-card .eto-bulk-hint {
    font-size: 0.75rem;
    color: var(--text-muted, #6e7681);
    margin-top: -6px;
}
.eto-bulk-actions {
    display: flex;
    gap: 10px;
    justify-content: flex-end;
    margin-top: 4px;
}
@keyframes eto-bulk-overlay-in {
    from { opacity: 0; }
    to { opacity: 1; }
}
@keyframes eto-bulk-card-in {
    from { opacity: 0; transform: translateY(8px) scale(0.98); }
    to { opacity: 1; transform: translateY(0) scale(1); }
}
@media (prefers-reduced-motion: reduce) {
    .eto-bulk-overlay,
    .eto-bulk-card { animation: none; }
}

/* адаптив — сайдбар сворачивается в горизонтальную полосу */
@media (max-width: 720px) {
    .tdv2-main {
        grid-template-columns: 1fr;
        grid-template-rows: auto minmax(0, 1fr);
    }
    .tdv2-sidebar {
        border-right: none;
        border-bottom: 1px solid var(--border-color);
        display: flex;
        flex-direction: row;
        gap: 8px;
        overflow-x: auto;
        overflow-y: hidden;
        padding: 8px 10px;
    }
    .tdv2-side-head {
        display: none;
    }
    .tdv2-side-item {
        min-width: 150px;
        margin-bottom: 0;
    }
}

/* ===== Планшетный режим Mixing: V2-модалы «Завершение»/«Детали»/«ЕТО» — больше рабочей зоны =====
   Скоуп body:has(#mixing-tablet-app:not(.hidden)) — действует только когда активен планшет; ПК не задет.
   #3 шире/выше · #1 сайдбар зон → горизонтальная лента (вся ширина — списку) · #2 comment сворачиваемый. */
body:has(#mixing-tablet-app:not(.hidden)) .modal-container:has(#modal-complete:not(.hidden) .complete-v2),
body:has(#mixing-tablet-app:not(.hidden)) .modal-container:has(#modal-task:not(.hidden) .task-detail-v2),
body:has(#mixing-tablet-app:not(.hidden)) .modal-container:has(#modal-eto-shift:not(.hidden) .complete-v2) {
    max-width: 96vw;
}
body:has(#mixing-tablet-app:not(.hidden)) #modal-complete:not(.hidden):has(.complete-v2),
body:has(#mixing-tablet-app:not(.hidden)) #modal-task:not(.hidden):has(.task-detail-v2),
body:has(#mixing-tablet-app:not(.hidden)) #modal-eto-shift:not(.hidden):has(.complete-v2) {
    height: 92vh;
}
/* #1 — сайдбар зон горизонтально (как ≤720px, но в планшете при любой ширине) */
body:has(#mixing-tablet-app:not(.hidden)) .tdv2-main {
    grid-template-columns: 1fr;
    grid-template-rows: auto minmax(0, 1fr);
}
body:has(#mixing-tablet-app:not(.hidden)) .tdv2-sidebar {
    border-right: none;
    border-bottom: 1px solid var(--border-color);
    display: flex;
    flex-direction: row;
    gap: 8px;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 8px 10px;
}
body:has(#mixing-tablet-app:not(.hidden)) .tdv2-side-head { display: none; }
body:has(#mixing-tablet-app:not(.hidden)) .tdv2-side-item { min-width: 150px; margin-bottom: 0; }

/* #2 — комментарий сворачиваемый. ПК: toggle всегда скрыт, comment раскрыт. */
.tdv2-comment-toggle { display: none; }
body:has(#mixing-tablet-app:not(.hidden)) .tdv2-complete-comment:not(.expanded) > .tdv2-comment-toggle {
    display: block;
    width: 100%;
    text-align: left;
    padding: 6px 2px;
    background: transparent;
    border: none;
    color: var(--text-secondary);
    font-size: 0.85rem;
    cursor: pointer;
}
body:has(#mixing-tablet-app:not(.hidden)) .tdv2-complete-comment:not(.expanded) > label,
body:has(#mixing-tablet-app:not(.hidden)) .tdv2-complete-comment:not(.expanded) > textarea {
    display: none;
}

/* ===== Tier 1 (03.06): компактная рабочая зона в планшете — больше работ на экране.
   Ужимаем ТОЛЬКО обвязку и заголовки; кликабельная строка операции (.tdv2-op padding) не трогается → touch ≥44px. */
/* #5 — компактная под-шапка (оборудование + чипы даты/типа/смены) */
body:has(#mixing-tablet-app:not(.hidden)) .tdv2-top { padding: 8px 16px 6px; gap: 6px; }
body:has(#mixing-tablet-app:not(.hidden)) .tdv2-equip { font-size: 0.95rem; }
/* #3 — скрыть поиск (рабочий идёт сверху вниз) + плотнее тулбар (остаются кнопки-фильтры) */
body:has(#mixing-tablet-app:not(.hidden)) .tdv2-search { display: none; }
body:has(#mixing-tablet-app:not(.hidden)) .tdv2-toolbar { padding: 6px 12px; gap: 6px; }
/* #4 — чипы зон в 1 строку (без прогресс-бара) */
body:has(#mixing-tablet-app:not(.hidden)) .tdv2-side-track { display: none; }
body:has(#mixing-tablet-app:not(.hidden)) .tdv2-side-item { padding: 6px 10px; }
/* #2 — заголовок категории тоньше */
body:has(#mixing-tablet-app:not(.hidden)) .tdv2-cat { margin: 6px 0 3px; padding: 4px 10px; font-size: 0.78rem; }
body:has(#mixing-tablet-app:not(.hidden)) .tdv2-cat:first-child { margin-top: 0; }
/* #1 — заголовки узлов ТОНКИЕ (без фона, тонкая полоса слева вместо рамки/блока) — главный рычаг,
   именно они дублировали каждую работу (~49px → ~22px) */
body:has(#mixing-tablet-app:not(.hidden)) .tdv2-unit {
    margin: 7px 0 2px;
    padding: 2px 2px 2px 6px;
    background: transparent;
    border-left: 2px solid var(--accent-blue);
    border-radius: 0;
    font-size: 0.78rem;
    color: var(--text-secondary);
}
body:has(#mixing-tablet-app:not(.hidden)) .tdv2-cat + .tdv2-unit { margin-top: 4px; }
/* #6 — строки операций плотнее по вертикали (margin сжат). touch-target ≥44px WCAG: onclick
   теперь на всей строке .tdv2-op.checkable (см. _mixCompleteOpRowHtml) → min-height делает весь
   ряд тапабельным без мёртвой зоны; align-items:center центрирует контент в 44px (одностроч. и
   многостроч. операции). */
body:has(#mixing-tablet-app:not(.hidden)) .tdv2-op { margin: 3px 0; min-height: 44px; box-sizing: border-box; }
body:has(#mixing-tablet-app:not(.hidden)) .tdv2-op.checkable { align-items: center; }

/* Tier 1 — доп. сжатие обвязки: модал-шапка/футер, чипы под-шапки, сайдбар, hint, comment.
   (кнопки футера сохраняют свой padding .modal-footer .btn → остаются tappable) */
body:has(#mixing-tablet-app:not(.hidden)) .tdv2-chip { padding: 3px 8px; font-size: 0.74rem; }
/* Дата/тип/смена возвращены в под-шапку, но компактно: для «Завершение»/«ЕТО» под-шапка — ОДНА
   центрированная строка (оборудование + чипы 📅/📋/⚙️ инлайн), без отдельного ряда → контекст вернулся
   без потери места. Detail не трогаем (у него в title-row ещё статус-бейдж) — там чипы на своём ряду. */
body:has(#mixing-tablet-app:not(.hidden)) #modal-complete .tdv2-top,
body:has(#mixing-tablet-app:not(.hidden)) #modal-eto-shift .tdv2-top {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 4px 12px;
}
body:has(#mixing-tablet-app:not(.hidden)) #modal-complete .tdv2-title-row,
body:has(#mixing-tablet-app:not(.hidden)) #modal-eto-shift .tdv2-title-row,
body:has(#mixing-tablet-app:not(.hidden)) #modal-complete .tdv2-equip,
body:has(#mixing-tablet-app:not(.hidden)) #modal-eto-shift .tdv2-equip { flex: 0 1 auto; }
body:has(#mixing-tablet-app:not(.hidden)) .tdv2-sidebar { padding: 4px 8px; }
body:has(#mixing-tablet-app:not(.hidden)) .tdv2-side-item { padding: 4px 8px; }
body:has(#mixing-tablet-app:not(.hidden)) .mix-hint-banner { margin: 4px 12px 0; padding: 6px 10px; font-size: 12px; }
body:has(#mixing-tablet-app:not(.hidden)) .tdv2-complete-comment { padding: 4px 12px; }
body:has(#mixing-tablet-app:not(.hidden)) #modal-complete > .modal-header,
body:has(#mixing-tablet-app:not(.hidden)) #modal-complete > .modal-footer,
body:has(#mixing-tablet-app:not(.hidden)) #modal-eto-shift > .modal-header,
body:has(#mixing-tablet-app:not(.hidden)) #modal-eto-shift > .modal-footer,
body:has(#mixing-tablet-app:not(.hidden)) #modal-task > .modal-header,
body:has(#mixing-tablet-app:not(.hidden)) #modal-task > .modal-footer {
    padding: 10px 20px;
}

/* ===== COMPACT OVERDUE CARDS ===== */
#overdue-tasks .task-card {
    padding: 10px 14px;
}

#overdue-tasks .task-card .task-equipment {
    font-size: 0.9rem;
    margin-bottom: 4px;
}

#overdue-tasks .task-card .task-meta {
    font-size: 0.78rem;
    gap: 6px;
}

#overdue-tasks .task-card .task-header {
    margin-bottom: 4px;
}

#overdue-tasks .task-card .task-status-badge {
    font-size: 0.75rem;
    padding: 2px 8px;
}

#overdue-tasks .task-card .task-date {
    font-size: 0.78rem;
}

#overdue-tasks .task-card .task-actions {
    margin-top: 6px;
}

#overdue-tasks .task-card .btn {
    padding: 4px 10px;
    font-size: 0.78rem;
}

/* ===== EMPTY STATE ===== */
.empty-state {
    text-align: center;
    padding: 60px 20px;
    color: var(--text-secondary);
}

.empty-state-icon {
    font-size: 3rem;
    margin-bottom: 16px;
}

.empty-state-text {
    font-size: 1.1rem;
}

/* ===== ADD TASK CARD ===== */
.add-task-card {
    grid-column: 1 / -1;
    display: flex;
    justify-content: center;
    margin-bottom: 16px;
}

.add-task-card .btn-add-task {
    padding: 16px 32px;
    font-size: 1.1rem;
}

/* ===== CHART =====*/
.chart-count {
    width: 40px;
    font-size: 0.8rem;
    color: var(--text-muted);
}

/* ===== СТАТУС НЕ ВЫПОЛНЕНО ===== */
.task-card.status-notdone {
    border-color: #9C27B0;
}

.task-status-badge.notdone {
    background: rgba(156, 39, 176, 0.2);
    color: #BA68C8;
}

.stat-notdone .stat-value {
    color: #9C27B0;
}

/* ===== ПОДСВЕТКА КОММЕНТАРИЯ ===== */
.task-comment.highlight {
    background: rgba(255, 193, 7, 0.15);
    border-left: 3px solid var(--accent-yellow);
    padding: 8px 12px;
    border-radius: 4px;
    margin-top: 8px;
    font-size: 0.9rem;
}

.task-card.has-comment {
    box-shadow: 0 0 0 2px rgba(255, 193, 7, 0.3);
}

/* Модалки большего размера (используется .modal-large вне статистики сотрудника) */
.modal.modal-large {
    max-width: 700px;
    width: 95%;
}

/* ===== ПЛАШКИ СТАТИСТИКИ ===== */
.stats-badges {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    margin-bottom: 20px;
}

.stat-badge {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 12px 20px;
    background: var(--bg-card);
    border-radius: 10px;
    cursor: pointer;
    transition: var(--transition);
    border: 2px solid transparent;
    min-width: 90px;
}

.stat-badge:hover {
    background: var(--bg-tertiary);
    transform: translateY(-2px);
}

.stat-badge.active {
    border-color: var(--accent-blue);
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.2);
}

.stat-badge .badge-icon {
    font-size: 1.5rem;
}

.stat-badge .badge-count {
    font-size: 1.4rem;
    font-weight: 700;
}

.stat-badge .badge-label {
    font-size: 0.75rem;
    color: var(--text-muted);
    text-align: center;
}

.stat-badge.done .badge-count {
    color: var(--accent-green);
}

.stat-badge.inprogress .badge-count {
    color: var(--accent-blue);
}

.stat-badge.notdone .badge-count {
    color: #9C27B0;
}

.stat-badge.overdue .badge-count {
    color: var(--accent-red);
}

/* AUDIT_14 E71: дубль .hidden удалён — идентичная декларация уже есть на строке 38.
   Дубль .regulations-header/.regulations-actions/.regulation-list/li/li::before тоже
   удалён — поздний блок (~2952+) затирал этот через cascade. */

/* Фильтры дат */
.date-filter {
    max-width: 150px;
}

/* Стили для модального окна деталей */
.task-regulations {
    margin-top: 20px;
    background: var(--bg-tertiary);
    padding: 16px;
    border-radius: 8px;
    border-left: 4px solid var(--accent-blue);
}

.task-regulations h4 {
    margin-bottom: 12px;
    color: var(--text-primary);
    font-size: 1rem;
}

.task-regulations ul {
    list-style: none;
    padding: 0;
}

.task-regulations li {
    position: relative;
    padding-left: 20px;
    margin-bottom: 6px;
    font-size: 0.9rem;
    color: var(--text-secondary);
}

.task-regulations li::before {
    content: "✔";
    position: absolute;
    left: 0;
    color: var(--accent-green);
    font-size: 0.8rem;
}

/* Предпросмотр работ в модальном окне редактирования */
.task-regulations-preview {
    background: var(--bg-tertiary);
    padding: 12px 16px;
    border-radius: 8px;
    border-left: 4px solid var(--accent-blue);
    margin-bottom: 16px;
}

.task-regulations-preview h4 {
    margin-bottom: 10px;
    color: var(--text-primary);
    font-size: 0.95rem;
}

.task-regulations-preview ul {
    list-style: none;
    padding: 0;
    max-height: 200px;
    overflow-y: auto;
}

.task-regulations-preview li {
    position: relative;
    padding-left: 18px;
    margin-bottom: 6px;
    font-size: 0.85rem;
    color: var(--text-secondary);
}

.task-regulations-preview li::before {
    content: "•";
    position: absolute;
    left: 0;
    color: var(--accent-green);
    font-weight: bold;
}

/* Перенос текста в деталях задания */
.task-detail p {
    word-wrap: break-word;
    overflow-wrap: break-word;
    word-break: break-word;
}

.modal-body {
    overflow-wrap: break-word;
    word-break: break-word;
}

/* ===== ПОДСКАЗКИ ===== */
.hint {
    font-size: 0.75rem;
    color: var(--text-muted);
    font-weight: normal;
}

/* ===== REGULATION CHECKLIST (COMPLETION MODAL) ===== */
.regulation-checklist {
    margin-bottom: 16px;
    padding: 16px;
    background: var(--bg-tertiary);
    border-radius: 10px;
    border: 1px solid var(--border-color);
}

.regulation-checklist h4 {
    margin-bottom: 0;
    font-size: 0.95rem;
    color: var(--text-primary);
}

.reg-checklist-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    margin-bottom: 12px;
}

.reg-checklist-toolbar h4 {
    margin: 0;
}

.regulation-checklist-items {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.regulation-checklist-item {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 8px 12px;
    background: var(--bg-card);
    border-radius: 8px;
    cursor: pointer;
    transition: var(--transition);
    border: 1px solid transparent;
}

.regulation-checklist-item:hover {
    border-color: var(--accent-blue);
}

.regulation-checklist-item.checked {
    background: rgba(76, 175, 80, 0.1);
    border-color: rgba(76, 175, 80, 0.3);
}

.regulation-checklist-item input[type="checkbox"] {
    margin-top: 2px;
    width: 18px;
    height: 18px;
    accent-color: var(--accent-green);
    cursor: pointer;
    flex-shrink: 0;
}

.regulation-checklist-item label {
    cursor: pointer;
    font-size: 0.9rem;
    color: var(--text-secondary);
    line-height: 1.4;
}

.regulation-checklist-item.checked label {
    color: var(--accent-green);
    text-decoration: line-through;
}

.regulation-checklist-counter {
    margin-top: 8px;
    font-size: 0.8rem;
    color: var(--text-muted);
    text-align: right;
}

/* Stat badge partial for manager panel */
.stat-badge.partial .badge-icon {
    background: rgba(255, 152, 0, 0.2);
}

.stat-badge.partial .badge-count {
    color: #FF9800;
}

/* Stat mini partial for monthly chart */
.stat-mini.partial {
    color: #FF9800;
}

/* ===== RESPONSIVE ===== */
@media (max-width: 768px) {
    .sidebar {
        width: 100%;
        height: auto;
        position: relative;
    }

    .main-content {
        margin-left: 0;
    }

    .stats-cards {
        grid-template-columns: repeat(2, 1fr);
    }

    .tasks-container {
        grid-template-columns: 1fr;
    }

    .filter-row {
        flex-direction: column;
    }

    .filters-panel .input-field {
        width: 100%;
    }
}

@media (max-width: 480px) {
    .stats-cards {
        grid-template-columns: 1fr;
    }

    .stat-card {
        padding: 16px;
    }

    .stat-value {
        font-size: 1.5rem;
    }
}

/* ===== РЕГЛАМЕНТ ТО: КАРТОЧКИ ОБОРУДОВАНИЯ ===== */
.regulations-container {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(440px, 1fr));
    gap: 16px;
}

.regulation-card {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 14px;
    padding: 0;
    overflow: hidden;
    transition: var(--transition);
    display: flex;
    flex-direction: column;
    min-height: 200px;
}

.regulation-card:hover {
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.25);
    border-color: rgba(59, 130, 246, 0.3);
}

.regulation-card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px 20px;
    background: linear-gradient(135deg, rgba(33, 150, 243, 0.08), rgba(76, 175, 80, 0.05));
    border-bottom: 1px solid var(--border-color);
}

.regulation-card-header h4 {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--text-primary);
    flex: 1;
    margin-right: 8px;
    word-wrap: break-word;
    overflow-wrap: anywhere;
    line-height: 1.3;
}

.regulation-card-header .btn-sm {
    padding: 6px 12px;
    font-size: 0.85rem;
    flex-shrink: 0;
}

/* Бейджи категорий */
.reg-badges {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    padding: 12px 20px 4px;
}

.cat-badge {
    display: inline-flex;
    align-items: baseline;
    gap: 8px;
    padding: 6px 14px;
    border-radius: 999px;
    font-size: 0.95rem;
    font-weight: 600;
    letter-spacing: 0.2px;
}

.cat-badge-type {
    font-weight: 700;
}

.cat-badge-count {
    font-size: 0.78rem;
    font-weight: 500;
    opacity: 0.75;
    padding-left: 8px;
    border-left: 1px solid currentColor;
}

.reg-total {
    padding: 4px 20px 8px;
    font-size: 0.8rem;
    color: var(--text-muted);
}

/* Секция категории */
.reg-category-section {
    padding: 0 16px 10px;
}

.reg-category-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 6px;
    padding: 8px 36px 8px 12px;
    font-size: 1rem;
    background: rgba(255, 255, 255, 0.02);
    border-radius: 6px;
    cursor: pointer;
    user-select: none;
    position: relative;
    transition: background 0.15s;
}

.reg-category-header:hover {
    background: rgba(255, 255, 255, 0.05);
}

.reg-category-header::after {
    content: '▾';
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 0.8rem;
    color: var(--text-muted);
    transition: transform 0.15s;
}

.reg-category-section.collapsed .reg-category-header::after {
    transform: translateY(-50%) rotate(-90deg);
}

.reg-category-section.collapsed .reg-table {
    display: none;
}

.reg-count {
    font-size: 0.82rem;
    color: var(--text-muted);
    background: var(--bg-tertiary);
    padding: 3px 10px;
    border-radius: 10px;
    font-weight: 500;
}

/* AUDIT_10 #14: .reg-unit-group/.reg-unit-name удалены — после AUDIT_9 узел рендерится inline в ячейке операции */

/* Таблица работ */
.reg-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.92rem;
    border-radius: 6px;
    overflow: hidden;
    table-layout: fixed;
}

.reg-table .reg-thead th {
    background: var(--bg-tertiary);
    color: var(--text-secondary);
    font-weight: 600;
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.3px;
    padding: 7px 10px;
    text-align: left;
    border-bottom: 1px solid var(--border-color);
}

.reg-table td {
    padding: 7px 10px;
    border-bottom: 1px solid rgba(48, 54, 61, 0.5);
    color: var(--text-secondary);
    vertical-align: top;
    line-height: 1.4;
    white-space: normal;
    word-wrap: break-word;
    overflow-wrap: anywhere;
}

.reg-table tr:last-child td {
    border-bottom: none;
}

.reg-table tr:hover td {
    background: rgba(255, 255, 255, 0.02);
}

.reg-th-num,
.reg-td-num {
    width: 30px;
    min-width: 30px;
    max-width: 30px;
    padding-left: 2px !important;
    padding-right: 2px !important;
    text-align: center;
    color: var(--text-muted) !important;
    font-weight: 600;
    font-size: 0.82rem;
}

.reg-td-unit {
    width: 32%;
    font-weight: 500;
    color: var(--text-primary) !important;
    word-wrap: break-word;
    overflow-wrap: anywhere;
}

.reg-td-op {
    color: var(--text-secondary) !important;
    word-wrap: break-word;
    overflow-wrap: anywhere;
    white-space: normal;
}

/* Деталь задания: узел сверху (метка) → операция (главная) */
.reg-td-op-cell {
    word-wrap: break-word;
    overflow-wrap: anywhere;
    white-space: normal;
}
.reg-op-unit {
    display: block;
    width: 100%;
    box-sizing: border-box;
    margin: 0 0 6px;
    padding: 4px 10px;
    background: rgba(96, 165, 250, 0.10);
    border: 1px solid rgba(96, 165, 250, 0.25);
    border-left: 3px solid #60a5fa;
    border-radius: 6px;
    font-size: 0.8rem;
    font-weight: 600;
    color: #93c5fd;
    letter-spacing: 0.2px;
}
.reg-op-text {
    font-weight: 700;
    color: var(--text-primary);
    font-size: 1rem;
    line-height: 1.4;
}

/* Категория в деталях задания */
.reg-detail-section {
    margin-bottom: 16px;
    border: 1px solid var(--border-color);
    border-radius: 8px;
    overflow: hidden;
}

.reg-detail-category {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px 14px;
    font-size: 0.9rem;
}

/* Чёткие разделители между работами в деталях задания (только в этой секции) */
.reg-detail-section .reg-table {
    border-collapse: separate;
    border-spacing: 0;
}
.reg-detail-section .reg-table td {
    padding: 12px 10px;
    border-bottom: 2px solid rgba(255, 255, 255, 0.07);
}
.reg-detail-section .reg-table tr:last-child td {
    border-bottom: none;
}
.reg-detail-section .reg-table .reg-row-done td,
.reg-detail-section .reg-table .reg-row-notdone td {
    border-bottom: 2px solid rgba(0, 0, 0, 0.2);
}
.reg-detail-section .reg-table tr:last-child.reg-row-done td,
.reg-detail-section .reg-table tr:last-child.reg-row-notdone td {
    border-bottom: none;
}

/* Статусы строк таблицы — заметная подсветка фона + маркер */
.reg-row-done td {
    background: rgba(34, 197, 94, 0.12);
    color: var(--accent-green);
}

.reg-row-notdone td {
    background: rgba(239, 68, 68, 0.14);
    color: var(--accent-red);
    text-decoration: line-through;
    text-decoration-color: rgba(239, 68, 68, 0.55);
}

.reg-th-status,
.reg-td-status {
    width: 36px;
    text-align: center;
    font-size: 1rem;
    padding: 6px 4px;
}

/* Чеклист в модальном окне — секции по категориям */
.reg-checklist-section {
    margin-bottom: 14px;
    border: 1px solid var(--border-color);
    border-radius: 8px;
    overflow: hidden;
}

.reg-checklist-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px 14px;
    font-size: 0.9rem;
}

.reg-checklist-items {
    padding: 4px 0;
}

.reg-note {
    background: rgba(59, 130, 246, 0.1);
    border: 1px solid rgba(59, 130, 246, 0.25);
    border-radius: 8px;
    padding: 8px 14px;
    margin-bottom: 12px;
    font-size: 0.82rem;
    color: #93c5fd;
}

.reg-cb-unit {
    color: var(--text-primary);
    font-weight: 600;
}

.reg-cb-num {
    color: var(--text-muted);
    font-weight: 600;
    margin-right: 2px;
}

/* Список работ (fallback) */
.regulation-list {
    list-style: none;
    padding: 0 0 0 20px;
    margin: 0;
}

.regulation-list li {
    position: relative;
    padding: 4px 0 4px 16px;
    font-size: 0.82rem;
    color: var(--text-secondary);
    line-height: 1.5;
}

.regulation-list li::before {
    content: '▸';
    position: absolute;
    left: 0;
    color: var(--text-muted);
    font-size: 0.7rem;
}

.regulations-header {
    margin-bottom: 20px;
}

.regulations-header h3 {
    font-size: 1.2rem;
    margin-bottom: 12px;
    color: var(--text-primary);
}

.regulations-actions {
    display: flex;
    gap: 12px;
    align-items: center;
    flex-wrap: wrap;
}

.regulations-actions .input-field {
    flex: 1;
    min-width: 200px;
    padding: 10px 14px;
}

/* Модальное окно регламента — категории */
.reg-edit-categories {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.reg-edit-categories .form-group {
    padding: 12px;
    background: var(--bg-tertiary);
    border-radius: 8px;
    border: 1px solid var(--border-color);
}

.reg-edit-categories label {
    font-weight: 600 !important;
    font-size: 0.95rem !important;
    margin-bottom: 6px;
}

/* Динамический список работ в модалке регламента */
.reg-edit-list {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-bottom: 8px;
}

.reg-edit-row {
    display: grid;
    grid-template-columns: 30px minmax(0, 1.2fr) minmax(0, 2fr) 36px;
    gap: 8px;
    align-items: center;
}

.reg-edit-row .reg-edit-num {
    text-align: center;
    color: var(--text-muted);
    font-size: 0.9rem;
    font-weight: 600;
}

.reg-edit-row input.input-field,
.reg-edit-row textarea.input-field {
    padding: 9px 12px !important;
    font-size: 0.95rem !important;
}

.reg-edit-row input.input-field {
    height: auto !important;
}

.reg-edit-row textarea.input-field {
    resize: none;
    overflow: hidden;
    line-height: 1.35;
    min-height: 38px;
    font-family: inherit;
    width: 100%;
    box-sizing: border-box;
    word-wrap: break-word;
    overflow-wrap: anywhere;
    white-space: pre-wrap;
}

.reg-edit-row .reg-edit-del {
    background: transparent;
    border: 1px solid rgba(239, 68, 68, 0.3);
    color: #ef4444;
    border-radius: 6px;
    width: 36px;
    height: 36px;
    cursor: pointer;
    font-size: 1rem;
    transition: background 0.15s;
}
.reg-edit-row .reg-edit-del:hover {
    background: rgba(239, 68, 68, 0.15);
}

.reg-edit-add-btn {
    align-self: flex-start;
    background: rgba(59, 130, 246, 0.1);
    border: 1px dashed rgba(59, 130, 246, 0.5);
    color: #60a5fa;
    padding: 8px 18px;
    border-radius: 6px;
    cursor: pointer;
    font-size: 0.92rem;
    font-weight: 600;
    margin-top: 4px;
    transition: background 0.15s;
}
.reg-edit-add-btn:hover {
    background: rgba(59, 130, 246, 0.2);
}

.reg-edit-empty {
    font-size: 0.88rem;
    color: var(--text-muted);
    font-style: italic;
    padding: 4px 0;
}

@media (max-width: 768px) {
    .regulations-container {
        grid-template-columns: 1fr;
    }
}

/* AUDIT_10 #15: для очень узких экранов (iPhone SE и т.п.) — гарантировать 1 колонку без minmax(440px) overflow */
@media (max-width: 480px) {
    .regulations-container {
        grid-template-columns: 1fr;
        gap: 12px;
    }
}

/* ===== ЕТО — Ежесменное техническое обслуживание ===== */
.eto-header {
    margin-bottom: 16px;
}

.eto-header h2 {
    font-size: 1.3rem;
    margin: 0;
}

.eto-subtabs {
    display: flex;
    gap: 10px;
    margin-bottom: 18px;
}

.eto-subtab {
    padding: 13px 30px;
    border-radius: 10px;
    background: var(--card-bg);
    border: 1px solid var(--border-color);
    color: var(--text-secondary);
    cursor: pointer;
    font-size: 1.02rem;
    font-weight: 600;
    transition: all 0.2s;
}

.eto-subtab:hover {
    border-color: var(--accent-blue);
    color: var(--text-primary);
}

.eto-subtab.active {
    background: var(--accent-blue);
    color: white;
    border-color: var(--accent-blue);
    box-shadow: 0 2px 10px rgba(33, 150, 243, 0.32);
}

.eto-shift-bar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 16px;
    border-radius: 10px;
    background: var(--card-bg);
    border: 1px solid var(--border-color);
    margin-bottom: 16px;
}

.eto-shift-info {
    display: flex;
    align-items: center;
    gap: 12px;
}

.eto-date {
    font-weight: 600;
    color: var(--text-primary);
    text-transform: capitalize;
}

.eto-shift-badge {
    padding: 4px 12px;
    border-radius: 20px;
    font-size: 0.82rem;
    font-weight: 600;
}

.eto-day {
    background: rgba(245, 158, 11, 0.15);
    color: #f59e0b;
}

.eto-night {
    background: rgba(99, 102, 241, 0.15);
    color: #818cf8;
}

.eto-shift-selector {
    display: flex;
    align-items: center;
    gap: 8px;
}

.eto-shift-selector label {
    font-size: 0.85rem;
    color: var(--text-muted);
}

.eto-shift-selector select {
    padding: 6px 10px;
    border-radius: 6px;
    font-size: 0.85rem;
}

/* Зоны */
.eto-zone {
    margin-bottom: 12px;
    border-radius: 10px;
    border: 1px solid var(--border-color);
    overflow: hidden;
}

.eto-zone-header {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 14px;
    background: rgba(99, 102, 241, 0.08);
    border-bottom: 1px solid var(--border-color);
    font-weight: 600;
}

.eto-zone-icon {
    font-size: 1.1rem;
}

.eto-zone-name {
    flex: 1;
    color: var(--text-primary);
}

.eto-zone-count {
    font-size: 0.78rem;
    color: var(--text-muted);
    font-weight: 400;
}

/* Пункты чеклиста */
.eto-item {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 10px 14px;
    cursor: pointer;
    border-bottom: 1px solid rgba(255, 255, 255, 0.04);
    transition: background 0.15s, color 0.2s;
    position: relative;
}

.eto-item:hover {
    background: rgba(99, 102, 241, 0.06);
}

.eto-item:last-child {
    border-bottom: none;
}

.eto-item.eto-checked {
    background: rgba(16, 185, 129, 0.08);
}

.eto-item.eto-checked .eto-item-num,
.eto-item.eto-checked .eto-item-equip,
.eto-item.eto-checked .eto-item-ops {
    color: #10b981 !important;
}

.eto-checkbox {
    margin-top: 3px;
    accent-color: #10b981;
    width: 18px;
    height: 18px;
    min-width: 18px;
    cursor: pointer;
}

.eto-item-num {
    min-width: 28px;
    width: 28px;
    text-align: right;
    font-weight: 700;
    color: var(--accent-blue);
    font-size: 0.82rem;
    flex-shrink: 0;
}

.eto-item-equip {
    min-width: 220px;
    width: 220px;
    font-weight: 600;
    color: var(--text-primary);
    font-size: 0.88rem;
    flex-shrink: 0;
}

.eto-item-ops {
    color: var(--text-secondary);
    font-size: 0.84rem;
    line-height: 1.4;
    flex: 1;
}

/* Кнопки редактирования/удаления */
.eto-edit-btn,
.eto-del-btn {
    background: none;
    border: none;
    cursor: pointer;
    font-size: 0.78rem;
    padding: 2px 4px;
    border-radius: 4px;
    opacity: 0;
    transition: opacity 0.15s;
    flex-shrink: 0;
}

.eto-item:hover .eto-edit-btn,
.eto-item:hover .eto-del-btn {
    opacity: 0.7;
}

.eto-edit-btn:hover,
.eto-del-btn:hover {
    opacity: 1 !important;
    background: rgba(255, 255, 255, 0.1);
}

/* Кнопка удаления в истории */
.eto-hist-del {
    background: none;
    border: none;
    cursor: pointer;
    font-size: 0.8rem;
    padding: 2px 6px;
    border-radius: 4px;
    opacity: 0.5;
    transition: opacity 0.15s;
}

.eto-hist-del:hover {
    opacity: 1;
    background: rgba(239, 68, 68, 0.15);
}

/* Подвал */
.eto-footer {
    margin-top: 16px;
    padding: 16px;
    background: var(--card-bg);
    border: 1px solid var(--border-color);
    border-radius: 10px;
}

.eto-comment {
    margin-bottom: 12px;
}

.eto-comment label {
    display: block;
    font-size: 0.85rem;
    margin-bottom: 6px;
    color: var(--text-secondary);
}

.eto-comment textarea {
    width: 100%;
    box-sizing: border-box;
}

.eto-actions {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.eto-counter {
    font-size: 0.9rem;
    color: var(--text-muted);
    font-weight: 600;
}

/* История */
.eto-history-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.88rem;
}

.eto-history-table thead {
    background: rgba(99, 102, 241, 0.1);
}

.eto-history-table th {
    padding: 10px 12px;
    text-align: left;
    font-weight: 600;
    color: var(--text-secondary);
    border-bottom: 2px solid var(--border-color);
}

.eto-history-row {
    cursor: pointer;
    transition: background 0.15s;
}

.eto-history-row:hover {
    background: rgba(99, 102, 241, 0.08);
}

.eto-history-row td {
    padding: 10px 12px;
    border-bottom: 1px solid var(--border-color);
}

.eto-pct-full {
    color: #10b981;
    font-weight: 600;
}

.eto-pct-half {
    color: #f59e0b;
    font-weight: 600;
}

.eto-pct-low {
    color: #ef4444;
    font-weight: 600;
}

/* Детали ЕТО */
.eto-detail-header {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
    padding: 12px 16px;
    background: var(--card-bg);
    border-radius: 8px;
    margin-bottom: 12px;
    font-size: 0.9rem;
}

.eto-detail-progress {
    padding: 10px 16px;
    background: rgba(99, 102, 241, 0.1);
    border-radius: 8px;
    margin-bottom: 12px;
    font-size: 0.95rem;
}

.eto-detail-comment {
    padding: 10px 16px;
    background: rgba(245, 158, 11, 0.1);
    border-radius: 8px;
    margin-bottom: 12px;
    font-size: 0.88rem;
}

.eto-detail-zone {
    margin-bottom: 10px;
}

.eto-detail-zone-title {
    font-weight: 600;
    padding: 8px 12px;
    background: rgba(99, 102, 241, 0.08);
    border-radius: 6px;
    margin-bottom: 4px;
}

.eto-detail-item {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    padding: 6px 12px;
    font-size: 0.84rem;
}

.eto-done {
    opacity: 1;
}

.eto-notdone {
    opacity: 0.5;
}

.eto-detail-equip {
    font-weight: 600;
    min-width: 180px;
}

.eto-detail-ops {
    color: var(--text-secondary);
}

/* Кнопка "Отметить все" + (Sprint 11B) "➕ Добавить зону" над списком ЕТО */
.eto-mark-all-bar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 8px;
    padding: 8px 0;
    margin-bottom: 8px;
    flex-wrap: wrap;
}

/* Sprint 11B U2/U3 — кнопки добавления пункта/зоны (manager+engineer) */
.eto-add-zone-btn {
    flex-shrink: 0;
}

.eto-add-item-btn {
    display: block;
    width: 100%;
    margin-top: 8px;
    padding: 10px 12px;
    background: transparent;
    border: 1px dashed var(--text-muted, #9ca3af);
    border-radius: 6px;
    color: var(--text-secondary, #9ca3af);
    cursor: pointer;
    font-size: 0.85rem;
    font-weight: 500;
    transition: all 0.15s;
}

.eto-add-item-btn:hover {
    border-color: var(--accent, #3b82f6);
    color: var(--accent, #3b82f6);
    background: rgba(59, 130, 246, 0.05);
}

.eto-add-item-btn:focus-visible {
    outline: 2px solid var(--accent, #3b82f6);
    outline-offset: 2px;
}

/* Sprint 11B U3 — emoji-picker для модалки новой зоны */
.eto-icon-picker {
    display: grid;
    grid-template-columns: repeat(8, 1fr);
    gap: 6px;
    margin-top: 6px;
}

.eto-icon-picker-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    aspect-ratio: 1 / 1;
    background: rgba(255, 255, 255, 0.04);
    border: 1.5px solid transparent;
    border-radius: 6px;
    cursor: pointer;
    font-size: 1.4rem;
    line-height: 1;
    padding: 0;
    transition: all 0.12s;
}

.eto-icon-picker-btn:hover {
    background: rgba(59, 130, 246, 0.12);
    border-color: rgba(59, 130, 246, 0.4);
}

.eto-icon-picker-btn.selected {
    background: rgba(59, 130, 246, 0.2);
    border-color: var(--accent, #3b82f6);
    box-shadow: 0 0 0 1px var(--accent, #3b82f6);
}

.eto-icon-picker-btn:focus-visible {
    outline: 2px solid var(--accent, #3b82f6);
    outline-offset: 2px;
}

@media (max-width: 480px) {
    .eto-icon-picker {
        grid-template-columns: repeat(4, 1fr);
    }
}

/* Sprint 11C U4 — кнопка пропустить пункт + inline reason input */
.eto-skip-btn {
    background: none;
    border: none;
    cursor: pointer;
    font-size: 0.78rem;
    padding: 2px 4px;
    border-radius: 4px;
    opacity: 0.35;
    transition: opacity 0.15s, background 0.15s;
    flex-shrink: 0;
}

.eto-item:hover .eto-skip-btn {
    opacity: 0.7;
}

.eto-skip-btn:hover {
    opacity: 1 !important;
    background: rgba(245, 158, 11, 0.15);
}

.eto-skip-btn.eto-skipped-btn {
    opacity: 1;
    background: rgba(245, 158, 11, 0.18);
}

.eto-item.eto-skipped {
    background: rgba(245, 158, 11, 0.06);
    border-left: 3px solid #f59e0b;
}

.eto-item.eto-skipped .eto-checkbox {
    opacity: 0.4;
    cursor: not-allowed;
}

.eto-skip-reason-row {
    padding: 6px 12px 8px 32px;
    background: rgba(245, 158, 11, 0.04);
    margin-bottom: 4px;
}

.eto-skip-reason-input {
    width: 100%;
    padding: 6px 10px;
    font-size: 0.85rem;
    background: var(--card-bg, rgba(255,255,255,0.04));
    border: 1px solid rgba(245, 158, 11, 0.4);
    border-radius: 4px;
    color: var(--text-primary, inherit);
}

.eto-skip-reason-input:focus {
    outline: 2px solid #f59e0b;
    outline-offset: 1px;
    border-color: #f59e0b;
}

/* Sprint 11C U8 — секции в detail-modal с цветовой кодировкой */
.eto-detail-section {
    margin: 12px 0;
    padding: 10px 14px;
    border-radius: 8px;
    border-left: 4px solid transparent;
}

.eto-detail-section-title {
    margin: 0 0 8px 0;
    font-size: 0.95rem;
    font-weight: 600;
}

.eto-detail-section-count {
    font-size: 0.85rem;
    color: var(--text-secondary, #9ca3af);
    font-weight: 400;
}

.eto-detail-section-notdone {
    background: rgba(239, 68, 68, 0.06);
    border-left-color: #ef4444;
}

.eto-detail-section-skipped {
    background: rgba(245, 158, 11, 0.06);
    border-left-color: #f59e0b;
}

.eto-detail-section-done {
    background: rgba(16, 185, 129, 0.06);
    border-left-color: #10b981;
}

.eto-detail-section-deleted {
    background: rgba(156, 163, 175, 0.08);
    border-left-color: #9ca3af;
}

.eto-detail-skip-reason {
    margin-top: 4px;
    padding: 4px 8px;
    font-size: 0.82rem;
    color: var(--text-secondary, #9ca3af);
    background: rgba(245, 158, 11, 0.08);
    border-radius: 4px;
}

.eto-detail-deleted .eto-detail-equip {
    font-style: italic;
    color: var(--text-muted, #6b7280);
}

.eto-detail-correction-link {
    padding: 8px 12px;
    margin-bottom: 12px;
    font-size: 0.85rem;
    background: rgba(99, 102, 241, 0.1);
    border-radius: 6px;
}

.eto-detail-correction-link a {
    color: var(--accent, #3b82f6);
    text-decoration: underline;
    cursor: pointer;
}

/* Sprint 11C U7 — корректировка в истории: indent + badge */
.eto-correction-badge {
    display: inline-block;
    margin-right: 4px;
    font-size: 0.85rem;
}

/* Sprint 13E U10: orphan badge — корректировка без оригинала (исходная запись удалена).
   Раньше бэйдж был просто красным emoji 🔄⚠️, без визуальной рамки. Теперь явный
   pill-стиль с border, чтобы пользователь увидел что это исключительный случай,
   и tooltip объясняет причину при hover. */
.eto-correction-badge.eto-correction-orphan {
    color: #ef4444;
    background: rgba(239, 68, 68, 0.12);
    border: 1px solid rgba(239, 68, 68, 0.4);
    padding: 1px 6px;
    border-radius: 10px;
    font-weight: 600;
    cursor: help;
}

/* Sprint 13E U10: pre-check сирот в detail-modal. */
.eto-detail-correction-orphan {
    color: #fca5a5;
    background: rgba(239, 68, 68, 0.1);
    border: 1px solid rgba(239, 68, 68, 0.35);
    padding: 8px 12px;
    border-radius: 6px;
    font-size: 13px;
}

.eto-history-correction-row td:first-child {
    padding-left: 28px;
    border-left: 3px solid rgba(99, 102, 241, 0.4);
}

.eto-history-correction-row {
    background: rgba(99, 102, 241, 0.03);
}

/* Sprint 11D U5 — search bar + clear/print кнопки */
.eto-search-bar {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 0 0 12px 0;
}

.eto-search-input {
    flex: 1 1 auto;
    min-width: 0;
}

.eto-search-clear {
    flex-shrink: 0;
    padding: 6px 12px;
}

.eto-print-btn {
    flex-shrink: 0;
}

.eto-empty-search {
    text-align: center;
    padding: 40px 20px;
    color: var(--text-muted, #9ca3af);
    font-size: 0.95rem;
    background: rgba(99, 102, 241, 0.04);
    border-radius: 8px;
    margin: 16px 0;
}

/* Sprint 11D U9 — filter bar истории */
.eto-history-filter-bar {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    margin-bottom: 12px;
    padding: 10px 12px;
    background: rgba(99, 102, 241, 0.04);
    border-radius: 8px;
    font-size: 0.85rem;
}

.eto-filter-label {
    display: flex;
    align-items: center;
    gap: 4px;
    color: var(--text-secondary, #9ca3af);
    font-size: 0.85rem;
}

.eto-filter-label input[type="date"] {
    padding: 4px 8px;
    background: var(--card-bg, rgba(255,255,255,0.04));
    border: 1px solid var(--border-color, #334155);
    border-radius: 4px;
    color: var(--text-primary, inherit);
    font-size: 0.85rem;
}

.eto-history-filter-bar select {
    padding: 4px 8px;
    background: var(--card-bg, rgba(255,255,255,0.04));
    border: 1px solid var(--border-color, #334155);
    border-radius: 4px;
    color: var(--text-primary, inherit);
    font-size: 0.85rem;
}

/* Опции в выпадающих списках фильтра — тёмная тема (default browser bg — белый) */
.eto-history-filter-bar select option {
    background: #1e293b;
    color: #f1f5f9;
}

/* 03.05: кнопка удаления зоны в zone-header (manager+engineer) */
.eto-del-zone-btn {
    background: none;
    border: none;
    cursor: pointer;
    font-size: 0.9rem;
    padding: 4px 8px;
    border-radius: 4px;
    opacity: 0.4;
    transition: opacity 0.15s, background 0.15s;
    margin-left: 8px;
}

.eto-zone-header:hover .eto-del-zone-btn {
    opacity: 0.8;
}

.eto-del-zone-btn:hover {
    opacity: 1;
    background: rgba(239, 68, 68, 0.18);
}

/* 03.05: кнопка печати в detail-modal */
.eto-detail-print-btn {
    margin-left: auto;
    padding: 4px 12px;
    font-size: 0.8rem;
}

.eto-filter-summary {
    color: var(--text-secondary, #9ca3af);
    font-size: 0.85rem;
}

/* Текст работ в чеклисте регламента (модальное окно завершения) */
.reg-cb-label {
    flex: 1;
    cursor: pointer;
    line-height: 1.4;
}

/* Кликабельные строки регламента */
.regulation-checklist-item {
    cursor: pointer;
}

.regulation-checklist-item:hover {
    background: rgba(59, 130, 246, 0.08);
}

/* ===== STATISTICS DASHBOARD ===== */
.stats-dashboard-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 24px;
    flex-wrap: wrap;
    gap: 16px;
}

.stats-dashboard-header h2 {
    font-size: 1.6rem;
    font-weight: 700;
    background: linear-gradient(135deg, #60a5fa, #34d399);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

.stats-period-selector {
    display: flex;
    background: var(--bg-tertiary);
    border-radius: 10px;
    overflow: hidden;
    border: 1px solid var(--border-color);
}

.stats-period-btn {
    padding: 10px 20px;
    background: transparent;
    border: none;
    color: var(--text-secondary);
    font-size: 0.9rem;
    cursor: pointer;
    transition: var(--transition);
    font-weight: 500;
}

.stats-period-btn:hover {
    color: var(--text-primary);
    background: rgba(255, 255, 255, 0.05);
}

.stats-period-btn.active {
    background: var(--accent-blue);
    color: #fff;
}

/* Dropdown месяца */
.stats-month-dropdown {
    padding: 10px 16px;
    background: transparent;
    border: none;
    color: var(--text-secondary);
    font-size: 0.9rem;
    cursor: pointer;
    font-weight: 500;
    outline: none;
    appearance: none;
    -webkit-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%238b949e' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 10px center;
    padding-right: 28px;
}

.stats-month-dropdown:hover {
    color: var(--text-primary);
    background-color: rgba(255, 255, 255, 0.05);
}

.stats-month-dropdown.active {
    background-color: var(--accent-blue);
    color: #fff;
}

.stats-month-dropdown option {
    background: var(--bg-secondary);
    color: var(--text-primary);
    padding: 8px;
}

.stats-section {
    margin-bottom: 32px;
}

.stats-section-title {
    font-size: 1.2rem;
    font-weight: 600;
    margin-bottom: 16px;
    padding-bottom: 8px;
    border-bottom: 1px solid var(--border-color);
    color: var(--text-primary);
}

.stats-subsection-title {
    font-size: 1rem;
    font-weight: 600;
    margin: 20px 0 12px;
    color: var(--text-secondary);
}

/* KPI Cards */
.stats-kpi-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 16px;
}

.stats-kpi-card {
    background: var(--bg-card);
    border-radius: 14px;
    padding: 20px 24px;
    border: 1px solid var(--border-color);
    position: relative;
    overflow: hidden;
    transition: var(--transition);
}

.stats-kpi-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3);
}

.stats-kpi-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
}

.stats-kpi-card.kpi-blue::before {
    background: linear-gradient(90deg, #3b82f6, #60a5fa);
}

.stats-kpi-card.kpi-green::before {
    background: linear-gradient(90deg, #22c55e, #4ade80);
}

.stats-kpi-card.kpi-orange::before {
    background: linear-gradient(90deg, #f59e0b, #fbbf24);
}

.stats-kpi-card.kpi-red::before {
    background: linear-gradient(90deg, #ef4444, #f87171);
}

.stats-kpi-card.kpi-purple::before {
    background: linear-gradient(90deg, #8b5cf6, #a78bfa);
}

.stats-kpi-value {
    font-size: 2.2rem;
    font-weight: 800;
    line-height: 1;
    margin-bottom: 4px;
}

.stats-kpi-label {
    font-size: 0.85rem;
    color: var(--text-secondary);
    font-weight: 500;
}

.stats-kpi-sub {
    font-size: 0.75rem;
    color: var(--text-muted);
    margin-top: 4px;
}

.stats-kpi-card.kpi-blue .stats-kpi-value {
    color: #60a5fa;
}

.stats-kpi-card.kpi-green .stats-kpi-value {
    color: #4ade80;
}

.stats-kpi-card.kpi-orange .stats-kpi-value {
    color: #fbbf24;
}

.stats-kpi-card.kpi-red .stats-kpi-value {
    color: #f87171;
}

.stats-kpi-card.kpi-purple .stats-kpi-value {
    color: #a78bfa;
}

.stats-kpi-card.kpi-gray::before {
    background: linear-gradient(90deg, #6b7280, #9ca3af);
}

.stats-kpi-card.kpi-gray .stats-kpi-value {
    color: #9ca3af;
}

.stats-kpi-card.kpi-teal::before {
    background: linear-gradient(90deg, #14b8a6, #2dd4bf);
}

.stats-kpi-card.kpi-teal .stats-kpi-value {
    color: #2dd4bf;
}

/* Ф2e (12.06.2026): KPI «📅 Запланировано» — индиго Планировщика ТО */
.stats-kpi-card.kpi-indigo::before {
    background: linear-gradient(90deg, #6366f1, #818cf8);
}

.stats-kpi-card.kpi-indigo .stats-kpi-value {
    color: #818cf8;
}

.stats-kpi-card.kpi-amber::before {
    background: linear-gradient(90deg, #f59e0b, #fcd34d);
}

.stats-kpi-card.kpi-amber .stats-kpi-value {
    color: #fcd34d;
}

/* Stats Table */
.stats-table-wrap {
    overflow-x: auto;
    margin-top: 8px;
}

.stats-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.88rem;
}

.stats-table th {
    background: var(--bg-tertiary);
    padding: 10px 14px;
    text-align: left;
    font-weight: 600;
    color: var(--text-secondary);
    border-bottom: 2px solid var(--border-color);
    white-space: nowrap;
    cursor: pointer;
    user-select: none;
}

.stats-table th:hover {
    color: var(--text-primary);
}

.stats-table td {
    padding: 10px 14px;
    border-bottom: 1px solid rgba(48, 54, 61, 0.5);
    color: var(--text-primary);
}

.stats-table tr:hover td {
    background: rgba(59, 130, 246, 0.06);
}

.stats-progress-bar {
    height: 8px;
    background: var(--bg-tertiary);
    border-radius: 4px;
    overflow: hidden;
    min-width: 80px;
}

.stats-progress-fill {
    height: 100%;
    border-radius: 4px;
    transition: width 0.8s ease;
}

.stats-badge {
    display: inline-block;
    padding: 2px 10px;
    border-radius: 10px;
    font-size: 0.78rem;
    font-weight: 600;
}

/* Top 5 problem cards */
.stats-top5-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 12px;
    margin-bottom: 16px;
}

.stats-top5-card {
    background: var(--bg-card);
    border-radius: 12px;
    padding: 16px;
    border: 1px solid var(--border-color);
    border-left: 4px solid #ef4444;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.stats-top5-card.ok {
    border-left-color: #22c55e;
}

.stats-top5-name {
    font-weight: 600;
    font-size: 0.9rem;
}

.stats-top5-stat {
    font-size: 0.82rem;
    color: var(--text-secondary);
}

/* Charts */
.stats-charts-row {
    display: grid;
    grid-template-columns: 1.4fr 1fr;
    gap: 16px;
}

.stats-chart-card {
    background: var(--bg-card);
    border-radius: 14px;
    padding: 20px;
    border: 1px solid var(--border-color);
    display: flex;
    flex-direction: column;
}

.stats-chart-card h4 {
    font-size: 0.95rem;
    font-weight: 600;
    margin-bottom: 16px;
    color: var(--text-secondary);
}

.svg-chart-container {
    width: 100%;
    min-height: 250px;
    position: relative;
}

.svg-chart-container svg {
    width: 100%;
    height: 100%;
}

/* Donut Chart — стек: круг сверху, легенда внизу горизонтальными пилюлями */
.donut-chart-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    gap: 18px;
    min-height: 240px;
    padding: 8px 0;
    flex: 1;
}

.donut-svg {
    width: 200px;
    height: 200px;
    flex-shrink: 0;
}

.donut-legend {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 8px 10px;
    justify-content: center;
    width: 100%;
}

.donut-legend-item {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 0.82rem;
    color: var(--text-secondary);
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 999px;
    padding: 5px 12px;
    flex: 0 0 auto;
}

.donut-legend-color {
    width: 10px;
    height: 10px;
    border-radius: 3px;
    flex-shrink: 0;
}

.donut-legend-val {
    font-weight: 700;
    color: var(--text-primary);
    margin-left: 4px;
    padding-left: 8px;
    border-left: 1px solid rgba(255, 255, 255, 0.12);
}

/* AUDIT_10 #14: .stats-heatmap/.heatmap-* удалены — heatmap-функция удалена в сессии 20 */

/* Stacked bar */
.stacked-bar-row {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 8px;
}

.stacked-bar-label {
    min-width: 50px;
    font-size: 0.8rem;
    color: var(--text-secondary);
    text-align: right;
}

.stacked-bar {
    flex: 1;
    height: 24px;
    background: var(--bg-tertiary);
    border-radius: 6px;
    overflow: hidden;
    display: flex;
}

.stacked-seg {
    height: 100%;
    transition: width 0.8s ease;
    position: relative;
}

.stacked-seg:hover {
    filter: brightness(1.2);
}

.stacked-bar-val {
    font-size: 0.78rem;
    color: var(--text-muted);
    min-width: 30px;
}

.stacked-legend {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
    margin-top: 12px;
    font-size: 0.8rem;
    color: var(--text-secondary);
}

.stacked-legend-item {
    display: flex;
    align-items: center;
    gap: 5px;
}

.stacked-legend-dot {
    width: 10px;
    height: 10px;
    border-radius: 2px;
}

/* Shift comparison bars */
.shift-compare-row {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 10px;
}

.shift-compare-label {
    min-width: 80px;
    font-weight: 600;
    font-size: 0.9rem;
    color: var(--text-primary);
}

.shift-compare-bar {
    flex: 1;
    height: 30px;
    background: var(--bg-tertiary);
    border-radius: 8px;
    overflow: hidden;
    position: relative;
}

.shift-compare-fill {
    height: 100%;
    border-radius: 8px;
    transition: width 1s ease;
    display: flex;
    align-items: center;
    padding-left: 10px;
    font-size: 0.78rem;
    color: #fff;
    font-weight: 600;
}

.shift-compare-val {
    font-size: 0.85rem;
    font-weight: 600;
    min-width: 50px;
    text-align: right;
}

/* ETO Calendar */
.stats-eto-month-nav {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 10px;
    justify-content: center;
}

.stats-eto-month-nav span {
    font-size: 0.85rem;
    font-weight: 600;
    min-width: 130px;
    text-align: center;
    text-transform: capitalize;
}

.eto-calendar-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 3px;
}

.eto-cal-header {
    text-align: center;
    font-size: 0.65rem;
    font-weight: 600;
    color: var(--text-muted);
    padding: 3px 0;
}

.eto-cal-day {
    aspect-ratio: 1;
    border-radius: 6px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    font-size: 0.7rem;
    font-weight: 600;
    min-height: 28px;
    transition: var(--transition);
    cursor: default;
    position: relative;
}

.eto-cal-day.empty {
    background: transparent;
}

.eto-cal-day.full {
    background: rgba(34, 197, 94, 0.25);
    color: #4ade80;
    border: 1px solid rgba(34, 197, 94, 0.3);
}

.eto-cal-day.partial {
    background: rgba(245, 158, 11, 0.25);
    color: #fbbf24;
    border: 1px solid rgba(245, 158, 11, 0.3);
}

.eto-cal-day.missed {
    background: rgba(239, 68, 68, 0.2);
    color: #f87171;
    border: 1px solid rgba(239, 68, 68, 0.3);
}

.eto-cal-day.none {
    background: var(--bg-tertiary);
    color: var(--text-muted);
}

.eto-cal-day.today {
    box-shadow: 0 0 0 2px #60a5fa;
}

.eto-cal-day:hover {
    transform: scale(1.1);
    z-index: 2;
}

.eto-cal-sub {
    font-size: 0.5rem;
    font-weight: 400;
    margin-top: 0;
    line-height: 1;
}

/* ETO day/night comparison — компактный горизонтальный layout */
.eto-daynight-block {
    display: flex;
    gap: 10px;
    align-items: stretch;
    margin-top: 4px;
}

.eto-dn-card {
    flex: 1;
    background: var(--bg-tertiary);
    border-radius: 8px;
    padding: 10px 12px;
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    column-gap: 10px;
    row-gap: 0;
    text-align: left;
}

.eto-dn-icon {
    font-size: 1.4rem;
    margin-bottom: 0;
    grid-row: 1 / span 2;
    align-self: center;
}

.eto-dn-val {
    font-size: 1.5rem;
    font-weight: 800;
    line-height: 1;
    grid-column: 3;
    grid-row: 1 / span 2;
    align-self: center;
}

.eto-dn-label {
    font-size: 0.72rem;
    color: var(--text-secondary);
    margin-top: 0;
    grid-column: 2;
    grid-row: 1;
    line-height: 1.2;
}

.eto-dn-sub {
    font-size: 0.65rem;
    color: var(--text-muted);
    margin-top: 0;
    grid-column: 2;
    grid-row: 2;
    line-height: 1.2;
}

/* Missed ETO items */
.eto-missed-bar-row {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 6px;
}

.eto-missed-label {
    min-width: 200px;
    font-size: 0.82rem;
    color: var(--text-secondary);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.eto-missed-bar {
    flex: 1;
    height: 18px;
    background: var(--bg-tertiary);
    border-radius: 4px;
    overflow: hidden;
}

.eto-missed-fill {
    height: 100%;
    background: linear-gradient(90deg, #ef4444, #f87171);
    border-radius: 4px;
    transition: width 0.8s ease;
}

.eto-missed-val {
    font-size: 0.78rem;
    color: var(--text-muted);
    min-width: 40px;
    text-align: right;
}

@media (max-width: 900px) {
    .stats-charts-row {
        grid-template-columns: 1fr;
    }

    .donut-svg {
        width: 170px;
        height: 170px;
    }
    .donut-chart-container {
        min-height: 210px;
    }

    .stats-kpi-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .eto-daynight-block {
        flex-direction: column;
    }
}

/* ===== ВАКУУМНЫЕ НАСОСЫ ===== */
.pumps-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 16px;
    margin-bottom: 24px;
}

.pumps-header h2 {
    font-size: 1.4rem;
    font-weight: 700;
}

.pumps-filters {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}

.pumps-filters .input-field {
    padding: 10px 14px;
    min-width: 180px;
}

.pumps-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(380px, 1fr));
    gap: 20px;
}

.pump-card {
    background: var(--bg-card);
    border-radius: 14px;
    border: 1px solid var(--border-color);
    overflow: hidden;
    transition: var(--transition);
    position: relative;
}

.pump-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 28px rgba(0, 0, 0, 0.35);
    border-color: rgba(33, 150, 243, 0.3);
}

.pump-card-header {
    padding: 16px 20px 12px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.04);
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 10px;
}

.pump-card-title {
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--text-primary);
}

.pump-card-type {
    font-size: 0.78rem;
    color: var(--text-muted);
    margin-top: 2px;
    font-family: 'Courier New', monospace;
}

.pump-location-badge {
    font-size: 0.72rem;
    padding: 3px 8px;
    border-radius: 6px;
    background: rgba(33, 150, 243, 0.12);
    color: #60a5fa;
    white-space: nowrap;
    flex-shrink: 0;
}

/* Блок моточасов */
.pump-hours-block {
    padding: 14px 20px;
    background: rgba(0, 0, 0, 0.15);
}

.pump-hours-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 8px;
}

.pump-hours-label {
    font-size: 0.82rem;
    color: var(--text-secondary);
}

.pump-hours-value {
    display: flex;
    align-items: center;
    gap: 6px;
}

.pump-hours-number {
    font-size: 1.5rem;
    font-weight: 800;
    font-family: 'Courier New', monospace;
    line-height: 1;
}

.pump-hours-unit {
    font-size: 0.75rem;
    color: var(--text-muted);
}

.pump-hours-edit-btn {
    background: none;
    border: 1px solid rgba(255, 255, 255, 0.1);
    color: var(--text-muted);
    cursor: pointer;
    padding: 4px 8px;
    border-radius: 6px;
    font-size: 0.8rem;
    transition: var(--transition);
}

.pump-hours-edit-btn:hover {
    background: rgba(33, 150, 243, 0.15);
    color: #60a5fa;
    border-color: rgba(33, 150, 243, 0.3);
}

.pump-hours-input {
    width: 100px;
    padding: 6px 10px;
    background: var(--bg-tertiary);
    border: 2px solid var(--accent-blue);
    border-radius: 6px;
    color: var(--text-primary);
    font-size: 1.1rem;
    font-weight: 700;
    font-family: 'Courier New', monospace;
    text-align: center;
    outline: none;
}

.pump-hours-input:focus {
    box-shadow: 0 0 0 3px rgba(33, 150, 243, 0.25);
}

/* Прогресс-бар выработки */
.pump-progress-bar {
    height: 6px;
    background: var(--bg-tertiary);
    border-radius: 3px;
    overflow: hidden;
    margin-top: 4px;
}

.pump-progress-fill {
    height: 100%;
    border-radius: 3px;
    transition: width 0.5s ease;
}

.pump-progress-fill.status-ok {
    background: linear-gradient(90deg, #22c55e, #4ade80);
}

.pump-progress-fill.status-warn {
    background: linear-gradient(90deg, #f59e0b, #fbbf24);
}

.pump-progress-fill.status-danger {
    background: linear-gradient(90deg, #ef4444, #f87171);
}

.pump-hours-remaining {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 6px;
    font-size: 0.75rem;
    color: var(--text-muted);
}

.pump-norm-value {
    color: var(--text-secondary);
    font-weight: 600;
}

/* Информация о насосе */
.pump-info {
    padding: 12px 20px 16px;
}

.pump-info-row {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 5px 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.03);
    font-size: 0.82rem;
    gap: 12px;
}

.pump-info-row:last-child {
    border-bottom: none;
}

.pump-info-label {
    color: var(--text-muted);
    flex-shrink: 0;
    min-width: 100px;
}

.pump-info-value {
    color: var(--text-primary);
    text-align: right;
    word-break: break-word;
}

/* Расходники */
.pump-consumables {
    padding: 12px 20px 16px;
    border-top: 1px solid rgba(255, 255, 255, 0.04);
}

.pump-consumables-title {
    font-size: 0.78rem;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 8px;
    font-weight: 600;
}

.pump-consumable-item {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 4px 0;
    font-size: 0.8rem;
    gap: 10px;
}

.pump-consumable-label {
    color: var(--text-secondary);
}

.pump-consumable-value {
    color: var(--text-primary);
    text-align: right;
    word-break: break-word;
    max-width: 60%;
}

/* Статус-индикатор */
.pump-status-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    display: inline-block;
    flex-shrink: 0;
}

.pump-status-dot.ok {
    background: #22c55e;
    box-shadow: 0 0 6px rgba(34, 197, 94, 0.5);
}

.pump-status-dot.warn {
    background: #f59e0b;
    box-shadow: 0 0 6px rgba(245, 158, 11, 0.5);
}

.pump-status-dot.danger {
    background: #ef4444;
    box-shadow: 0 0 6px rgba(239, 68, 68, 0.5);
    animation: pulse-danger 1.5s infinite;
}

@keyframes pulse-danger {

    0%,
    100% {
        box-shadow: 0 0 6px rgba(239, 68, 68, 0.5);
    }

    50% {
        box-shadow: 0 0 14px rgba(239, 68, 68, 0.8);
    }
}

/* Phase 3.5 fix 6: hint про "Абсолютная наработка" — explanation для user'а
   что это accumulator (не reset). */
.pump-hours-hint {
    font-size: 0.7rem;
    color: var(--text-muted);
    font-style: italic;
    margin-top: 2px;
    margin-bottom: 8px;
    line-height: 1.3;
}
.form-hint {
    font-size: 0.72rem;
    color: var(--text-muted);
    font-style: italic;
    margin-top: 4px;
    line-height: 1.35;
}

/* Без норматива */
.pump-no-norm {
    color: var(--text-muted);
    font-style: italic;
    font-size: 0.82rem;
}

/* ===== Phase 2 (23.05.2026): pumps works + service modal ===== */
/* Карточка насоса при наличии ≥1 due работы — red border-left + glow */
.pump-card.is-due {
    border-left: 4px solid #ef4444;
    box-shadow: 0 0 0 1px rgba(239, 68, 68, 0.4), 0 6px 20px rgba(239, 68, 68, 0.18);
}

/* Блок «Работы по наработке» внутри карточки */
.pump-works-block {
    margin: 12px 0 8px;
    padding: 10px 12px;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 8px;
}
.pump-works-title {
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 8px;
    display: flex;
    align-items: center;
    gap: 8px;
}
.pump-works-due-count {
    background: rgba(239, 68, 68, 0.18);
    color: #f87171;
    padding: 2px 8px;
    border-radius: 999px;
    font-size: 0.72rem;
    font-weight: 700;
}
.pump-works-list {
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.pump-no-works {
    color: var(--text-muted);
    font-size: 0.78rem;
    font-style: italic;
    padding: 8px 0;
}

/* Работа: 1 строка — icon + name + counter + progress + label */
.pump-work-row {
    display: grid;
    grid-template-columns: 22px minmax(0, 1fr) auto;
    grid-template-rows: auto auto;
    gap: 2px 8px;
    padding: 6px 8px;
    background: rgba(0, 0, 0, 0.18);
    border-radius: 6px;
    border-left: 3px solid transparent;
    font-size: 0.78rem;
}
.pump-work-icon {
    grid-row: 1 / 3;
    align-self: center;
    font-size: 1rem;
}
.pump-work-name {
    color: var(--text-primary);
    font-weight: 500;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.pump-work-counter {
    color: var(--text-secondary);
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
}
.pump-work-pct {
    color: var(--text-muted);
    font-size: 0.72rem;
    margin-left: 4px;
}
.pump-work-progress {
    grid-column: 2 / 4;
    height: 4px;
    background: rgba(255, 255, 255, 0.05);
    border-radius: 2px;
    overflow: hidden;
    position: relative;
}
.pump-work-progress-fill {
    height: 100%;
    background: #4ade80;
    transition: width 0.2s ease;
}
.pump-work-label {
    display: none; /* label выводится в counter; future expansion */
}
/* Status colors */
.pump-work-ok { border-left-color: #4ade80; }
.pump-work-ok .pump-work-progress-fill { background: #4ade80; }
.pump-work-attn { border-left-color: #60a5fa; }
.pump-work-attn .pump-work-progress-fill { background: #60a5fa; }
.pump-work-warn { border-left-color: #fbbf24; }
.pump-work-warn .pump-work-progress-fill { background: #fbbf24; }
.pump-work-overdue { border-left-color: #ef4444; background: rgba(239, 68, 68, 0.08); }
.pump-work-overdue .pump-work-progress-fill { background: #ef4444; }
.pump-work-overdue .pump-work-counter { color: #f87171; font-weight: 600; }
.pump-work-inactive { opacity: 0.5; border-left-color: var(--text-muted); }
.pump-work-inactive .pump-work-progress-fill { background: var(--text-muted); }

/* Кнопка «Обслужить» — одна большая под works list */
.pump-service-btn {
    margin-top: 10px;
    width: 100%;
    padding: 10px 16px;
    font-size: 0.92rem;
    font-weight: 600;
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.15s ease;
    border: none;
}
.pump-service-btn.is-ok {
    background: transparent;
    color: var(--text-primary);
    border: 1px solid rgba(255, 255, 255, 0.15);
}
.pump-service-btn.is-ok:hover:not(:disabled) {
    background: rgba(255, 255, 255, 0.05);
    border-color: rgba(255, 255, 255, 0.3);
}
.pump-service-btn.is-due {
    background: linear-gradient(135deg, #f97316, #ea580c);
    color: white;
    box-shadow: 0 4px 12px rgba(249, 115, 22, 0.3);
}
.pump-service-btn.is-due:hover:not(:disabled) {
    background: linear-gradient(135deg, #fb923c, #f97316);
    transform: translateY(-1px);
    box-shadow: 0 6px 16px rgba(249, 115, 22, 0.4);
}
.pump-service-btn:disabled {
    opacity: 0.4;
    cursor: not-allowed;
    background: transparent;
    color: var(--text-muted);
    border: 1px dashed rgba(255, 255, 255, 0.15);
}

/* Top banner: «⚠ N работ требуют обслуживания» */
.pump-due-banner {
    background: rgba(239, 68, 68, 0.08);
    border: 1px solid rgba(239, 68, 68, 0.3);
    border-left: 4px solid #ef4444;
    border-radius: 8px;
    padding: 10px 14px;
    margin-bottom: 12px;
    max-height: 220px;
    overflow-y: auto;
}
.pump-due-banner-title {
    font-weight: 600;
    color: #f87171;
    margin-bottom: 6px;
    font-size: 0.9rem;
}
.pump-due-banner-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.pump-due-banner-item {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 4px 6px;
    border-radius: 4px;
    cursor: pointer;
    font-size: 0.78rem;
    color: var(--text-secondary);
    transition: background 0.12s ease;
}
.pump-due-banner-item:hover {
    background: rgba(255, 255, 255, 0.04);
    color: var(--text-primary);
}
.pump-due-banner-icon { font-size: 1rem; }
.pump-due-banner-pump { font-weight: 600; color: var(--text-primary); }
.pump-due-banner-work { color: var(--text-secondary); }
.pump-due-banner-overdue {
    margin-left: auto;
    color: #f87171;
    font-weight: 600;
    font-variant-numeric: tabular-nums;
}
/* Phase 3.5 fix 3: group-by-pump banner — иконки работ + count */
.pump-due-banner-pump-icon { font-size: 1.1rem; }
.pump-due-banner-icons {
    color: var(--text-secondary);
    font-size: 0.95rem;
    letter-spacing: 2px;
}
.pump-due-banner-count {
    color: var(--text-muted);
    font-size: 0.74rem;
    font-style: italic;
}

/* Phase 3.7 (23.05.2026): executor banner с кнопкой «Принять» */
.pump-due-banner-executor {
    margin-bottom: 16px;
}
.pump-due-banner-item-executor {
    cursor: default;
    flex-wrap: wrap;
}
.pump-due-banner-accept-btn {
    margin-left: 8px;
    padding: 4px 14px;
    font-size: 0.82rem;
    font-weight: 600;
    background: linear-gradient(135deg, #f97316, #ea580c);
    color: white;
    border: none;
    border-radius: 6px;
    cursor: pointer;
    transition: all 0.15s ease;
    box-shadow: 0 2px 6px rgba(249, 115, 22, 0.25);
}
.pump-due-banner-accept-btn:hover:not(:disabled) {
    background: linear-gradient(135deg, #fb923c, #f97316);
    transform: translateY(-1px);
    box-shadow: 0 4px 10px rgba(249, 115, 22, 0.35);
}
.pump-due-banner-accept-btn:disabled {
    opacity: 0.4;
    cursor: not-allowed;
    background: transparent;
    color: var(--text-muted);
    border: 1px dashed rgba(255, 255, 255, 0.2);
    box-shadow: none;
}
.pump-due-banner-more {
    color: var(--text-muted);
    font-size: 0.74rem;
    font-style: italic;
    padding: 2px 6px;
}

/* ===== Service modal #modal-pump-service ===== */
.pump-service-info {
    background: rgba(255, 255, 255, 0.04);
    padding: 8px 12px;
    border-radius: 6px;
    margin-bottom: 12px;
    font-size: 0.88rem;
    color: var(--text-secondary);
}
.pump-service-info strong {
    color: var(--text-primary);
    font-variant-numeric: tabular-nums;
}
.pump-service-quick {
    display: flex;
    gap: 8px;
    margin-bottom: 14px;
}
.pump-service-list {
    display: flex;
    flex-direction: column;
    gap: 14px;
}
.pump-service-section {
    background: rgba(255, 255, 255, 0.02);
    border: 1px solid rgba(255, 255, 255, 0.05);
    border-radius: 8px;
    padding: 10px 12px;
}
.pump-service-section-due {
    background: rgba(239, 68, 68, 0.06);
    border-color: rgba(239, 68, 68, 0.25);
}
.pump-service-section-title {
    font-weight: 600;
    font-size: 0.82rem;
    margin-bottom: 10px;
    color: var(--text-primary);
}
.pump-service-section-due .pump-service-section-title {
    color: #f87171;
}
.pump-service-row {
    display: grid;
    grid-template-columns: 24px 28px minmax(0, 1fr);
    gap: 10px;
    padding: 10px 12px;
    margin-bottom: 6px;
    background: rgba(0, 0, 0, 0.18);
    border: 1px solid rgba(255, 255, 255, 0.05);
    border-radius: 6px;
    cursor: pointer;
    transition: all 0.15s ease;
}
.pump-service-row:hover {
    border-color: rgba(255, 255, 255, 0.18);
    background: rgba(0, 0, 0, 0.28);
}
.pump-service-row.is-due {
    border-left: 3px solid #ef4444;
    background: rgba(239, 68, 68, 0.04);
}
.pump-service-row.is-inactive {
    opacity: 0.5;
    cursor: not-allowed;
}
.pump-service-row:has(input:checked) {
    background: rgba(74, 222, 128, 0.08);
    border-color: rgba(74, 222, 128, 0.3);
}
.pump-service-checkbox {
    width: 18px;
    height: 18px;
    accent-color: #4ade80;
    cursor: pointer;
    align-self: center;
}
.pump-service-row-icon {
    font-size: 1.2rem;
    align-self: center;
}
.pump-service-row-main { min-width: 0; }
.pump-service-row-name {
    font-weight: 500;
    color: var(--text-primary);
    margin-bottom: 4px;
}
.pump-service-row-inactive {
    color: var(--text-muted);
    font-size: 0.74rem;
    font-style: italic;
    font-weight: normal;
}
.pump-service-row-progress {
    height: 4px;
    background: rgba(255, 255, 255, 0.06);
    border-radius: 2px;
    overflow: hidden;
    margin-bottom: 5px;
}
.pump-service-row-progress-fill {
    height: 100%;
    background: #4ade80;
    transition: width 0.2s ease;
}
.pump-service-row-progress-fill.overdue {
    background: #ef4444;
}
.pump-service-row-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    font-size: 0.74rem;
    color: var(--text-secondary);
}
.pump-service-row-meta > span {
    white-space: nowrap;
}
.pump-service-row-overdue {
    color: #f87171;
    font-weight: 600;
}
.pump-service-row-last {
    color: var(--text-muted);
}
.pump-service-collision-banner {
    background: rgba(251, 191, 36, 0.1);
    border: 1px solid rgba(251, 191, 36, 0.4);
    border-radius: 6px;
    padding: 8px 12px;
    margin-bottom: 12px;
    color: #fbbf24;
    font-size: 0.84rem;
}

/* ===== Phase 3 (23.05.2026): sidebar badge + pump-edit works CRUD ===== */
/* Red pill в sidebar nav-item — счётчик due работ */
.nav-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 22px;
    height: 18px;
    padding: 0 7px;
    margin-left: auto;
    background: #ef4444;
    color: white;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 700;
    line-height: 1;
    box-shadow: 0 1px 4px rgba(239, 68, 68, 0.5);
    animation: pump-badge-pulse 2s ease-in-out infinite;
}
.nav-badge.hidden {
    display: none !important;
}
@keyframes pump-badge-pulse {
    0%, 100% { box-shadow: 0 1px 4px rgba(239, 68, 68, 0.5); }
    50% { box-shadow: 0 1px 8px rgba(239, 68, 68, 0.8); }
}
@media (prefers-reduced-motion: reduce) {
    .nav-badge { animation: none; }
}

/* Pump-edit modal: секция «Работы по наработке» */
.pump-edit-works-section {
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    padding-top: 16px;
}
.pump-edit-works-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 6px;
    gap: 12px;
    flex-wrap: wrap;
}
.pump-edit-works-header h4 {
    margin: 0;
    font-size: 1rem;
    color: var(--text-primary);
}
.pump-edit-works-hint {
    color: var(--text-muted);
    font-size: 0.78rem;
    margin-bottom: 12px;
    font-style: italic;
}
.pump-edit-works-empty {
    color: var(--text-muted);
    font-size: 0.84rem;
    text-align: center;
    padding: 16px;
    border: 1px dashed rgba(255, 255, 255, 0.1);
    border-radius: 6px;
    background: rgba(0, 0, 0, 0.12);
}

/* Editable row для одной работы — компактный grid */
.pump-edit-work-row {
    background: rgba(0, 0, 0, 0.2);
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 6px;
    padding: 8px 10px;
    margin-bottom: 8px;
}
/* 2-row layout, не overflow в modal-large (720px max).
   Row 1: icon (44px) + name (1fr) + delete (auto) — основная identification.
   Row 2: norma + lastHours + lastDate + active + oil-radio (flex-wrap) — параметры. */
.pump-edit-work-grid {
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.pump-edit-work-row-top {
    display: grid;
    grid-template-columns: 44px minmax(0, 1fr) auto;
    gap: 8px;
    align-items: center;
}
.pump-edit-work-row-bottom {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
    padding-left: 52px; /* align с icon в row-top */
}
.pump-edit-work-field {
    display: flex;
    flex-direction: column;
    gap: 2px;
    font-size: 0.72rem;
    color: var(--text-muted);
}
.pump-edit-work-field input {
    font-size: 0.85rem;
}
.pump-edit-work-icon-in {
    text-align: center;
    font-size: 1.1rem;
    padding: 6px 4px !important;
}
.pump-edit-work-name-in {
    padding: 6px 8px !important;
}
.pump-edit-work-norm-in,
.pump-edit-work-last-h-in {
    padding: 5px 8px !important;
    font-variant-numeric: tabular-nums;
    width: 90px;
}
.pump-edit-work-last-date-in {
    padding: 5px 8px !important;
    color-scheme: dark;
    width: 140px;
}
.pump-edit-work-active-label,
.pump-edit-work-oil-label {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 0.78rem;
    color: var(--text-secondary);
    white-space: nowrap;
    cursor: pointer;
    user-select: none;
    padding: 4px 8px;
    background: rgba(255, 255, 255, 0.04);
    border-radius: 4px;
}
.pump-edit-work-active-label input,
.pump-edit-work-oil-label input {
    cursor: pointer;
}
.pump-edit-work-delete-btn {
    background: transparent;
    border: 1px solid rgba(239, 68, 68, 0.35);
    color: #f87171;
    border-radius: 4px;
    padding: 6px 10px;
    font-size: 1rem;
    cursor: pointer;
    transition: all 0.15s ease;
}
.pump-edit-work-delete-btn:hover {
    background: rgba(239, 68, 68, 0.15);
    border-color: rgba(239, 68, 68, 0.6);
}
@media (max-width: 720px) {
    .pump-edit-work-row-bottom {
        padding-left: 0;
    }
}

/* btn-small — small inline buttons (если ещё не определён) */
.btn-small {
    padding: 4px 10px !important;
    font-size: 0.78rem !important;
}

@media (max-width: 900px) {
    .pumps-grid {
        grid-template-columns: 1fr;
    }

    .pumps-header {
        flex-direction: column;
        align-items: stretch;
    }
}

/* ===== AUDIT_11 N37: универсальное :focus-visible для интерактивных элементов ===== */
/* Keyboard-юзер должен ясно видеть, где фокус. Mouse-клик не показывает outline благодаря :focus-visible. */
button:focus-visible,
.btn:focus-visible,
.task-card:focus-visible,
.task-status-badge:focus-visible,
.kanban-card:focus-visible,
.eto-zone:focus-visible,
.regulation-card:focus-visible,
.pump-card:focus-visible,
.input-field:focus-visible,
input[type="text"]:focus-visible,
input[type="number"]:focus-visible,
input[type="password"]:focus-visible,
input[type="date"]:focus-visible,
select:focus-visible,
textarea:focus-visible,
[role="button"]:focus-visible,
[tabindex]:not([tabindex="-1"]):focus-visible {
    outline: 2px solid var(--accent-blue);
    outline-offset: 2px;
}

/* ===== AUDIT_11 N38: @media print — сохранить цвета статусов и категорий при печати ===== */
@media print {
    .task-status-badge,
    .task-detail-status,
    .kanban-card,
    .audit-action-badge,
    .reg-row-done,
    .reg-row-notdone,
    .reg-category-section,
    .cat-badge {
        -webkit-print-color-adjust: exact;
        print-color-adjust: exact;
    }
    /* Скрыть служебные элементы при печати — индикатор SSE, баннеры, тосты */
    #sse-status, #sse-disconnect-banner, #sync-indicator, .sync-error-toast, .sidebar {
        display: none !important;
    }
}

/* 03.05: Ctrl+P из открытой detail-modal ЕТО — структурированная печать вместо
   плоской копии viewport. Двойной триггер: `:has()` (Chrome 105+/Firefox 121+/Safari 15.4+)
   и body.printing-eto-detail (старые браузеры — выставляется через beforeprint event
   в IIFE в mixing-eto.js). Кнопка «🖨️ Печать» в шапке модалки открывает popup
   с тем же layout (printEtoDetail) — backup-путь если @media print не сработала. */
@media print {
    /* При открытой ETO detail-modal — скрываем основной UI */
    body:has(#modal-task:not(.hidden) .eto-detail) > *:not(#modal-overlay),
    body.printing-eto-detail > *:not(#modal-overlay) {
        display: none !important;
    }
    /* Overlay из fixed/centered → static document flow, белый фон */
    body:has(#modal-task:not(.hidden) .eto-detail) #modal-overlay,
    body.printing-eto-detail #modal-overlay {
        position: static !important;
        background: #fff !important;
        display: block !important;
        padding: 0 !important;
        height: auto !important;
        width: auto !important;
        z-index: auto !important;
    }
    /* Скрыть остальные модалки (на случай если какая-то ещё открыта) */
    body:has(#modal-task:not(.hidden) .eto-detail) #modal-overlay > .modal:not(#modal-task),
    body.printing-eto-detail #modal-overlay > .modal:not(#modal-task) {
        display: none !important;
    }
    body:has(#modal-task:not(.hidden) .eto-detail) #modal-task,
    body.printing-eto-detail #modal-task {
        position: static !important;
        max-width: none !important;
        max-height: none !important;
        width: 100% !important;
        height: auto !important;
        margin: 0 !important;
        padding: 0 !important;
        box-shadow: none !important;
        background: #fff !important;
        color: #000 !important;
        transform: none !important;
        border: none !important;
        border-radius: 0 !important;
        overflow: visible !important;
    }
    body:has(#modal-task:not(.hidden) .eto-detail) #modal-task .modal-header,
    body.printing-eto-detail #modal-task .modal-header {
        background: #fff !important;
        color: #111 !important;
        border-bottom: 2px solid #111 !important;
        padding: 0 0 8px 0 !important;
        margin-bottom: 12px !important;
    }
    body:has(#modal-task:not(.hidden) .eto-detail) #modal-task .modal-header h3,
    body.printing-eto-detail #modal-task .modal-header h3 {
        color: #111 !important;
        font-size: 18px !important;
    }
    body:has(#modal-task:not(.hidden) .eto-detail) #modal-task .modal-body,
    body.printing-eto-detail #modal-task .modal-body {
        padding: 0 !important;
        max-height: none !important;
        overflow: visible !important;
        background: #fff !important;
        color: #000 !important;
    }
    /* Скрыть интерактивные элементы — close-кнопка, печать button */
    body:has(.eto-detail) .modal-close,
    body:has(.eto-detail) .eto-detail-print-btn,
    body.printing-eto-detail .modal-close,
    body.printing-eto-detail .eto-detail-print-btn {
        display: none !important;
    }

    /* Header detail — белый, чёрный текст, читаемые pill-блоки */
    .eto-detail-header {
        background: #f3f4f6 !important;
        color: #111 !important;
        padding: 8px 12px !important;
        border-radius: 6px !important;
        gap: 12px !important;
        flex-wrap: wrap !important;
        page-break-inside: avoid;
    }
    .eto-detail-header > span {
        background: #fff !important;
        padding: 4px 10px !important;
        border-radius: 4px !important;
        border: 1px solid #d1d5db !important;
    }
    .eto-detail-progress {
        background: #fef9c3 !important;
        color: #111 !important;
        padding: 10px 14px !important;
        border-radius: 6px !important;
        margin-bottom: 10px !important;
        page-break-inside: avoid;
    }
    .eto-detail-correction-link {
        background: #e0e7ff !important;
        color: #312e81 !important;
        padding: 8px 12px !important;
        page-break-inside: avoid;
    }
    .eto-detail-correction-link a { color: #1e40af !important; }
    .eto-detail-comment {
        background: #fef3c7 !important;
        color: #451a03 !important;
        padding: 10px 14px !important;
        border-radius: 6px !important;
        page-break-inside: avoid;
    }

    /* 3 цветные секции — обязательно цветные при печати */
    .eto-detail-section {
        page-break-inside: avoid;
        margin: 12px 0 !important;
        padding: 10px 14px !important;
        border-radius: 6px !important;
        border-left-width: 4px !important;
        border-left-style: solid !important;
        -webkit-print-color-adjust: exact;
        print-color-adjust: exact;
    }
    .eto-detail-section-notdone {
        background: #fef2f2 !important;
        border-left-color: #ef4444 !important;
    }
    .eto-detail-section-skipped {
        background: #fffbeb !important;
        border-left-color: #f59e0b !important;
    }
    .eto-detail-section-done {
        background: #f0fdf4 !important;
        border-left-color: #10b981 !important;
    }
    .eto-detail-section-deleted {
        background: #f3f4f6 !important;
        border-left-color: #9ca3af !important;
    }
    .eto-detail-section-title {
        color: #111 !important;
        margin: 0 0 8px 0 !important;
        font-size: 14px !important;
        font-weight: 700 !important;
    }
    .eto-detail-section-count {
        color: #4b5563 !important;
        font-weight: 400 !important;
        margin-left: 4px !important;
    }

    /* Зоны как блоки внутри секций */
    .eto-detail-zone {
        page-break-inside: avoid;
        margin: 8px 0 !important;
        background: #fff !important;
        border-radius: 4px !important;
    }
    .eto-detail-zone-title {
        background: #e2e8f0 !important;
        color: #0f172a !important;
        padding: 6px 10px !important;
        border-radius: 4px !important;
        font-weight: 600 !important;
        margin-bottom: 4px !important;
    }
    .eto-detail-item {
        page-break-inside: avoid;
        padding: 6px 10px !important;
        border-bottom: 1px solid #e5e7eb !important;
        background: #fff !important;
        color: #111 !important;
        gap: 8px !important;
    }
    .eto-detail-equip {
        font-weight: 600 !important;
        color: #111 !important;
        min-width: auto !important;
    }
    .eto-detail-ops {
        color: #4b5563 !important;
    }
    .eto-detail-skip-reason {
        background: #fef3c7 !important;
        color: #92400e !important;
        margin-top: 4px !important;
        padding: 4px 8px !important;
        border-radius: 3px !important;
        font-size: 11.5px !important;
        page-break-inside: avoid;
    }
    .eto-detail-deleted .eto-detail-equip {
        color: #6b7280 !important;
        font-style: italic !important;
    }

    @page { margin: 12mm; }
}

/* AUDIT_14 E49: WCAG 2.3.3 — vestibular-disorder триггеры. Гасим infinite-pulse'ы и
   slide-in'ы для пользователей с prefers-reduced-motion. Симметрия packing.css. */
@media (prefers-reduced-motion: reduce) {
    .stat-overdue.pulse,
    .pump-status-dot.danger,
    .sse-status.sse-connecting .sse-dot,
    .sse-disconnect-banner,
    .task-card.loading::after {
        animation: none !important;
    }
}

/* AUDIT_14 E4 (хвост): универсальный close-button для всех toast'ов (renderToast). */
.toast-close {
    background: transparent;
    border: none;
    color: inherit;
    font-size: 22px;
    line-height: 1;
    cursor: pointer;
    padding: 0 4px;
    margin-left: auto;
    opacity: 0.85;
}
.toast-close:hover { opacity: 1; }
.toast-close:focus-visible { outline: 2px solid #fbbf24; outline-offset: 2px; border-radius: 4px; }

/* === Центрированный toast Mixing (mixCenterToast, зеркало .ewo-center-toast) ===
   Один тост на экране, новый вытесняет старый. Полноэкранный dim-overlay. */
.mix-center-toast {
    position: fixed;
    inset: 0;
    z-index: 100000;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(0, 0, 0, 0.4);
    padding: 20px;
    animation: mix-center-toast-fade-in 0.18s ease;
}
.mix-center-toast-leaving {
    animation: mix-center-toast-fade-out 0.2s ease forwards;
}
@keyframes mix-center-toast-fade-in {
    from { opacity: 0; }
    to { opacity: 1; }
}
@keyframes mix-center-toast-fade-out {
    from { opacity: 1; }
    to { opacity: 0; }
}
.mix-center-toast-msg {
    position: relative;
    max-width: 540px;
    padding: 24px 56px 24px 28px;
    border-radius: 14px;
    font-size: 17px;
    font-weight: 600;
    line-height: 1.45;
    color: #fff;
    box-shadow: 0 16px 60px rgba(0, 0, 0, 0.5), 0 0 0 1px rgba(255, 255, 255, 0.12);
    text-align: center;
    white-space: pre-wrap;
    overflow-wrap: anywhere;
    animation: mix-center-toast-pop 0.22s ease;
}
@keyframes mix-center-toast-pop {
    from { opacity: 0; transform: translateY(20px) scale(0.95); }
    to { opacity: 1; transform: translateY(0) scale(1); }
}
.mix-center-toast-success .mix-center-toast-msg { background: linear-gradient(135deg, #10b981, #059669); }
.mix-center-toast-warning .mix-center-toast-msg { background: linear-gradient(135deg, #f59e0b, #d97706); }
.mix-center-toast-error   .mix-center-toast-msg { background: linear-gradient(135deg, #ef4444, #dc2626); }
.mix-center-toast-info    .mix-center-toast-msg { background: linear-gradient(135deg, #3b82f6, #2563eb); }
.mix-center-toast-close {
    position: absolute;
    top: 8px;
    right: 12px;
    width: 32px;
    height: 32px;
    border: none;
    background: rgba(255, 255, 255, 0.18);
    color: #fff;
    font-size: 22px;
    line-height: 1;
    border-radius: 50%;
    cursor: pointer;
    font-family: inherit;
    display: flex;
    align-items: center;
    justify-content: center;
}
.mix-center-toast-close:hover { background: rgba(255, 255, 255, 0.35); }
@media (prefers-reduced-motion: reduce) {
    .mix-center-toast,
    .mix-center-toast-msg { animation: none; }
}
@media (max-width: 768px) {
    .mix-center-toast-msg { font-size: 16px; padding: 20px 48px 20px 22px; }
}

/* Sprint 13E U24: inline field-error (WCAG 3.3.1). Показывается рядом с input
   через showFieldError(input, msg) из core-utils.js. Также input получает
   aria-invalid="true" + aria-describedby — паттерн стандартный для screen-readers.
   Auto-clear на первом input/change событии. */
.field-error {
    display: block;
    margin: 4px 0 0 0;
    padding: 4px 8px;
    background: rgba(239, 68, 68, 0.12);
    border-left: 3px solid #ef4444;
    color: #fca5a5;
    font-size: 12px;
    border-radius: 0 4px 4px 0;
    line-height: 1.3;
}
[aria-invalid="true"] {
    border-color: #ef4444 !important;
    box-shadow: 0 0 0 1px #ef4444;
}

/* AUDIT_14 E75: skip-to-main link. По умолчанию visually-hidden, на focus — видимый
   баннер сверху страницы. WCAG 2.4.1 (Bypass Blocks). */
.skip-link {
    position: absolute;
    left: -9999px;
    top: 0;
    z-index: 100001;
    padding: 8px 16px;
    background: #2563eb;
    color: #fff;
    text-decoration: none;
    border-radius: 0 0 8px 0;
    font-size: 14px;
    font-weight: 600;
}
.skip-link:focus {
    left: 0;
    outline: 3px solid #fbbf24;
    outline-offset: 2px;
}

/* ===== ЕЖЕСМЕННОЕ ЗАДАНИЕ ЕТО — баннер панели исполнителя + модал выполнения ===== */
.eto-shift-banner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    flex-wrap: wrap;
    padding: 14px 18px;
    margin-bottom: 16px;
    border-radius: 12px;
    border: 1px solid var(--border-color);
    background: var(--bg-secondary);
}
.eto-shift-banner-open   { border-color: #f59e0b; background: rgba(245, 158, 11, 0.10); }
.eto-shift-banner-inwork { border-color: #3b82f6; background: rgba(59, 130, 246, 0.10); }
.eto-shift-banner-done   { border-color: #22c55e; background: rgba(34, 197, 94, 0.10); }
.eto-shift-banner-failed { border-color: #ef4444; background: rgba(239, 68, 68, 0.10); }
.eto-shift-banner-main { display: flex; align-items: center; gap: 12px; min-width: 0; }
.eto-shift-banner-icon { font-size: 1.7rem; flex-shrink: 0; }
.eto-shift-banner-text { min-width: 0; }
.eto-shift-banner-title { font-size: 1rem; font-weight: 700; color: var(--text-primary); }
.eto-shift-banner-sub { font-size: 0.82rem; color: var(--text-secondary); margin-top: 2px; }
.eto-shift-banner-right { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.eto-shift-countdown { font-size: 0.82rem; }

/* Модал #modal-eto-shift переиспользует .complete-v2 / .tdv2-* (V2 2-панельный).
   Расширение/sticky-зоны — отдельный скоуп по #modal-eto-shift (симметрия с #modal-complete). */
.modal-container:has(#modal-eto-shift:not(.hidden) .complete-v2) {
    max-width: min(960px, 95vw);
}
#modal-eto-shift:not(.hidden):has(.complete-v2) {
    display: flex;
    flex-direction: column;
    height: 88vh;
    overflow: hidden;
}
#modal-eto-shift:not(.hidden):has(.complete-v2) > .modal-header,
#modal-eto-shift:not(.hidden):has(.complete-v2) > .modal-footer {
    flex-shrink: 0;
}
#modal-eto-shift:not(.hidden):has(.complete-v2) > .modal-body {
    flex: 1;
    min-height: 0;
    overflow: hidden;
    padding: 0;
}

/* Пункт чек-листа ЕТО — 3 состояния: без отметки / выполнено / пропущено */
.etotask-item {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 8px;
    padding: 9px 11px;
    margin: 4px 0;
    border: 1px solid var(--border-color);
    border-radius: 8px;
    background: var(--bg-tertiary);
    font-size: 0.88rem;
    line-height: 1.4;
}
.etotask-item.checked { border-color: #22c55e; background: rgba(34, 197, 94, 0.10); }
.etotask-item.skipped { border-color: #ef4444; background: rgba(239, 68, 68, 0.08); }
.etotask-item-main { flex: 1; display: flex; align-items: flex-start; gap: 10px; cursor: pointer; min-width: 0; }
.etotask-item-check {
    flex-shrink: 0;
    width: 22px;
    height: 22px;
    border-radius: 6px;
    border: 1px solid var(--border-color);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.8rem;
    background: var(--bg-secondary);
}
.etotask-item.checked .etotask-item-check { background: #22c55e; border-color: #22c55e; color: #fff; }
.etotask-item-text { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.etotask-item-equip { font-weight: 600; color: var(--text-primary); word-break: break-word; }
.etotask-item-ops { font-size: 0.8rem; color: var(--text-muted); word-break: break-word; }
.etotask-skip-btn {
    flex-shrink: 0;
    padding: 4px 9px;
    border-radius: 6px;
    border: 1px solid var(--border-color);
    background: var(--bg-secondary);
    cursor: pointer;
    font-size: 0.85rem;
    transition: var(--transition);
}
.etotask-skip-btn:hover { border-color: #ef4444; }
.etotask-skip-btn.on { border-color: #ef4444; background: rgba(239, 68, 68, 0.18); }
.etotask-skip-reason {
    flex-basis: 100%;
    width: 100%;
    box-sizing: border-box;
    margin-top: 4px;
    padding: 7px 9px;
    border-radius: 6px;
    border: 1px solid #ef4444;
    background: var(--bg-secondary);
    color: var(--text-primary);
    font-size: 0.82rem;
}
.etotask-skip-reason:focus { outline: none; border-color: #f87171; }

/* Боковая вкладка ЕТО в server-mode — только регламент: прячем UI свободной сдачи. */
.eto-regulation-only .eto-footer,
.eto-regulation-only .eto-shift-bar,
.eto-regulation-only .eto-checkbox,
.eto-regulation-only .eto-skip-btn,
.eto-regulation-only .eto-skip-reason-row,
.eto-regulation-only .js-eto-mark-all { display: none; }
.eto-regulation-only .eto-item { cursor: default; }

/* История ЕТО — авто-просроченная запись (notDone). */
.eto-notdone-badge {
    display: inline-block;
    padding: 1px 7px;
    border-radius: 10px;
    background: rgba(239, 68, 68, 0.18);
    color: #ef4444;
    font-size: 0.72rem;
    font-weight: 700;
    white-space: nowrap;
}
.eto-history-row-notdone { background: rgba(239, 68, 68, 0.06); }

/* Модал «Детали ЕТО» (2-панельный V2) — read-only пункт записи истории */
.etodet-item {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 9px 11px;
    margin: 4px 0;
    border: 1px solid var(--border-color);
    border-radius: 8px;
    background: var(--bg-tertiary);
    font-size: 0.88rem;
    line-height: 1.4;
}
.etodet-item.etodet-done { border-left: 3px solid #22c55e; }
.etodet-item.etodet-skipped { border-left: 3px solid #ef4444; }
.etodet-item.etodet-notdone { border-left: 3px solid #6e7681; }
.etodet-item-icon { flex-shrink: 0; font-size: 1rem; }
.etodet-item-text { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.etodet-item-equip { font-weight: 600; color: var(--text-primary); word-break: break-word; }
.etodet-item-ops { font-size: 0.8rem; color: var(--text-muted); word-break: break-word; }
.etodet-item-reason { font-size: 0.8rem; color: #f59e0b; word-break: break-word; margin-top: 2px; }
.etodet-notdone-banner {
    flex-shrink: 0;
    margin: 0 20px 10px;
    padding: 8px 12px;
    background: rgba(239, 68, 68, 0.12);
    border: 1px solid #ef4444;
    border-radius: 8px;
    color: #ef4444;
    font-size: 0.85rem;
    font-weight: 600;
}

/* Модал выполнения задания — 3-е состояние операции «не выполнено» (UI-отметка) */
.tdv2-op-main { flex: 1; display: flex; align-items: flex-start; gap: 10px; cursor: pointer; min-width: 0; }
.tdv2-op-skip {
    flex-shrink: 0;
    align-self: center;
    padding: 3px 8px;
    border-radius: 6px;
    border: 1px solid var(--border-color);
    background: var(--bg-secondary);
    cursor: pointer;
    font-size: 0.82rem;
    transition: var(--transition);
}
.tdv2-op-skip:hover { border-color: #ef4444; }
.tdv2-op-skip.on { border-color: #ef4444; background: rgba(239, 68, 68, 0.18); }

/* ===== 24.05.2026 Batch B Phase 4: динамические смены CRUD ===== */
.shifts-list { display: flex; flex-direction: column; gap: 6px; }
.shifts-row {
    display: grid;
    grid-template-columns: 32px 1fr 28px 80px auto;
    align-items: center;
    gap: 12px;
    padding: 8px 12px;
    background: rgba(255,255,255,0.04);
    border: 1px solid var(--border-color, #30363d);
    border-radius: 8px;
    transition: background 0.15s, border-color 0.15s;
}
.shifts-row:hover { background: rgba(255,255,255,0.07); border-color: rgba(255,255,255,0.18); }
.shifts-row-icon { font-size: 22px; line-height: 1; text-align: center; }
.shifts-row-name { font-weight: 600; color: var(--text-primary, #e2e8f0); }
.shifts-row-swatch { display: inline-block; width: 28px; height: 22px; border-radius: 5px; border: 1px solid rgba(255,255,255,0.18); }
.shifts-row-color-hex { font-family: monospace; font-size: 11px; color: var(--text-muted, #94a3b8); }
.shifts-row-actions { display: flex; gap: 4px; }
.shifts-row-actions .btn-sm { padding: 4px 8px; font-size: 12px; line-height: 1.2; }

.shift-color-presets { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 6px; }
.shift-color-preset {
    width: 28px; height: 28px;
    border-radius: 6px;
    border: 2px solid transparent;
    cursor: pointer;
    transition: transform 0.1s, border-color 0.1s;
}
.shift-color-preset:hover { transform: scale(1.1); }
.shift-color-preset.selected { border-color: #fff; box-shadow: 0 0 0 2px rgba(255,255,255,0.3); }

.shift-icon-picker {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 6px;
}
.shift-icon-option {
    aspect-ratio: 1;
    font-size: 22px;
    background: rgba(255,255,255,0.04);
    border: 2px solid transparent;
    border-radius: 8px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.1s, border-color 0.1s;
}
.shift-icon-option:hover { background: rgba(255,255,255,0.1); }
.shift-icon-option.selected { border-color: var(--accent-blue, #3b82f6); background: rgba(59,130,246,0.15); }

/* ===== 24.05.2026 Batch O3: Orphan-shifts section в Settings ===== */
.shifts-orphan-section {
    background: rgba(245, 158, 11, 0.06);
    border: 1px solid rgba(245, 158, 11, 0.35);
    border-radius: 10px;
    padding: 12px 14px;
}
.shifts-orphan-header {
    margin-bottom: 10px;
    padding-bottom: 8px;
    border-bottom: 1px dashed rgba(245, 158, 11, 0.25);
}
.shifts-orphan-header h4 {
    color: #fbbf24;
    font-weight: 700;
}
.shifts-orphan-row {
    display: grid;
    grid-template-columns: 28px 1fr auto auto;
    align-items: center;
    gap: 12px;
    padding: 8px 10px;
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(245, 158, 11, 0.2);
    border-radius: 8px;
    margin-top: 6px;
    transition: background 0.15s, border-color 0.15s;
}
.shifts-orphan-row:hover {
    background: rgba(255,255,255,0.06);
    border-color: rgba(245, 158, 11, 0.45);
}
.shifts-orphan-icon {
    font-size: 18px;
    line-height: 1;
    text-align: center;
    color: #f59e0b;
}
.shifts-orphan-name {
    font-weight: 600;
    color: var(--text-primary, #e2e8f0);
}
.shifts-orphan-count {
    font-size: 12px;
    color: var(--text-muted, #94a3b8);
    font-family: monospace;
    white-space: nowrap;
}
.shifts-orphan-btn-reassign {
    padding: 5px 12px;
    font-size: 12px;
    line-height: 1.2;
    white-space: nowrap;
}
@media (max-width: 640px) {
    .shifts-orphan-row {
        grid-template-columns: 28px 1fr;
        grid-template-rows: auto auto auto;
    }
    .shifts-orphan-count { grid-column: 2; }
    .shifts-orphan-btn-reassign { grid-column: 1 / -1; justify-self: stretch; }
}

.tdv2-op.notdone { border-color: #ef4444; background: rgba(239, 68, 68, 0.08); }

/* ===== Session 3 T3.4 (25.05.2026): QR оборудования (Settings tab, manager-only) ===== */
.qr-panel {
    /* Полная ширина main content area — на широких мониторах больше плиток per row */
    max-width: none;
    margin: 0;
    padding: 20px 24px;
}
.qr-panel-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 16px;
    margin-bottom: 16px;
    flex-wrap: wrap;
}
.qr-panel-title h2 {
    margin: 0 0 4px 0;
    font-size: 22px;
    font-weight: 700;
    color: var(--text-primary, #f1f5f9);
}
.qr-panel-subtitle {
    font-size: 13px;
    color: var(--text-muted, #94a3b8);
    line-height: 1.5;
}
.qr-panel-actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}
.qr-panel-footer {
    margin-top: 24px;
    padding: 12px 16px;
    background: rgba(99, 102, 241, 0.06);
    border: 1px solid rgba(148, 163, 184, 0.16);
    border-radius: 10px;
    font-size: 12px;
    color: var(--text-muted, #94a3b8);
    text-align: center;
}
.qr-base-url {
    padding: 10px 14px;
    background: rgba(99, 102, 241, 0.08);
    border: 1px solid rgba(99, 102, 241, 0.24);
    border-radius: 10px;
    font-size: 13px;
    margin-bottom: 14px;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px 14px;
}
.qr-base-url code {
    font-family: 'Consolas', 'Monaco', monospace;
    background: rgba(15, 23, 42, 0.4);
    padding: 2px 8px;
    border-radius: 4px;
    color: #818cf8;
    font-size: 12px;
}
.qr-base-url-hint {
    color: var(--text-muted, #94a3b8);
    font-size: 11px;
}
/* Master QR цеха (Фаза 7A) — indigo/amber акцент, отличает от тайлов оборудования */
.qr-master-section {
    display: flex;
    align-items: center;
    gap: 18px;
    margin-bottom: 18px;
    padding: 18px 20px;
    background: linear-gradient(135deg, rgba(99,102,241,0.10) 0%, rgba(30,27,75,0.18) 100%);
    border: 2px solid rgba(99,102,241,0.4);
    border-radius: 14px;
}
.qr-master-section.qr-master-empty { border-style: dashed; border-color: rgba(99,102,241,0.3); }
.qr-master-info { flex: 1; min-width: 0; }
.qr-master-title { font-size: 16px; font-weight: 700; color: #c7d2fe; margin: 0 0 4px; }
.qr-master-hint { font-size: 12px; color: var(--text-muted, #94a3b8); margin: 0 0 10px; line-height: 1.5; }
.qr-master-meta { font-size: 12px; color: var(--text-secondary, #cbd5e1); margin-bottom: 12px; display: flex; flex-wrap: wrap; gap: 4px 10px; align-items: center; }
.qr-master-meta code { background: rgba(99,102,241,0.18); padding: 2px 8px; border-radius: 6px; color: #c7d2fe; font-weight: 600; }
.qr-master-url { color: var(--text-muted, #94a3b8); overflow-wrap: anywhere; }
.qr-master-actions { display: flex; flex-wrap: wrap; gap: 8px; }
.qr-master-create-btn { font-size: 13px; }
.qr-master-preview { flex-shrink: 0; width: 130px; height: 130px; background: #fff; border-radius: 10px; padding: 8px; display: flex; align-items: center; justify-content: center; }
.qr-master-preview svg { width: 100%; height: 100%; display: block; }
@media (max-width: 620px) {
    .qr-master-section { flex-direction: column-reverse; align-items: stretch; }
    .qr-master-preview { align-self: center; }
}
.qr-search-wrap {
    position: relative;
    margin-bottom: 16px;
    max-width: 480px;
}
.qr-search-input {
    width: 100%;
    padding: 10px 36px 10px 14px;
    background: rgba(30, 41, 59, 0.6);
    border: 1px solid rgba(148, 163, 184, 0.2);
    border-radius: 10px;
    color: var(--text-primary, #f1f5f9);
    font-size: 14px;
    font-family: inherit;
    transition: border-color 0.2s;
}
.qr-search-input:focus-visible {
    outline: none;
    border-color: rgba(99, 102, 241, 0.5);
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.15);
}
.qr-search-clear {
    position: absolute;
    right: 8px;
    top: 50%;
    transform: translateY(-50%);
    background: transparent;
    border: none;
    color: var(--text-muted, #94a3b8);
    cursor: pointer;
    font-size: 14px;
    width: 24px;
    height: 24px;
    border-radius: 4px;
    transition: background 0.2s, color 0.2s;
}
.qr-search-clear:hover { background: rgba(148, 163, 184, 0.12); color: var(--text-primary, #f1f5f9); }
.qr-section {
    margin-bottom: 20px;
    background: rgba(30, 41, 59, 0.5);
    border: 1px solid rgba(148, 163, 184, 0.16);
    border-radius: 12px;
    overflow: hidden;
}
.qr-section-title {
    margin: 0;
    padding: 12px 16px;
    background: rgba(15, 23, 42, 0.5);
    font-size: 13px;
    font-weight: 600;
    color: var(--text-secondary, #cbd5e1);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    border-bottom: 1px solid rgba(148, 163, 184, 0.12);
    display: flex;
    justify-content: space-between;
    align-items: baseline;
}
.qr-section-count {
    font-size: 12px;
    color: var(--text-muted, #94a3b8);
    text-transform: none;
    letter-spacing: 0;
    font-variant-numeric: tabular-nums;
}
.qr-section-orphans .qr-section-title { background: rgba(245, 158, 11, 0.08); color: #fbbf24; }
.qr-orphan-hint {
    padding: 8px 16px;
    font-size: 12px;
    color: #fcd34d;
    background: rgba(245, 158, 11, 0.04);
    border-bottom: 1px solid rgba(245, 158, 11, 0.16);
}
/* Compact tile grid (25.05.2026 UX rev) — replaces full-width rows для visual scannability */
.qr-tiles-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
    gap: 10px;
    padding: 12px;
}
.qr-tile {
    position: relative;
    background: rgba(15, 23, 42, 0.5);
    border: 1px solid rgba(148, 163, 184, 0.14);
    border-radius: 12px;
    padding: 10px 10px 8px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    transition: border-color 0.15s, background 0.15s, transform 0.15s;
}
.qr-tile:hover {
    border-color: rgba(99, 102, 241, 0.32);
    background: rgba(99, 102, 241, 0.06);
    transform: translateY(-1px);
}
.qr-tile.qr-tile-selected {
    border-color: rgba(99, 102, 241, 0.5);
    background: rgba(99, 102, 241, 0.10);
    box-shadow: 0 0 0 2px rgba(99, 102, 241, 0.15);
}
.qr-tile.qr-tile-empty {
    background: rgba(15, 23, 42, 0.3);
    border-style: dashed;
}
.qr-tile.qr-tile-orphan {
    background: rgba(245, 158, 11, 0.06);
    border-color: rgba(245, 158, 11, 0.32);
}
.qr-tile-checkbox {
    position: absolute;
    top: 8px;
    left: 8px;
    z-index: 2;
}
.qr-tile-checkbox input[type="checkbox"] {
    width: 16px; height: 16px;
    accent-color: #6366f1;
    cursor: pointer;
    margin: 0;
}
.qr-tile-name {
    display: flex;
    align-items: flex-start;
    gap: 6px;
    font-size: 12px;
    font-weight: 600;
    color: var(--text-primary, #f1f5f9);
    line-height: 1.3;
    min-height: 32px;
    padding-left: 22px; /* leave room for checkbox */
}
.qr-tile-empty .qr-tile-name,
.qr-tile-orphan .qr-tile-name {
    padding-left: 0;  /* no checkbox in empty/orphan tiles */
}
.qr-tile-icon { font-size: 14px; flex-shrink: 0; line-height: 1.2; }
.qr-tile-text {
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    word-break: break-word;
}
.qr-tile-preview {
    width: 100%;
    aspect-ratio: 1 / 1;
    background: #ffffff;
    border-radius: 6px;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}
.qr-tile-preview svg { display: block; width: 100%; height: 100%; }
.qr-tile-preview-empty {
    background: rgba(148, 163, 184, 0.06);
    color: var(--text-dim, #64748b);
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    border: 1px dashed rgba(148, 163, 184, 0.2);
}
.qr-tile-orphan .qr-tile-preview-empty {
    background: rgba(245, 158, 11, 0.04);
    color: #fbbf24;
}
.qr-preview-loading {
    width: 60%; height: 60%;
    background: rgba(99, 102, 241, 0.12);
    border-radius: 6px;
    animation: qrPreviewPulse 1.4s ease-in-out infinite;
}
.qr-preview-error {
    color: #ef4444;
    font-size: 24px;
}
@keyframes qrPreviewPulse {
    0%, 100% { opacity: 0.5; }
    50% { opacity: 0.9; }
}
.qr-tile-code {
    text-align: center;
}
.qr-tile-code code {
    font-family: 'Consolas', 'Monaco', monospace;
    background: rgba(15, 23, 42, 0.6);
    padding: 2px 8px;
    border-radius: 4px;
    color: #818cf8;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.04em;
}
.qr-tile-actions {
    display: flex;
    gap: 3px;
    justify-content: center;
    flex-wrap: wrap;
}
.qr-tile-actions .qr-btn {
    padding: 5px 7px;
    font-size: 11px;
    min-width: 28px;
    justify-content: center;
}
.qr-tile-create-btn {
    margin-top: auto;
    font-size: 12px;
    padding: 7px 10px;
}
.qr-btn {
    background: rgba(99, 102, 241, 0.12);
    border: 1px solid rgba(99, 102, 241, 0.24);
    color: var(--text-secondary, #cbd5e1);
    border-radius: 8px;
    padding: 8px 14px;
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s;
    font-family: inherit;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    line-height: 1;
}
.qr-btn:hover { background: rgba(99, 102, 241, 0.2); border-color: rgba(99, 102, 241, 0.4); color: var(--text-primary, #f1f5f9); }
.qr-btn:focus-visible {
    outline: none;
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.3);
}
.qr-btn-small { padding: 6px 10px; font-size: 12px; }
.qr-btn-primary {
    background: linear-gradient(135deg, #6366f1, #818cf8);
    border-color: rgba(129, 140, 248, 0.4);
    color: #ffffff;
}
.qr-btn-primary:hover { background: linear-gradient(135deg, #4f46e5, #6366f1); color: #ffffff; }
.qr-btn-danger {
    background: rgba(239, 68, 68, 0.10);
    border-color: rgba(239, 68, 68, 0.32);
    color: #fca5a5;
}
.qr-btn-danger:hover { background: rgba(239, 68, 68, 0.20); border-color: rgba(239, 68, 68, 0.50); color: #fecaca; }
.qr-btn-link {
    background: transparent;
    border-color: rgba(148, 163, 184, 0.2);
    color: var(--text-muted, #94a3b8);
}
.qr-btn-link:hover { color: var(--text-primary, #f1f5f9); background: rgba(148, 163, 184, 0.08); }
.qr-btn-disabled, .qr-btn[disabled] {
    opacity: 0.4;
    cursor: not-allowed;
    pointer-events: none;
}
.qr-empty-state {
    padding: 60px 20px;
    text-align: center;
    color: var(--text-muted, #94a3b8);
}
.qr-empty-icon { font-size: 48px; margin-bottom: 12px; opacity: 0.6; }
.qr-empty-state-inline {
    padding: 24px 16px;
    text-align: center;
    color: var(--text-muted, #94a3b8);
    font-size: 13px;
}
.qr-loading {
    padding: 40px 20px;
    text-align: center;
    color: var(--text-muted, #94a3b8);
    font-size: 14px;
}

/* Responsive — tile grid auto-fits; explicit overrides только для очень узких viewport */
@media (max-width: 540px) {
    .qr-panel { padding: 12px; }
    .qr-tiles-grid { grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 8px; padding: 8px; }
    .qr-tile { padding: 8px; }
    .qr-tile-name { font-size: 11px; min-height: 28px; }
}

/* prefers-reduced-motion */
@media (prefers-reduced-motion: reduce) {
    .qr-tile { transition: none; }
    .qr-btn { transition: none; }
    .qr-search-input { transition: none; }
    .qr-preview-loading { animation: none; opacity: 0.7; }
}

/* T4.3 Orphan reassign modal */
.qr-reassign-overlay {
    position: fixed; inset: 0; z-index: 1000;
    background: rgba(15, 23, 42, 0.7);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    display: flex; align-items: center; justify-content: center;
    padding: 20px;
    animation: qrFadeIn 0.18s ease-out;
}
@keyframes qrFadeIn { from { opacity: 0; } to { opacity: 1; } }
.qr-reassign-modal {
    background: #1e293b;
    border: 1px solid rgba(148, 163, 184, 0.24);
    border-radius: 16px;
    max-width: 520px;
    width: 100%;
    max-height: 90vh;
    overflow: auto;
    box-shadow: 0 24px 80px rgba(0, 0, 0, 0.5);
    animation: qrSlideUp 0.22s ease-out;
}
@keyframes qrSlideUp { from { transform: translateY(20px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
.qr-reassign-header {
    display: flex; justify-content: space-between; align-items: center;
    padding: 18px 20px;
    border-bottom: 1px solid rgba(148, 163, 184, 0.12);
}
.qr-reassign-header h3 {
    margin: 0;
    font-size: 17px;
    font-weight: 700;
    color: var(--text-primary, #f1f5f9);
}
.qr-reassign-close {
    background: transparent; border: none;
    color: var(--text-muted, #94a3b8);
    cursor: pointer;
    font-size: 18px;
    width: 32px; height: 32px;
    border-radius: 8px;
    transition: background 0.15s, color 0.15s;
}
.qr-reassign-close:hover { background: rgba(148, 163, 184, 0.12); color: var(--text-primary, #f1f5f9); }
.qr-reassign-body { padding: 20px; }
.qr-reassign-meta {
    background: rgba(245, 158, 11, 0.06);
    border: 1px solid rgba(245, 158, 11, 0.24);
    border-radius: 10px;
    padding: 12px 14px;
    margin-bottom: 16px;
    display: flex; flex-direction: column; gap: 6px;
}
.qr-reassign-meta-row { display: flex; align-items: center; gap: 10px; font-size: 13px; }
.qr-reassign-label {
    color: var(--text-muted, #94a3b8);
    min-width: 50px;
    font-size: 12px;
}
.qr-reassign-meta code {
    font-family: 'Consolas', 'Monaco', monospace;
    background: rgba(15, 23, 42, 0.5);
    padding: 2px 8px;
    border-radius: 4px;
    color: #818cf8;
    font-weight: 600;
}
.qr-reassign-orphan-name { color: #fbbf24; overflow-wrap: anywhere; }
.qr-reassign-field { margin-bottom: 12px; }
.qr-reassign-field label {
    display: block;
    font-size: 13px;
    color: var(--text-secondary, #cbd5e1);
    margin-bottom: 8px;
    font-weight: 500;
}
.qr-reassign-select {
    width: 100%;
    padding: 10px 12px;
    background: rgba(15, 23, 42, 0.6);
    border: 1px solid rgba(148, 163, 184, 0.24);
    border-radius: 8px;
    color: var(--text-primary, #f1f5f9);
    font-size: 14px;
    font-family: inherit;
}
.qr-reassign-select:focus-visible {
    outline: none;
    border-color: rgba(99, 102, 241, 0.5);
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.15);
}
.qr-reassign-select optgroup {
    background: #1e293b;
    color: var(--text-muted, #94a3b8);
    font-style: normal;
    font-weight: 600;
}
.qr-reassign-hint {
    font-size: 12px;
    color: var(--text-muted, #94a3b8);
    line-height: 1.5;
}
.qr-reassign-actions {
    display: flex; justify-content: flex-end; gap: 8px;
    padding: 14px 20px;
    border-top: 1px solid rgba(148, 163, 184, 0.12);
}
.qr-reassign-cancel { background: transparent; border-color: rgba(148, 163, 184, 0.24); }
@media (max-width: 540px) {
    .qr-reassign-modal { max-width: 100%; border-radius: 12px; }
    .qr-reassign-actions { flex-direction: column-reverse; }
    .qr-reassign-actions .qr-btn { width: 100%; justify-content: center; }
}
@media (prefers-reduced-motion: reduce) {
    .qr-reassign-overlay, .qr-reassign-modal { animation: none; }
}

/* Copy URL modal (25.05.2026) — программная замена window.prompt. Стиль зеркало reassign. */
.qr-link-overlay {
    position: fixed; inset: 0; z-index: 1000;
    background: rgba(15, 23, 42, 0.7);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    display: flex; align-items: center; justify-content: center;
    padding: 20px;
    animation: qrFadeIn 0.18s ease-out;
}
.qr-link-modal {
    background: #1e293b;
    border: 1px solid rgba(148, 163, 184, 0.24);
    border-radius: 16px;
    max-width: 460px;
    width: 100%;
    max-height: 90vh;
    overflow: auto;
    box-shadow: 0 24px 80px rgba(0, 0, 0, 0.5);
    animation: qrSlideUp 0.22s ease-out;
}
.qr-link-header {
    display: flex; justify-content: space-between; align-items: center;
    padding: 18px 20px;
    border-bottom: 1px solid rgba(148, 163, 184, 0.12);
}
.qr-link-header h3 {
    margin: 0;
    font-size: 17px;
    font-weight: 700;
    color: var(--text-primary, #f1f5f9);
}
.qr-link-close {
    background: transparent; border: none;
    color: var(--text-muted, #94a3b8);
    cursor: pointer;
    font-size: 18px;
    width: 32px; height: 32px;
    border-radius: 8px;
    transition: background 0.15s, color 0.15s;
}
.qr-link-close:hover { background: rgba(148, 163, 184, 0.12); color: var(--text-primary, #f1f5f9); }
.qr-link-body { padding: 20px; }
.qr-link-meta-row {
    display: flex; align-items: center; gap: 10px;
    font-size: 13px; margin-bottom: 8px;
    padding: 4px 0;
}
.qr-link-meta-label {
    color: var(--text-muted, #94a3b8);
    min-width: 110px;
    font-size: 12px;
}
.qr-link-code {
    font-family: 'Consolas', 'Monaco', monospace;
    background: rgba(15, 23, 42, 0.5);
    padding: 2px 10px;
    border-radius: 4px;
    color: #818cf8;
    font-weight: 700;
    letter-spacing: 0.5px;
}
.qr-link-equipment {
    color: var(--text-primary, #f1f5f9);
    overflow-wrap: anywhere;
    flex: 1; min-width: 0;
}
.qr-link-url-label {
    display: block;
    font-size: 13px;
    color: var(--text-secondary, #cbd5e1);
    margin: 12px 0 8px 0;
    font-weight: 500;
}
.qr-link-url-input {
    width: 100%;
    padding: 10px 12px;
    background: rgba(15, 23, 42, 0.6);
    border: 1px solid rgba(148, 163, 184, 0.24);
    border-radius: 8px;
    color: #818cf8;
    font-size: 13px;
    font-family: 'Consolas', 'Monaco', monospace;
    box-sizing: border-box;
}
.qr-link-url-input:focus-visible {
    outline: none;
    border-color: rgba(99, 102, 241, 0.5);
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.15);
}
.qr-link-hint {
    font-size: 12px;
    color: var(--text-muted, #94a3b8);
    line-height: 1.5;
    margin-top: 10px;
}
.qr-link-actions {
    display: flex; justify-content: flex-end; gap: 8px;
    padding: 14px 20px;
    border-top: 1px solid rgba(148, 163, 184, 0.12);
}
.qr-link-actions .qr-btn { min-width: 130px; justify-content: center; }
.qr-link-copy {
    background: linear-gradient(135deg, #4f46e5, #6366f1);
    color: #fff;
    border: 1px solid rgba(99, 102, 241, 0.5);
    font-weight: 600;
}
.qr-link-copy:hover:not(:disabled) {
    background: linear-gradient(135deg, #4338ca, #4f46e5);
    box-shadow: 0 4px 14px rgba(79, 70, 229, 0.4);
}
.qr-link-copy.qr-link-copy-success {
    background: linear-gradient(135deg, #059669, #10b981) !important;
    border-color: rgba(16, 185, 129, 0.5) !important;
    box-shadow: 0 4px 14px rgba(16, 185, 129, 0.35) !important;
}
.qr-link-open {
    background: transparent;
    border: 1px solid rgba(148, 163, 184, 0.24);
    color: var(--text-secondary, #cbd5e1);
}
.qr-link-open:hover { background: rgba(148, 163, 184, 0.12); color: var(--text-primary, #f1f5f9); }
@media (max-width: 540px) {
    .qr-link-modal { max-width: 100%; border-radius: 12px; }
    .qr-link-actions { flex-direction: column-reverse; }
    .qr-link-actions .qr-btn { width: 100%; }
}
@media (prefers-reduced-motion: reduce) {
    .qr-link-overlay, .qr-link-modal { animation: none; }
}

/* ===== 🗓 График смен (Ф1, 11.06.2026) — вкладка shift-calendar ===== */
.scal-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
    margin-bottom: 10px;
}
.scal-toolbar-group { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.scal-month-title { font-size: 18px; font-weight: 700; min-width: 170px; text-align: center; }
.scal-nav-btn { padding: 6px 12px; }
.scal-danger-btn { border-color: rgba(239, 68, 68, 0.5) !important; color: #fca5a5 !important; }
.scal-year-stats { color: var(--text-secondary, #8b949e); font-size: 13px; margin-bottom: 12px; }
.scal-hint-empty { color: #fbbf24; margin-left: 8px; }

.scal-grid-wrap {
    overflow-x: auto;
    border: 1px solid var(--border-color, #30363d);
    border-radius: 10px;
    background: var(--bg-secondary, #161b22);
    padding: 10px;
}
.scal-grid { border-collapse: separate; border-spacing: 3px; }
.scal-row-label { font-size: 12px; font-weight: 700; white-space: nowrap; padding: 0 8px; color: var(--text-secondary, #8b949e); }
.scal-day-head { font-size: 11px; font-weight: 700; text-align: center; padding: 2px 0; min-width: 38px; }
.scal-day-head .scal-wd { display: block; font-size: 9px; font-weight: 500; color: var(--text-secondary, #8b949e); }
.scal-day-head.scal-wknd, .scal-day-head.scal-wknd .scal-wd { color: #f87171; }
.scal-cell-td { padding: 0; }
.scal-cell-td.scal-today .scal-cell { box-shadow: 0 0 0 2px var(--accent-blue, #58a6ff); }
.scal-cell {
    --scal-c: #64748b;
    display: block;
    width: 100%;
    min-width: 38px;
    min-height: 30px;
    padding: 3px 4px;
    border: 1px solid var(--scal-c);
    border-radius: 6px;
    background: color-mix(in srgb, var(--scal-c) 26%, transparent);
    color: var(--text-primary, #e6edf3);
    font-size: 11px;
    font-weight: 700;
    cursor: pointer;
    font-family: inherit;
    max-width: 64px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    transition: filter 0.12s;
}
.scal-cell:hover, .scal-cell:focus-visible { filter: brightness(1.35); outline: none; }
.scal-cell-off { border-style: dashed; border-color: var(--border-color, #30363d); background: transparent; color: var(--text-secondary, #8b949e); font-weight: 500; }
.scal-cell-none { border-color: transparent; background: rgba(255, 255, 255, 0.04); color: var(--text-secondary, #8b949e); }
.scal-cell-orphan { border-style: dotted; }

.scal-legend { margin-top: 12px; font-size: 12px; color: var(--text-secondary, #8b949e); display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.scal-legend-chip {
    --scal-c: #64748b;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 2px 9px;
    border: 1px solid var(--scal-c);
    border-radius: 10px;
    background: color-mix(in srgb, var(--scal-c) 26%, transparent);
    color: var(--text-primary, #e6edf3);
    font-weight: 600;
}
.scal-legend-off { opacity: 0.8; }

/* Оверлеи (правка дня + мастер импорта/пресетов) — body-level, выше контента, ниже confirmModal */
.scal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.6);
    z-index: 1040;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 16px;
}
.scal-modal {
    background: var(--bg-secondary, #161b22);
    border: 1px solid var(--border-color, #30363d);
    border-radius: 12px;
    width: 100%;
    max-width: 420px;
    max-height: 90vh;
    display: flex;
    flex-direction: column;
    box-shadow: 0 16px 48px rgba(0, 0, 0, 0.5);
}
.scal-modal-wide { max-width: 640px; }
.scal-modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 14px 18px;
    border-bottom: 1px solid var(--border-color, #30363d);
}
.scal-modal-header h3 { margin: 0; font-size: 16px; }
.scal-modal-close {
    background: none;
    border: none;
    color: var(--text-secondary, #8b949e);
    font-size: 22px;
    cursor: pointer;
    line-height: 1;
    padding: 2px 8px;
}
.scal-modal-close:hover { color: var(--text-primary, #e6edf3); }
.scal-modal-body { padding: 16px 18px; overflow-y: auto; display: flex; flex-direction: column; gap: 12px; }
.scal-modal-footer {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    padding: 12px 18px;
    border-top: 1px solid var(--border-color, #30363d);
}
.scal-field { display: flex; flex-direction: column; gap: 5px; font-size: 13px; }
.scal-field > span { color: var(--text-secondary, #8b949e); font-weight: 600; }
.scal-field select, .scal-field input {
    background: var(--bg-primary, #0d1117);
    border: 1px solid var(--border-color, #30363d);
    border-radius: 8px;
    color: var(--text-primary, #e6edf3);
    padding: 8px 10px;
    font-size: 14px;
    font-family: inherit;
}
.scal-de-hint { font-size: 12px; color: var(--text-secondary, #8b949e); }
.scal-collision-banner {
    margin: 10px 18px 0;
    padding: 8px 12px;
    border: 1px solid rgba(245, 158, 11, 0.5);
    background: rgba(245, 158, 11, 0.12);
    border-radius: 8px;
    color: #fbbf24;
    font-size: 13px;
}
.scal-file-label input[type="file"] { display: none; }
.scal-file-label { display: inline-block; cursor: pointer; }
.scal-map-block { border-top: 1px solid var(--border-color, #30363d); padding-top: 10px; }
.scal-map-title { font-size: 13px; font-weight: 600; margin-bottom: 8px; }
.scal-map-row { flex-direction: row; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 6px; }
.scal-map-row select { min-width: 180px; }
.scal-preview-stats { display: flex; flex-direction: column; gap: 6px; font-size: 14px; }
.scal-warn { color: #fbbf24; }
.scal-preset-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)); gap: 10px; }
.scal-preset-card {
    text-align: left;
    background: var(--bg-primary, #0d1117);
    border: 1px solid var(--border-color, #30363d);
    border-radius: 10px;
    padding: 12px;
    cursor: pointer;
    color: var(--text-primary, #e6edf3);
    font-family: inherit;
    transition: border-color 0.12s, background 0.12s;
}
.scal-preset-card:hover, .scal-preset-card:focus-visible { border-color: var(--accent-blue, #58a6ff); background: var(--bg-secondary, #161b22); outline: none; }
.scal-preset-name { font-weight: 700; font-size: 14px; margin-bottom: 4px; }
.scal-preset-meta { font-size: 11px; color: var(--accent-blue, #58a6ff); margin-bottom: 6px; }
.scal-preset-desc { font-size: 12px; color: var(--text-secondary, #8b949e); line-height: 1.4; }
.scal-preset-chosen { font-size: 13px; color: var(--text-secondary, #8b949e); border-left: 3px solid var(--accent-blue, #58a6ff); padding-left: 10px; }

/* Ф1.5: индивидуальные дорожки (строки под Д/Н) */
.scal-track-label { white-space: nowrap; }
.scal-track-btns { display: inline-flex; gap: 2px; margin-left: 4px; vertical-align: middle; }
.scal-track-btn {
    background: none;
    border: 1px solid transparent;
    border-radius: 5px;
    font-size: 11px;
    padding: 1px 4px;
    cursor: pointer;
    opacity: 0.55;
}
.scal-track-btn:hover, .scal-track-btn:focus-visible { opacity: 1; border-color: var(--border-color, #30363d); outline: none; }
.scal-wd-checks { display: flex; gap: 10px; flex-wrap: wrap; padding: 4px 0; }
.scal-wd-check {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 13px;
    color: var(--text-primary, #e6edf3);
    cursor: pointer;
    text-transform: capitalize;
}
.scal-wd-check input { accent-color: var(--accent-blue, #58a6ff); width: 16px; height: 16px; }

@media (max-width: 640px) {
    .scal-month-title { min-width: 0; font-size: 15px; }
    .scal-toolbar-actions .btn { padding: 6px 10px; font-size: 12px; }
    .scal-modal { max-width: 100%; }
}
/* Наглядные примеры пресетов (12.06.2026): схема цикла на карточке выбора */
.scal-ex { margin-top: 8px; width: 100%; }
.scal-ex-row { display: flex; align-items: center; gap: 5px; margin-top: 3px; }
.scal-ex-lbl { font-size: 10px; width: 14px; flex: 0 0 14px; text-align: center; }
.scal-ex-cells { display: flex; gap: 2px; flex: 1; min-width: 0; }
.scal-ex-c {
    flex: 1;
    min-width: 0;
    height: 16px;
    border-radius: 4px;
    font-style: normal;
    font-size: 9.5px;
    font-weight: 700;
    line-height: 16px;
    text-align: center;
    color: #fff;
    background: color-mix(in srgb, var(--exc, #64748b) 55%, transparent);
    border: 1px solid var(--exc, #64748b);
    overflow: hidden;
}
.scal-ex-off {
    background: transparent;
    border: 1px dashed var(--border-color, #30363d);
    color: var(--text-secondary, #8b949e);
    font-weight: 400;
}
.scal-ex-cap { font-size: 10px; color: var(--text-secondary, #8b949e); margin-top: 4px; }
/* Живая полоса первых 14 дней от якоря (шаг параметров) */
.scal-lex-title { font-size: 12px; color: var(--text-secondary, #8b949e); margin: 10px 0 6px; }
.scal-lex {
    display: grid;
    grid-template-columns: repeat(14, 1fr);
    gap: 3px;
}
.scal-lex-col {
    display: flex;
    flex-direction: column;
    gap: 3px;
    min-width: 0;
    border-radius: 6px;
    padding: 2px;
}
.scal-lex-anchor { outline: 1px dashed #818cf8; outline-offset: 1px; }
.scal-lex-d {
    font-size: 9px;
    color: var(--text-secondary, #8b949e);
    text-align: center;
    white-space: nowrap;
    overflow: hidden;
}
.scal-lex-d em { display: block; font-style: normal; opacity: 0.75; }
.scal-lex-d.scal-wknd { color: #f87171; }
.scal-lex-chip {
    height: 18px;
    border-radius: 4px;
    font-style: normal;
    font-size: 9px;
    font-weight: 700;
    line-height: 18px;
    text-align: center;
    color: #fff;
    background: color-mix(in srgb, var(--exc, #64748b) 55%, transparent);
    border: 1px solid var(--exc, #64748b);
    overflow: hidden;
    white-space: nowrap;
}
.scal-lex-off { background: transparent; border: 1px dashed var(--border-color, #30363d); color: var(--text-secondary, #8b949e); font-weight: 400; }
.scal-lex-unk { background: rgba(148, 163, 184, 0.15); border: 1px dashed #94a3b8; color: #cbd5e1; }

@media (prefers-reduced-motion: reduce) {
    .scal-cell, .scal-preset-card { transition: none; }
}

/* ============================================
   📅 Планировщик ТО (Ф2c, 12.06.2026) — вкладка maintenance-plans (mxpl-*).
   Оверлеи/модалы/поля реиспользуют .scal-* (выше); здесь — таблица правил,
   бейджи, сегмент типа ТО, группы превью генерации, диалог удаления.
   ============================================ */
.mxpl-counter { color: var(--text-secondary, #8b949e); font-size: 14px; }
.mxpl-table-wrap { overflow-x: auto; margin-top: 14px; }
.mxpl-table { width: 100%; border-collapse: collapse; font-size: 13.5px; }
.mxpl-table th {
    text-align: left;
    padding: 8px 10px;
    color: var(--text-secondary, #8b949e);
    font-size: 11.5px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    border-bottom: 2px solid var(--border-color, #30363d);
    white-space: nowrap;
}
.mxpl-table td { padding: 9px 10px; border-bottom: 1px solid var(--border-color, #30363d); vertical-align: middle; }
.mxpl-table tbody tr:hover { background: rgba(148, 163, 184, 0.06); }
.mxpl-row-inactive { opacity: 0.55; }
.mxpl-eq { font-weight: 600; }
.mxpl-dim { color: var(--text-secondary, #8b949e); }
.mxpl-badge-type {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 10px;
    font-size: 12px;
    font-weight: 600;
    background: rgba(79, 70, 229, 0.18);
    color: #a5b4fc;
    border: 1px solid rgba(99, 102, 241, 0.35);
}
.mxpl-badge-off {
    font-size: 11px;
    color: #fbbf24;
    border: 1px dashed rgba(251, 191, 36, 0.5);
    border-radius: 8px;
    padding: 1px 6px;
    margin-left: 6px;
    white-space: nowrap;
}
.mxpl-badge-future {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 10px;
    font-size: 12px;
    background: rgba(34, 197, 94, 0.14);
    color: #86efac;
    border: 1px solid rgba(34, 197, 94, 0.3);
    white-space: nowrap;
}
.mxpl-actions { white-space: nowrap; text-align: right; }
.mxpl-act-btn {
    background: transparent;
    border: 1px solid var(--border-color, #30363d);
    border-radius: 8px;
    padding: 5px 9px;
    cursor: pointer;
    font-size: 14px;
    line-height: 1;
    margin-left: 4px;
    color: var(--text-primary, #e6edf3);
}
.mxpl-act-btn:hover { border-color: #94a3b8; background: rgba(148, 163, 184, 0.1); }
.mxpl-act-danger:hover { border-color: #ef4444; background: rgba(239, 68, 68, 0.12); }
/* Сегмент «Тип ТО» в модале правила */
.mxpl-seg { display: flex; gap: 8px; }
.mxpl-seg button {
    flex: 1;
    padding: 9px 12px;
    border-radius: 10px;
    border: 1px solid var(--border-color, #30363d);
    background: transparent;
    color: var(--text-primary, #e6edf3);
    cursor: pointer;
    font-size: 14px;
}
.mxpl-seg button.active { border-color: #6366f1; background: rgba(99, 102, 241, 0.18); font-weight: 600; }
.mxpl-seg button:disabled { opacity: 0.4; cursor: not-allowed; }
/* Периодичность: «повторять каждые [N] [нед./мес.]» + живая подсказка под строкой */
.mxpl-period-row { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.mxpl-period-prefix { color: var(--text-secondary, #8b949e); font-weight: 400; }
.mxpl-period-row input { width: 90px; flex: 0 0 auto; }
.mxpl-period-row select { flex: 1; min-width: 110px; }
.mxpl-period-hint strong { color: #86efac; }
.mxpl-check { display: flex; align-items: center; gap: 8px; font-size: 14px; cursor: pointer; }
/* Превью генерации: предупреждения по правилам + группы по правилам */
.mxpl-issues { display: flex; flex-direction: column; gap: 6px; }
.mxpl-group {
    border: 1px solid var(--border-color, #30363d);
    border-radius: 10px;
    padding: 8px 12px;
}
.mxpl-group summary { cursor: pointer; font-size: 13.5px; padding: 4px 0; }
.mxpl-group[open] summary { border-bottom: 1px solid var(--border-color, #30363d); margin-bottom: 6px; }
.mxpl-table-sm { font-size: 12.5px; }
.mxpl-table-sm td, .mxpl-table-sm th { padding: 5px 8px; }
.mxpl-row-dim { opacity: 0.55; }
.mxpl-chip { display: inline-block; padding: 1px 8px; border-radius: 9px; font-size: 11.5px; white-space: nowrap; }
.mxpl-chip-ok { background: rgba(34, 197, 94, 0.14); color: #86efac; }
.mxpl-chip-dim { background: rgba(148, 163, 184, 0.14); color: #cbd5e1; }
.mxpl-chip-bad { background: rgba(239, 68, 68, 0.14); color: #fca5a5; }
.mxpl-chip-upd { background: rgba(99, 102, 241, 0.16); color: #a5b4fc; }
.mxpl-chip-sup { background: rgba(168, 85, 247, 0.16); color: #d8b4fe; cursor: help; }
.mxpl-shifted { color: #fbbf24; font-weight: 700; cursor: help; }
/* Диалог удаления с выбором «только правило / правило + будущие задания» */
.mxpl-del-rule { font-weight: 600; }
.mxpl-del-actions { display: flex; flex-direction: column; gap: 8px; }
.mxpl-del-actions .btn { width: 100%; }
.mxpl-btn-danger {
    background: rgba(239, 68, 68, 0.15);
    border: 1px solid rgba(239, 68, 68, 0.5);
    color: #fca5a5;
}
.mxpl-btn-danger:hover { background: rgba(239, 68, 68, 0.25); }
/* Ф2e: строка-подсказка окна «Запланировано» на дашборде (скрыто N дальних) */
.planned-window-note {
    margin: 0 0 14px;
    padding: 9px 14px;
    border: 1px dashed rgba(99, 102, 241, 0.45);
    border-radius: 10px;
    background: rgba(99, 102, 241, 0.08);
    color: var(--text-secondary, #8b949e);
    font-size: 13px;
}
.planned-window-note strong { color: #a5b4fc; }
@media (max-width: 640px) {
    .mxpl-table { font-size: 12.5px; }
    .mxpl-table th, .mxpl-table td { padding: 6px 6px; }
}