/* Дисплейный шрифт: Golos Text (ParaType, для русских госсервисов) — вариативный
   woff2 по подмножествам, self-hosted в static/fonts/. Заголовки/логотип; тело —
   системный гротеск, коды — моноширинный. */
@font-face {
    font-family: "Golos Text"; font-style: normal; font-weight: 100 900; font-display: swap;
    src: url("../fonts/golos-text-cyrillic-ext.woff2") format("woff2");
    unicode-range: U+0460-052F, U+1C80-1C88, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
@font-face {
    font-family: "Golos Text"; font-style: normal; font-weight: 100 900; font-display: swap;
    src: url("../fonts/golos-text-cyrillic.woff2") format("woff2");
    unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
    font-family: "Golos Text"; font-style: normal; font-weight: 100 900; font-display: swap;
    src: url("../fonts/golos-text-latin-ext.woff2") format("woff2");
    unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
    font-family: "Golos Text"; font-style: normal; font-weight: 100 900; font-display: swap;
    src: url("../fonts/golos-text-latin.woff2") format("woff2");
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

:root {
    /* Палитра «Бланк»: прохладная офисная бумага + индиго-чернила (печать),
       бирюза — будущий раздел «Бюро переводов». Декор (гильоше/печати) —
       js/guilloche.js.

       Тёмная тема — ниже, через :root[data-theme="dark"] и режим «авто»
       (prefers-color-scheme). Светлые значения здесь — единственный источник
       правды для светлой темы; менять их = менять светлый интерфейс. */
    color-scheme: light;        /* нативные контролы (select, его список, дата) — светлые */
    --bg: #e9ecf1;
    --surface: #ffffff;
    --text: #15181f;
    --muted: #59636f;
    --accent: #2e2a86;
    --accent-hover: #211e6b;
    --accent-soft: #ecebf7;
    --accent-line: #c7c4e6;
    --tr: #0f766e;
    --tr-soft: #e4f1ee;
    --tr-line: #b6dbd3;
    /* Статус-чипы переводов — отдельная семантика статуса, НЕ акцент. Реальных
       состояний у документа два: черновик (нейтральный) и напечатан (бирюзовый).
       Тёмные значения — в блоках темы ниже (правим во всех трёх синхронно). */
    --st-draft: #6b7682;        /* текст чипа «черновик» */
    --st-draft-bg: #f0f3f7;     /* фон чипа «черновик» */
    --st-draft-ln: #d4dae3;     /* граница чипа «черновик» */
    --st-done: #0f766e;         /* текст чипа «напечатан» (бирюзовый, читаемый) */
    --st-done-bg: #e4f1ee;      /* фон чипа «напечатан» */
    --st-done-ln: #b6dbd3;      /* граница чипа «напечатан» */
    --danger: #b3261e;
    --ok: #15803d;
    --warn: #8c5410;
    --border: #cdd4de;
    --hair: #cdd4de;
    --radius: 3px;
    --mono: ui-monospace, "SF Mono", "SFMono-Regular", "Cascadia Code", "Liberation Mono", Consolas, monospace;
    --display: "Golos Text", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;

    /* Семантические токены интерфейса: значения 1:1 равны прежним хардкодам, поэтому
       светлая тема не меняется ни на пиксель. Тёмные значения — в блоке темы. */
    --on-accent: #ffffff;       /* текст на заливке акцента (кнопки, активный чип) */
    --row-hover: #f0f4ff;       /* ховер строк таблиц/списков/результатов поиска */
    --nav-active: #eef2ff;      /* фон активного пункта навигации редактора, выбранного адреса */
    --nav-hover: #f3f5f9;       /* ховер пункта навигации редактора */
    --th-bg: #eef0f4;           /* фон th таблиц, .scan-doc, .rc-avatar.icon */
    --ok-soft: #eef7ee;         /* tr.current, .badge.printed, .pill.ok, checklist ok */
    --warn-pill: #e0a800;       /* заливка .pill.warn */
    --warn-pill-ink: #4a3500;   /* текст .pill.warn */
    --warn-soft: #fff3cd;       /* .notice bg, .chip.incomplete bg */
    --warn-line: #e0a800;       /* границы .notice/.chip.incomplete/.field-hint */
    --hint-bg: #fff8e6;         /* .field-hint bg, .note bg */
    --hint-text: #92600a;       /* .field-hint color, .recs li color */
    --danger-soft: #fff5f5;     /* input.input-invalid bg, .dt-del:hover bg */
    --msg-bg: #e0e7ff;          /* .chip bg, .messages li bg */
    --msg-err-bg: #fee2e2;      /* .messages li.error bg */
    --kbd-bg: #f1f3f7;          /* фон kbd */
    --placeholder: #9aa3b1;     /* ::placeholder */
    --field-soft: #fcfcfe;      /* фон .form-filter (почти белый) */
    --field-missing-bg: #fffdf5;/* фон незаполненного ключевого поля */
    --card-hover-bg: #fafbff;   /* ховер карточки результата поиска */
    --dashed-line: #c7d2fe;     /* пунктир .attach и hover-рамки карточек */
    --overlay: rgba(0, 0, 0, .4);     /* затемнение модального оверлея */
    --topbar-bg: rgba(255, 255, 255, .88); /* фон липкой шапки (полупрозрачный) */
    --pv-ground: #888;          /* фон вокруг листа в превью документа */
}

/* ======================== ТЁМНАЯ ТЕМА ========================
   Применяется в двух случаях (по образцу static/admin/js/theme.js, атрибут
   data-theme на <html>):
     1) пользователь явно выбрал «Тёмная»     → :root[data-theme="dark"];
     2) режим «Авто» при тёмной системе       → @media (prefers-color-scheme: dark)
                                                  :root[data-theme="auto"].
   Значения переопределяют светлые токены из :root выше. Два набора селекторов
   неизбежны (явная тёмная должна работать и на светлой системе), но
   декларации идентичны — правим в обоих местах синхронно. */
:root[data-theme="dark"] {
    color-scheme: dark;         /* браузер рисует select/список/дату тёмными — иначе чёрный текст */
    --bg: #15141e;
    --surface: #1e1d2b;
    --text: #e6e7f2;
    --muted: #8a8ba0;
    --accent: #8c87ea;
    --accent-hover: #a8a4f1;
    --accent-soft: #2a2750;
    --accent-line: #423f73;
    --tr: #4db6a8;
    --tr-soft: #143430;
    --tr-line: #2d5a52;
    /* Статус-чипы переводов — тёмная тема (явная). Контраст проверен на --surface
       #1e1d2b: светлый текст на затемнённом фоне статуса. */
    --st-draft: #98a1ae;
    --st-draft-bg: #262838;
    --st-draft-ln: #3a3d4d;
    --st-done: #5fc7b8;
    --st-done-bg: #143430;
    --st-done-ln: #2d5a52;
    --danger: #ef7a72;
    --ok: #5cbd7b;
    --warn: #d9a441;
    --border: #2f323e;
    --hair: #2a2d38;

    --on-accent: #14121d;
    --row-hover: #21202e;
    --nav-active: #21202e;
    --nav-hover: #21202e;
    --th-bg: #232233;
    --ok-soft: #16311f;
    --warn-pill: #d9a441;
    --warn-pill-ink: #1c1605;
    --warn-soft: #322914;
    --warn-line: #6e5a24;
    --hint-bg: #2c2614;
    --hint-text: #e0b257;
    --danger-soft: #3a1d1d;
    --msg-bg: #262a44;
    --msg-err-bg: #3a1d1d;
    --kbd-bg: #24232f;
    --placeholder: #6a6f80;
    --field-soft: #1a1926;
    --field-missing-bg: #2c2614;
    --card-hover-bg: #232233;
    --dashed-line: #423f73;
    --overlay: rgba(0, 0, 0, .6);
    --topbar-bg: rgba(21, 20, 30, .88);
    --pv-ground: #0e0d14;
}

@media (prefers-color-scheme: dark) {
    :root[data-theme="auto"] {
        color-scheme: dark;
        --bg: #15141e;
        --surface: #1e1d2b;
        --text: #e6e7f2;
        --muted: #8a8ba0;
        --accent: #8c87ea;
        --accent-hover: #a8a4f1;
        --accent-soft: #2a2750;
        --accent-line: #423f73;
        --tr: #4db6a8;
        --tr-soft: #143430;
        --tr-line: #2d5a52;
        /* Статус-чипы переводов — тёмная тема (авто при системной тёмной). */
        --st-draft: #98a1ae;
        --st-draft-bg: #262838;
        --st-draft-ln: #3a3d4d;
        --st-done: #5fc7b8;
        --st-done-bg: #143430;
        --st-done-ln: #2d5a52;
        --danger: #ef7a72;
        --ok: #5cbd7b;
        --warn: #d9a441;
        --border: #2f323e;
        --hair: #2a2d38;

        --on-accent: #14121d;
        --row-hover: #21202e;
        --nav-active: #21202e;
        --nav-hover: #21202e;
        --th-bg: #232233;
        --ok-soft: #16311f;
        --warn-pill: #d9a441;
        --warn-pill-ink: #1c1605;
        --warn-soft: #322914;
        --warn-line: #6e5a24;
        --hint-bg: #2c2614;
        --hint-text: #e0b257;
        --danger-soft: #3a1d1d;
        --msg-bg: #262a44;
        --msg-err-bg: #3a1d1d;
        --kbd-bg: #24232f;
        --placeholder: #6a6f80;
        --field-soft: #1a1926;
        --field-missing-bg: #2c2614;
        --card-hover-bg: #232233;
        --dashed-line: #423f73;
        --overlay: rgba(0, 0, 0, .6);
        --topbar-bg: rgba(21, 20, 30, .88);
        --pv-ground: #0e0d14;
    }
}

* { box-sizing: border-box; }

body {
    margin: 0;
    background: var(--bg);
    color: var(--text);
    font-family: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
    font-size: 16px;
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
}

a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }

/* Дисплейный шрифт — на крупных заголовках и логотипе (моно-метки остаются моно) */
h1, h2,
.topbar .brand b,
.home-panel h3,
.detail-group h3,
.modal-head h3 {
    font-family: var(--display);
    letter-spacing: -.01em;
}

/* Защитная гильоше-вуаль на всех страницах (рисует js/guilloche.js) */
.veil {
    position: fixed;
    inset: 0;
    width: 100%;
    height: 100%;
    z-index: -1;
    pointer-events: none;
}

.topbar {
    position: sticky;
    top: 0;
    z-index: 20;
    background: var(--topbar-bg);
    backdrop-filter: saturate(1.4) blur(8px);
    border-bottom: 1px solid var(--border);
    display: flex;
    align-items: center;
    gap: 1.3rem;
    padding: 0.5rem 1.4rem;
}

.topbar .brand {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    font-weight: 800;
    color: var(--text);
    letter-spacing: .01em;
}
.topbar .brand:hover { text-decoration: none; }
.topbar .brand canvas { width: 32px; height: 32px; display: block; }
.topbar .brand b { font-weight: 800; }
.topbar .brand b span { color: var(--accent); }

/* Постоянная навигация в шапке (на всех страницах для авторизованных) */
.topnav { display: flex; gap: 1.2rem; align-items: stretch; }
.topnav a {
    color: var(--muted);
    font-size: .74rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .11em;
    padding: .2rem 0;
    border-bottom: 2px solid transparent;
}
.topnav a:hover { color: var(--accent); text-decoration: none; border-bottom-color: var(--accent); }
.topnav a.active {
    color: var(--text);
    border-bottom-color: var(--accent);
}

.topbar .spacer { flex: 1; }

.topbar .who {
    color: var(--muted);
    font-size: 0.84rem;
    display: flex;
    align-items: center;
    gap: 0.55rem;
}
.topbar .who .office {
    font-family: var(--mono);
    font-size: 0.68rem;
    letter-spacing: .04em;
    color: var(--accent);
    background: var(--accent-soft);
    border: 1px solid var(--accent-line);
    border-radius: 2px;
    padding: 0.12rem 0.4rem;
    text-transform: uppercase;
}

/* Колокол уведомлений в шапке (волна 3a). Открытие — нативный <details>;
   список — абсолютный поповер под колоколом, в духе .field-hint. */
.notif { position: relative; }
.notif summary { list-style: none; cursor: pointer; }
.notif summary::-webkit-details-marker { display: none; }
.notif-bell {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--muted);
    padding: 0.2rem;
    border-radius: var(--radius);
}
.notif-bell:hover { color: var(--accent); }
.notif[open] .notif-bell { color: var(--accent); }
/* Бейдж числа непрочитанных (переиспользует акцент/опасный токен) */
.notif-badge {
    position: absolute;
    top: -3px;
    right: -4px;
    min-width: 1rem;
    height: 1rem;
    padding: 0 0.22rem;
    border-radius: 999px;
    background: var(--danger);
    color: #fff;
    font-size: 0.62rem;
    font-weight: 700;
    line-height: 1rem;
    text-align: center;
    box-sizing: border-box;
}
.notif-badge.empty { display: none; }
/* Поповер со списком */
.notif-pop {
    position: absolute;
    z-index: 30;
    right: 0;
    top: calc(100% + 9px);
    width: 320px;
    max-height: 70vh;
    overflow-y: auto;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: 0 8px 28px rgba(0, 0, 0, 0.18);
}
.notif-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.55rem 0.8rem;
    border-bottom: 1px solid var(--border);
    font-weight: 700;
    font-size: 0.82rem;
}
.notif-head form { margin: 0; }
.notif-loading { padding: 0.8rem; font-size: 0.85rem; }
.notif-items { list-style: none; margin: 0; padding: 0; }
.notif-item { border-bottom: 1px solid var(--border); }
.notif-item:last-child { border-bottom: none; }
.notif-item form { margin: 0; }
.notif-link {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
    width: 100%;
    text-align: left;
    background: none;
    color: var(--text);
    border: none;
    border-radius: 0;
    padding: 0.55rem 0.8rem;
    font-size: 0.85rem;
    cursor: pointer;
}
.notif-link:hover { background: var(--accent-soft); }
.notif-item.unread .notif-link { background: var(--accent-soft); }
.notif-item.unread .notif-text { font-weight: 600; }
.notif-time { color: var(--muted); font-size: 0.7rem; font-family: var(--mono); }
.notif-empty { padding: 0.8rem; font-size: 0.85rem; }

