/* ЗАТОЧИ! / Путь Ножа — дизайн-система. Этап 1 апгрейда визуала. */

/* === Локальные шрифты (вместо Google Fonts) ===
   В РФ Google Fonts CDN часто фильтруется/таймаутится. Возим шрифты внутри:
   - Inter и Caveat — variable-фонты, одним файлом покрывают все веса.
   - PT Serif и JetBrains Mono — 4 статических веса каждый.
   - font-display: swap — сначала системный фолбэк, потом подменяется на наш
     (нет «невидимого текста» при медленном первом запуске).
   - Subset: латиница + кириллица + типографика. Размеры: 47-160 KB каждый. */
@font-face {
  font-family: 'Inter';
  src: url('../assets/fonts/Inter.woff2') format('woff2-variations'),
       url('../assets/fonts/Inter.woff2') format('woff2');
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Caveat';
  src: url('../assets/fonts/Caveat.woff2') format('woff2-variations'),
       url('../assets/fonts/Caveat.woff2') format('woff2');
  font-weight: 400 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'PT Serif';
  src: url('../assets/fonts/PTSerif-Regular.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'PT Serif';
  src: url('../assets/fonts/PTSerif-Bold.woff2') format('woff2');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'PT Serif';
  src: url('../assets/fonts/PTSerif-Italic.woff2') format('woff2');
  font-weight: 400;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: 'PT Serif';
  src: url('../assets/fonts/PTSerif-BoldItalic.woff2') format('woff2');
  font-weight: 700;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: 'JetBrains Mono';
  src: url('../assets/fonts/JetBrainsMono-Regular.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'JetBrains Mono';
  src: url('../assets/fonts/JetBrainsMono-Medium.woff2') format('woff2');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'JetBrains Mono';
  src: url('../assets/fonts/JetBrainsMono-SemiBold.woff2') format('woff2');
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'JetBrains Mono';
  src: url('../assets/fonts/JetBrainsMono-Bold.woff2') format('woff2');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

/* === Дизайн-токены: тёмная тема (основная) === */
:root,
:root[data-theme="dark"] {
  /* Фон в три слоя */
  --bg:        #16181C;
  --bgRaised:  #1F2227;
  --bgHi:      #272A30;
  --bgInput:   #15171B;

  /* Хейрлайны */
  --rule:       rgba(176,181,186,0.10);
  --ruleStrong: rgba(176,181,186,0.22);
  --ruleWarm:   rgba(201,177,134,0.18);

  /* Текст */
  --text:      #F0EAD8;
  --textMuted: #9BA0A8;
  --textDim:   #6B7079;
  --textNum:   #E7E2D0;

  /* Акценты */
  --bronze:    #A98556;
  --bronzeDim: #6E5736;
  --cinnabar:  #D8333F;
  --bamboo:    #7FB35F;   /* «лист бамбука» — статус «оплачено», прибыль */
  --blood:     #8B0000;
  --blade:     #B0B5BA;
  --paper:     #F5EFE0;

  /* Hanko-печати */
  --stampOk:  #7FB35F;
  --stampHot: #D8333F;

  /* CSS-фильтр для PNG-эскиза Клинка под тёмную тему */
  --knifeFilter: invert(0.88) sepia(0.18) hue-rotate(355deg) brightness(1.05) contrast(1.05);

  /* Лейаут */
  --topbar-h: 52px;
  --tabbar-h: 64px;
  --radius: 4px;

  /* Совместимость со старыми селекторами (постепенно удаляются) */
  --steel: var(--bg);
  --leaf: var(--bamboo);
  --steel-lighter: var(--bgHi);
  --steel-darker: var(--bgInput);
  --field-bg: var(--bgInput);
  --field-border: var(--rule);
  --field-border-focus: var(--bronze);
  --text-muted: var(--textMuted);
}

/* === Светлая тема === */
:root[data-theme="light"] {
  --bg:        #EDE9DE;
  --bgRaised:  #F5EFE0;
  --bgHi:      #E3DDCC;
  --bgInput:   #F8F3E4;

  --rule:       rgba(42,45,52,0.12);
  --ruleStrong: rgba(42,45,52,0.24);
  --ruleWarm:   rgba(139,111,71,0.28);

  --text:      #1F2227;
  --textMuted: #5A5E66;
  --textDim:   #8A8E96;
  --textNum:   #2A2D34;

  --bronze:    #8B6F47;
  --bronzeDim: #B79865;
  --cinnabar:  #C8202C;
  --bamboo:    #5E8E44;
  --blade:     #7A7F86;

  --stampOk:  #5E8E44;
  --stampHot: #C8202C;

  --knifeFilter: sepia(0.42) hue-rotate(355deg) saturate(0.7) brightness(0.55) contrast(1.15);
}

* { box-sizing: border-box; margin: 0; padding: 0; }

/* HTML-атрибут [hidden] перебивается явным display:flex — фиксим жёстко */
[hidden] { display: none !important; }

html, body {
  height: 100%;
  overflow-x: hidden;
}

body {
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  font-feature-settings: 'cv11','ss01','ss03';
  background: var(--bg);
  color: var(--text);
  line-height: 1.4;
  font-size: 14px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* === Утилиты-классы из дизайн-системы === */
.mono { font-family: 'JetBrains Mono', ui-monospace, monospace; font-feature-settings: 'tnum'; }
.muted { color: var(--textMuted); }
.dim { color: var(--textDim); }
.bronze-text { color: var(--bronze); }
.row { display: flex; align-items: center; gap: 10px; }
.spc { flex: 1; }
.divider { height: 1px; background: var(--rule); margin: 14px 0; }

/* Фабричная маркировка-разделитель «─── РАЗДЕЛ ───» */
.fab-rule {
  display: flex; align-items: center; gap: 8px;
  font-family: 'JetBrains Mono', monospace; font-size: 10px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--textDim);
  padding: 14px 16px 6px;
}
.fab-rule::before, .fab-rule::after {
  content: ''; flex: 1; height: 1px; background: var(--rule);
}

/* === Hanko-печать (квадратная, повёрнутая) === */
.hanko {
  display: inline-flex; align-items: center; justify-content: center;
  width: 54px; height: 54px;
  font-family: 'Inter', sans-serif; font-weight: 800; font-size: 9px;
  letter-spacing: 0.08em; text-align: center; line-height: 1.05;
  color: var(--stampOk); border: 2px solid var(--stampOk);
  text-transform: uppercase; transform: rotate(-6deg);
  background: transparent;
  flex-shrink: 0;
}
.hanko-sm { width: 36px; height: 36px; font-size: 7px; border-width: 1.5px; }

/* === Реплика Клинка === */
.knife-voice {
  font-family: 'PT Serif', serif; font-style: italic;
  color: var(--bronzeDim); font-size: 13.5px; line-height: 1.45;
  padding-left: 14px; border-left: 2px solid var(--bronze);
}

.brand {
  display: flex;
  align-items: baseline;
}

/* === Content / Views ===
   Главные вкладки без верхней панели — padding-top по safe-area-inset-top.
   Топ-панель появляется только в формовых вьюхах (приёмка/заказ/процесс). */
.content {
  padding-top: env(safe-area-inset-top, 0);
  padding-bottom: var(--tabbar-h);
  min-height: 100vh;
}

/* На форме/карточке заказа/обработке Ножа есть топбар со стрелкой «Назад» */
body[data-view="form-new-order"] .brand-tagline,
body[data-view="order-detail"]   .brand-tagline,
body[data-view="knife-process"]  .brand-tagline { display: none; }
body[data-view="form-new-order"] .content,
body[data-view="order-detail"]   .content,
body[data-view="knife-process"]  .content { padding-top: var(--topbar-h); }

.view {
  padding: 24px 20px 40px;
}

/* === Home / Empty state === */
.view-home {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 40px 24px 60px;
  min-height: calc(100vh - var(--tabbar-h));
}

/* === Buttons === */
.btn {
  font-family: 'Inter', sans-serif;
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 2.2px;
  text-transform: uppercase;
  padding: 16px 32px;
  border: none;
  border-radius: var(--radius);
  cursor: pointer;
  transition: all 0.15s;
}

.btn:disabled { opacity: 0.5; cursor: not-allowed; }

.btn-primary {
  background: var(--bronze);
  color: var(--paper);
}

.btn-primary:hover:not(:disabled) {
  background: #9d7e54;
}

.btn-secondary {
  background: transparent;
  color: var(--paper);
  border: 1px solid var(--field-border);
}

.btn-secondary:hover {
  border-color: var(--bronze);
}

.orders-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.today-summary {
  background: var(--steel-lighter);
  border-radius: var(--radius);
  border-left: 3px solid var(--cinnabar);
  padding: 12px 16px;
  margin-bottom: 12px;
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 12px;
}

.today-summary-label {
  font-family: 'PT Serif', serif;
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--cinnabar);
}

.today-summary-meta {
  display: flex;
  gap: 14px;
  align-items: baseline;
}

.today-summary-count {
  font-size: 13px;
  color: var(--text-muted);
}

.today-summary-sum {
  font-family: 'PT Serif', serif;
  font-weight: 700;
  font-size: 20px;
  color: var(--paper);
  font-variant-numeric: tabular-nums;
}

.list-empty {
  font-family: 'PT Serif', serif;
  font-style: italic;
  color: var(--text-muted);
  padding: 32px 4px;
  text-align: center;
  line-height: 1.5;
}

/* === Карточка заказа === */
.detail-block {
  margin-bottom: 22px;
}

.detail-block-title {
  font-family: 'PT Serif', serif;
  font-weight: 700;
  font-size: 14px;
  color: var(--bamboo);
  text-transform: uppercase;
  letter-spacing: 2.4px;
  margin-bottom: 12px;
  padding-bottom: 6px;
  border-bottom: 1px solid var(--field-border);
}

.grit-fepa { font-weight: 700; color: var(--bamboo); }

/* Карточки сталей */
.steels-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}

@media (min-width: 720px) {
  .steels-grid { grid-template-columns: 1fr 1fr; }
}

/* Узкий экран — пасты и абразивы стопкой */
@media (max-width: 480px) {
  .pastes-row, .abrasives-row { grid-template-columns: 1fr; }
}

/* Затраты и окупаемость */
.expense-summary {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(110px, 1fr));
  gap: 8px;
  margin-bottom: 16px;
}

/* Верхняя сводка Статистики — крупнее, с акцентом */
.expense-summary--top {
  margin-bottom: 22px;
}
.expense-summary--top .expense-cell { padding: 14px 14px; }
.expense-summary--top .expense-cell-value { font-size: 20px; }
.expense-summary--top .expense-cell--exp { border-left-color: var(--cinnabar); }
.expense-summary--top .expense-cell--exp .expense-cell-value { color: var(--cinnabar); }

.expense-cell {
  background: var(--steel-lighter);
  border-radius: var(--radius);
  border-left: 3px solid var(--bronze);
  padding: 10px 12px;
  min-width: 0;
}

.expense-cell-label {
  font-size: 11px;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 4px;
}

.expense-cell-value {
  font-family: 'PT Serif', serif;
  font-weight: 700;
  font-size: 16px;
  color: var(--paper);
  font-variant-numeric: tabular-nums;
}

.expense-positive { border-left-color: var(--leaf); background: rgba(107,159,79,0.08); }
.expense-positive .expense-cell-value { color: var(--leaf); }
.expense-negative { border-left-color: var(--cinnabar); }
.expense-negative .expense-cell-value { color: var(--cinnabar); }

/* Планшет: Категория + Дата в одну строку, потом название, потом сумма + кнопка */
@media (min-width: 480px) {
  .expense-add-form {
    grid-template-columns: 1fr 1fr;
  }
  .expense-add-form #newExpenseName { grid-column: 1 / -1; }
}

/* Совсем широко — всё в одну строку (нужно достаточно места) */
@media (min-width: 920px) {
  .expense-add-form {
    grid-template-columns: 140px 2fr 110px 140px auto;
  }
  .expense-add-form #newExpenseName { grid-column: auto; }
}

/* Полоска разбивки по категориям над списком */
.expense-cat-breakdown {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-bottom: 14px;
}

.cat-strip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  background: var(--steel-lighter);
  padding: 5px 10px;
  border-radius: 12px;
  border: 1px solid var(--field-border);
  color: var(--paper);
}

.cat-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}

.cat-strip[data-cat="equipment"] .cat-dot { background: var(--bronze); }
.cat-strip[data-cat="abrasives"] .cat-dot { background: var(--bamboo); }
.cat-strip[data-cat="supplies"]  .cat-dot { background: var(--leaf);   }
.cat-strip[data-cat="other"]     .cat-dot { background: var(--text-muted); }

.cat-strip-name { color: var(--text-muted); font-size: 11px; }
.cat-strip-val  { font-weight: 700; font-variant-numeric: tabular-nums; }

/* Подсветка авто-подставленного поля (HRC из каталога стали) */
.field-autofilled {
  animation: fieldAutofillFlash 1.4s ease;
}

@keyframes fieldAutofillFlash {
  0%   { background: rgba(139,111,71,0.45); }
  100% { background: var(--field-bg); }
}

/* Распознавание клиента по телефону */
.client-found-banner {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  background: rgba(139,111,71,0.10);
  border: 1px solid var(--bronze);
  border-radius: var(--radius);
  margin-bottom: 12px;
}

.client-found-icon {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--bronze);
  color: var(--paper);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  flex-shrink: 0;
}

.client-found-text {
  flex: 1;
  font-size: 14px;
  color: var(--paper);
  line-height: 1.4;
}

.client-found-meta {
  display: block;
  font-size: 12px;
  color: var(--bamboo);
  font-style: italic;
  margin-top: 2px;
}

/* «Прошлые Ножи клиента» в форме приёма */
.client-knives-history {
  background: rgba(176,181,186,0.04);
  border-radius: var(--radius);
  padding: 12px;
  margin-bottom: 14px;
}

.history-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 8px;
  gap: 8px;
  flex-wrap: wrap;
}

.history-title {
  font-family: 'PT Serif', serif;
  font-weight: 700;
  font-size: 14px;
  color: var(--bamboo);
}

.history-grid {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.history-card {
  display: flex;
  gap: 10px;
  padding: 10px 12px;
  background: var(--steel-lighter);
  border: 1px solid var(--field-border);
  border-radius: var(--radius);
  cursor: pointer;
  transition: all 0.15s;
  align-items: flex-start;
}

.history-card:hover { border-color: var(--bamboo); }

.history-card--checked {
  border-color: var(--bronze);
  background: rgba(139,111,71,0.12);
}

.history-card input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: var(--bronze);
  flex-shrink: 0;
  margin-top: 2px;
}

.history-card-body { flex: 1; min-width: 0; }

.history-card-name {
  font-family: 'PT Serif', serif;
  font-weight: 700;
  font-size: 14px;
  color: var(--paper);
}

.history-card-meta {
  font-size: 12px;
  color: var(--text-muted);
  margin-top: 2px;
}

.history-card-last {
  font-size: 11px;
  color: var(--bamboo);
  font-style: italic;
  margin-top: 4px;
}

.hist-entry {
  background: var(--steel-lighter);
  border-left: 2px solid var(--bamboo);
  padding: 10px 12px;
  border-radius: var(--radius);
  font-size: 13px;
  line-height: 1.45;
}

.hist-entry-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 8px;
  margin-bottom: 4px;
}

.hist-entry-date {
  font-family: 'PT Serif', serif;
  font-weight: 700;
  color: var(--bamboo);
  font-size: 13px;
}

.hist-entry-row {
  color: var(--paper);
  padding: 2px 0;
}

.hist-key {
  color: var(--text-muted);
  font-size: 12px;
  margin-right: 4px;
}

