
/* ============================================================
   АРХИТЕКТУРНОЕ ПРИМЕЧАНИЕ
   ============================================================
   Все Web Components в /components используют LIGHT DOM (НЕ Shadow DOM).
   Это сделано НАМЕРЕННО:
   - глобальный CSS из этого файла применяется ко всем секциям
   - querySelectorAll() из app.js видит все элементы внутри компонентов
   - совместимость со скрин-ридерами выше
   - проще отладка через DevTools

   Минус: нет изоляции стилей — все классы и id должны быть уникальны
   во ВСЁМ приложении. При добавлении новых компонентов — проверять
   уникальность через `grep` по components/.
   ============================================================ */

  :root {
    /* Темная тема (по умолчанию) */
    /* #14: Палитра отличается от основной программы followup
       (там --accent: #3b82f6 синий). Если нужна единая семья — 
       замените --accent на #3b82f6 и --accent-dark на #2563eb. */
    --bg: #0F1923;
    --surface: #1A2736;
    --surface-alt: #1E2F40;
    --border: #2A3F55;
    --border-focus: #00BCD4;
    --accent: #00BCD4;
    --accent-dark: #0097A7;
    --accent-light: rgba(0,188,212,.12);
    --on-accent: #0F1923;            /* контрастный текст на акцентном фоне */
    --text: #E8EDF2;
    --text-sec: #8FA4B8;
    --text-muted: #5E7588;
    --danger: #E57373;            /* было #FF5252 — менее насыщенный коралловый, легче для глаз */
    --danger-bg: rgba(229,115,115,.12);
    --warning: #E8A547;            /* мягкий янтарный (было хардкод var(--warning)) */
    --warning-bg: rgba(232,165,71,.12);
    --success: #4CAF50;
    --success-bg: rgba(76,175,80,.12);
    --head: #E8EDF2;
    --radius: 8px;
    --shadow: 0 2px 12px rgba(0,0,0,.3);
    --tr: 0.25s ease;
    --glow: 0 0 20px rgba(0,188,212,.15);
    --input-bg: #162230;
  }

  /* ============================================================
     СВЕТЛАЯ ТЕМА v2.3.1 — высококонтрастная (стиль MS Word)
     ============================================================
     Образец — Microsoft Word: ЧИСТО БЕЛЫЙ фон, ЧЁРНЫЙ текст,
     серый контур вокруг карточек, синий акцент.
     Никаких бежевых полутонов, никаких "приглушённых" цветов —
     максимальная читаемость, контраст текста к фону >12:1.
     ============================================================ */
  body.light-theme {
    --bg: #E5E5E5;                   /* серый фон вокруг "страниц" — как в Word */
    --surface: #FFFFFF;              /* карточки — чисто белый */
    --surface-alt: #F5F5F5;          /* вторичный фон таблиц/чипов — очень светлый серый */
    --border: #B0B0B0;               /* серая рамка как в Word — заметная */
    --border-focus: #2B7FBF;
    --accent: #2B7FBF;               /* офисный голубой — узнаваемый */
    --accent-dark: #1F5A8A;
    --accent-light: rgba(43,127,191,.10);
    --on-accent: #FFFFFF;
    --text: #000000;                 /* ЧЁРНЫЙ — как в документе */
    --text-sec: #404040;             /* тёмно-серый для подписей */
    --text-muted: #707070;
    --head: #000000;
    --danger: #C00000;               /* классический красный из Office */
    --danger-bg: rgba(192,0,0,.08);
    --warning: #BF8F00;              /* тёмно-золотой */
    --warning-bg: rgba(191,143,0,.10);
    --success: #2F7D2F;
    --success-bg: rgba(47,125,47,.10);
    --shadow: 0 0 0 1px #B0B0B0, 0 2px 4px rgba(0,0,0,.10);
    --glow: 0 0 0 2px rgba(43,127,191,.40);
    --input-bg: #FFFFFF;
  }

  /* Шапка — белая страница с серой рамкой как в Word */
  body.light-theme .page-header {
    background: #FFFFFF;
    border: 1px solid #B0B0B0;
    box-shadow: 0 2px 6px rgba(0,0,0,.10);
  }
  body.light-theme .page-header .org-name { color: #000000; font-weight: 700; }
  body.light-theme .page-header .org-addr { color: #404040; }

  /* Шапки секций — светло-серый блок с чёрным текстом */
  body.light-theme .section-header {
    background: #F5F5F5;
    color: #000000;
    border-bottom: 1px solid #B0B0B0;
    font-weight: 700;
  }
  body.light-theme .section-header:hover {
    background: #EBEBEB;
  }
  body.light-theme .section-header .num {
    background: var(--accent);
    color: #FFFFFF;
  }
  body.light-theme .section {
    background: #FFFFFF;
    border: 1px solid #B0B0B0;
    box-shadow: 0 2px 4px rgba(0,0,0,.08);
  }

  /* Поля ввода — белые с чёткой серой рамкой, чёрный текст */
  body.light-theme .field input,
  body.light-theme .field select,
  body.light-theme .field textarea,
  body.light-theme .mt input,
  body.light-theme .mt select {
    background: #FFFFFF;
    border: 1px solid #909090;
    color: #000000;
  }
  body.light-theme .field input::placeholder,
  body.light-theme .field textarea::placeholder { color: #909090; }
  body.light-theme .field input:hover,
  body.light-theme .field select:hover,
  body.light-theme .field textarea:hover {
    border-color: #404040;
  }
  body.light-theme .field input:focus,
  body.light-theme .field select:focus,
  body.light-theme .field textarea:focus,
  body.light-theme .mt input:focus,
  body.light-theme .mt select:focus {
    border-color: var(--accent);
    box-shadow: var(--glow);
    outline: none;
  }
  body.light-theme .field label {
    color: #000000;
    font-weight: 600;
  }

  /* Верхняя нав-панель — белая с серой рамкой */
  body.light-theme .top-nav-bar {
    background: #FFFFFF;
    border: 1px solid #B0B0B0;
    box-shadow: 0 2px 4px rgba(0,0,0,.08);
  }
  body.light-theme .top-nav-btn {
    background: transparent;
    color: #000000;
    font-weight: 500;
  }
  body.light-theme .top-nav-btn:hover {
    background: var(--accent-light);
    color: var(--accent);
  }
  body.light-theme .top-nav-btn.active {
    background: var(--accent);
    color: #FFFFFF;
  }
  body.light-theme .top-nav-btn .nav-num {
    background: #E0E0E0;
    color: #000000;
    font-weight: 700;
  }
  body.light-theme .top-nav-btn.active .nav-num {
    background: rgba(255,255,255,.30);
    color: #FFFFFF;
  }

  /* Сайдбар — белый */
  body.light-theme .sidebar {
    background: #FFFFFF;
    border-left: 1px solid #B0B0B0;
    box-shadow: -4px 0 12px rgba(0,0,0,.15);
  }
  body.light-theme .sidebar-btn,
  body.light-theme .sidebar-nav-link {
    color: #000000;
    background: transparent;
  }
  body.light-theme .sidebar-btn:hover,
  body.light-theme .sidebar-nav-link:hover {
    background: var(--accent-light);
    color: var(--accent);
  }
  body.light-theme .sidebar-btn svg { fill: #404040; }
  body.light-theme .sidebar-btn:hover svg { fill: var(--accent); }
  body.light-theme .sidebar h3 { color: var(--accent); }
  body.light-theme .sidebar-version { color: #909090; }
  body.light-theme .sidebar-sep { background: #B0B0B0; }

  /* FAB */
  body.light-theme .fab {
    background: var(--accent);
    color: #FFFFFF;
    box-shadow: 0 4px 10px rgba(43,127,191,.40);
  }
  body.light-theme .fab:hover {
    background: var(--accent-dark);
  }

  /* Чипы */
  body.light-theme .symptom-chips .chip,
  body.light-theme .checkup-rec {
    background: #FFFFFF;
    border: 1px solid #909090;
    color: #000000;
  }
  body.light-theme .symptom-chips .chip:hover,
  body.light-theme .checkup-rec:hover {
    border-color: var(--accent);
    background: var(--accent-light);
  }
  body.light-theme .symptom-chips .chip.active {
    background: var(--accent);
    color: #FFFFFF;
    border-color: var(--accent);
    font-weight: 600;
  }

  /* Таблица измерений */
  body.light-theme .mt th {
    background: #E0E0E0;
    color: #000000;
    border: 1px solid #B0B0B0;
    font-weight: 700;
  }
  body.light-theme .mt td {
    border: 1px solid #B0B0B0;
    color: #000000;
  }
  body.light-theme .mt tbody tr:hover td { background: #F5F5F5; }

  /* Модалки */
  body.light-theme .modal-overlay { background: rgba(0,0,0,.40); }
  body.light-theme .modal {
    background: #FFFFFF;
    border: 1px solid #B0B0B0;
    box-shadow: 0 12px 36px rgba(0,0,0,.30);
  }
  body.light-theme .modal-head {
    background: #F5F5F5;
    border-bottom: 1px solid #B0B0B0;
    color: #000000;
  }

  /* Статус-плашки */
  body.light-theme .status-banner.status-info {
    background: var(--accent-light);
    color: var(--accent-dark);
    border-color: var(--accent);
  }
  body.light-theme .status-banner.status-warn {
    background: var(--warning-bg);
    color: var(--warning);
    border-color: var(--warning);
  }
  body.light-theme .status-banner.status-error {
    background: var(--danger-bg);
    color: var(--danger);
    border-color: var(--danger);
  }

  /* Графики истории */
  body.light-theme .history-chart {
    background: #FFFFFF;
    border: 1px solid #B0B0B0;
  }
  body.light-theme .history-empty,
  body.light-theme .history-summary {
    background: #FFFFFF;
    border: 1px solid #B0B0B0;
    color: #000000;
  }

  /* Архив поиск */
  body.light-theme .archive-list {
    background: #FFFFFF;
    border: 1px solid #B0B0B0;
    box-shadow: 0 6px 18px rgba(0,0,0,.15);
  }
  body.light-theme .archive-item:hover,
  body.light-theme .archive-item:focus {
    background: var(--accent-light);
  }
  body.light-theme .archive-item { color: #000000; }
  body.light-theme .patient-finder-list { background: #FFFFFF; }
  body.light-theme .patient-finder-rec {
    background: #F5F5F5;
    border: 1px solid #B0B0B0;
  }

  /* Stepper */
  body.light-theme .stepper-btn {
    background: var(--accent);
    color: #FFFFFF;
    border: none;
    font-weight: 600;
  }
  body.light-theme .stepper-btn:hover { background: var(--accent-dark); }
  body.light-theme .stepper-btn:disabled { background: #C0C0C0; color: #707070; }

  /* Подсказка-иконка */
  body.light-theme .mt .norm-tip-icon {
    background: var(--accent);
    color: #FFFFFF;
  }
  body.light-theme .mt .norm-tip-popover {
    background: #FFFFFF;
    border: 2px solid var(--accent);
    color: #000000;
    box-shadow: 0 6px 18px rgba(0,0,0,.20);
  }

  /* Селект режима */
  body.light-theme .page-header h1 .mode-switcher {
    background: #FFFFFF;
    border: 1.5px solid var(--accent);
    color: var(--accent);
    font-weight: 700;
  }
  body.light-theme .page-header h1 .mode-switcher .mode-switcher-icon {
    color: var(--accent);
  }
  body.light-theme .page-header h1 .mode-switcher:hover {
    background: var(--accent);
    color: #FFFFFF;
    box-shadow: 0 4px 12px rgba(43,127,191,.30);
  }
  body.light-theme .page-header h1 .mode-switcher:hover .mode-switcher-icon { color: #FFFFFF; }

  /* Дата протокола в шапке */
  body.light-theme .page-header .header-date-label { color: #404040; }
  body.light-theme .page-header .header-date-input {
    background: #FFFFFF;
    border: 1px solid #909090;
    color: #000000;
  }

  /* Stepper-progress */
  body.light-theme .stepper-progress { background: #E0E0E0; }
  body.light-theme .stepper-progress-bar { background: var(--accent); }

  /* Body */
  body.light-theme { color: #000000; }

  *,*::before,*::after { box-sizing: border-box; margin: 0; padding: 0; }
  body { font-family: Arial, 'Helvetica Neue', Helvetica, sans-serif; background: var(--bg); color: var(--text); line-height: 1.55; min-height: 100vh; transition: background 0.3s, color 0.3s; }

  /* Шапка */
  .page-header { max-width: 1250px; margin: 12px auto 6px; background: var(--surface); color: var(--text); padding: 14px 18px 12px; text-align: center; position: relative; overflow: hidden; border: 1px solid var(--border); border-radius: 10px; box-shadow: var(--shadow); }
  .page-header h1 { font-size: 18px; font-weight: 700; letter-spacing: .3px; margin: 6px 0 4px; color: var(--head); }
  .page-header .org-name { font-size: 14px; font-weight: 700; color: var(--text); }
  .page-header .org-addr { font-size: 11px; font-weight: 400; color: var(--text-sec); margin-bottom: 2px; }
  .sidebar-version { padding: 8px 14px; font-size: 10px; color: var(--text-muted); text-align: right; letter-spacing: 0.5px; opacity: 0.6; }

  /* Селектор режима протокола внутри h1 — выглядит как заголовок,
     при наведении подсвечивается, можно переключить */
  .page-header { position: relative; }
  .page-header h1 .mode-switcher {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: var(--accent-light);
    border: 1.5px solid var(--accent);
    color: var(--head);
    font-size: inherit;
    font-weight: inherit;
    letter-spacing: inherit;
    font-family: inherit;
    text-align: center;
    cursor: pointer;
    padding: 6px 16px;
    border-radius: 24px;
    transition: all 0.18s ease;
    box-shadow: 0 1px 3px rgba(0,0,0,.12);
  }
  .page-header h1 .mode-switcher .mode-switcher-icon {
    color: var(--accent);
    flex-shrink: 0;
    transition: transform 0.3s ease;
  }
  .page-header h1 .mode-switcher:hover {
    background: var(--accent);
    color: var(--on-accent);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(0,188,212,.30);
  }
  .page-header h1 .mode-switcher:hover .mode-switcher-icon {
    color: var(--on-accent);
    transform: rotate(180deg);
  }
  .page-header h1 .mode-switcher:active { transform: translateY(0); }
  .page-header h1 .mode-switcher:focus-visible {
    outline: 3px solid var(--accent);
    outline-offset: 2px;
  }

  /* Дата протокола в правом верхнем углу шапки */
  .page-header .header-date-wrap {
    position: absolute;
    top: 12px;
    right: 16px;
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 11px;
    color: var(--text-sec);
  }
  .page-header .header-date-label { font-weight: 500; }
  .page-header .header-date-input {
    background: var(--input-bg);
    color: var(--text);
    border: 1px solid var(--border);
    border-radius: 4px;
    padding: 3px 6px;
    font-size: 11.5px;
    font-family: inherit;
    width: 130px;
    outline: none;
  }
  .page-header .header-date-input:focus { border-color: var(--accent); box-shadow: 0 0 0 2px rgba(0,188,212,.15); }

  @media (max-width: 600px) {
    .page-header .header-date-wrap { position: static; justify-content: center; margin-top: 4px; }
  }

  .container { max-width: 1250px; margin: 0 auto; padding: 10px 16px 40px; }

  /* === Верхняя панель навигации === */
  .top-nav-bar {
    position: sticky;
    top: 0;
    z-index: 4500;
    max-width: 1250px;
    margin: 0 auto 8px;
    padding: 6px 8px;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 10px;
    box-shadow: var(--shadow);
    display: flex;
    gap: 4px;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;  /* iOS momentum */
    overscroll-behavior-x: contain;     /* не цепляем скролл страницы */
    scrollbar-width: thin;
    backdrop-filter: blur(6px);
    -ms-overflow-style: none;           /* IE/Edge — скрытая полоса */
    touch-action: pan-x;                /* horizontal pan на мобиле */
  }
  .top-nav-bar::-webkit-scrollbar { height: 6px; }
  .top-nav-bar::-webkit-scrollbar-thumb { background: var(--border); border-radius: 3px; }
  .top-nav-btn {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 7px 12px;
    background: transparent;
    color: var(--text-sec);
    border: 1px solid transparent;
    border-radius: 6px;
    font-family: inherit;
    font-size: 12px;
    font-weight: 600;
    cursor: pointer;
    white-space: nowrap;
    transition: all var(--tr);
  }
  .top-nav-btn .nav-num {
    background: var(--surface-alt);
    color: var(--text-sec);
    width: 20px; height: 20px;
    border-radius: 50%;
    font-size: 10px;
    font-weight: 800;
    font-family: 'Consolas', monospace;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: all var(--tr);
  }
  .top-nav-btn:hover { background: var(--accent-light); color: var(--accent); border-color: rgba(0,188,212,.25); }
  .top-nav-btn:hover .nav-num { background: var(--accent); color: var(--on-accent); }
  .top-nav-btn.active { background: var(--accent-light); color: var(--accent); border-color: var(--accent); }
  .top-nav-btn.active .nav-num { background: var(--accent); color: var(--on-accent); box-shadow: 0 0 6px rgba(0,188,212,.5); }
  .top-nav-btn.completed .nav-num { background: var(--success); color: #fff; }
  .top-nav-btn.hidden-btn { display: none; }

  @media print { .top-nav-bar { display: none !important; } }

  /* М6: на узких экранах верхняя панель сжимается до номеров без подписей */
  @media (max-width: 720px) {
    .top-nav-bar { gap: 2px; padding: 4px 6px; }
    .top-nav-btn { padding: 6px 8px; font-size: 0; min-width: 32px; justify-content: center; }
    .top-nav-btn .nav-num { width: 22px; height: 22px; font-size: 11px; }
    /* активная кнопка — показываем подпись чтобы было видно где находишься */
    .top-nav-btn.active { font-size: 12px; padding: 6px 12px; }
  }

  /* === Пошаговый режим (Stepper) === */
  /* По умолчанию stepper-controls скрыт. Показывается только в активной секции при body.stepper-mode */
  stepper-controls { display: none; }
  /* Stepper-mode имеет приоритет над модовыми правилами:
     даже если секция должна быть видна по режиму, в stepper-режиме показывается только активная */
  body.stepper-mode .section:not(.stepper-active) { display: none !important; }
  body.stepper-mode .section.stepper-active { display: block !important; }
  body.stepper-mode .section.stepper-active stepper-controls { display: block; margin-top: 14px; }
  body.stepper-mode .section.stepper-active .section-header { cursor: default; }
  body.stepper-mode .section.stepper-active .section-header .chevron { display: none; }

  .stepper-bar {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 14px;
    background: var(--surface-alt);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    border-left: 3px solid var(--accent);
  }
  .stepper-btn {
    background: var(--surface);
    color: var(--text);
    border: 1px solid var(--border);
    border-radius: 6px;
    padding: 8px 18px;
    font-family: inherit;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition: all var(--tr);
    flex-shrink: 0;
  }
  .stepper-btn:hover:not(:disabled) {
    border-color: var(--accent);
    color: var(--accent);
    background: var(--accent-light);
  }
  .stepper-btn:disabled { opacity: 0.4; cursor: not-allowed; }
  .stepper-btn.stepper-next:not(:disabled) {
    background: var(--accent);
    color: var(--on-accent);
    border-color: var(--accent);
  }
  .stepper-btn.stepper-next:not(:disabled):hover { background: var(--accent-dark); border-color: var(--accent-dark); color: var(--on-accent); }
  .stepper-progress { flex: 1; min-width: 0; }
  .stepper-step-label {
    font-size: 11px;
    color: var(--text-sec);
    text-transform: uppercase;
    letter-spacing: .5px;
    display: block;
    margin-bottom: 4px;
  }
  .stepper-step-label .stepper-cur { color: var(--accent); font-weight: 700; }
  .stepper-bar-line { height: 4px; background: var(--border); border-radius: 2px; overflow: hidden; }
  .stepper-bar-fill { height: 100%; background: var(--accent); transition: width 0.3s; width: 0%; }

  @media print {
    stepper-controls { display: none !important; }
    body.stepper-mode .section { display: block !important; }
  }

  /* Кнопки и тулбар скрыты, так как есть боковое меню */
  .toolbar-vis { display: none; }
  
  .btn { display: inline-flex; align-items: center; gap: 4px; padding: 7px 12px; border: none; border-radius: var(--radius); font-family: inherit; font-size: 11.5px; font-weight: 600; cursor: pointer; transition: all var(--tr); letter-spacing: .2px; }
  .btn:hover { transform: translateY(-1px); box-shadow: var(--glow); }
  .btn-primary { background: var(--accent); color: var(--on-accent); }
  .btn-primary:hover { background: var(--accent-dark); }
  .btn-outline { background: var(--surface); color: var(--text); border: 1px solid var(--border); }
  .btn-outline:hover { border-color: var(--accent); color: var(--accent); }

  /* Разделы */
  .section { background: var(--surface); border-radius: 10px; box-shadow: var(--shadow); margin-bottom: 6px; overflow: hidden; border: 1px solid var(--border); transition: all var(--tr); scroll-margin-top: 20px; }
  /* Секция 1 — без overflow:hidden, чтобы выпадушка автодополнения адреса не обрезалась */
  .section[data-sec="1"] { overflow: visible; }
  .section[data-sec="1"] .section-body { overflow: visible; }
  .section[data-sec="1"] .section-body.hidden { overflow: hidden; }
  .section:hover { box-shadow: 0 4px 20px rgba(0,188,212,.1); border-color: rgba(0,188,212,.25); }
  .section.hidden-section { display: none; }
  
  .section-header { background: var(--surface-alt); color: var(--text); border-left: 3px solid var(--accent); padding: 9px 14px; font-size: 13px; font-weight: 700; display: flex; align-items: center; gap: 8px; cursor: pointer; user-select: none; transition: all var(--tr); }
  .section-header:hover { background: rgba(0,188,212,.06); }
  
  /* Кружок с номером. Добавлен класс .completed для зеленого цвета */
  .section-header .num { background: var(--accent); color: var(--on-accent); width: 24px; height: 24px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 11px; font-weight: 800; font-family: 'Consolas', monospace; flex-shrink: 0; box-shadow: 0 0 8px rgba(0,188,212,.4); transition: all 0.3s ease; }
  .section-header .num.completed { background: var(--success); color: #fff; box-shadow: 0 0 8px rgba(76,175,80,.4); }
  
  .section-header .chevron { margin-left: auto; transition: transform .3s; font-size: 14px; color: var(--text-muted); }
  .section-header.collapsed .chevron { transform: rotate(-90deg); }
  
  .section-body { padding: 12px 16px 14px; overflow: hidden; transition: max-height .35s ease, opacity .25s; }
  .section-body.hidden { max-height: 0 !important; padding: 0 16px; opacity: 0; pointer-events: none; }

  /* Сетки */
  .form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px 16px; }
  .form-grid .full { grid-column: 1 / -1; }
  .form-grid-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 10px 16px; }
  .form-grid-addr { display: grid; grid-template-columns: 2fr 1fr; gap: 10px 16px; }
  
  /* Адрес */
  .addr-wrap { position: relative; }
  .addr-list { position: absolute; top: 100%; left: 0; right: 0; background: var(--surface); border: 1.5px solid var(--accent); border-top: none; border-radius: 0 0 var(--radius) var(--radius); max-height: 220px; overflow-y: auto; z-index: 100; display: none; box-shadow: 0 8px 24px rgba(0,0,0,.4); }
  .addr-list.open { display: block; }
  .addr-list div { padding: 8px 12px; font-size: 12px; cursor: pointer; border-bottom: 1px solid var(--border); color: var(--text); transition: background .15s; }
  .addr-list div:hover, .addr-list div.active { background: var(--accent); color: var(--on-accent); }

  /* Поля ввода */
  .field { display: flex; flex-direction: column; gap: 4px; }
  .field label { font-size: 10px; font-weight: 600; color: var(--accent); text-transform: uppercase; letter-spacing: .6px; }
  .field input, .field select, .field textarea { font-family: inherit; font-size: 13.5px; padding: 8px 10px; border: 1.5px solid var(--border); border-radius: var(--radius); background: var(--input-bg); color: var(--text); transition: all var(--tr); outline: none; width: 100%; }
  .field input:hover, .field select:hover { border-color: rgba(0,188,212,.4); }
  .field input:focus, .field select:focus, .field textarea:focus { border-color: var(--accent); box-shadow: 0 0 0 3px rgba(0,188,212,.15); background: var(--surface); }
  .field input::placeholder, .field textarea::placeholder { color: var(--text-muted); }
  
  /* Класс для подсветки ошибок валидации */
  .field input.has-error, .mt input.has-error, .mt select.has-error, .field select.has-error { border-color: var(--danger); box-shadow: 0 0 0 3px var(--danger-bg); }
  .field input.has-warn, .mt input.has-warn, .mt select.has-warn, .field select.has-warn { border-color: var(--warning); box-shadow: 0 0 0 2px rgba(232,165,71,.15); }
  .field input.has-ok, .mt input.has-ok, .mt select.has-ok, .field select.has-ok { border-color: var(--success); box-shadow: 0 0 0 2px var(--success-bg); }
  .val-warn-error { border-left: 4px solid var(--danger) !important; }
  .val-warn-warn { border-left: 4px solid var(--warning) !important; }

  .field select { appearance: none; background-image: url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%2300BCD4' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 12px center; padding-right: 32px; }
  .field textarea { resize: vertical; min-height: 56px; }

  /* Чекбоксы */
  .cb-label { display: flex; align-items: center; gap: 6px; font-size: 12.5px; cursor: pointer; color: var(--text); padding: 3px 0; font-weight: 400; }
  .cb-label input[type="checkbox"] { width: 16px; height: 16px; accent-color: var(--accent); flex-shrink: 0; cursor: pointer; }
  
  /* Чипы для быстрого добавления (сопутствующие заболевания и т.п.) */
  .chip { background: var(--surface-alt); color: var(--text); border: 1px solid var(--border); border-radius: 14px; padding: 4px 10px; font-size: 11.5px; cursor: pointer; transition: all 0.15s; font-family: inherit; line-height: 1.3; }
  .chip:hover { background: var(--accent-light); border-color: var(--accent); color: var(--accent); }
  .chip:active { transform: scale(0.96); }

  /* Таблицы */
  .mt { width: 100%; border-collapse: separate; border-spacing: 0; font-size: 12.5px; margin-top: 8px; border: 1.5px solid var(--border); border-radius: var(--radius); overflow: hidden; table-layout: fixed; }
  .mt th { background: rgba(0,188,212,.1); color: var(--accent); padding: 10px 10px; font-weight: 700; font-size: 10px; text-transform: uppercase; letter-spacing: .5px; text-align: center; border-bottom: 1.5px solid var(--border); }
  .mt th:first-child { text-align: left; }
  .mt td { padding: 8px 8px; border-bottom: 1px solid var(--border); }
  .mt tr:last-child td { border-bottom: none; }
  .mt td:first-child { font-weight: 600; background: var(--surface-alt); font-size: 11px; color: var(--text-sec); }
  /* Подсказка-иконка (?) рядом с параметром в таблице измерений.
     Появляется при ховере мышью на десктопе, при тапе/фокусе — на мобильном.
     В печать НЕ попадает (см. правило ниже + clone-фильтр в generatePrintView). */
  .mt .norm-tip { position: relative; display: inline-flex; align-items: center; justify-content: center; margin-left: 6px; cursor: help; vertical-align: middle; }
  .mt .norm-tip-icon { display: inline-flex; align-items: center; justify-content: center; width: 16px; height: 16px; border-radius: 50%; background: var(--accent); color: var(--on-accent); font-size: 10px; font-weight: 700; font-family: 'Consolas', monospace; line-height: 1; user-select: none; transition: transform 0.15s; }
  .mt .norm-tip:hover .norm-tip-icon,
  .mt .norm-tip:focus .norm-tip-icon { transform: scale(1.15); box-shadow: 0 0 0 3px rgba(0,188,212,.25); }
  .mt .norm-tip-popover {
    position: absolute;
    left: calc(100% + 8px);
    top: 50%;
    transform: translateY(-50%);
    min-width: 220px;
    max-width: 320px;
    padding: 10px 12px;
    background: var(--surface);
    color: var(--text);
    border: 1.5px solid var(--accent);
    border-radius: 8px;
    box-shadow: 0 6px 20px rgba(0,0,0,.4);
    font-size: 12px;
    font-weight: 400;
    line-height: 1.4;
    white-space: normal;
    z-index: 1000;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.15s, visibility 0.15s;
    pointer-events: none;
  }
  .mt .norm-tip:hover .norm-tip-popover,
  .mt .norm-tip:focus .norm-tip-popover,
  .mt .norm-tip:focus-within .norm-tip-popover { opacity: 1; visibility: visible; }
  /* Стрелочка слева */
  .mt .norm-tip-popover::before {
    content: '';
    position: absolute;
    left: -7px;
    top: 50%;
    transform: translateY(-50%);
    width: 0; height: 0;
    border-style: solid;
    border-width: 6px 7px 6px 0;
    border-color: transparent var(--accent) transparent transparent;
  }
  /* На узких экранах — popover вниз а не вправо (вправо может вылезать за экран) */
  @media (max-width: 720px) {
    .mt .norm-tip-popover { left: auto; right: 0; top: calc(100% + 8px); transform: none; min-width: 200px; max-width: calc(100vw - 40px); }
    .mt .norm-tip-popover::before { left: auto; right: 8px; top: -7px; transform: none; border-width: 0 6px 7px 6px; border-color: transparent transparent var(--accent) transparent; }
  }
  /* В печать — никаких подсказок */
  @media print { .mt .norm-tip { display: none !important; } }
  .mt input, .mt select { width: 100%; border: 1.5px solid var(--border); border-radius: 6px; padding: 7px 8px; font-family: 'Consolas', monospace; font-size: 12.5px; text-align: center; outline: none; color: var(--text); background: var(--input-bg); transition: all var(--tr); }
  .mt input:hover, .mt select:hover { border-color: rgba(0,188,212,.4); }
  .mt input:focus, .mt select:focus { border-color: var(--accent); box-shadow: 0 0 0 2px rgba(0,188,212,.15); }

  /* Осложнения */
  .comp-row { display: flex; align-items: center; gap: 12px; padding: 9px 0; border-bottom: 1px solid var(--border); }
  .comp-row:last-child { border-bottom: none; }
  .comp-row .label { flex: 1; font-size: 13.5px; color: var(--text); }
  .tg { display: flex; border-radius: var(--radius); overflow: hidden; border: 1.5px solid var(--border); }
  .tg button { padding: 6px 16px; border: none; background: var(--surface); font-family: inherit; font-size: 12px; font-weight: 600; cursor: pointer; color: var(--text-muted); transition: all var(--tr); }
  .tg button+button { border-left: 1.5px solid var(--border); }
  .tg button:hover { background: var(--surface-alt); }
  .tg button.a-no { background: var(--success-bg); color: var(--success); font-weight: 700; }
  .tg button.a-yes { background: var(--danger-bg); color: var(--danger); font-weight: 700; }

  /* Памятка */
  .rec-block { background: rgba(255,152,0,.06); border: 1.5px solid rgba(255,152,0,.3); border-radius: 8px; padding: 16px 18px; margin-top: 14px; }
  .rec-block h3 { font-size: 16px; font-weight: 700; color: var(--warning); margin-bottom: 8px; }
  .rec-block p { font-size: 12.5px; line-height: 1.6; margin-bottom: 6px; color: var(--text-sec); }
  .rec-block .warn { color: var(--warning); font-weight: 700; }

  /* Подписи */
  .signatures { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 16px; margin-top: 14px; transition: all 0.3s; }
  .sig-block { text-align: center; padding-top: 10px; background: var(--surface-alt); border-radius: var(--radius); padding: 12px 8px; }
  .sig-line { border-top: 1.5px solid var(--accent); margin: 30px 12px 4px; }
  .sig-label { font-size: 10px; color: var(--text-muted); }
  .sig-role { font-size: 10.5px; font-weight: 600; white-space: nowrap; color: var(--accent); }

  /* Всплывающее окно диагноза */
  .rec-popup { position: fixed; top: 50%; left: 50%; transform: translate(-50%, -50%); background: var(--surface); border: 2px solid var(--accent); border-radius: 12px; padding: 22px 26px; max-width: 520px; width: 90%; z-index: 9001; box-shadow: 0 12px 48px rgba(0,0,0,.5); }
  .rec-popup h3 { font-size: 15px; font-weight: 700; color: var(--accent); margin-bottom: 10px; display: flex; align-items: center; gap: 8px; }
  .rec-popup .rec-type { background: var(--accent-light); border: 1.5px solid var(--accent); border-radius: 8px; padding: 10px 14px; font-size: 13px; font-weight: 600; color: var(--accent); margin-bottom: 8px; }
  .rec-popup .rec-mode { font-size: 12px; color: var(--text-sec); margin-bottom: 8px; line-height: 1.5; }
  .rec-popup .rec-note { font-size: 11px; color: var(--text-muted); font-style: italic; margin-bottom: 14px; }
  .rec-popup button { padding: 9px 22px; border: none; border-radius: var(--radius); font-family: inherit; font-size: 13px; font-weight: 600; cursor: pointer; margin-right: 8px; transition: all var(--tr); }
  .rec-popup .btn-apply { background: var(--accent); color: var(--on-accent); }
  .rec-popup .btn-apply:hover { background: var(--accent-dark); }
  .rec-popup .btn-skip { background: var(--surface-alt); color: var(--text); border: 1px solid var(--border); }
  .rec-popup-overlay { position: fixed; inset: 0; background: rgba(0,0,0,.6); z-index: 9000; display: none; }
  .rec-popup-overlay.open { display: block; }

  /* Модальное окно настроек */
  .modal-overlay { position: fixed; inset: 0; background: rgba(0,0,0,.6); z-index: 9000; display: none; align-items: center; justify-content: center; }
  .modal-overlay.open { display: flex; }
  .modal { background: var(--surface); border-radius: 12px; width: 520px; max-width: 92vw; max-height: 85vh; overflow-y: auto; box-shadow: 0 20px 60px rgba(0,0,0,.4); }
  .modal-head { padding: 16px 20px; border-bottom: 1px solid var(--border); color: var(--text); display: flex; align-items: center; justify-content: space-between; }
  .modal-head h2 { font-size: 16px; font-weight: 700; }
  .modal-close { background: none; border: none; font-size: 22px; cursor: pointer; color: var(--text-sec); transition: color 0.2s; }
  .modal-close:hover { color: var(--danger); }
  .modal-body { padding: 16px 20px 20px; }
  .modal-body label.setting { display: flex; align-items: center; gap: 10px; padding: 7px 0; font-size: 13px; cursor: pointer; border-bottom: 1px solid var(--border); color: var(--text); }
  .modal-body label.setting:last-child { border-bottom: none; }
  .modal-body label.setting input[type="checkbox"], .modal-body label.setting input[type="radio"] { width: 18px; height: 18px; accent-color: var(--accent); cursor: pointer; }

  .manual-input { font-family: inherit; font-size: 12px; padding: 7px 10px; border: 1.5px solid var(--border); border-radius: var(--radius); width: 100%; outline: none; background: var(--input-bg); color: var(--text); display: none; margin-top: 4px; }
  .manual-input.show { display: block; }
  
  /* #15: Утилитарные классы для замены повторяющихся inline-стилей */
  .u-mt-8 { margin-top: 8px; }
  .u-mt-4 { margin-top: 4px; }
  .u-w-100 { width: 100%; }
  .u-hidden { display: none; }
  .u-section-subhead { font-size: 12px; font-weight: 600; color: var(--text-sec); text-transform: uppercase; margin: 14px 0 8px; }
  .u-bg-alt { background: var(--surface-alt); }
  
  /* Все readonly-поля автоматически получают приглушённый фон */
  input[readonly], textarea[readonly] { background: var(--surface-alt); }
  
  /* #24: Таблица "Измерения и программирование электродов" */
  .meas-prog-wrap { overflow-x: auto; }
  .meas-prog-table { width: 100%; border-collapse: collapse; }
  .meas-prog-table thead th {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--text-sec);
    padding: 8px;
    border-bottom: 1px solid var(--border);
    text-align: center;
    background: var(--surface-alt);
  }
  .meas-prog-table thead th.col-param { text-align: left; }
  .meas-prog-table thead th.chamber-pp { color: #818cf8; border-bottom: 2px solid #6366f1; }
  .meas-prog-table thead th.chamber-rv { color: #34d399; border-bottom: 2px solid #10b981; }
  .meas-prog-table thead th.chamber-lv { color: #fbbf24; border-bottom: 2px solid #f59e0b; }
  .meas-prog-table thead .subhead th { font-size: 10px; padding: 4px 6px; background: transparent; border-bottom: 1px solid var(--border); }
  .meas-prog-table thead .subhead th.col-meas { color: #60a5fa; }
  .meas-prog-table thead .subhead th.col-prog { color: #c084fc; }
  
  .meas-prog-table tbody td {
    padding: 6px 8px;
    border-bottom: 1px solid rgba(42, 63, 85, 0.4);
    vertical-align: middle;
    font-size: 12px;
  }
  .meas-prog-table tbody td:first-child { color: var(--text); width: 22%; }
  .meas-prog-table tbody td.cell-na {
    text-align: center;
    color: var(--text-muted);
    font-style: italic;
    background: rgba(0, 0, 0, 0.12);
  }
  .meas-prog-table tbody td.cell-merged {
    text-align: center;
    background: rgba(0, 188, 212, 0.04);
  }
  .meas-prog-table tbody td input,
  .meas-prog-table tbody td select { width: 100%; min-width: 70px; }
  .meas-prog-table tbody td.cell-merged select { max-width: 140px; margin: 0 auto; }
  
  /* Адаптивно для мобильного: стопка по строкам, каждый параметр — карточка по камерам */
  @media (max-width: 768px) {
    .meas-prog-table thead { display: none; }
    .meas-prog-table, .meas-prog-table tbody { display: block; width: 100%; }
    .meas-prog-table tr {
      display: block;
      margin-bottom: 14px;
      padding: 10px 12px;
      background: var(--surface-alt);
      border-radius: var(--radius);
      border-left: 3px solid var(--border);
    }
    .meas-prog-table tbody td {
      display: flex;
      align-items: center;
      gap: 12px;
      padding: 6px 0;
      border: none;
      border-bottom: 1px dashed rgba(42, 63, 85, 0.3);
      width: 100%;
    }
    .meas-prog-table tbody td:last-child { border-bottom: none; }
    .meas-prog-table tbody td:first-child {
      width: 100%;
      font-weight: 600;
      color: var(--accent);
      font-size: 13px;
      padding-bottom: 6px;
      margin-bottom: 4px;
      border-bottom: 1px solid var(--border);
    }
    .meas-prog-table tbody td:first-child::before { content: ''; }
    .meas-prog-table tbody td:not(:first-child)::before {
      content: attr(data-label);
      flex: 0 0 110px;
      font-size: 11px;
      color: var(--text-sec);
      text-transform: uppercase;
      letter-spacing: 0.3px;
    }
    .meas-prog-table tbody td.cell-na::before { color: var(--text-muted); }
    .meas-prog-table tbody td input,
    .meas-prog-table tbody td select { flex: 1; }
    
    /* Скрытые камеры в мобильном — скрываем все ячейки этой камеры */
    .meas-prog-table tbody td.col-pp.col-hidden,
    .meas-prog-table tbody td.col-rv.col-hidden,
    .meas-prog-table tbody td.col-lv.col-hidden { display: none !important; }
    
    /* Если в строке скрыты все 6 ячеек данных, скрываем строку целиком — JS пометит */
    .meas-prog-table tr.row-all-hidden { display: none !important; }
  }

  /* Оповещения об ошибках (сверху) */
  .val-warn { position: fixed; bottom: 20px; right: 20px; left: auto; top: auto; transform: none; background: var(--surface); border: 2px solid var(--danger); border-radius: 10px; padding: 12px 36px 12px 16px; max-width: 380px; width: auto; z-index: 8500; box-shadow: 0 8px 24px rgba(0,0,0,.4); font-size: 12px; line-height: 1.45; animation: valSlide .3s ease; }
  .val-warn .vw-title { font-weight: 700; color: var(--danger); font-size: 12.5px; margin-bottom: 4px; display: flex; align-items: center; gap: 6px; }
  .val-warn .vw-body { color: var(--text); font-size: 11.5px; max-height: 30vh; overflow-y: auto; }
  .val-warn .vw-body b { color: var(--danger); }
  .val-warn .vw-close { position: absolute; top: 6px; right: 8px; background: none; border: none; font-size: 18px; cursor: pointer; color: var(--text-muted); padding: 0; line-height: 1; }
  .val-warn .vw-close:hover { color: var(--text); }
  @keyframes valSlide { from{opacity:0; top:0;} to{opacity:1; top:20px;} }

  /* Настройки врачей */
  .doc-group { margin-bottom: 14px; }
  .doc-group-title { font-size: 11px; font-weight: 700; color: var(--accent); text-transform: uppercase; letter-spacing: .5px; margin-bottom: 6px; }
  .doc-list { display: flex; flex-direction: column; gap: 4px; margin-bottom: 6px; }
  .doc-item { display: grid; grid-template-columns: auto 1fr 1.4fr 130px auto; align-items: center; gap: 6px; background: var(--input-bg); border: 1px solid var(--border); border-radius: 6px; padding: 4px 8px; }
  .doc-item .doc-name { min-width: 0; background: transparent; border: none; outline: none; color: var(--text); font-family: inherit; font-size: 12.5px; padding: 2px 0; }
  .doc-item .doc-role { min-width: 0; background: transparent; border: none; border-left: 1px dashed var(--border); padding: 2px 6px; outline: none; color: var(--text-sec); font-family: inherit; font-size: 11.5px; font-style: italic; }
  .doc-item .doc-role:focus { color: var(--text); font-style: normal; }
  .doc-item .doc-phone { background: transparent; border: none; border-left: 1px dashed var(--border); padding: 2px 6px; outline: none; color: var(--text-sec); font-family: 'Consolas', monospace; font-size: 11.5px; }
  .doc-item .doc-phone:focus { color: var(--text); }
  .doc-item .doc-head { width: 14px; height: 14px; cursor: pointer; opacity: .5; transition: opacity .2s; flex-shrink: 0; display: flex; align-items: center; justify-content: center; font-size: 12px; color: var(--warning); }
  .doc-item .doc-head:hover, .doc-item .doc-head.active { opacity: 1; }
  .doc-item .doc-del { width: 20px; height: 20px; border: none; background: transparent; cursor: pointer; color: var(--danger); font-size: 16px; display: flex; align-items: center; justify-content: center; opacity: .5; }
  .doc-item .doc-del:hover { opacity: 1; }
  /* Если у группы нет звёздочки (хирурги, аритмологи) — первая колонка отсутствует */
  .doc-item:not(:has(.doc-head)) { grid-template-columns: 1fr 1.4fr 130px auto; }
  /* На узких экранах role и phone уезжают на отдельные строки */
  @media (max-width: 720px) {
    .doc-item { grid-template-columns: auto 1fr auto; }
    .doc-item:not(:has(.doc-head)) { grid-template-columns: 1fr auto; }
    .doc-item .doc-role,
    .doc-item .doc-phone { grid-column: 1 / -1; border-left: none; border-top: 1px dashed var(--border); padding: 4px 0 2px; }
  }
  .doc-add { display: flex; gap: 6px; }
  .doc-add input { flex: 1; padding: 5px 8px; border: 1.5px solid var(--border); border-radius: 6px; background: var(--input-bg); color: var(--text); font-family: inherit; font-size: 12px; outline: none; }
  .doc-add input:focus { border-color: var(--accent); }
  .doc-add button { padding: 5px 12px; border: none; border-radius: 6px; background: var(--accent); color: var(--on-accent); font-family: inherit; font-size: 12px; font-weight: 700; cursor: pointer; }

  /* Кнопка FAB */
  .fab { position: fixed !important; right: 20px; bottom: 20px; width: 48px; height: 48px; border-radius: 50%; background: var(--accent); border: 2px solid var(--bg); cursor: grab; z-index: 99999; display: flex; align-items: center; justify-content: center; box-shadow: 0 4px 20px rgba(0,188,212,.5), 0 0 0 1px rgba(255,255,255,.1); transition: box-shadow .2s, transform .2s; touch-action: none; }
  .fab:hover { box-shadow: 0 6px 28px rgba(0,188,212,.7); transform: scale(1.08); }
  .fab:active { cursor: grabbing; }
  .fab svg { width: 22px; height: 22px; fill: #0F1923; pointer-events: none; }

  /* Боковое меню */
  .sidebar { position: fixed; top: 0; right: -280px; width: 280px; height: 100vh; background: var(--surface); border-left: 2px solid var(--accent); z-index: 4999; transition: right .3s ease; overflow-y: auto; padding: 16px 14px; box-shadow: -4px 0 30px rgba(0,0,0,.4); }
  .sidebar.open { right: 0; }
  .sidebar-close { position: absolute; top: 10px; right: 10px; background: none; border: none; cursor: pointer; }
  .sidebar-close svg { width: 20px; height: 20px; fill: var(--text-muted); }
  .sidebar h3 { font-size: 12px; font-weight: 700; color: var(--accent); text-transform: uppercase; letter-spacing: 1px; margin: 0 0 10px; padding-bottom: 8px; border-bottom: 1px solid var(--border); }
  
  .sidebar-btn { display: flex; align-items: center; gap: 10px; width: 100%; padding: 11px 12px; border: 1px solid var(--border); border-radius: var(--radius); background: var(--surface-alt); color: var(--text); font-family: inherit; font-size: 12.5px; font-weight: 600; cursor: pointer; transition: all var(--tr); margin-bottom: 6px; text-align: left; }
  .sidebar-btn:hover { border-color: var(--accent); background: rgba(0,188,212,.08); color: var(--accent); }
  .sidebar-btn svg { width: 18px; height: 18px; flex-shrink: 0; fill: var(--text-muted); transition: fill .2s; }
  .sidebar-btn:hover svg { fill: var(--accent); }
  
  .sidebar-nav { display: flex; flex-direction: column; gap: 4px; margin-bottom: 14px; }
  .sidebar-nav-link { background: none; border: none; color: var(--text-sec); font-size: 12px; text-align: left; padding: 4px 8px; cursor: pointer; transition: color 0.2s; border-radius: 4px; }
  .sidebar-nav-link:hover { color: var(--accent); background: rgba(0,188,212,.05); }

  .sidebar-sep { height: 1px; background: var(--border); margin: 10px 0; }
  .sidebar-overlay { position: fixed; inset: 0; background: rgba(0,0,0,.3); z-index: 4998; display: none; }
  .sidebar-overlay.open { display: block; }

  /* Для скрытия ненужных колонок в таблице ЭКС */
  .col-hidden { display: none; }
  .col-span-all { border: inherit; }

  /* CSS ДЛЯ ПЕЧАТИ */
  #printView { display: none; }
  @media print {
    body { background: #fff !important; font-size: 10pt; font-family: Arial, sans-serif; margin: 0; padding: 0; color: #000 !important; }
    .page-header, .container, .fab, .sidebar, .sidebar-overlay, .modal-overlay, .rec-popup, .rec-popup-overlay, .addr-list, .val-warn, #error-toast, #test-results-modal, #save-indicator { display: none !important; }
    #printView { display: block !important; padding: 0 5mm; }
    @page { margin: 10mm 10mm 9mm 10mm; }
    
    #printView.footer-all .pv-footer { display: flex; position: fixed; }
    #printView.footer-first .pv-footer { display: flex; position: fixed; }
    #printView.footer-first-last .pv-footer { display: flex; position: fixed; }
    #printView.footer-last .pv-footer { display: none; }
    #printView.footer-off .pv-footer { display: none; }
    #printView .ft-qr svg { width: 100% !important; height: 100% !important; display: block; }
    
    #printView .pv-footer { position: fixed; bottom: 0; left: 0; right: 0; height: 24mm; display: none; align-items: center; justify-content: space-between; padding: 1mm 5mm; border-top: 0.5pt solid #000; font-size: 7pt; background: #fff; -webkit-print-color-adjust: exact; print-color-adjust: exact; }
    #printView .pv-footer .ft-qr { width: 22mm; height: 22mm; flex-shrink: 0; }
    
    #printView h1 { font-size: 13pt; font-weight: 700; text-align: center; margin: 0.5mm 0; letter-spacing: 0.5pt; }
    #printView .pv-org { font-size: 9pt; text-align: center; margin: 0 0 0.3mm; font-weight: 400; }
    #printView .pv-sigs-row { display: flex; align-items: flex-end; justify-content: space-between; gap: 6mm; margin-top: 4mm; }
    #printView .pv-sigs-row .pv-protocol-date { font-size: 10pt; min-width: 35mm; padding-bottom: 1mm; white-space: nowrap; }
    #printView .pv-sigs-row .pv-sigs { flex: 1; }
    /* QR справа от подписей — режимы last / first-last */
    #printView .pv-sigs-row-with-qr .pv-sigs-qr { width: 28mm; height: 28mm; flex-shrink: 0; }
    #printView .pv-sigs-row-with-qr .pv-sigs-qr svg { width: 100% !important; height: 100% !important; display: block; }
    #printView .pv-brand { font-size: 9pt; text-align: center; letter-spacing: 0.5pt; margin: 0 0 1.5mm; font-weight: 700; font-variant: small-caps; }
    #printView .pv-sh { font-size: 11pt; font-weight: 700; border-bottom: 1pt solid #000; padding: 0.5mm 0; margin: 2mm 0 0.5mm; }
    #printView .pv-sh.no-border { border-bottom: none; }
    #printView .pv-field { font-size: 9pt; margin: 0.3mm 0; line-height: 1.45; }
    #printView .pv-field b { font-weight: 700; }
    
    #printView table { border-collapse: collapse; width: 100%; margin: 1mm 0; font-size: 8.5pt; table-layout: fixed; }
    #printView th { border: 1pt solid #000; padding: 1mm 2mm; font-weight: 700; font-size: 7pt; text-transform: uppercase; text-align: center; background: #FFF; border-bottom: 1.5pt solid #000; }
    #printView th:first-child { text-align: left; }
    #printView td { border: 1pt solid #000; padding: 0.8mm 2mm; text-align: center; }
    #printView td:first-child { text-align: left; font-weight: 600; font-size: 7.5pt; }
    
    #printView .pv-comp { font-size: 9pt; margin: 0.3mm 0; font-weight: 600; }
    #printView .pv-textarea { font-size: 9pt; border: none; padding: 0; margin: 0.3mm 0; }
    #printView .pv-memo { border: none; padding: 0; margin: 0.5mm 0; }
    #printView .pv-memo h3 { font-size: 10pt; font-weight: 700; border-bottom: 0.5pt solid #000; padding-bottom: 0.5mm; margin-bottom: 1mm; }
    #printView .pv-memo p { font-size: 7.5pt; margin: 0.3mm 0; line-height: 1.35; }
    #printView .pv-memo .warn { font-weight: 700; }
    
    #printView .pv-sigs { display: flex; justify-content: space-between; margin-top: 1mm; }
    #printView .pv-sig { text-align: center; flex: 1; }
    #printView .pv-sig .name { font-size: 9.5pt; font-weight: 700; margin-bottom: 10mm; }
    /* ЛИНИЯ ПОДПИСИ ИСПРАВЛЕНА: Фиксированная ширина 45мм, выровнена по центру */
    #printView .pv-sig .line { border-top: 0.5pt solid #000; margin: 0 auto; width: 45mm; font-size: 7pt; padding-top: 0.5mm; font-weight: 400; }
  }

/* ============================================================
   МОБИЛЬНАЯ АДАПТАЦИЯ
   ============================================================
   Брейкпоинты:
   - 720px — планшеты (уже частично сделано выше)
   - 600px — крупные телефоны (iPhone 14 Pro Max ~430px, после поворота)
   - 480px — обычные смартфоны
   - 360px — узкие смартфоны (старые Android, iPhone SE)
   ============================================================ */

  /* iOS Safari зумирует страницу если font-size < 16px при фокусе.
     Поднимаем до 16px на мобильных устройствах для всех вводов формы. */
  @media (max-width: 720px) {
    .field input, .field select, .field textarea,
    .mt input, .mt select,
    .doc-name, .doc-role, .doc-phone,
    #diagSearch, #memoEditorTextarea,
    .manual-input,
    .doc-add input {
      font-size: 16px !important;
    }
    /* После поднятия шрифта input'ы становятся крупнее — чуть уменьшим padding */
    .field input, .field select, .field textarea { padding: 9px 10px; }
  }

  /* Адаптивная сетка форм: на телефонах в одну колонку */
  @media (max-width: 600px) {
    .form-grid,
    .form-grid-3,
    .form-grid-addr,
    .signatures {
      grid-template-columns: 1fr !important;
      gap: 8px;
    }
    /* Шапка компактнее */
    .page-header { padding: 10px 12px; margin: 6px auto 4px; border-radius: 8px; }
    .page-header h1 { font-size: 15px; margin: 4px 0 2px; line-height: 1.25; }
    .page-header .org-name { font-size: 12px; }
    .page-header .org-addr { font-size: 10px; }
    .page-header .brand { font-size: 9px; padding: 2px 10px; letter-spacing: 1.5px; }

    .container { padding: 8px 10px 80px; }

    /* Touch-target минимум: чекбоксы и радио в настройках */
    .modal-body label.setting input[type="checkbox"],
    .modal-body label.setting input[type="radio"] { width: 22px; height: 22px; }
    .modal-body label.setting { padding: 10px 0; font-size: 14px; }

    /* Заголовки секций крупнее для тыка пальцем */
    .section-header { padding: 12px 14px; font-size: 14px; min-height: 44px; }
    .section-header .num { width: 26px; height: 26px; font-size: 12px; }

    /* Чипы — больше воздуха для пальца */
    .chip { padding: 8px 12px !important; font-size: 13px !important; min-height: 36px; }

    /* Stepper: кнопки на всю ширину чтобы попадать пальцем */
    .stepper-btn { padding: 12px 16px !important; font-size: 14px !important; min-height: 44px; }

    /* Модалки — на узком экране в полный экран */
    .modal { max-width: 100vw; max-height: 100vh; width: 100vw; height: 100vh; border-radius: 0; }
    .modal-head { padding: 12px 14px; }
    .modal-body { padding: 12px 14px 20px; }

    /* Onboarding и crypto-offer кнопки — в столбик чтобы не выходили за край */
    #onboardingModal .modal-body > div:last-child,
    #cryptoOfferModal .modal-body > div:last-child {
      flex-direction: column !important;
      align-items: stretch !important;
    }
    #onboardingModal .modal-body button,
    #cryptoOfferModal .modal-body button { width: 100%; padding: 12px 14px !important; font-size: 14px !important; }

    /* Sidebar — почти на весь экран */
    .sidebar { width: 88vw; right: -100vw; }
    .sidebar-btn { padding: 14px 12px; font-size: 14px; min-height: 44px; }

    /* FAB — уже подходящего размера, но убираем hover-эффекты */
    .fab:hover { transform: none; }

    /* Val-warn — на всю ширину снизу */
    .val-warn { left: 8px; right: 8px; max-width: none; bottom: 8px; }
  }

  /* Очень узкие экраны (старые телефоны) */
  @media (max-width: 360px) {
    .container { padding: 6px 6px 80px; }
    .page-header h1 { font-size: 13px; }
    .top-nav-btn { min-width: 28px; padding: 5px 6px; }
    .top-nav-btn .nav-num { width: 20px; height: 20px; font-size: 10px; }
    .section-header { padding: 10px 10px; font-size: 13px; }
    /* Таблица измерений на ультра-узком — ещё компактнее */
    .meas-prog-table tbody td:not(:first-child)::before { flex: 0 0 80px; font-size: 10px; }
  }

  /* Печать — ничего из мобильного не должно влиять */
  @media print {
    .field input, .field select, .field textarea { font-size: 10pt !important; padding: 1pt 2pt !important; }
  }

  /* iPhone X+ safe-area: учитываем нотч и home-indicator */
  @supports (padding: env(safe-area-inset-bottom)) {
    .container { padding-bottom: calc(80px + env(safe-area-inset-bottom)); }
    .fab { bottom: calc(20px + env(safe-area-inset-bottom)); right: calc(20px + env(safe-area-inset-right)); }
    .val-warn { bottom: calc(8px + env(safe-area-inset-bottom)); right: calc(8px + env(safe-area-inset-right)); }
    .sidebar { padding-top: calc(16px + env(safe-area-inset-top)); padding-bottom: calc(20px + env(safe-area-inset-bottom)); }
  }

  /* === РЕЖИМ ПРОВЕРКИ ЭКС === */
  /*
     Секции с одинаковыми data-sec=6/7/8 существуют для обоих режимов.
     Различение — по классу .checkup-only (есть → только в проверке).
     Секции БЕЗ .checkup-only при mode-checkup скрываются (имплантационные).
     Секции С .checkup-only при mode-implantation скрываются.
  */
  /* По умолчанию (имплантация) — скрываем только checkup-секции */
  .section.checkup-only { display: none; }
  /* В режиме проверки — наоборот: скрываем имплантационные 6/7/8 */
  body.mode-checkup .section[data-sec="6"]:not(.checkup-only),
  body.mode-checkup .section[data-sec="7"]:not(.checkup-only),
  body.mode-checkup .section[data-sec="8"]:not(.checkup-only) { display: none !important; }
  /* И показываем checkup-секции */
  body.mode-checkup .section.checkup-only { display: block; }
  /* Раздел 9 «Рекомендации» — только для имплантации (в проверке свой раздел 8) */
  body.mode-checkup .section.implant-only { display: none !important; }

  /* Подписи: в режиме проверки только аритмолог-программист.
     Хирург и кардиолог-наблюдающий — не показываются. */
  body.mode-checkup #sigBlockSurgeon,
  body.mode-checkup #sigBlockCardio { display: none !important; }
  body.mode-checkup .signatures { grid-template-columns: 1fr !important; }

  /* Чипы симптомов */
  .symptom-chips { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 6px; }
  .symptom-chips .chip {
    padding: 6px 12px;
    background: var(--surface-alt);
    color: var(--text);
    border: 1px solid var(--border);
    border-radius: 14px;
    cursor: pointer;
    font-size: 12px;
    transition: all 0.15s;
    user-select: none;
  }
  .symptom-chips .chip:hover { border-color: var(--accent); }
  .symptom-chips .chip.active {
    background: var(--accent-light);
    border-color: var(--accent);
    color: var(--accent);
    font-weight: 600;
  }
  .symptom-chips .chip.no-complaints { border-color: var(--success); }
  .symptom-chips .chip.no-complaints.active { background: var(--success-bg); color: var(--success); }
  .symptom-chips .chip-edit {
    padding: 4px 10px;
    background: transparent;
    border: 1px dashed var(--border);
    color: var(--text-muted);
    cursor: pointer;
    border-radius: 14px;
    font-size: 11px;
  }

  /* Чекбоксы рекомендаций проверки */
  .checkup-recs { display: grid; grid-template-columns: 1fr 1fr; gap: 6px 10px; }
  .checkup-rec {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 7px 10px;
    background: var(--surface-alt);
    border: 1px solid var(--border);
    border-radius: 8px;
    cursor: pointer;
    font-size: 12.5px;
    transition: all 0.15s;
    line-height: 1.3;
  }
  .checkup-rec:hover { border-color: var(--accent); }
  .checkup-rec input[type="checkbox"] { width: 18px; height: 18px; accent-color: var(--accent); cursor: pointer; flex-shrink: 0; }
  .checkup-rec input[type="checkbox"]:checked + span { color: var(--accent); font-weight: 600; }
  /* На мобильных — в один столбец чтобы не сжимать текст */
  @media (max-width: 600px) { .checkup-recs { grid-template-columns: 1fr; } }

  /* Выпадающий список совпадений из архива (под полем ФИО) */
  .archive-list {
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    right: 0;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 8px;
    box-shadow: 0 8px 24px rgba(0,0,0,.35);
    max-height: 320px;
    overflow-y: auto;
    z-index: 100;
    display: none;
  }
  .archive-list.open { display: block; }
  .archive-item {
    padding: 10px 12px;
    cursor: pointer;
    border-bottom: 1px solid var(--border);
    transition: background 0.12s;
  }
  .archive-item:last-child { border-bottom: none; }
  .archive-item:hover, .archive-item:focus {
    background: var(--accent-light);
    outline: none;
  }
  .archive-fio { font-size: 13px; font-weight: 600; color: var(--text); margin-bottom: 2px; }
  .archive-meta { font-size: 11px; color: var(--text-sec); }

  /* Кнопка нав-панели "История" — только в режиме проверки */
  .top-nav-btn.checkup-only-btn,
  .sidebar-btn.checkup-only-btn { display: none; }
  body.mode-checkup .top-nav-btn.checkup-only-btn { display: inline-flex; }
  body.mode-checkup .sidebar-btn.checkup-only-btn { display: flex; }
  /* implant-only — наоборот: видны только в имплантации, скрыты в проверке */
  body.mode-checkup .top-nav-btn.implant-only-btn,
  body.mode-checkup .sidebar-nav-link.implant-only-btn,
  body.mode-checkup .modal-body label.setting.implant-only-setting { display: none !important; }

  /* === ИСТОРИЯ ПРОВЕРОК — графики === */
  .history-summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
    padding: 8px 12px;
    background: var(--surface-alt);
    border-radius: 6px;
    margin-bottom: 16px;
    font-size: 12px;
    color: var(--text-sec);
  }
  .history-new-btn {
    padding: 6px 14px;
    background: var(--accent);
    color: var(--on-accent);
    border: none;
    border-radius: 6px;
    cursor: pointer;
    font-size: 12.5px;
    font-weight: 600;
    font-family: inherit;
    flex-shrink: 0;
  }
  .history-new-btn:hover { background: var(--accent-dark); }
  .history-empty {
    padding: 24px 16px;
    text-align: center;
    color: var(--text-muted);
    font-size: 12.5px;
    background: var(--surface-alt);
    border-radius: 8px;
    border: 1px dashed var(--border);
    line-height: 1.55;
  }
  .history-charts-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
  }
  @media (max-width: 1024px) { .history-charts-grid { grid-template-columns: 1fr; } }
  .history-charts-grid .history-chart { margin-bottom: 0; }
  /* Внутри узких колонок — SVG должен сжиматься */
  .history-charts-grid .history-chart svg { max-width: 100%; height: auto; }
  .history-chart {
    background: var(--surface-alt);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 12px 14px;
    margin-bottom: 12px;
  }
  .history-chart-empty { text-align: center; padding: 14px; }
  .chart-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 8px;
    flex-wrap: wrap;
    gap: 8px;
  }
  .chart-header h4 {
    margin: 0;
    font-size: 13px;
    font-weight: 700;
    color: var(--text);
  }
  .chart-unit { font-weight: 400; color: var(--text-sec); font-size: 11px; }
  .chart-legend {
    display: flex;
    gap: 12px;
    font-size: 11px;
    color: var(--text-sec);
  }
  .chart-legend-item {
    display: inline-flex;
    align-items: center;
    gap: 5px;
  }
  .chart-legend-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
  }
  .chart-svg {
    width: 100%;
    height: auto;
    max-height: 240px;
    display: block;
  }

  @media print {
    /* Графики истории и сама секция в печать не идут (по требованию пользователя) */
    .section[data-sec="11"], #printView .section[data-sec="11"] { display: none !important; }
  }

  /* === МОДАЛКА «НАЙТИ ПАЦИЕНТА» === */
  .patient-finder-list {
    max-height: 60vh;
    overflow-y: auto;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-alt);
  }
  .patient-finder-group {
    border-bottom: 1px solid var(--border);
    padding: 10px 12px;
  }
  .patient-finder-group:last-child { border-bottom: none; }
  .patient-finder-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 8px;
    margin-bottom: 6px;
    flex-wrap: wrap;
  }
  .patient-finder-fio { font-size: 14px; font-weight: 700; color: var(--text); }
  .patient-finder-meta { font-size: 11.5px; color: var(--text-sec); margin-top: 2px; }
  .patient-finder-records {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    padding-left: 8px;
    border-left: 2px solid var(--accent);
  }
  .patient-finder-rec {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 6px;
    padding: 3px 8px;
    font-size: 11.5px;
  }
  .patient-finder-rec .rec-mode { color: var(--accent); font-weight: 600; }
  .patient-finder-rec .rec-date { color: var(--text); }
  .patient-finder-rec .pf-rec-del {
    background: transparent;
    border: none;
    color: var(--danger);
    cursor: pointer;
    font-size: 14px;
    line-height: 1;
    padding: 0 2px;
    opacity: 0.5;
    transition: opacity 0.15s;
  }
  .patient-finder-rec .pf-rec-del:hover { opacity: 1; }
  .pf-btn {
    padding: 5px 10px;
    border-radius: 6px;
    font-size: 11.5px;
    cursor: pointer;
    font-family: inherit;
    border: 1px solid var(--border);
    background: var(--surface);
    color: var(--text);
    transition: all 0.15s;
  }
  .pf-btn-load { background: var(--accent); color: var(--on-accent); border-color: var(--accent); font-weight: 600; }
  .pf-btn-load:hover { background: var(--accent-dark); }
  .pf-btn-export:hover { border-color: var(--accent); color: var(--accent); }

  /* === ПЛАШКИ СТАТУСА (под шапкой) === */
  .status-banners { max-width: 1250px; margin: 0 auto; padding: 0 16px; display: flex; flex-direction: column; gap: 6px; }
  .status-banners:empty { display: none; }
  .status-banner {
    padding: 8px 14px;
    border-radius: 8px;
    font-size: 13px;
    line-height: 1.4;
    border: 1px solid;
  }
  .status-banner.status-info  { background: var(--accent-light); color: var(--accent); border-color: rgba(0,188,212,.3); }
  .status-banner.status-warn  { background: var(--warning-bg, rgba(232,165,71,.15)); color: var(--warning, #E8A547); border-color: var(--warning, #E8A547); }
  .status-banner.status-error { background: rgba(229,115,115,.12); color: var(--danger, #E57373); border-color: var(--danger, #E57373); font-weight: 600; }
  @media print { .status-banners { display: none !important; } }

  /* === Сравнительная таблица «было ↔ стало» (печать) === */
  #printView .pv-comparison h2 { font-size: 10pt; }
  #printView .pv-comp-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 9pt;
    margin-bottom: 4mm;
  }
  #printView .pv-comp-table th,
  #printView .pv-comp-table td {
    border: 0.5pt solid #000;
    padding: 1.5mm 2mm;
    text-align: left;
  }
  #printView .pv-comp-table th {
    background: #f0f0f0;
    font-weight: 700;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }

  /* Блок «Статус пациента» в сайдбаре */
  .sidebar-patient-status:empty { display: none; }
  .side-stat {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 7px 10px;
    margin-bottom: 4px;
    border-radius: 6px;
    font-size: 12.5px;
    border: 1px solid;
  }
  .side-stat-icon { flex-shrink: 0; font-size: 14px; }
  .side-stat-label { color: var(--text-sec); flex-shrink: 0; }
  .side-stat-value { font-weight: 600; margin-left: auto; }
  .side-stat-info { background: var(--accent-light); color: var(--accent); border-color: rgba(0,188,212,.30); }
  .side-stat-warn { background: var(--warning-bg); color: var(--warning); border-color: var(--warning); }
  .side-stat-error { background: var(--danger-bg); color: var(--danger); border-color: var(--danger); font-weight: 600; }

  body.light-theme .side-stat-info { background: var(--accent-light); color: var(--accent-dark); border-color: var(--accent); }
  body.light-theme .side-stat-warn { background: var(--warning-bg); color: var(--warning); border-color: var(--warning); }
  body.light-theme .side-stat-error { background: var(--danger-bg); color: var(--danger); border-color: var(--danger); }

  /* Settings: пункт «11. История» виден только в режиме проверки */
  .modal-body label.setting.checkup-only-setting { display: none; }
  body.mode-checkup .modal-body label.setting.checkup-only-setting { display: flex; }