main.container {
    max-width: 1100px;
    margin: 1.5rem auto;
    padding: 0 1.2rem;
}

.card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 1.2rem 1.4rem;
}

.cards {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 1rem;
}

.card h3 { margin: 0 0 0.4rem; }
.card .muted { color: var(--muted); font-size: 0.9rem; }
.card.disabled { opacity: 0.55; }

button, .btn {
    background: var(--accent);
    color: var(--on-accent);
    border: none;
    border-radius: var(--radius);
    padding: 0.55rem 1.1rem;
    font-size: 1rem;
    cursor: pointer;
}
button:hover, .btn:hover { background: var(--accent-hover); }

button.link {
    background: none;
    color: var(--accent);
    padding: 0;
    font-size: 0.9rem;
}
button.link:hover { background: none; text-decoration: underline; }

form p { margin: 0 0 1rem; }

input[type="text"], input[type="password"] {
    width: 100%;
    padding: 0.55rem 0.7rem;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    font-size: 1rem;
}
input:focus { outline: 2px solid var(--accent); outline-offset: -1px; }

label { display: block; margin-bottom: 0.3rem; font-weight: 600; }

.errorlist {
    color: var(--danger);
    list-style: none;
    padding: 0;
    margin: 0.3rem 0 0;
    font-size: 0.9rem;
}