.hist-stage-angle {
  color: var(--bronze);
  font-variant-numeric: tabular-nums;
}

/* Шкала Пути Ножа */
.sharpness-scale {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 6px;
}

.sharpness-pill {
  background: var(--steel-lighter);
  border: 1px solid var(--field-border);
  border-radius: var(--radius);
  padding: 10px 4px 8px;
  display: flex;
  flex-direction: column;
  align-items: center;
  cursor: pointer;
  transition: all 0.15s;
  color: var(--paper);
  font-family: 'Inter', sans-serif;
  min-width: 0;
}

.sharpness-pill:hover {
  border-color: var(--bamboo);
}

.sharpness-pill--active {
  background: var(--bronze);
  border-color: var(--bronze);
  color: var(--paper);
}

.sharpness-pill-num {
  font-family: 'PT Serif', serif;
  font-weight: 700;
  font-size: 20px;
  line-height: 1;
  letter-spacing: 1px;
}

.sharpness-pill-name {
  font-size: 10px;
  margin-top: 6px;
  text-align: center;
  line-height: 1.15;
  letter-spacing: 0.2px;
}

.sharpness-criterion {
  margin-top: 10px;
  font-family: 'PT Serif', serif;
  font-style: italic;
  color: var(--bamboo);
  font-size: 14px;
  text-align: center;
  line-height: 1.4;
}

.sharpness-chip {
  display: inline-block;
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  padding: 2px 10px;
  background: var(--bronze);
  color: var(--paper);
  border-radius: 10px;
  letter-spacing: 0.3px;
  font-weight: 600;
}

.restoration-badge {
  display: inline-block;
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.5px;
  padding: 2px 10px;
  background: rgba(200,32,44,0.20);
  color: var(--cinnabar);
  border-radius: 10px;
  text-transform: lowercase;
  font-style: italic;
}

.work-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 9px 10px;
  cursor: pointer;
  border-radius: var(--radius);
  transition: background 0.12s;
}

.work-item:hover { background: rgba(176,181,186,0.04); }

.work-item input[type="checkbox"] {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  accent-color: var(--bronze);
  cursor: pointer;
}

.work-name {
  flex: 1;
  font-size: 15px;
  color: var(--paper);
}

.work-price {
  color: var(--text-muted);
  font-size: 13px;
  font-variant-numeric: tabular-nums;
}

.work-item input:checked ~ .work-name { font-weight: 500; }
.work-item input:checked ~ .work-price { color: var(--bamboo); }

.works-total {
  margin-top: 14px;
  padding: 14px 16px;
  background: var(--steel-lighter);
  border-radius: var(--radius);
  border-left: 3px solid var(--bronze);
  display: flex;
  justify-content: space-between;
  align-items: baseline;
}

.works-total-label {
  font-family: 'PT Serif', serif;
  color: var(--bamboo);
  font-weight: 700;
  letter-spacing: 0.5px;
}

.works-total-value {
  font-family: 'PT Serif', serif;
  color: var(--paper);
  font-size: 20px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}

/* === Этапы заточки === */
.stage-block {
  background: var(--steel-darker);
  border-radius: var(--radius);
  border-left: 2px solid var(--blade);
  padding: 12px 14px;
  margin-bottom: 10px;
}

.stage-block-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px;
}

.stage-idx {
  font-family: 'PT Serif', serif;
  font-weight: 700;
  font-size: 14px;
  color: var(--bamboo);
  letter-spacing: 0.5px;
}

.stage-num { color: var(--paper); }

.stage-block .field-row {
  grid-template-columns: 2fr 1fr;
}

.btn-remove-stage {
  background: transparent;
  border: none;
  color: var(--text-muted);
  font-size: 22px;
  line-height: 1;
  width: 28px;
  height: 28px;
  cursor: pointer;
  border-radius: 50%;
  transition: all 0.15s;
}

.btn-remove-stage:hover {
  background: rgba(200,32,44,0.15);
  color: var(--cinnabar);
}

.stages-empty {
  font-family: 'PT Serif', serif;
  font-style: italic;
  color: var(--text-muted);
  padding: 16px 4px;
  text-align: center;
  font-size: 14px;
  line-height: 1.5;
}

/* Чекбоксы внутри этапа (микроподвод, тех. барьер) */
.stage-checkbox {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 2px;
  margin-top: 8px;
  cursor: pointer;
  font-size: 14px;
  color: var(--paper);
}

.stage-checkbox input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: var(--bronze);
  flex-shrink: 0;
  cursor: pointer;
}

.stage-range-hint {
  margin: 4px 2px 0;
  font-size: 12px;
  color: var(--text-muted);
  font-style: italic;
}

/* Эквиваленты зернистости под полем «Зернистость» в этапе */
.grit-eq-line {
  margin: 6px 2px 8px;
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  color: var(--text-muted);
  line-height: 1.4;
  min-height: 16px;
  font-variant-numeric: tabular-nums;
}

.grit-eq-line:empty::before {
  content: 'введи маркировку (F600 / J1200 / 10/7 / 9 мкм) — подставлю эквиваленты';
  color: rgba(176,181,186,0.30);
  font-style: italic;
}

.grit-eq-pair b {
  color: var(--bamboo);
  font-weight: 600;
}

.grit-eq-mkm b { color: var(--bronze); }

/* Приоритетная шкала (выбранная в Профиле) — крупнее и киноварного цвета */
.grit-eq-pref {
  font-size: 13px;
}
.grit-eq-pref b {
  color: var(--cinnabar) !important;
  font-size: 13px;
}

.grit-eq-stage {
  color: var(--bronze);
  font-style: italic;
  margin-left: 4px;
}

/* Подсказка типичного угла под полем «Угол при замере» */
.angle-typical-hint {
  display: block;
  margin: 6px 2px 0;
  font-family: 'PT Serif', serif;
  font-style: italic;
  font-size: 12px;
  color: var(--text-muted);
  line-height: 1.4;
}

.angle-typical-hint b {
  color: var(--bamboo);
  font-style: normal;
  font-family: 'Inter', sans-serif;
  font-variant-numeric: tabular-nums;
  margin: 0 2px;
}

/* Финишный этап — подсвечен бронзой */
.stage-block--finish {
  border-left-color: var(--bronze);
}

.stage-cat {
  color: var(--bamboo);
  font-style: italic;
  font-weight: 400;
  font-size: 13px;
  letter-spacing: 0.5px;
}

/* «Итого по Ножу» внутри экрана обработки */
.knife-total-bar {
  margin-top: 14px;
  padding: 14px 16px;
  background: var(--steel-lighter);
  border-radius: var(--radius);
  border-left: 3px solid var(--bronze);
  display: flex;
  justify-content: space-between;
  align-items: baseline;
}

.knife-total-label {
  font-family: 'PT Serif', serif;
  color: var(--bamboo);
  font-weight: 700;
  letter-spacing: 0.5px;
}

.knife-total-value {
  font-family: 'PT Serif', serif;
  color: var(--paper);
  font-size: 22px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}

/* Статус-бар внизу обработки Ножа */
.process-status-bar {
  margin-top: 24px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  align-items: stretch;
}

.process-status-bar .btn { width: 100%; }

.process-status-done {
  text-align: center;
  font-family: 'PT Serif', serif;
  font-weight: 700;
  font-size: 18px;
  color: var(--bronze);
  padding: 14px;
  background: rgba(139,111,71,0.12);
  border-radius: var(--radius);
  border: 1px solid rgba(139,111,71,0.4);
  letter-spacing: 2px;
  text-transform: uppercase;
}

/* === Form === */
.view-form { padding: 20px 20px 80px; }

.field-group {
  border: none;
  margin-bottom: 24px;
}

.field-group-title {
  font-family: 'Inter', sans-serif;
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--bamboo);
  margin-bottom: 12px;
  padding-left: 2px;
}

.field {
  display: block;
  margin-bottom: 12px;
}

.field-label {
  display: block;
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  color: var(--text-muted);
  margin-bottom: 6px;
  letter-spacing: 0.3px;
}

.field-label .hint {
  font-style: italic;
  color: rgba(245,239,224,0.4);
  font-size: 11px;
}

.field input,
.field select,
.field textarea {
  width: 100%;
  background: var(--field-bg);
  border: 1px solid var(--field-border);
  border-radius: var(--radius);
  padding: 12px 14px;
  color: var(--paper);
  font-family: 'Inter', sans-serif;
  font-size: 15px;
  outline: none;
  transition: border-color 0.15s;
  -webkit-appearance: none;
  appearance: none;
}

.field input:focus,
.field select:focus,
.field textarea:focus {
  border-color: var(--field-border-focus);
}

.field textarea { resize: vertical; min-height: 60px; }

.field select {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'><path d='M1 1l5 5 5-5' stroke='%23C9B186' stroke-width='1.5' stroke-linecap='round'/></svg>");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 36px;
}

.field-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

/* === Knife block (форма) === */
.knife-block {
  background: var(--steel-darker);
  border-radius: var(--radius);
  border-left: 2px solid var(--blade);
  padding: 14px 16px;
  margin-bottom: 12px;
}

.knife-block-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px;
}

.knife-block-num {
  font-family: 'PT Serif', serif;
  font-weight: 700;
  font-size: 15px;
  color: var(--paper);
}

.btn-remove-knife {
  background: transparent;
  border: none;
  color: var(--text-muted);
  font-size: 22px;
  width: 28px;
  height: 28px;
  cursor: pointer;
  border-radius: 50%;
  transition: all 0.15s;
}

.btn-remove-knife:hover {
  background: rgba(200,32,44,0.15);
  color: var(--cinnabar);
}

.btn-add-knife {
  width: 100%;
  background: transparent;
  border: 1px dashed var(--field-border);
  border-radius: var(--radius);
  padding: 14px;
  font-family: 'Inter', sans-serif;
  font-size: 14px;
  color: var(--bamboo);
  cursor: pointer;
  transition: all 0.15s;
}

.btn-add-knife:hover {
  border-color: var(--bronze);
  color: var(--paper);
}

.btn-add-knife span {
  font-size: 18px;
  margin-right: 6px;
  vertical-align: middle;
}

.form-actions {
  display: flex;
  gap: 12px;
  margin-top: 24px;
}

.form-actions .btn { flex: 1; }

/* === Tabbar === */
.tabbar {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  height: var(--tabbar-h);
  display: flex;
  background: var(--steel);
  border-top: 1px solid rgba(176,181,186,0.08);
  z-index: 10;
}

.tab {
  flex: 1 1 0;
  min-width: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  padding: 4px 2px;
  background: transparent;
  border: none;
  color: rgba(176,181,186,0.55);
  cursor: pointer;
  transition: color 0.15s;
  overflow: hidden;
}

.tab:hover { color: var(--blade); }
.tab.active { color: var(--cinnabar); }

/* Когда форма открыта — скрыть нижнюю навигацию */
body[data-view="form-new-order"] .tabbar { display: none; }
body[data-view="form-new-order"] .content { padding-bottom: 20px; }

/* === Печатная область (PDF-акт) === */
.print-area { display: none; }

/* На экране page-break-divider невидим */
/* Схема Ножа в акте */
/* === Toast === */
.toast {
  position: fixed;
  bottom: calc(var(--tabbar-h) + 20px);
  left: 50%;
  transform: translateX(-50%);
  background: var(--steel-lighter);
  color: var(--paper);
  padding: 12px 24px;
  border-radius: var(--radius);
  border: 1px solid var(--bronze);
  font-family: 'Inter', sans-serif;
  font-size: 14px;
  z-index: 100;
  box-shadow: 0 4px 16px rgba(0,0,0,0.4);
  animation: toast-in 0.2s ease-out;
}

@keyframes toast-in {
  from { opacity: 0; transform: translate(-50%, 10px); }
  to   { opacity: 1; transform: translate(-50%, 0); }
}

