/* Self-hosted Inter (variable, 100–900). Относительные url работают и на экране (css в /),
   и в PDF (pdf.js задаёт <base href="http://127.0.0.1:PORT/">). */
@font-face{font-family:'Inter';font-style:normal;font-weight:100 900;font-display:swap;
  src:url('cdn/fonts/inter-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:'Inter';font-style:normal;font-weight:100 900;font-display:swap;
  src:url('cdn/fonts/inter-cyrillic.woff2') format('woff2');
  unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}
@font-face{font-family:'Inter';font-style:normal;font-weight:100 900;font-display:swap;
  src:url('cdn/fonts/inter-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:'Inter';font-style:normal;font-weight:100 900;font-display:swap;
  src:url('cdn/fonts/inter-latin.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}

/* ===== Контейнер документа (бывший body) ===== */
.amx-doc{
  /* палитра */
  --teal:#008d80;          /* акцент */
  --teal-deep:#005e56;     /* глубокий для градиента */
  --teal-2:#00a896;
  --mint:#eaf4f3;          /* дополнительный */
  --mint-line:#cfe6e2;
  --rule:#9cc6c0;          /* линия для рукописного поля */
  --ink:#1c2e2b;
  --muted:#5f736f;
  --line:#e3ece9;
  --paper:#fff;
  --bg:#e9eeed;

  background:var(--bg);
  font-family:'Inter',system-ui,Arial,sans-serif;
  color:var(--ink);
  font-size:13.5px;          /* единый базовый размер: «сырые» p/ul/span/li не крупнее текста amx-классов */
  -webkit-font-smoothing:antialiased;
  line-height:1.62;
  padding:32px 0;
  text-align:left;
}
/* локальный reset — только внутри контейнера */
.amx-doc *{box-sizing:border-box;margin:0;padding:0}
.amx-doc svg{display:block}
/* «сырые» теги без amx-классов — единая типографика, чтобы не выбивались по размеру/жирности */
.amx-doc p,.amx-doc li,.amx-doc span{font-size:13.5px}
.amx-doc b,.amx-doc strong{font-weight:600}

.amx-doc .amx-page{width:210mm;max-width:100%;min-height:297mm;background:var(--paper);
  margin:0 auto 30px;box-shadow:0 18px 60px rgba(0,60,54,.16);position:relative}
/* обрезка нужна только там, где есть крупный декор (вотермарк/призрачная цифра) */
.amx-doc .amx-cover,.amx-doc .amx-sign-page,.amx-doc .amx-divider{overflow:hidden}
/* «осиротевший» блок вне страницы (напр. callout, вынесенный дизайнером) — центрируем как страницу, чтобы не уезжал */
.amx-doc > .amx-callout{width:210mm;max-width:100%;margin:0 auto 30px}
.amx-doc .amx-ic{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.6;
  stroke-linecap:round;stroke-linejoin:round}

/* ===================== ОБЛОЖКА ===================== */
.amx-doc .amx-cover{display:flex;flex-direction:column;
  background:linear-gradient(150deg,var(--teal-deep),var(--teal));color:#fff}
.amx-doc .amx-cover-top{padding:30mm 24mm 26mm;position:relative;overflow:hidden}
.amx-doc .amx-cover-top .amx-wm{position:absolute;right:-20mm;top:-10mm;width:140mm;height:140mm;opacity:.08;color:#fff}
.amx-doc .amx-brand{display:flex;align-items:center;gap:11px;font-weight:700;letter-spacing:.14em;
  font-size:12.5px;text-transform:uppercase}
.amx-doc .amx-brand .amx-mark{width:30px;height:30px;border-radius:8px;background:#fff;color:var(--teal);
  display:grid;place-items:center;font-weight:800;font-size:18px}
.amx-doc .amx-doc-kind{margin-top:40mm;font-size:12px;letter-spacing:.34em;text-transform:uppercase;opacity:.78}
.amx-doc .amx-cover-title{font-weight:800;font-size:50px;line-height:1.05;margin-top:12px;letter-spacing:-.5px}
.amx-doc .amx-cover-title .amx-cover-sub{display:block;font-size:20px;font-weight:600;opacity:.82;margin-top:12px;letter-spacing:0}
.amx-doc .amx-accent-line{width:62mm;height:2px;background:#fff;opacity:.55;margin-top:22px}

.amx-doc .amx-cover-bottom{padding:20mm 24mm 0;flex:1;display:flex;flex-direction:column}
.amx-doc .amx-cover-foot{margin-top:auto;padding:0 0 22mm;display:flex;justify-content:space-between;
  align-items:flex-end;color:rgba(255,255,255,.78);font-size:12px}
.amx-doc .amx-cover-foot .amx-seal{font-weight:800;font-size:20px;letter-spacing:-.3px;color:#fff}

/* ===================== ОБЩЕЕ ДЛЯ КОНТЕНТНЫХ СТР. ===================== */
.amx-doc .amx-content{padding:20mm 22mm 24mm}
.amx-doc .amx-run-head{display:flex;justify-content:space-between;align-items:center;
  border-bottom:1px solid var(--line);padding-bottom:10px;margin-bottom:22px;
  font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.amx-doc .amx-run-head b{color:var(--teal)}

/* ===================== РУКОВОДСТВО ===================== */
.amx-doc .amx-guide-h{display:flex;align-items:center;gap:14px;margin-bottom:8px}
.amx-doc .amx-guide-h .amx-gic{width:42px;height:42px;border-radius:11px;background:var(--mint);color:var(--teal);
  display:grid;place-items:center;flex:none}
.amx-doc .amx-guide-h .amx-guide-title{font-size:28px;font-weight:800;letter-spacing:-.5px}
.amx-doc .amx-guide-lead{color:var(--muted);font-size:14px;margin-bottom:22px;max-width:150mm}

.amx-doc .amx-gcard{border:1px solid var(--line);border-radius:14px;padding:18px 20px;margin-bottom:16px}
.amx-doc .amx-gcard-h{font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:var(--teal);
  font-weight:700;margin-bottom:14px;display:flex;align-items:center;gap:9px}
.amx-doc .amx-gcard-h .amx-ic{width:18px;height:18px}

.amx-doc .amx-legend-row{display:flex;gap:18px;align-items:center}
.amx-doc .amx-legend-demo{flex:1}
.amx-doc .amx-legend-arrow{color:var(--teal);flex:none}
.amx-doc .amx-legend-text{flex:1.1;font-size:13.5px;color:#33433f}
.amx-doc .amx-legend-text b{color:var(--ink)}

.amx-doc .amx-checklist{list-style:none;display:grid;grid-template-columns:1fr;gap:9px}
.amx-doc .amx-checklist li{display:flex;gap:10px;font-size:13.5px;align-items:flex-start}
.amx-doc .amx-checklist li .amx-ic{width:18px;height:18px;color:var(--teal);flex:none;margin-top:2px}

.amx-doc .amx-steps{display:grid;gap:13px}
/* шаг: заголовок (бейдж-номер + текст) сверху, описание под ним — НЕ в строку */
.amx-doc .amx-step{display:block}
.amx-doc .amx-step .amx-num{flex:none;width:28px;height:28px;border-radius:50%;
  background:var(--teal);color:#fff;display:grid;place-items:center;font-size:13px;font-weight:700}
.amx-doc .amx-step .amx-st-t{font-weight:700;font-size:14px;display:flex;align-items:center;gap:11px}
.amx-doc .amx-step .amx-st-d{font-size:13px;color:var(--muted);margin:3px 0 0 39px}

/* ===================== ПУНКТЫ ДОГОВОРА ===================== */
.amx-doc .amx-preamble{font-size:13.5px;color:#2b3a37;margin-bottom:8px}
.amx-doc .amx-sec{margin-bottom:26px;break-inside:avoid;position:relative}
/* обложка раздела: бейдж-номер + крупное название + акцентная линия снизу */
.amx-doc .amx-sec-h{display:flex;align-items:center;gap:14px;margin-bottom:16px;
  padding-bottom:13px;border-bottom:2px solid var(--mint-line)}
.amx-doc .amx-sec-h .amx-sic{width:38px;height:38px;border-radius:10px;background:var(--mint);color:var(--teal);
  display:grid;place-items:center;flex:none}
.amx-doc .amx-sec-h .amx-sic .amx-ic{width:20px;height:20px}
.amx-doc .amx-sec-no{flex:none;width:38px;height:38px;border-radius:10px;line-height:1;
  background:linear-gradient(150deg,var(--teal-deep),var(--teal));color:#fff;
  display:grid;place-items:center;font-size:17px;font-weight:800}
.amx-doc .amx-sec-t{font-size:19px;font-weight:800;letter-spacing:-.2px;flex:1}
.amx-doc .amx-sec-rule{display:none}
.amx-doc .amx-sec > .amx-cl,
.amx-doc .amx-sec > .amx-signs{margin-left:0}
.amx-doc .amx-sec > .amx-callout,
.amx-doc .amx-sec > .amx-fillblock{margin-left:44px}
.amx-doc .amx-cl{display:flex;flex-wrap:wrap;gap:5px 12px;margin:7px 0;font-size:13.5px;color:#2b3a37}
.amx-doc .amx-cl .amx-n{color:var(--teal);font-weight:700;min-width:32px;white-space:nowrap}
/* текст пункта рядом с номером (flex-basis 0 — не переносится под номер при длинном тексте) */
.amx-doc .amx-cl > span:not(.amx-n){flex:1 1 0;min-width:0}
/* вложенный список — НЕ сбоку от текста, а на отдельной строке во всю ширину, с отступом под текст */
.amx-doc .amx-cl > .amx-cl-list{flex:1 0 100%;margin:3px 0 1px 44px}
.amx-doc .amx-cl.amx-sub{margin-left:44px}
.amx-doc .amx-cl.amx-sub .amx-n{min-width:40px;font-weight:600}
.amx-doc .amx-cl-list{list-style:none;margin:7px 0 1px;display:grid;gap:6px}
.amx-doc .amx-cl-list li{position:relative;padding-left:18px;font-size:13.5px;color:#2b3a37;line-height:1.55}
.amx-doc .amx-cl-list li::before{content:"";position:absolute;left:0;top:9px;width:9px;height:1.6px;
  background:var(--teal);border-radius:2px}
/* список с SVG-галочками (например «что подготовить»): выравниваем иконку, убираем маркер-тире */
.amx-doc .amx-cl-list li:has(svg),.amx-doc .amx-checklist li{display:flex;gap:10px;align-items:flex-start;padding-left:0}
.amx-doc .amx-cl-list li:has(svg)::before{display:none}
.amx-doc .amx-cl-list li > svg,.amx-doc .amx-cl-list li > .amx-ic,
.amx-doc .amx-checklist li > svg,.amx-doc .amx-checklist li > .amx-ic{
  width:17px;height:17px;color:var(--teal);flex:none;margin-top:2px}

/* --- highlight ключевого пункта --- */
.amx-doc .amx-callout > div{min-width:0;overflow-wrap:anywhere}
.amx-doc .amx-callout{display:flex;gap:13px;align-items:flex-start;max-width:100%;background:var(--mint);
  border-left:3px solid var(--teal);border-radius:10px;padding:13px 16px;margin:13px 0}
.amx-doc .amx-callout .amx-ic{width:22px;height:22px;color:var(--teal);flex:none;margin-top:1px}
.amx-doc .amx-callout .amx-lbl{font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--teal);font-weight:700}
.amx-doc .amx-callout .amx-txt{font-size:13.5px;margin-top:3px}

/* --- БЛОК ПОЛЕЙ ДЛЯ ЗАПОЛНЕНИЯ --- */
.amx-doc .amx-fillblock{background:#fff;border:1px solid var(--line);border-radius:12px;
  padding:16px 18px;margin:14px 0;break-inside:avoid}
.amx-doc .amx-fb-title{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--teal);
  font-weight:700;margin-bottom:8px;display:flex;align-items:center;gap:8px}
.amx-doc .amx-fb-title .amx-ic{width:16px;height:16px}
.amx-doc .amx-fb-row{display:flex;align-items:flex-end;gap:14px;padding:9px 0}
.amx-doc .amx-fb-label{min-width:185px;font-size:13px;font-weight:600;color:#2a3b38;line-height:1.4}
.amx-doc .amx-fb-line{flex:1;border-bottom:1.6px solid var(--rule);height:17px}
/* длинное поле (адрес и т.п.): метка + первая линия в строке, вторая линия — во всю ширину ниже */
.amx-doc .amx-fb-row.amx-fb-multi{flex-wrap:wrap;row-gap:13px}
.amx-doc .amx-fb-row.amx-fb-multi .amx-fb-line:nth-child(n+3){flex:1 0 100%}
.amx-doc .amx-fb-unit{font-size:13px;font-weight:600;color:#2a3b38;white-space:nowrap;align-self:flex-end;padding-bottom:1px}
.amx-doc .amx-fb-note{display:flex;gap:9px;margin-top:13px;padding:11px 13px;background:var(--mint);
  border-radius:10px;font-size:12px;color:var(--muted);line-height:1.5}
.amx-doc .amx-fb-note .amx-ic{width:16px;height:16px;color:var(--teal);flex:none;margin-top:1px}
.amx-doc .amx-fb-note b{color:#33433f;font-weight:600}

/* двухколоночная раскладка внутри блока полей */
.amx-doc .amx-fb-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 28px}
.amx-doc .amx-fb-grid > .amx-fb-row{border-bottom:none;padding:7px 0}
.amx-doc .amx-fb-grid .amx-fb-label{min-width:120px}
.amx-doc .amx-fb-people{display:grid;grid-template-columns:1fr 1fr;margin-top:2px}
.amx-doc .amx-fb-col{padding:0 22px}
.amx-doc .amx-fb-col:first-child{padding-left:0}
.amx-doc .amx-fb-col:last-child{padding-right:0}
.amx-doc .amx-fb-people .amx-fb-col + .amx-fb-col{padding-left:0}
.amx-doc .amx-fb-col-h{font-size:12.5px;font-weight:700;color:var(--ink);margin:2px 0 4px;
  display:flex;align-items:center;gap:8px}
.amx-doc .amx-fb-col-h .amx-ic{width:16px;height:16px;color:var(--teal)}
.amx-doc .amx-fb-col .amx-fb-row{border-bottom:none;padding:7px 0}
.amx-doc .amx-fb-col .amx-fb-label{min-width:100px}
.amx-doc .amx-fb-sub .amx-fb-label{min-width:92px}

/* под-блок (напр. «Паспорт») внутри карточки человека */
.amx-doc .amx-fb-sub{background:#fff;border:1px solid var(--line);border-radius:10px;
  padding:12px 14px;margin-top:10px}
.amx-doc .amx-fb-sub-h{font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--teal);
  font-weight:700;margin-bottom:6px;display:flex;align-items:center;gap:7px}
.amx-doc .amx-fb-sub-h .amx-ic{width:15px;height:15px}
.amx-doc .amx-fb-pair{display:grid;grid-template-columns:1fr 1fr;gap:0 16px}
.amx-doc .amx-fb-pair .amx-fb-row{padding:8px 0}
.amx-doc .amx-fb-pair .amx-fb-label{min-width:46px}

/* --- подписи --- */
.amx-doc .amx-signs{display:grid;grid-template-columns:1fr 1fr;gap:36px;margin-top:14px}
.amx-doc .amx-sign{border-top:2px solid var(--ink);padding-top:10px}
.amx-doc .amx-sign .amx-role{font-weight:700}
.amx-doc .amx-sign .amx-line{margin-top:26px;border-bottom:1.6px solid var(--rule);height:1px}
.amx-doc .amx-sign .amx-cap{font-size:11px;color:var(--muted);margin-top:6px}

/* ===================== ШМУЦТИТУЛ РАЗДЕЛА ===================== */
.amx-doc .amx-divider{display:flex;flex-direction:column;justify-content:center;
  padding:0 24mm;position:relative;overflow:hidden}
.amx-doc .amx-dv-top{position:absolute;top:20mm;left:24mm;right:24mm;display:flex;
  justify-content:space-between;align-items:center;
  font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.amx-doc .amx-dv-top b{color:var(--teal)}
.amx-doc .amx-dv-ghost{position:absolute;right:6mm;top:50%;transform:translateY(-50%);
  font-size:340px;line-height:.78;font-weight:800;color:var(--mint);
  letter-spacing:-12px;z-index:0;user-select:none}
.amx-doc .amx-dv-body{position:relative;z-index:1}
.amx-doc .amx-dv-label{color:var(--teal);font-weight:700;letter-spacing:.2em;
  text-transform:uppercase;font-size:13px}
.amx-doc .amx-dv-title{font-size:44px;font-weight:800;letter-spacing:-1px;line-height:1.06;
  margin-top:12px;max-width:140mm}
.amx-doc .amx-dv-rule{width:54mm;height:3px;background:var(--teal);border-radius:2px;margin:24px 0}
.amx-doc .amx-dv-desc{color:var(--muted);font-size:17px;line-height:1.5;max-width:120mm}
/* объединённая страница: «обложка» сверху + блок подписей снизу */
.amx-doc .amx-sign-page{display:flex;flex-direction:column;padding:40mm 24mm 26mm;position:relative;overflow:hidden}
.amx-doc .amx-sign-head{position:relative;margin-top:auto}
.amx-doc .amx-sign-foot{position:relative;z-index:1;margin-top:auto}
.amx-doc .amx-doc-contacts{position:relative;z-index:1;margin-top:14mm;background:var(--mint);border-radius:14px;
  padding:16px 22px;display:flex;align-items:center;justify-content:space-between;gap:14px 22px;flex-wrap:wrap}
.amx-doc .amx-dc-check{display:flex;align-items:center;gap:10px;font-size:13.5px;color:var(--ink)}
.amx-doc .amx-dc-check .amx-ic{width:22px;height:22px;color:var(--teal);flex:none}
.amx-doc .amx-dc-check b{color:var(--teal)}
.amx-doc .amx-dc-call{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--ink);flex-wrap:wrap}
.amx-doc .amx-dc-call .amx-ic{width:18px;height:18px;color:var(--teal);flex:none}
.amx-doc .amx-dc-phone{font-weight:800;color:var(--teal);text-decoration:none;font-size:13.5px;white-space:nowrap}
.amx-doc .amx-dc-247{color:var(--ink);font-size:13px;white-space:nowrap}

/* На узких экранах НЕ ломаем вёрстку: лист остаётся истинным A4 (210мм), а весь документ
   ужимается по ширине через zoom (см. docStyle в app.js). Только лёгкий внешний отступ. */
@media screen and (max-width:820px){
  .amx-doc{padding:10px 0}
}

/* списки в документе: без двойных браузерных маркеров, выровнены по абзацу */
.amx-doc ul,.amx-doc ol{list-style:none}
.amx-doc .amx-content ul:not(.amx-cl-list):not(.amx-checklist),
.amx-doc .amx-sec ul:not(.amx-cl-list):not(.amx-checklist),
.amx-doc .amx-content ol,.amx-doc .amx-sec ol{margin:7px 0;padding-left:18px}
.amx-doc .amx-content ul:not(.amx-cl-list):not(.amx-checklist) li,
.amx-doc .amx-sec ul:not(.amx-cl-list):not(.amx-checklist) li,
.amx-doc .amx-content ol li,.amx-doc .amx-sec ol li{
  position:relative;font-size:13.5px;color:#2b3a37;line-height:1.55;margin:5px 0;list-style:none}
.amx-doc .amx-content ul:not(.amx-cl-list):not(.amx-checklist) li::before,
.amx-doc .amx-sec ul:not(.amx-cl-list):not(.amx-checklist) li::before{
  content:"—";position:absolute;left:-16px;color:var(--teal)}

/* печать: листы A4, цвета/градиенты печатаются, каждый лист — своя страница */
@media print{
  .amx-doc{background:#fff;padding:0;zoom:1 !important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .amx-doc *{-webkit-print-color-adjust:exact !important;print-color-adjust:exact !important}
  /* высота по контенту: переполненная страница перетекает на след. лист, а не обрезается */
  .amx-doc .amx-page{width:210mm;max-width:210mm;min-height:auto;box-shadow:none;margin:0 auto;
    page-break-after:always;break-after:page;page-break-inside:auto}
  .amx-doc .amx-page:last-child{page-break-after:auto;break-after:auto}
  /* обложка, шмуцтитулы разделов и страница подписей — полноценные A4-листы на всю высоту */
  .amx-doc .amx-cover,.amx-doc .amx-divider,.amx-doc .amx-sign-page{height:297mm;min-height:297mm;overflow:hidden}
  /* атомарные блоки не рвём между листами */
  .amx-doc .amx-sec,.amx-doc .amx-callout,.amx-doc .amx-fillblock,
  .amx-doc .amx-fb-people,.amx-doc .amx-fb-sub,.amx-doc .amx-step{
    page-break-inside:avoid;break-inside:avoid}
}