.login-page {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
}

.login-box {
    width: 100%;
    max-width: 380px;
}

.login-box h1 {
    text-align: center;
    font-size: 1.4rem;
    margin-bottom: 1rem;
}

/* Картотека */

.tabs {
    display: flex;
    gap: 0.25rem;
    border-bottom: 1px solid var(--border);
    margin-bottom: 1rem;
    flex-wrap: wrap;
}
.tab {
    padding: 0.45rem 0.9rem;
    border-radius: var(--radius) var(--radius) 0 0;
    color: var(--muted);
}
.tab:hover { text-decoration: none; color: var(--accent); }
.tab.active {
    background: var(--surface);
    border: 1px solid var(--border);
    border-bottom-color: var(--surface);
    margin-bottom: -1px;
    color: var(--text);
    font-weight: 600;
}

.list-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}
.list-header h2 { margin: 0; }

/* Единый дизайн поля поиска (как поиск стороны в документе) — для всех поисков */
.search-input {
    display: block;
    width: 100%;
    margin-bottom: 1rem;
    padding: 0.65rem 0.85rem;
    font-size: 1.05rem;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    background: var(--surface);
    color: var(--text);
}
.search-input:focus { outline: 2px solid var(--accent); outline-offset: -1px; }
.search-input::placeholder { color: var(--placeholder); }

table.data {
    width: 100%;
    border-collapse: collapse;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
}
table.data th, table.data td {
    text-align: left;
    padding: 0.5rem 0.75rem;
    border-bottom: 1px solid var(--border);
    font-size: 0.95rem;
}
table.data th { background: var(--th-bg); font-weight: 600; }
table.data tbody tr:hover { background: var(--row-hover); }

.pagination {
    display: flex;
    gap: 1rem;
    align-items: center;
    margin-top: 1rem;
}

fieldset.card { margin: 0 0 1rem; border: 1px solid var(--border); }
fieldset.card legend {
    font-weight: 600;
    padding: 0 0.5rem;
}

.form-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 0.8rem 1rem;
}
.form-field label { font-weight: 500; font-size: 0.9rem; }
.form-field.has-error input, .form-field.has-error select { border-color: var(--danger); }

/* Нормализация ввода (js/normalize.js): подсветка и сообщение об ошибке */
input.input-invalid { border-color: var(--danger); background: var(--danger-soft); }
.norm-error { display: block; color: var(--danger); font-size: 0.8rem; margin-top: 0.2rem; }

select, textarea {
    width: 100%;
    padding: 0.5rem 0.7rem;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    font-size: 1rem;
    background: var(--surface);
    color: var(--text);
    font-family: inherit;
}

input[type="date"], input[type="number"] {
    width: 100%;
    padding: 0.5rem 0.7rem;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    font-size: 1rem;
}

.form-actions { display: flex; gap: 1rem; align-items: center; margin-top: 1rem; }
.btn.secondary { background: var(--muted); }

.detail-group { margin-bottom: 1rem; }
.detail-group h3 { margin-top: 0; }
.detail-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 0.6rem 1.5rem;
    margin: 0;
}
.detail-grid dt { color: var(--muted); font-size: 0.85rem; }
.detail-grid dd { margin: 0; }
.card-meta { font-size: 0.85rem; }

/* Сканы */

.scans { margin-bottom: 1rem; }
.scans h3 { margin-top: 0; }
.scan-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    margin-bottom: 1rem;
}
.scan { margin: 0; max-width: 180px; }
.scan img {
    max-height: 140px;
    max-width: 180px;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    display: block;
}
.scan-doc {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 140px;
    height: 140px;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    background: var(--th-bg);
    font-size: 0.8rem;
    padding: 0.5rem;
    text-align: center;
    word-break: break-all;
}
.scan figcaption { font-size: 0.85rem; }
.scan figcaption .muted { display: block; }
button.link.danger { color: var(--danger); }
.scan-upload {
    display: flex;
    gap: 0.6rem;
    align-items: center;
    flex-wrap: wrap;
}
.scan-upload select { width: auto; }
.scan-upload input[type="file"] { flex: 1; min-width: 220px; }

.registrations { margin-bottom: 1rem; }
.registrations h3 { margin-top: 0; }
.registrations table.data { margin-bottom: 1rem; }
table.data tr.current { background: var(--ok-soft); }
.reg-actions { white-space: nowrap; display: flex; gap: 0.6rem; align-items: center; }
.reg-actions form { display: inline; }
.registration-add {
    display: flex;
    gap: 0.6rem;
    align-items: flex-start;
    flex-wrap: wrap;
}
.registration-add select,
.registration-add input,
.registration-add textarea { width: auto; }
.employment-add {
    display: flex;
    gap: 0.6rem;
    align-items: flex-start;
    flex-wrap: wrap;
}
.employment-add .emp-field {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
    min-width: 12rem;
}
.employment-add .emp-field label {
    margin: 0;
    font-size: 0.85rem;
    font-weight: 600;
}
.employment-add .emp-field input,
.employment-add .emp-field select,
.employment-add .emp-field textarea { width: 100%; }
.employment-add .emp-field-wide { flex-basis: 100%; min-width: 0; }
.employment-add .emp-submit { align-self: flex-end; }
.employment-add .hint { margin: 0.2rem 0 0; }
.reg-dwelling { min-width: 240px; }
.reg-dwelling-chosen { font-weight: 600; }
/* Ряд «поиск помещения + создать»: поле тянется на всю ширину, кнопки создания справа */
.registration-add .reg-dwelling { flex: 1 1 100%; min-width: 0; }
.dwelling-search { display: flex; gap: 0.7rem; align-items: center; }
.dwelling-search .search-input { flex: 1; margin-bottom: 0; }
.dwelling-create { white-space: nowrap; font-size: 0.92rem; color: var(--muted); }
.search-results {
    list-style: none;
    padding: 0;
    margin: 0.3rem 0 0;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    max-height: 180px;
    overflow-y: auto;
}
.search-results li {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.6rem;
    padding: 0.3rem 0.6rem;
}
.search-results li:hover { background: var(--row-hover); }
.reg-new-dwelling { white-space: nowrap; }