/* === Desktop adaptation === */
@media (min-width: 768px) {
  body { background: #1c1e22; }

  /* .content — обычный block, центрируем через margin */
  .content {
    max-width: 520px;
    margin-left: auto;
    margin-right: auto;
    background: var(--steel);
    box-shadow: 0 0 0 1px rgba(176,181,186,0.06);
  }

  /* .topbar и .tabbar — fixed, центрируем через left+transform */
  .topbar, .tabbar {
    max-width: 520px;
    left: 50%;
    right: auto;
    transform: translateX(-50%);
    background: var(--steel);
  }

  /* Скрываем topbar формы в начальной позиции корректно (он тоже fixed) */
  .topbar-form { max-width: 520px; }

  .brand-name { font-size: 28px; letter-spacing: 7px; }
  .brand-name .ex { font-size: 32px; }
  .product-title { font-size: 44px; margin-bottom: 32px; }
  .empty-title { font-size: 26px; }
  .empty-slogan { font-size: 17px; }
  .empty-cta { font-size: 15px; }
  .btn { font-size: 15px; letter-spacing: 2.5px; padding: 18px 36px; }
  .btn-compact { padding: 10px 16px; font-size: 12px; }
  .tab-label { font-size: 12px; }
}

/* ════════════════════════════════════════════════════════════════════
   ЭТАП 1 — апгрейд визуала из дизайн-передачи Claude Design.
   Новые классы перекрывают старые селекторы по специфичности и порядку.
   ════════════════════════════════════════════════════════════════════ */

/* === Топбар (плоский, без shadow) === */
.tbar{
  position: fixed; top: 0; left: 0; right: 0;
  display: flex; align-items: center; gap: 6px;
  height: var(--topbar-h); padding: 0 12px;
  background: var(--bg);
  border-bottom: 1px solid var(--rule);
  z-index: 100;
}
.tbar-brand{
  font-family: 'Inter', sans-serif;
  font-weight: 800; font-size: 14px; letter-spacing: 0.36em;
  color: var(--cinnabar);
  text-transform: uppercase;
}
.tbar-title{
  flex: 1; font-weight: 600; font-size: 16px; letter-spacing: -0.01em;
  text-align: center; color: var(--text);
}
.tbar-btn{
  width: 40px; height: 40px;
  display: flex; align-items: center; justify-content: center;
  color: var(--text); background: transparent; border: 0; cursor: pointer;
  border-radius: 4px;
}
.tbar-btn:hover{ background: var(--bgHi); }
.tbar-btn:active{ background: var(--bgRaised); }

/* === Контент с учётом fixed-топбара/таббара ===
   Главные вьюхи без верхней панели, переопределение в form/order/process. */
.content{
  padding-top: env(safe-area-inset-top, 0);
  padding-bottom: var(--tabbar-h);
  min-height: 100vh;
}

/* === Таббар === */
.tabbar{
  position: fixed; bottom: 0; left: 0; right: 0;
  display: grid; grid-template-columns: repeat(7, 1fr);
  background: var(--bg);
  border-top: 1px solid var(--rule);
  padding-bottom: env(safe-area-inset-bottom);
  z-index: 100;
}
.tab{
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 2px; padding: 6px 1px 8px; cursor: pointer;
  color: var(--textDim); background: transparent; border: 0;
  position: relative; font-family: inherit;
  min-width: 0; /* чтобы grid-ячейка могла ужаться меньше контента */
}
.tab svg{ width: 20px; height: 20px; flex-shrink: 0; }
.tab span{
  font-size: 9.5px; letter-spacing: 0; font-weight: 500;
  max-width: 100%;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
/* На очень узких экранах (Android 5″) — прячем подписи, оставляем только иконки */
@media (max-width: 360px) {
  .tab span{ display: none; }
  .tab{ gap: 0; padding: 10px 0; }
  .tab svg{ width: 22px; height: 22px; }
}
.tab.active{ color: var(--text); }
.tab.active::before{
  content: ''; position: absolute; top: 0; left: 20%; right: 20%; height: 2px;
  background: var(--cinnabar);
}

/* === Карточки === */
.card{
  background: var(--bgRaised);
  border: 1px solid var(--rule);
  border-radius: 6px;
  padding: 14px;
  margin: 0 12px 10px;
}

/* === Кнопки (override старого .btn) === */
.btn{
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  height: 48px; padding: 0 18px;
  border-radius: 6px; border: 0;
  font-family: inherit; font-weight: 600; font-size: 14.5px;
  letter-spacing: 0.01em;
  cursor: pointer; text-transform: none;
}
.btn-primary{
  background: var(--bronze); color: #fff;
  box-shadow: inset 0 -2px 0 rgba(0,0,0,0.18), 0 1px 0 var(--ruleStrong);
}
.btn-primary:hover{ filter: brightness(1.05); }
.btn-ghost{
  background: transparent; color: var(--text);
  border: 1px solid var(--ruleStrong);
}
.btn-ghost:hover{ background: var(--bgHi); }
.btn-danger{
  background: transparent; color: var(--cinnabar);
  border: 1px solid var(--cinnabar);
}
.btn-block{ display: flex; width: 100%; }

/* === Формы (override) === */
.field{
  display: flex; flex-direction: column; gap: 5px;
  padding: 0;
}
.field-label{
  font-size: 11px; color: var(--textMuted); letter-spacing: 0.06em;
  text-transform: uppercase; font-weight: 600;
}
.field input, .field textarea, .field select,
input[type="text"], input[type="tel"], input[type="number"], input[type="date"],
input[type="month"], input[type="search"], textarea, select{
  width: 100%;
  background: var(--bgInput);
  border: 1px solid var(--rule);
  border-bottom: 1px solid var(--ruleStrong);
  color: var(--text);
  font-family: inherit; font-size: 14.5px;
  padding: 11px 12px; border-radius: 4px;
  outline: none;
}
.field input:focus, .field textarea:focus, .field select:focus,
input:focus, textarea:focus, select:focus{
  border-color: var(--bronze);
}
.field textarea, textarea{ min-height: 64px; resize: vertical; }

/* «бронзовая вспышка» при автоподстановке HRC из каталога */
@keyframes bronze-flash{
  0%   { background: var(--bgInput); }
  20%  { background: rgba(169,133,86,0.20); }
  100% { background: var(--bgInput); }
}
.field input.flash,
.field-autofilled input{ animation: bronze-flash 800ms ease-out; }

/* === Главная (splash) === */
.view-home{
  display: flex !important;
  flex-direction: column;
  padding: 18px 24px 24px;
  min-height: calc(100vh - var(--topbar-h) - var(--tabbar-h));
  background: var(--bg);
  text-align: left;
}
.view-home[hidden]{ display: none !important; }

.home-mark{
  display: flex; justify-content: center; align-items: baseline;
  padding: 8px 0 28px;
}
.home-brand-mark{
  font-family: 'Inter', sans-serif;
  font-weight: 800; font-size: 22px; letter-spacing: 0.36em;
  color: var(--cinnabar);
  text-transform: uppercase;
}

.home-brand{ position: relative; margin-bottom: 24px; }
.home-brand-name{
  font-family: 'PT Serif', serif; font-style: italic; font-weight: 400;
  font-size: 34px; color: var(--text);
  line-height: 1; letter-spacing: -0.01em;
}
.home-brand-rule{
  position: absolute; left: 0; bottom: -14px;
  width: 64px; height: 1px; background: var(--ruleWarm);
}

@keyframes knifeBreath{
  0%, 100% { transform: scaleX(-1) rotate(-22deg) translateY(0); }
  50%      { transform: scaleX(-1) rotate(-22deg) translateY(-3px); }
}
.home-knife{
  margin: 28px 0 36px;
  display: flex; justify-content: center; align-items: center;
  min-height: 160px; overflow: visible;
}
.home-knife-img{
  width: 94%; height: auto; display: block;
  transform-origin: center;
  filter: var(--knifeFilter);
  opacity: 0.92;
  animation: knifeBreath 6.5s ease-in-out infinite;
}

.home-voice{
  margin-top: 8px;
  font-size: 16px; color: var(--text);
  font-family: 'PT Serif', serif; font-style: italic;
  line-height: 1.35; letter-spacing: -0.005em;
}
.home-voice-meta{
  font-size: 11px; color: var(--textDim);
  margin-top: 8px; letter-spacing: 0.08em;
}
.home-cta{
  display: flex; flex-direction: column; gap: 8px;
  margin-top: auto; padding-top: 24px;
}
.home-cta-hint{
  font-size: 11.5px; text-align: center; margin-top: 2px;
}
.home-foot{
  margin-top: 18px; padding-top: 14px;
  border-top: 1px solid var(--ruleWarm);
  display: flex; justify-content: space-between; align-items: baseline;
  font-size: 10px; letter-spacing: 0.16em;
  color: var(--textDim); text-transform: uppercase;
}
.home-foot-ver{ color: var(--bronze); }

/* === Сегментный статус заказа === */
.stat-chip{
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 11px; font-weight: 500; letter-spacing: 0.02em;
  padding: 3px 8px; border-radius: 3px;
  background: transparent; border: 1px solid var(--ruleStrong);
  color: var(--textMuted);
}
.stat-chip.work{ color: var(--bronze); border-color: var(--bronzeDim); }
.stat-chip.done{ color: var(--blade); border-color: var(--ruleStrong); }
.stat-chip.paid{ color: var(--bamboo); border-color: var(--bamboo); opacity: 0.9; }

/* === Пилюли (справочники / переключатели) === */
.pill-row{
  display: flex; gap: 6px; padding: 10px 12px;
  overflow-x: auto;
  border-bottom: 1px solid var(--rule);
}
.pill{
  flex-shrink: 0; padding: 7px 14px; border-radius: 999px;
  border: 1px solid var(--rule); background: transparent;
  color: var(--textMuted); font-size: 12.5px; font-weight: 500;
  cursor: pointer; font-family: inherit;
}
.pill.on, .pill.ref-pill--active{
  color: var(--text); border-color: var(--bronze); background: var(--bgHi);
}

/* === Блоки этапов техкарты === */
.stage{
  background: var(--bgRaised);
  border: 1px solid var(--rule);
  border-left: 3px solid var(--rule);
  border-radius: 0 6px 6px 0;
  padding: 12px 14px;
  margin: 0 12px 6px 16px;
  position: relative;
}
.stage.done{ opacity: 0.75; border-left-color: var(--bamboo); }
.stage.active{
  border-left-color: var(--cinnabar);
  background: var(--bgHi);
  box-shadow: 0 0 0 1px rgba(216,51,63,0.25);
}

/* === Таймлайн истории Клинка === */
.timeline{
  position: relative;
  padding: 8px 16px 14px 32px;
}
.timeline::before{
  content: ''; position: absolute; left: 18px; top: 8px; bottom: 14px;
  width: 1px; background: var(--ruleWarm);
}
.tl-item{
  position: relative; padding: 8px 0;
  display: grid; grid-template-columns: auto 1fr auto; gap: 10px;
  font-size: 13px;
}
.tl-item::before{
  content: ''; position: absolute; left: -19px; top: 14px;
  width: 7px; height: 7px; background: var(--bronze);
  transform: rotate(45deg);
}
.tl-date{
  font-family: 'JetBrains Mono', monospace; font-size: 12px; color: var(--textMuted);
}
.tl-meta{ color: var(--text); }
.tl-meta em{
  font-style: normal; color: var(--bronze);
  font-family: 'JetBrains Mono', monospace;
}
.tl-scale{
  font-family: 'Inter', sans-serif; font-size: 11px; font-weight: 600;
  color: var(--bronze);
}

/* === Журнал (Этап 2) === */
.j-search-row{
  display: flex; gap: 8px;
  padding: 12px 12px 6px;
}
.j-search-input{
  flex: 1; display: flex; align-items: center; gap: 8px;
  height: 42px; padding: 0 12px;
  background: var(--bgInput);
  border: 1px solid var(--rule);
  border-radius: 4px;
  color: var(--textDim); font-size: 13px;
}
.j-new-btn{
  height: 42px; padding: 0 14px;
  font-size: 13px;
}

.j-group-head{
  display: flex; align-items: baseline; gap: 12px;
  padding: 14px 16px 6px;
  border-top: 1px solid var(--rule);
  background: var(--bg);
  position: sticky; top: var(--topbar-h); z-index: 1;
}
.j-group-date{
  font-size: 13px; font-weight: 600;
  color: var(--text); letter-spacing: 0.02em;
}
.j-group-meta{ font-size: 11px; }
.j-group-sum{
  font-size: 13px; color: var(--bronze); font-weight: 500;
}

.j-order{
  margin: 0 12px 8px;
  padding: 12px 14px;
  background: var(--bgRaised);
  border: 1px solid var(--rule);
  border-radius: 4px;
  display: grid; grid-template-columns: auto 1fr auto;
  gap: 12px; cursor: pointer;
  position: relative; overflow: hidden;
}
.j-order:hover{ border-color: var(--ruleStrong); }
.j-order-num{
  font-size: 22px; font-weight: 500;
  color: var(--text); line-height: 1; letter-spacing: -0.02em;
  align-self: center;
}
.j-order-name{ font-weight: 600; font-size: 14px; }
.j-order-tag{ font-size: 12px; margin-top: 2px; }
.j-order-meta{
  display: flex; gap: 8px; margin-top: 6px;
  font-size: 11.5px; color: var(--textMuted);
  align-items: center;
}
.j-order-meta .stat-chip{ padding: 0; border: 0; }
.j-order-right{
  display: flex; flex-direction: column; align-items: flex-end; gap: 6px;
}
.j-order-sum{ font-size: 14px; font-weight: 600; }

.j-empty{
  padding: 60px 24px;
  text-align: center;
}

/* === View-list: убираем общий padding .view — список сам управляет краями === */
.view-list{ padding: 0 0 30px !important; }

/* === Этап 3: форма приёмки (Intake) === */

/* Fieldset / legend стилизуем как fab-rule */
.view-form{
  padding: 0 0 20px;
}
.view-form fieldset.field-group{
  border: 0; padding: 0; margin: 0;
}
.view-form .field-group-title{
  display: flex; align-items: center; gap: 8px;
  font-family: 'JetBrains Mono', monospace; font-size: 10px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--textDim);
  padding: 14px 16px 6px;
  float: none; width: auto;
}
.view-form .field-group-title::before{
  content: ''; height: 1px; flex: 0 0 16px; background: var(--rule);
}

/* Поля внутри формы — в card-стиле */
.view-form .field-group > .field,
.view-form .field-group > .client-found-banner,
.view-form .field-group > .client-knives-history{
  margin: 0 12px 10px;
}
.view-form .field-group > .field{
  background: var(--bgRaised);
  border: 1px solid var(--rule);
  border-radius: 4px;
  padding: 12px 14px;
}

/* Knife-block — новая обёртка */
.knife-block{
  background: var(--bgRaised);
  border: 1px solid var(--rule);
  border-radius: 6px;
  margin: 0 12px 10px;
  overflow: hidden;
  padding: 0;
}
.knife-block-header{
  display: flex; align-items: center; gap: 10px;
  padding: 10px 14px;
  border-bottom: 1px solid var(--rule);
  background: var(--bgHi);
  margin-bottom: 0;
}
.knife-block-num{
  font-family: 'JetBrains Mono', monospace; font-size: 11px;
  color: var(--textDim); letter-spacing: 0.04em;
  font-weight: 500;
}
.knife-idx{
  display: inline-block; margin-left: 4px;
  color: var(--text); font-weight: 600;
}
.btn-remove-knife{
  width: 32px; height: 32px;
  display: flex; align-items: center; justify-content: center;
  background: transparent; border: 0; border-radius: 4px;
  color: var(--blood); cursor: pointer; font-size: 18px;
  margin-left: auto;
}
.btn-remove-knife:hover{ background: rgba(139,0,0,0.10); }

/* Внутри блока — поля */
.knife-block > .field,
.knife-block > .field-row{
  padding: 12px 14px 0;
}
.knife-block > .field:last-child{ padding-bottom: 14px; }
.knife-block .field-row{
  display: grid; grid-template-columns: 1fr 1fr; gap: 10px;
}
.knife-block .angle-typical-hint,
.knife-block .knife-type-hint{
  display: flex; align-items: center; gap: 6px;
  font-family: 'JetBrains Mono', monospace; font-size: 11.5px;
  color: var(--bronze);
  padding: 4px 14px 0;
}

/* Кнопка «+ Добавить новый Нож» */
.btn-add-knife{
  display: flex; align-items: center; justify-content: center; gap: 8px;
  width: calc(100% - 24px);
  margin: 4px 12px 14px;
  height: 44px;
  background: transparent;
  border: 1px dashed var(--ruleStrong);
  border-radius: 6px;
  color: var(--text); font-family: inherit; font-size: 14px;
  cursor: pointer;
}
.btn-add-knife:hover{ border-color: var(--bronze); color: var(--bronze); }
.btn-add-knife span{ font-size: 18px; line-height: 1; }

/* Кнопки внизу формы */
.form-actions{
  display: flex; gap: 8px;
  padding: 10px 12px 24px;
}
.form-actions .btn-secondary{
  flex: 1;
}
.form-actions .btn-primary{
  flex: 2;
}

/* Баннер «найден клиент» */
.client-found-banner{
  background: rgba(169,133,86,0.10);
  border: 1px solid var(--bronzeDim);
  border-radius: 4px;
  padding: 10px 12px;
  display: flex; gap: 10px; align-items: flex-start;
}
.client-found-icon{
  color: var(--bronze); font-weight: 700; font-size: 16px;
  flex-shrink: 0; margin-top: -1px;
}
.client-found-text{
  flex: 1; font-size: 13.5px;
}
.client-found-text strong{ font-weight: 600; }
.client-found-meta{
  display: block; font-family: 'JetBrains Mono', monospace;
  color: var(--textDim); font-size: 11px;
  margin-top: 2px; letter-spacing: 0.04em;
}

/* История Клинков клиента */
.client-knives-history .history-head{
  display: flex; align-items: baseline; justify-content: space-between;
  margin-bottom: 8px;
  font-family: 'JetBrains Mono', monospace; font-size: 10px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--textDim);
}
.client-knives-history .history-title{ color: var(--textMuted); }
.client-knives-history .history-grid{
  display: flex; flex-direction: column; gap: 0;
  background: var(--bgRaised);
  border: 1px solid var(--rule);
  border-radius: 4px;
  padding: 4px 0;
}
.client-knives-history .history-card{
  display: flex; align-items: center; gap: 12px;
  padding: 10px 14px;
  border-top: 1px solid var(--rule);
  cursor: pointer;
}
.client-knives-history .history-card:first-child{ border-top: 0; }
.client-knives-history .history-card input[type="checkbox"]{
  width: 18px; height: 18px; accent-color: var(--bronze);
  margin: 0;
}
.client-knives-history .history-card-body{ flex: 1; }
.client-knives-history .history-card-name{
  font-size: 14px; font-weight: 500;
}
.client-knives-history .history-card-meta{
  font-family: 'JetBrains Mono', monospace; font-size: 11.5px;
  color: var(--textMuted); margin-top: 2px;
}
.client-knives-history .history-card-last{
  font-family: 'JetBrains Mono', monospace; font-size: 11px;
  color: var(--textDim); margin-top: 1px;
}
.client-knives-history .history-card--checked{ background: rgba(169,133,86,0.08); }

