/* ==========================================================================
   Шаг 07 — Технологическая карта (КАРТА ТЕХНОЛОГИЧЕСКОЙ ИНФОРМАЦИИ).
   Лист A4 (альбом) по образцу «Формы технической спецификации».
   Все размеры листа — в мм (точная печать A4 landscape), как на шаге 6.

   п.11 ТЗ: линии таблиц намеренно ТОНЬШЕ эталонной формы — единый hairline 1px
   (--tc-line), без жирных рамок. Цвет линий чёрный (#000) — тоньше, но не бледнее
   эталона (принято Максимом, см. Фазу 5).
   ========================================================================== */

:root {
  --tc-line:        #000000;   /* тонкие линии таблиц: чёрные (п.11 ТЗ — тонкие, но чёрные) */
  --tc-line-strong: #000000;   /* линии-бланки под подпись */
  --tc-ink:         #000000;   /* весь текст листа — чёрный #000000 */
  --tc-muted:       #6a6a6a;   /* только подписи тулбара (не печатается) */
}

/* ── Панель управления (не печатается) ───────────────────────── */
.tc-toolbar {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px;
  padding: 14px 16px;
  background: var(--color-bg-surface, #fff);
  border: 1px solid var(--color-border-card, #ededed);
  border-radius: var(--k-radius, 4px);
  margin-bottom: 20px;
}
.tc-toolbar__group { display: flex; align-items: center; gap: 8px; }
.tc-toolbar__sep {
  width: 1px;
  align-self: stretch;
  background: var(--color-border-card, #ededed);
  margin: 0 2px;
}
.tc-toolbar__spacer { flex: 1; }
.tc-toolbar__caption {
  font-family: var(--k-font);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--tc-muted);
}

/* Переключатель режима + кнопки действий — в стилистике кнопок навигации */
.tc-modeseg { display: inline-flex; gap: 8px; }
.tc-navbtn.btn--nav { font-size: 13px; padding: 8px 18px 8px 8px; gap: 10px; }
.tc-navbtn .btn--nav__ic { width: 28px; height: 28px; }

/* Активный режим — зелёная заливка кружка + зелёный лейбл (постоянный hover) */
.tc-modebtn.is-active {
  background: var(--k-green-light, #e6f4ef);
  border-color: var(--k-green, #00895f);
  color: var(--k-green-dark, #006b4a);
}
.tc-modebtn.is-active .btn--nav__ic {
  background: var(--k-green, #00895f);
  color: var(--k-white, #fff);
}

/* ── Плавающая кнопка «Принять изменения» (режим редактирования) ── */
.tc-accept-fab {
  position: fixed;
  left: 50%;
  bottom: 28px;
  transform: translate(-50%, 0);
  z-index: 60;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--k-font);
  font-size: 15px;
  font-weight: var(--k-fw-medium, 500);
  color: var(--k-white, #fff);
  background: var(--k-green, #00895f);
  border: 1px solid var(--k-green, #00895f);
  border-radius: var(--k-radius-pill, 12px);
  padding: 13px 28px;
  cursor: pointer;
  box-shadow: 0 8px 24px rgba(0, 107, 74, 0.28);
  animation: tc-fab-in 250ms var(--k-ease, cubic-bezier(.4,0,.2,1)) both;
  transition: background var(--k-dur, 250ms) var(--k-ease, cubic-bezier(.4,0,.2,1)),
              border-color var(--k-dur, 250ms) var(--k-ease, cubic-bezier(.4,0,.2,1));
}
.tc-accept-fab:hover {
  background: var(--k-green-dark, #006b4a);
  border-color: var(--k-green-dark, #006b4a);
}
@keyframes tc-fab-in {
  from { opacity: 0; transform: translate(-50%, 14px); }
  to   { opacity: 1; transform: translate(-50%, 0); }
}
@media (prefers-reduced-motion: reduce) { .tc-accept-fab { animation-duration: 1ms; } }

/* В оверлее FAB поднимается над ним (z 1000), иначе кнопка остаётся под оверлеем */
.tc-accept-fab.is-over-overlay { z-index: 1001; }

/* ── «Развернуть лист»: полноэкранный оверлей рабочей области ──── */
/* По умолчанию обёртка прозрачна для раскладки (тулбар и сцена ведут себя
   как прежде — прямые потомки .step). */
.tc-workarea { display: contents; }

.tc-workarea.is-expanded {
  display: flex;
  flex-direction: column;
  gap: 16px;
  position: fixed;
  inset: 0;
  z-index: 1000;
  background: var(--color-bg-surface, #fff);
  padding: 16px;
  overflow: auto;
}
/* Тулбар в оверлее остаётся сверху (включая «Редактирование») */
.tc-workarea.is-expanded .tc-toolbar {
  margin-bottom: 0;
  flex-shrink: 0;
}
/* Сцена занимает остаток высоты; лист вписан по ширине (крупно и читабельно),
   по вертикали — прокрутка, т.к. альбомный A4 при fit-по-ширине выше экрана. */
.tc-workarea.is-expanded .tc-stage {
  flex: 1 1 auto;
  min-height: 0;
  overflow-x: hidden;
  overflow-y: auto;
  align-items: flex-start;
  justify-content: center;
}
.tc-workarea.is-expanded .tc-stage__scaler { transform-origin: top center; }

/* Крестик закрытия оверлея */
.tc-overlay-close {
  position: fixed;
  top: 18px;
  right: 18px;
  z-index: 1001;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: var(--color-bg-surface, #fff);
  color: var(--k-gray-60, #606060);
  border: 1px solid var(--color-border-card, #ededed);
  border-radius: var(--k-radius, 4px);
  cursor: pointer;
  transition: color var(--k-dur-micro, 120ms), border-color var(--k-dur-micro, 120ms);
}
.tc-overlay-close:hover {
  color: var(--k-red, #eb5757);
  border-color: var(--k-red, #eb5757);
}

/* ── Сцена для масштабирования на экране (как .appr-stage) ────── */
.tc-stage {
  width: 100%;
  display: flex;
  justify-content: center;
  overflow: hidden;
  background: #e9eaec;
  border: 1px solid var(--color-border-card, #ededed);
  border-radius: var(--k-radius, 4px);
  padding: 0;
}
.tc-stage__scaler { transform-origin: top center; }

/* ── Лист A4 ─────────────────────────────────────────────────── */
.tc-sheet {
  width: 297mm;
  height: 210mm;
  background: #fff;
  box-sizing: border-box;
  padding: 4mm;
  font-family: var(--k-font, 'PT Root UI', sans-serif);
  font-size: 2.6mm;
  line-height: 1.25;
  color: var(--tc-ink);
  position: relative;
  display: flex;
  flex-direction: column;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.12);
}

/* Внешняя рамка всего листа — единый hairline (как все линии таблиц, --tc-line).
   Оборачивает всю «Карту технологической информации»: от шапки до подписей. Сидит
   внутри небольшого поля листа (.tc-sheet padding), содержимое — внутри рамки. */
.tc-frame {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  box-sizing: border-box;
  border: 1px solid var(--tc-line);
  padding: 3mm 4mm;
}

/* ── Универсальные редактируемые поля (как .appr-req-input) ───── */
/* Однострочное: всегда <input>, в режиме «Просмотр» выглядит обычным текстом. */
.tc-inp {
  width: 100%;
  box-sizing: border-box;
  border: none;
  background: transparent;
  font-family: inherit;
  font-size: inherit;
  line-height: 1.25;
  color: inherit;
  text-align: inherit;   /* input по умолчанию start — наследуем выравнивание ячейки */
  padding: 0;
}
.tc-inp:focus { outline: none; }
.tc-inp::placeholder { color: #c2c2c2; }
.tc-inp--mono { font-family: var(--k-font-mono, 'JetBrains Mono', monospace); }
.is-view .tc-inp { pointer-events: none; }
.is-edit .tc-inp {
  background: var(--k-gray-f6, #f6f6f6);
  box-shadow: inset 0 0 0 1px var(--k-gray-da, #dadada);
  border-radius: var(--k-radius, 4px);
  cursor: text;
}
.is-edit .tc-inp:focus {
  background: var(--k-white, #fff);
  box-shadow: inset 0 0 0 1.5px var(--k-green, #00895f);
}

/* Многострочное: <textarea> в правке, текст с переносами в просмотре. */
.tc-ta {
  width: 100%;
  box-sizing: border-box;
  border: none;
  background: transparent;
  font-family: inherit;
  font-size: inherit;
  line-height: 1.25;
  color: inherit;
  text-align: inherit;
  padding: 0;
  resize: none;
  overflow: hidden;
  display: block;
}
.tc-ta:focus { outline: none; }
.tc-ta::placeholder { color: #c2c2c2; }
.is-edit .tc-ta {
  background: var(--k-gray-f6, #f6f6f6);
  box-shadow: inset 0 0 0 1px var(--k-gray-da, #dadada);
  border-radius: var(--k-radius, 4px);
  cursor: text;
}
.is-edit .tc-ta:focus {
  background: var(--k-white, #fff);
  box-shadow: inset 0 0 0 1.5px var(--k-green, #00895f);
}
.tc-multi { white-space: pre-wrap; }

/* ── Шапка ───────────────────────────────────────────────────── */
.tc-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 8mm;
}
.tc-header__left { flex: 0 0 70mm; }
.tc-kti { font-size: 2.4mm; color: var(--tc-ink); }
.tc-approve {
  flex: 0 0 96mm;
  margin-left: auto;          /* блок «УТВЕРЖДАЮ» прижат к правому краю листа */
  text-align: left;
  font-size: 2.5mm;
  line-height: 1.3;
}
.tc-approve__title {
  font-weight: 700;
  text-align: left;           /* «УТВЕРЖДАЮ» над текстом «Заместитель…», а не по центру блока */
  margin-bottom: 0.6mm;
}
.tc-approve__row {
  display: flex;
  align-items: flex-end;
  gap: 2mm;
  margin-top: 0.8mm;
}
.tc-approve__sigline {
  flex: 0 0 28mm;
  border-bottom: 1px solid var(--tc-line-strong);
  height: 3.4mm;
}
.tc-approve__date { margin-top: 0.6mm; color: var(--tc-ink); }

/* ── Титульная строка (3 колонки) ────────────────────────────── */
.tc-titlebar {
  display: flex;
  border: 1px solid var(--tc-line);
  margin-top: 2.5mm;
}
.tc-titlebar > div {
  border-right: 1px solid var(--tc-line);
  padding: 1.5mm 2mm;
  box-sizing: border-box;
}
.tc-titlebar > div:last-child { border-right: none; }
.tc-tb-ttp {
  flex: 0 0 30mm;
  text-align: center;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.tc-tb-ttp__label { font-weight: 700; }
.tc-tb-mid {
  flex: 1;
  text-align: center;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.tc-tb-mid__title { font-weight: 700; font-size: 3mm; }
.tc-tb-mid__sub { color: var(--tc-ink); }
.tc-tb-right { flex: 0 0 108mm; display: flex; flex-direction: column; }
.tc-tb-right__prod { font-weight: 700; }
.tc-tb-right__equip {
  font-weight: 700;
  border-top: 1px solid var(--tc-line);
  margin-top: 1.2mm;
  padding-top: 1.2mm;
}

/* ── Блок «фото»: единая чёрная рамка — зеркало шага 6 (слева) + мини-таблица (рядом) ── */
.tc-photo {
  margin-top: 2.5mm;
  display: flex;
  align-items: stretch;          /* высоту блока задаёт колонка-«фото» */
  border: 1px solid var(--tc-line);   /* единая чёрная рамка блока (hairline, как везде) */
}
/* Колонка «фото»: фикс. ширина (PHOTO_COL_MM inline) + делитель к таблице; внутри —
   ApprovalPhoto натурального размера 287×96мм, отмасштабированный transform’ом. */
.tc-photo__stage {
  flex: 0 0 auto;
  position: relative;
  overflow: hidden;
  border-right: 1px solid var(--tc-line);   /* делитель «фото | таблица» */
  background: #fff;
}
.tc-photo__mirror { position: absolute; top: 0; left: 0; }

/* ── Мини-таблица рядом с фото — на всю высоту блока (= высоте развёртки, п.1) ── */
.tc-photo__side { flex: 1 1 auto; min-width: 0; }
.tc-mini {
  width: 100%;
  height: 100%;                  /* растягиваем на всю высоту блока — п.1 */
  border-collapse: collapse;
  table-layout: fixed;
  color: var(--tc-ink);          /* весь текст таблицы чёрный — п.5 */
}
/* Внутренние линии чёрные; внешние рёбра совпадают с рамкой блока (не дублируем). */
.tc-mini td {
  border-right: 1px solid var(--tc-line);
  border-bottom: 1px solid var(--tc-line);
  padding: 1mm 1.5mm;
  vertical-align: middle;
  font-size: 2.5mm;
  color: var(--tc-ink);
}
.tc-mini tr:last-child td { border-bottom: none; }
.tc-mini td:last-child { border-right: none; }
.tc-mini__label {
  width: 34mm;
  color: var(--tc-ink);
  font-weight: 700;          /* метка-заголовок жирнее своего значения */
}
.tc-mini__value { color: var(--tc-ink); }
/* Текст-значение в просмотре (зеркало шага 6 либо переопределение techCard.mini). */
.tc-mini__txt { white-space: pre-wrap; word-break: break-word; color: var(--tc-ink); }
.tc-mini__txt--mono { font-family: var(--k-font-mono, monospace); }

/* Цвета печати: свотчи-прямоугольники + коды под линией-разделителем (строго как шаг 6). */
/* Контейнер свотчей+кодов заполняет всю высоту ячейки: закрашенный блок свотчей
   растягивается на всю свободную высоту строки, вертикальные линии доходят до верхней и
   нижней рамки, а коды остаются в потоке (ячейка резервирует под них высоту — не вылезают). */
.tc-mini__colors { padding: 0 !important; }
.tc-colors {
  height: 100%;                  /* тянемся на всю высоту ячейки (table-cell задаёт высоту) */
  display: flex;
  flex-direction: column;
}
.tc-sw, .tc-cc { display: grid; grid-template-columns: repeat(6, 1fr); }
.tc-sw { flex: 0 0 auto; }                         /* свотчи — по содержимому (невысокие) */
.tc-cc { flex: 1 1 auto; grid-auto-rows: 1fr; }    /* коды занимают всю свободную высоту */
.tc-sw__cell {
  border-right: 1px solid var(--tc-line);
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 4mm;
  font-family: var(--k-font-mono, monospace);
  font-weight: 700;
  font-size: 3mm;
}
.tc-sw__cell:last-child { border-right: none; }
.tc-sw__cell--off { color: #cdcdcd; }          /* пустая ячейка — как .appr-colors__cell--empty */
.tc-cc { border-top: 1px solid var(--tc-line); }   /* линия-разделитель цвет | код */
.tc-cc__cell {
  border-right: 1px solid var(--tc-line);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.6mm 0.3mm;
  min-height: 4.5mm;
  font-size: 2.3mm;
  font-family: var(--k-font-mono, monospace);
  color: var(--tc-ink);
}
.tc-cc__cell:last-child { border-right: none; }
.tc-cc__cell .tc-inp { text-align: center; color: var(--tc-ink); }

/* Площадь запечатки, %: вертикальные линии на всю высоту строки (как .appr-colors-pcts
   шага 6) — п.3. Read-only зеркало шага 6 (без переопределения) — п.4. */
.tc-mini__pcts { padding: 0 !important; position: relative; }
.tc-pct {
  position: absolute;
  inset: 0;                      /* заполняет всю ячейку → линии доходят до рамки */
  display: grid;
  grid-template-columns: repeat(6, 1fr);
}
.tc-pct__cell {
  border-right: 1px solid var(--tc-line);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2.3mm;
  font-family: var(--k-font-mono, monospace);
  color: var(--tc-ink);
}
.tc-pct__cell:last-child { border-right: none; }

/* ── «На готовой продукции допускается:» ─────────────────────── */
.tc-allow { margin-top: 2.5mm; }
.tc-allow__title { font-weight: 700; font-size: 2.8mm; margin-bottom: 1mm; position: relative; }
.is-edit .tc-allow__title { padding-right: 5.5mm; }
.tc-del-btn--title { right: 0; top: 50%; transform: translateY(-50%); }
.tc-allow__list { margin: 0; padding: 0; list-style: none; }
.tc-allow__item {
  display: flex;
  gap: 1.6mm;
  font-size: 2.4mm;
  line-height: 1.3;
  margin-bottom: 0.5mm;
  position: relative;
}
.tc-allow__num { flex: 0 0 5mm; color: var(--tc-ink); }
.tc-allow__text { flex: 1; min-width: 0; }
/* В правке резервируем справа полоску под кнопку удаления пункта */
.is-edit .tc-allow__item { padding-right: 5.5mm; }
.tc-del-btn--row { right: 0; top: 50%; transform: translateY(-50%); }

/* ── Большая средняя таблица: резиновые столбцы (Фаза 6) ──────────
   table-layout:auto — ширины подстраиваются под содержимое; width:100%
   держит таблицу на всю ширину листа (удаление столбца растягивает остальные,
   добавление — сжимает). Ячейки резиновые: текст переносится по словам, без
   обрезки (никаких overflow:hidden/фикс-высот). */
.tc-table {
  width: 100%;
  border-collapse: collapse;
  table-layout: auto;
  margin-top: 2.5mm;
  /* Внешняя рамка — только верх+лево. Правый и нижний край листа дорисовывают
     последние ячейки (их border-right / border-bottom). Так линии нигде не
     накладываются по две: иначе на стыке рамки и крайней ячейки получается 2px
     («толстая» линия) — border-collapse схлопнул бы их в браузере, но html2canvas
     и дробный transform:scale рисуют стык двойным. */
  border-top: 1px solid var(--tc-line);
  border-left: 1px solid var(--tc-line);
}
/* Каждая ячейка рисует только правую и нижнюю грань — одна линия на стык
   (раньше border со всех сторон давал двойную линию на наложении ячеек). */
.tc-table th, .tc-table td {
  border: 0;
  border-right: 1px solid var(--tc-line);
  border-bottom: 1px solid var(--tc-line);
  padding: 1mm 1mm;
  vertical-align: middle;
  text-align: center;
  white-space: normal;          /* резиновая ячейка: перенос по словам */
  overflow-wrap: break-word;    /* длинные «слова» тоже переносятся, не вылезают */
}
.tc-table th {
  position: relative;           /* якорь для кнопки удаления столбца */
  font-weight: 700;             /* заголовок столбца жирнее своего значения */
  font-size: 2.1mm;
  line-height: 1.15;
  color: var(--tc-ink);
}
.tc-table td {
  font-size: 2.4mm;
  font-family: var(--k-font-mono, monospace);
}
/* Перенос текста и в просмотре (.tc-multi по умолчанию pre-wrap), и в правке;
   min-width:0 не даёт textarea навязывать столбцу большую минимальную ширину. */
.tc-table .tc-multi { white-space: normal; overflow-wrap: break-word; }
.tc-table .tc-ta { min-width: 0; }

/* В правке резервируем справа полоску под кнопку удаления столбца — текст
   заголовка переносится левее, кнопка его не перекрывает (высоту не меняем). */
.is-edit .tc-table th { padding-right: 5.5mm; }

/* Кнопка удаления столбца — паттерн .appr-del-btn (видна только в режиме правки,
   рендерится из JSX лишь в edit). Сидит в зарезервированной полоске справа. */
.tc-del-btn {
  position: absolute;
  z-index: 5;
  width: 4.2mm;
  height: 4.2mm;
  border-radius: var(--k-radius, 4px);
  background: var(--k-white, #fff);
  color: var(--k-gray-60, #606060);
  border: 1px solid var(--k-gray-da, #dadada);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  line-height: 0;
  transition: color 150ms var(--k-ease, cubic-bezier(.4,0,.2,1)),
              border-color 150ms var(--k-ease, cubic-bezier(.4,0,.2,1)),
              background 150ms var(--k-ease, cubic-bezier(.4,0,.2,1));
}
.tc-del-btn:hover {
  color: var(--k-red, #eb5757);
  border-color: var(--k-red, #eb5757);
  background: #fdecec;
}
.tc-del-btn--col { right: 0.7mm; top: 50%; transform: translateY(-50%); }

/* Плавное исчезновение столбца при удалении (обе ячейки помечаются классом —
   аналог .appr-removing; transform на table-cell ненадёжен, поэтому только opacity). */
.tc-removing {
  animation: tc-col-fade 240ms var(--k-ease, cubic-bezier(.4,0,.2,1)) forwards;
  pointer-events: none;
}
@keyframes tc-col-fade { to { opacity: 0; } }
@media (prefers-reduced-motion: reduce) { .tc-removing { animation-duration: 1ms; } }

/* Кнопка «+ столбец» — паттерн .appr-add-row-btn, компактнее (бережём место листа). */
.tc-addcol-btn {
  display: inline-flex;
  align-items: center;
  gap: 1.5mm;
  margin-top: 1.2mm;
  padding: 1.2mm 3mm;
  border: 1px dashed var(--k-green, #00895f);
  border-radius: var(--k-radius, 4px);
  background: transparent;
  color: var(--k-green, #00895f);
  font-family: var(--k-font);
  font-size: 2.6mm;
  line-height: 1;
  cursor: pointer;
  transition: background 150ms;
}
.tc-addcol-btn:hover { background: var(--k-green-light, #e6f4ef); }
.tc-addcol-btn__plus { font-size: 3.6mm; font-weight: 700; line-height: 1; }

/* ── Нижняя зона: MiniGrid-сетки (Фаза 7) ───────────────────────── */
.tc-foot { display: flex; gap: 4mm; margin-top: 2.5mm; align-items: flex-start; }
.tc-foot__col { display: flex; flex-direction: column; gap: 2mm; min-width: 0; }
.tc-foot__col--left  { flex: 0 0 57%; }
.tc-foot__col--right { flex: 1; }

/* Общие стили метки-заголовка строки (переиспользуется из tc-gt). */
.tc-gt__rowlabel { text-align: left; color: var(--tc-ink); font-weight: 700; }
.tc-gt__name     { text-align: left; font-weight: 700; }

/* ── MiniGrid: универсальная редактируемая сетка малых блоков ───────
   Резиновые столбцы (table-layout:auto), data-tc-col + анимация удаления —
   по образцу tc-table. Плюс операции над строками (Фаза 7).          */
.tc-mg {
  width: 100%;
  border-collapse: collapse;
  table-layout: auto;
  border-top:  1px solid var(--tc-line);
  border-left: 1px solid var(--tc-line);
}
.tc-mg th, .tc-mg td {
  border: 0;
  border-right:  1px solid var(--tc-line);
  border-bottom: 1px solid var(--tc-line);
  padding: 0.9mm 1.5mm;
  font-size: 2.4mm;
  vertical-align: middle;
  text-align: center;
  white-space: normal;
  overflow-wrap: break-word;
}
.tc-mg th {
  font-weight: 700;
  color: var(--tc-ink);
  position: relative;   /* якорь для кнопки удаления столбца */
}
/* В правке резервируем справа полоску под кнопку удаления столбца */
.is-edit .tc-mg th { padding-right: 5.5mm; }
/* Метка-строка: text-align left через .tc-gt__rowlabel */
.tc-mg .tc-gt__rowlabel .tc-inp { text-align: left; }
.tc-mg td .tc-inp { text-align: center; }

/* Ячейка с кнопкой удаления строки — отдельная колонка справа.
   В просмотре не рендерится (editable &&), поэтому скрывать не нужно. */
.tc-mg__btncell {
  padding: 0 0.5mm !important;
  width: 5mm;
  min-width: 5mm;
  text-align: center;
  vertical-align: middle;
}

/* Кнопки «+ строка» / «+ столбец» под таблицей */
.tc-mg-actions {
  display: flex;
  gap: 2mm;
  flex-wrap: wrap;
  margin-top: 1.2mm;
}

/* Блок «Высота паллеты» — визуально как старый .tc-pallet (рамка + fafafa) */
.tc-mg-pallet .tc-mg td {
  text-align: center;
  font-size: 2.8mm;
  padding: 2mm 1mm;
  background: #fafafa;
}

/* ── Подписи ─────────────────────────────────────────────────── */
.tc-signs {
  display: flex;
  align-items: flex-end;
  gap: 3mm;
  margin-top: 3mm;
  font-size: 2.6mm;
}
.tc-sign { display: flex; align-items: flex-end; gap: 2mm; }
.tc-sign__role { white-space: nowrap; color: var(--tc-ink); }
.tc-sign__line {
  flex: 0 0 34mm;
  border-bottom: 1px solid var(--tc-line-strong);
  height: 3.6mm;
}
.tc-sign__name { flex: 0 0 36mm; }

/* ── Печать: только лист, A4 landscape, масштаб 1:1 ──────────── */
@media print {
  @page { size: A4 landscape; margin: 0; }
  body * { visibility: hidden; }
  .tc-print-root, .tc-print-root * { visibility: visible; }
  .tc-print-root { position: absolute; left: 0; top: 0; margin: 0; padding: 0; }
  .tc-toolbar, .app-header, .app-footer, .tc-accept-fab,
  .tc-del-btn, .tc-addcol-btn, .tc-mg-actions, .tc-overlay-close { display: none !important; }
  /* Ячейка кнопки удаления строки (tc-mg__btncell) в правке — скрыть колонку */
  .tc-mg__btncell { display: none !important; }
  /* «Развернуть лист»: нейтрализуем оверлей, чтобы печатался только лист
     без задвоения и без смещения позиционированием. */
  .tc-workarea.is-expanded {
    position: static !important;
    display: block !important;
    overflow: visible !important;
    background: none !important;
    padding: 0 !important;
    z-index: auto !important;
  }
  /* Печать без органов управления — снимаем резерв под кнопки удаления. */
  .tc-table th { padding-right: 1mm !important; }
  .tc-mg th    { padding-right: 1mm !important; }
  .tc-stage { background: none; border: none; padding: 0; overflow: visible; }
  .tc-stage__scaler { transform: none !important; }
  .tc-sheet { box-shadow: none; width: 297mm; height: 210mm; }
  /* Поля-инпуты печатаем как обычный текст (без рамок/фона) */
  .tc-inp, .tc-ta { border: none !important; box-shadow: none !important; background: transparent !important; }
  /* Принудительно печатаем фоны/линии (иначе Chrome их «экономит») */
  .tc-print-root, .tc-print-root * {
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
  }
}