/* Стороны документа: чипы привязанных карточек + создание «на лету» */
.party-role { margin: 0.6rem 0; }
.chips {
    list-style: none;
    padding: 0;
    margin: 0.3rem 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
}
.chip {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    background: var(--msg-bg);
    padding: 0.25rem 0.6rem;
    border-radius: var(--radius);
}
.chip.incomplete { background: var(--warn-soft); border: 1px solid var(--warn-line); }
.chip-warn { cursor: help; }
.chip-edit {
    background: none;
    border: none;
    padding: 0;
    color: var(--accent);
    cursor: pointer;
    text-decoration: underline;
    font-size: 0.85em;
}
.chip-x {
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
    color: #888;  /* нейтральный серый — читается и на светлой, и на тёмной */
    line-height: 1;
}
.party-create { display: flex; flex-wrap: wrap; gap: 0.8rem; margin-top: 0.4rem; }

/* Автоподбор адреса (DaData) */
.address-search { margin: 0 0 0.8rem; }
.address-search-label { display: block; font-weight: 600; }
.address-query { width: 100%; box-sizing: border-box; }
.address-suggestions {
    list-style: none;
    padding: 0;
    margin: 0.3rem 0 0;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    max-height: 220px;
    overflow-y: auto;
}
.address-suggestions li { padding: 0; }
.address-suggestions li button {
    display: block;
    width: 100%;
    text-align: left;
    padding: 0.35rem 0.6rem;
}
.address-suggestions li button:hover { background: var(--row-hover); }

/* Автопоиск ИНН (static/js/inn.js): кнопка у поля inn, блок капчи и сообщения. */
.inn-lookup { display: block; margin-top: 0.3rem; }
.inn-lookup__btn {
    font-size: 0.82rem;
    padding: 0.2rem 0.6rem;
    line-height: 1.2;
    border: 1px solid var(--accent-line);
    border-radius: var(--radius);
    background: var(--accent-soft);
    color: var(--accent);
    cursor: pointer;
}
.inn-lookup__btn:hover { background: var(--accent); color: #fff; border-color: var(--accent); }
.inn-lookup__btn:disabled,
.inn-lookup__btn--busy { opacity: 0.6; cursor: default; }

/* Подсветка успешно подставленного ИНН (~2с). */
.inn-lookup__found {
    border-color: var(--ok) !important;
    background: var(--ok-soft) !important;
    transition: background 0.3s, border-color 0.3s;
}

/* Контейнер сообщений/капчи под кнопкой. */
.inn-lookup__box { margin-top: 0.3rem; }
.inn-lookup__msg {
    font-size: 0.82rem;
    padding: 0.25rem 0.5rem;
    border-radius: var(--radius);
    border: 1px solid var(--border);
}
.inn-lookup__msg--success { color: var(--ok); background: var(--ok-soft); border-color: var(--ok); }
.inn-lookup__msg--error { color: var(--danger); background: var(--danger-soft); border-color: var(--danger); }
.inn-lookup__msg--info { color: var(--muted); background: var(--surface); }

/* Блок капчи: картинка + поле цифр + кнопка «Проверить». */
.inn-lookup__captcha {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.4rem;
    padding: 0.4rem;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    background: var(--surface);
}
.inn-lookup__captcha-img {
    display: block;
    max-height: 50px;
    border: 1px solid var(--border);
    border-radius: var(--radius);
}
.inn-lookup__captcha-input {
    width: 8rem;
    font-size: 0.9rem;
    letter-spacing: 0.15em;
}
.inn-lookup__captcha-btn {
    font-size: 0.82rem;
    padding: 0.2rem 0.6rem;
    border-radius: var(--radius);
}
.inn-lookup__captcha-btn:disabled { opacity: 0.6; cursor: default; }

.modal-overlay {
    position: fixed;
    inset: 0;
    background: var(--overlay);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1000;
}
.modal {
    background: var(--surface);
    border-radius: var(--radius);
    padding: 1.2rem;
    width: 560px;
    max-width: 92vw;
    max-height: 85vh;
    overflow-y: auto;
}
.modal-head { display: flex; justify-content: space-between; align-items: center; }
.modal-head h3 { margin: 0; }
.modal .field { margin: 0.5rem 0; }
.modal-actions { display: flex; gap: 1rem; align-items: center; margin-top: 1rem; }

.messages { list-style: none; padding: 0; margin: 0 0 1rem; }
.messages li {
    padding: 0.6rem 1rem;
    border-radius: var(--radius);
    margin-bottom: 0.5rem;
    background: var(--msg-bg);
}
.messages li.error { background: var(--msg-err-bg); color: var(--danger); }

/* === Главная (рабочий стол оператора): форма → ввод → печать === */

.home { display: flex; flex-direction: column; gap: 1.1rem; }

/* Пусковая панель */
.home-launch {
    position: relative;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 1.4rem 1.6rem 1.6rem;
    box-shadow: 0 1px 0 rgba(20, 24, 40, .03), 0 14px 40px -28px rgba(46, 42, 134, .4);
}
.home-launch .frame { position: absolute; inset: 0; width: 100%; height: 100%; pointer-events: none; }
.home-launch .inner { position: relative; z-index: 1; }
.home .eyebrow {
    margin: 0 0 .35rem;
    font-family: var(--mono);
    font-size: .7rem;
    font-weight: 600;
    letter-spacing: .2em;
    text-transform: uppercase;
    color: var(--accent);
    display: flex;
    align-items: center;
    gap: .5rem;
}
.home .eyebrow::before { content: ""; width: 18px; height: 1px; background: var(--accent-line); }
.home-launch h2 { margin: .1rem 0 .9rem; font-size: 1.7rem; font-weight: 800; letter-spacing: -.015em; }

/* Командная строка выбора формы */
.home .cmd { position: relative; display: flex; align-items: center; }
.home .cmd .car { position: absolute; left: .95rem; font-family: var(--mono); font-weight: 700; color: var(--accent); font-size: 1.1rem; }
.form-filter {
    width: 100%;
    font-size: 1.1rem;
    padding: .85rem 1rem .85rem 2.5rem;
    border: 1.5px solid var(--accent-line);
    border-radius: var(--radius);
    background: var(--field-soft);
}
.form-filter::placeholder { color: var(--placeholder); }
.form-filter:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 4px rgba(46, 42, 134, .13); background: var(--surface); }
.home .cmd .kbd { position: absolute; right: .7rem; display: flex; gap: .3rem; }
.home .cmd .kbd kbd { font-family: var(--mono); font-size: .66rem; color: var(--muted); background: var(--kbd-bg); border: 1px solid var(--border); border-bottom-width: 2px; border-radius: 3px; padding: .12rem .35rem; }

/* Группы и клетки форм */
.form-group { margin-top: 1.2rem; }
.form-group h3 {
    margin: 0 0 .55rem;
    font-family: var(--mono);
    font-size: .7rem;
    font-weight: 600;
    letter-spacing: .13em;
    text-transform: uppercase;
    color: var(--muted);
    display: flex;
    align-items: center;
    gap: .6rem;
}
.form-group h3::after { content: ""; flex: 1; height: 1px; background: var(--border); }
.form-tiles { display: grid; grid-template-columns: repeat(auto-fill, minmax(218px, 1fr)); gap: .7rem; }
.form-tile { margin: 0; }
.form-tile button {
    position: relative;
    display: block;
    width: 100%;
    text-align: left;
    background: var(--surface);
    color: var(--text);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: .8rem .9rem .85rem;
    overflow: hidden;
    font-size: 1rem;
    transition: border-color .12s, box-shadow .12s, transform .12s;
}
.form-tile .corner { position: absolute; right: -6px; top: -6px; width: 46px; height: 46px; opacity: .5; pointer-events: none; }
.form-tile .code { display: block; font-family: var(--mono); font-size: 1.05rem; font-weight: 700; color: var(--accent); letter-spacing: .01em; }
.form-tile .name { display: block; margin-top: .2rem; font-size: .85rem; color: var(--text); line-height: 1.3; }
.form-tile .name.solo { font-size: 1rem; font-weight: 600; color: var(--text); margin-top: 0; }
.form-tile button:hover { border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent), 0 10px 24px -16px rgba(46, 42, 134, .6); transform: translateY(-1px); }