.o-head{ padding: 14px 16px 8px; }
.o-head-top{
  display: flex; align-items: baseline; gap: 14px;
}
.o-num{
  font-family: 'JetBrains Mono', monospace;
  font-size: 34px; font-weight: 500;
  color: var(--text); letter-spacing: -0.02em; line-height: 1;
}
.o-client{ flex: 1; }
.o-client-name{ font-size: 14px; font-weight: 600; }
.o-client-tag{ font-size: 12px; margin-top: 1px; }
.o-head-meta{
  display: flex; gap: 14px; margin-top: 14px;
  font-size: 12px; color: var(--textMuted);
  align-items: center; flex-wrap: wrap;
}
.o-progress{
  margin-top: 12px; height: 3px;
  background: var(--rule); border-radius: 2px; overflow: hidden;
}
.o-progress-fill{
  height: 100%;
  background: linear-gradient(90deg, var(--bronze), var(--blade));
  transition: width 200ms ease;
}

.o-list{ margin: 0 12px; }
.o-knife{
  display: grid; grid-template-columns: 34px 1fr auto; gap: 10px;
  padding: 12px;
  border-bottom: 1px solid var(--rule);
  position: relative; cursor: pointer;
}
.o-knife:first-child{ border-top: 1px solid var(--rule); }
.o-knife::before{
  content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
  background: var(--rule);
}
.o-knife.done::before{ background: var(--bamboo); }
.o-knife.active::before{ background: var(--cinnabar); }
.o-knife.active{ background: rgba(216,51,63,0.06); }
.o-knife-idx{
  font-family: 'JetBrains Mono', monospace; font-size: 13;
  color: var(--textMuted); font-weight: 500;
  align-self: center; padding-left: 6px;
}
.o-knife.done .o-knife-idx{ color: var(--bamboo); }
.o-knife-line{
  display: flex; align-items: baseline; gap: 8px; flex-wrap: wrap;
}
.o-knife-name{
  font-size: 14px; font-weight: 600; color: var(--text);
}
.o-knife.done .o-knife-name{ color: var(--textMuted); }
.o-knife-tech{
  font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--textDim);
}
.o-knife-state{
  font-size: 12px; color: var(--textDim); margin-top: 2px;
}
.o-knife-right{
  display: flex; flex-direction: column; align-items: flex-end; gap: 6px;
  align-self: center;
}
.o-knife-final{
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px; color: var(--bronze); font-weight: 600; letter-spacing: 0.04em;
}
.o-knife-chev{
  color: var(--textDim);
  width: 16px; height: 16px; flex-shrink: 0;
}

/* Расчёт + оплата */
.o-calc{ margin: 0 12px; }
.o-calc-row{
  display: flex; justify-content: space-between; align-items: baseline;
  margin-bottom: 10px;
}
.o-calc-label{ color: var(--textMuted); font-size: 13px; }
.o-calc-val{ font-family: 'JetBrains Mono', monospace; font-size: 14px; }
.o-calc-total{
  display: flex; justify-content: space-between; align-items: baseline;
}
.o-calc-total-lbl{ font-size: 14px; font-weight: 600; }
.o-calc-total-val{
  font-family: 'JetBrains Mono', monospace;
  font-size: 24px; font-weight: 600; color: var(--bronze);
}

.o-actions{
  display: flex; gap: 8px; padding: 10px 12px;
}
.o-actions .btn{ flex: 1; }

/* ════════════════════════════════════════════════════════════════
   АДАПТИВНОСТЬ: три брейкпойнта + «сцена» на широких экранах
   - mobile (<768px):  фрейм во весь экран, всё прижато к краям
   - tablet (768+):    фрейм 560px по центру
   - laptop (1100+):   фрейм 640px + «сцена» с градиентами
   - desktop (1440+):  фрейм 720px + маркировка по углам
   ════════════════════════════════════════════════════════════════ */

/* === Сцена вокруг фрейма (на десктопе видна) === */
@media (min-width: 768px) {
  body {
    background:
      radial-gradient(ellipse at top, rgba(169,133,86,0.07), transparent 55%),
      radial-gradient(ellipse at bottom right, rgba(216,51,63,0.05), transparent 55%),
      #0d0e11;
  }
  :root[data-theme="light"] body {
    background:
      radial-gradient(ellipse at top, rgba(139,111,71,0.10), transparent 55%),
      radial-gradient(ellipse at bottom right, rgba(200,32,44,0.05), transparent 55%),
      #DAD3C2;
  }

  .tbar,
  .tabbar {
    left: 50%;
    right: auto;
    max-width: 560px;
    width: 100%;
    transform: translateX(-50%);
    box-shadow: 0 0 0 1px var(--rule);
  }
  .content {
    max-width: 560px;
    margin-left: auto;
    margin-right: auto;
    box-shadow:
      0 0 0 1px var(--rule),
      0 8px 32px rgba(0,0,0,0.35);
  }
  .j-group-head {
    max-width: 560px;
    margin: 0 auto;
  }
}

/* === Laptop: фрейм комфортнее === */
@media (min-width: 1100px) {
  .tbar,
  .tabbar {
    max-width: 640px;
  }
  .content {
    max-width: 640px;
  }
  .j-group-head {
    max-width: 640px;
  }
}

/* === Desktop: ещё шире + угловые маркировки === */
@media (min-width: 1440px) {
  .tbar,
  .tabbar {
    max-width: 720px;
  }
  .content {
    max-width: 720px;
  }
  .j-group-head {
    max-width: 720px;
  }
  /* Маркировка по углам сцены — фабричный декор */
  body::before {
    content: 'путь ножа · android · pwa';
    position: fixed; top: 16px; left: 50%; transform: translateX(-50%);
    font-family: 'JetBrains Mono', monospace;
    font-size: 9.5px; letter-spacing: 0.32em;
    text-transform: uppercase;
    color: rgba(216,51,63,0.30);
    z-index: 1;
    pointer-events: none;
  }
  body::after {
    content: 'каждый Клинок помнит своего Мастера';
    position: fixed; bottom: 16px; left: 50%; transform: translateX(-50%);
    font-family: 'PT Serif', serif; font-style: italic;
    font-size: 11px;
    color: rgba(176,181,186,0.20);
    z-index: 1;
    pointer-events: none;
  }
}

/* На print — скрываем декор сцены */
@media print {
  body::before, body::after { display: none !important; }
  body { background: #fff !important; }
}

/* ════════════════════════════════════════════════════════════════
   ЭТАП 4 — Tech (техкарта), Refs (справочники), Profile, Calc.
   ════════════════════════════════════════════════════════════════ */

/* === Справочники: контейнер == */
.view-tables{ padding: 0 0 30px; }

/* Pill-row уже определён в Этапе 1. Дополню для табличной зоны Refs. */

/* Зернистости — реестровая сетка 4 колонок */
.r-grit-block{
  margin: 0 12px 10px;
  border: 1px solid var(--rule);
  border-radius: 4px;
  overflow: hidden;
}
.r-grit-head{
  display: grid; grid-template-columns: 1fr 1fr 1fr 1fr;
  padding: 8px 10px;
  background: var(--bgHi);
  font-family: 'JetBrains Mono', monospace; font-size: 10.5px;
  color: var(--textMuted); letter-spacing: 0.1em; text-transform: uppercase;
}
.r-grit-row{
  display: grid; grid-template-columns: 1fr 1fr 1fr 1fr;
  padding: 10px;
  font-family: 'JetBrains Mono', monospace; font-size: 13px;
  border-top: 1px solid var(--rule);
}
.r-grit-row:nth-child(odd){ background: var(--bgRaised); }
.r-grit-row .grit-fepa{ color: var(--bronze); font-weight: 600; }

/* Стали — карточки */
.r-steel{
  background: var(--bgRaised);
  border: 1px solid var(--rule);
  border-radius: 6px;
  margin: 0 12px 10px;
  padding: 14px;
}
.r-steel-head{
  display: flex; align-items: baseline; gap: 10px; margin-bottom: 10px;
  flex-wrap: wrap;
}
.r-steel-mark{
  font-family: 'JetBrains Mono', monospace;
  font-size: 16px; font-weight: 600; color: var(--text);
}
.r-steel-hrc{
  font-family: 'JetBrains Mono', monospace; font-size: 11px;
  color: var(--textDim);
}
.r-steel-use{ font-size: 11.5px; color: var(--textMuted); }
.r-steel-comp{
  font-family: 'JetBrains Mono', monospace; font-size: 11.5px;
  color: var(--textMuted); margin-bottom: 8px; line-height: 1.4;
}
.r-steel-props{
  display: grid; grid-template-columns: 1fr 1fr; gap: 4px 14px;
}
.r-steel-prop{
  display: flex; align-items: center; gap: 8px; font-size: 11px;
}
.r-steel-prop-lbl{ width: 56px; color: var(--textDim); }
.r-steel-prop-bar{
  flex: 1; display: flex; gap: 1.5px; min-width: 0;
}
.r-steel-prop-bar > i{
  flex: 1; height: 5px; background: var(--rule);
  display: block;
}
.r-steel-prop-bar > i.on{ background: var(--bronze); }
.r-steel-prop-val{
  font-family: 'JetBrains Mono', monospace; font-size: 11px;
  width: 14px; color: var(--bronze); text-align: right;
}
.r-steel-eq{
  font-family: 'JetBrains Mono', monospace; font-size: 11px;
  color: var(--textDim); margin-top: 8px; padding-top: 8px;
  border-top: 1px solid var(--rule);
}

/* Поиск по сталям */
.r-steels-filter{
  margin: 10px 12px 14px;
  width: calc(100% - 24px);
}

/* Углы — таблица 3 колонки */
.r-angles{
  margin: 0 12px 14px;
  border: 1px solid var(--rule);
  border-radius: 4px; overflow: hidden;
}
.r-angles-head{
  display: grid; grid-template-columns: 1.4fr 1fr 1fr;
  padding: 10px 12px; background: var(--bgHi);
  font-family: 'JetBrains Mono', monospace; font-size: 10.5px;
  color: var(--textMuted); letter-spacing: 0.1em; text-transform: uppercase;
}
.r-angles-row{
  display: grid; grid-template-columns: 1.4fr 1fr 1fr; align-items: center;
  padding: 11px 12px; font-size: 13px;
  border-top: 1px solid var(--rule);
}
.r-angles-row:nth-child(odd){ background: var(--bgRaised); }
.r-angles-row .full{ font-family: 'JetBrains Mono', monospace; font-weight: 500; }
.r-angles-row .side{ font-family: 'JetBrains Mono', monospace; color: var(--bronze); font-weight: 500; }

/* Абразивы — карточки */
.r-abr-card{
  background: var(--bgRaised);
  border: 1px solid var(--rule); border-radius: 6px;
  padding: 12px 14px;
  margin: 0 12px 8px;
}
.r-abr-head{
  display: flex; align-items: baseline; gap: 10px;
}
.r-abr-name{ font-size: 14px; font-weight: 600; }
.r-abr-note{
  font-family: 'PT Serif', serif; font-style: italic; font-size: 11.5px;
  color: var(--bronze); margin-top: 3px;
}
.r-paste{
  display: flex; justify-content: space-between; align-items: baseline;
  margin: 0 12px; padding: 10px 0;
  border-bottom: 1px solid var(--rule);
}
.r-paste-name{ font-size: 13.5px; }
.r-paste-meta{ font-size: 11.5px; color: var(--textDim); font-family: 'JetBrains Mono', monospace; }

.p-head{
  padding: 18px 16px 14px; text-align: center;
  border-bottom: 1px solid var(--rule);
}
.p-avatar{
  width: 88px; height: 88px; margin: 0 auto 12px;
  border: 1.5px solid var(--bronze); border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-family: 'PT Serif', serif; font-style: italic;
  font-size: 30px; font-weight: 700; color: var(--bronze);
}
.p-name{ font-size: 18px; font-weight: 600; }
.p-tag{
  font-family: 'PT Serif', serif; font-style: italic;
  font-size: 13px; margin-top: 2px; color: var(--bronze);
}

.p-row{
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 14px;
  border-top: 1px solid var(--rule);
}
.p-row:first-child{ border-top: 0; }
.p-row-body{ flex: 1; min-width: 0; padding-right: 12px; }
.p-row-label{
  font-family: 'JetBrains Mono', monospace; font-size: 10px;
  letter-spacing: 0.08em; text-transform: uppercase; color: var(--textDim);
}
.p-row-val{
  font-size: 14px; margin-top: 2px;
}
.p-row-val input,
.p-row-val textarea,
.p-row-val select{
  background: transparent; border: 0; padding: 0;
  font-size: 14px; color: var(--text);
  width: 100%;
}
.p-row-val input:focus,
.p-row-val textarea:focus,
.p-row-val select:focus{ border: 0; outline: none; }

.p-scale-grid{
  display: grid; grid-template-columns: 1fr 1fr 1fr 1fr; gap: 4px;
}
.p-scale-grid .pill{
  padding: 10px 6px; text-align: center; flex: unset;
}

.p-rates{
  display: grid; grid-template-columns: 1fr 1fr; gap: 14px;
}

/* === Calc === */
.view-calc{ padding: 0 0 24px; }

.c-result{
  padding: 16px;
}
.c-result-meta{
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--textDim); margin-bottom: 10px; text-align: center;
}
.c-length-row{ display: flex; align-items: baseline; gap: 8px; }
.c-length-input{ flex: 1; min-width: 0; font-size: 18px; }
.c-length-unit{
  font-family: 'JetBrains Mono', monospace; font-size: 12px;
  color: var(--textDim); letter-spacing: 0.06em;
}
.c-kbutton-row{
  display: flex; flex-wrap: wrap; gap: 6px;
}
.c-kbutton{
  flex: 1 1 auto; min-width: 72px; padding: 8px 8px; text-align: center; font-size: 11.5px;
}
.c-kbutton .mono{ font-size: 10px; margin-top: 2px; display: block; }
.c-extra{ flex: 1 1 calc(50% - 6px); }
.c-extra[disabled]{ opacity: 0.4; cursor: not-allowed; }

.c-breakdown{
  width: 100%; border-collapse: collapse;
  font-family: 'JetBrains Mono', monospace; font-size: 11.5px;
}
.c-breakdown tr{ border-bottom: 1px dashed var(--rule); }
.c-breakdown tr:last-child{ border-bottom: 0; }
.c-breakdown td{ padding: 6px 0; vertical-align: top; }
.c-row-lbl{
  font-family: 'Inter', sans-serif; font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.06em;
  color: var(--text); width: 50%;
}
.c-row-lbl .dim{ text-transform: none; letter-spacing: 0; }
.c-row-val{ color: var(--textDim); text-align: right; padding-right: 12px !important; white-space: nowrap; }
.c-row-sum{ color: var(--text); text-align: right; white-space: nowrap; }

.c-result-total{
  display: flex; justify-content: space-between; align-items: baseline;
  margin-top: 12px; padding-top: 12px;
  border-top: 1.5px solid var(--ruleStrong);
}
.c-result-total-lbl{
  font-family: 'Inter', sans-serif; font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.12em; color: var(--text);
}
.c-result-total-val{
  font-size: 28px; font-weight: 600; color: var(--bronze); letter-spacing: -0.01em;
}

/* === Помощник по абразивам === */
.helper-hrc-slider{
  width: 100%; margin-top: 8px;
  accent-color: var(--bronze);
}
.helper-hrc-marks{
  display: flex; justify-content: space-between;
  font-size: 10px; margin-top: 2px;
}

.helper-result{
  padding: 14px 14px 18px;
}
.helper-result-head{
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 12px; padding-bottom: 10px;
  border-bottom: 1.5px solid var(--ruleStrong);
}
.helper-result-title{
  font-family: 'Inter', sans-serif; font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.12em; color: var(--text);
}
.helper-set-badge{
  font-family: 'JetBrains Mono', monospace; font-size: 10px;
  text-transform: uppercase; letter-spacing: 0.08em;
  padding: 3px 8px; border-radius: 0;
  border: 1px solid var(--ruleStrong);
}
.helper-set-hard  { color: var(--cinnabar); border-color: var(--cinnabar); }
.helper-set-mixed { color: var(--bronze);   border-color: var(--bronze); }
.helper-set-soft  { color: var(--textDim);  border-color: var(--rule); }