/* Панели рабочего стола (поиск / продолжить) — каждая на всю ширину */
.home-panel { position: relative; overflow: hidden; }
.home-panel > * { position: relative; z-index: 1; }
.home-panel .wm { position: absolute; right: -40px; bottom: -40px; width: 230px; height: 230px; z-index: 0; pointer-events: none; }
.home-panel h3 { margin: 0 0 .5rem; font-size: 1.05rem; font-weight: 800; letter-spacing: -.01em; display: flex; align-items: baseline; gap: .5rem; }
.home-panel h3 .ix { font-family: var(--mono); font-size: .72rem; color: var(--accent); font-weight: 600; }
.home-panel .lead { margin: .1rem 0 .7rem; color: var(--muted); font-size: .82rem; }
.home-panel .panel-sub {
    margin: 1.1rem 0 .5rem;
    padding-top: .7rem;
    border-top: 1px solid var(--border);
    font-family: var(--mono);
    font-size: .68rem;
    text-transform: uppercase;
    letter-spacing: .12em;
    color: var(--muted);
}
.home-search-input { margin-bottom: .8rem; }

/* Поиск клиента/документа — под кнопками форм, отделён линией внутри пусковой панели */
.home-find { margin-top: 1.4rem; padding-top: 1.2rem; border-top: 1px solid var(--border); }
.home-find h3 { margin: 0 0 .6rem; font-size: 1.05rem; font-weight: 800; letter-spacing: -.01em; }

/* Списки работ (черновики/печать/поиск) — общий вид */
.work-list { list-style: none; margin: 0; padding: 0; }
.work-list li { display: flex; justify-content: space-between; align-items: center; gap: .8rem; padding: .5rem 0; border-bottom: 1px solid var(--hair); }
.work-list li:last-child { border-bottom: none; }
.work-list .w-main { min-width: 0; }
.work-list .w-title { display: block; font-weight: 600; overflow-wrap: anywhere; }
.work-list .w-sub { color: var(--muted); font-size: .8rem; }
.work-list .w-sub .c { font-family: var(--mono); color: var(--accent); }
.work-list .w-actions { white-space: nowrap; font-size: .82rem; font-family: var(--mono); }

.search-cat { margin: .9rem 0 .3rem; font-family: var(--mono); font-size: .68rem; text-transform: uppercase; letter-spacing: .12em; color: var(--muted); }
.search-cat:first-child { margin-top: 0; }

[x-cloak] { display: none !important; }

/* === Бирюзовый брендинг главной раздела «Бюро переводов» ===
   Скоуп .translation-home переопределяет акцентные токены на бирюзовые
   (--tr-семейство), поэтому ВСЕ элементы пусковой панели/панели «Продолжить»
   (eyebrow, фильтр, коды, наведение плиток, ссылки) автоматически зеленеют —
   правила выше используют var(--accent…). Hover-оттенок задаём явно: для --tr
   нет готового «тёмного», берём затемнённую бирюзу. Два hover/focus-теня в
   .form-filter/.form-tile зашиты индиго-rgba (var() там не подставить) —
   переопределяем их бирюзовой rgba. Canvas-декор берёт цвет не из var(--accent)
   этого узла, а из :root (см. guilloche.js cssVar→documentElement); поэтому он
   перекрашивается в JS — accentFor() отдаёт --tr для узлов внутри .translation-home. */
.translation-home {
    --accent: var(--tr);
    --accent-hover: #0b5a53;
    --accent-soft: var(--tr-soft);
    --accent-line: var(--tr-line);
}
/* Тёмная тема: для бирюзы тёмный hover не годится — берём посветлее.
   Зеркалим способ задания базовой тёмной темы (явная dark + auto при системной). */