.helper-stages{
  display: flex; flex-direction: column; gap: 14px;
}
.helper-stage{
  padding: 10px 0; border-bottom: 1px dashed var(--rule);
}
.helper-stage:last-child{ border-bottom: 0; }
.helper-stage-head{
  display: flex; align-items: baseline; gap: 8px;
  margin-bottom: 6px;
}
.helper-stage-num{
  font-size: 11px; color: var(--bronzeDim); font-weight: 600;
}
.helper-stage-name{
  font-family: 'PT Serif', serif; font-size: 15px; color: var(--text);
  flex: 1;
}
.helper-stage-mkm{ font-size: 10px; }
.helper-stage-grit{
  font-size: 11.5px; color: var(--text);
  display: flex; gap: 6px; align-items: baseline;
  margin-bottom: 8px;
}
.helper-stage-grit .grit-fepa{ color: var(--cinnabar); font-weight: 600; }
.helper-stage-abr{
  display: flex; flex-wrap: wrap; gap: 6px;
}
.helper-abr-chip{
  font-family: 'Inter', sans-serif; font-size: 11px;
  padding: 3px 7px;
  border: 1px solid var(--rule); color: var(--textDim);
  background: transparent;
}

/* Подсказка «из твоего пула» под этапом */
.helper-pool-line{
  display: flex; flex-wrap: wrap; align-items: baseline;
  gap: 4px 8px; margin-top: 8px;
  padding-top: 6px; border-top: 1px dashed var(--rule);
}
.helper-pool-label{
  font-size: 9px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--bronze); font-weight: 700;
}
.helper-pool-chip{
  font-family: 'Inter', sans-serif; font-size: 11px;
  padding: 3px 7px;
  border: 1px solid var(--bronze); color: var(--bronze);
  background: rgba(169,133,86,0.06);
}
.helper-pool-empty{ font-size: 11px; color: var(--textDim); font-style: italic; }

/* === Вкладка «Моё» === */
.view-mine{ padding: 0 0 24px; }

.mine-knife-card{
  background: var(--bgRaised);
  border: 1px solid var(--rule);
  border-left: 3px solid var(--bronze);
  padding: 12px 14px;
  margin-bottom: 10px;
}
.mine-knife-head{
  display: flex; justify-content: space-between; align-items: baseline; gap: 10px;
  margin-bottom: 6px;
}
.mine-knife-name{
  font-family: 'PT Serif', serif; font-size: 15px; font-weight: 700; color: var(--text);
  flex: 1; min-width: 0;
}
.mine-knife-actions{ display: flex; gap: 4px; }
.mine-knife-edit, .mine-knife-del{
  width: 28px; height: 28px;
  background: transparent; border: 1px solid var(--rule);
  color: var(--textDim); cursor: pointer; border-radius: 3px;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 16px;
}
.mine-knife-edit:hover{ color: var(--bronze); border-color: var(--bronze); }
.mine-knife-del{ color: var(--blood); }
.mine-knife-del:hover{ background: rgba(139,0,0,0.10); }
.mine-knife-meta{
  font-size: 11.5px; color: var(--textDim);
  letter-spacing: 0.04em;
  margin-bottom: 6px;
}
.mine-knife-angle{
  font-size: 12px; color: var(--text);
  padding-top: 4px; border-top: 1px dashed var(--rule);
}
.mine-knife-angle b{ color: var(--bronze); }
.mine-knife-finish{
  font-size: 12px; color: var(--text);
  margin-top: 4px; line-height: 1.4;
}

.mine-knife-log-row{
  margin-top: 10px; padding-top: 8px;
  border-top: 1px dashed var(--rule);
  display: flex; justify-content: flex-end;
}
.mine-knife-log-btn{
  padding: 6px 12px; font-size: 12px;
  display: inline-flex; align-items: center; gap: 6px;
}

.mine-log-form{
  margin-top: 10px; padding-top: 10px;
  border-top: 1px solid var(--bronze);
}
.mine-log-title{
  font-family: 'PT Serif', serif; font-size: 13px; font-weight: 700;
  color: var(--bronze); margin-bottom: 8px;
}
.mine-log-fields{
  display: grid; grid-template-columns: 1fr 1fr; gap: 10px;
}
.mine-log-actions{
  display: flex; gap: 8px; margin-top: 12px;
  justify-content: flex-end;
}
.mine-log-actions .btn{ min-width: 110px; }
.mine-knife-photos{
  display: grid; grid-template-columns: repeat(auto-fill, minmax(96px, 1fr));
  gap: 6px; margin-top: 10px;
}
.mine-knife-photo{
  position: relative;
  background: var(--bgInput);
  border: 1px solid var(--rule);
  overflow: hidden;
}
.mine-knife-photo img{
  width: 100%; height: 90px; object-fit: cover; cursor: zoom-in;
  display: block;
}
.mine-knife-photo-cap{
  position: absolute; left: 0; right: 0; bottom: 0;
  font-size: 9.5px; padding: 3px 5px; background: rgba(0,0,0,0.55);
  color: #fff; letter-spacing: 0.02em;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}

/* Сетка фото в форме редактирования Ножа */
.mine-photos-block{ margin-top: 14px; }
.mine-photos-grid{
  display: grid; grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
  gap: 8px; margin: 8px 0 10px;
}
.mine-photos-empty{
  grid-column: 1 / -1;
  text-align: center; font-size: 12px; padding: 14px 8px;
}
.mine-photo{
  position: relative;
  background: var(--bgInput);
  border: 1px solid var(--rule);
}
.mine-photo img{
  width: 100%; height: 100px; object-fit: cover; cursor: zoom-in;
  display: block;
}
.mine-photo-caption{
  width: 100%; box-sizing: border-box;
  background: var(--bgRaised); border: 0; border-top: 1px solid var(--rule);
  padding: 5px 7px; font-size: 11px; color: var(--text);
  font-family: 'Inter', sans-serif;
}
.mine-photo-remove{
  position: absolute; top: 4px; right: 4px;
  width: 22px; height: 22px;
  background: rgba(0,0,0,0.6); color: #fff; border: 0;
  border-radius: 50%; cursor: pointer; font-size: 14px;
  line-height: 1; display: inline-flex; align-items: center; justify-content: center;
}
.mine-photo-remove:hover{ background: var(--blood); }
.mine-photo-add{ position: relative; }
.mine-photo-add input[type="file"]{
  position: absolute; opacity: 0; pointer-events: none;
}

/* === Микроскопия РК (техкарта) === */
.t-micro-wrap{
  position: relative;
  padding: 8px 0 12px;
}
.t-micro-img{
  width: 100%; max-width: 320px;
  display: block; margin: 0 auto 8px;
  border: 1px solid var(--rule);
  cursor: zoom-in;
}
.t-micro-caption{
  width: 100%; box-sizing: border-box;
  background: var(--bgInput); border: 1px solid var(--rule);
  border-radius: 3px;
  padding: 8px 10px; font-size: 12.5px; color: var(--text);
  font-family: 'Inter', sans-serif;
}
.t-micro-rem{
  position: absolute; top: 8px; right: 8px;
  width: 24px; height: 24px;
  background: rgba(0,0,0,0.6); color: #fff; border: 0;
  border-radius: 50%; cursor: pointer; font-size: 14px;
  display: inline-flex; align-items: center; justify-content: center;
}
.t-micro-rem:hover{ background: var(--blood); }

/* === Микроскопия в Акте (§02 строка Клинка) === */
.akt-knife-micro{
  margin-top: 6px;
  display: flex; align-items: center; gap: 8px;
  padding-top: 6px; border-top: 1px dashed var(--bronze-l);
}
.akt-knife-micro img{
  width: 70px; height: 70px; object-fit: cover;
  border: 1px solid var(--ink-3);
  display: block;
}
.akt-knife-micro-cap{
  font-size: 9px; letter-spacing: 0.14em; color: var(--bronze-d);
  text-transform: uppercase; font-weight: 700;
  flex: 1;
}
.mine-knife-finish .mono{ font-size: 10.5px; letter-spacing: 0.08em; text-transform: uppercase; }
.mine-knife-notes{
  font-size: 12px; color: var(--textDim);
  margin-top: 6px; line-height: 1.4;
}

.mine-knife-form{ padding: 14px 16px 16px; margin-bottom: 10px; }
.mine-form-title{
  font-family: 'PT Serif', serif; font-size: 14px; font-weight: 700;
  color: var(--bronze); margin-bottom: 10px;
  padding-bottom: 6px; border-bottom: 1px solid var(--bronze);
}
.mine-form-row{
  display: grid; grid-template-columns: 1fr 1fr; gap: 10px;
  margin-top: 8px;
}
.mine-form-row:has(.field:nth-child(3)){
  grid-template-columns: 1fr 1fr 1fr;
}
.mine-form-actions{
  display: flex; gap: 8px; margin-top: 14px;
  justify-content: flex-end;
}
.mine-form-actions .btn{ min-width: 100px; }

/* === Каталог абразивов (Apex-формат) === */
.pill-row--sub{ margin-bottom: 10px; }
.abr-search-row{ margin-bottom: 10px; }
.abr-search-input{
  width: 100%; padding: 10px 12px;
  background: var(--bgInput); border: 1px solid var(--rule);
  border-radius: 3px; color: var(--text); font-size: 13.5px;
  font-family: 'Inter', sans-serif;
}
.abr-maker-pills{
  display: flex; flex-wrap: wrap; gap: 4px; margin-bottom: 14px;
}
.abr-maker-pills .pill{ font-size: 11.5px; padding: 5px 9px; }

.abr-maker-group{ margin-bottom: 18px; }
.abr-maker-head{
  border-bottom: 1px solid var(--bronze); padding-bottom: 4px; margin-bottom: 6px;
}
.abr-maker-name{
  font-family: 'PT Serif', serif; font-size: 15px; font-weight: 700; color: var(--text);
}
.abr-line{ margin-bottom: 10px; }
.abr-line-head{
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 4px 0; gap: 8px;
  font-size: 11.5px;
}
.abr-line-name{ color: var(--text); font-weight: 600; }
.abr-line-meta{ font-size: 10.5px; }

.abr-row{
  display: grid; grid-template-columns: 22px 1fr; gap: 10px;
  padding: 8px 6px; cursor: pointer;
  border-bottom: 1px dashed var(--rule);
  align-items: start;
}
.abr-row:last-child{ border-bottom: 0; }
.abr-row.on{ background: rgba(169,133,86,0.08); }
.abr-row-cb{ width: 18px; height: 18px; accent-color: var(--bronze); margin-top: 1px; }
.abr-row-body{ min-width: 0; }
.abr-row-main{
  display: flex; flex-wrap: wrap; gap: 4px 10px; align-items: baseline;
  font-size: 11.5px;
}
.abr-row-grit{
  font-size: 13px; font-weight: 700; color: var(--text); letter-spacing: 0.02em;
}
.abr-row-sys{ font-size: 10px; text-transform: uppercase; letter-spacing: 0.06em; }
.abr-row-color{ font-size: 11px; color: var(--bronze); }
.abr-row-mkm{ font-size: 11px; }
.abr-row-stage{
  font-size: 9.5px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--bronze);
}
.abr-row-note{ font-size: 11px; margin-top: 2px; line-height: 1.35; }

.abr-row--nat .abr-row-grit{ font-size: 14px; }

.abr-add-card{ padding: 12px 14px; }

.abr-pool-stage{ margin-bottom: 12px; }
.abr-pool-stage-head{
  font-size: 9.5px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--bronze); font-weight: 700; padding: 6px 0 4px;
  border-bottom: 1px solid var(--bronze);
}
.abr-pool-item{
  display: flex; justify-content: space-between; align-items: center;
  padding: 8px 4px; border-bottom: 1px dashed var(--rule);
  font-size: 12px;
}
.abr-pool-item:last-child{ border-bottom: 0; }
.abr-pool-name{ font-size: 13px; }
.abr-pool-remove{
  width: 26px; height: 26px;
  background: transparent; border: 0;
  color: var(--blood); cursor: pointer; font-size: 16px;
  border-radius: 3px;
}
.abr-pool-remove:hover{ background: rgba(139,0,0,0.10); }

.t-head{ padding: 14px 16px 10px; }
.t-head-row{ display: flex; align-items: flex-start; gap: 14px; }
.t-stamp{
  width: 54px; height: 54px; flex-shrink: 0;
  border: 1.5px solid var(--ruleStrong);
  background: var(--bgInput);
  position: relative; overflow: hidden;
  display: flex; align-items: center; justify-content: center;
}
.t-stamp img{
  width: 88%;
  transform: scaleX(-1) rotate(-22deg);
  filter: var(--knifeFilter);
  opacity: 0.85;
}
.t-stamp-code{
  position: absolute; left: 3px; top: 2px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 8px; color: var(--bronze); letter-spacing: 0.06em;
}

.t-head-info{ flex: 1; min-width: 0; }
.t-head-line{ display: flex; align-items: baseline; gap: 8px; flex-wrap: wrap; }
.t-name{
  font-size: 22px; font-weight: 600; letter-spacing: -0.01em;
}
.t-id{ font-family: 'JetBrains Mono', monospace; font-size: 12px; color: var(--textDim); }
.t-voice{
  font-family: 'PT Serif', serif; font-style: italic;
  margin: 6px 0 0;
  font-size: 13px; color: var(--bronzeDim);
}

.t-params{
  margin-top: 14px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 0;
  border: 1px solid var(--rule); border-radius: 4px; overflow: hidden;
}
.t-param{
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 9px 12px;
  font-size: 13px;
}
.t-param.bt{ border-top: 1px solid var(--rule); }
.t-param.br{ border-right: 1px solid var(--rule); }
.t-param-key{
  font-family: 'JetBrains Mono', monospace; font-size: 11px;
  letter-spacing: 0.04em; text-transform: uppercase; color: var(--textDim);
}
.t-param-val{
  font-family: 'JetBrains Mono', monospace; font-weight: 500;
}

/* === Tech: stage-block override (поверх существующей логики) === */
.stage-block{
  background: var(--bgRaised);
  border: 1px solid var(--rule);
  border-left: 3px solid var(--rule);
  border-radius: 0 6px 6px 0;
  padding: 12px 14px;
  margin: 0 12px 6px 16px;
  position: relative;
  list-style: none;
}
.stage-block--finish{ border-left-color: var(--bronze); }
.stage-block-header{
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 8px;
  background: transparent; padding: 0; border: 0;
}
.stage-idx{
  font-family: 'JetBrains Mono', monospace; font-size: 11px;
  letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--textMuted);
}
.stage-num{
  display: inline-block; color: var(--text); font-weight: 600;
  margin: 0 4px;
}
.stage-cat{
  color: var(--bronze); font-style: italic;
  font-family: 'PT Serif', serif; font-size: 12px;
  text-transform: lowercase; letter-spacing: 0;
}
.btn-remove-stage{
  width: 28px; height: 28px;
  display: flex; align-items: center; justify-content: center;
  background: transparent; border: 0;
  color: var(--blood); cursor: pointer;
  border-radius: 4px;
  font-size: 16px;
}
.btn-remove-stage:hover{ background: rgba(139,0,0,0.10); }

.stage-block .field-row{
  display: grid; grid-template-columns: 1fr 1fr; gap: 10px;
  margin-top: 6px;
}
.grit-eq-line{
  display: flex; flex-wrap: wrap; gap: 10px;
  margin-top: 6px; padding: 6px 8px;
  background: var(--bgInput); border-radius: 3px;
  font-family: 'JetBrains Mono', monospace; font-size: 11px;
  color: var(--textDim);
}
.grit-eq-pref{ color: var(--cinnabar); font-weight: 600; }
.grit-eq-pref b{ color: var(--cinnabar); }
.grit-eq-line b{ color: var(--text); font-weight: 500; }

.stage-checkbox{
  display: flex; align-items: center; gap: 8px;
  margin-top: 8px; cursor: pointer;
  font-size: 12.5px; color: var(--textMuted);
}
.stage-checkbox input{
  width: 16px; height: 16px; accent-color: var(--bronze);
}
.stage-range-hint{
  margin-top: 4px; font-family: 'JetBrains Mono', monospace;
  font-size: 11px; color: var(--bronze); padding-left: 2px;
}
.angle-typical-hint{
  display: block; margin-top: 6px;
  font-family: 'JetBrains Mono', monospace; font-size: 11.5px;
  color: var(--bronze); padding: 0 2px;
}
.stages-empty{
  margin: 6px 16px 10px;
  color: var(--textMuted); font-size: 13px;
}

/* «Итого по работам» и «Итого по Ножу» */
.works-total, .knife-total-bar{
  display: flex; align-items: baseline; justify-content: space-between;
  padding: 10px 14px;
  background: var(--bgRaised);
  border: 1px solid var(--rule);
  border-radius: 4px;
  margin: 8px 12px 4px;
}
.works-total-label, .knife-total-label{
  font-family: 'JetBrains Mono', monospace; font-size: 11px;
  letter-spacing: 0.08em; text-transform: uppercase; color: var(--textDim);
}
.works-total-value{
  font-family: 'JetBrains Mono', monospace; font-size: 14px; font-weight: 500;
}
.knife-total-value{
  font-family: 'JetBrains Mono', monospace; font-size: 20px;
  font-weight: 600; color: var(--bronze);
}

/* Шкала остроты — pill-стиль (рендер из renderSharpnessSection) */
.sharpness-scale{
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 6px;
  padding: 10px 0;
}
.sharpness-pill{
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  padding: 10px 4px 8px; border-radius: 4px;
  border: 1px solid var(--rule); background: var(--bgRaised);
  cursor: pointer; transition: background 80ms;
  font-family: inherit;
}
.sharpness-pill:hover{ background: var(--bgHi); }
.sharpness-pill--active{
  border-color: var(--bronze);
  background: rgba(169,133,86,0.10);
}
.sharpness-pill-num{
  font-family: 'Inter', sans-serif; font-weight: 600; font-size: 14px;
  letter-spacing: 0.04em; color: var(--bronze);
}
.sharpness-pill-name{
  font-size: 10.5px; color: var(--text); text-align: center; line-height: 1.15;
}
.sharpness-pill--active .sharpness-pill-name{ font-weight: 600; }
.sharpness-criterion{
  font-family: 'PT Serif', serif; font-style: italic;
  font-size: 12.5px; color: var(--bronzeDim);
  padding: 8px 12px 0; margin-top: 6px;
  border-top: 1px solid var(--rule);
}
.hist-entry{
  background: var(--bgRaised);
  border: 1px solid var(--rule);
  border-left: 2px solid var(--bronzeDim);
  border-radius: 0 4px 4px 0;
  padding: 10px 12px;
  margin-bottom: 6px;
}
.hist-entry-head{
  display: flex; justify-content: space-between; align-items: baseline;
  margin-bottom: 6px;
}
.hist-entry-date{
  font-family: 'JetBrains Mono', monospace; font-size: 12px; color: var(--textMuted);
}
.hist-entry-row{
  font-size: 12.5px; color: var(--text); margin-top: 3px;
}
.hist-key{
  font-family: 'JetBrains Mono', monospace; font-size: 10.5px;
  letter-spacing: 0.04em; text-transform: uppercase; color: var(--textDim);
  margin-right: 4px;
}
.hist-stage-angle{
  color: var(--bronze); font-family: 'JetBrains Mono', monospace;
}
.sharpness-chip{
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: 0.04em;
  color: var(--bronze); border: 1px solid var(--bronzeDim);
  padding: 2px 6px; border-radius: 3px;
}

/* Detail-block → секции, как card */
.detail-block{
  background: var(--bgRaised);
  border: 1px solid var(--rule);
  border-radius: 6px;
  padding: 14px;
  margin: 0 12px 10px;
}
.detail-block-title{
  font-family: 'JetBrains Mono', monospace; font-size: 11px;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--textMuted); font-weight: 600;
  margin: 0 0 10px;
  display: flex; align-items: center; gap: 8px;
}
.restoration-badge{
  font-family: 'JetBrains Mono', monospace; font-size: 9px;
  letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--cinnabar); border: 1px solid var(--cinnabar);
  padding: 2px 6px; border-radius: 3px;
}

/* Финальная статус-полоса (Нож готов) */
.process-status-bar{
  padding: 14px 12px 22px;
  display: flex; flex-direction: column; gap: 8px;
}
.process-status-bar .btn{ width: 100%; }
.process-status-done{
  display: flex; align-items: center; justify-content: center; gap: 8px;
  font-family: 'JetBrains Mono', monospace; font-size: 12px;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--bamboo); border: 1px solid var(--bamboo);
  padding: 12px; border-radius: 4px;
  background: rgba(127,179,95,0.08);
}

/* Категория этапа в шапке (старый класс stage-cat) */
.stage-block .stage-cat{ margin-left: 6px; }

/* === Tech: details «редактировать параметры» === */
.t-params-edit{
  margin: 0 12px 10px;
  background: var(--bgRaised);
  border: 1px solid var(--rule); border-radius: 6px;
  padding: 0;
}
.t-params-edit > summary{
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 14px;
  cursor: pointer;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--textMuted);
  list-style: none;
}
.t-params-edit > summary::-webkit-details-marker{ display: none; }
.t-params-edit > summary .chev{
  color: var(--textDim);
  transition: transform 150ms;
}
.t-params-edit[open] > summary .chev{ transform: rotate(180deg); }
.t-params-edit > summary:hover{ background: var(--bgHi); }
.t-params-edit-body{
  padding: 0 14px 14px;
  display: flex; flex-direction: column; gap: 10px;
  border-top: 1px solid var(--rule);
  padding-top: 14px;
}
.t-params-edit-body .field-row{
  display: grid; grid-template-columns: 1fr 1fr; gap: 10px;
}

/* ════════════════════════════════════════════════════════════════
   ЭТАП 5 — Stats: период, hero-плашки, график, сводка, затраты.
   ════════════════════════════════════════════════════════════════ */

.view-stats{ padding: 0 0 30px; }

/* Период */
.s-period{ padding: 12px 16px 4px; }
.s-period-bar{
  display: flex; align-items: center; gap: 10px;
  padding: 6px 0;
}
.s-period-bar .mono{ font-size: 14px; font-weight: 500; }
.s-period-bar .rule{
  flex: 1; height: 1px; background: var(--ruleWarm);
}
.s-period-inputs{
  display: flex; gap: 8px; margin-top: 8px;
}
.s-period-inputs label{
  flex: 1; display: flex; align-items: center; gap: 8px;
  background: var(--bgInput);
  border: 1px solid var(--rule); border-radius: 4px;
  padding: 6px 10px;
}
.s-period-inputs label > span{
  font-family: 'JetBrains Mono', monospace; font-size: 10px;
  letter-spacing: 0.12em; text-transform: uppercase; color: var(--textDim);
}
.s-period-inputs input{
  background: transparent; border: 0; padding: 0;
  color: var(--text); font-family: 'JetBrains Mono', monospace;
  font-size: 13px; color-scheme: dark;
  width: 100%;
}

/* Hero-плашки */
.s-hero{
  display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 6px;
  padding: 4px 12px 0;
}
.s-hero-cell{
  background: var(--bgRaised);
  border: 1px solid var(--rule);
  border-top: 2px solid var(--ruleStrong);
  border-radius: 2px 2px 4px 4px;
  padding: 12px 10px;
}
.s-hero-cell.income{ border-top-color: var(--bronze); }
.s-hero-cell.profit{ border-top-color: var(--bamboo); }
.s-hero-label{
  font-family: 'JetBrains Mono', monospace; font-size: 10px;
  letter-spacing: 0.1em; text-transform: uppercase; color: var(--textDim);
}
.s-hero-value{
  font-family: 'JetBrains Mono', monospace;
  font-size: 18px; font-weight: 600; color: var(--textMuted);
  margin-top: 6px; line-height: 1; letter-spacing: -0.01em;
}
.s-hero-cell.income .s-hero-value{ color: var(--text); }
.s-hero-cell.profit .s-hero-value{ color: var(--bamboo); }
.s-hero-value .unit{
  font-family: 'JetBrains Mono', monospace; font-size: 11px;
  color: var(--textDim); margin-left: 2px;
}

/* График — реестровый с засечками */
.s-chart-card{
  margin: 0 12px 10px;
  background: var(--bgRaised);
  border: 1px solid var(--rule); border-radius: 4px;
  padding: 12px 10px 8px;
}
.s-chart-body{
  display: flex; gap: 6px;
}
.s-chart-yaxis{
  display: flex; flex-direction: column-reverse;
  justify-content: space-between;
  height: 140px; padding-bottom: 18px; padding-top: 2px;
}
.s-chart-yaxis span{
  font-family: 'JetBrains Mono', monospace;
  font-size: 9px; color: var(--textDim);
  line-height: 1; text-align: right;
}
.s-chart-pane{ flex: 1; position: relative; }
.s-chart-grid{
  position: absolute; inset: 0 0 18px 0;
  pointer-events: none;
}
.s-chart-grid > .gline{
  position: absolute; left: 0; right: 0;
  border-top: 1px dashed var(--rule);
}
.s-chart-grid > .gline.base{ border-top: 1px solid var(--ruleStrong); border-style: solid; }
.s-chart-grid > .gline.avg{
  border-top: 1px dashed var(--bronze);
}
.s-chart-grid > .gline.avg > .lbl{
  position: absolute; right: 0; bottom: 1px;
  font-family: 'JetBrains Mono', monospace; font-size: 9px;
  color: var(--bronze); background: var(--bgRaised);
  padding: 0 4px; letter-spacing: 0.05em;
}
.s-chart-bars{
  display: flex; align-items: flex-end; gap: 2px;
  height: 140px; position: relative; padding-bottom: 18px;
}
.s-chart-bar-slot{
  flex: 1; display: flex; flex-direction: column;
  align-items: center; height: 100%;
  justify-content: flex-end; position: relative;
}
.s-chart-bar{
  width: 100%; background: var(--bronzeDim); opacity: 0.6;
  border-top: 2px solid var(--ruleStrong);
}
.s-chart-bar.above{ background: var(--bronze); opacity: 1; border-top-color: var(--text); }
.s-chart-bar-label{
  position: absolute; bottom: 0;
  font-family: 'JetBrains Mono', monospace; font-size: 8.5px;
  color: var(--textDim); letter-spacing: -0.02em;
}
.s-chart-bar-zero{ width: 100%; height: 1px; background: var(--ruleStrong); }

.s-chart-foot{
  display: flex; justify-content: space-between;
  margin-top: 6px; padding-top: 8px;
  border-top: 1px solid var(--rule);
  font-size: 11px;
}

/* Сводка — реестровый список */
.s-summary{
  background: var(--bgRaised);
  border: 1px solid var(--rule); border-radius: 4px;
  margin: 0 12px 10px;
}
.s-summary-row{
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 10px 14px;
  border-top: 1px solid var(--rule);
  font-size: 13px;
}
.s-summary-row:first-child{ border-top: 0; }
.s-summary-row .key{ color: var(--textMuted); }
.s-summary-row .val{
  font-family: 'JetBrains Mono', monospace; font-weight: 500;
}

/* Затраты — прогресс-полосы по категориям */
.s-cat-card{
  background: var(--bgRaised);
  border: 1px solid var(--rule); border-radius: 4px;
  padding: 12px 14px;
  margin: 0 12px 10px;
}
.s-cat-row{ margin-top: 12px; }
.s-cat-row:first-child{ margin-top: 0; }
.s-cat-row-head{
  display: flex; justify-content: space-between;
  font-size: 12.5px; margin-bottom: 4px;
}
.s-cat-row-head .mono{ color: var(--textMuted); }
.s-cat-bar{
  height: 4px; background: var(--rule);
  border-radius: 2px; overflow: hidden;
}
.s-cat-bar-fill{
  height: 100%; background: var(--blade); opacity: 0.8;
}
.s-cat-bar-fill.equipment{ background: var(--bronze); }
.s-cat-bar-fill.abrasives{ background: var(--bamboo); }
.s-cat-bar-fill.supplies{ background: var(--blade); }
.s-cat-bar-fill.other{ background: var(--textDim); }

/* Форма добавления траты */
.s-add-form{
  display: grid; grid-template-columns: 1fr; gap: 8px;
  margin: 8px 12px 8px;
}
.s-add-form select,
.s-add-form input{ width: 100%; }
@media (min-width: 480px) {
  .s-add-form{ grid-template-columns: 1fr 1fr; }
  .s-add-form .name-col{ grid-column: 1 / -1; }
  .s-add-form .btn-col{ grid-column: 1 / -1; }
}

/* Список трат */
.s-exp-list{ margin: 0 12px; }
.s-exp-item{
  display: grid; grid-template-columns: auto 1fr auto auto; gap: 10px;
  align-items: center;
  padding: 10px 0;
  border-bottom: 1px solid var(--rule);
}
.s-exp-item:last-child{ border-bottom: 0; }
.s-exp-chip{
  font-family: 'JetBrains Mono', monospace; font-size: 9.5px;
  letter-spacing: 0.04em; text-transform: uppercase;
  padding: 3px 8px; border-radius: 3px;
  color: var(--text); background: var(--bgHi);
  border: 1px solid var(--rule);
}
.s-exp-chip.equipment{ color: var(--bronze); border-color: var(--bronzeDim); }
.s-exp-chip.abrasives{ color: var(--bamboo); border-color: var(--bamboo); }
.s-exp-chip.supplies{ color: var(--blade); border-color: var(--ruleStrong); }
.s-exp-chip.other{ color: var(--textDim); border-color: var(--rule); }
.s-exp-name{ font-size: 13.5px; }
.s-exp-date{ font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--textDim); }
.s-exp-amount{ font-family: 'JetBrains Mono', monospace; font-size: 13px; }
.s-exp-rem{
  width: 28px; height: 28px; border: 0; background: transparent;
  color: var(--blood); cursor: pointer; border-radius: 3px;
  font-size: 16px;
}
.s-exp-rem:hover{ background: rgba(139,0,0,0.10); }

/* === Главная: слоган под Клинком (всегда) + статус ниже (только при активном заказе) === */
.home-slogan{
  margin-top: 8px;
  font-family: 'PT Serif', serif; font-style: italic;
  font-size: 16px; color: var(--text);
  line-height: 1.35; letter-spacing: -0.005em;
  text-align: center;
}
.home-voice{
  margin-top: 32px;  /* большое пространство между слоганом и статусом работы */
}