:root[data-theme="dark"] .translation-home { --accent-hover: #6fc8bb; }
@media (prefers-color-scheme: dark) {
    :root[data-theme="auto"] .translation-home { --accent-hover: #6fc8bb; }
}
.translation-home .form-filter:focus { box-shadow: 0 0 0 4px rgba(15, 118, 110, .15); }
.translation-home .form-tile button:hover { box-shadow: 0 0 0 1px var(--accent), 0 10px 24px -16px rgba(15, 118, 110, .6); }
.translation-home .home-launch { box-shadow: 0 1px 0 rgba(20, 24, 40, .03), 0 14px 40px -28px rgba(15, 118, 110, .4); }

/* --- Очередь «В работе» / «Напечатано» (правая панель раздела переводов) --- */
/* Сетка рабочего стола: слева приёмная (шире), справа очередь. На узких — в столбик. */
.translation-home.home { display: grid; grid-template-columns: 1.6fr 1fr; gap: 1.4rem; align-items: start; }
@media (max-width: 920px) { .translation-home.home { grid-template-columns: 1fr; } }

/* Шапка очереди: заголовок + счётчик переводов. */
.translation-home .qhead { display: flex; align-items: baseline; justify-content: space-between; gap: .6rem; }
.translation-home .qhead h3 { margin: 0; }
.translation-home .qcount { font-family: var(--mono); font-size: .72rem; color: var(--muted); font-variant-numeric: tabular-nums; white-space: nowrap; }
.translation-home .qlead { margin: .25rem 0 .9rem; color: var(--muted); font-size: .8rem; }

/* Строка перевода: реестровый код + флаг страны + время в подстроке. */
.translation-home .work-list .w-sub { display: flex; flex-wrap: wrap; gap: .45rem; align-items: center; }
.translation-home .work-list .w-sub .c { font-variant-numeric: tabular-nums; letter-spacing: .02em; }
.translation-home .work-list .w-sub time { color: var(--muted); font-variant-numeric: tabular-nums; }
/* Реестровый «флаг» страны — моно-код в рамке (UZB/TJK …). Нейтральный, не статус. */
.translation-home .flag {
    font-family: var(--mono); font-size: .62rem; letter-spacing: .08em; text-transform: uppercase;
    color: var(--muted); border: 1px solid var(--border); border-radius: 2px; padding: .05rem .3rem; line-height: 1.3;
}
/* Правая колонка строки: статус-чип над действием. */
.translation-home .work-list .w-actions { display: flex; flex-direction: column; align-items: flex-end; gap: .4rem; }

/* Статус-чип: семантика статуса (НЕ акцент). Точка слева = currentColor. */
.translation-home .chip {
    font-family: var(--mono); font-size: .6rem; letter-spacing: .06em; text-transform: uppercase;
    padding: .12rem .4rem .12rem .35rem; border-radius: 2px; border: 1px solid;
    display: inline-flex; align-items: center; gap: .3rem; white-space: nowrap; line-height: 1.4;
}
.translation-home .chip::before { content: ""; width: 5px; height: 5px; border-radius: 50%; background: currentColor; }
.translation-home .chip.draft { color: var(--st-draft); border-color: var(--st-draft-ln); background: var(--st-draft-bg); }
.translation-home .chip.done { color: var(--st-done); border-color: var(--st-done-ln); background: var(--st-done-bg); }

/* Действие-ссылка в строке очереди (кнопка «взять в работу» внутри POST-формы):
   выглядит как ссылка-действие, чтобы не ломать ряд w-actions. */
.translation-home .work-list .w-actions .linklike {
    background: none; border: none; padding: 0; cursor: pointer;
    font: inherit; color: var(--accent); white-space: nowrap;
}
.translation-home .work-list .w-actions .linklike:hover { text-decoration: underline; }

/* --- Панель статуса заказа на странице документа-перевода (редактор/просмотр).
   Скромный блок в бирюзовом скоупе; переиспользует чипы статуса выше. --- */
.translation-status { margin: 0 0 1rem; padding: .9rem 1.1rem; }
.translation-status .ts-head { display: flex; flex-wrap: wrap; align-items: center; gap: .6rem; }
.translation-status .ts-head h3 { margin: 0; font-size: .95rem; }
.translation-status .ts-scope {
    font-family: var(--mono); font-size: .58rem; letter-spacing: .08em; text-transform: uppercase;
    color: var(--muted); border: 1px solid var(--border); border-radius: 2px; padding: .05rem .35rem;
}
.translation-status .ts-actions { display: flex; flex-wrap: wrap; align-items: flex-end; gap: .7rem; margin-top: .8rem; }
.translation-status .ts-actions:empty { display: none; }
.translation-status .ts-send { display: flex; flex-wrap: wrap; align-items: flex-end; gap: .5rem; }
.translation-status .ts-send label {
    display: block; width: 100%; font-size: .72rem; color: var(--muted); margin-bottom: .15rem;
}
.translation-status .ts-send select { min-width: 14rem; }

/* --- Чат по заказу на странице документа-перевода. Скромный блок в том же
   бирюзовом скоупе; список переиспользует .messages, форма — токены полей. --- */
.chat-thread { margin: 0 0 1rem; padding: .9rem 1.1rem; }
.chat-thread h3 { margin: 0 0 .7rem; font-size: .95rem; }
.chat-thread .chat-messages { max-height: 18rem; overflow-y: auto; }
.chat-thread .chat-messages li { display: flex; flex-direction: column; gap: .25rem; }
.chat-thread .chat-meta {
    display: flex; flex-wrap: wrap; align-items: baseline; gap: .5rem;
    font-size: .72rem; color: var(--muted);
}
.chat-thread .chat-author { font-weight: 600; color: var(--text); }
.chat-thread .chat-office {
    font-family: var(--mono); font-size: .58rem; letter-spacing: .06em;
    color: var(--accent);
}
.chat-thread .chat-time { font-family: var(--mono); font-size: .66rem; margin-left: auto; }
.chat-thread .chat-text { white-space: pre-wrap; }
.chat-thread .chat-empty { background: none; padding: .3rem 0; }
.chat-thread .chat-form { display: flex; flex-direction: column; align-items: flex-end; gap: .5rem; }
.chat-thread .chat-form textarea { width: 100%; resize: vertical; }

/* Плитка-заглушка будущей формы («готовится») — некликабельна. */
.translation-home .form-tile.soon button { cursor: default; background: var(--field-soft); }
.translation-home .form-tile.soon button:hover { border-color: var(--border); box-shadow: none; transform: none; }
.translation-home .form-tile.soon .name { color: var(--muted); }
.translation-home .form-tile .tag {
    display: inline-block; margin-top: .4rem; font-family: var(--mono); font-size: .56rem;
    letter-spacing: .1em; text-transform: uppercase; color: var(--warn);
    background: var(--warn-soft); border: 1px solid var(--warn-line); border-radius: 2px; padding: .08rem .35rem;
}

/* === Декор внутренних страниц (рисует js/guilloche.js) === */
/* Гильоше-линейка под заголовком списка/карточки */
.page-rule { display: block; width: 100%; height: 14px; margin: .1rem 0 1.1rem; }
/* Печать-водяной знак на главной секции карточки/документа */
.detail-group.sealed { position: relative; overflow: hidden; }
.detail-group.sealed > * { position: relative; z-index: 1; }
.detail-group.sealed .wm { position: absolute; right: -42px; bottom: -42px; width: 210px; height: 210px; z-index: 0; pointer-events: none; }
/* Печать в левой панели редактора */
.doc-edit .panel { overflow: hidden; }
.doc-edit .panel > * { position: relative; z-index: 1; }
.doc-edit .panel .wm { position: absolute; right: -26px; bottom: -26px; width: 168px; height: 168px; z-index: 0; pointer-events: none; }

/* === Редактор документа: две зоны (панель сторон + секции) === */
.doc-edit .doc-head { display: flex; align-items: center; gap: 0.8rem; flex-wrap: wrap; margin-bottom: 1rem; }
.doc-edit .doc-head h1 { margin: 0; font-size: 1.4rem; letter-spacing: -0.01em; }
.doc-edit .doc-head .doc-sub { color: var(--muted); font-size: 0.9rem; }
.doc-edit .badge {
    display: inline-flex; align-items: center; gap: 0.35rem; font-size: 0.76rem;
    font-weight: 600; padding: 0.2rem 0.6rem; border-radius: 999px;
    text-transform: uppercase; letter-spacing: 0.03em;
    background: var(--accent-soft); color: var(--accent);
}
.doc-edit .badge::before { content: "●"; font-size: 0.6em; }
.doc-edit .badge.printed { background: var(--ok-soft); color: var(--ok); }

/* Бейдж статуса документа: «завершён» (зелёный, сильнее всего) > «печатался»
   (янтарный — промежуточный) > «черновик» (нейтральный). Базовый вид нужен и в
   шапке просмотра (.list-header), где бейджа раньше не было. */
.list-header .badge {
    display: inline-flex; align-items: center; gap: 0.35rem; font-size: 0.76rem;
    font-weight: 600; padding: 0.2rem 0.6rem; border-radius: 999px;
    text-transform: uppercase; letter-spacing: 0.03em; vertical-align: middle;
    background: var(--accent-soft); color: var(--accent);
}
.list-header .badge::before { content: "●"; font-size: 0.6em; }
.doc-edit .badge.printed,
.list-header .badge.printed { background: #fbf1e0; color: var(--warn); }
.doc-edit .badge.frozen,
.list-header .badge.frozen { background: var(--ok-soft); color: var(--ok); }

/* История жизненного цикла документа (_doc_history.html): левая панель редактора
   и шапка просмотра. */
.doc-history { margin-top: 1rem; font-size: 0.84rem; }
.doc-history .dh-title {
    font-weight: 600; color: var(--muted); text-transform: uppercase;
    letter-spacing: 0.03em; font-size: 0.72rem; margin-bottom: 0.4rem;
}
.doc-history .dh-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 0.3rem; }
.doc-history .dh-list .dh-when { color: var(--muted); font-variant-numeric: tabular-nums; margin-right: 0.4rem; }
.doc-history .dh-list .dh-soft { color: var(--muted); }

/* Поле причины возврата в черновик (разморозка завершённого документа). */
.reopen-reason {
    padding: 0.3rem 0.5rem; border: 1px solid var(--border);
    border-radius: var(--radius); font-size: 0.85rem; min-width: 11rem;
}

.doc-edit .lay { display: grid; grid-template-columns: 313px 1fr; gap: 1.4rem; align-items: start; }
@media (max-width: 880px) { .doc-edit .lay { grid-template-columns: 1fr; } }

/* Левая панель */
.doc-edit .panel { position: sticky; top: 0.8rem; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 0.4rem; }
.doc-edit .navlist { display: flex; flex-direction: column; gap: 0.15rem; }
.doc-edit .navitem { display: flex; align-items: center; gap: 0.6rem; width: 100%; text-align: left; background: none; border: none; border-radius: 6px; padding: 0.55rem 0.65rem; cursor: pointer; font-family: inherit; color: var(--text); }
.doc-edit .navitem:hover { background: var(--nav-hover); }
.doc-edit .navitem.active { background: var(--nav-active); }
.doc-edit .navitem.active .ni-name { color: var(--accent); }
.doc-edit .navitem .ni-main { display: flex; flex-direction: column; min-width: 0; flex: 1; }
.doc-edit .navitem .ni-role { font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.03em; color: var(--muted); }
.doc-edit .navitem .ni-name { font-weight: 600; font-size: 0.95rem; overflow-wrap: anywhere; }
/* Раскладка «пункт на сторону»: заголовок группы + пункт «добавить» */
.doc-edit .navgroup { font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.04em; color: var(--muted); font-weight: 700; padding: 0.6rem 0.65rem 0.2rem; }
.doc-edit .navitem.navadd .ni-name { color: var(--accent); font-weight: 600; }
.doc-edit .navitem.navadd { padding-top: 0.35rem; padding-bottom: 0.35rem; }
.doc-edit .pill { flex: none; min-width: 1.3rem; height: 1.3rem; padding: 0 0.35rem; border-radius: 999px; font-size: 0.72rem; font-weight: 700; display: inline-flex; align-items: center; justify-content: center; }
.doc-edit .pill.warn { background: var(--warn-pill); color: var(--warn-pill-ink); }
.doc-edit .pill.ok { background: var(--ok-soft); color: var(--ok); }
.doc-edit .nsep { height: 1px; background: var(--border); margin: 0.5rem 0.4rem; }
.doc-edit .readiness { padding: 0.2rem 0.55rem 0.4rem; }
.doc-edit .readiness h4 { margin: 0 0 0.5rem; font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.05em; color: var(--muted); }
.doc-edit .checklist { list-style: none; margin: 0; padding: 0; }
.doc-edit .checklist li { display: flex; align-items: flex-start; gap: 0.45rem; padding: 0.28rem 0; font-size: 0.85rem; }
.doc-edit .checklist .mark { flex: none; width: 1rem; text-align: center; font-weight: 700; }
.doc-edit .checklist li.ok { color: var(--muted); } .doc-edit .checklist li.ok .mark { color: var(--ok); }
.doc-edit .checklist li.todo .mark { color: var(--warn-pill); }
.doc-edit .recs { padding: 0.2rem 0.55rem 0.4rem; }
.doc-edit .recs h4 { margin: 0 0 0.5rem; font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.05em; color: var(--muted); }
.doc-edit .recs ul { list-style: none; margin: 0; padding: 0; }
.doc-edit .recs li { display: flex; align-items: flex-start; gap: 0.45rem; padding: 0.28rem 0; font-size: 0.85rem; color: var(--hint-text); }
.doc-edit .recs .mark { flex: none; }
.doc-edit .panel-actions { display: flex; flex-direction: column; gap: 0.4rem; padding: 0.2rem 0.4rem 0.3rem; }
.doc-edit .panel-actions .btn { width: 100%; text-align: center; }

/* Заголовок стороны */
.doc-edit .entity-head { display: flex; align-items: center; gap: 0.8rem; flex-wrap: wrap; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 0.7rem 1rem; margin-bottom: 0.8rem; }
.doc-edit .entity-head .eh-main { min-width: 0; }
.doc-edit .entity-head .role { font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.04em; color: var(--muted); font-weight: 600; }
.doc-edit .entity-head .ename { font-weight: 700; font-size: 1.05rem; }
.doc-edit .entity-head .ename a { color: inherit; text-decoration: none; }
.doc-edit .entity-head .ename a:hover { text-decoration: underline; }
.doc-edit .entity-head .eh-act { margin-left: auto; display: flex; gap: 0.9rem; font-size: 0.88rem; }
.doc-edit .linkbtn { background: none; border: none; padding: 0; cursor: pointer; color: var(--accent); font-size: inherit; font-family: inherit; }
.doc-edit .linkbtn:hover { text-decoration: underline; }
.doc-edit .linkbtn.muted { color: var(--muted); }

/* Группа-карточка полей + мелкий заголовок справа */
.doc-edit .group { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 0.7rem 1.1rem 1rem; margin-bottom: 0.8rem; }
.doc-edit .group-head { display: flex; align-items: center; gap: 0.6rem; margin: 0 0 0.7rem; }
.doc-edit .group-head::before { content: ""; flex: 1; height: 1px; background: var(--border); }
.doc-edit .group-head h3 { margin: 0; font-size: 0.72rem; font-weight: 600; color: var(--muted); text-transform: uppercase; letter-spacing: 0.04em; }
/* Поля по верху ячейки: всплывающий хинт растит ячейку вниз (смещает нижнее),
   а не сдвигает поле — соседи в ряду не растягиваются. */
.doc-edit .form-grid { align-items: start; }

.doc-edit .section-save { margin-top: 0.4rem; }

/* Выбор адреса места работы — радио-карточки с подсказками */
.doc-edit .addr-choice { display: flex; flex-direction: column; gap: 0.4rem; }
.doc-edit .addr-opt { display: flex; align-items: flex-start; gap: 0.5rem; padding: 0.5rem 0.7rem; border: 1px solid var(--border); border-radius: var(--radius); cursor: pointer; }
.doc-edit .addr-opt:hover { border-color: var(--dashed-line); background: var(--card-hover-bg); }
.doc-edit .addr-opt.sel { border-color: var(--accent); background: var(--nav-active); }
.doc-edit .addr-opt input { margin-top: 0.2rem; }
.doc-edit .addr-opt .ao-main { display: flex; flex-direction: column; }
.doc-edit .addr-opt .ao-t { font-weight: 600; font-size: 0.92rem; }
.doc-edit .addr-opt .ao-s { font-size: 0.82rem; color: var(--muted); }
.doc-edit [data-wp-premises][hidden] { display: none; }

/* Режим предпросмотра: панель убираем, лист разворачиваем на всю ширину окна
   (альбомные бланки 297мм не влезали в правую колонку 1fr и уходили вправо).
   full-bleed: выходим за max-width контейнера к краям вьюпорта. */
.doc-edit .lay.pv-only { grid-template-columns: 1fr; width: 100vw; margin-left: calc(50% - 50vw); padding: 0 1.4rem; }
.doc-edit .lay.pv-only > .panel { display: none; }
.doc-edit .pv-bar { display: flex; gap: 0.6rem; align-items: center; margin-bottom: 0.7rem; }
.doc-edit .pv-bar .btn { width: auto; }
.doc-edit .pv-sec .pv-host { max-height: 86vh; }

/* Редактор динамической таблицы (УПП: места работы / выезды / доходы) */
.doc-edit .doc-table-edit .dt-hint { margin: -0.2rem 0 0.6rem; font-size: 0.82rem; color: var(--muted); }
.doc-edit .dt-scroll { overflow-x: auto; }
.doc-edit table.doc-table { width: 100%; border-collapse: collapse; font-size: 0.9rem; }
.doc-edit table.doc-table th {
    text-align: left; font-weight: 600; font-size: 0.78rem; color: var(--muted);
    padding: 0 0.4rem 0.3rem; white-space: nowrap;
}
.doc-edit table.doc-table td { padding: 0.15rem 0.4rem 0.15rem 0; vertical-align: top; }
.doc-edit table.doc-table td .muted { padding: 0.4rem 0; }
.doc-edit table.doc-table input { width: 100%; min-width: 7rem; }
.doc-edit table.doc-table th.dt-rm, .doc-edit table.doc-table td.dt-rm { width: 1.8rem; padding-right: 0; }
.doc-edit .dt-del {
    background: none; color: var(--muted); border: 1px solid var(--border);
    padding: 0.25rem 0.45rem; line-height: 1; border-radius: var(--radius); cursor: pointer;
}
.doc-edit .dt-del:hover { color: var(--danger); border-color: var(--danger); background: var(--danger-soft); }
.doc-edit .dt-add { margin-top: 0.5rem; padding: 0.3rem 0.8rem; font-size: 0.88rem; }

/* Поле поиска в секции стороны — без нижнего отступа (компактно) */
.doc-edit .attach .search-input { margin-bottom: 0.2rem; }

/* Результаты поиска стороны — кликабельные карточки целиком (без кнопки) */
.doc-edit .result-cards { margin: 0.5rem 0 0; padding: 0; display: flex; flex-direction: column; gap: 0.4rem; }
.doc-edit .result-card {
    display: flex; align-items: center; gap: 0.7rem; width: 100%; text-align: left;
    padding: 0.55rem 0.7rem; border: 1px solid var(--border); border-radius: var(--radius);
    background: var(--surface); color: var(--text); cursor: pointer; font-family: inherit;
}
.doc-edit .result-card:hover { border-color: var(--dashed-line); background: var(--card-hover-bg); }
.doc-edit .result-card:focus { outline: none; border-color: var(--accent); background: var(--nav-active); box-shadow: 0 0 0 2px var(--accent-soft); }
.doc-edit .rc-avatar { flex: none; width: 2.1rem; height: 2.1rem; border-radius: 50%; background: var(--nav-active); color: var(--accent); display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 0.8rem; }
.doc-edit .rc-avatar.icon { background: var(--th-bg); font-size: 1rem; }
.doc-edit .rc-main { display: flex; flex-direction: column; min-width: 0; flex: 1; }
.doc-edit .rc-name { font-weight: 600; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.doc-edit .rc-sub { font-size: 0.82rem; color: var(--muted); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.doc-edit .attach { background: var(--surface); border: 1px dashed var(--dashed-line); border-radius: var(--radius); padding: 0.8rem 1rem; }
.doc-edit .attach .muted { margin: 0 0 0.5rem; }
.doc-edit .note { background: var(--hint-bg); border: 1px solid var(--warn-line); border-radius: var(--radius); padding: 0.5rem 0.8rem; margin-bottom: 0.8rem; font-size: 0.9rem; }

/* Результаты поиска законного представителя: компактные строки (имя · реквизиты · родство · выбрать) */
.legal-rep .lr-results { list-style: none; margin: 0.4rem 0 0.8rem; padding: 0; display: flex; flex-direction: column; gap: 0.35rem; }
.legal-rep .lr-result form { display: flex; align-items: center; gap: 0.6rem; flex-wrap: wrap; padding: 0.4rem 0.6rem; border: 1px solid var(--border); border-radius: var(--radius); background: var(--surface); }
.legal-rep .lr-result-name { font-weight: 600; }
.legal-rep .lr-result .muted { font-size: 0.82rem; }

/* Подсветка незаполненного ключевого поля (жёлтый фон + рамка) */
.doc-edit .form-field.field-missing input,
.doc-edit .form-field.field-missing select { border-color: var(--warn-line); background: var(--field-missing-bg); }

/* Подсказка по полю — балун-облачко (js/hints.js), всплывает над низом, не двигая поле */
.form-field { position: relative; }
.field-hint {
    display: none; position: absolute; z-index: 30; left: 0; top: calc(100% + 9px);
    width: max-content; max-width: 300px;
    background: var(--hint-bg); color: var(--hint-text); border: 1px solid var(--warn-line);
    padding: 0.45rem 0.65rem; border-radius: 10px; font-size: 0.8rem; line-height: 1.35;
    box-shadow: 0 6px 18px rgba(31, 36, 48, .16);
}
.field-hint::before, .field-hint::after { content: ""; position: absolute; bottom: 100%; border: 8px solid transparent; }
.field-hint::before { left: 15px; border-bottom-color: var(--warn-line); }
.field-hint::after { left: 16px; border-width: 7px; border-bottom-color: var(--hint-bg); }

.notice {
    background: var(--warn-soft);
    border: 1px solid var(--warn-line);
    border-radius: var(--radius);
    padding: 0.5rem 0.8rem;
    margin: 0.6rem 0;
    font-size: 0.9rem;
}
.form-empty-hint { margin: 0.6rem 0 0; }
.panel-more { display: inline-block; margin-top: 0.6rem; font-size: 0.85rem; }

/* Чипы-фильтры (жизненный цикл документа в списке) */
.status-filter { display: flex; gap: 0.4rem; margin-bottom: 0.8rem; }
.chip-link {
    padding: 0.25rem 0.7rem;
    border: 1px solid var(--border);
    border-radius: 999px;
    color: var(--muted);
    font-size: 0.85rem;
}
.chip-link:hover { text-decoration: none; color: var(--accent); }
.chip-link.active {
    background: var(--accent);
    border-color: var(--accent);
    color: var(--on-accent);
}

/* Список документов: две колонки — слева «Напечатано», справа «Черновики». */
.doc-cols { display: flex; gap: 1.2rem; align-items: flex-start; }
.doc-cols .doc-col { flex: 1 1 0; min-width: 0; }
.doc-col-head {
    margin: 0 0 0.5rem;
    font-size: 1rem;
    display: flex;
    align-items: baseline;
    gap: 0.4rem;
}
.doc-col-head .doc-count { color: var(--muted); font-size: 0.8rem; font-weight: 400; }
.doc-col td.doc-date {
    white-space: nowrap;
    text-align: right;
    color: var(--muted);
    font-size: 0.85rem;
}
@media (max-width: 800px) { .doc-cols { flex-direction: column; } }

/* Переключатель темы в шапке: сегмент Авто / Светлая / Тёмная (js/theme.js).
   Активная кнопка отмечается aria-pressed="true". */
.theme-seg {
    display: inline-flex;
    border: 1px solid var(--border);
    border-radius: 999px;
    overflow: hidden;
}
.theme-seg button {
    appearance: none;
    border: 0;
    background: transparent;
    color: var(--muted);
    font: inherit;
    font-size: .8rem;
    padding: .28rem .7rem;
    cursor: pointer;
    line-height: 1;
}
.theme-seg button[aria-pressed="true"] { background: var(--accent); color: var(--on-accent); }

/* === Изоляция листа в превью документа ===
   Лист всегда «бумажный» (как на печати): даже в тёмной теме контент бланка,
   читающий var(--text)/var(--surface)/var(--border), остаётся тёмным на белом.
   Печатные шаблоны (documents/*, generated/*, @media print) при этом не трогаем —
   переопределяем токены только в области предпросмотра. */
.pv-host .paper, .pv-host .print-area {
    --text: #15181f;
    --bg: #e9ecf1;
    --surface: #ffffff;
    --muted: #59636f;
    --border: #cdd4de;
    --hair: #cdd4de;
    color: #15181f;
}