/* === TS-PROF — фирменный красный блок === */
.r-tsprof{
  margin: 10px 12px;
  padding: 0;
  overflow: hidden;
  border-color: rgba(216,51,63,0.30);
}
.r-tsprof-head{
  background: #C8202C;
  padding: 18px 16px;
  color: #fff;
  display: flex; flex-direction: column; gap: 4px;
}
.r-tsprof-logo{
  font-family: 'Inter', sans-serif; font-weight: 900;
  font-size: 28px; letter-spacing: -0.02em;
  color: #fff;
  text-transform: none;  /* TSPROF — фирменное написание, слитно */
}
.r-tsprof-tag{
  font-family: 'PT Serif', serif; font-style: italic;
  font-size: 12.5px; color: rgba(255,255,255,0.85);
  line-height: 1.35;
}
.r-tsprof-body{
  padding: 14px 16px 4px;
  font-size: 13px; color: var(--textMuted);
  line-height: 1.5;
}
.r-tsprof-body p{ margin: 0; }
.btn-tsprof{
  background: #C8202C;
  color: #fff !important;
  margin: 12px 16px 16px;
  width: calc(100% - 32px);
  height: 46px;
  text-decoration: none;
  letter-spacing: 0.02em;
  box-shadow: inset 0 -2px 0 rgba(0,0,0,0.22);
}
.btn-tsprof:hover{ filter: brightness(1.08); }
.btn-tsprof svg{ stroke: #fff; }

/* === Profile: логотип и подпись Мастера === */
.p-img-card{
  padding: 14px;
}
.p-img-preview{
  background: #fff;
  padding: 14px;
  border-radius: 4px;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 12px;
  min-height: 80px;
}
.p-img-preview img{
  max-width: 100%;
  max-height: 180px;
  object-fit: contain;
  display: block;
}
.p-img-preview--sign{
  padding: 18px 14px;
  background: #fff;
}
.p-img-preview--sign img{ max-height: 100px; }
.p-img-empty{
  background: var(--bgInput);
  border: 1px dashed var(--ruleStrong);
  border-radius: 4px;
  padding: 28px 14px;
  text-align: center;
  margin-bottom: 12px;
}
.p-img-actions{
  display: flex; flex-direction: column; gap: 8px;
}
.p-img-actions .btn{
  width: 100%;
  cursor: pointer;
}

/* Если есть логотип — показываем его в шапке Профиля (поверх инициалов) */
.p-head .p-logo-img{
  max-width: 120px;
  max-height: 60px;
  object-fit: contain;
  margin: 0 auto 8px;
  display: block;
}

/* === TS-PROF пилюля — всегда фирменная красная, не зависит от состояния === */
.pill[data-ref-id="tsprof"]{
  background: #C8202C;
  border-color: #C8202C;
  color: #fff !important;
  font-weight: 700;
  letter-spacing: 0.04em;
}
.pill[data-ref-id="tsprof"]:hover{ filter: brightness(1.10); }
.pill[data-ref-id="tsprof"].on{
  background: #A00018;
  border-color: #A00018;
  box-shadow: inset 0 -2px 0 rgba(0,0,0,0.2);
}

/* Pill-row в Refs — гарантируем видимость поверх view-tables padding:0 */
.view-tables .pill-row{
  position: sticky; top: var(--topbar-h); z-index: 2;
  background: var(--bg);
  padding: 12px 12px;
  margin: 0;
}
.view-tables .pill-row .pill{
  flex-shrink: 0; min-height: 34px;
  display: inline-flex; align-items: center;
  white-space: nowrap;
}

/* ════════════════════════════════════════════════════════════════
   ЭТАП 6 — PDF-акт: hanko, водяной знак, бумажная фактура.
   Перекрывают старые act-* стили (специфичность выше за счёт порядка).
   ════════════════════════════════════════════════════════════════ */

/* === Базовые цвета акта: всегда тёплая бумага, тёмный текст === */
/* Бумажная фактура — почти невидимое зерно поверх фона */
/* Водяной знак — диагональный Клинок, очень бледный */
/* === Шапка акта === */
/* === Заголовок документа === */
/* === Секционные блоки === */
/* === Профиль: каталог дополнительных работ === */
.p-works-card{ padding: 12px 14px 14px; }
.p-works-list{
  display: flex; flex-direction: column; gap: 6px;
  margin-bottom: 10px;
}
.p-work-row{
  display: grid; grid-template-columns: 1fr 90px 32px; gap: 6px;
  align-items: center;
}
.p-work-name{
  background: var(--bgInput);
  border: 1px solid var(--rule);
  border-radius: 3px; padding: 8px 10px;
  font-size: 13.5px; color: var(--text);
}
.p-work-price{
  background: var(--bgInput);
  border: 1px solid var(--rule);
  border-radius: 3px; padding: 8px 10px;
  font-size: 13.5px; color: var(--text);
  text-align: right;
}
.p-work-rem{
  width: 32px; height: 32px;
  background: transparent; border: 0;
  color: var(--blood); cursor: pointer;
  border-radius: 3px;
  font-size: 16px;
}
.p-work-rem:hover{ background: rgba(139,0,0,0.10); }

.p-works-add{
  border: 1px dashed var(--ruleStrong);
  width: 100%;
}
.p-works-add:hover{ border-color: var(--bronze); color: var(--bronze); }

/* === Техкарта: плоский список работ === */
.works-list{
  display: flex; flex-direction: column;
  margin: 6px 0;
}
.work-item{
  display: grid; grid-template-columns: auto 1fr auto; gap: 10px;
  align-items: center;
  padding: 10px 4px;
  border-top: 1px solid var(--rule);
  cursor: pointer;
  font-size: 13.5px;
}
.work-item:first-child{ border-top: 0; }
.work-item input[type="checkbox"]{
  width: 18px; height: 18px; accent-color: var(--bronze);
}
.work-item .work-name{ color: var(--text); }
.work-item .work-price{
  color: var(--bronze); font-size: 13px;
}
.work-item:has(input:checked){ background: rgba(169,133,86,0.05); }
.work-item:has(input:checked) .work-name{ font-weight: 600; }

/* === Stepper для углов: кнопки −/+ + инпут === */
.angle-stepper{
  display: grid; grid-template-columns: 36px 1fr 36px; gap: 0;
  align-items: stretch;
  background: var(--bgInput);
  border: 1px solid var(--rule);
  border-bottom: 1px solid var(--ruleStrong);
  border-radius: 4px;
  overflow: hidden;
}
.angle-stepper .angle-input{
  background: transparent;
  border: 0;
  border-left: 1px solid var(--rule);
  border-right: 1px solid var(--rule);
  border-radius: 0;
  color: var(--text);
  font-size: 16px; font-weight: 600;
  padding: 9px 6px;
  text-align: center;
  width: 100%;
  outline: none;
}
.angle-stepper .angle-input:focus{
  background: rgba(169,133,86,0.08);
}
.angle-btn{
  background: transparent;
  border: 0;
  color: var(--bronze);
  font-family: inherit;
  font-size: 22px; font-weight: 600;
  cursor: pointer;
  padding: 0;
  line-height: 1;
  user-select: none;
}
.angle-btn:hover{ background: var(--bgHi); }
.angle-btn:active{ background: rgba(169,133,86,0.20); }

/* === Toggle «точная подстройка» в шапке секции «Этапы заточки» === */
.detail-block-title-row{
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px; margin-bottom: 10px; flex-wrap: wrap;
}
.angle-fine-toggle{
  display: flex; align-items: center; gap: 8px;
  cursor: pointer;
  font-size: 11.5px; color: var(--textMuted);
  font-family: 'JetBrains Mono', monospace;
  letter-spacing: 0.04em;
}
.angle-fine-toggle input[type="checkbox"]{
  width: 16px; height: 16px;
  accent-color: var(--bronze);
}
.angle-fine-toggle:has(input:checked){ color: var(--bronze); }
.angle-fine-toggle:has(input:checked) span{ font-weight: 600; }

/* === Выравнивание полей по высоте в .field-row (Замер и тип заточки, Длина/HRC и т.п.) === */
.field-row{ align-items: stretch; }
.field-row > .field{ display: flex; flex-direction: column; }
.field-row > .field > .angle-stepper,
.field-row > .field > input,
.field-row > .field > select,
.field-row > .field > textarea{
  min-height: 44px;
  flex: 1;
}
/* Inputs внутри angle-stepper занимают всю высоту обёртки */
.angle-stepper{ min-height: 44px; }
.angle-stepper .angle-input{ height: 100%; }
.angle-stepper .angle-btn{ height: 100%; }

/* === Универсальное выравнивание полей по высоте — на всех экранах === */

/* Один стандарт высоты для всех видимых полей ввода */
.field input,
.field select,
.field textarea,
.knife-block-body input,
.knife-block-body select,
.knife-block-body textarea,
.t-params-edit-body input,
.t-params-edit-body select,
.t-params-edit-body textarea,
.s-add-form input,
.s-add-form select,
.p-rates input,
.p-rates select{
  min-height: 44px;
}

/* Textarea — отдельная вертикальная норма (multi-line), но стартует с 64px */
.field textarea,
.knife-block-body textarea,
.t-params-edit-body textarea{
  min-height: 64px;
}

/* Двухколоночные grid-сетки тянут детей по высоте */
.field-row,
.knife-block-body,
.t-params-edit-body .field-row,
.p-rates,
.s-add-form,
.s-period-inputs{
  align-items: stretch;
}

/* Поле-обёртка .field растягивается по строке, внутренний контрол — тоже */
.field-row > .field,
.knife-block-body > .field,
.p-rates > .field,
.s-add-form > .field{
  display: flex; flex-direction: column;
}
.field-row > .field > input,
.field-row > .field > select,
.field-row > .field > textarea,
.field-row > .field > .angle-stepper,
.knife-block-body > .field > input,
.knife-block-body > .field > select,
.knife-block-body > .field > textarea,
.p-rates > .field > input,
.p-rates > .field > select{
  flex: 1;
}

/* Stats: форма добавления траты — кнопка и инпут одинаковой высоты */
.s-add-form .btn{ min-height: 44px; height: 44px; }
.s-add-form input,
.s-add-form select{ height: 44px; }

/* Стат-период: моноширинные month-input одной высоты */
.s-period-inputs input{ height: 24px; min-height: 0; }
.s-period-inputs label{ min-height: 44px; }

/* === Выравнивание лейблов в парных полях === */
/* Резерв под 2 строки label — даже если одна строка, лейбл «прижимается» к низу,
   и поля под ним стартуют с одного уровня. */
.field-row .field-label,
.knife-block-body .field-label,
.t-params-edit-body .field-label,
.p-rates .field-label,
.s-add-form .field-label{
  min-height: 28px;       /* ≈ 2 строки при 11px шрифте 0.06em letter-spacing */
  display: flex;
  align-items: flex-end;
  line-height: 1.25;
}
/* .field — контрол всегда внизу карточки */
.field-row > .field,
.knife-block-body > .field,
.p-rates > .field{
  justify-content: flex-end;
}

/* === Tech: фотографии Ножа (закрепление в станке + любые) === */
.t-photos-card{ padding: 12px 14px 14px; }
.t-photos-grid{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(96px, 1fr));
  gap: 6px;
  margin-bottom: 10px;
}
.t-photo{
  position: relative;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  border-radius: 4px;
  background: var(--bgInput);
  border: 1px solid var(--rule);
}
.t-photo img{
  width: 100%; height: 100%;
  object-fit: cover; display: block;
  cursor: zoom-in;
}
.t-photo-rem{
  position: absolute; top: 4px; right: 4px;
  width: 22px; height: 22px;
  background: rgba(22,24,28,0.85);
  color: #fff; border: 0; border-radius: 50%;
  font-size: 14px; line-height: 1;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  padding: 0;
}
.t-photo-rem:hover{ background: var(--blood); }
.t-photos-add{
  border: 1px dashed var(--ruleStrong);
  cursor: pointer;
}
.t-photos-add input{ position: absolute; left: -9999px; }
.t-photos-add:hover{ border-color: var(--bronze); color: var(--bronze); }

/* Lightbox */
.t-lightbox{
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.92);
  display: none; align-items: center; justify-content: center;
  z-index: 1000;
  padding: 20px;
}
.t-lightbox.show{ display: flex; }
.t-lightbox img{
  max-width: 100%; max-height: 100%;
  object-fit: contain;
  display: block;
}
.t-lightbox-close{
  position: fixed; top: 20px; right: 20px;
  width: 44px; height: 44px;
  background: rgba(255,255,255,0.10);
  color: #fff; border: 0; border-radius: 50%;
  font-size: 22px; line-height: 1;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
}
.t-lightbox-close:hover{ background: rgba(255,255,255,0.20); }

/* === Поиск в Журнале — реальный input + очистка === */
.j-search-input{
  flex: 1; display: flex; align-items: center; gap: 8px;
  height: 42px; padding: 0 12px;
  background: var(--bgInput);
  border: 1px solid var(--rule);
  border-radius: 4px;
  color: var(--text);
  position: relative;
}
.j-search-input > svg{ flex-shrink: 0; color: var(--textDim); }
.j-search-input input{
  flex: 1; background: transparent; border: 0; outline: none;
  color: var(--text);
  font-family: inherit; font-size: 13px;
  padding: 0; min-height: 0;
  width: 100%;
}
.j-search-input input::placeholder{ color: var(--textDim); }
.j-search-input input::-webkit-search-cancel-button{ display: none; }
.j-search-clear{
  width: 24px; height: 24px; flex-shrink: 0;
  background: transparent; border: 0; cursor: pointer;
  color: var(--textDim); font-size: 18px; line-height: 1;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
}
.j-search-clear:hover{ background: var(--bgHi); color: var(--text); }

/* ════════════════════════════════════════════════════════════════
   Полировка: a11y, reduced-motion, авто-цена, кнопка «Оплачено»,
   отрицательная прибыль.
   ════════════════════════════════════════════════════════════════ */

/* === Уважение к reduced-motion: отключаем анимацию Клинка === */
@media (prefers-reduced-motion: reduce) {
  .home-knife-img{
    animation: none !important;
    transform: scaleX(-1) rotate(-22deg);
  }
  * {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}

/* === Глобальные focus-стили (a11y) === */
.btn:focus-visible,
.tab:focus-visible,
.tbar-btn:focus-visible,
.pill:focus-visible,
.scale-cell:focus-visible,
.sharpness-pill:focus-visible,
.angle-btn:focus-visible,
.j-search-clear:focus-visible{
  outline: 2px solid var(--bronze);
  outline-offset: 2px;
}
input:focus-visible,
textarea:focus-visible,
select:focus-visible{
  outline: none;
  border-color: var(--bronze);
  box-shadow: 0 0 0 2px rgba(169,133,86,0.25);
}

/* === Авто-цена в техкарте === */
.t-auto-hint{
  display: flex; align-items: center; justify-content: space-between;
  gap: 10px; margin-top: 6px; padding: 6px 10px;
  background: var(--bgInput);
  border: 1px solid var(--rule);
  border-radius: 4px;
  font-size: 12px;
  color: var(--textMuted);
}
.t-auto-hint .mono{ color: var(--text); }
.t-auto-hint .mono b{ color: var(--bronze); font-weight: 600; }
.t-auto-apply{
  background: var(--bronze); color: #fff; border: 0;
  padding: 5px 12px; border-radius: 3px;
  font-family: inherit; font-size: 11.5px; font-weight: 600;
  cursor: pointer;
  flex-shrink: 0;
}
.t-auto-apply:hover{ filter: brightness(1.08); }
.t-auto-applied{
  font-family: 'JetBrains Mono', monospace;
  font-size: 10.5px; letter-spacing: 0.04em;
  color: var(--bamboo); text-transform: uppercase;
  flex-shrink: 0;
}

/* === Кнопка «Оплачено» === */
.btn-paid{
  background: rgba(127,179,95,0.10);
  color: var(--bamboo);
  border: 1px solid var(--bamboo);
}
.btn-paid:hover{ background: rgba(127,179,95,0.18); }

/* === Отрицательная прибыль в Stats === */
.s-hero-cell.profit--negative{
  border-top-color: var(--blood) !important;
}
.s-hero-cell.profit--negative .s-hero-value{
  color: var(--blood) !important;
}

/* === Баннер «локализация в работе» для не-русских локалей === */
.locale-banner{
  position: fixed; left: 50%; transform: translateX(-50%);
  top: calc(env(safe-area-inset-top, 0px) + 6px);
  z-index: 99;
  max-width: 500px; width: calc(100% - 24px);
  padding: 8px 12px;
  background: rgba(216,51,63,0.12);
  border: 1px solid rgba(216,51,63,0.40);
  color: var(--text);
  border-radius: 4px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; letter-spacing: 0.02em;
  text-align: center;
  pointer-events: none;
}
@media (min-width: 768px) {
  .locale-banner{ max-width: 560px; }
}
/* Когда баннер виден — сдвигаем контент вниз на реальную высоту баннера.
   Переменная --locale-banner-h ставится из JS (updateLocaleBannerOffset),
   потому что текст баннера на DE/ES может занимать 2 строки.
   В формовых вьюхах баннер сидит под топбаром (см. ниже). */
body.has-locale-banner .content{
  padding-top: var(--locale-banner-h, 52px);
}
body.has-locale-banner[data-view="form-new-order"] .content,
body.has-locale-banner[data-view="order-detail"]   .content,
body.has-locale-banner[data-view="knife-process"]  .content{
  padding-top: calc(var(--topbar-h) + var(--locale-banner-h, 52px));
}
body.has-locale-banner[data-view="form-new-order"] .locale-banner,
body.has-locale-banner[data-view="order-detail"]   .locale-banner,
body.has-locale-banner[data-view="knife-process"]  .locale-banner{
  top: calc(var(--topbar-h) + 6px);
}

/* ============================================================
   АКТ ВЫПОЛНЕННЫХ РАБОТ · v2 (Заводской бланк)
   Hi-fi реализация дизайн-хэндоффа Act for app Android
   ============================================================ */

.akt-sheet {
  --paper:    #F5EFE0;
  --paper-2:  #EEE6D2;
  --ink:      #1F2227;
  --ink-2:    #4a4d52;
  --ink-3:    #80828a;
  --ink-4:    #b5b1a6;
  --bronze:   #8B6F47;
  --bronze-d: #6e5535;
  --bronze-l: #b39570;
  --bamboo:   #A89968;
  --moss:     #5C7549;
  --cinnabar: #C8202C;
  --blood:    #8B0000;

  position: relative;
  width: 794px;
  min-height: 1123px;
  background: var(--paper);
  color: var(--ink);
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 10.5px;
  line-height: 1.45;
  overflow: hidden;
  box-sizing: border-box;
  padding: 28px 32px 18px;
  display: flex; flex-direction: column;
  font-feature-settings: "kern", "liga", "tnum";
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;

  /* Принудительно сохранять цвета (бумажный фон, шапки таблицы, шумовая текстура)
     в print-preview даже без галочки «Фон» / "Background graphics" пользователя. */
  -webkit-print-color-adjust: exact;
  print-color-adjust: exact;
  color-adjust: exact;
}
.akt-sheet *,
.akt-sheet *::before,
.akt-sheet *::after {
  -webkit-print-color-adjust: exact;
  print-color-adjust: exact;
}

.akt-sheet .serif { font-family: 'PT Serif', Georgia, serif; }
.akt-sheet .mono  { font-family: 'JetBrains Mono', ui-monospace, monospace; font-variant-numeric: tabular-nums; }
.akt-sheet .hand  { font-family: 'Caveat', cursive; }
.akt-sheet > * { position: relative; }
.akt-sheet > .akt-body { flex: 1 1 auto; min-height: 0; z-index: 2; }
.akt-sheet > .akt-footer { margin-top: auto; z-index: 2; }

/* Бумажная фактура */
.akt-grain {
  position: absolute; inset: 0; width: 100%; height: 100%;
  pointer-events: none; mix-blend-mode: multiply; opacity: 0.34; z-index: 50;
}
.akt-mmgrid {
  position: absolute; inset: 0; width: 100%; height: 100%;
  pointer-events: none; opacity: 0.26; z-index: 0;
}
.akt-watermark {
  position: absolute; left: 50%; top: 50%;
  transform: translate(-50%, -50%) rotate(-26deg);
  width: 120%; pointer-events: none; opacity: 0.035; z-index: 0;
}

/* === HEADER === */
.akt-header { z-index: 2; }
.akt-h-row {
  display: flex; align-items: baseline; justify-content: space-between; gap: 16px;
}
.akt-h-no, .akt-h-title {
  font-family: 'PT Serif', Georgia, serif;
  font-size: 28px; font-weight: 700; line-height: 1; letter-spacing: -0.005em;
}
.akt-h-meta {
  margin-top: 8px; padding-top: 6px;
  border-top: 1px solid var(--bronze);
  display: flex; align-items: baseline; justify-content: space-between; gap: 12px;
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 10px; color: var(--ink-2); letter-spacing: 0.05em;
}
.akt-h-master { text-align: right; }

/* === BODY: sidebar + main === */
.akt-body {
  margin-top: 14px;
  display: grid; grid-template-columns: 168px 1fr; gap: 18px;
}

/* SIDEBAR */
.akt-sidebar {
  padding-right: 12px;
  display: flex; flex-direction: column; gap: 16px;
}
.akt-logo-wrap { text-align: center; }
.akt-logo-slot {
  width: 100%; height: 70px;
  display: inline-flex; align-items: center; justify-content: center;
  text-align: center;
  background-image: repeating-linear-gradient(45deg, transparent 0 5px, rgba(139,111,71,0.10) 5px 6px);
  border: 1px dashed var(--bronze);
  color: var(--bronze-d);
  font-family: 'JetBrains Mono', monospace;
  font-size: 8px; font-weight: 500; letter-spacing: 0.14em; text-transform: uppercase;
  padding: 3px 5px; line-height: 1.2;
}
.akt-logo-slot.has-logo {
  background-image: none; border: 0; padding: 0;
}
.akt-logo-slot.has-logo img {
  max-width: 100%; max-height: 70px; object-fit: contain;
}
.akt-logo-city {
  margin-top: 4px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 8.5px; letter-spacing: 0.22em; color: var(--bronze-d); font-weight: 700;
}
.akt-sb-rule { height: 1px; background: var(--bronze); opacity: 0.4; }
.akt-sb-title {
  font-family: 'JetBrains Mono', monospace;
  font-size: 8.5px; letter-spacing: 0.22em; color: var(--bronze-d);
  text-align: center; font-weight: 700; margin-bottom: 6px;
}
.akt-sb-img {
  width: 100%; max-height: 310px; object-fit: contain; display: block;
}
.akt-sb-img-angles { max-height: 330px; }

.akt-legend {
  display: grid; grid-template-columns: auto 1fr; column-gap: 8px; row-gap: 3px;
  margin: 0;
}
.akt-legend dt {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; color: var(--cinnabar); font-weight: 700;
}
.akt-legend dd {
  margin: 0; font-size: 9.5px; line-height: 1.35; color: var(--ink);
}

/* MAIN */
.akt-main { min-width: 0; }

.akt-sect {
  display: flex; align-items: baseline; gap: 8px;
  border-bottom: 1px solid var(--bronze);
  padding-bottom: 3px; margin-top: 32px; margin-bottom: 8px;
  font-weight: 400;
}
/* :first-child НЕ использовать — каждый h3 первый ребёнок своего <section>.
   Только явный .first на первой секции (§01). */
.akt-sect.first { margin-top: 0; }
.akt-sect-no {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; color: var(--cinnabar); font-weight: 700; letter-spacing: 0.05em;
}
.akt-sect-name {
  font-family: 'JetBrains Mono', monospace;
  font-size: 9px; letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--ink); font-weight: 600;
}

/* §01 Клиент */
.akt-client {
  display: grid;
  grid-template-columns: auto 1fr auto 1fr auto 1fr;
  column-gap: 10px; row-gap: 4px;
  align-items: baseline;
}
.akt-field-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 8.5px; letter-spacing: 0.2em;
  color: var(--ink-3); text-transform: uppercase; font-weight: 500;
}
.akt-field-val { font-size: 11px; }
.akt-field-val.serif {
  font-family: 'PT Serif', serif; font-size: 14px; font-weight: 700;
}
.akt-field-val.mono {
  font-family: 'JetBrains Mono', monospace; font-size: 11px;
}

/* §02 Клинки заказа */
.akt-knives-head {
  padding: 4px 10px; background: var(--paper-2);
  display: grid; grid-template-columns: 22px 1fr 90px; column-gap: 10px;
}
.akt-knives-head span {
  font-family: 'JetBrains Mono', monospace;
  font-size: 8.5px; letter-spacing: 0.22em; font-weight: 700; color: var(--bronze-d);
}
.akt-knives-head .akt-col-total { text-align: right; }

.akt-knife-row {
  padding: 8px 10px 6px;
  border-bottom: 1px dotted var(--bronze-l);
  display: grid; grid-template-columns: 22px 1fr 90px;
  column-gap: 10px; align-items: start;
}
.akt-knife-row:last-of-type { border-bottom: 0; }
.akt-knife-row .akt-knife-n {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; color: var(--cinnabar); font-weight: 700; padding-top: 1px;
}
.akt-knife-headline {
  display: flex; justify-content: space-between; gap: 8px; align-items: baseline;
}
.akt-knife-title {
  font-family: 'PT Serif', serif; font-size: 12.5px; font-weight: 700; line-height: 1.25;
}
.akt-knife-meta {
  font-family: 'JetBrains Mono', monospace;
  font-size: 9px; color: var(--ink-3); letter-spacing: 0.06em; text-align: right;
  white-space: nowrap;
}
.akt-line { margin-top: 3px; display: flex; flex-wrap: wrap; gap: 2px 10px; align-items: baseline; }
.akt-line-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 8px; letter-spacing: 0.18em; color: var(--bronze-d); font-weight: 700;
}
.akt-state-text {
  font-family: 'Caveat', cursive; font-size: 14.5px; line-height: 1.2; color: var(--ink);
}
.akt-stage {
  font-family: 'JetBrains Mono', monospace; font-size: 10px;
}
.akt-stage-type { color: var(--ink-3); }
.akt-stage-grit { font-weight: 700; color: var(--ink); }
.akt-stage-angle { color: var(--cinnabar); }
.akt-after-stages {
  font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--ink-2);
}
.akt-after-stages b { font-weight: 700; color: var(--ink); }
.akt-after-stages .akt-measured {
  font-size: 11px; color: var(--cinnabar); font-weight: 700;
}
.akt-extra-item { color: var(--ink-2); font-size: 10px; }
.akt-extra-item .mono { font-family: 'JetBrains Mono', monospace; }
.akt-sharp-chip {
  font-family: 'JetBrains Mono', monospace;
  font-size: 9px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--cinnabar); font-weight: 700;
}
.akt-sharp-chip .akt-sharp-name {
  font-family: 'PT Serif', serif; font-size: 11px;
  letter-spacing: 0; text-transform: none; font-style: italic; font-weight: 400;
  color: var(--ink);
}
.akt-knife-total {
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 14px; font-weight: 700;
  text-align: right; color: var(--cinnabar); padding-top: 1px;
  font-variant-numeric: tabular-nums;
}

.akt-grand {
  padding: 8px 10px; background: var(--paper-2);
  display: grid; grid-template-columns: 1fr 100px; column-gap: 10px;
  align-items: baseline; margin-top: 4px;
}
.akt-grand-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 9.5px; letter-spacing: 0.22em; font-weight: 700; color: var(--ink);
}
.akt-grand-sum {
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 22px; font-weight: 700;
  color: var(--cinnabar); text-align: right; line-height: 1;
  font-variant-numeric: tabular-nums;
}

/* §03 Памятка */
.akt-memo-grid {
  display: grid; grid-template-columns: 1fr 1fr; column-gap: 18px; padding-top: 2px;
}
.akt-memo-col-title {
  font-family: 'JetBrains Mono', monospace;
  font-size: 8.5px; letter-spacing: 0.22em; font-weight: 700;
  padding-bottom: 3px; margin-bottom: 4px;
}
.akt-memo-col-title.no { color: var(--blood); }
.akt-memo-col-title.yes { color: var(--moss); }
.akt-memo-items {
  column-count: 2; column-gap: 10px;
}
.akt-memo-item {
  font-size: 9.5px; line-height: 1.45; padding: 1px 0; break-inside: avoid;
}
.akt-memo-item .akt-bullet {
  font-family: 'JetBrains Mono', monospace;
  font-size: 8px; margin-right: 4px;
}
.akt-memo-item .akt-bullet.no { color: var(--blood); }
.akt-memo-item .akt-bullet.yes { color: var(--moss); }

/* §04 Оплата */
.akt-pay {
  padding-top: 2px;
  display: grid; grid-template-columns: auto 1fr auto 1fr;
  column-gap: 10px; row-gap: 4px; align-items: baseline;
}
.akt-pay-phone {
  font-family: 'JetBrains Mono', monospace;
  font-size: 13px; color: var(--cinnabar); font-weight: 700;
}
.akt-pay-full { grid-column: 2 / -1; }

/* §05 Подпись */
.akt-sign {
  display: grid; grid-template-columns: 220px 1fr; column-gap: 14px; align-items: center;
}
.akt-sign-slot {
  width: 100%; height: 42px;
  display: inline-flex; align-items: center; justify-content: center;
  background-image: repeating-linear-gradient(45deg, transparent 0 5px, rgba(139,111,71,0.10) 5px 6px);
  border: 1px dashed var(--bronze);
  color: var(--bronze-d);
  font-family: 'JetBrains Mono', monospace;
  font-size: 8px; letter-spacing: 0.14em; text-transform: uppercase;
}
.akt-sign-slot.has-sig {
  background-image: none; border: 0;
}
.akt-sign-slot.has-sig img {
  max-width: 100%; max-height: 42px; object-fit: contain;
}
.akt-sign-name {
  font-family: 'PT Serif', serif; font-size: 13px; font-weight: 700;
}

/* === FOOTER === */
.akt-footer {
  padding-top: 12px;
}
.akt-thanks {
  font-family: 'PT Serif', serif; font-style: italic;
  text-align: center; color: var(--moss);
  font-size: 13px; font-weight: 400; letter-spacing: 0.06em; margin-bottom: 8px;
}
.akt-foot-line {
  padding-top: 8px; border-top: 1px solid var(--bronze); text-align: center;
}
.akt-brand-name {
  font-family: 'PT Serif', serif;
  color: var(--cinnabar); font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.06em;
}
.akt-brand-product {
  font-family: 'PT Serif', serif; font-style: italic; color: var(--ink-2);
}
.akt-brand-slogan {
  font-family: 'PT Serif', serif; font-style: italic; color: var(--bamboo);
}
.akt-brand-dot { color: var(--bronze-d); margin: 0 8px; }

/* === Превью на экране (когда #printArea показан в UI) === */
.akt-preview-wrap {
  background: #2A2D34;
  padding: 24px; display: flex; justify-content: center;
  min-height: 100vh;
}
.akt-preview-wrap .akt-sheet {
  box-shadow: 0 10px 60px rgba(0,0,0,0.5);
}

/* === Печать === */
@media print {
  body > *:not(#printArea):not(.print-area) { display: none !important; }
  html, body {
    overflow: visible !important; height: auto !important;
    background: #fff !important; margin: 0 !important; padding: 0 !important;
  }
  #printArea, .print-area {
    display: block !important; width: 100% !important;
    margin: 0 !important; padding: 0 !important;
  }
  .akt-preview-wrap { background: transparent; padding: 0; min-height: 0; }
  .akt-sheet {
    box-shadow: none !important;
    width: 100% !important; min-height: auto !important;
  }
  @page { size: A4 portrait; margin: 0; }
}
